Scrutinizer GitHub App not installed

We could not synchronize checks via GitHub's checks API since Scrutinizer's GitHub App is not installed for this repository.

Install GitHub App

Passed
Push — master ( 9c7550...b7043b )
by Henrique
04:02
created

Cnpj::validate()   B

Complexity

Conditions 10
Paths 13

Size

Total Lines 37
Code Lines 19

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 19
CRAP Score 10.0125

Importance

Changes 0
Metric Value
eloc 19
dl 0
loc 37
ccs 19
cts 20
cp 0.95
rs 7.6666
c 0
b 0
f 0
cc 10
nc 13
nop 1
crap 10.0125

How to fix   Complexity   

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
/*
4
 * This file is part of Respect/Validation.
5
 *
6
 * (c) Alexandre Gomes Gaigalas <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the "LICENSE.md"
9
 * file that was distributed with this source code.
10
 */
11
12
declare(strict_types=1);
13
14
namespace Respect\Validation\Rules;
15
16
use function is_scalar;
17
use function mb_strlen;
18
use function preg_replace;
19
20
/**
21
 * Validates if the input is a Brazilian National Registry of Legal Entities (CNPJ) number.
22
 *
23
 * @author Alexandre Gomes Gaigalas <[email protected]>
24
 * @author Henrique Moody <[email protected]>
25
 * @author Jayson Reis <[email protected]>
26
 * @author Nick Lombard <[email protected]>
27
 * @author Renato Moura <[email protected]>
28
 * @author William Espindola <[email protected]>
29
 */
30
final class Cnpj extends AbstractRule
31
{
32
    /**
33
     * {@inheritdoc}
34
     */
35 33
    public function validate($input): bool
36
    {
37 33
        if (!is_scalar($input)) {
38
            return false;
39
        }
40
41
        // Code ported from jsfromhell.com
42 33
        $cleanInput = preg_replace('/\D/', '', $input);
43 33
        $b = [6, 5, 4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2];
44
45 33
        if ($cleanInput < 1) {
46 2
            return false;
47
        }
48
49 32
        if (14 != mb_strlen($cleanInput)) {
50 5
            return false;
51
        }
52
53 27
        $n = 0;
54 27
        for ($i = 0; $i < 12; ++$i) {
55 27
            $n += $cleanInput[$i] * $b[$i+1];
56
        }
57
58 27
        if ($cleanInput[12] != ((($n %= 11) < 2) ? 0 : 11 - $n)) {
59 14
            return false;
60
        }
61
62 13
        $n = 0;
63 13
        for ($i = 0; $i <= 12; ++$i) {
64 13
            $n += $cleanInput[$i] * $b[$i];
65
        }
66
67 13
        if ($cleanInput[13] != ((($n %= 11) < 2) ? 0 : 11 - $n)) {
68 1
            return false;
69
        }
70
71 12
        return true;
72
    }
73
}
74