vito/app/Policies/ServerLogPolicy.php
2025-03-12 13:31:10 +01:00

68 lines
1.4 KiB
PHP

<?php
namespace App\Policies;
use App\Models\Server;
use App\Models\ServerLog;
use App\Models\User;
use Illuminate\Auth\Access\HandlesAuthorization;
class ServerLogPolicy
{
use HandlesAuthorization;
public function viewAny(User $user, Server $server): bool
{
if ($user->isAdmin()) {
return true;
}
return $server->project->users->contains($user);
}
public function view(User $user, ServerLog $serverLog): bool
{
if ($user->isAdmin()) {
return true;
}
return $serverLog->server->project->users->contains($user);
}
public function create(User $user, Server $server): bool
{
if ($user->isAdmin()) {
return true;
}
return $server->project->users->contains($user);
}
public function update(User $user, ServerLog $serverLog): bool
{
if ($user->isAdmin()) {
return true;
}
return $serverLog->server->project->users->contains($user);
}
public function delete(User $user, ServerLog $serverLog): bool
{
if ($user->isAdmin()) {
return true;
}
return $serverLog->server->project->users->contains($user);
}
public function deleteMany(User $user, Server $server): bool
{
if ($user->isAdmin()) {
return true;
}
return $server->project->users->contains($user);
}
}