Completed
Push — master ( afb93c...2180a3 )
by Freek
24:20 queued 09:20
created

Authorized::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 6

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 4
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 6
ccs 4
cts 4
cp 1
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 2
crap 1
1
<?php
2
3
namespace Spatie\ValidationRules\Rules;
4
5
use Illuminate\Support\Facades\Auth;
6
use Illuminate\Contracts\Validation\Rule;
7
8
class Authorized implements Rule
9
{
10
    /** @var string */
11
    protected $ability;
12
13
    /** @var array */
14
    protected $arguments;
15
16
    /** @var string */
17
    protected $className;
18
19
    /** @var string */
20
    protected $attribute;
21
22 30
    public function __construct(string $ability, string $className)
23
    {
24 30
        $this->ability = $ability;
25
26 30
        $this->className = $className;
27 30
    }
28
29 30
    public function passes($attribute, $value): bool
30
    {
31 30
        $this->attribute = $attribute;
32
33 30
        if (! $user = Auth::user()) {
34 24
            return false;
35
        }
36
37 6
        if (! $model = $this->className::find($value)) {
0 ignored issues
show
Bug introduced by
The method find cannot be called on $this->className (of type string).

Methods can only be called on objects. This check looks for methods being called on variables that have been inferred to never be objects.

Loading history...
38
            return false;
39
        }
40
41 6
        return $user->can($this->ability, $model);
42
    }
43
44 6
    public function message(): string
45
    {
46 6
        $classBasename = class_basename($this->className);
47
48 6
        return __('validationRules::messages.authorized', [
49 6
            'attribute' => $this->attribute,
50 6
            'ability' => $this->ability,
51 6
            'className' => $classBasename,
52
        ]);
53
    }
54
}
55