Field::__invoke()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 9
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 2

Importance

Changes 0
Metric Value
cc 2
eloc 4
nc 2
nop 2
dl 0
loc 9
ccs 5
cts 5
cp 1
crap 2
rs 10
c 0
b 0
f 0
1
<?php
2
3
namespace Mbright\Validation\Rule\Sanitize;
4
5
class Field implements SanitizeRuleInterface
6
{
7
    /** @var string */
8
    protected $otherField;
9
10
    /**
11
     * @param string $other_field The name of the other subject field.
12
     */
13 18
    public function __construct(string $otherField)
14
    {
15 18
        $this->otherField = $otherField;
16 18
    }
17
18
    /**
19
     * Modifies the field value to match that of another field.
20
     *
21
     * @param object $subject The subject to be filtered.
22
     * @param string $field The subject field name.
23
     *
24
     * @return bool True if the value was sanitized, false if not.
25
     */
26 18
    public function __invoke($subject, string $field): bool
27
    {
28
        // the other field needs to exist and *not* be null
29 18
        if (! isset($subject->{$this->otherField})) {
30 3
            return false;
31
        }
32 15
        $subject->$field = $subject->{$this->otherField};
33
34 15
        return true;
35
    }
36
}
37