vito/app/Policies/DatabaseUserPolicy.php
2024-11-23 10:38:36 +01:00

49 lines
1.5 KiB
PHP

<?php
namespace App\Policies;
use App\Models\DatabaseUser;
use App\Models\Server;
use App\Models\User;
use Illuminate\Auth\Access\HandlesAuthorization;
class DatabaseUserPolicy
{
use HandlesAuthorization;
public function viewAny(User $user, Server $server): bool
{
return ($user->isAdmin() || $server->project->users->contains($user))
&& $server->isReady()
&& $server->database();
}
public function view(User $user, DatabaseUser $databaseUser): bool
{
return ($user->isAdmin() || $databaseUser->server->project->users->contains($user)) &&
$databaseUser->server->isReady()
&& $databaseUser->server->database();
}
public function create(User $user, Server $server): bool
{
return ($user->isAdmin() || $server->project->users->contains($user))
&& $server->isReady()
&& $server->database();
}
public function update(User $user, DatabaseUser $databaseUser): bool
{
return ($user->isAdmin() || $databaseUser->server->project->users->contains($user)) &&
$databaseUser->server->isReady()
&& $databaseUser->server->database();
}
public function delete(User $user, DatabaseUser $databaseUser): bool
{
return ($user->isAdmin() || $databaseUser->server->project->users->contains($user)) &&
$databaseUser->server->isReady()
&& $databaseUser->server->database();
}
}