Cnh   A
last analyzed

Complexity

Total Complexity 6

Size/Duplication

Total Lines 79
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 1
Metric Value
eloc 24
dl 0
loc 79
ccs 25
cts 25
cp 1
rs 10
c 1
b 0
f 1
wmc 6

6 Methods

Rating   Name   Duplication   Size   Complexity  
A createFromString() 0 3 1
A __construct() 0 4 1
A calculateSecondDigit() 0 9 1
A calculateFirstDigit() 0 9 1
A format() 0 3 1
A calculateDigit() 0 6 1
1
<?php
2
3
namespace Brazanation\Documents;
4
5
final class Cnh extends AbstractDocument
6
{
7
    const LENGTH = 11;
8
9
    const LABEL = 'CNH';
10
11
    const REGEX = '/^([\d]{3})([\d]{3})([\d]{4})([\d]{1})$/';
12
13
    const NUMBER_OF_DIGITS = 2;
14
15
    /**
16
     * Cnh constructor.
17
     *
18
     * @param string $cnh Only accept numbers
19
     */
20 10
    public function __construct(string $cnh)
21
    {
22 10
        $cnh = preg_replace('/\D/', '', $cnh);
23 10
        parent::__construct($cnh, self::LENGTH, self::NUMBER_OF_DIGITS, self::LABEL);
24
    }
25
26 5
    public static function createFromString(string $number)
27
    {
28 5
        return parent::tryCreateFromString(self::class, $number, self::LENGTH, self::NUMBER_OF_DIGITS, self::LABEL);
29
    }
30
31
    /**
32
     * {@inheritdoc}
33
     */
34 8
    public function calculateDigit(string $baseNumber) : string
35
    {
36 8
        $firstDigit = $this->calculateFirstDigit($baseNumber);
37 8
        $secondDigit = $this->calculateSecondDigit($baseNumber);
38
39 8
        return "{$firstDigit}{$secondDigit}";
40
    }
41
42
    /**
43
     * {@inheritdoc}
44
     */
45 2
    public function format() : string
46
    {
47 2
        return "{$this}";
48
    }
49
50
    /**
51
     * Calculate check digit from base number.
52
     *
53
     * @param string $baseNumber Base numeric section to be calculate your digit.
54
     *
55
     * @return string Returns a calculated checker digit.
56
     */
57 8
    private function calculateFirstDigit(string $baseNumber) : string
58
    {
59 8
        $calculator = new DigitCalculator($baseNumber);
60 8
        $calculator->withMultipliersInterval(1, 9);
61 8
        $calculator->replaceWhen('0', 10, 11);
62 8
        $calculator->withModule(DigitCalculator::MODULE_11);
63 8
        $firstDigit = $calculator->calculate();
64
65 8
        return "{$firstDigit}";
66
    }
67
68
    /**
69
     * Calculate check digit from base number.
70
     *
71
     * @param string $baseNumber Base numeric section to be calculate your digit.
72
     *
73
     * @return string Returns a calculated checker digit.
74
     */
75 8
    private function calculateSecondDigit(string $baseNumber) : string
76
    {
77 8
        $calculator = new DigitCalculator($baseNumber);
78 8
        $calculator->withMultipliers([9, 8, 7, 6, 5, 4, 3, 2, 1]);
79 8
        $calculator->replaceWhen('0', 10, 11);
80 8
        $calculator->withModule(DigitCalculator::MODULE_11);
81 8
        $secondDigit = $calculator->calculate();
82
83 8
        return "{$secondDigit}";
84
    }
85
}
86