Completed
Push — update_docs ( 6b821b )
by Laurent
128:10 queued 119:52
created

PhoneField   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 31
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 1

Importance

Changes 0
Metric Value
wmc 5
lcom 0
cbo 1
dl 0
loc 31
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
/*
6
 * This file is part of the Tests package.
7
 *
8
 * (c) Dev-Int Création <[email protected]>.
9
 *
10
 * For the full copyright and license information, please view the LICENSE
11
 * file that was distributed with this source code.
12
 */
13
14
namespace Domain\Model\Common\VO;
15
16
use Domain\Model\Common\Exception\InvalidPhone;
17
18
final class PhoneField
19
{
20
    private string $phone;
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_STRING, expecting T_FUNCTION or T_CONST
Loading history...
21
22
    public function __construct(string $phone)
23
    {
24
        if (false === \filter_var($phone, \FILTER_SANITIZE_NUMBER_INT)) {
25
            throw new InvalidPhone();
26
        }
27
28
        $phoneSanitized = \filter_var($phone, \FILTER_SANITIZE_NUMBER_INT);
29
        $phoneToCheck = \str_replace('-', '', $phoneSanitized);
30
31
        if (10 > \strlen($phoneToCheck) || \strlen($phoneToCheck) > 14) {
32
            throw new InvalidPhone();
33
        }
34
35
        $this->phone = $phoneSanitized;
36
    }
37
38
    public static function fromString(string $phone): self
39
    {
40
        return new self($phone);
41
    }
42
43
    public function getValue(): string
44
    {
45
        return $this->phone;
46
    }
47
}
48