aboutsummaryrefslogtreecommitdiffstats
path: root/lib/private/Files/Cache/Wrapper/CacheJail.php
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2017-12-04 15:16:39 +0100
committerRobin Appelman <robin@icewind.nl>2017-12-04 15:16:39 +0100
commitc87d6892531c75c7d34bd4493f4569c8ab828c0e (patch)
treef37c99cdb0521c70d90d146dc69b72b72aaddae7 /lib/private/Files/Cache/Wrapper/CacheJail.php
parent567757c793faed6925a538571a9e4f5b8b396bfd (diff)
downloadnextcloud-server-c87d6892531c75c7d34bd4493f4569c8ab828c0e.tar.gz
nextcloud-server-c87d6892531c75c7d34bd4493f4569c8ab828c0e.zip
delay calculating the shared cache root until it's used
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'lib/private/Files/Cache/Wrapper/CacheJail.php')
-rw-r--r--lib/private/Files/Cache/Wrapper/CacheJail.php23
1 files changed, 14 insertions, 9 deletions
diff --git a/lib/private/Files/Cache/Wrapper/CacheJail.php b/lib/private/Files/Cache/Wrapper/CacheJail.php
index f14166ae840..357851bedd5 100644
--- a/lib/private/Files/Cache/Wrapper/CacheJail.php
+++ b/lib/private/Files/Cache/Wrapper/CacheJail.php
@@ -27,6 +27,7 @@
*/
namespace OC\Files\Cache\Wrapper;
+
use OC\Files\Cache\Cache;
use OCP\Files\Cache\ICacheEntry;
use OCP\Files\Search\ISearchQuery;
@@ -49,11 +50,15 @@ class CacheJail extends CacheWrapper {
$this->root = $root;
}
+ protected function getRoot() {
+ return $this->root;
+ }
+
protected function getSourcePath($path) {
if ($path === '') {
- return $this->root;
+ return $this->getRoot();
} else {
- return $this->root . '/' . ltrim($path, '/');
+ return $this->getRoot() . '/' . ltrim($path, '/');
}
}
@@ -62,13 +67,13 @@ class CacheJail extends CacheWrapper {
* @return null|string the jailed path or null if the path is outside the jail
*/
protected function getJailedPath($path) {
- if ($this->root === '') {
+ if ($this->getRoot() === '') {
return $path;
}
- $rootLength = strlen($this->root) + 1;
- if ($path === $this->root) {
+ $rootLength = strlen($this->getRoot()) + 1;
+ if ($path === $this->getRoot()) {
return '';
- } else if (substr($path, 0, $rootLength) === $this->root . '/') {
+ } else if (substr($path, 0, $rootLength) === $this->getRoot() . '/') {
return substr($path, $rootLength);
} else {
return null;
@@ -87,8 +92,8 @@ class CacheJail extends CacheWrapper {
}
protected function filterCacheEntry($entry) {
- $rootLength = strlen($this->root) + 1;
- return ($entry['path'] === $this->root) or (substr($entry['path'], 0, $rootLength) === $this->root . '/');
+ $rootLength = strlen($this->getRoot()) + 1;
+ return ($entry['path'] === $this->getRoot()) or (substr($entry['path'], 0, $rootLength) === $this->getRoot() . '/');
}
/**
@@ -190,7 +195,7 @@ class CacheJail extends CacheWrapper {
* remove all entries for files that are stored on the storage from the cache
*/
public function clear() {
- $this->getCache()->remove($this->root);
+ $this->getCache()->remove($this->getRoot());
}
/**