<?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\Filter; use ONGR\ElasticsearchBundle\DSL\BuilderInterface; use ONGR\ElasticsearchBundle\DSL\ParametersTrait; /** * Represents Elasticsearch "and" filter. * * @link http://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-and-filter.html */ class AndFilter implements BuilderInterface { use ParametersTrait; /** * @var array */ private $filters = []; /** * @param BuilderInterface[] $filters Filter array. * @param array $parameters Optional parameters. */ public function __construct(array $filters = [], array $parameters = []) { $this->set($filters); $this->setParameters($parameters); } /** * Sets filters. * * @param BuilderInterface[] $filters Filter array. */ public function set(array $filters) { foreach ($filters as $filter) { $this->add($filter); } } /** * Adds filter. * * @param BuilderInterface $filter * * @return AndFilter */ public function add(BuilderInterface $filter) { $this->filters[] = [$filter->getType() => $filter->toArray()]; return $this; } /** * Clears filters. */ public function clear() { $this->filters = []; } /** * {@inheritdoc} */ public function toArray() { $query = $this->processArray(); if (count($query) > 0) { $query['filters'] = $this->filters; } else { $query = $this->filters; } return $query; } /** * {@inheritdoc} */ public function getType() { return 'and'; } }