mirror of
https://github.com/vitodeploy/vito.git
synced 2025-07-04 23:42:34 +00:00
#591 - workers
This commit is contained in:
@ -13,7 +13,8 @@
|
||||
class CreateCronJob
|
||||
{
|
||||
/**
|
||||
* @param array<string, mixed> $input
|
||||
* @param array<string, mixed> $input
|
||||
*
|
||||
* @throws SSHError
|
||||
*/
|
||||
public function create(Server $server, array $input): CronJob
|
||||
|
@ -8,6 +8,7 @@
|
||||
use App\Models\Site;
|
||||
use App\Models\Worker;
|
||||
use App\SSH\Services\ProcessManager\ProcessManager;
|
||||
use Illuminate\Support\Facades\Validator;
|
||||
use Illuminate\Validation\Rule;
|
||||
use Illuminate\Validation\ValidationException;
|
||||
|
||||
@ -20,6 +21,8 @@ class CreateWorker
|
||||
*/
|
||||
public function create(Server $server, array $input, ?Site $site = null): void
|
||||
{
|
||||
Validator::make($input, self::rules($server, $site))->validate();
|
||||
|
||||
$worker = new Worker([
|
||||
'server_id' => $server->id,
|
||||
'site_id' => $site?->id,
|
||||
|
@ -8,6 +8,7 @@
|
||||
use App\Models\Site;
|
||||
use App\Models\Worker;
|
||||
use App\SSH\Services\ProcessManager\ProcessManager;
|
||||
use Illuminate\Support\Facades\Validator;
|
||||
use Illuminate\Validation\Rule;
|
||||
use Illuminate\Validation\ValidationException;
|
||||
|
||||
@ -20,6 +21,8 @@ class EditWorker
|
||||
*/
|
||||
public function edit(Worker $worker, array $input): void
|
||||
{
|
||||
Validator::make($input, self::rules($worker->server, $worker->site))->validate();
|
||||
|
||||
$worker->fill([
|
||||
'command' => $input['command'],
|
||||
'user' => $input['user'],
|
||||
|
131
app/Http/Controllers/WorkerController.php
Normal file
131
app/Http/Controllers/WorkerController.php
Normal file
@ -0,0 +1,131 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Actions\Worker\CreateWorker;
|
||||
use App\Actions\Worker\DeleteWorker;
|
||||
use App\Actions\Worker\EditWorker;
|
||||
use App\Actions\Worker\GetWorkerLogs;
|
||||
use App\Actions\Worker\ManageWorker;
|
||||
use App\Http\Resources\WorkerResource;
|
||||
use App\Models\Server;
|
||||
use App\Models\Site;
|
||||
use App\Models\Worker;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
use Inertia\Inertia;
|
||||
use Inertia\Response;
|
||||
use Spatie\RouteAttributes\Attributes\Delete;
|
||||
use Spatie\RouteAttributes\Attributes\Get;
|
||||
use Spatie\RouteAttributes\Attributes\Middleware;
|
||||
use Spatie\RouteAttributes\Attributes\Post;
|
||||
use Spatie\RouteAttributes\Attributes\Prefix;
|
||||
use Spatie\RouteAttributes\Attributes\Put;
|
||||
|
||||
#[Prefix('servers/{server}')]
|
||||
#[Middleware(['auth', 'has-project'])]
|
||||
class WorkerController extends Controller
|
||||
{
|
||||
#[Get('/workers', name: 'workers')]
|
||||
public function index(Server $server): Response
|
||||
{
|
||||
$this->authorize('viewAny', [Worker::class, $server]);
|
||||
|
||||
return Inertia::render('workers/index', [
|
||||
'workers' => WorkerResource::collection(
|
||||
$server->workers()->latest()->simplePaginate(config('web.pagination_size'))
|
||||
),
|
||||
]);
|
||||
}
|
||||
|
||||
#[Get('/sites/{site}/workers', name: 'sites.workers')]
|
||||
public function site(Server $server, Site $site): Response
|
||||
{
|
||||
$this->authorize('viewAny', [Worker::class, $server, $site]);
|
||||
|
||||
return Inertia::render('workers/index', [
|
||||
'workers' => WorkerResource::collection(
|
||||
$site->workers()->latest()->simplePaginate(config('web.pagination_size'))
|
||||
),
|
||||
]);
|
||||
}
|
||||
|
||||
#[Post('/workers/{site?}', name: 'workers.store')]
|
||||
public function store(Request $request, Server $server, ?Site $site = null): RedirectResponse
|
||||
{
|
||||
$this->authorize('create', [Worker::class, $server, $site]);
|
||||
|
||||
app(CreateWorker::class)->create($server, $request->all(), $site);
|
||||
|
||||
return back()
|
||||
->with('info', 'Worker is being created.');
|
||||
}
|
||||
|
||||
#[Put('/workers/{worker}/{site?}', name: 'workers.update')]
|
||||
public function update(Request $request, Server $server, Worker $worker, ?Site $site = null): RedirectResponse
|
||||
{
|
||||
$this->authorize('update', [$worker, $server, $site]);
|
||||
|
||||
app(EditWorker::class)->edit($worker, $request->all());
|
||||
|
||||
return back()
|
||||
->with('info', 'Worker is being updated.');
|
||||
}
|
||||
|
||||
#[Post('/workers/{worker}/start', name: 'workers.start')]
|
||||
public function start(Server $server, Worker $worker): RedirectResponse
|
||||
{
|
||||
$this->authorize('update', [$worker, $server]);
|
||||
|
||||
app(ManageWorker::class)->start($worker);
|
||||
|
||||
return back()
|
||||
->with('info', 'Worker is being started.');
|
||||
}
|
||||
|
||||
#[Post('/workers/{worker}/stop', name: 'workers.stop')]
|
||||
public function stop(Server $server, Worker $worker): RedirectResponse
|
||||
{
|
||||
$this->authorize('update', [$worker, $server]);
|
||||
|
||||
app(ManageWorker::class)->stop($worker);
|
||||
|
||||
return back()
|
||||
->with('info', 'Worker is being stopped.');
|
||||
}
|
||||
|
||||
#[Post('/workers/{worker}/restart', name: 'workers.restart')]
|
||||
public function restart(Server $server, Worker $worker): RedirectResponse
|
||||
{
|
||||
$this->authorize('update', [$worker, $server]);
|
||||
|
||||
app(ManageWorker::class)->restart($worker);
|
||||
|
||||
return back()
|
||||
->with('info', 'Worker is being restarted.');
|
||||
}
|
||||
|
||||
#[Get('/workers/{worker}/logs', name: 'workers.logs')]
|
||||
public function logs(Server $server, Worker $worker): JsonResponse
|
||||
{
|
||||
$this->authorize('view', [$worker, $server]);
|
||||
|
||||
$logs = app(GetWorkerLogs::class)->getLogs($worker);
|
||||
|
||||
return response()->json([
|
||||
'logs' => $logs,
|
||||
]);
|
||||
}
|
||||
|
||||
#[Delete('/{worker}/{site?}', name: 'workers.destroy')]
|
||||
public function destroy(Server $server, Worker $worker, ?Site $site = null): RedirectResponse
|
||||
{
|
||||
$this->authorize('delete', [$worker, $server, $site]);
|
||||
|
||||
app(DeleteWorker::class)->delete($worker);
|
||||
|
||||
return back()
|
||||
->with('info', 'Worker is being deleted.');
|
||||
}
|
||||
}
|
31
app/Http/Resources/WorkerResource.php
Normal file
31
app/Http/Resources/WorkerResource.php
Normal file
@ -0,0 +1,31 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Resources;
|
||||
|
||||
use App\Models\Worker;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
|
||||
/** @mixin Worker */
|
||||
class WorkerResource extends JsonResource
|
||||
{
|
||||
/**
|
||||
* @return array<string, mixed>
|
||||
*/
|
||||
public function toArray(Request $request): array
|
||||
{
|
||||
return [
|
||||
'id' => $this->id,
|
||||
'server_id' => $this->server_id,
|
||||
'command' => $this->command,
|
||||
'user' => $this->user,
|
||||
'auto_start' => $this->auto_start,
|
||||
'auto_restart' => $this->auto_restart,
|
||||
'numprocs' => $this->numprocs,
|
||||
'status' => $this->status,
|
||||
'status_color' => Worker::$statusColors[$this->status] ?? 'gray',
|
||||
'created_at' => $this->created_at,
|
||||
'updated_at' => $this->updated_at,
|
||||
];
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user