first commit
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
<?php
|
||||
namespace WapplerSystems\Meilisearch\Domain\Search\ApacheSolrDocument;
|
||||
namespace WapplerSystems\Meilisearch\Domain\Search\ApacheMeilisearchDocument;
|
||||
|
||||
/***************************************************************
|
||||
* Copyright notice
|
||||
@@ -28,16 +28,16 @@ use WapplerSystems\Meilisearch\Access\Rootline;
|
||||
use WapplerSystems\Meilisearch\Domain\Site\SiteRepository;
|
||||
use WapplerSystems\Meilisearch\Domain\Variants\IdBuilder;
|
||||
use WapplerSystems\Meilisearch\Domain\Site\Site;
|
||||
use WapplerSystems\Meilisearch\System\Solr\Document\Document;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\Document\Document;
|
||||
use WapplerSystems\Meilisearch\Typo3PageContentExtractor;
|
||||
use WapplerSystems\Meilisearch\Util;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
use TYPO3\CMS\Frontend\Controller\TypoScriptFrontendController;
|
||||
|
||||
/**
|
||||
* Builder class to build an ApacheSolrDocument
|
||||
* Builder class to build an ApacheMeilisearchDocument
|
||||
*
|
||||
* Responsible to build \WapplerSystems\Meilisearch\System\Solr\Document\Document
|
||||
* Responsible to build \WapplerSystems\Meilisearch\System\Meilisearch\Document\Document
|
||||
*
|
||||
* @author Timo Hund <timo.hund@dkd.de>
|
||||
*/
|
||||
@@ -121,7 +121,7 @@ class Builder
|
||||
|
||||
|
||||
/**
|
||||
* Creates a Solr document with the basic / core fields set already.
|
||||
* Creates a Meilisearch document with the basic / core fields set already.
|
||||
*
|
||||
* @param array $itemRecord
|
||||
* @param string $type
|
||||
|
@@ -1,5 +1,5 @@
|
||||
<?php
|
||||
namespace WapplerSystems\Meilisearch\Domain\Search\ApacheSolrDocument;
|
||||
namespace WapplerSystems\Meilisearch\Domain\Search\ApacheMeilisearchDocument;
|
||||
|
||||
/***************************************************************
|
||||
* Copyright notice
|
||||
@@ -28,12 +28,12 @@ use WapplerSystems\Meilisearch\ConnectionManager;
|
||||
use WapplerSystems\Meilisearch\Domain\Search\Query\QueryBuilder;
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Result\Parser\DocumentEscapeService;
|
||||
use WapplerSystems\Meilisearch\Domain\Site\SiteRepository;
|
||||
use WapplerSystems\Meilisearch\NoSolrConnectionFoundException;
|
||||
use WapplerSystems\Meilisearch\NoMeilisearchConnectionFoundException;
|
||||
use WapplerSystems\Meilisearch\Search;
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
use WapplerSystems\Meilisearch\System\Solr\Document\Document;
|
||||
use WapplerSystems\Meilisearch\System\Solr\SolrCommunicationException;
|
||||
use WapplerSystems\Meilisearch\System\Solr\SolrConnection;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\Document\Document;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\MeilisearchCommunicationException;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\MeilisearchConnection;
|
||||
use WapplerSystems\Meilisearch\Util;
|
||||
use TYPO3\CMS\Core\SingletonInterface;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
@@ -73,13 +73,13 @@ class Repository implements SingletonInterface
|
||||
*/
|
||||
public function __construct(DocumentEscapeService $documentEscapeService = null, TypoScriptConfiguration $typoScriptConfiguration = null, QueryBuilder $queryBuilder = null)
|
||||
{
|
||||
$this->typoScriptConfiguration = $typoScriptConfiguration ?? Util::getSolrConfiguration();
|
||||
$this->typoScriptConfiguration = $typoScriptConfiguration ?? Util::getMeilisearchConfiguration();
|
||||
$this->documentEscapeService = $documentEscapeService ?? GeneralUtility::makeInstance(DocumentEscapeService::class, /** @scrutinizer ignore-type */ $typoScriptConfiguration);
|
||||
$this->queryBuilder = $queryBuilder ?? GeneralUtility::makeInstance(QueryBuilder::class, /** @scrutinizer ignore-type */ $this->typoScriptConfiguration);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns firs found \WapplerSystems\Meilisearch\System\Solr\Document\Document for current page by given language id.
|
||||
* Returns firs found \WapplerSystems\Meilisearch\System\Meilisearch\Document\Document for current page by given language id.
|
||||
*
|
||||
* @param $languageId
|
||||
* @return Document|false
|
||||
@@ -91,7 +91,7 @@ class Repository implements SingletonInterface
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns all found \WapplerSystems\Meilisearch\System\Solr\Document\Document[] by given page id and language id.
|
||||
* Returns all found \WapplerSystems\Meilisearch\System\Meilisearch\Document\Document[] by given page id and language id.
|
||||
* Returns empty array if nothing found, e.g. if no language or no page(or no index for page) is present.
|
||||
*
|
||||
* @param int $pageId
|
||||
@@ -104,9 +104,9 @@ class Repository implements SingletonInterface
|
||||
$this->initializeSearch($pageId, $languageId);
|
||||
$pageQuery = $this->queryBuilder->buildPageQuery($pageId);
|
||||
$response = $this->search->search($pageQuery, 0, 10000);
|
||||
} catch (NoSolrConnectionFoundException $exception) {
|
||||
} catch (NoMeilisearchConnectionFoundException $exception) {
|
||||
return [];
|
||||
} catch (SolrCommunicationException $exception) {
|
||||
} catch (MeilisearchCommunicationException $exception) {
|
||||
return [];
|
||||
}
|
||||
$data = $response->getParsedData();
|
||||
@@ -127,9 +127,9 @@ class Repository implements SingletonInterface
|
||||
$this->initializeSearch($pageId, $languageId);
|
||||
$recordQuery = $this->queryBuilder->buildRecordQuery($type, $uid, $pageId);
|
||||
$response = $this->search->search($recordQuery, 0, 10000);
|
||||
} catch (NoSolrConnectionFoundException $exception) {
|
||||
} catch (NoMeilisearchConnectionFoundException $exception) {
|
||||
return [];
|
||||
} catch (SolrCommunicationException $exception) {
|
||||
} catch (MeilisearchCommunicationException $exception) {
|
||||
return [];
|
||||
}
|
||||
$data = $response->getParsedData();
|
||||
@@ -152,19 +152,19 @@ class Repository implements SingletonInterface
|
||||
}
|
||||
/* @var $connectionManager ConnectionManager */
|
||||
$connectionManager = GeneralUtility::makeInstance(ConnectionManager::class);
|
||||
$solrConnection = $connectionManager->getConnectionByPageId($pageId, $languageId);
|
||||
$meilisearchConnection = $connectionManager->getConnectionByPageId($pageId, $languageId);
|
||||
|
||||
$this->search = $this->getSearch($solrConnection);
|
||||
$this->search = $this->getSearch($meilisearchConnection);
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves an instance of the Search object.
|
||||
*
|
||||
* @param SolrConnection $solrConnection
|
||||
* @param MeilisearchConnection $meilisearchConnection
|
||||
* @return Search
|
||||
*/
|
||||
protected function getSearch($solrConnection)
|
||||
protected function getSearch($meilisearchConnection)
|
||||
{
|
||||
return GeneralUtility::makeInstance(Search::class, /** @scrutinizer ignore-type */ $solrConnection);
|
||||
return GeneralUtility::makeInstance(Search::class, /** @scrutinizer ignore-type */ $meilisearchConnection);
|
||||
}
|
||||
}
|
||||
|
@@ -4,7 +4,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\LastSearches;
|
||||
/***************************************************************
|
||||
* Copyright notice
|
||||
*
|
||||
* (c) 2010-2017 dkd Internet Service GmbH <solr-support@dkd.de>
|
||||
* (c) 2010-2017 dkd Internet Service GmbH <meilisearch-support@dkd.de>
|
||||
* All rights reserved
|
||||
*
|
||||
* This script is part of the TYPO3 project. The TYPO3 project is
|
||||
|
@@ -44,7 +44,7 @@ use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
use TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer;
|
||||
|
||||
/**
|
||||
* The AbstractQueryBuilder contains all logic to initialize solr queries independent from TYPO3.
|
||||
* The AbstractQueryBuilder contains all logic to initialize meilisearch queries independent from TYPO3.
|
||||
*/
|
||||
abstract class AbstractQueryBuilder {
|
||||
|
||||
@@ -340,7 +340,7 @@ abstract class AbstractQueryBuilder {
|
||||
}
|
||||
|
||||
/**
|
||||
* Can be used to use a specific filter string in the solr query.
|
||||
* Can be used to use a specific filter string in the meilisearch query.
|
||||
*
|
||||
* @param string $filterString
|
||||
* @param string $filterName
|
||||
|
@@ -27,7 +27,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\Query;
|
||||
use Solarium\QueryType\Extract\Query as SolariumExtractQuery;
|
||||
|
||||
/**
|
||||
* Specialized query for content extraction using Solr Cell
|
||||
* Specialized query for content extraction using Meilisearch Cell
|
||||
*
|
||||
*/
|
||||
class ExtractingQuery extends SolariumExtractQuery
|
||||
|
@@ -25,7 +25,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\Query\Helper;
|
||||
***************************************************************/
|
||||
|
||||
/**
|
||||
* The EscpaeService is responsible to escape the querystring as expected for Apache Solr.
|
||||
* The EscpaeService is responsible to escape the querystring as expected for Meilisearch.
|
||||
*
|
||||
* This class should have no dependencies since it only contains static functions
|
||||
*
|
||||
|
@@ -4,7 +4,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\Query\ParameterBuilder;
|
||||
/***************************************************************
|
||||
* Copyright notice
|
||||
*
|
||||
* (c) 2010-2017 dkd Internet Service GmbH <solr-support@dkd.de>
|
||||
* (c) 2010-2017 dkd Internet Service GmbH <meilisearch-support@dkd.de>
|
||||
* All rights reserved
|
||||
*
|
||||
* This script is part of the TYPO3 project. The TYPO3 project is
|
||||
@@ -37,7 +37,7 @@ abstract class AbstractFieldList extends AbstractDeactivatable
|
||||
protected $fieldList = [];
|
||||
|
||||
/**
|
||||
* Parameter key which should be used for Apache Solr URL query
|
||||
* Parameter key which should be used for Meilisearch URL query
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
|
@@ -4,7 +4,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\Query\ParameterBuilder;
|
||||
/***************************************************************
|
||||
* Copyright notice
|
||||
*
|
||||
* (c) 2010-2017 dkd Internet Service GmbH <solr-support@dkd.de>
|
||||
* (c) 2010-2017 dkd Internet Service GmbH <meilisearch-support@dkd.de>
|
||||
* All rights reserved
|
||||
*
|
||||
* This script is part of the TYPO3 project. The TYPO3 project is
|
||||
@@ -33,7 +33,7 @@ use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
class BigramPhraseFields extends AbstractFieldList implements ParameterBuilder
|
||||
{
|
||||
/**
|
||||
* Parameter key which should be used for Apache Solr URL query
|
||||
* Parameter key which should be used for Meilisearch URL query
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
@@ -52,17 +52,17 @@ class BigramPhraseFields extends AbstractFieldList implements ParameterBuilder
|
||||
}
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return BigramPhraseFields
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
$isEnabled = $solrConfiguration->getBigramPhraseSearchIsEnabled();
|
||||
$isEnabled = $meilisearchConfiguration->getBigramPhraseSearchIsEnabled();
|
||||
if (!$isEnabled) {
|
||||
return new BigramPhraseFields(false);
|
||||
}
|
||||
|
||||
return self::fromString((string)$solrConfiguration->getSearchQueryBigramPhraseFields());
|
||||
return self::fromString((string)$meilisearchConfiguration->getSearchQueryBigramPhraseFields());
|
||||
}
|
||||
|
||||
/**
|
||||
|
@@ -28,7 +28,7 @@ use WapplerSystems\Meilisearch\Domain\Search\Query\AbstractQueryBuilder;
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
|
||||
/**
|
||||
* The Elevation ParameterProvider is responsible to build the solr query parameters
|
||||
* The Elevation ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the elevation.
|
||||
*/
|
||||
class Elevation extends AbstractDeactivatable implements ParameterBuilder
|
||||
@@ -89,18 +89,18 @@ class Elevation extends AbstractDeactivatable implements ParameterBuilder
|
||||
}
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return Elevation
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
$isEnabled = $solrConfiguration->getSearchElevation();
|
||||
$isEnabled = $meilisearchConfiguration->getSearchElevation();
|
||||
if (!$isEnabled) {
|
||||
return new Elevation(false);
|
||||
}
|
||||
|
||||
$force = $solrConfiguration->getSearchElevationForceElevation();
|
||||
$markResults = $solrConfiguration->getSearchElevationMarkElevatedResults();
|
||||
$force = $meilisearchConfiguration->getSearchElevationForceElevation();
|
||||
$markResults = $meilisearchConfiguration->getSearchElevationMarkElevatedResults();
|
||||
return new Elevation(true, $force, $markResults);
|
||||
}
|
||||
|
||||
|
@@ -30,7 +30,7 @@ use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\SortingExpression;
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
|
||||
/**
|
||||
* The Faceting ParameterProvider is responsible to build the solr query parameters
|
||||
* The Faceting ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the highlighting.
|
||||
*/
|
||||
class Faceting extends AbstractDeactivatable implements ParameterBuilder
|
||||
@@ -196,19 +196,19 @@ class Faceting extends AbstractDeactivatable implements ParameterBuilder
|
||||
}
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return Faceting
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
$isEnabled = $solrConfiguration->getSearchFaceting();
|
||||
$isEnabled = $meilisearchConfiguration->getSearchFaceting();
|
||||
if (!$isEnabled) {
|
||||
return new Faceting(false);
|
||||
}
|
||||
|
||||
$minCount = $solrConfiguration->getSearchFacetingMinimumCount();
|
||||
$limit = $solrConfiguration->getSearchFacetingFacetLimit();
|
||||
$sorting = $solrConfiguration->getSearchFacetingSortBy();
|
||||
$minCount = $meilisearchConfiguration->getSearchFacetingMinimumCount();
|
||||
$limit = $meilisearchConfiguration->getSearchFacetingFacetLimit();
|
||||
$sorting = $meilisearchConfiguration->getSearchFacetingSortBy();
|
||||
|
||||
return new Faceting($isEnabled, $sorting, $minCount, $limit);
|
||||
}
|
||||
|
@@ -28,7 +28,7 @@ use WapplerSystems\Meilisearch\Domain\Search\Query\AbstractQueryBuilder;
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
|
||||
/**
|
||||
* The FieldCollapsing ParameterProvider is responsible to build the solr query parameters
|
||||
* The FieldCollapsing ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the field collapsing.
|
||||
*/
|
||||
class FieldCollapsing extends AbstractDeactivatable implements ParameterBuilder
|
||||
@@ -112,19 +112,19 @@ class FieldCollapsing extends AbstractDeactivatable implements ParameterBuilder
|
||||
}
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return FieldCollapsing
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
$isEnabled = $solrConfiguration->getSearchVariants();
|
||||
$isEnabled = $meilisearchConfiguration->getSearchVariants();
|
||||
if (!$isEnabled) {
|
||||
return new FieldCollapsing(false);
|
||||
}
|
||||
|
||||
$collapseField = $solrConfiguration->getSearchVariantsField();
|
||||
$expand = (bool)$solrConfiguration->getSearchVariantsExpand();
|
||||
$expandRows = $solrConfiguration->getSearchVariantsLimit();
|
||||
$collapseField = $meilisearchConfiguration->getSearchVariantsField();
|
||||
$expand = (bool)$meilisearchConfiguration->getSearchVariantsExpand();
|
||||
$expandRows = $meilisearchConfiguration->getSearchVariantsLimit();
|
||||
|
||||
return new FieldCollapsing(true, $collapseField, $expand, $expandRows);
|
||||
}
|
||||
|
@@ -28,7 +28,7 @@ use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
|
||||
/**
|
||||
* The Filters ParameterProvider is responsible to build the solr query parameters
|
||||
* The Filters ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the filtering.
|
||||
*/
|
||||
class Filters
|
||||
@@ -140,10 +140,10 @@ class Filters
|
||||
}
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return Filters
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
return new Filters();
|
||||
}
|
||||
|
@@ -28,7 +28,7 @@ use WapplerSystems\Meilisearch\Domain\Search\Query\AbstractQueryBuilder;
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
|
||||
/**
|
||||
* The Grouping ParameterProvider is responsible to build the solr query parameters
|
||||
* The Grouping ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the grouping.
|
||||
*/
|
||||
class Grouping extends AbstractDeactivatable implements ParameterBuilder
|
||||
@@ -185,12 +185,12 @@ class Grouping extends AbstractDeactivatable implements ParameterBuilder
|
||||
}
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return Grouping
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
$isEnabled = $solrConfiguration->getSearchGrouping();
|
||||
$isEnabled = $meilisearchConfiguration->getSearchGrouping();
|
||||
if (!$isEnabled) {
|
||||
return new Grouping(false);
|
||||
}
|
||||
@@ -199,10 +199,10 @@ class Grouping extends AbstractDeactivatable implements ParameterBuilder
|
||||
$queries = [];
|
||||
$sortings = [];
|
||||
|
||||
$resultsPerGroup = $solrConfiguration->getSearchGroupingHighestGroupResultsLimit();
|
||||
$configuredGroups = $solrConfiguration->getSearchGroupingGroupsConfiguration();
|
||||
$numberOfGroups = $solrConfiguration->getSearchGroupingNumberOfGroups();
|
||||
$sortBy = $solrConfiguration->getSearchGroupingSortBy();
|
||||
$resultsPerGroup = $meilisearchConfiguration->getSearchGroupingHighestGroupResultsLimit();
|
||||
$configuredGroups = $meilisearchConfiguration->getSearchGroupingGroupsConfiguration();
|
||||
$numberOfGroups = $meilisearchConfiguration->getSearchGroupingNumberOfGroups();
|
||||
$sortBy = $meilisearchConfiguration->getSearchGroupingSortBy();
|
||||
|
||||
foreach ($configuredGroups as $groupName => $groupConfiguration) {
|
||||
if (isset($groupConfiguration['field'])) {
|
||||
|
@@ -30,7 +30,7 @@ use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
|
||||
/**
|
||||
* The Highlighting ParameterProvider is responsible to build the solr query parameters
|
||||
* The Highlighting ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the highlighting.
|
||||
*/
|
||||
class Highlighting extends AbstractDeactivatable implements ParameterBuilder
|
||||
@@ -147,19 +147,19 @@ class Highlighting extends AbstractDeactivatable implements ParameterBuilder
|
||||
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return Highlighting
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
$isEnabled = $solrConfiguration->getSearchResultsHighlighting();
|
||||
$isEnabled = $meilisearchConfiguration->getSearchResultsHighlighting();
|
||||
if (!$isEnabled) {
|
||||
return new Highlighting(false);
|
||||
}
|
||||
|
||||
$fragmentSize = $solrConfiguration->getSearchResultsHighlightingFragmentSize();
|
||||
$highlightingFields = $solrConfiguration->getSearchResultsHighlightingFields();
|
||||
$wrap = explode('|', $solrConfiguration->getSearchResultsHighlightingWrap());
|
||||
$fragmentSize = $meilisearchConfiguration->getSearchResultsHighlightingFragmentSize();
|
||||
$highlightingFields = $meilisearchConfiguration->getSearchResultsHighlightingFields();
|
||||
$wrap = explode('|', $meilisearchConfiguration->getSearchResultsHighlightingWrap());
|
||||
$prefix = isset($wrap[0]) ? $wrap[0] : '';
|
||||
$postfix = isset($wrap[1]) ? $wrap[1] : '';
|
||||
|
||||
|
@@ -26,7 +26,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\Query\ParameterBuilder;
|
||||
|
||||
|
||||
/**
|
||||
* The Operator ParameterProvider is responsible to build the solr query parameters
|
||||
* The Operator ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the operator q.op.
|
||||
*/
|
||||
class Operator extends AbstractDeactivatable
|
||||
|
@@ -29,7 +29,7 @@ use WapplerSystems\Meilisearch\Domain\Search\Query\AbstractQueryBuilder;
|
||||
|
||||
/**
|
||||
* The implementation of ParameterBuilder is responsible to build an array with
|
||||
* the query parameter that are needed for solr
|
||||
* the query parameter that are needed for meilisearch
|
||||
*
|
||||
* Interface ParameterProvider
|
||||
*/
|
||||
|
@@ -4,7 +4,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\Query\ParameterBuilder;
|
||||
/***************************************************************
|
||||
* Copyright notice
|
||||
*
|
||||
* (c) 2010-2017 dkd Internet Service GmbH <solr-support@dkd.de>
|
||||
* (c) 2010-2017 dkd Internet Service GmbH <meilisearch-support@dkd.de>
|
||||
* All rights reserved
|
||||
*
|
||||
* This script is part of the TYPO3 project. The TYPO3 project is
|
||||
@@ -33,7 +33,7 @@ use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
class PhraseFields extends AbstractFieldList implements ParameterBuilder
|
||||
{
|
||||
/**
|
||||
* Parameter key which should be used for Apache Solr URL query
|
||||
* Parameter key which should be used for Meilisearch URL query
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
@@ -52,17 +52,17 @@ class PhraseFields extends AbstractFieldList implements ParameterBuilder
|
||||
}
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return PhraseFields
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
$isEnabled = $solrConfiguration->getPhraseSearchIsEnabled();
|
||||
$isEnabled = $meilisearchConfiguration->getPhraseSearchIsEnabled();
|
||||
if (!$isEnabled) {
|
||||
return new PhraseFields(false);
|
||||
}
|
||||
|
||||
return self::fromString((string)$solrConfiguration->getSearchQueryPhraseFields());
|
||||
return self::fromString((string)$meilisearchConfiguration->getSearchQueryPhraseFields());
|
||||
}
|
||||
|
||||
/**
|
||||
|
@@ -28,7 +28,7 @@ use WapplerSystems\Meilisearch\Domain\Search\Query\AbstractQueryBuilder;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
|
||||
/**
|
||||
* The QueryFields class holds all information for the query which fields should be used to query (Solr qf parameter).
|
||||
* The QueryFields class holds all information for the query which fields should be used to query (Meilisearch qf parameter).
|
||||
*/
|
||||
class QueryFields implements ParameterBuilder
|
||||
{
|
||||
|
@@ -30,7 +30,7 @@ use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
|
||||
/**
|
||||
* The ReturnFields class is responsible to hold a list of field names that should be returned from
|
||||
* solr.
|
||||
* meilisearch.
|
||||
*/
|
||||
class ReturnFields implements ParameterBuilder
|
||||
{
|
||||
|
@@ -29,7 +29,7 @@ use WapplerSystems\Meilisearch\Domain\Search\Query\AbstractQueryBuilder;
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
|
||||
/**
|
||||
* The Slops ParameterProvider is responsible to build the solr query parameters
|
||||
* The Slops ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the several slop arguments.
|
||||
*/
|
||||
class Slops implements ParameterBuilder
|
||||
@@ -171,12 +171,12 @@ class Slops implements ParameterBuilder
|
||||
}
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return Slops
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
$searchConfiguration = $solrConfiguration->getSearchConfiguration();
|
||||
$searchConfiguration = $meilisearchConfiguration->getSearchConfiguration();
|
||||
$querySlop = static::getQuerySlopFromConfiguration($searchConfiguration);
|
||||
$phraseSlop = static::getPhraseSlopFromConfiguration($searchConfiguration);
|
||||
$bigramPhraseSlop = static::getBigramPhraseSlopFromConfiguration($searchConfiguration);
|
||||
|
@@ -27,7 +27,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\Query\ParameterBuilder;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
|
||||
/**
|
||||
* The Sorting ParameterProvider is responsible to build the solr query parameters
|
||||
* The Sorting ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the sorting.
|
||||
*/
|
||||
class Sorting extends AbstractDeactivatable
|
||||
|
@@ -27,7 +27,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\Query\ParameterBuilder;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
|
||||
/**
|
||||
* The Sorting ParameterProvider is responsible to build the solr query parameters
|
||||
* The Sorting ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the sorting.
|
||||
*/
|
||||
class Sortings extends AbstractDeactivatable
|
||||
|
@@ -28,7 +28,7 @@ use WapplerSystems\Meilisearch\Domain\Search\Query\AbstractQueryBuilder;
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
|
||||
/**
|
||||
* The Spellchecking ParameterProvider is responsible to build the solr query parameters
|
||||
* The Spellchecking ParameterProvider is responsible to build the meilisearch query parameters
|
||||
* that are needed for the spellchecking.
|
||||
*/
|
||||
class Spellchecking extends AbstractDeactivatable implements ParameterBuilder
|
||||
@@ -60,17 +60,17 @@ class Spellchecking extends AbstractDeactivatable implements ParameterBuilder
|
||||
}
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return Spellchecking
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
$isEnabled = $solrConfiguration->getSearchSpellchecking();
|
||||
$isEnabled = $meilisearchConfiguration->getSearchSpellchecking();
|
||||
if (!$isEnabled) {
|
||||
return new Spellchecking(false);
|
||||
}
|
||||
|
||||
$maxCollationTries = $solrConfiguration->getSearchSpellcheckingNumberOfSuggestionsToTry();
|
||||
$maxCollationTries = $meilisearchConfiguration->getSearchSpellcheckingNumberOfSuggestionsToTry();
|
||||
|
||||
return new Spellchecking($isEnabled, $maxCollationTries);
|
||||
}
|
||||
|
@@ -4,7 +4,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\Query\ParameterBuilder;
|
||||
/***************************************************************
|
||||
* Copyright notice
|
||||
*
|
||||
* (c) 2010-2017 dkd Internet Service GmbH <solr-support@dkd.de>
|
||||
* (c) 2010-2017 dkd Internet Service GmbH <meilisearch-support@dkd.de>
|
||||
* All rights reserved
|
||||
*
|
||||
* This script is part of the TYPO3 project. The TYPO3 project is
|
||||
@@ -33,7 +33,7 @@ use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
class TrigramPhraseFields extends AbstractFieldList implements ParameterBuilder
|
||||
{
|
||||
/**
|
||||
* Parameter key which should be used for Apache Solr URL query
|
||||
* Parameter key which should be used for Meilisearch URL query
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
@@ -52,17 +52,17 @@ class TrigramPhraseFields extends AbstractFieldList implements ParameterBuilder
|
||||
}
|
||||
|
||||
/**
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
* @return TrigramPhraseFields
|
||||
*/
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $solrConfiguration)
|
||||
public static function fromTypoScriptConfiguration(TypoScriptConfiguration $meilisearchConfiguration)
|
||||
{
|
||||
$isEnabled = $solrConfiguration->getTrigramPhraseSearchIsEnabled();
|
||||
$isEnabled = $meilisearchConfiguration->getTrigramPhraseSearchIsEnabled();
|
||||
if (!$isEnabled) {
|
||||
return new TrigramPhraseFields(false);
|
||||
}
|
||||
|
||||
return self::fromString((string)$solrConfiguration->getSearchQueryTrigramPhraseFields());
|
||||
return self::fromString((string)$meilisearchConfiguration->getSearchQueryTrigramPhraseFields());
|
||||
}
|
||||
|
||||
/**
|
||||
|
@@ -43,13 +43,13 @@ use WapplerSystems\Meilisearch\Domain\Site\SiteHashService;
|
||||
use WapplerSystems\Meilisearch\Domain\Site\SiteRepository;
|
||||
use WapplerSystems\Meilisearch\FieldProcessor\PageUidToHierarchy;
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
use WapplerSystems\Meilisearch\System\Logging\SolrLogManager;
|
||||
use WapplerSystems\Meilisearch\System\Logging\MeilisearchLogManager;
|
||||
use WapplerSystems\Meilisearch\Util;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
use TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer;
|
||||
|
||||
/**
|
||||
* The concrete QueryBuilder contains all TYPO3 specific initialization logic of solr queries, for TYPO3.
|
||||
* The concrete QueryBuilder contains all TYPO3 specific initialization logic of meilisearch queries, for TYPO3.
|
||||
*/
|
||||
class QueryBuilder extends AbstractQueryBuilder {
|
||||
|
||||
@@ -67,7 +67,7 @@ class QueryBuilder extends AbstractQueryBuilder {
|
||||
protected $typoScriptConfiguration = null;
|
||||
|
||||
/**
|
||||
* @var SolrLogManager;
|
||||
* @var MeilisearchLogManager;
|
||||
*/
|
||||
protected $logger = null;
|
||||
|
||||
@@ -79,13 +79,13 @@ class QueryBuilder extends AbstractQueryBuilder {
|
||||
/**
|
||||
* QueryBuilder constructor.
|
||||
* @param TypoScriptConfiguration|null $configuration
|
||||
* @param SolrLogManager|null $solrLogManager
|
||||
* @param MeilisearchLogManager|null $meilisearchLogManager
|
||||
* @param SiteHashService|null $siteHashService
|
||||
*/
|
||||
public function __construct(TypoScriptConfiguration $configuration = null, SolrLogManager $solrLogManager = null, SiteHashService $siteHashService = null)
|
||||
public function __construct(TypoScriptConfiguration $configuration = null, MeilisearchLogManager $meilisearchLogManager = null, SiteHashService $siteHashService = null)
|
||||
{
|
||||
$this->typoScriptConfiguration = $configuration ?? Util::getSolrConfiguration();
|
||||
$this->logger = $solrLogManager ?? GeneralUtility::makeInstance(SolrLogManager::class, /** @scrutinizer ignore-type */ __CLASS__);
|
||||
$this->typoScriptConfiguration = $configuration ?? Util::getMeilisearchConfiguration();
|
||||
$this->logger = $meilisearchLogManager ?? GeneralUtility::makeInstance(MeilisearchLogManager::class, /** @scrutinizer ignore-type */ __CLASS__);
|
||||
$this->siteHashService = $siteHashService ?? GeneralUtility::makeInstance(SiteHashService::class);
|
||||
}
|
||||
|
||||
@@ -121,7 +121,7 @@ class QueryBuilder extends AbstractQueryBuilder {
|
||||
public function buildSearchQuery($rawQuery, $resultsPerPage = 10, array $additionalFiltersFromRequest = []) : SearchQuery
|
||||
{
|
||||
if ($this->typoScriptConfiguration->getLoggingQuerySearchWords()) {
|
||||
$this->logger->log(SolrLogManager::INFO, 'Received search query', [$rawQuery]);
|
||||
$this->logger->log(MeilisearchLogManager::INFO, 'Received search query', [$rawQuery]);
|
||||
}
|
||||
|
||||
/* @var $query SearchQuery */
|
||||
@@ -170,7 +170,7 @@ class QueryBuilder extends AbstractQueryBuilder {
|
||||
|
||||
/**
|
||||
* Returns Query for Search which finds document for given page.
|
||||
* Note: The Connection is per language as recommended in ext-solr docs.
|
||||
* Note: The Connection is per language as recommended in ext-meilisearch docs.
|
||||
*
|
||||
* @return Query
|
||||
*/
|
||||
@@ -361,7 +361,7 @@ class QueryBuilder extends AbstractQueryBuilder {
|
||||
}
|
||||
|
||||
/**
|
||||
* Applies the configured initial query settings to set the alternative query for solr as required.
|
||||
* Applies the configured initial query settings to set the alternative query for meilisearch as required.
|
||||
*
|
||||
* @return QueryBuilder
|
||||
*/
|
||||
|
@@ -50,17 +50,17 @@ class SuggestQuery extends Query
|
||||
* SuggestQuery constructor.
|
||||
*
|
||||
* @param string $keywords
|
||||
* @param TypoScriptConfiguration $solrConfiguration
|
||||
* @param TypoScriptConfiguration $meilisearchConfiguration
|
||||
*/
|
||||
public function __construct($keywords, $solrConfiguration = null)
|
||||
public function __construct($keywords, $meilisearchConfiguration = null)
|
||||
{
|
||||
parent::__construct();
|
||||
$keywords = (string)$keywords;
|
||||
|
||||
$solrConfiguration = $solrConfiguration ?? Util::getSolrConfiguration();
|
||||
$meilisearchConfiguration = $meilisearchConfiguration ?? Util::getMeilisearchConfiguration();
|
||||
|
||||
$this->setQuery($keywords);
|
||||
$this->configuration = $solrConfiguration->getObjectByPathOrDefault('plugin.tx_meilisearch.suggest.', []);
|
||||
$this->configuration = $meilisearchConfiguration->getObjectByPathOrDefault('plugin.tx_meilisearch.suggest.', []);
|
||||
|
||||
if (!empty($this->configuration['treatMultipleTermsAsSingleTerm'])) {
|
||||
$this->prefix = EscapeService::escape($keywords);
|
||||
|
@@ -117,7 +117,7 @@ abstract class AbstractFacet
|
||||
}
|
||||
|
||||
/**
|
||||
* Get solr field name
|
||||
* Get meilisearch field name
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
|
@@ -118,13 +118,13 @@ abstract class AbstractFacetParser implements FacetParserInterface
|
||||
|
||||
|
||||
/**
|
||||
* @param array $facetValuesFromSolrResponse
|
||||
* @param array $facetValuesFromMeilisearchResponse
|
||||
* @param array $facetValuesFromSearchRequest
|
||||
* @return mixed
|
||||
*/
|
||||
protected function getMergedFacetValueFromSearchRequestAndSolrResponse($facetValuesFromSolrResponse, $facetValuesFromSearchRequest)
|
||||
protected function getMergedFacetValueFromSearchRequestAndMeilisearchResponse($facetValuesFromMeilisearchResponse, $facetValuesFromSearchRequest)
|
||||
{
|
||||
$facetValueItemsToCreate = $facetValuesFromSolrResponse;
|
||||
$facetValueItemsToCreate = $facetValuesFromMeilisearchResponse;
|
||||
|
||||
foreach ($facetValuesFromSearchRequest as $valueFromRequest) {
|
||||
// if we have options in the request that have not been in the response we add them with a count of 0
|
||||
|
@@ -16,7 +16,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\OptionBased\
|
||||
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\AbstractFacetParser;
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\SearchResultSet;
|
||||
use WapplerSystems\Meilisearch\System\Solr\ParsingUtil;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\ParsingUtil;
|
||||
|
||||
/**
|
||||
* Class HierarchyFacetParser
|
||||
@@ -34,9 +34,9 @@ class HierarchyFacetParser extends AbstractFacetParser
|
||||
$response = $resultSet->getResponse();
|
||||
$fieldName = $facetConfiguration['field'];
|
||||
$label = $this->getPlainLabelOrApplyCObject($facetConfiguration);
|
||||
$optionsFromSolrResponse = isset($response->facet_counts->facet_fields->{$fieldName}) ? ParsingUtil::getMapArrayFromFlatArray($response->facet_counts->facet_fields->{$fieldName}) : [];
|
||||
$optionsFromMeilisearchResponse = isset($response->facet_counts->facet_fields->{$fieldName}) ? ParsingUtil::getMapArrayFromFlatArray($response->facet_counts->facet_fields->{$fieldName}) : [];
|
||||
$optionsFromRequest = $this->getActiveFacetValuesFromRequest($resultSet, $facetName);
|
||||
$hasOptionsInResponse = !empty($optionsFromSolrResponse);
|
||||
$hasOptionsInResponse = !empty($optionsFromMeilisearchResponse);
|
||||
$hasSelectedOptionsInRequest = count($optionsFromRequest) > 0;
|
||||
$hasNoOptionsToShow = !$hasOptionsInResponse && !$hasSelectedOptionsInRequest;
|
||||
$hideEmpty = !$resultSet->getUsedSearchRequest()->getContextTypoScriptConfiguration()->getSearchFacetingShowEmptyFacetsByName($facetName);
|
||||
@@ -53,7 +53,7 @@ class HierarchyFacetParser extends AbstractFacetParser
|
||||
|
||||
$facet->setIsAvailable($hasOptionsInResponse);
|
||||
|
||||
$nodesToCreate = $this->getMergedFacetValueFromSearchRequestAndSolrResponse($optionsFromSolrResponse, $optionsFromRequest);
|
||||
$nodesToCreate = $this->getMergedFacetValueFromSearchRequestAndMeilisearchResponse($optionsFromMeilisearchResponse, $optionsFromRequest);
|
||||
|
||||
if ($this->facetOptionsMustBeResorted($facetConfiguration)) {
|
||||
$nodesToCreate = $this->sortFacetOptionsInNaturalOrder($nodesToCreate);
|
||||
@@ -96,13 +96,13 @@ class HierarchyFacetParser extends AbstractFacetParser
|
||||
/**
|
||||
* Checks if options must be resorted.
|
||||
*
|
||||
* Apache Solr facet.sort can be set globally or per facet.
|
||||
* Meilisearch facet.sort can be set globally or per facet.
|
||||
* Relevant TypoScript paths:
|
||||
* plugin.tx_meilisearch.search.faceting.sortBy causes facet.sort Apache Solr parameter
|
||||
* plugin.tx_meilisearch.search.faceting.sortBy causes facet.sort Meilisearch parameter
|
||||
* plugin.tx_meilisearch.search.faceting.facets.[facetName].sortBy causes f.<fieldname>.facet.sort parameter
|
||||
*
|
||||
* see: https://lucene.apache.org/solr/guide/6_6/faceting.html#Faceting-Thefacet.sortParameter
|
||||
* see: https://wiki.apache.org/solr/SimpleFacetParameters#facet.sort : "This parameter can be specified on a per field basis."
|
||||
* see: https://lucene.apache.org/meilisearch/guide/6_6/faceting.html#Faceting-Thefacet.sortParameter
|
||||
* see: https://wiki.apache.org/meilisearch/SimpleFacetParameters#facet.sort : "This parameter can be specified on a per field basis."
|
||||
*
|
||||
* @param array $facetConfiguration
|
||||
* @return bool
|
||||
|
@@ -29,7 +29,7 @@ class HierarchyTool
|
||||
}
|
||||
|
||||
/**
|
||||
* Replaces @@@slash@@@ with \/ to have the path usable for solr again.
|
||||
* Replaces @@@slash@@@ with \/ to have the path usable for meilisearch again.
|
||||
*
|
||||
* @param string $pathWithReplacedContentSlashes
|
||||
* @return string
|
||||
|
@@ -27,7 +27,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\OptionBased\
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\FacetUrlDecoderInterface;
|
||||
|
||||
/**
|
||||
* Filter encoder to build Solr hierarchy queries from tx_meilisearch[filter]
|
||||
* Filter encoder to build Meilisearch hierarchy queries from tx_meilisearch[filter]
|
||||
*
|
||||
* @author Ingo Renner <ingo@typo3.org>
|
||||
*/
|
||||
@@ -42,11 +42,11 @@ class HierarchyUrlDecoder implements FacetUrlDecoderInterface
|
||||
const DELIMITER = '/';
|
||||
|
||||
/**
|
||||
* Parses the given hierarchy filter and returns a Solr filter query.
|
||||
* Parses the given hierarchy filter and returns a Meilisearch filter query.
|
||||
*
|
||||
* @param string $hierarchy The hierarchy filter query.
|
||||
* @param array $configuration Facet configuration
|
||||
* @return string Lucene query language filter to be used for querying Solr
|
||||
* @return string Lucene query language filter to be used for querying Meilisearch
|
||||
*/
|
||||
public function decode($hierarchy, array $configuration = [])
|
||||
{
|
||||
|
@@ -16,7 +16,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\OptionBased\
|
||||
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\AbstractFacetParser;
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\SearchResultSet;
|
||||
use WapplerSystems\Meilisearch\System\Solr\ResponseAdapter;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\ResponseAdapter;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
use TYPO3\CMS\Extbase\SignalSlot\Dispatcher;
|
||||
|
||||
@@ -49,10 +49,10 @@ class OptionsFacetParser extends AbstractFacetParser
|
||||
$response = $resultSet->getResponse();
|
||||
$fieldName = $facetConfiguration['field'];
|
||||
$label = $this->getPlainLabelOrApplyCObject($facetConfiguration);
|
||||
$optionsFromSolrResponse = $this->getOptionsFromSolrResponse($facetName, $response);
|
||||
$metricsFromSolrResponse = $this->getMetricsFromSolrResponse($facetName, $response);
|
||||
$optionsFromMeilisearchResponse = $this->getOptionsFromMeilisearchResponse($facetName, $response);
|
||||
$metricsFromMeilisearchResponse = $this->getMetricsFromMeilisearchResponse($facetName, $response);
|
||||
$optionsFromRequest = $this->getActiveFacetValuesFromRequest($resultSet, $facetName);
|
||||
$hasOptionsInResponse = !empty($optionsFromSolrResponse);
|
||||
$hasOptionsInResponse = !empty($optionsFromMeilisearchResponse);
|
||||
$hasSelectedOptionsInRequest = count($optionsFromRequest) > 0;
|
||||
$hasNoOptionsToShow = !$hasOptionsInResponse && !$hasSelectedOptionsInRequest;
|
||||
$hideEmpty = !$resultSet->getUsedSearchRequest()->getContextTypoScriptConfiguration()->getSearchFacetingShowEmptyFacetsByName($facetName);
|
||||
@@ -75,7 +75,7 @@ class OptionsFacetParser extends AbstractFacetParser
|
||||
$facet->setIsUsed($hasActiveOptions);
|
||||
$facet->setIsAvailable($hasOptionsInResponse);
|
||||
|
||||
$optionsToCreate = $this->getMergedFacetValueFromSearchRequestAndSolrResponse($optionsFromSolrResponse, $optionsFromRequest);
|
||||
$optionsToCreate = $this->getMergedFacetValueFromSearchRequestAndMeilisearchResponse($optionsFromMeilisearchResponse, $optionsFromRequest);
|
||||
foreach ($optionsToCreate as $optionsValue => $count) {
|
||||
if ($this->getIsExcludedFacetValue($optionsValue, $facetConfiguration)) {
|
||||
continue;
|
||||
@@ -83,11 +83,11 @@ class OptionsFacetParser extends AbstractFacetParser
|
||||
|
||||
$isOptionsActive = in_array($optionsValue, $optionsFromRequest);
|
||||
$label = $this->getLabelFromRenderingInstructions($optionsValue, $count, $facetName, $facetConfiguration);
|
||||
$facet->addOption($this->objectManager->get(Option::class, $facet, $label, $optionsValue, $count, $isOptionsActive, $metricsFromSolrResponse[$optionsValue]));
|
||||
$facet->addOption($this->objectManager->get(Option::class, $facet, $label, $optionsValue, $count, $isOptionsActive, $metricsFromMeilisearchResponse[$optionsValue]));
|
||||
}
|
||||
|
||||
// after all options have been created we apply a manualSortOrder if configured
|
||||
// the sortBy (lex,..) is done by the solr server and triggered by the query, therefore it does not
|
||||
// the sortBy (lex,..) is done by the meilisearch server and triggered by the query, therefore it does not
|
||||
// need to be handled in the frontend.
|
||||
$this->applyManualSortOrder($facet, $facetConfiguration);
|
||||
$this->applyReverseOrder($facet, $facetConfiguration);
|
||||
@@ -104,20 +104,20 @@ class OptionsFacetParser extends AbstractFacetParser
|
||||
* @param ResponseAdapter $response
|
||||
* @return array
|
||||
*/
|
||||
protected function getOptionsFromSolrResponse($facetName, ResponseAdapter $response)
|
||||
protected function getOptionsFromMeilisearchResponse($facetName, ResponseAdapter $response)
|
||||
{
|
||||
$optionsFromSolrResponse = [];
|
||||
$optionsFromMeilisearchResponse = [];
|
||||
if (!isset($response->facets->{$facetName})) {
|
||||
return $optionsFromSolrResponse;
|
||||
return $optionsFromMeilisearchResponse;
|
||||
}
|
||||
|
||||
foreach ($response->facets->{$facetName}->buckets as $bucket) {
|
||||
$optionValue = $bucket->val;
|
||||
$optionCount = $bucket->count;
|
||||
$optionsFromSolrResponse[$optionValue] = $optionCount;
|
||||
$optionsFromMeilisearchResponse[$optionValue] = $optionCount;
|
||||
}
|
||||
|
||||
return $optionsFromSolrResponse;
|
||||
return $optionsFromMeilisearchResponse;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -125,9 +125,9 @@ class OptionsFacetParser extends AbstractFacetParser
|
||||
* @param ResponseAdapter $response
|
||||
* @return array
|
||||
*/
|
||||
protected function getMetricsFromSolrResponse($facetName, ResponseAdapter $response)
|
||||
protected function getMetricsFromMeilisearchResponse($facetName, ResponseAdapter $response)
|
||||
{
|
||||
$metricsFromSolrResponse = [];
|
||||
$metricsFromMeilisearchResponse = [];
|
||||
|
||||
if (!isset($response->facets->{$facetName}->buckets)) {
|
||||
return [];
|
||||
@@ -138,11 +138,11 @@ class OptionsFacetParser extends AbstractFacetParser
|
||||
foreach ($bucketVariables as $key => $value) {
|
||||
if (strpos($key, 'metrics_') === 0) {
|
||||
$metricsKey = str_replace('metrics_', '', $key);
|
||||
$metricsFromSolrResponse[$bucket->val][$metricsKey] = $value;
|
||||
$metricsFromMeilisearchResponse[$bucket->val][$metricsKey] = $value;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $metricsFromSolrResponse;
|
||||
return $metricsFromMeilisearchResponse;
|
||||
}
|
||||
}
|
||||
|
@@ -16,7 +16,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\OptionBased\
|
||||
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\AbstractFacetParser;
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\SearchResultSet;
|
||||
use WapplerSystems\Meilisearch\System\Solr\ResponseAdapter;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\ResponseAdapter;
|
||||
|
||||
/**
|
||||
* Class QueryGroupFacetParser
|
||||
@@ -86,7 +86,7 @@ class QueryGroupFacetParser extends AbstractFacetParser
|
||||
|
||||
|
||||
// after all options have been created we apply a manualSortOrder if configured
|
||||
// the sortBy (lex,..) is done by the solr server and triggered by the query, therefore it does not
|
||||
// the sortBy (lex,..) is done by the meilisearch server and triggered by the query, therefore it does not
|
||||
// need to be handled in the frontend.
|
||||
$this->applyManualSortOrder($facet, $facetConfiguration);
|
||||
$this->applyReverseOrder($facet, $facetConfiguration);
|
||||
@@ -112,7 +112,7 @@ class QueryGroupFacetParser extends AbstractFacetParser
|
||||
|
||||
// todo: add test cases to check if this is needed https://forge.typo3.org/issues/45440
|
||||
// remove tags from the facet.query response, for facet.field
|
||||
// and facet.range Solr does that on its own automatically
|
||||
// and facet.range Meilisearch does that on its own automatically
|
||||
$rawValue = preg_replace('/^\{!ex=[^\}]*\}(.*)/', '\\1', $rawValue);
|
||||
|
||||
list($field, $query) = explode(':', $rawValue, 2);
|
||||
|
@@ -16,7 +16,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\RangeBased;
|
||||
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\AbstractFacetParser;
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\SearchResultSet;
|
||||
use WapplerSystems\Meilisearch\System\Solr\ParsingUtil;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\ParsingUtil;
|
||||
|
||||
/**
|
||||
* Class AbstractRangeFacetParser
|
||||
|
@@ -103,7 +103,7 @@ class DateRange extends AbstractRangeFacetItem
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves the end date that was received from solr for this facet.
|
||||
* Retrieves the end date that was received from meilisearch for this facet.
|
||||
*
|
||||
* @return \DateTime
|
||||
*/
|
||||
@@ -113,7 +113,7 @@ class DateRange extends AbstractRangeFacetItem
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves the start date that was received from solr for this facet.
|
||||
* Retrieves the start date that was received from meilisearch for this facet.
|
||||
*
|
||||
* @return \DateTime
|
||||
*/
|
||||
|
@@ -30,7 +30,7 @@ use WapplerSystems\Meilisearch\System\DateTime\FormatService;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
|
||||
/**
|
||||
* Parser to build solr range queries from tx_meilisearch[filter]
|
||||
* Parser to build meilisearch range queries from tx_meilisearch[filter]
|
||||
*
|
||||
* @author Markus Goldbach <markus.goldbach@dkd.de>
|
||||
*/
|
||||
@@ -45,12 +45,12 @@ class DateRangeUrlDecoder implements FacetUrlDecoderInterface
|
||||
const DELIMITER = '-';
|
||||
|
||||
/**
|
||||
* Parses the given date range from a GET parameter and returns a Solr
|
||||
* Parses the given date range from a GET parameter and returns a Meilisearch
|
||||
* date range filter.
|
||||
*
|
||||
* @param string $dateRange The range filter query string from the query URL
|
||||
* @param array $configuration Facet configuration
|
||||
* @return string Lucene query language filter to be used for querying Solr
|
||||
* @return string Lucene query language filter to be used for querying Meilisearch
|
||||
*/
|
||||
public function decode($dateRange, array $configuration = [])
|
||||
{
|
||||
|
@@ -102,7 +102,7 @@ class NumericRange extends AbstractRangeFacetItem
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves the end date that was received from solr for this facet.
|
||||
* Retrieves the end date that was received from meilisearch for this facet.
|
||||
*
|
||||
* @return float
|
||||
*/
|
||||
@@ -112,7 +112,7 @@ class NumericRange extends AbstractRangeFacetItem
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves the start date that was received from solr for this facet.
|
||||
* Retrieves the start date that was received from meilisearch for this facet.
|
||||
*
|
||||
* @return float
|
||||
*/
|
||||
|
@@ -29,7 +29,7 @@ namespace WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\RangeBased\N
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Facets\FacetUrlDecoderInterface;
|
||||
|
||||
/**
|
||||
* Parser to build Solr range queries from tx_meilisearch[filter]
|
||||
* Parser to build Meilisearch range queries from tx_meilisearch[filter]
|
||||
*
|
||||
* @author Markus Goldbach <markus.goldbach@dkd.de>
|
||||
* @author Ingo Renner <ingo@typo3.org>
|
||||
@@ -46,12 +46,12 @@ class NumericRangeUrlDecoder implements FacetUrlDecoderInterface
|
||||
const DELIMITER = '-';
|
||||
|
||||
/**
|
||||
* Parses the given range from a GET parameter and returns a Solr range
|
||||
* Parses the given range from a GET parameter and returns a Meilisearch range
|
||||
* filter.
|
||||
*
|
||||
* @param string $range The range filter from the URL.
|
||||
* @param array $configuration Facet configuration
|
||||
* @return string Lucene query language filter to be used for querying Solr
|
||||
* @return string Lucene query language filter to be used for querying Meilisearch
|
||||
* @throws \InvalidArgumentException
|
||||
*/
|
||||
public function decode($range, array $configuration = [])
|
||||
|
@@ -32,7 +32,7 @@ use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
|
||||
/**
|
||||
* A ResultParser is responsible to create the result object structure from the \Apache_Solr_Response
|
||||
* A ResultParser is responsible to create the result object structure from the \Apache_Meilisearch_Response
|
||||
* and assign it to the SearchResultSet.
|
||||
*/
|
||||
abstract class AbstractResultParser {
|
||||
|
@@ -62,7 +62,7 @@ class DefaultResultParser extends AbstractResultParser {
|
||||
}
|
||||
|
||||
foreach ($documents as $searchResult) {
|
||||
$searchResultObject = $this->searchResultBuilder->fromApacheSolrDocument($searchResult);
|
||||
$searchResultObject = $this->searchResultBuilder->fromApacheMeilisearchDocument($searchResult);
|
||||
$searchResults[] = $searchResultObject;
|
||||
}
|
||||
|
||||
|
@@ -26,11 +26,11 @@ namespace WapplerSystems\Meilisearch\Domain\Search\ResultSet\Result\Parser;
|
||||
***************************************************************/
|
||||
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
use WapplerSystems\Meilisearch\System\Solr\Document\Document;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\Document\Document;
|
||||
use WapplerSystems\Meilisearch\Util;
|
||||
|
||||
/**
|
||||
* Applies htmlspecialschars on documents of a solr response.
|
||||
* Applies htmlspecialschars on documents of a meilisearch response.
|
||||
*/
|
||||
class DocumentEscapeService {
|
||||
|
||||
@@ -44,7 +44,7 @@ class DocumentEscapeService {
|
||||
* @param TypoScriptConfiguration|null $typoScriptConfiguration
|
||||
*/
|
||||
public function __construct(TypoScriptConfiguration $typoScriptConfiguration = null) {
|
||||
$this->typoScriptConfiguration = $typoScriptConfiguration ?? Util::getSolrConfiguration();
|
||||
$this->typoScriptConfiguration = $typoScriptConfiguration ?? Util::getMeilisearchConfiguration();
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -56,13 +56,13 @@ class DocumentEscapeService {
|
||||
*/
|
||||
public function applyHtmlSpecialCharsOnAllFields(array $documents)
|
||||
{
|
||||
$trustedSolrFields = $this->typoScriptConfiguration->getSearchTrustedFieldsArray();
|
||||
$trustedMeilisearchFields = $this->typoScriptConfiguration->getSearchTrustedFieldsArray();
|
||||
|
||||
foreach ($documents as $key => $document) {
|
||||
$fieldNames = array_keys($document->getFields() ?? []);
|
||||
|
||||
foreach ($fieldNames as $fieldName) {
|
||||
if (is_array($trustedSolrFields) && in_array($fieldName, $trustedSolrFields)) {
|
||||
if (is_array($trustedMeilisearchFields) && in_array($fieldName, $trustedMeilisearchFields)) {
|
||||
// we skip this field, since it was marked as secure
|
||||
continue;
|
||||
}
|
||||
|
@@ -26,10 +26,10 @@ namespace WapplerSystems\Meilisearch\Domain\Search\ResultSet\Result;
|
||||
***************************************************************/
|
||||
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Grouping\GroupItem;
|
||||
use WapplerSystems\Meilisearch\System\Solr\Document\Document;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\Document\Document;
|
||||
|
||||
/**
|
||||
* Solr document class that should be used in the frontend in the search context.
|
||||
* Meilisearch document class that should be used in the frontend in the search context.
|
||||
*
|
||||
* @author Timo Schmidt <timo.schmidt@dkd.de>
|
||||
*/
|
||||
@@ -38,7 +38,7 @@ class SearchResult extends Document
|
||||
/**
|
||||
* The variant field value
|
||||
*
|
||||
* Value of Solr collapse field, which is defined via
|
||||
* Value of Meilisearch collapse field, which is defined via
|
||||
* TypoScript variable "variants.variantField"
|
||||
*
|
||||
* @var string
|
||||
|
@@ -25,24 +25,24 @@ namespace WapplerSystems\Meilisearch\Domain\Search\ResultSet\Result;
|
||||
* This copyright notice MUST APPEAR in all copies of the script!
|
||||
***************************************************************/
|
||||
|
||||
use WapplerSystems\Meilisearch\System\Solr\Document\Document;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\Document\Document;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
|
||||
/**
|
||||
* The SearchResultBuilder is responsible to build a SearchResult object from an \WapplerSystems\Meilisearch\System\Solr\Document\Document
|
||||
* The SearchResultBuilder is responsible to build a SearchResult object from an \WapplerSystems\Meilisearch\System\Meilisearch\Document\Document
|
||||
* and should use a different class as SearchResult if configured.
|
||||
*/
|
||||
class SearchResultBuilder {
|
||||
|
||||
/**
|
||||
* This method is used to wrap the original solr document instance in an instance of the configured SearchResult
|
||||
* This method is used to wrap the original meilisearch document instance in an instance of the configured SearchResult
|
||||
* class.
|
||||
*
|
||||
* @param Document $originalDocument
|
||||
* @throws \InvalidArgumentException
|
||||
* @return SearchResult
|
||||
*/
|
||||
public function fromApacheSolrDocument(Document $originalDocument)
|
||||
public function fromApacheMeilisearchDocument(Document $originalDocument)
|
||||
{
|
||||
|
||||
$searchResultClassName = $this->getResultClassName();
|
||||
@@ -60,7 +60,7 @@ class SearchResultBuilder {
|
||||
*/
|
||||
protected function getResultClassName()
|
||||
{
|
||||
return isset($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['solr']['searchResultClassName ']) ?
|
||||
$GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['solr']['searchResultClassName '] : SearchResult::class;
|
||||
return isset($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['meilisearch']['searchResultClassName ']) ?
|
||||
$GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['meilisearch']['searchResultClassName '] : SearchResult::class;
|
||||
}
|
||||
}
|
||||
|
@@ -25,7 +25,7 @@ use TYPO3\CMS\Extbase\Object\ObjectManagerInterface;
|
||||
use TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer;
|
||||
|
||||
/**
|
||||
* This processor is used to transform the solr response into a
|
||||
* This processor is used to transform the meilisearch response into a
|
||||
* domain object hierarchy that can be used in the application (controller and view).
|
||||
*
|
||||
* @author Frans Saris <frans@beech.it>
|
||||
@@ -83,7 +83,7 @@ class ResultSetReconstitutionProcessor implements SearchResultSetProcessor
|
||||
$resultSet = $this->parseSpellCheckingResponseIntoObjects($resultSet);
|
||||
$resultSet = $this->parseSortingIntoObjects($resultSet);
|
||||
|
||||
// here we can reconstitute other domain objects from the solr response
|
||||
// here we can reconstitute other domain objects from the meilisearch response
|
||||
$resultSet = $this->parseFacetsIntoObjects($resultSet);
|
||||
|
||||
return $resultSet;
|
||||
|
@@ -35,10 +35,10 @@ use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Sorting\SortingCollection
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Spellchecking\Suggestion;
|
||||
use WapplerSystems\Meilisearch\Domain\Search\SearchRequest;
|
||||
use WapplerSystems\Meilisearch\Search;
|
||||
use WapplerSystems\Meilisearch\System\Solr\ResponseAdapter;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\ResponseAdapter;
|
||||
|
||||
/**
|
||||
* The SearchResultSet is used to provided access to the \Apache_Solr_Response and
|
||||
* The SearchResultSet is used to provided access to the \Apache_Meilisearch_Response and
|
||||
* other relevant information, like the used Query and Request objects.
|
||||
*
|
||||
* @author Timo Schmidt <timo.schmidt@dkd.de>
|
||||
|
@@ -41,10 +41,10 @@ use WapplerSystems\Meilisearch\Search\QueryAware;
|
||||
use WapplerSystems\Meilisearch\Search\SearchAware;
|
||||
use WapplerSystems\Meilisearch\Search\SearchComponentManager;
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
use WapplerSystems\Meilisearch\System\Logging\SolrLogManager;
|
||||
use WapplerSystems\Meilisearch\System\Solr\Document\Document;
|
||||
use WapplerSystems\Meilisearch\System\Solr\ResponseAdapter;
|
||||
use WapplerSystems\Meilisearch\System\Solr\SolrIncompleteResponseException;
|
||||
use WapplerSystems\Meilisearch\System\Logging\MeilisearchLogManager;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\Document\Document;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\ResponseAdapter;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\MeilisearchIncompleteResponseException;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
use WapplerSystems\Meilisearch\Domain\Search\ResultSet\Result\SearchResultBuilder;
|
||||
use TYPO3\CMS\Extbase\Object\ObjectManager;
|
||||
@@ -79,7 +79,7 @@ class SearchResultSetService
|
||||
/**
|
||||
* @var boolean
|
||||
*/
|
||||
protected $isSolrAvailable = false;
|
||||
protected $isMeilisearchAvailable = false;
|
||||
|
||||
/**
|
||||
* @var TypoScriptConfiguration
|
||||
@@ -87,7 +87,7 @@ class SearchResultSetService
|
||||
protected $typoScriptConfiguration;
|
||||
|
||||
/**
|
||||
* @var SolrLogManager
|
||||
* @var MeilisearchLogManager
|
||||
*/
|
||||
protected $logger = null;
|
||||
|
||||
@@ -109,17 +109,17 @@ class SearchResultSetService
|
||||
/**
|
||||
* @param TypoScriptConfiguration $configuration
|
||||
* @param Search $search
|
||||
* @param SolrLogManager $solrLogManager
|
||||
* @param MeilisearchLogManager $meilisearchLogManager
|
||||
* @param SearchResultBuilder $resultBuilder
|
||||
* @param QueryBuilder $queryBuilder
|
||||
*/
|
||||
public function __construct(TypoScriptConfiguration $configuration, Search $search, SolrLogManager $solrLogManager = null, SearchResultBuilder $resultBuilder = null, QueryBuilder $queryBuilder = null)
|
||||
public function __construct(TypoScriptConfiguration $configuration, Search $search, MeilisearchLogManager $meilisearchLogManager = null, SearchResultBuilder $resultBuilder = null, QueryBuilder $queryBuilder = null)
|
||||
{
|
||||
$this->search = $search;
|
||||
$this->typoScriptConfiguration = $configuration;
|
||||
$this->logger = $solrLogManager ?? GeneralUtility::makeInstance(SolrLogManager::class, /** @scrutinizer ignore-type */ __CLASS__);
|
||||
$this->logger = $meilisearchLogManager ?? GeneralUtility::makeInstance(MeilisearchLogManager::class, /** @scrutinizer ignore-type */ __CLASS__);
|
||||
$this->searchResultBuilder = $resultBuilder ?? GeneralUtility::makeInstance(SearchResultBuilder::class);
|
||||
$this->queryBuilder = $queryBuilder ?? GeneralUtility::makeInstance(QueryBuilder::class, /** @scrutinizer ignore-type */ $configuration, /** @scrutinizer ignore-type */ $solrLogManager);
|
||||
$this->queryBuilder = $queryBuilder ?? GeneralUtility::makeInstance(QueryBuilder::class, /** @scrutinizer ignore-type */ $configuration, /** @scrutinizer ignore-type */ $meilisearchLogManager);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -134,10 +134,10 @@ class SearchResultSetService
|
||||
* @param bool $useCache
|
||||
* @return bool
|
||||
*/
|
||||
public function getIsSolrAvailable($useCache = true)
|
||||
public function getIsMeilisearchAvailable($useCache = true)
|
||||
{
|
||||
$this->isSolrAvailable = $this->search->ping($useCache);
|
||||
return $this->isSolrAvailable;
|
||||
$this->isMeilisearchAvailable = $this->search->ping($useCache);
|
||||
return $this->isMeilisearchAvailable;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -179,8 +179,8 @@ class SearchResultSetService
|
||||
*/
|
||||
protected function getResultSetClassName()
|
||||
{
|
||||
return isset($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['solr']['searchResultSetClassName ']) ?
|
||||
$GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['solr']['searchResultSetClassName '] : SearchResultSet::class;
|
||||
return isset($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['meilisearch']['searchResultSetClassName ']) ?
|
||||
$GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['meilisearch']['searchResultSetClassName '] : SearchResultSet::class;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -204,7 +204,7 @@ class SearchResultSetService
|
||||
$this->initializeRegisteredSearchComponents($query, $searchRequest);
|
||||
$resultSet->setUsedQuery($query);
|
||||
|
||||
// performing the actual search, sending the query to the Solr server
|
||||
// performing the actual search, sending the query to the Meilisearch server
|
||||
$query = $this->modifyQuery($query, $searchRequest, $this->search);
|
||||
$response = $this->doASearch($query, $searchRequest);
|
||||
|
||||
@@ -294,7 +294,7 @@ class SearchResultSetService
|
||||
}
|
||||
|
||||
/**
|
||||
* Executes the search and builds a fake response for a current bug in Apache Solr 6.3
|
||||
* Executes the search and builds a fake response for a current bug in Meilisearch 6.3
|
||||
*
|
||||
* @param Query $query
|
||||
* @param SearchRequest $searchRequest
|
||||
@@ -308,7 +308,7 @@ class SearchResultSetService
|
||||
|
||||
$response = $this->search->search($query, $offSet, null);
|
||||
if($response === null) {
|
||||
throw new SolrIncompleteResponseException('The response retrieved from solr was incomplete', 1505989678);
|
||||
throw new MeilisearchIncompleteResponseException('The response retrieved from meilisearch was incomplete', 1505989678);
|
||||
}
|
||||
|
||||
return $response;
|
||||
@@ -375,19 +375,19 @@ class SearchResultSetService
|
||||
}
|
||||
|
||||
/**
|
||||
* Allows to modify a query before eventually handing it over to Solr.
|
||||
* Allows to modify a query before eventually handing it over to Meilisearch.
|
||||
*
|
||||
* @param Query $query The current query before it's being handed over to Solr.
|
||||
* @param Query $query The current query before it's being handed over to Meilisearch.
|
||||
* @param SearchRequest $searchRequest The searchRequest, relevant in the current context
|
||||
* @param Search $search The search, relevant in the current context
|
||||
* @throws \UnexpectedValueException
|
||||
* @return Query The modified query that is actually going to be given to Solr.
|
||||
* @return Query The modified query that is actually going to be given to Meilisearch.
|
||||
*/
|
||||
protected function modifyQuery(Query $query, SearchRequest $searchRequest, Search $search)
|
||||
{
|
||||
// hook to modify the search query
|
||||
if (is_array($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['solr']['modifySearchQuery'])) {
|
||||
foreach ($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['solr']['modifySearchQuery'] as $classReference) {
|
||||
if (is_array($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['meilisearch']['modifySearchQuery'])) {
|
||||
foreach ($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['meilisearch']['modifySearchQuery'] as $classReference) {
|
||||
$queryModifier = $this->objectManager->get($classReference);
|
||||
|
||||
if ($queryModifier instanceof Modifier) {
|
||||
@@ -413,7 +413,7 @@ class SearchResultSetService
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves a single document from solr by document id.
|
||||
* Retrieves a single document from meilisearch by document id.
|
||||
*
|
||||
* @param string $documentId
|
||||
* @return SearchResult
|
||||
@@ -431,7 +431,7 @@ class SearchResultSetService
|
||||
throw new \UnexpectedValueException("Response did not contain a valid Document object");
|
||||
}
|
||||
|
||||
return $this->searchResultBuilder->fromApacheSolrDocument($resultDocument);
|
||||
return $this->searchResultBuilder->fromApacheMeilisearchDocument($resultDocument);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -443,11 +443,11 @@ class SearchResultSetService
|
||||
*/
|
||||
private function handleSearchHook($eventName, SearchResultSet $resultSet)
|
||||
{
|
||||
if (!is_array($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['solr'][$eventName])) {
|
||||
if (!is_array($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['meilisearch'][$eventName])) {
|
||||
return $resultSet;
|
||||
}
|
||||
|
||||
foreach ($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['solr'][$eventName] as $classReference) {
|
||||
foreach ($GLOBALS['TYPO3_CONF_VARS']['EXTCONF']['meilisearch'][$eventName] as $classReference) {
|
||||
$afterSearchProcessor = $this->objectManager->get($classReference);
|
||||
if ($afterSearchProcessor instanceof SearchResultSetProcessor) {
|
||||
$afterSearchProcessor->process($resultSet);
|
||||
|
@@ -38,13 +38,13 @@ class ScoreCalculationService
|
||||
* Renders an overview of how the score for a certain document has been
|
||||
* calculated.
|
||||
*
|
||||
* @param string $solrDebugData debug data from the solr response
|
||||
* @param string $meilisearchDebugData debug data from the meilisearch response
|
||||
* @param string $queryFields
|
||||
* @return string The HTML showing the score analysis
|
||||
*/
|
||||
public function getRenderedScores($solrDebugData, $queryFields)
|
||||
public function getRenderedScores($meilisearchDebugData, $queryFields)
|
||||
{
|
||||
$highScores = $this->parseScores($solrDebugData, $queryFields);
|
||||
$highScores = $this->parseScores($meilisearchDebugData, $queryFields);
|
||||
return $this->render($highScores);
|
||||
}
|
||||
|
||||
|
@@ -102,8 +102,8 @@ class SearchRequestBuilder
|
||||
|
||||
if ($this->shouldHideResultsFromInitialSearch($searchRequest)) {
|
||||
// initialize search with an empty query, which would by default return all documents
|
||||
// anyway, tell Solr to not return any result documents
|
||||
// Solr will still return facets though
|
||||
// anyway, tell Meilisearch to not return any result documents
|
||||
// Meilisearch will still return facets though
|
||||
$currentNumberOfResultsShown = 0;
|
||||
}
|
||||
|
||||
|
@@ -35,7 +35,7 @@ use WapplerSystems\Meilisearch\Domain\Search\ResultSet\SearchResultSetService;
|
||||
use WapplerSystems\Meilisearch\Domain\Search\SearchRequest;
|
||||
use WapplerSystems\Meilisearch\Search;
|
||||
use WapplerSystems\Meilisearch\System\Configuration\TypoScriptConfiguration;
|
||||
use WapplerSystems\Meilisearch\System\Solr\ParsingUtil;
|
||||
use WapplerSystems\Meilisearch\System\Meilisearch\ParsingUtil;
|
||||
use WapplerSystems\Meilisearch\Util;
|
||||
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
||||
use TYPO3\CMS\Frontend\Controller\TypoScriptFrontendController;
|
||||
@@ -95,15 +95,15 @@ class SuggestService {
|
||||
$groupList = Util::getFrontendUserGroupsList();
|
||||
|
||||
$suggestQuery = $this->queryBuilder->buildSuggestQuery($searchRequest->getRawUserQuery(), $additionalFilters, $requestId, $groupList);
|
||||
$solrSuggestions = $this->getSolrSuggestions($suggestQuery);
|
||||
$meilisearchSuggestions = $this->getMeilisearchSuggestions($suggestQuery);
|
||||
|
||||
if ($solrSuggestions === []) {
|
||||
if ($meilisearchSuggestions === []) {
|
||||
return ['status' => false];
|
||||
}
|
||||
|
||||
$maxSuggestions = $this->typoScriptConfiguration->getSuggestNumberOfSuggestions();
|
||||
$showTopResults = $this->typoScriptConfiguration->getSuggestShowTopResults();
|
||||
$suggestions = $this->getSuggestionArray($suggestQuery, $solrSuggestions, $maxSuggestions);
|
||||
$suggestions = $this->getSuggestionArray($suggestQuery, $meilisearchSuggestions, $maxSuggestions);
|
||||
|
||||
if (!$showTopResults) {
|
||||
return $this->getResultArray($searchRequest, $suggestions, [], false);
|
||||
@@ -155,17 +155,17 @@ class SuggestService {
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves the suggestions from the solr server.
|
||||
* Retrieves the suggestions from the meilisearch server.
|
||||
*
|
||||
* @param SuggestQuery $suggestQuery
|
||||
* @return array
|
||||
*/
|
||||
protected function getSolrSuggestions(SuggestQuery $suggestQuery) : array
|
||||
protected function getMeilisearchSuggestions(SuggestQuery $suggestQuery) : array
|
||||
{
|
||||
$pageId = $this->tsfe->getRequestedId();
|
||||
$languageId = Util::getLanguageUid();
|
||||
$solr = GeneralUtility::makeInstance(ConnectionManager::class)->getConnectionByPageId($pageId, $languageId);
|
||||
$search = GeneralUtility::makeInstance(Search::class, /** @scrutinizer ignore-type */ $solr);
|
||||
$meilisearch = GeneralUtility::makeInstance(ConnectionManager::class)->getConnectionByPageId($pageId, $languageId);
|
||||
$search = GeneralUtility::makeInstance(Search::class, /** @scrutinizer ignore-type */ $meilisearch);
|
||||
$response = $search->search($suggestQuery, 0, 0);
|
||||
|
||||
$rawResponse = $response->getRawResponse();
|
||||
@@ -178,19 +178,19 @@ class SuggestService {
|
||||
}
|
||||
|
||||
/**
|
||||
* Extracts the suggestions from solr as array.
|
||||
* Extracts the suggestions from meilisearch as array.
|
||||
*
|
||||
* @param SuggestQuery $suggestQuery
|
||||
* @param array $solrSuggestions
|
||||
* @param array $meilisearchSuggestions
|
||||
* @param integer $maxSuggestions
|
||||
* @return array
|
||||
*/
|
||||
protected function getSuggestionArray(SuggestQuery $suggestQuery, $solrSuggestions, $maxSuggestions) : array
|
||||
protected function getSuggestionArray(SuggestQuery $suggestQuery, $meilisearchSuggestions, $maxSuggestions) : array
|
||||
{
|
||||
$queryString = $suggestQuery->getQuery();
|
||||
$suggestionCount = 0;
|
||||
$suggestions = [];
|
||||
foreach ($solrSuggestions as $string => $count) {
|
||||
foreach ($meilisearchSuggestions as $string => $count) {
|
||||
$suggestion = trim($queryString . ' ' . $string);
|
||||
$suggestions[$suggestion] = $count;
|
||||
$suggestionCount++;
|
||||
|
Reference in New Issue
Block a user