2023-05-03 09:27:44 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Actions\Proxy;
|
|
|
|
|
2024-03-12 11:22:02 +01:00
|
|
|
use App\Events\ProxyStarted;
|
2023-05-03 09:27:44 +01:00
|
|
|
use App\Models\Server;
|
2023-05-15 13:45:37 +02:00
|
|
|
use Illuminate\Support\Str;
|
2023-09-18 12:29:50 +02:00
|
|
|
use Lorisleiva\Actions\Concerns\AsAction;
|
2023-08-08 11:51:36 +02:00
|
|
|
use Spatie\Activitylog\Models\Activity;
|
2023-05-03 09:27:44 +01:00
|
|
|
|
2023-07-14 13:38:24 +02:00
|
|
|
class StartProxy
|
2023-05-03 09:27:44 +01:00
|
|
|
{
|
2023-09-18 12:29:50 +02:00
|
|
|
use AsAction;
|
2023-10-13 14:25:30 +02:00
|
|
|
public function handle(Server $server, bool $async = true): string|Activity
|
2023-05-03 09:27:44 +01:00
|
|
|
{
|
2023-10-13 14:25:30 +02:00
|
|
|
try {
|
|
|
|
$proxyType = $server->proxyType();
|
2024-03-11 15:08:05 +01:00
|
|
|
if (is_null($proxyType) || $proxyType === 'NONE') {
|
2024-03-04 10:42:54 +01:00
|
|
|
return 'OK';
|
|
|
|
}
|
2023-10-13 14:25:30 +02:00
|
|
|
$commands = collect([]);
|
2024-03-11 15:08:05 +01:00
|
|
|
$proxy_path = $server->proxyPath();
|
2023-10-13 14:25:30 +02:00
|
|
|
$configuration = CheckConfiguration::run($server);
|
|
|
|
if (!$configuration) {
|
|
|
|
throw new \Exception("Configuration is not synced");
|
|
|
|
}
|
|
|
|
SaveConfiguration::run($server, $configuration);
|
|
|
|
$docker_compose_yml_base64 = base64_encode($configuration);
|
|
|
|
$server->proxy->last_applied_settings = Str::of($docker_compose_yml_base64)->pipe('md5')->value;
|
2023-09-25 09:17:42 +02:00
|
|
|
$server->save();
|
2023-11-28 18:42:09 +01:00
|
|
|
if ($server->isSwarm()) {
|
|
|
|
$commands = $commands->merge([
|
2024-04-16 20:57:54 +02:00
|
|
|
"mkdir -p $proxy_path/dynamic",
|
|
|
|
"cd $proxy_path",
|
2023-11-28 18:42:09 +01:00
|
|
|
"echo 'Creating required Docker Compose file.'",
|
|
|
|
"echo 'Starting coolify-proxy.'",
|
2024-04-16 20:57:54 +02:00
|
|
|
"docker stack deploy -c docker-compose.yml coolify-proxy",
|
2023-11-28 18:42:09 +01:00
|
|
|
"echo 'Proxy started successfully.'"
|
|
|
|
]);
|
|
|
|
} else {
|
2024-03-11 17:17:34 +01:00
|
|
|
$caddfile = "import /dynamic/*.caddy";
|
2023-11-28 18:42:09 +01:00
|
|
|
$commands = $commands->merge([
|
2024-04-16 20:57:54 +02:00
|
|
|
"mkdir -p $proxy_path/dynamic",
|
|
|
|
"cd $proxy_path",
|
2024-03-11 17:17:34 +01:00
|
|
|
"echo '$caddfile' > $proxy_path/dynamic/Caddyfile",
|
2023-11-28 18:42:09 +01:00
|
|
|
"echo 'Creating required Docker Compose file.'",
|
|
|
|
"echo 'Pulling docker image.'",
|
|
|
|
'docker compose pull',
|
|
|
|
"echo 'Stopping existing coolify-proxy.'",
|
|
|
|
"docker compose down -v --remove-orphans > /dev/null 2>&1",
|
|
|
|
"echo 'Starting coolify-proxy.'",
|
|
|
|
'docker compose up -d --remove-orphans',
|
|
|
|
"echo 'Proxy started successfully.'"
|
|
|
|
]);
|
|
|
|
$commands = $commands->merge(connectProxyToNetworks($server));
|
|
|
|
}
|
|
|
|
|
2023-10-13 14:25:30 +02:00
|
|
|
if ($async) {
|
2024-03-12 11:22:02 +01:00
|
|
|
$activity = remote_process($commands, $server, callEventOnFinish: 'ProxyStarted', callEventData: $server);
|
2023-10-13 14:25:30 +02:00
|
|
|
return $activity;
|
|
|
|
} else {
|
|
|
|
instant_remote_process($commands, $server);
|
|
|
|
$server->proxy->set('status', 'running');
|
|
|
|
$server->proxy->set('type', $proxyType);
|
|
|
|
$server->save();
|
2024-03-12 11:22:02 +01:00
|
|
|
ProxyStarted::dispatch($server);
|
2023-10-13 14:25:30 +02:00
|
|
|
return 'OK';
|
|
|
|
}
|
2023-11-28 15:49:24 +01:00
|
|
|
} catch (\Throwable $e) {
|
2023-10-13 14:25:30 +02:00
|
|
|
ray($e);
|
|
|
|
throw $e;
|
2023-09-14 12:45:50 +02:00
|
|
|
}
|
2023-05-03 09:27:44 +01:00
|
|
|
}
|
2023-08-08 11:51:36 +02:00
|
|
|
}
|