diff options
author | Joas Schilling <coding@schilljs.com> | 2019-02-07 15:43:20 +0100 |
---|---|---|
committer | Julius Härtl <jus@bitgrid.net> | 2019-03-01 20:56:18 +0100 |
commit | ece471de360ebbebee6b098a20d65042dd69928c (patch) | |
tree | 707fecfce0fce8c9d34c2210e3b656e7e63dabd8 /lib/private/Collaboration/Resources/Collection.php | |
parent | dee6f7f61f0f0d1827ed0555f199d7bce67e67b6 (diff) | |
download | nextcloud-server-ece471de360ebbebee6b098a20d65042dd69928c.tar.gz nextcloud-server-ece471de360ebbebee6b098a20d65042dd69928c.zip |
Start implementing access cache
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib/private/Collaboration/Resources/Collection.php')
-rw-r--r-- | lib/private/Collaboration/Resources/Collection.php | 18 |
1 files changed, 13 insertions, 5 deletions
diff --git a/lib/private/Collaboration/Resources/Collection.php b/lib/private/Collaboration/Resources/Collection.php index 5770e8918fd..c538580b8f8 100644 --- a/lib/private/Collaboration/Resources/Collection.php +++ b/lib/private/Collaboration/Resources/Collection.php @@ -46,6 +46,9 @@ class Collection implements ICollection { /** @var string */ protected $name; + /** @var bool|null */ + protected $access; + /** @var IResource[] */ protected $resources; @@ -53,12 +56,14 @@ class Collection implements ICollection { IManager $manager, IDBConnection $connection, int $id, - string $name + string $name, + ?bool $access ) { $this->manager = $manager; $this->connection = $connection; $this->id = $id; $this->name = $name; + $this->access = $access; $this->resources = []; } @@ -161,13 +166,16 @@ class Collection implements ICollection { * @since 16.0.0 */ public function canAccess(IUser $user = null): bool { - foreach ($this->getResources() as $resource) { - if ($resource->canAccess($user)) { - return true; + if ($this->access === null) { + $this->access = false; + foreach ($this->getResources() as $resource) { + if ($resource->canAccess($user)) { + $this->access = true; + } } } - return false; + return $this->access; } protected function isSameResource(IResource $resource1, IResource $resource2): bool { |