Passed
Pull Request — master (#165)
by Sergei
02:36
created

EqualsNullHandler::getFilterClass()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 0
Metric Value
eloc 1
c 0
b 0
f 0
dl 0
loc 3
ccs 2
cts 2
cp 1
rs 10
cc 1
nc 1
nop 0
crap 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Data\Reader\Iterable\FilterHandler;
6
7
use InvalidArgumentException;
8
use Yiisoft\Arrays\ArrayHelper;
9
use Yiisoft\Data\Reader\Filter\EqualsNull;
10
use Yiisoft\Data\Reader\FilterInterface;
11
use Yiisoft\Data\Reader\Iterable\IterableFilterHandlerInterface;
12
13
/**
14
 * `EqualsNull` iterable filter handler checks that the item's field value is null.
15
 */
16
final class EqualsNullHandler implements IterableFilterHandlerInterface
17
{
18 143
    public function getFilterClass(): string
19
    {
20 143
        return EqualsNull::class;
21
    }
22
23 9
    public function match(array|object $item, FilterInterface $filter, array $iterableFilterHandlers): bool
24
    {
25
        /** @var EqualsNull $filter */
26
27 9
        return ArrayHelper::getValue($item, $filter->field) === null;
0 ignored issues
show
Bug introduced by
Accessing field on the interface Yiisoft\Data\Reader\FilterInterface suggest that you code against a concrete implementation. How about adding an instanceof check?
Loading history...
28
    }
29
}
30