mirror of
https://github.com/nextcloud/server.git
synced 2026-02-20 00:12:30 -05:00
refactor: remove where specification from SELECT getter
- search constraints are now fully in control of SystemTagsInFilesDetector::detectAssignedSystemTagsIn(), avoids duplication of a WHERE statement Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
This commit is contained in:
parent
dbfd2f936a
commit
df662f50bd
3 changed files with 8 additions and 7 deletions
|
|
@ -55,7 +55,6 @@ class CacheQueryBuilder extends QueryBuilder {
|
|||
$this->expr()->eq('systemtag.id', 'systemtagmap.systemtagid'),
|
||||
$this->expr()->eq('systemtag.visibility', $this->createNamedParameter(true))
|
||||
))
|
||||
->where($this->expr()->like('systemtag.name', $this->createNamedParameter('_%')))
|
||||
->groupBy('systemtag.name', 'systemtag.id', 'systemtag.visibility', 'systemtag.editable');
|
||||
|
||||
return $this;
|
||||
|
|
|
|||
|
|
@ -35,7 +35,6 @@ use OCP\Files\Cache\ICache;
|
|||
use OCP\Files\Cache\ICacheEntry;
|
||||
use OCP\Files\Folder;
|
||||
use OCP\Files\IMimeTypeLoader;
|
||||
use OCP\Files\IRootFolder;
|
||||
use OCP\Files\Mount\IMountPoint;
|
||||
use OCP\Files\Search\ISearchBinaryOperator;
|
||||
use OCP\Files\Search\ISearchQuery;
|
||||
|
|
@ -228,5 +227,4 @@ class QuerySearchHelper {
|
|||
|
||||
return [$caches, $mountByMountPoint];
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
|
|
@ -28,9 +28,11 @@ namespace OC\SystemTag;
|
|||
|
||||
use OC\Files\Cache\QuerySearchHelper;
|
||||
use OC\Files\Node\Root;
|
||||
use OC\Files\Search\SearchBinaryOperator;
|
||||
use OC\Files\Search\SearchComparison;
|
||||
use OC\Files\Search\SearchQuery;
|
||||
use OCP\Files\Folder;
|
||||
use OCP\Files\Search\ISearchBinaryOperator;
|
||||
use OCP\Files\Search\ISearchComparison;
|
||||
|
||||
class SystemTagsInFilesDetector {
|
||||
|
|
@ -43,13 +45,15 @@ class SystemTagsInFilesDetector {
|
|||
int $limit = 0,
|
||||
int $offset = 0
|
||||
): array {
|
||||
$operator = new SearchComparison(ISearchComparison::COMPARE_LIKE, 'systemtag', '%');
|
||||
// Currently query has to have exactly one search condition. If no media type is provided,
|
||||
// we fall back to the presence of a system tag.
|
||||
if (empty($filteredMediaType)) {
|
||||
$query = new SearchQuery(new SearchComparison(ISearchComparison::COMPARE_LIKE, 'systemtag', '%'), $limit, $offset, []);
|
||||
} else {
|
||||
$query = new SearchQuery(new SearchComparison(ISearchComparison::COMPARE_LIKE, 'mimetype', $filteredMediaType . '/%'), $limit, $offset, []);
|
||||
if ($filteredMediaType !== '') {
|
||||
$mimeOperator = new SearchComparison(ISearchComparison::COMPARE_LIKE, 'mimetype', $filteredMediaType . '/%');
|
||||
$operator = new SearchBinaryOperator(ISearchBinaryOperator::OPERATOR_AND, [$operator, $mimeOperator]);
|
||||
}
|
||||
|
||||
$query = new SearchQuery($operator, $limit, $offset, []);
|
||||
[$caches, ] = $this->searchHelper->getCachesAndMountPointsForSearch(
|
||||
$this->getRootFolder($folder),
|
||||
$folder->getPath(),
|
||||
|
|
|
|||
Loading…
Reference in a new issue