Test Failed
Pull Request — 1.x (#84)
by
unknown
03:49
created

ValidPhoneNumber::isPhoneNumberValid()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 9
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
eloc 4
nc 2
nop 1
dl 0
loc 9
rs 10
c 1
b 0
f 0
1
<?php
2
3
namespace Milwad\LaravelValidate\Rules;
4
5
use Closure;
6
use Illuminate\Contracts\Validation\ValidationRule;
0 ignored issues
show
Bug introduced by
The type Illuminate\Contracts\Validation\ValidationRule was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
7
use Milwad\LaravelValidate\Utils\CountryPhoneCallback;
8
9
class ValidPhoneNumber implements ValidationRule
10
{
11
    public function __construct(
12
        protected ?string $code = null
13
    ){}
14
15
    /**
16
     * Check phone number is valid.
17
     *
18
     * @param string $attribute
19
     * @param mixed $value
20
     * @param Closure $fail
21
     * @return void
22
     */
23
    public function validate(string $attribute, mixed $value, Closure $fail): void
24
    {
25
        if (! $this->isPhoneNumberValid($value)) {
26
27
            $fail('validate.phone-number')->translate();
28
        }
29
    }
30
31
    /**
32
     * Check if phone number is valid
33
     *
34
     * @param mixed $value
35
     * @return bool
36
     */
37
    private function isPhoneNumberValid(mixed $value): bool
38
    {
39
        if (is_string($this->code)) {
40
            $passes = (new CountryPhoneCallback($value, $this->code))->callPhoneValidator();
41
42
            return collect($passes)->some(fn ($passe) => $passe);
0 ignored issues
show
Bug introduced by
$passes of type array is incompatible with the type Illuminate\Contracts\Support\Arrayable expected by parameter $value of collect(). ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

42
            return collect(/** @scrutinizer ignore-type */ $passes)->some(fn ($passe) => $passe);
Loading history...
43
        }
44
45
        return preg_match('/^[\+]?[(]?[0-9]{3}[)]?[-\s\.]?[0-9]{3}[-\s\.]?[0-9]{4,6}$/', $value);
0 ignored issues
show
Bug Best Practice introduced by
The expression return preg_match('/^[\+...?[0-9]{4,6}$/', $value) returns the type integer which is incompatible with the type-hinted return boolean.
Loading history...
46
    }
47
}
48