Passed
Pull Request — master (#303)
by
unknown
02:26
created

EachHandler::validate()   B

Complexity

Conditions 9
Paths 6

Size

Total Lines 51
Code Lines 30

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 28
CRAP Score 9.0033

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 30
c 1
b 0
f 0
dl 0
loc 51
ccs 28
cts 29
cp 0.9655
rs 8.0555
cc 9
nc 6
nop 3
crap 9.0033

How to fix   Long Method   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Validator\Rule;
6
7
use InvalidArgumentException;
8
use Yiisoft\Validator\Exception\UnexpectedRuleException;
9
use Yiisoft\Validator\Formatter;
10
use Yiisoft\Validator\FormatterInterface;
11
use Yiisoft\Validator\Result;
12
use Yiisoft\Validator\RuleHandlerInterface;
13
use Yiisoft\Validator\RuleInterface;
14
use Yiisoft\Validator\ValidationContext;
15
16
/**
17
 * Validates an array by checking each of its elements against a set of rules.
18
 */
19
final class EachHandler implements RuleHandlerInterface
20
{
21
    private FormatterInterface $formatter;
22
23 12
    public function __construct(?FormatterInterface $formatter = null)
24
    {
25 12
        $this->formatter = $formatter ?? new Formatter();
26
    }
27
28 11
    public function validate(mixed $value, object $rule, ValidationContext $context): Result
29
    {
30 11
        if (!$rule instanceof Each) {
31 1
            throw new UnexpectedRuleException(Each::class, $rule);
32
        }
33
34
        /** @var Each $eachRule */
35 10
        $eachRule = $rule;
36
37 10
        $rules = $rule->getRules();
38 10
        if ($rules === []) {
39
            throw new InvalidArgumentException('Rules are required.');
40
        }
41
42 10
        $result = new Result();
43 10
        if (!is_iterable($value)) {
44 1
            $formattedMessage = $this->formatter->format(
45 1
                $rule->getIncorrectInputMessage(),
46 1
                ['attribute' => $context->getAttribute(), 'value' => $value]
47
            );
48 1
            $result->addError($formattedMessage);
49
50 1
            return $result;
51
        }
52
53 9
        foreach ($value as $index => $item) {
54
            /** @var array<mixed, \Closure|\Closure[]|RuleInterface|RuleInterface[]> $rule */
55 9
            $rule = [$index => $rules];
56 9
            $itemResult = $context->getValidator()->validate($item, $rule);
57 9
            if ($itemResult->isValid()) {
58 8
                continue;
59
            }
60
61 8
            foreach ($itemResult->getErrors() as $error) {
62 8
                if ($error->getValuePath() === []) {
63 7
                    $errorKey = [$index];
64 7
                    $formatMessage = true;
65
                } else {
66 5
                    $errorKey = [$index, ...$error->getValuePath()];
67 5
                    $formatMessage = false;
68
                }
69
70 8
                $message = !$formatMessage ? $error->getMessage() : $this->formatter->format($eachRule->getMessage(), [
71 7
                    'error' => $error->getMessage(),
72
                    'value' => $item,
73
                ]);
74 8
                $result->addError($message, $errorKey);
75
            }
76
        }
77
78 9
        return $result;
79
    }
80
}
81