Test Failed
Pull Request — 1.x (#56)
by
unknown
11:07
created

ValidDuplicateCharacter   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 16
Duplicated Lines 0 %

Importance

Changes 1
Bugs 1 Features 0
Metric Value
eloc 4
dl 0
loc 16
rs 10
c 1
b 1
f 0
wmc 2

1 Method

Rating   Name   Duplication   Size   Complexity  
A validate() 0 6 2
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
8
class ValidDuplicateCharacter implements ValidationRule
9
{
10
    /**
11
     * Check duplicate characters, splitted by comma.
12
     *
13
     * @param string $attribute
14
     * @param mixed $value
15
     * @param Closure $fail
16
     * @return void
17
     */
18
    public function validate(string $attribute, mixed $value, Closure $fail): void
19
    {
20
        $value = explode(',', $value);
21
22
        if (! collect($value)->duplicates()->isEmpty()) {
0 ignored issues
show
Bug introduced by
$value of type string[] 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

22
        if (! collect(/** @scrutinizer ignore-type */ $value)->duplicates()->isEmpty()) {
Loading history...
23
            $fail('validate.duplicate_character')->translate();
24
        }
25
    }
26
}
27