@@ 22-85 (lines=64) @@ | ||
19 | * |
|
20 | * @link https://goo.gl/yzXvqD |
|
21 | */ |
|
22 | class DiversifiedSamplerAggregation extends AbstractAggregation |
|
23 | { |
|
24 | use BucketingTrait; |
|
25 | ||
26 | /** |
|
27 | * Defines how many results will be received from each shard |
|
28 | * @param integer $shardSize |
|
29 | */ |
|
30 | private $shardSize; |
|
31 | ||
32 | /** |
|
33 | * DiversifiedSamplerAggregation constructor. |
|
34 | * |
|
35 | * @param string $name Aggregation name |
|
36 | * @param string $field Elasticsearch field name |
|
37 | * @param int $shardSize Shard size, by default it's 100 |
|
38 | */ |
|
39 | public function __construct($name, $field = null, $shardSize = null) |
|
40 | { |
|
41 | parent::__construct($name); |
|
42 | ||
43 | $this->setField($field); |
|
44 | $this->setShardSize($shardSize); |
|
45 | } |
|
46 | ||
47 | /** |
|
48 | * @return mixed |
|
49 | */ |
|
50 | public function getShardSize() |
|
51 | { |
|
52 | return $this->shardSize; |
|
53 | } |
|
54 | ||
55 | /** |
|
56 | * @param mixed $shardSize |
|
57 | */ |
|
58 | public function setShardSize($shardSize) |
|
59 | { |
|
60 | $this->shardSize = $shardSize; |
|
61 | } |
|
62 | ||
63 | /** |
|
64 | * @inheritdoc |
|
65 | */ |
|
66 | public function getType() |
|
67 | { |
|
68 | return 'diversified_sampler'; |
|
69 | } |
|
70 | ||
71 | /** |
|
72 | * @inheritdoc |
|
73 | */ |
|
74 | protected function getArray() |
|
75 | { |
|
76 | $out = array_filter( |
|
77 | [ |
|
78 | 'field' => $this->getField(), |
|
79 | 'shard_size' => $this->getShardSize(), |
|
80 | ] |
|
81 | ); |
|
82 | ||
83 | return $out; |
|
84 | } |
|
85 | } |
|
86 |
@@ 22-85 (lines=64) @@ | ||
19 | * |
|
20 | * @link https://www.elastic.co/guide/en/elasticsearch/reference/2.3/search-aggregations-bucket-sampler-aggregation.html |
|
21 | */ |
|
22 | class SamplerAggregation extends AbstractAggregation |
|
23 | { |
|
24 | use BucketingTrait; |
|
25 | ||
26 | /** |
|
27 | * Defines how many results will be received from each shard |
|
28 | * @param string $shardSize |
|
29 | */ |
|
30 | private $shardSize; |
|
31 | ||
32 | /** |
|
33 | * Inner aggregations container init. |
|
34 | * |
|
35 | * @param string $name |
|
36 | * @param string $field |
|
37 | * @param int $shardSize |
|
38 | */ |
|
39 | public function __construct($name, $field = null, $shardSize = null) |
|
40 | { |
|
41 | parent::__construct($name); |
|
42 | ||
43 | $this->setField($field); |
|
44 | $this->setShardSize($shardSize); |
|
45 | } |
|
46 | ||
47 | /** |
|
48 | * @return int |
|
49 | */ |
|
50 | public function getShardSize() |
|
51 | { |
|
52 | return $this->shardSize; |
|
53 | } |
|
54 | ||
55 | /** |
|
56 | * @param int $shardSize |
|
57 | */ |
|
58 | public function setShardSize($shardSize) |
|
59 | { |
|
60 | $this->shardSize = $shardSize; |
|
61 | } |
|
62 | ||
63 | /** |
|
64 | * {@inheritdoc} |
|
65 | */ |
|
66 | public function getType() |
|
67 | { |
|
68 | return 'sampler'; |
|
69 | } |
|
70 | ||
71 | /** |
|
72 | * {@inheritdoc} |
|
73 | */ |
|
74 | public function getArray() |
|
75 | { |
|
76 | $out = array_filter( |
|
77 | [ |
|
78 | 'field' => $this->getField(), |
|
79 | 'shard_size' => $this->getShardSize(), |
|
80 | ] |
|
81 | ); |
|
82 | ||
83 | return $out; |
|
84 | } |
|
85 | } |
|
86 |