summaryrefslogtreecommitdiffstats
path: root/lib/private/Collaboration
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2019-02-11 13:04:27 +0100
committerJulius Härtl <jus@bitgrid.net>2019-03-01 20:56:19 +0100
commita8a547240124c8b64e2f4cc0c4b4f5cd3aed41c5 (patch)
treea16752f25612143c46c9138f9fa659a42d966b56 /lib/private/Collaboration
parent59c92a75139b9db1cc1171f41bac971c2c528873 (diff)
downloadnextcloud-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.php26
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;
}