blob: 06f6daea441ad001bb989299f619cbe6ac356cbc (
plain)
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
|
<?php
namespace Elastica\Filter;
/**
* Multi Abstract filter object. Should be extended by filter types composed of an array of sub filters.
*
* @author Nicolas Ruflin <spam@ruflin.com>
*/
abstract class AbstractMulti extends AbstractFilter
{
/**
* Filters.
*
* @var array
*/
protected $_filters = array();
/**
* @param \Elastica\Filter\AbstractFilter $filters
*/
public function __construct(array $filters = array())
{
if (!empty($filters)) {
$this->setFilters($filters);
}
}
/**
* Add filter.
*
* @param \Elastica\Filter\AbstractFilter $filter
*
* @return $this
*/
public function addFilter(AbstractFilter $filter)
{
$this->_filters[] = $filter->toArray();
return $this;
}
/**
* Set filters.
*
* @param array $filters
*
* @return $this
*/
public function setFilters(array $filters)
{
$this->_filters = array();
foreach ($filters as $filter) {
$this->addFilter($filter);
}
return $this;
}
/**
* @return array Filters
*/
public function getFilters()
{
return $this->_filters;
}
/**
* @see \Elastica\Param::toArray()
*
* @return array
*/
public function toArray()
{
$data = parent::toArray();
$name = $this->_getBaseName();
$filterData = $data[$name];
if (empty($filterData)) {
$filterData = $this->_filters;
} else {
$filterData['filters'] = $this->_filters;
}
$data[$name] = $filterData;
return $data;
}
}
|