2023-06-30 09:42:59 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Console\Commands;
|
|
|
|
|
2023-06-30 20:26:40 +00:00
|
|
|
use App\Enums\ApplicationDeploymentStatus;
|
2023-11-16 19:48:25 +00:00
|
|
|
use App\Jobs\CleanupHelperContainersJob;
|
2023-06-30 09:42:59 +00:00
|
|
|
use App\Models\ApplicationDeploymentQueue;
|
2023-11-15 09:20:48 +00:00
|
|
|
use App\Models\InstanceSettings;
|
2023-12-27 22:06:22 +00:00
|
|
|
use App\Models\ScheduledDatabaseBackup;
|
2023-11-16 19:48:25 +00:00
|
|
|
use App\Models\Server;
|
2023-10-24 08:10:55 +00:00
|
|
|
use App\Models\StandalonePostgresql;
|
2023-06-30 09:42:59 +00:00
|
|
|
use Illuminate\Console\Command;
|
2023-11-15 09:18:41 +00:00
|
|
|
use Illuminate\Support\Facades\Http;
|
2023-06-30 09:42:59 +00:00
|
|
|
|
|
|
|
class Init extends Command
|
|
|
|
{
|
2024-02-08 10:05:31 +00:00
|
|
|
protected $signature = 'app:init {--full-cleanup}';
|
2023-06-30 09:42:59 +00:00
|
|
|
protected $description = 'Cleanup instance related stuffs';
|
2023-08-08 09:51:36 +00:00
|
|
|
|
2023-06-30 09:42:59 +00:00
|
|
|
public function handle()
|
|
|
|
{
|
2023-11-15 09:18:41 +00:00
|
|
|
$this->alive();
|
2024-02-08 11:36:33 +00:00
|
|
|
$full_cleanup = $this->option('full-cleanup');
|
|
|
|
if ($full_cleanup) {
|
|
|
|
echo "Running init cleanupsg.\n";
|
2024-02-08 10:05:31 +00:00
|
|
|
|
2023-12-27 22:06:22 +00:00
|
|
|
// Required for falsely deleted coolify db
|
|
|
|
$this->restore_coolify_db_backup();
|
2024-02-08 10:05:31 +00:00
|
|
|
$this->cleanup_in_progress_application_deployments();
|
|
|
|
$this->cleanup_stucked_helper_containers();
|
|
|
|
$this->call('cleanup:queue');
|
|
|
|
$this->call('cleanup:stucked-resources');
|
|
|
|
try {
|
|
|
|
setup_dynamic_configuration();
|
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Could not setup dynamic configuration: {$e->getMessage()}\n";
|
|
|
|
}
|
2023-12-27 22:06:22 +00:00
|
|
|
|
2024-02-08 10:05:31 +00:00
|
|
|
$settings = InstanceSettings::get();
|
|
|
|
if (!is_null(env('AUTOUPDATE', null))) {
|
|
|
|
if (env('AUTOUPDATE') == true) {
|
|
|
|
$settings->update(['is_auto_update_enabled' => true]);
|
|
|
|
} else {
|
|
|
|
$settings->update(['is_auto_update_enabled' => false]);
|
|
|
|
}
|
2023-12-11 22:26:49 +00:00
|
|
|
}
|
2024-02-08 10:05:31 +00:00
|
|
|
return;
|
2023-12-11 19:55:58 +00:00
|
|
|
}
|
2024-02-08 10:05:31 +00:00
|
|
|
echo "Running cleanups.\n";
|
|
|
|
$this->cleanup_stucked_helper_containers();
|
|
|
|
$this->call('cleanup:stucked-resources');
|
2023-11-16 19:48:25 +00:00
|
|
|
}
|
2024-01-02 20:03:51 +00:00
|
|
|
private function restore_coolify_db_backup()
|
|
|
|
{
|
2023-12-27 22:06:22 +00:00
|
|
|
try {
|
|
|
|
$database = StandalonePostgresql::withTrashed()->find(0);
|
2023-12-27 22:07:39 +00:00
|
|
|
if ($database && $database->trashed()) {
|
2023-12-27 22:06:22 +00:00
|
|
|
echo "Restoring coolify db backup\n";
|
|
|
|
$database->restore();
|
|
|
|
$scheduledBackup = ScheduledDatabaseBackup::find(0);
|
|
|
|
if (!$scheduledBackup) {
|
|
|
|
ScheduledDatabaseBackup::create([
|
|
|
|
'id' => 0,
|
|
|
|
'enabled' => true,
|
|
|
|
'save_s3' => false,
|
|
|
|
'frequency' => '0 0 * * *',
|
|
|
|
'database_id' => $database->id,
|
|
|
|
'database_type' => 'App\Models\StandalonePostgresql',
|
|
|
|
'team_id' => 0,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
}
|
2024-01-02 20:03:51 +00:00
|
|
|
} catch (\Throwable $e) {
|
2023-12-27 22:06:22 +00:00
|
|
|
echo "Error in restoring coolify db backup: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
}
|
2023-11-29 15:19:40 +00:00
|
|
|
private function cleanup_stucked_helper_containers()
|
|
|
|
{
|
2023-11-16 19:48:25 +00:00
|
|
|
$servers = Server::all();
|
|
|
|
foreach ($servers as $server) {
|
|
|
|
if ($server->isFunctional()) {
|
|
|
|
CleanupHelperContainersJob::dispatch($server);
|
|
|
|
}
|
|
|
|
}
|
2023-06-30 20:26:40 +00:00
|
|
|
}
|
2023-11-15 09:18:41 +00:00
|
|
|
private function alive()
|
|
|
|
{
|
|
|
|
$id = config('app.id');
|
2023-11-17 12:59:45 +00:00
|
|
|
$version = config('version');
|
2023-11-15 09:20:48 +00:00
|
|
|
$settings = InstanceSettings::get();
|
|
|
|
$do_not_track = data_get($settings, 'do_not_track');
|
2023-11-15 09:26:31 +00:00
|
|
|
if ($do_not_track == true) {
|
2023-11-15 09:37:02 +00:00
|
|
|
echo "Skipping alive as do_not_track is enabled\n";
|
2023-11-15 09:20:48 +00:00
|
|
|
return;
|
|
|
|
}
|
2023-11-15 09:18:41 +00:00
|
|
|
try {
|
2024-01-11 10:34:05 +00:00
|
|
|
Http::get("https://undead.coolify.io/v4/alive?appId=$id&version=$version");
|
2023-11-15 09:37:02 +00:00
|
|
|
echo "I am alive!\n";
|
2023-11-15 09:18:41 +00:00
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Error in alive: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
}
|
2023-11-29 14:23:03 +00:00
|
|
|
// private function cleanup_ssh()
|
|
|
|
// {
|
|
|
|
|
2023-11-29 15:19:40 +00:00
|
|
|
// TODO: it will cleanup id.root@host.docker.internal
|
2023-11-29 14:23:03 +00:00
|
|
|
// try {
|
|
|
|
// $files = Storage::allFiles('ssh/keys');
|
|
|
|
// foreach ($files as $file) {
|
|
|
|
// Storage::delete($file);
|
|
|
|
// }
|
|
|
|
// $files = Storage::allFiles('ssh/mux');
|
|
|
|
// foreach ($files as $file) {
|
|
|
|
// Storage::delete($file);
|
|
|
|
// }
|
|
|
|
// } catch (\Throwable $e) {
|
|
|
|
// echo "Error in cleaning ssh: {$e->getMessage()}\n";
|
|
|
|
// }
|
|
|
|
// }
|
2023-06-30 20:26:40 +00:00
|
|
|
private function cleanup_in_progress_application_deployments()
|
|
|
|
{
|
|
|
|
// Cleanup any failed deployments
|
|
|
|
|
2023-06-30 09:42:59 +00:00
|
|
|
try {
|
2023-12-13 11:13:20 +00:00
|
|
|
$halted_deployments = ApplicationDeploymentQueue::where('status', '==', ApplicationDeploymentStatus::IN_PROGRESS)->where('status', '==', ApplicationDeploymentStatus::QUEUED)->get();
|
2023-06-30 20:26:40 +00:00
|
|
|
foreach ($halted_deployments as $deployment) {
|
|
|
|
$deployment->status = ApplicationDeploymentStatus::FAILED->value;
|
|
|
|
$deployment->save();
|
|
|
|
}
|
2023-09-11 15:36:30 +00:00
|
|
|
} catch (\Throwable $e) {
|
2023-06-30 09:42:59 +00:00
|
|
|
echo "Error: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|