-
Notifications
You must be signed in to change notification settings - Fork 196
/
QueryEndpoint.php
101 lines (86 loc) · 2.15 KB
/
QueryEndpoint.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
<?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\ElasticsearchDSL\SearchEndpoint;
use ONGR\ElasticsearchDSL\BuilderInterface;
use ONGR\ElasticsearchDSL\Query\Compound\BoolQuery;
use ONGR\ElasticsearchDSL\Serializer\Normalizer\OrderedNormalizerInterface;
use Symfony\Component\Serializer\Normalizer\NormalizerInterface;
/**
* Search query dsl endpoint.
*/
class QueryEndpoint extends AbstractSearchEndpoint implements OrderedNormalizerInterface
{
/**
* Endpoint name
*/
const NAME = 'query';
/**
* @var BoolQuery
*/
private $bool;
/**
* @var bool
*/
private $filtersSet = false;
/**
* {@inheritdoc}
*/
public function normalize(NormalizerInterface $normalizer, string $format = null, array $context = [])
{
if (!$this->filtersSet && $this->hasReference('filter_query')) {
/** @var BuilderInterface $filter */
$filter = $this->getReference('filter_query');
$this->addToBool($filter, BoolQuery::FILTER);
$this->filtersSet = true;
}
if (!$this->bool) {
return null;
}
return $this->bool->toArray();
}
/**
* {@inheritdoc}
*/
public function add(BuilderInterface $builder, $key = null)
{
return $this->addToBool($builder, BoolQuery::MUST, $key);
}
/**
* {@inheritdoc}
*/
public function addToBool(BuilderInterface $builder, $boolType = null, $key = null)
{
if (!$this->bool) {
$this->bool = new BoolQuery();
}
return $this->bool->add($builder, $boolType, $key);
}
/**
* {@inheritdoc}
*/
public function getOrder()
{
return 2;
}
/**
* @return BoolQuery
*/
public function getBool()
{
return $this->bool;
}
/**
* {@inheritdoc}
*/
public function getAll($boolType = null)
{
return $this->bool->getQueries($boolType);
}
}