* All rights reserved * * This script is part of the TYPO3 project. The TYPO3 project is * free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * The GNU General Public License can be found at * http://www.gnu.org/copyleft/gpl.html. * * This script is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * This copyright notice MUST APPEAR in all copies of the script! ***************************************************************/ use WapplerSystems\Meilisearch\Domain\Search\Query\QueryBuilder; use WapplerSystems\Meilisearch\Domain\Search\Query\Query; use WapplerSystems\Meilisearch\Domain\Search\SearchRequest; use WapplerSystems\Meilisearch\Domain\Search\SearchRequestAware; use TYPO3\CMS\Core\Utility\GeneralUtility; /** * Debug search component * * * @author Ingo Renner */ class DebugComponent extends AbstractComponent implements QueryAware, SearchRequestAware { /** * Solr query * * @var Query */ protected $query; /** * @var SearchRequest */ protected $seachRequest; /** * QueryBuilder * * @var QueryBuilder|object */ protected $queryBuilder; /** * AccessComponent constructor. * @param QueryBuilder|null */ public function __construct(QueryBuilder $queryBuilder = null) { $this->queryBuilder = $queryBuilder ?? GeneralUtility::makeInstance(QueryBuilder::class); } /** * Provides a component that is aware of the current SearchRequest * * @param SearchRequest $searchRequest */ public function setSearchRequest(SearchRequest $searchRequest) { $this->seachRequest = $searchRequest; } /** * Initializes the search component. * * Sets the debug query parameter * */ public function initializeSearchComponent() { if ($this->seachRequest->getContextTypoScriptConfiguration()->getEnabledDebugMode()) { $this->queryBuilder->startFrom($this->query)->useDebug(true); } } /** * Provides the extension component with an instance of the current query. * * @param Query $query Current query */ public function setQuery(Query $query) { $this->query = $query; } }