mirror of
https://github.com/pelican-dev/panel.git
synced 2026-05-04 18:00:48 +03:00
Admin Roles (#502)
* add spatie/permissions * add policies * add role resource * add root admin role handling * replace some "root_admin" with function * add model specific permissions * make permission selection nicer * fix user creation * fix tests * add back subuser checks in server policy * add custom model for role * assign new users to role if root_admin is set * add api for roles * fix phpstan * add permissions for settings page * remove "restore" and "forceDelete" permissions * add user count to list * prevent deletion if role has users * update user list * fix server policy * remove old `root_admin` column * small refactor * fix tests * forgot can checks here * forgot use * disable editing own roles & disable assigning root admin * don't allow to rename root admin role * remove php bombing exception handler * fix role assignment when creating a user * fix disableOptionWhen * fix missing `root_admin` attribute on react frontend * add permission check for bulk delete * rename viewAny to viewList * improve canAccessPanel check * fix admin not displaying for non-root admins * make sure non root admins can't edit root admins * fix import * fix settings page permission check * fix server permissions for non-subusers * fix settings page permission check v2 * small cleanup * cleanup config file * move consts from resouce into enum & model * Update database/migrations/2024_08_01_114538_remove_root_admin_column.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * fix config * fix phpstan * fix phpstan 2.0 --------- Co-authored-by: Lance Pioch <lancepioch@gmail.com>
This commit is contained in:
@@ -7,6 +7,7 @@ use App\Models\Server;
|
||||
use App\Models\Subuser;
|
||||
use App\Models\Allocation;
|
||||
use App\Models\Permission;
|
||||
use App\Models\Role;
|
||||
|
||||
class ClientControllerTest extends ClientApiIntegrationTestCase
|
||||
{
|
||||
@@ -47,7 +48,7 @@ class ClientControllerTest extends ClientApiIntegrationTestCase
|
||||
{
|
||||
/** @var \App\Models\User[] $users */
|
||||
$users = User::factory()->times(2)->create();
|
||||
$users[0]->update(['root_admin' => true]);
|
||||
$users[0]->syncRoles(Role::getRootAdmin());
|
||||
|
||||
/** @var \App\Models\Server[] $servers */
|
||||
$servers = [
|
||||
@@ -225,7 +226,7 @@ class ClientControllerTest extends ClientApiIntegrationTestCase
|
||||
{
|
||||
/** @var \App\Models\User[] $users */
|
||||
$users = User::factory()->times(4)->create();
|
||||
$users[0]->update(['root_admin' => true]);
|
||||
$users[0]->syncRoles(Role::getRootAdmin());
|
||||
|
||||
$servers = [
|
||||
$this->createServerModel(['user_id' => $users[0]->id]),
|
||||
@@ -260,7 +261,7 @@ class ClientControllerTest extends ClientApiIntegrationTestCase
|
||||
{
|
||||
/** @var \App\Models\User[] $users */
|
||||
$users = User::factory()->times(4)->create();
|
||||
$users[0]->update(['root_admin' => true]);
|
||||
$users[0]->syncRoles(Role::getRootAdmin());
|
||||
|
||||
$servers = [
|
||||
$this->createServerModel(['user_id' => $users[0]->id]),
|
||||
|
||||
Reference in New Issue
Block a user