summaryrefslogtreecommitdiffstats
path: root/core/Controller/SearchController.php
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2020-06-16 15:22:36 +0200
committerRobin Appelman <robin@icewind.nl>2020-06-16 15:45:17 +0200
commitfda55db4c97df9e8973645ed3164457a426a5a23 (patch)
tree339d74316ec0bc2ea7bcd086cc13dc0ff31a501a /core/Controller/SearchController.php
parent13f119d48d091b8b1cc789b590a235086a077d93 (diff)
downloadnextcloud-server-fda55db4c97df9e8973645ed3164457a426a5a23.tar.gz
nextcloud-server-fda55db4c97df9e8973645ed3164457a426a5a23.zip
Filter out search results that have invalid encoding
this prevents a single invalid search results from erroring the entire search request Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'core/Controller/SearchController.php')
-rw-r--r--core/Controller/SearchController.php23
1 files changed, 20 insertions, 3 deletions
diff --git a/core/Controller/SearchController.php b/core/Controller/SearchController.php
index 8d3a6f623b7..a24aa7fa1ec 100644
--- a/core/Controller/SearchController.php
+++ b/core/Controller/SearchController.php
@@ -28,20 +28,28 @@ namespace OC\Core\Controller;
use OCP\AppFramework\Controller;
use OCP\AppFramework\Http\JSONResponse;
+use OCP\ILogger;
use OCP\IRequest;
use OCP\ISearch;
+use OCP\Search\Result;
class SearchController extends Controller {
/** @var ISearch */
private $searcher;
+ /** @var ILogger */
+ private $logger;
- public function __construct(string $appName,
- IRequest $request,
- ISearch $search) {
+ public function __construct(
+ string $appName,
+ IRequest $request,
+ ISearch $search,
+ ILogger $logger
+ ) {
parent::__construct($appName, $request);
$this->searcher = $search;
+ $this->logger = $logger;
}
/**
@@ -50,6 +58,15 @@ class SearchController extends Controller {
public function search(string $query, array $inApps = [], int $page = 1, int $size = 30): JSONResponse {
$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);
}
}