This commit is contained in:
Saeed Vaziry
2024-09-27 20:36:03 +02:00
committed by GitHub
parent b62c40c97d
commit f6bc04763b
122 changed files with 6609 additions and 807 deletions

View File

@ -2,7 +2,6 @@
namespace App\Policies;
use App\Enums\UserRole;
use App\Models\Project;
use App\Models\User;
@ -10,26 +9,26 @@ class ProjectPolicy
{
public function viewAny(User $user): bool
{
return $user->role === UserRole::ADMIN;
return $user->isAdmin();
}
public function view(User $user, Project $project): bool
{
return $user->role === UserRole::ADMIN || $project->users->contains($user);
return $user->isAdmin() || $project->users->contains($user);
}
public function create(User $user): bool
{
return $user->role === UserRole::ADMIN;
return $user->isAdmin();
}
public function update(User $user, Project $project): bool
{
return $user->role === UserRole::ADMIN;
return $user->isAdmin();
}
public function delete(User $user, Project $project): bool
{
return $user->role === UserRole::ADMIN;
return $user->isAdmin();
}
}

View File

@ -2,40 +2,38 @@
namespace App\Policies;
use App\Enums\UserRole;
use App\Models\Project;
use App\Models\Server;
use App\Models\User;
class ServerPolicy
{
public function viewAny(User $user, Project $project): bool
public function viewAny(User $user): bool
{
return $user->role === UserRole::ADMIN || $project->users->contains($user);
return $user->isAdmin() || $user->currentProject?->users->contains($user);
}
public function view(User $user, Server $server): bool
{
return $user->role === UserRole::ADMIN || $server->project->users->contains($user);
return $user->isAdmin() || $server->project->users->contains($user);
}
public function create(User $user, Project $project): bool
public function create(User $user): bool
{
return $user->role === UserRole::ADMIN || $project->users->contains($user);
return $user->isAdmin() || $user->currentProject?->users->contains($user);
}
public function update(User $user, Server $server): bool
{
return $user->role === UserRole::ADMIN || $server->project->users->contains($user);
return $user->isAdmin() || $server->project->users->contains($user);
}
public function delete(User $user, Server $server): bool
{
return $user->role === UserRole::ADMIN || $server->project->users->contains($user);
return $user->isAdmin() || $server->project->users->contains($user);
}
public function manage(User $user, Server $server): bool
{
return $user->role === UserRole::ADMIN || $server->project->users->contains($user);
return $user->isAdmin() || $server->project->users->contains($user);
}
}

View File

@ -0,0 +1,37 @@
<?php
namespace App\Policies;
use App\Models\ServerProvider;
use App\Models\User;
use Illuminate\Auth\Access\HandlesAuthorization;
class ServerProviderPolicy
{
use HandlesAuthorization;
public function viewAny(User $user): bool
{
return $user->isAdmin();
}
public function view(User $user, ServerProvider $serverProvider): bool
{
return $user->isAdmin();
}
public function create(User $user): bool
{
return $user->isAdmin();
}
public function update(User $user, ServerProvider $serverProvider): bool
{
return $user->isAdmin();
}
public function delete(User $user, ServerProvider $serverProvider): bool
{
return $user->isAdmin();
}
}

View File

@ -0,0 +1,41 @@
<?php
namespace App\Policies;
use App\Models\Server;
use App\Models\Site;
use App\Models\User;
use Illuminate\Auth\Access\HandlesAuthorization;
class SitePolicy
{
use HandlesAuthorization;
public function viewAny(User $user, Server $server): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) && $server->isReady();
}
public function view(User $user, Site $site): bool
{
return ($user->isAdmin() || $site->server->project->users->contains($user)) &&
$site->server->isReady();
}
public function create(User $user, Server $server): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) && $server->isReady();
}
public function update(User $user, Site $site): bool
{
return ($user->isAdmin() || $site->server->project->users->contains($user)) &&
$site->server->isReady();
}
public function delete(User $user, Site $site): bool
{
return ($user->isAdmin() || $site->server->project->users->contains($user)) &&
$site->server->isReady();
}
}

View File

@ -0,0 +1,36 @@
<?php
namespace App\Policies;
use App\Models\User;
use Illuminate\Auth\Access\HandlesAuthorization;
class UserPolicy
{
use HandlesAuthorization;
public function viewAny(User $user): bool
{
return $user->isAdmin();
}
public function view(User $user, User $model): bool
{
return $user->isAdmin();
}
public function create(User $user): bool
{
return $user->isAdmin();
}
public function update(User $user, User $model): bool
{
return $user->isAdmin();
}
public function delete(User $user, User $model): bool
{
return $user->isAdmin();
}
}