mirror of
https://github.com/vitodeploy/vito.git
synced 2025-07-04 23:42:34 +00:00
2.x
This commit is contained in:
@ -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();
|
||||
}
|
||||
}
|
||||
|
@ -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);
|
||||
}
|
||||
}
|
||||
|
37
app/Policies/ServerProviderPolicy.php
Normal file
37
app/Policies/ServerProviderPolicy.php
Normal 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();
|
||||
}
|
||||
}
|
41
app/Policies/SitePolicy.php
Normal file
41
app/Policies/SitePolicy.php
Normal 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();
|
||||
}
|
||||
}
|
36
app/Policies/UserPolicy.php
Normal file
36
app/Policies/UserPolicy.php
Normal 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();
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user