You've already forked Epicnabbo-Catalogus-Updated-Daily
🆙 More fixes 🆙
This commit is contained in:
@@ -8,15 +8,19 @@ use Illuminate\Support\Facades\Cache;
|
||||
|
||||
class PermissionsService
|
||||
{
|
||||
/** @var Collection<string, int>|null */
|
||||
public private(set) ?Collection $permissions;
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
$this->permissions = Cache::remember(
|
||||
/** @var Collection<string, int> $permissions */
|
||||
$permissions = Cache::remember(
|
||||
key: 'website_permissions',
|
||||
ttl: now()->addMinutes(30),
|
||||
callback: fn () => WebsitePermission::all()->pluck('min_rank', 'permission')
|
||||
callback: fn () => WebsitePermission::pluck('min_rank', 'permission')
|
||||
);
|
||||
|
||||
$this->permissions = $permissions;
|
||||
}
|
||||
|
||||
public function getOrDefault(string $permissionName, bool $default = false): bool
|
||||
@@ -29,17 +33,23 @@ class PermissionsService
|
||||
return false;
|
||||
}
|
||||
|
||||
return auth()->user()->rank >= (int) $this->permissions->get($permissionName);
|
||||
/** @var \App\Models\User $user */
|
||||
$user = auth()->user();
|
||||
|
||||
return $user->rank >= (int) $this->permissions->get($permissionName);
|
||||
}
|
||||
|
||||
public function refresh(): void
|
||||
{
|
||||
Cache::forget('website_permissions');
|
||||
|
||||
$this->permissions = Cache::remember(
|
||||
/** @var Collection<string, int> $permissions */
|
||||
$permissions = Cache::remember(
|
||||
key: 'website_permissions',
|
||||
ttl: now()->addMinutes(30),
|
||||
callback: fn () => WebsitePermission::all()->pluck('min_rank', 'permission')
|
||||
callback: fn () => WebsitePermission::pluck('min_rank', 'permission')
|
||||
);
|
||||
|
||||
$this->permissions = $permissions;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user