'datetime', 'last_login_at' => 'datetime', 'password' => 'hashed', ]; } /** @return BelongsToMany */ public function roles(): BelongsToMany { return $this->belongsToMany( AdminRole::class, 'admin_user_roles', 'admin_user_id', 'role_id', ); } /** @return BelongsToMany */ public function permissions(): BelongsToMany { return $this->belongsToMany( AdminPermission::class, 'admin_user_permissions', 'admin_user_id', 'permission_id', ); } /** 是否具备指定权限(含 `super_admin` 角色全放行)。 */ public function hasAdminPermission(string $slug): bool { $this->loadMissing(['roles.permissions', 'permissions']); foreach ($this->roles as $role) { if ($role->slug === self::ROLE_SUPER_ADMIN) { return true; } foreach ($role->permissions as $permission) { if ($permission->slug === $slug) { return true; } } } foreach ($this->permissions as $permission) { if ($permission->slug === $slug) { return true; } } return false; } /** * @return list */ public function adminPermissionSlugs(): array { $this->loadMissing(['roles.permissions', 'permissions']); if ($this->roles->contains('slug', self::ROLE_SUPER_ADMIN)) { return AdminPermission::query()->orderBy('slug')->pluck('slug')->all(); } $out = []; foreach ($this->roles as $role) { foreach ($role->permissions as $permission) { $out[$permission->slug] = true; } } foreach ($this->permissions as $permission) { $out[$permission->slug] = true; } return array_keys($out); } /** * @return list */ public function adminRoleSlugs(): array { $this->loadMissing('roles'); return $this->roles ->pluck('slug') ->filter(static fn ($slug): bool => is_string($slug) && $slug !== '') ->values() ->all(); } }