-
Simonas Šerlinskas authored
from now, if there is only one query set, there will be no more generated bool query. Also Query class from now on is absolutely not necessary. There is no BC breaks.
Simonas Šerlinskas authoredfrom now, if there is only one query set, there will be no more generated bool query. Also Query class from now on is absolutely not necessary. There is no BC breaks.
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
Query.php 2.71 KiB
<?php
/*
* This file is part of the ONGR package.
*
* (c) NFQ Technologies UAB <info@nfq.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace ONGR\ElasticsearchBundle\DSL\Query;
use ONGR\ElasticsearchBundle\DSL\Bool\Bool;
use ONGR\ElasticsearchBundle\DSL\BuilderInterface;
/**
* Query class.
*
* @deprecated will remove in 1.0 Query container now is implemented directly in search.
*/
class Query implements BuilderInterface
{
/**
* @var BuilderInterface[]
*/
private $queries;
/**
* @var NestedQuery
*
* @deprecated will remove in 1.0 Add NestedQuery to the Query as all other queries.
*/
private $nested = null;
/**
* @param array $boolParams Possible values:
* - disable_coord => true
* - false
* - minimum_should_match
* - boost.
*/
public function __construct($boolParams = [])
{
$this->queries = new Bool();
$this->queries->setParameters($boolParams);
}
/**
* @param BuilderInterface $query Query.
* @param string $boolType Possible boolType values:
* - must
* - must_not
* - should.
*/
public function addQuery(BuilderInterface $query, $boolType = 'must')
{
$this->queries->addToBool($query, $boolType);
}
/**
* Overrides query.
*
* @param BuilderInterface $query
*/
public function setQuery(BuilderInterface $query)
{
$this->queries = $query;
}
/**
* @param array $boolParams Possible values:
* - disable_coord => true
* - false
* - minimum_should_match
* - boost.
*/
public function setBoolParameters($boolParams)
{
$this->queries->setParameters($boolParams);
}
/**
* @param string $path
* @param BuilderInterface $query
*
* @deprecated will remove in 1.0 Add NestedQuery to the Query as all other queries.
*/
public function addToNested($path, $query)
{
$this->nested = new NestedQuery($path, $query);
}
/**
* {@inheritdoc}
*/
public function getType()
{
return 'query';
}
/**
* {@inheritdoc}
*/
public function toArray()
{
$output = [
$this->queries->getType() => $this->queries->toArray(),
];
return $output;
}
}