mirror of
https://github.com/vitodeploy/vito.git
synced 2025-07-03 06:56:15 +00:00
User management (#185)
This commit is contained in:
35
app/Policies/ProjectPolicy.php
Normal file
35
app/Policies/ProjectPolicy.php
Normal file
@ -0,0 +1,35 @@
|
||||
<?php
|
||||
|
||||
namespace App\Policies;
|
||||
|
||||
use App\Enums\UserRole;
|
||||
use App\Models\Project;
|
||||
use App\Models\User;
|
||||
|
||||
class ProjectPolicy
|
||||
{
|
||||
public function viewAny(User $user): bool
|
||||
{
|
||||
return $user->role === UserRole::ADMIN;
|
||||
}
|
||||
|
||||
public function view(User $user, Project $project): bool
|
||||
{
|
||||
return $user->role === UserRole::ADMIN || $project->users->contains($user);
|
||||
}
|
||||
|
||||
public function create(User $user): bool
|
||||
{
|
||||
return $user->role === UserRole::ADMIN;
|
||||
}
|
||||
|
||||
public function update(User $user, Project $project): bool
|
||||
{
|
||||
return $user->role === UserRole::ADMIN;
|
||||
}
|
||||
|
||||
public function delete(User $user, Project $project): bool
|
||||
{
|
||||
return $user->role === UserRole::ADMIN;
|
||||
}
|
||||
}
|
41
app/Policies/ServerPolicy.php
Normal file
41
app/Policies/ServerPolicy.php
Normal file
@ -0,0 +1,41 @@
|
||||
<?php
|
||||
|
||||
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
|
||||
{
|
||||
return $user->role === UserRole::ADMIN || $project->users->contains($user);
|
||||
}
|
||||
|
||||
public function view(User $user, Server $server): bool
|
||||
{
|
||||
return $user->role === UserRole::ADMIN || $server->project->users->contains($user);
|
||||
}
|
||||
|
||||
public function create(User $user, Project $project): bool
|
||||
{
|
||||
return $user->role === UserRole::ADMIN || $project->users->contains($user);
|
||||
}
|
||||
|
||||
public function update(User $user, Server $server): bool
|
||||
{
|
||||
return $user->role === UserRole::ADMIN || $server->project->users->contains($user);
|
||||
}
|
||||
|
||||
public function delete(User $user, Server $server): bool
|
||||
{
|
||||
return $user->role === UserRole::ADMIN || $server->project->users->contains($user);
|
||||
}
|
||||
|
||||
public function manage(User $user, Server $server): bool
|
||||
{
|
||||
return $user->role === UserRole::ADMIN || $server->project->users->contains($user);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user