añadir funicionalidades de permisos y grupos
This commit is contained in:
@@ -4,6 +4,7 @@ namespace App\Models;
|
||||
|
||||
// use Illuminate\Contracts\Auth\MustVerifyEmail;
|
||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||
use Illuminate\Database\Eloquent\SoftDeletes;
|
||||
use Illuminate\Foundation\Auth\User as Authenticatable;
|
||||
use Illuminate\Notifications\Notifiable;
|
||||
use Illuminate\Support\Str;
|
||||
@@ -12,8 +13,7 @@ use Spatie\Permission\Traits\HasRoles;
|
||||
class User extends Authenticatable
|
||||
{
|
||||
/** @use HasFactory<\Database\Factories\UserFactory> */
|
||||
use HasFactory, Notifiable;
|
||||
use HasRoles;
|
||||
use HasFactory, Notifiable, HasRoles, SoftDeletes;
|
||||
|
||||
/**
|
||||
* The attributes that are mass assignable.
|
||||
@@ -60,4 +60,34 @@ class User extends Authenticatable
|
||||
->map(fn (string $name) => Str::of($name)->substr(0, 1))
|
||||
->implode('');
|
||||
}
|
||||
|
||||
public function groups()
|
||||
{
|
||||
return $this->belongsToMany(Group::class)
|
||||
->withTimestamps()
|
||||
->using(GroupUser::class);
|
||||
}
|
||||
|
||||
public function hasPermissionThroughGroup($permission)
|
||||
{
|
||||
return $this->groups->flatMap(function ($group) {
|
||||
return $group->permissions;
|
||||
})->contains('name', $permission);
|
||||
}
|
||||
|
||||
public function getAllPermissionsAttribute()
|
||||
{
|
||||
return $this->getAllPermissions()
|
||||
->merge($this->groups->flatMap->permissions)
|
||||
->unique('id');
|
||||
}
|
||||
|
||||
public function hasAnyPermission($permissions): bool
|
||||
{
|
||||
return $this->hasPermissionTo($permissions) ||
|
||||
$this->groups->contains(function ($group) use ($permissions) {
|
||||
return $group->hasAnyPermission($permissions);
|
||||
});
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user