src/module-elasticsuite-catalog/Model/Product/Search/Request/Container/Filter/SearchBlacklist.php
<?php
/**
* DISCLAIMER
*
* Do not edit or add to this file if you wish to upgrade Smile ElasticSuite to newer
* versions in the future.
*
* @category Smile
* @package Smile\ElasticSuiteCatalog
* @author Romain Ruaud <romain.ruaud@smile.fr>
* @copyright 2020 Smile
* @license Open Software License ("OSL") v. 3.0
*/
namespace Smile\ElasticsuiteCatalog\Model\Product\Search\Request\Container\Filter;
use Smile\ElasticsuiteCore\Api\Search\Request\Container\FilterInterface;
use Smile\ElasticsuiteCore\Search\Request\QueryInterface;
/**
* Search Blacklist filter implementation
*
* @category Smile
* @package Smile\ElasticSuiteCatalog
* @author Romain Ruaud <romain.ruaud@smile.fr>
*/
class SearchBlacklist implements FilterInterface
{
/**
* @var \Smile\ElasticsuiteCore\Search\Request\Query\QueryFactory
*/
private $queryFactory;
/**
* @var \Smile\ElasticsuiteCore\Api\Search\ContextInterface
*/
private $searchContext;
/**
* Search Blacklist filter constructor.
*
* @param \Smile\ElasticsuiteCore\Search\Request\Query\QueryFactory $queryFactory Query Factory
* @param \Smile\ElasticsuiteCore\Api\Search\ContextInterface $searchContext Current search context.
*/
public function __construct(
\Smile\ElasticsuiteCore\Search\Request\Query\QueryFactory $queryFactory,
\Smile\ElasticsuiteCore\Api\Search\ContextInterface $searchContext
) {
$this->queryFactory = $queryFactory;
$this->searchContext = $searchContext;
}
/**
* {@inheritDoc}
*/
public function getFilterQuery()
{
$query = null;
if (($this->getSearchQueryId() !== null) && $this->searchContext->isBlacklistingApplied()) {
$query = $this->getIsNotBlacklistedQuery((int) $this->getSearchQueryId());
}
return $query;
}
/**
* Returns search query id.
*
* @return NULL|integer
*/
private function getSearchQueryId()
{
$queryId = null;
if ($this->searchContext->getCurrentSearchQuery()) {
$queryId = $this->searchContext->getCurrentSearchQuery()->getId();
}
return $queryId;
}
/**
* Create the "is not blacklisted" query according to context parameters.
*
* @param int $value The nested query field id value
*
* @return \Smile\ElasticsuiteCore\Search\Request\QueryInterface
*/
private function getIsNotBlacklistedQuery($value)
{
$isBlacklisted = $this->queryFactory->create(
QueryInterface::TYPE_NESTED,
[
'path' => 'search_query',
'query' => $this->queryFactory->create(
QueryInterface::TYPE_BOOL,
[
'must' => [
$this->queryFactory->create(
QueryInterface::TYPE_TERM,
['field' => 'search_query.query_id', 'value' => $value]
),
$this->queryFactory->create(
QueryInterface::TYPE_TERM,
['field' => 'search_query.is_blacklisted', 'value' => true]
),
],
]
),
]
);
$notBlacklisted = $this->queryFactory->create(QueryInterface::TYPE_NOT, ['query' => $isBlacklisted]);
return $notBlacklisted;
}
}