This commit is contained in:
Saeed Vaziry
2025-06-04 08:08:20 +02:00
parent efacadba10
commit c3f69f3247
114 changed files with 4032 additions and 765 deletions

View File

@ -2,7 +2,6 @@
namespace App\Policies;
use App\Enums\SiteFeature;
use App\Models\Command;
use App\Models\Server;
use App\Models\Site;
@ -17,7 +16,6 @@ public function viewAny(User $user, Site $site, Server $server): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$server->isReady() &&
$site->hasFeature(SiteFeature::COMMANDS) &&
$site->isReady();
}
@ -27,7 +25,6 @@ public function view(User $user, Command $command, Site $site, Server $server):
$site->server_id === $server->id &&
$server->isReady() &&
$site->isReady() &&
$site->hasFeature(SiteFeature::COMMANDS) &&
$command->site_id === $site->id;
}
@ -35,7 +32,6 @@ public function create(User $user, Site $site, Server $server): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$server->isReady() &&
$site->hasFeature(SiteFeature::COMMANDS) &&
$site->isReady();
}
@ -45,7 +41,6 @@ public function update(User $user, Command $command, Site $site, Server $server)
$site->server_id === $server->id &&
$server->isReady() &&
$site->isReady() &&
$site->hasFeature(SiteFeature::COMMANDS) &&
$command->site_id === $site->id;
}
@ -55,7 +50,6 @@ public function delete(User $user, Command $command, Site $site, Server $server)
$site->server_id === $server->id &&
$server->isReady() &&
$site->isReady() &&
$site->hasFeature(SiteFeature::COMMANDS) &&
$command->site_id === $site->id;
}
}

View File

@ -2,34 +2,40 @@
namespace App\Policies;
use App\Models\Redirect;
use App\Models\Server;
use App\Models\Site;
use App\Models\User;
class RedirectPolicy
{
public function view(User $user, Site $site, Server $server): bool
public function viewAny(User $user, Site $site, Server $server): bool
{
if ($user->isAdmin()) {
return true;
}
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$server->isReady() &&
$site->isReady();
}
return $site->server->project->users->contains($user);
public function view(User $user, Redirect $redirect, Site $site, Server $server): bool
{
return ($user->isAdmin() || $site->server->project->users->contains($user))
&& $site->server_id === $server->id
&& $site->server->isReady()
&& $redirect->site_id === $site->id;
}
public function create(User $user, Site $site, Server $server): bool
{
return ($user->isAdmin() || $site->server->project->users->contains($user))
&& $site->server_id === $server->id
&& $site->server->isReady()
&& $site->server->webserver();
&& $site->server->isReady();
}
public function delete(User $user, Site $site, Server $server): bool
public function delete(User $user, Redirect $redirect, Site $site, Server $server): bool
{
return ($user->isAdmin() || $site->server->project->users->contains($user))
&& $site->server_id === $server->id
&& $site->server->isReady()
&& $site->server->webserver();
&& $server->isReady()
&& $redirect->site_id === $site->id;
}
}

View File

@ -2,7 +2,6 @@
namespace App\Policies;
use App\Enums\SiteFeature;
use App\Models\Server;
use App\Models\Site;
use App\Models\Ssl;
@ -17,7 +16,6 @@ public function viewAny(User $user, Site $site, Server $server): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$server->isReady() &&
$site->hasFeature(SiteFeature::SSL) &&
$site->isReady();
}
@ -27,7 +25,6 @@ public function view(User $user, Ssl $ssl, Site $site, Server $server): bool
$site->server_id === $server->id &&
$server->isReady() &&
$site->isReady() &&
$site->hasFeature(SiteFeature::SSL) &&
$ssl->site_id === $site->id;
}
@ -35,18 +32,16 @@ public function create(User $user, Site $site, Server $server): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$server->isReady() &&
$site->hasFeature(SiteFeature::SSL) &&
$site->isReady();
}
public function update(User $user, Ssl $ssl, Site $site, Server $server): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$site->server_id === $server->id &&
$server->isReady() &&
$site->isReady() &&
$site->hasFeature(SiteFeature::SSL) &&
$ssl->site_id === $site->id;
$site->server_id === $server->id &&
$server->isReady() &&
$site->isReady() &&
$ssl->site_id === $site->id;
}
public function delete(User $user, Ssl $ssl, Site $site, Server $server): bool
@ -55,7 +50,6 @@ public function delete(User $user, Ssl $ssl, Site $site, Server $server): bool
$site->server_id === $server->id &&
$server->isReady() &&
$site->isReady() &&
$site->hasFeature(SiteFeature::SSL) &&
$ssl->site_id === $site->id;
}
}

View File

@ -2,7 +2,6 @@
namespace App\Policies;
use App\Enums\SiteFeature;
use App\Models\Server;
use App\Models\Site;
use App\Models\User;
@ -17,70 +16,37 @@ public function viewAny(User $user, Server $server, ?Site $site = null): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$server->isReady() &&
(
! $site instanceof Site ||
(
$site->hasFeature(SiteFeature::WORKERS) &&
$site->isReady()
)
);
$server->processManager();
}
public function view(User $user, Worker $worker, Server $server, ?Site $site = null): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$server->isReady() &&
(
! $site instanceof Site ||
(
$site->server_id === $server->id &&
$site->hasFeature(SiteFeature::WORKERS) &&
$site->isReady() &&
$worker->site_id === $site->id
)
);
$worker->server_id === $server->id &&
$server->processManager();
}
public function create(User $user, Server $server, ?Site $site = null): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$server->isReady() &&
(
! $site instanceof Site ||
(
$site->hasFeature(SiteFeature::WORKERS) &&
$site->isReady()
)
);
$server->processManager();
}
public function update(User $user, Worker $worker, Server $server, ?Site $site = null): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$server->isReady() &&
(
! $site instanceof Site ||
(
$site->server_id === $server->id &&
$site->hasFeature(SiteFeature::WORKERS) &&
$site->isReady() &&
$worker->site_id === $site->id
)
);
$worker->server_id === $server->id &&
$server->processManager();
}
public function delete(User $user, Worker $worker, Server $server, ?Site $site = null): bool
{
return ($user->isAdmin() || $server->project->users->contains($user)) &&
$server->isReady() &&
(
! $site instanceof Site ||
(
$site->server_id === $server->id &&
$site->hasFeature(SiteFeature::WORKERS) &&
$site->isReady() &&
$worker->site_id === $site->id
)
);
$worker->server_id === $server->id &&
$server->processManager();
}
}