]> source.dussan.org Git - nextcloud-server.git/commitdiff
Filter out search results that have invalid encoding 21431/head
authorRobin Appelman <robin@icewind.nl>
Tue, 16 Jun 2020 13:22:36 +0000 (15:22 +0200)
committerRobin Appelman <robin@icewind.nl>
Tue, 16 Jun 2020 13:45:17 +0000 (15:45 +0200)
this prevents a single invalid search results from erroring the entire search request

Signed-off-by: Robin Appelman <robin@icewind.nl>
core/Controller/SearchController.php

index 8d3a6f623b727dd798c1ec3f1289aa5207c7aa56..a24aa7fa1ec07f365be8fe6791a8e7463dd31338 100644 (file)
@@ -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);
        }
 }