use node search api for legacy file search endpoint
Signed-off-by: Robin Appelman <robin@icewind.nl>
This commit is contained in:
parent
854697818c
commit
9c046efd2d
|
@ -34,7 +34,6 @@ use OC\DB\QueryBuilder\Literal;
|
||||||
use OC\Files\Search\SearchBinaryOperator;
|
use OC\Files\Search\SearchBinaryOperator;
|
||||||
use OC\Files\Search\SearchComparison;
|
use OC\Files\Search\SearchComparison;
|
||||||
use OC\Files\Search\SearchQuery;
|
use OC\Files\Search\SearchQuery;
|
||||||
use OC\Files\Storage\Wrapper\Jail;
|
|
||||||
use OC\Files\Storage\Storage;
|
use OC\Files\Storage\Storage;
|
||||||
use OCA\Files_Sharing\SharedStorage;
|
use OCA\Files_Sharing\SharedStorage;
|
||||||
use OCP\DB\QueryBuilder\IQueryBuilder;
|
use OCP\DB\QueryBuilder\IQueryBuilder;
|
||||||
|
|
|
@ -28,7 +28,14 @@
|
||||||
|
|
||||||
namespace OC\Search\Provider;
|
namespace OC\Search\Provider;
|
||||||
|
|
||||||
use OC\Files\Filesystem;
|
use OC\Files\Search\SearchComparison;
|
||||||
|
use OC\Files\Search\SearchOrder;
|
||||||
|
use OC\Files\Search\SearchQuery;
|
||||||
|
use OCP\Files\FileInfo;
|
||||||
|
use OCP\Files\IRootFolder;
|
||||||
|
use OCP\Files\Search\ISearchComparison;
|
||||||
|
use OCP\Files\Search\ISearchOrder;
|
||||||
|
use OCP\IUserSession;
|
||||||
use OCP\Search\PagedProvider;
|
use OCP\Search\PagedProvider;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -45,35 +52,38 @@ class File extends PagedProvider {
|
||||||
* @return \OCP\Search\Result[]
|
* @return \OCP\Search\Result[]
|
||||||
*/
|
*/
|
||||||
public function search($query, int $limit = null, int $offset = null) {
|
public function search($query, int $limit = null, int $offset = null) {
|
||||||
if ($offset === null) {
|
/** @var IRootFolder $rootFolder */
|
||||||
$offset = 0;
|
$rootFolder = \OC::$server->query(IRootFolder::class);
|
||||||
|
/** @var IUserSession $userSession */
|
||||||
|
$userSession = \OC::$server->query(IUserSession::class);
|
||||||
|
$user = $userSession->getUser();
|
||||||
|
if (!$user) {
|
||||||
|
return [];
|
||||||
}
|
}
|
||||||
\OC_Util::setupFS();
|
$userFolder = $rootFolder->getUserFolder($user->getUID());
|
||||||
$files = Filesystem::search($query);
|
$fileQuery = new SearchQuery(
|
||||||
|
new SearchComparison(ISearchComparison::COMPARE_LIKE, 'name', '%' . $query . '%'),
|
||||||
|
(int)$limit,
|
||||||
|
(int)$offset,
|
||||||
|
[
|
||||||
|
new SearchOrder(ISearchOrder::DIRECTION_DESCENDING, 'mtime'),
|
||||||
|
],
|
||||||
|
$user
|
||||||
|
);
|
||||||
|
$files = $userFolder->search($fileQuery);
|
||||||
$results = [];
|
$results = [];
|
||||||
if ($limit !== null) {
|
|
||||||
$files = array_slice($files, $offset, $offset + $limit);
|
|
||||||
}
|
|
||||||
// edit results
|
// edit results
|
||||||
foreach ($files as $fileData) {
|
foreach ($files as $fileData) {
|
||||||
// skip versions
|
|
||||||
if (strpos($fileData['path'], '_versions') === 0) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// skip top-level folder
|
|
||||||
if ($fileData['name'] === 'files' && $fileData['parent'] === -1) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// create audio result
|
// create audio result
|
||||||
if ($fileData['mimepart'] === 'audio') {
|
if ($fileData->getMimePart() === 'audio') {
|
||||||
$result = new \OC\Search\Result\Audio($fileData);
|
$result = new \OC\Search\Result\Audio($fileData);
|
||||||
}
|
}
|
||||||
// create image result
|
// create image result
|
||||||
elseif ($fileData['mimepart'] === 'image') {
|
elseif ($fileData->getMimePart() === 'image') {
|
||||||
$result = new \OC\Search\Result\Image($fileData);
|
$result = new \OC\Search\Result\Image($fileData);
|
||||||
}
|
}
|
||||||
// create folder result
|
// create folder result
|
||||||
elseif ($fileData['mimetype'] === 'httpd/unix-directory') {
|
elseif ($fileData->getMimetype() === FileInfo::MIMETYPE_FOLDER) {
|
||||||
$result = new \OC\Search\Result\Folder($fileData);
|
$result = new \OC\Search\Result\Folder($fileData);
|
||||||
}
|
}
|
||||||
// or create file result
|
// or create file result
|
||||||
|
|
|
@ -78,14 +78,13 @@ class File extends \OCP\Search\Result {
|
||||||
public function __construct(FileInfo $data) {
|
public function __construct(FileInfo $data) {
|
||||||
$path = $this->getRelativePath($data->getPath());
|
$path = $this->getRelativePath($data->getPath());
|
||||||
|
|
||||||
$info = pathinfo($path);
|
|
||||||
$this->id = $data->getId();
|
$this->id = $data->getId();
|
||||||
$this->name = $info['basename'];
|
$this->name = $data->getName();
|
||||||
$this->link = \OC::$server->getURLGenerator()->linkToRoute(
|
$this->link = \OC::$server->getURLGenerator()->linkToRoute(
|
||||||
'files.view.index',
|
'files.view.index',
|
||||||
[
|
[
|
||||||
'dir' => $info['dirname'],
|
'dir' => dirname($path),
|
||||||
'scrollto' => $info['basename'],
|
'scrollto' => $data->getName(),
|
||||||
]
|
]
|
||||||
);
|
);
|
||||||
$this->permissions = $data->getPermissions();
|
$this->permissions = $data->getPermissions();
|
||||||
|
|
Loading…
Reference in New Issue