mirror of
https://github.com/pelican-dev/panel.git
synced 2025-10-29 23:26:52 +01:00
Fix user permissions service (#1819)
This commit is contained in:
parent
430f28a847
commit
8e006ac32d
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
namespace App\Services\Servers;
|
namespace App\Services\Servers;
|
||||||
|
|
||||||
|
use App\Models\Permission;
|
||||||
use App\Models\Server;
|
use App\Models\Server;
|
||||||
use App\Models\Subuser;
|
use App\Models\Subuser;
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
@ -17,23 +18,26 @@ class GetUserPermissionsService
|
|||||||
*/
|
*/
|
||||||
public function handle(Server $server, User $user): array
|
public function handle(Server $server, User $user): array
|
||||||
{
|
{
|
||||||
if ($user->id === $server->owner_id) {
|
$isOwner = $user->id === $server->owner_id;
|
||||||
|
$isAdmin = $user->isAdmin() && ($user->can('view', $server) || $user->can('update', $server));
|
||||||
|
|
||||||
|
if ($isOwner && !$isAdmin) {
|
||||||
return ['*'];
|
return ['*'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($user->isAdmin() && ($user->can('view', $server) || $user->can('update', $server))) {
|
$adminPermissions = [
|
||||||
$permissions = $user->can('update', $server) ? ['*'] : ['websocket.connect', 'backup.read'];
|
'admin.websocket.errors',
|
||||||
|
'admin.websocket.install',
|
||||||
|
'admin.websocket.transfer',
|
||||||
|
];
|
||||||
|
|
||||||
$permissions[] = 'admin.websocket.errors';
|
if ($isAdmin) {
|
||||||
$permissions[] = 'admin.websocket.install';
|
return $isOwner || $user->can('update', $server) ? array_merge(['*'], $adminPermissions) : array_merge([Permission::ACTION_WEBSOCKET_CONNECT], $adminPermissions);
|
||||||
$permissions[] = 'admin.websocket.transfer';
|
|
||||||
|
|
||||||
return $permissions;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @var Subuser|null $subuserPermissions */
|
/** @var Subuser|null $subuser */
|
||||||
$subuserPermissions = $server->subusers()->where('user_id', $user->id)->first();
|
$subuser = $server->subusers()->where('user_id', $user->id)->first();
|
||||||
|
|
||||||
return $subuserPermissions ? $subuserPermissions->permissions : [];
|
return $subuser->permissions ?? [];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user