diff options
author | Joas Schilling <coding@schilljs.com> | 2019-02-11 13:04:27 +0100 |
---|---|---|
committer | Julius Härtl <jus@bitgrid.net> | 2019-03-01 20:56:19 +0100 |
commit | a8a547240124c8b64e2f4cc0c4b4f5cd3aed41c5 (patch) | |
tree | a16752f25612143c46c9138f9fa659a42d966b56 /lib/private/Collaboration | |
parent | 59c92a75139b9db1cc1171f41bac971c2c528873 (diff) | |
download | nextcloud-server-a8a547240124c8b64e2f4cc0c4b4f5cd3aed41c5.tar.gz nextcloud-server-a8a547240124c8b64e2f4cc0c4b4f5cd3aed41c5.zip |
Improve searchCollections()
* Search ignores collection where we know the user can not access them
* If we filtered all results, we start over with a bigger offset
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib/private/Collaboration')
-rw-r--r-- | lib/private/Collaboration/Resources/Manager.php | 26 |
1 files changed, 20 insertions, 6 deletions
diff --git a/lib/private/Collaboration/Resources/Manager.php b/lib/private/Collaboration/Resources/Manager.php index b7aeb221d88..d26c6b5d141 100644 --- a/lib/private/Collaboration/Resources/Manager.php +++ b/lib/private/Collaboration/Resources/Manager.php @@ -100,7 +100,6 @@ class Manager implements IManager { throw new CollectionException('Collection not found'); } - $access = $row['access'] === null ? null : (bool) $row['access']; if ($user instanceof IUser) { $access = [$user->getUID() => $access]; @@ -120,23 +119,38 @@ class Manager implements IManager { */ public function searchCollections(IUser $user, string $filter, int $limit = 50, int $start = 0): array { $query = $this->connection->getQueryBuilder(); - $query->select('*') + $userId = $user instanceof IUser ? $user->getUID() : ''; + + $query->select('c.*', 'a.access') ->from(self::TABLE_COLLECTIONS) - ->where($query->expr()->iLike('name', $query->createNamedParameter($filter, IQueryBuilder::PARAM_STR))) + ->leftJoin( + 'r', self::TABLE_ACCESS_CACHE, 'a', + $query->expr()->andX( + $query->expr()->eq('c.id', 'a.resource_id'), + $query->expr()->eq('a.user_id', $query->createNamedParameter($userId, IQueryBuilder::PARAM_STR)) + ) + ) + ->where($query->expr()->iLike('c.name', $query->createNamedParameter($filter, IQueryBuilder::PARAM_STR))) + ->andWhere($query->expr()->neq('a.access', $query->createNamedParameter(0, IQueryBuilder::PARAM_INT))) ->setMaxResults($limit) ->setFirstResult($start); $result = $query->execute(); $collections = []; - /** TODO: this is a huge performance bottleneck */ + + $foundResults = 0; while ($row = $result->fetch()) { - $collection = new Collection($this, $this->connection, (int)$row['id'], (string)$row['name']); + $foundResults++; + $access = $row['access'] === null ? null : (bool) $row['access']; + $collection = new Collection($this, $this->connection, (int)$row['id'], (string)$row['name'], $user, $access); if ($collection->canAccess($user)) { $collections[] = $collection; } } $result->closeCursor(); - // TODO: call with increased first result if no matches found + if (empty($collections) && $foundResults === $limit) { + $this->searchCollections($user, $filter, $limit, $start + $limit); + } return $collections; } |