Skip to content

Commit

Permalink
TASK: Extract sanitation rule and use it in suggestions
Browse files Browse the repository at this point in the history
  • Loading branch information
daniellienert committed Jan 26, 2021
1 parent 0c43a79 commit 0902359
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 2 deletions.
3 changes: 2 additions & 1 deletion Classes/Controller/SuggestController.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
use Flowpack\ElasticSearch\ContentRepositoryAdaptor\Eel\ElasticSearchQueryBuilder;
use Flowpack\ElasticSearch\ContentRepositoryAdaptor\ElasticSearchClient;
use Flowpack\ElasticSearch\ContentRepositoryAdaptor\Exception\QueryBuildingException;
use Flowpack\SearchPlugin\Utility\Sanitation;
use Neos\Cache\Frontend\VariableFrontend;
use Neos\Flow\Annotations as Flow;
use Neos\Flow\Mvc\Controller\ActionController;
Expand Down Expand Up @@ -115,7 +116,7 @@ protected function buildRequestForTerm(string $term, string $contextNodeIdentifi

// The suggest function only works well with one word
// special search characters are escaped
$suggestTerm = str_replace(['=', '>', '<', '(', ')', '{', '}', '[', ']', '^', '"', '~', '*', '?', ':', '\\', '/'], ['', '', '', '(', '\)', '\{', '\}', '[', '\]', '\^', '\"', '\~', '\*', '\?', '\:', '\\\\', '\/'], explode(' ', $term)[0]);
$suggestTerm = Sanitation::sanitizeSearchInput(explode(' ', $term)[0]);

if (!$this->elasticSearchQueryTemplateCache->has($cacheKey)) {
$contentContext = $this->createContentContext('live', $dimensionCombination ? json_decode($dimensionCombination, true) : []);
Expand Down
4 changes: 3 additions & 1 deletion Classes/EelHelper/SuggestionIndexHelper.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
*/

use Flowpack\SearchPlugin\Exception;
use Flowpack\SearchPlugin\Utility\Sanitation;
use Neos\Eel\ProtectedContextAwareInterface;
use Neos\Flow\Annotations as Flow;

Expand Down Expand Up @@ -47,8 +48,9 @@ protected function prepareInput($input): ?array
{
$process = static function (?string $input) {
$input = preg_replace("/\r|\n/", '', $input);
return array_values(array_filter(explode(' ', preg_replace("/[^[:alnum:][:space:]]/u", ' ', strip_tags($input)))));
return array_values(array_filter(explode(' ', Sanitation::sanitizeSearchInput(strip_tags($input)))));
};

if (\is_string($input)) {
return $process($input);
} elseif (\is_array($input)) {
Expand Down
24 changes: 24 additions & 0 deletions Classes/Utility/Sanitation.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
<?php
declare(strict_types=1);

namespace Flowpack\SearchPlugin\Utility;

/*
* This file is part of the Flowpack.SearchPlugin package.
*
* (c) Contributors of the Flowpack Team - flowpack.org
*
* This package is Open Source Software. For the full copyright and license
* information, please view the LICENSE file which was distributed with this
* source code.
*/

class Sanitation
{

public static function sanitizeSearchInput(string $input): string
{
return str_replace(['=', '>', '<', '(', ')', '{', '}', '[', ']', '^', '"', '~', '*', '?', ':', '\\', '/'], ['', '', '', '(', '\)', '\{', '\}', '[', '\]', '\^', '\"', '\~', '\*', '\?', '\:', '\\\\', '\/'], $input);
}

}

0 comments on commit 0902359

Please sign in to comment.