mirror of
https://github.com/pelican-dev/panel.git
synced 2025-10-29 23:26:52 +01:00
44 lines
1.2 KiB
PHP
44 lines
1.2 KiB
PHP
<?php
|
|
|
|
namespace App\Services\Servers;
|
|
|
|
use App\Models\Permission;
|
|
use App\Models\Server;
|
|
use App\Models\Subuser;
|
|
use App\Models\User;
|
|
|
|
class GetUserPermissionsService
|
|
{
|
|
/**
|
|
* Returns the server specific permissions that a user has. This checks
|
|
* if they are an admin, the owner or a subuser for the server. If no
|
|
* permissions are found, an empty array is returned.
|
|
*
|
|
* @return string[]
|
|
*/
|
|
public function handle(Server $server, User $user): array
|
|
{
|
|
$isOwner = $user->id === $server->owner_id;
|
|
$isAdmin = $user->isAdmin() && ($user->can('view', $server) || $user->can('update', $server));
|
|
|
|
if ($isOwner && !$isAdmin) {
|
|
return ['*'];
|
|
}
|
|
|
|
$adminPermissions = [
|
|
'admin.websocket.errors',
|
|
'admin.websocket.install',
|
|
'admin.websocket.transfer',
|
|
];
|
|
|
|
if ($isAdmin) {
|
|
return $isOwner || $user->can('update', $server) ? array_merge(['*'], $adminPermissions) : array_merge([Permission::ACTION_WEBSOCKET_CONNECT], $adminPermissions);
|
|
}
|
|
|
|
/** @var Subuser|null $subuser */
|
|
$subuser = $server->subusers()->where('user_id', $user->id)->first();
|
|
|
|
return $subuser->permissions ?? [];
|
|
}
|
|
}
|