diff options
author | Robin Appelman <robin@icewind.nl> | 2020-06-16 15:22:36 +0200 |
---|---|---|
committer | Robin Appelman <robin@icewind.nl> | 2020-06-16 15:45:17 +0200 |
commit | fda55db4c97df9e8973645ed3164457a426a5a23 (patch) | |
tree | 339d74316ec0bc2ea7bcd086cc13dc0ff31a501a /core/Controller/SearchController.php | |
parent | 13f119d48d091b8b1cc789b590a235086a077d93 (diff) | |
download | nextcloud-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.php | 23 |
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); } } |