Completed
Push — master ( bdd757...e0683b )
by ARCANEDEV
11:00
created

Role::loadPermissions()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 2

Importance

Changes 0
Metric Value
dl 0
loc 4
rs 10
c 0
b 0
f 0
ccs 2
cts 2
cp 1
cc 2
eloc 2
nc 2
nop 1
crap 2
1
<?php namespace Arcanedev\LaravelAuth\Models;
2
3
use Arcanedev\LaravelAuth\Bases\Model;
4
use Arcanedev\LaravelAuth\Models\Relationships\RoleRelationships;
5
use Arcanedev\LaravelAuth\Traits\Activatable;
6
use Arcanesoft\Contracts\Auth\Models\Permission as PermissionContract;
7
use Arcanesoft\Contracts\Auth\Models\Role as RoleContract;
8
use Illuminate\Database\Eloquent\Model as Eloquent;
9
use Illuminate\Support\Str;
10
11
/**
12
 * Class     Role
13
 *
14
 * @package  Arcanedev\LaravelAuth\Models
15
 * @author   ARCANEDEV <[email protected]>
16
 *
17
 * @property  int                                       id
18
 * @property  string                                    name
19
 * @property  string                                    slug
20
 * @property  string                                    description
21
 * @property  bool                                      is_active
22
 * @property  bool                                      is_locked
23
 * @property  \Carbon\Carbon                            created_at
24
 * @property  \Carbon\Carbon                            updated_at
25
 * @property  \Illuminate\Database\Eloquent\Collection  users
26
 * @property  \Illuminate\Database\Eloquent\Collection  permissions
27
 */
28
class Role extends Model implements RoleContract
29
{
30
    /* ------------------------------------------------------------------------------------------------
31
     |  Traits
32
     | ------------------------------------------------------------------------------------------------
33
     */
34
    use RoleRelationships, Activatable;
35
36
    /* ------------------------------------------------------------------------------------------------
37
     |  Properties
38
     | ------------------------------------------------------------------------------------------------
39
     */
40
    /**
41
     * The attributes that are mass assignable.
42
     *
43
     * @var array
44
     */
45
    protected $fillable = ['name', 'slug', 'description'];
46
47
    /**
48
     * The attributes that should be casted to native types.
49
     *
50
     * @var array
51
     */
52
    protected $casts = [
53
        'is_active' => 'boolean',
54
        'is_locked' => 'boolean',
55
    ];
56
57
    /* ------------------------------------------------------------------------------------------------
58
     |  Constructor
59
     | ------------------------------------------------------------------------------------------------
60
     */
61
    /**
62
     * Create a new Eloquent model instance.
63
     *
64
     * @param  array  $attributes
65
     */
66 612
    public function __construct(array $attributes = [])
67
    {
68 612
        $this->setTable(config('laravel-auth.roles.table', 'roles'));
69
70 612
        parent::__construct($attributes);
71 612
    }
72
73
    /* ------------------------------------------------------------------------------------------------
74
     |  Getters & Setters
75
     | ------------------------------------------------------------------------------------------------
76
     */
77
    /**
78
     * Set the name attribute.
79
     *
80
     * @param  string  $name
81
     */
82 270
    public function setNameAttribute($name)
83
    {
84 270
        $this->attributes['name'] = $name;
85 270
        $this->setSlugAttribute($name);
86 270
    }
87
88
    /**
89
     * Set the slug attribute.
90
     *
91
     * @param  string  $slug
92
     */
93 270
    public function setSlugAttribute($slug)
94
    {
95 270
        $this->attributes['slug'] = $this->slugify($slug);
96 270
    }
97
98
    /* ------------------------------------------------------------------------------------------------
99
     |  CRUD Functions
100
     | ------------------------------------------------------------------------------------------------
101
     */
102
    /**
103
     * Attach a permission to a role.
104
     *
105
     * @param  \Arcanesoft\Contracts\Auth\Models\User|int  $user
106
     * @param  bool                                        $reload
107
     */
108 27
    public function attachUser($user, $reload = true)
109
    {
110 27
        if ( ! $this->hasUser($user)) {
111 27
            $this->users()->attach($user);
112 27
            $this->loadUsers($reload);
113 9
        }
114 27
    }
115
116
    /**
117
     * Detach a user from a role.
118
     *
119
     * @param  \Arcanesoft\Contracts\Auth\Models\User|int  $user
120
     * @param  bool                                        $reload
121
     *
122
     * @return int
123
     */
124 9
    public function detachUser($user, $reload = true)
125
    {
126 9
        if ($user instanceof Eloquent)
0 ignored issues
show
Bug introduced by
The class Illuminate\Database\Eloquent\Model does not exist. Did you forget a USE statement, or did you not list all dependencies?

This error could be the result of:

1. Missing dependencies

PHP Analyzer uses your composer.json file (if available) to determine the dependencies of your project and to determine all the available classes and functions. It expects the composer.json to be in the root folder of your repository.

Are you sure this class is defined by one of your dependencies, or did you maybe not list a dependency in either the require or require-dev section?

2. Missing use statement

PHP does not complain about undefined classes in ìnstanceof checks. For example, the following PHP code will work perfectly fine:

if ($x instanceof DoesNotExist) {
    // Do something.
}

If you have not tested against this specific condition, such errors might go unnoticed.

Loading history...
127 9
            $user = (array) $user->getKey();
128
129 9
        $result = $this->users()->detach($user);
130 9
        $this->loadUsers($reload);
131
132 9
        return $result;
133
    }
134
135
    /**
136
     * Detach all users from a role.
137
     *
138
     * @param  bool  $reload
139
     *
140
     * @return int
141
     */
142 9
    public function detachAllUsers($reload = true)
143
    {
144 9
        $result = $this->users()->detach();
145 9
        $this->loadUsers($reload);
146
147 9
        return $result;
148
    }
149
150
    /**
151
     * Check if role has the given user (User Model or Id).
152
     *
153
     * @param  \Arcanesoft\Contracts\Auth\Models\User|int  $id
154
     *
155
     * @return bool
156
     */
157 27
    public function hasUser($id)
158
    {
159 27
        if ($id instanceof Eloquent)
0 ignored issues
show
Bug introduced by
The class Illuminate\Database\Eloquent\Model does not exist. Did you forget a USE statement, or did you not list all dependencies?

This error could be the result of:

1. Missing dependencies

PHP Analyzer uses your composer.json file (if available) to determine the dependencies of your project and to determine all the available classes and functions. It expects the composer.json to be in the root folder of your repository.

Are you sure this class is defined by one of your dependencies, or did you maybe not list a dependency in either the require or require-dev section?

2. Missing use statement

PHP does not complain about undefined classes in ìnstanceof checks. For example, the following PHP code will work perfectly fine:

if ($x instanceof DoesNotExist) {
    // Do something.
}

If you have not tested against this specific condition, such errors might go unnoticed.

Loading history...
160 27
            $id = $id->getKey();
161
162 27
        return $this->users->contains($id);
163
    }
164
165
    /**
166
     * Attach a permission to a role.
167
     *
168
     * @param  \Arcanesoft\Contracts\Auth\Models\Permission|int  $permission
169
     * @param  bool                                              $reload
170
     */
171 81
    public function attachPermission($permission, $reload = true)
172
    {
173 81
        if ( ! $this->hasPermission($permission)) {
174 81
            $this->permissions()->attach($permission);
175 81
            $this->loadPermissions($reload);
176 27
        }
177 81
    }
178
179
    /**
180
     * Detach a permission from a role.
181
     *
182
     * @param  \Arcanesoft\Contracts\Auth\Models\Permission|int  $permission
183
     * @param  bool                                              $reload
184
     *
185
     * @return int
186
     */
187 9
    public function detachPermission($permission, $reload = true)
188
    {
189 9
        if ($permission instanceof Eloquent)
0 ignored issues
show
Bug introduced by
The class Illuminate\Database\Eloquent\Model does not exist. Did you forget a USE statement, or did you not list all dependencies?

This error could be the result of:

1. Missing dependencies

PHP Analyzer uses your composer.json file (if available) to determine the dependencies of your project and to determine all the available classes and functions. It expects the composer.json to be in the root folder of your repository.

Are you sure this class is defined by one of your dependencies, or did you maybe not list a dependency in either the require or require-dev section?

2. Missing use statement

PHP does not complain about undefined classes in ìnstanceof checks. For example, the following PHP code will work perfectly fine:

if ($x instanceof DoesNotExist) {
    // Do something.
}

If you have not tested against this specific condition, such errors might go unnoticed.

Loading history...
190 9
            $permission = (array) $permission->getKey();
191
192 9
        $result = $this->permissions()->detach($permission);
193 9
        $this->loadPermissions($reload);
194
195 9
        return $result;
196
    }
197
198
    /**
199
     * Detach all permissions from a role.
200
     *
201
     * @param  bool  $reload
202
     *
203
     * @return int
204
     */
205 9
    public function detachAllPermissions($reload = true)
206
    {
207 9
        $result = $this->permissions()->detach();
208 9
        $this->loadPermissions($reload);
209
210 9
        return $result;
211
    }
212
213
    /**
214
     * Check if role has the given permission (Permission Model or Id).
215
     *
216
     * @param  mixed  $id
217
     *
218
     * @return bool
219
     */
220 81
    public function hasPermission($id)
221
    {
222 81
        if ($id instanceof Eloquent)
0 ignored issues
show
Bug introduced by
The class Illuminate\Database\Eloquent\Model does not exist. Did you forget a USE statement, or did you not list all dependencies?

This error could be the result of:

1. Missing dependencies

PHP Analyzer uses your composer.json file (if available) to determine the dependencies of your project and to determine all the available classes and functions. It expects the composer.json to be in the root folder of your repository.

Are you sure this class is defined by one of your dependencies, or did you maybe not list a dependency in either the require or require-dev section?

2. Missing use statement

PHP does not complain about undefined classes in ìnstanceof checks. For example, the following PHP code will work perfectly fine:

if ($x instanceof DoesNotExist) {
    // Do something.
}

If you have not tested against this specific condition, such errors might go unnoticed.

Loading history...
223 81
            $id = $id->getKey();
224
225 81
        return $this->permissions->contains($id);
226
    }
227
228
    /* ------------------------------------------------------------------------------------------------
229
     |  Check Functions
230
     | ------------------------------------------------------------------------------------------------
231
     */
232
    /**
233
     * Check if role is associated with a permission by slug.
234
     *
235
     * @param  string  $slug
236
     *
237
     * @return bool
238
     */
239
    public function can($slug)
240
    {
241 27
        $permissions = $this->permissions->filter(function(PermissionContract $permission) use ($slug) {
242 27
            return $permission->checkSlug($slug);
243 27
        });
244
245 27
        return $permissions->count() === 1;
246
    }
247
248
    /**
249
     * Check if a role is associated with any of given permissions.
250
     *
251
     * @param  array  $permissions
252
     * @param  array  &$failedPermissions
253
     *
254
     * @return bool
255
     */
256 18
    public function canAny(array $permissions, array &$failedPermissions = [])
257
    {
258 18
        foreach ($permissions as $permission) {
259 18
            if ( ! $this->can($permission))
260 18
                $failedPermissions[] = $permission;
261 6
        }
262
263 18
        return count($permissions) !== count($failedPermissions);
264
    }
265
266
    /**
267
     * Check if role is associated with all given permissions.
268
     *
269
     * @param  array  $permissions
270
     * @param  array  &$failedPermissions
271
     *
272
     * @return bool
273
     */
274 9
    public function canAll(array $permissions, array &$failedPermissions = [])
275
    {
276 9
        $this->canAny($permissions, $failedPermissions);
277
278 9
        return count($failedPermissions) === 0;
279
    }
280
281
    /**
282
     * Check if the role is locked.
283
     *
284
     * @return bool
285
     */
286 18
    public function isLocked()
287
    {
288 18
        return $this->is_locked;
289
    }
290
291
    /**
292
     * Check if slug is the same as the given value.
293
     *
294
     * @param  string  $value
295
     *
296
     * @return bool
297
     */
298 54
    public function checkSlug($value)
299
    {
300 54
        return $this->slug === $this->slugify($value);
301
    }
302
303
    /* ------------------------------------------------------------------------------------------------
304
     |  Other Functions
305
     | ------------------------------------------------------------------------------------------------
306
     */
307
    /**
308
     * Load the users.
309
     *
310
     * @param  bool  $load
311
     *
312
     * @return self
313
     */
314 27
    protected function loadUsers($load = true)
315
    {
316 27
        return $load ? $this->load('users') : $this;
317
    }
318
319
    /**
320
     * Load the permissions.
321
     *
322
     * @param  bool  $load
323
     *
324
     * @return self
325
     */
326 81
    protected function loadPermissions($load = true)
327
    {
328 81
        return $load ? $this->load('permissions') : $this;
329
    }
330
331
    /**
332
     * Slugify the value.
333
     *
334
     * @param  string  $value
335
     *
336
     * @return string
337
     */
338 270
    protected function slugify($value)
339
    {
340 270
        return Str::slug($value, config('laravel-auth.roles.slug-separator', '-'));
341
    }
342
}
343