|
12 | 12 | use OCP\Files\Search\ISearchComparison;
|
13 | 13 | use OCP\Files\Search\ISearchOperator;
|
14 | 14 | use OCP\Files\Search\ISearchOrder;
|
| 15 | +use OCP\FilesMetadata\IFilesMetadataManager; |
15 | 16 | use OCP\FilesMetadata\IMetadataQuery;
|
16 | 17 |
|
17 | 18 | /**
|
@@ -80,13 +81,10 @@ class SearchBuilder {
|
80 | 81 |
|
81 | 82 | public const TAG_FAVORITE = '_$!<Favorite>!$_';
|
82 | 83 |
|
83 |
| - /** @var IMimeTypeLoader */ |
84 |
| - private $mimetypeLoader; |
85 |
| - |
86 | 84 | public function __construct(
|
87 |
| - IMimeTypeLoader $mimetypeLoader, |
| 85 | + private IMimeTypeLoader $mimetypeLoader, |
| 86 | + private IFilesMetadataManager $filesMetadataManager, |
88 | 87 | ) {
|
89 |
| - $this->mimetypeLoader = $mimetypeLoader; |
90 | 88 | }
|
91 | 89 |
|
92 | 90 | /**
|
@@ -285,11 +283,18 @@ private function validateComparison(ISearchComparison $operator) {
|
285 | 283 |
|
286 | 284 |
|
287 | 285 | private function getExtraOperatorField(ISearchComparison $operator, IMetadataQuery $metadataQuery): array {
|
288 |
| - $paramType = self::$fieldTypes[$operator->getField()]; |
289 | 286 | $field = $operator->getField();
|
290 | 287 | $value = $operator->getValue();
|
291 | 288 | $type = $operator->getType();
|
292 | 289 |
|
| 290 | + $knownMetadata = $this->filesMetadataManager->getKnownMetadata(); |
| 291 | + $isIndex = $knownMetadata->isIndex($field); |
| 292 | + $paramType = $knownMetadata->getType($field) === 'int' ? 'integer' : 'string'; |
| 293 | + |
| 294 | + if (!$isIndex) { |
| 295 | + throw new \InvalidArgumentException('Cannot search non indexed metadata key'); |
| 296 | + } |
| 297 | + |
293 | 298 | switch ($operator->getExtra()) {
|
294 | 299 | case IMetadataQuery::EXTRA:
|
295 | 300 | $metadataQuery->joinIndex($field); // join index table if not joined yet
|
|
0 commit comments