diff options
author | Louis Chemineau <louis@chmn.me> | 2025-01-20 13:45:33 +0100 |
---|---|---|
committer | Louis Chemineau <louis@chmn.me> | 2025-01-27 13:03:49 +0100 |
commit | 840ee6d59a4121d0e03cd10ce8b148648ca8699f (patch) | |
tree | 877a020092432575785cbcf1dd2c8184d7a701a7 /lib/private | |
parent | 5c8f529284bef59bfcc2f81ca2cbf6be7ded1276 (diff) | |
download | nextcloud-server-840ee6d59a4121d0e03cd10ce8b148648ca8699f.tar.gz nextcloud-server-840ee6d59a4121d0e03cd10ce8b148648ca8699f.zip |
fix: Metadata field searchbackport/50273/stable29
Signed-off-by: Louis Chemineau <louis@chmn.me>
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/Files/Cache/SearchBuilder.php | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/lib/private/Files/Cache/SearchBuilder.php b/lib/private/Files/Cache/SearchBuilder.php index e8063b77aa5..1ba1aa5be96 100644 --- a/lib/private/Files/Cache/SearchBuilder.php +++ b/lib/private/Files/Cache/SearchBuilder.php @@ -33,6 +33,7 @@ use OCP\Files\Search\ISearchBinaryOperator; use OCP\Files\Search\ISearchComparison; use OCP\Files\Search\ISearchOperator; use OCP\Files\Search\ISearchOrder; +use OCP\FilesMetadata\IFilesMetadataManager; use OCP\FilesMetadata\IMetadataQuery; /** @@ -101,13 +102,10 @@ class SearchBuilder { public const TAG_FAVORITE = '_$!<Favorite>!$_'; - /** @var IMimeTypeLoader */ - private $mimetypeLoader; - public function __construct( - IMimeTypeLoader $mimetypeLoader + private IMimeTypeLoader $mimetypeLoader, + private IFilesMetadataManager $filesMetadataManager, ) { - $this->mimetypeLoader = $mimetypeLoader; } /** @@ -306,11 +304,18 @@ class SearchBuilder { private function getExtraOperatorField(ISearchComparison $operator, IMetadataQuery $metadataQuery): array { - $paramType = self::$fieldTypes[$operator->getField()]; $field = $operator->getField(); $value = $operator->getValue(); $type = $operator->getType(); + $knownMetadata = $this->filesMetadataManager->getKnownMetadata(); + $isIndex = $knownMetadata->isIndex($field); + $paramType = $knownMetadata->getType($field) === 'int' ? 'integer' : 'string'; + + if (!$isIndex) { + throw new \InvalidArgumentException('Cannot search non indexed metadata key'); + } + switch($operator->getExtra()) { case IMetadataQuery::EXTRA: $metadataQuery->joinIndex($field); // join index table if not joined yet |