Passed
Push — master ( 2b6758...acf834 )
by Aleksei
06:59
created

MatchRegularExpression::validateValue()   A

Complexity

Conditions 6
Paths 12

Size

Total Lines 13
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 8
CRAP Score 6

Importance

Changes 0
Metric Value
cc 6
eloc 7
nc 12
nop 2
dl 0
loc 13
ccs 8
cts 8
cp 1
crap 6
rs 9.2222
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Validator\Rule;
6
7
use Yiisoft\Validator\DataSetInterface;
8
use Yiisoft\Validator\HasValidationErrorMessage;
9
use Yiisoft\Validator\Result;
10
use Yiisoft\Validator\Rule;
11
12
/**
13
 * RegularExpressionValidator validates that the attribute value matches the specified [[pattern]].
14
 *
15
 * If the [[not]] property is set true, the validator will ensure the attribute value do NOT match the [[pattern]].
16
 */
17
class MatchRegularExpression extends Rule
18
{
19
    use HasValidationErrorMessage;
20
21
    /**
22
     * @var string the regular expression to be matched with
23
     */
24
    private string $pattern;
25
    /**
26
     * @var bool whether to invert the validation logic. Defaults to false. If set to true,
27
     * the regular expression defined via [[pattern]] should NOT match the attribute value.
28
     */
29
    private bool $not = false;
30
31
    private string $message = 'Value is invalid.';
32
33 2
    public function __construct(string $pattern)
34
    {
35 2
        $this->pattern = $pattern;
36 2
    }
37
38 1
    protected function validateValue($value, DataSetInterface $dataSet = null): Result
39
    {
40 1
        $result = new Result();
41
42 1
        $valid = !is_array($value) &&
43 1
            ((!$this->not && preg_match($this->pattern, $value))
44 1
                || ($this->not && !preg_match($this->pattern, $value)));
45
46 1
        if (!$valid) {
47 1
            $result->addError($this->translateMessage($this->message));
48
        }
49
50 1
        return $result;
51
    }
52
53 1
    public function not(): self
54
    {
55 1
        $new = clone $this;
56 1
        $new->not = true;
57 1
        return $new;
58
    }
59
60 2
    public function getOptions(): array
61
    {
62 2
        return array_merge(
63 2
            parent::getOptions(),
64
            [
65 2
                'message' => $this->translateMessage($this->message),
66 2
                'not' => $this->not,
67 2
                'pattern' => $this->pattern,
68
            ],
69
        );
70
    }
71
}
72