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
Pull Request — master (#1087)
by Henrique
02:56
created

Cnpj::isValid()   B

Complexity

Conditions 10
Paths 13

Size

Total Lines 31
Code Lines 15

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 15
CRAP Score 10.0244

Importance

Changes 0
Metric Value
cc 10
eloc 15
nc 13
nop 1
dl 0
loc 31
ccs 15
cts 16
cp 0.9375
crap 10.0244
rs 7.6666
c 0
b 0
f 0

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 Gaigalas <[email protected]>
24
 * @author Henrique Moody <[email protected]>
25
 * @author Jayson Reis <[email protected]>
26
 * @author Renato Moura <[email protected]>
27
 * @author Nick Lombard <[email protected]>
28
 * @author William Espindola <[email protected]>
29
 */
30
final class Cnpj extends AbstractRule
31
{
32
    /**
33
     * {@inheritdoc}
34
     */
35 33
    public function isValid($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
        for ($i = 0, $n = 0; $i < 12; $n += $cleanInput[$i] * $b[++$i]);
54
55 27
        if ($cleanInput[12] != ((($n %= 11) < 2) ? 0 : 11 - $n)) {
56 14
            return false;
57
        }
58
59 13
        for ($i = 0, $n = 0; $i <= 12; $n += $cleanInput[$i] * $b[$i++]);
60
61 13
        if ($cleanInput[13] != ((($n %= 11) < 2) ? 0 : 11 - $n)) {
62 1
            return false;
63
        }
64
65 12
        return true;
66
    }
67
}
68