Skip to content
Snippets Groups Projects
Unverified Commit ffc85ad6 authored by Roeland Jago Douma's avatar Roeland Jago Douma Committed by GitHub
Browse files

Merge pull request #21431 from nextcloud/search-filter-invalid-results

Filter out search results that have invalid encoding
parents 0825530a fda55db4
No related branches found
No related tags found
No related merge requests found
...@@ -28,20 +28,28 @@ namespace OC\Core\Controller; ...@@ -28,20 +28,28 @@ namespace OC\Core\Controller;
use OCP\AppFramework\Controller; use OCP\AppFramework\Controller;
use OCP\AppFramework\Http\JSONResponse; use OCP\AppFramework\Http\JSONResponse;
use OCP\ILogger;
use OCP\IRequest; use OCP\IRequest;
use OCP\ISearch; use OCP\ISearch;
use OCP\Search\Result;
class SearchController extends Controller { class SearchController extends Controller {
/** @var ISearch */ /** @var ISearch */
private $searcher; private $searcher;
/** @var ILogger */
private $logger;
public function __construct(string $appName, public function __construct(
IRequest $request, string $appName,
ISearch $search) { IRequest $request,
ISearch $search,
ILogger $logger
) {
parent::__construct($appName, $request); parent::__construct($appName, $request);
$this->searcher = $search; $this->searcher = $search;
$this->logger = $logger;
} }
/** /**
...@@ -50,6 +58,15 @@ class SearchController extends Controller { ...@@ -50,6 +58,15 @@ class SearchController extends Controller {
public function search(string $query, array $inApps = [], int $page = 1, int $size = 30): JSONResponse { public function search(string $query, array $inApps = [], int $page = 1, int $size = 30): JSONResponse {
$results = $this->searcher->searchPaged($query, $inApps, $page, $size); $results = $this->searcher->searchPaged($query, $inApps, $page, $size);
$results = array_filter($results, function (Result $result) {
if (json_encode($result, JSON_HEX_TAG) === false) {
$this->logger->warning("Skipping search result due to invalid encoding: {type: " . $result->type . ", id: " . $result->id . "}");
return false;
} else {
return true;
}
});
return new JSONResponse($results); return new JSONResponse($results);
} }
} }
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment