summaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2021-03-18 16:22:29 +0100
committerbackportbot[bot] <backportbot[bot]@users.noreply.github.com>2021-03-23 13:41:10 +0000
commit680e21b7c5afd62397eae03f7e934c5282ffb068 (patch)
tree51245b9907c8774c4f3c0623cdc89ca6113d982e /apps
parentc60f0e06d0063ddd902404fd351e1f367c7e0dc7 (diff)
downloadnextcloud-server-680e21b7c5afd62397eae03f7e934c5282ffb068.tar.gz
nextcloud-server-680e21b7c5afd62397eae03f7e934c5282ffb068.zip
use "newer" node search api directly in unified search
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'apps')
-rw-r--r--apps/files/lib/Search/FilesSearchProvider.php73
1 files changed, 42 insertions, 31 deletions
diff --git a/apps/files/lib/Search/FilesSearchProvider.php b/apps/files/lib/Search/FilesSearchProvider.php
index 1c4bc75ade7..180ce45ce09 100644
--- a/apps/files/lib/Search/FilesSearchProvider.php
+++ b/apps/files/lib/Search/FilesSearchProvider.php
@@ -29,10 +29,13 @@ declare(strict_types=1);
namespace OCA\Files\Search;
-use OC\Search\Provider\File;
-use OC\Search\Result\File as FileResult;
+use OC\Files\Search\SearchComparison;
+use OC\Files\Search\SearchQuery;
+use OCP\Files\FileInfo;
use OCP\Files\IMimeTypeDetector;
use OCP\Files\IRootFolder;
+use OCP\Files\Search\ISearchComparison;
+use OCP\Files\Node;
use OCP\IL10N;
use OCP\IURLGenerator;
use OCP\IUser;
@@ -43,9 +46,6 @@ use OCP\Search\SearchResultEntry;
class FilesSearchProvider implements IProvider {
- /** @var File */
- private $fileSearch;
-
/** @var IL10N */
private $l10n;
@@ -58,13 +58,13 @@ class FilesSearchProvider implements IProvider {
/** @var IRootFolder */
private $rootFolder;
- public function __construct(File $fileSearch,
- IL10N $l10n,
- IURLGenerator $urlGenerator,
- IMimeTypeDetector $mimeTypeDetector,
- IRootFolder $rootFolder) {
+ public function __construct(
+ IL10N $l10n,
+ IURLGenerator $urlGenerator,
+ IMimeTypeDetector $mimeTypeDetector,
+ IRootFolder $rootFolder
+ ) {
$this->l10n = $l10n;
- $this->fileSearch = $fileSearch;
$this->urlGenerator = $urlGenerator;
$this->mimeTypeDetector = $mimeTypeDetector;
$this->rootFolder = $rootFolder;
@@ -99,29 +99,40 @@ class FilesSearchProvider implements IProvider {
* @inheritDoc
*/
public function search(IUser $user, ISearchQuery $query): SearchResult {
-
- // Make sure we setup the users filesystem
- $this->rootFolder->getUserFolder($user->getUID());
+ $userFolder = $this->rootFolder->getUserFolder($user->getUID());
+ $fileQuery = new SearchQuery(
+ new SearchComparison(ISearchComparison::COMPARE_LIKE, 'name', '%' . $query->getTerm() . '%'),
+ $query->getLimit(),
+ (int)$query->getCursor(),
+ [],
+ $user
+ );
return SearchResult::paginated(
$this->l10n->t('Files'),
- array_map(function (FileResult $result) {
+ array_map(function (Node $result) use ($userFolder) {
// Generate thumbnail url
- $thumbnailUrl = $result->has_preview
- ? $this->urlGenerator->linkToRouteAbsolute('core.Preview.getPreviewByFileId', ['x' => 32, 'y' => 32, 'fileId' => $result->id])
- : '';
+ $thumbnailUrl = $this->urlGenerator->linkToRouteAbsolute('core.Preview.getPreviewByFileId', ['x' => 32, 'y' => 32, 'fileId' => $result->getId()]);
+ $path = $userFolder->getRelativePath($result->getPath());
+ $link = $this->urlGenerator->linkToRoute(
+ 'files.view.index',
+ [
+ 'dir' => dirname($path),
+ 'scrollto' => $result->getName(),
+ ]
+ );
$searchResultEntry = new SearchResultEntry(
$thumbnailUrl,
- $result->name,
- $this->formatSubline($result),
- $this->urlGenerator->getAbsoluteURL($result->link),
- $result->type === 'folder' ? 'icon-folder' : $this->mimeTypeDetector->mimeTypeIcon($result->mime_type)
+ $result->getName(),
+ $this->formatSubline($path),
+ $this->urlGenerator->getAbsoluteURL($link),
+ $result->getMimetype() === FileInfo::MIMETYPE_FOLDER ? 'icon-folder' : $this->mimeTypeDetector->mimeTypeIcon($result->getMimetype())
);
- $searchResultEntry->addAttribute('fileId', (string)$result->id);
- $searchResultEntry->addAttribute('path', $result->path);
+ $searchResultEntry->addAttribute('fileId', (string)$result->getId());
+ $searchResultEntry->addAttribute('path', $path);
return $searchResultEntry;
- }, $this->fileSearch->search($query->getTerm(), $query->getLimit(), (int)$query->getCursor())),
+ }, $userFolder->search($fileQuery)),
$query->getCursor() + $query->getLimit()
);
}
@@ -129,16 +140,16 @@ class FilesSearchProvider implements IProvider {
/**
* Format subline for files
*
- * @param FileResult $result
+ * @param string $path
* @return string
*/
- private function formatSubline($result): string {
+ private function formatSubline(string $path): string {
// Do not show the location if the file is in root
- if ($result->path === '/' . $result->name) {
+ if (strrpos($path, '/') > 0) {
+ $path = ltrim(dirname($path), '/');
+ return $this->l10n->t('in %s', [$path]);
+ } else {
return '';
}
-
- $path = ltrim(dirname($result->path), '/');
- return $this->l10n->t('in %s', [$path]);
}
}