Completed
Pull Request — master (#348)
by
unknown
09:42 queued 08:20
created

BoostingQuery   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 51
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 1

Importance

Changes 0
Metric Value
wmc 3
c 0
b 0
f 0
lcom 1
cbo 1
dl 0
loc 51
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\Query\Compound;
15
16
use ONGR\ElasticsearchDSL\BuilderInterface;
17
18
/**
19
 * Represents Elasticsearch "boosting" query.
20
 *
21
 * @link https://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-boosting-query.html
22
 */
23
class BoostingQuery implements BuilderInterface
24
{
25
    public function __construct(
26
        private BuilderInterface $positive,
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...
27
        private BuilderInterface $negative,
28
        private int|float $negativeBoost
29
    ) {
30
31
    }
32
33
    public function getType(): string
34
    {
35
        return 'boosting';
36
    }
37
38
    public function toArray(): array
39
    {
40
        $query = [
41
            'positive' => $this->positive->toArray(),
42
            'negative' => $this->negative->toArray(),
43
            'negative_boost' => $this->negativeBoost,
44
        ];
45
46
        return [$this->getType() => $query];
47
    }
48
}
49