Completed
Pull Request — master (#348)
by
unknown
01:15
created

MissingAggregation   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 36
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 2

Importance

Changes 0
Metric Value
wmc 4
lcom 0
cbo 2
dl 0
loc 36
c 0
b 0
f 0
rs 10
1
<?php
2
3
/*
4
 * This file is part of the ONGR package.
5
 *
6
 * (c) NFQ Technologies UAB <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
declare(strict_types=1);
13
14
namespace ONGR\ElasticsearchDSL\Aggregation\Bucketing;
15
16
use ONGR\ElasticsearchDSL\Aggregation\AbstractAggregation;
17
use ONGR\ElasticsearchDSL\Aggregation\Type\BucketingTrait;
18
19
/**
20
 * Class representing missing aggregation.
21
 *
22
 * @link https://www.elastic.co/guide/en/elasticsearch/reference/current/search-aggregations-bucket-missing-aggregation.html
23
 */
24
class MissingAggregation extends AbstractAggregation
25
{
26
    use BucketingTrait;
27
28
    public function __construct(private string $name, private ?string $field = null)
0 ignored issues
show
Bug introduced by
This code did not parse for me. Apparently, there is an error somewhere around this line:

Syntax error, unexpected T_PRIVATE, expecting T_VARIABLE
Loading history...
29
    {
30
        parent::__construct($name);
31
32
        $this->setField($field);
33
    }
34
35
    public function getArray(): array
36
    {
37
        if ($this->getField()) {
38
            return ['field' => $this->getField()];
39
        }
40
41
        throw new \LogicException('Missing aggregation must have a field set.');
42
    }
43
44
    public function getType(): string
45
    {
46
        return 'missing';
47
    }
48
}
49