Call private cache methods only for OC\Files\Cache\Cache

The two implementation detail methods `correctFolderSize` and
`calculateFolderSize` should only be called for instances of
`OC\Files\Cache\Cache`. This commit adds guarding checks
whenever they are called.
This commit is contained in:
Daniel Jagszent 2016-04-15 17:33:02 +02:00
parent 63a385d2b8
commit 5a0938ad8e
5 changed files with 34 additions and 10 deletions

View file

@ -469,7 +469,7 @@ class Scanner extends BasicEmitter implements IScanner {
try { try {
$callback(); $callback();
\OC_Hook::emit('Scanner', 'correctFolderSize', array('path' => $path)); \OC_Hook::emit('Scanner', 'correctFolderSize', array('path' => $path));
if ($this->cacheActive) { if ($this->cacheActive && $this->cache instanceof Cache) {
$this->cache->correctFolderSize($path); $this->cache->correctFolderSize($path);
} }
} catch (\OCP\Files\StorageInvalidException $e) { } catch (\OCP\Files\StorageInvalidException $e) {

View file

@ -123,7 +123,9 @@ class Updater implements IUpdater {
} else { } else {
// scanner didn't provide size info, fallback to full size calculation // scanner didn't provide size info, fallback to full size calculation
$sizeDifference = 0; $sizeDifference = 0;
$this->cache->correctFolderSize($path, $data); if ($this->cache instanceof Cache) {
$this->cache->correctFolderSize($path, $data);
}
} }
$this->correctParentStorageMtime($path); $this->correctParentStorageMtime($path);
$this->propagator->propagateChange($path, $time, $sizeDifference); $this->propagator->propagateChange($path, $time, $sizeDifference);
@ -145,7 +147,9 @@ class Updater implements IUpdater {
} }
$this->cache->remove($path); $this->cache->remove($path);
$this->cache->correctFolderSize($parent); if ($this->cache instanceof Cache) {
$this->cache->correctFolderSize($parent);
}
$this->correctParentStorageMtime($path); $this->correctParentStorageMtime($path);
$this->propagator->propagateChange($path, time()); $this->propagator->propagateChange($path, time());
} }
@ -187,8 +191,12 @@ class Updater implements IUpdater {
$this->cache->update($fileId, ['mimetype' => $mimeType]); $this->cache->update($fileId, ['mimetype' => $mimeType]);
} }
$sourceCache->correctFolderSize($source); if ($sourceCache instanceof Cache) {
$this->cache->correctFolderSize($target); $sourceCache->correctFolderSize($source);
}
if ($this->cache instanceof Cache) {
$this->cache->correctFolderSize($target);
}
if ($sourceUpdater instanceof Updater) { if ($sourceUpdater instanceof Updater) {
$sourceUpdater->correctParentStorageMtime($source); $sourceUpdater->correctParentStorageMtime($source);
} }

View file

@ -106,7 +106,9 @@ class Watcher implements IWatcher {
if ($cachedData['mimetype'] === 'httpd/unix-directory') { if ($cachedData['mimetype'] === 'httpd/unix-directory') {
$this->cleanFolder($path); $this->cleanFolder($path);
} }
$this->cache->correctFolderSize($path); if ($this->cache instanceof Cache) {
$this->cache->correctFolderSize($path);
}
} }
/** /**

View file

@ -23,6 +23,7 @@
*/ */
namespace OC\Files\Cache\Wrapper; namespace OC\Files\Cache\Wrapper;
use OC\Files\Cache\Cache;
/** /**
* Jail to a subdirectory of the wrapped cache * Jail to a subdirectory of the wrapped cache
@ -233,7 +234,9 @@ class CacheJail extends CacheWrapper {
* @param array $data (optional) meta data of the folder * @param array $data (optional) meta data of the folder
*/ */
public function correctFolderSize($path, $data = null) { public function correctFolderSize($path, $data = null) {
$this->cache->correctFolderSize($this->getSourcePath($path), $data); if ($this->cache instanceof Cache) {
$this->cache->correctFolderSize($this->getSourcePath($path), $data);
}
} }
/** /**
@ -244,7 +247,12 @@ class CacheJail extends CacheWrapper {
* @return int * @return int
*/ */
public function calculateFolderSize($path, $entry = null) { public function calculateFolderSize($path, $entry = null) {
return $this->cache->calculateFolderSize($this->getSourcePath($path), $entry); if ($this->cache instanceof Cache) {
return $this->cache->calculateFolderSize($this->getSourcePath($path), $entry);
} else {
return 0;
}
} }
/** /**

View file

@ -240,7 +240,9 @@ class CacheWrapper extends Cache {
* @param array $data (optional) meta data of the folder * @param array $data (optional) meta data of the folder
*/ */
public function correctFolderSize($path, $data = null) { public function correctFolderSize($path, $data = null) {
$this->cache->correctFolderSize($path, $data); if ($this->cache instanceof Cache) {
$this->cache->correctFolderSize($path, $data);
}
} }
/** /**
@ -251,7 +253,11 @@ class CacheWrapper extends Cache {
* @return int * @return int
*/ */
public function calculateFolderSize($path, $entry = null) { public function calculateFolderSize($path, $entry = null) {
return $this->cache->calculateFolderSize($path, $entry); if ($this->cache instanceof Cache) {
return $this->cache->calculateFolderSize($path, $entry);
} else {
return 0;
}
} }
/** /**