diff options
author | Robin Appelman <robin@icewind.nl> | 2016-08-25 15:49:36 +0200 |
---|---|---|
committer | Robin Appelman <robin@icewind.nl> | 2016-08-25 17:22:25 +0200 |
commit | 2693ae870eff6a6aec769c035c200f0b5caf4e6f (patch) | |
tree | c332331085cadc93889ffb8aa733cf6bc6738078 | |
parent | b2d365734a692c6e09a07d0190fdabf64f3a295a (diff) | |
download | nextcloud-server-2693ae870eff6a6aec769c035c200f0b5caf4e6f.tar.gz nextcloud-server-2693ae870eff6a6aec769c035c200f0b5caf4e6f.zip |
cache user folders
-rw-r--r-- | lib/private/Files/Node/Root.php | 42 | ||||
-rw-r--r-- | lib/private/legacy/util.php | 1 | ||||
-rw-r--r-- | tests/lib/TestCase.php | 1 |
3 files changed, 28 insertions, 16 deletions
diff --git a/lib/private/Files/Node/Root.php b/lib/private/Files/Node/Root.php index bad865a7987..e5921206a39 100644 --- a/lib/private/Files/Node/Root.php +++ b/lib/private/Files/Node/Root.php @@ -28,6 +28,7 @@ namespace OC\Files\Node; +use OC\Cache\CappedMemoryCache; use OC\Files\Mount\Manager; use OC\Files\Mount\MountPoint; use OCP\Files\NotFoundException; @@ -71,6 +72,8 @@ class Root extends Folder implements IRootFolder { */ private $user; + private $userFolderCache; + /** * @param \OC\Files\Mount\Manager $manager * @param \OC\Files\View $view @@ -81,6 +84,7 @@ class Root extends Folder implements IRootFolder { $this->mountManager = $manager; $this->user = $user; $this->emitter = new PublicEmitter(); + $this->userFolderCache = new CappedMemoryCache(); } /** @@ -335,25 +339,31 @@ class Root extends Folder implements IRootFolder { * @return \OCP\Files\Folder */ public function getUserFolder($userId) { - \OC\Files\Filesystem::initMountPoints($userId); - $dir = '/' . $userId; - $folder = null; - - try { - $folder = $this->get($dir); - } catch (NotFoundException $e) { - $folder = $this->newFolder($dir); - } + if (!$this->userFolderCache->hasKey($userId)) { + \OC\Files\Filesystem::initMountPoints($userId); + $dir = '/' . $userId; + $folder = null; + + try { + $folder = $this->get($dir); + } catch (NotFoundException $e) { + $folder = $this->newFolder($dir); + } - $dir = '/files'; - try { - $folder = $folder->get($dir); - } catch (NotFoundException $e) { - $folder = $folder->newFolder($dir); - \OC_Util::copySkeleton($userId, $folder); + $dir = '/files'; + try { + $folder = $folder->get($dir); + } catch (NotFoundException $e) { + $folder = $folder->newFolder($dir); + \OC_Util::copySkeleton($userId, $folder); + } + $this->userFolderCache->set($userId, $folder); } - return $folder; + return $this->userFolderCache->get($userId); + } + public function clearCache() { + $this->userFolderCache = new CappedMemoryCache(); } } diff --git a/lib/private/legacy/util.php b/lib/private/legacy/util.php index a975da39271..73c0e2249cb 100644 --- a/lib/private/legacy/util.php +++ b/lib/private/legacy/util.php @@ -356,6 +356,7 @@ class OC_Util { */ public static function tearDownFS() { \OC\Files\Filesystem::tearDown(); + \OC::$server->getRootFolder()->clearCache(); self::$fsSetup = false; self::$rootMounted = false; } diff --git a/tests/lib/TestCase.php b/tests/lib/TestCase.php index 514cb6ea3a5..b9b18c644fd 100644 --- a/tests/lib/TestCase.php +++ b/tests/lib/TestCase.php @@ -24,6 +24,7 @@ namespace Test; use DOMDocument; use DOMNode; +use OC\Cache\CappedMemoryCache; use OC\Command\QueueBus; use OC\Files\Filesystem; use OC\Template\Base; |