2023-06-30 11:42:59 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Console\Commands;
|
|
|
|
|
2023-06-30 22:26:40 +02:00
|
|
|
use App\Enums\ApplicationDeploymentStatus;
|
2023-11-16 20:48:25 +01:00
|
|
|
use App\Jobs\CleanupHelperContainersJob;
|
2023-10-24 10:10:55 +02:00
|
|
|
use App\Models\Application;
|
2023-06-30 11:42:59 +02:00
|
|
|
use App\Models\ApplicationDeploymentQueue;
|
2023-11-15 10:20:48 +01:00
|
|
|
use App\Models\InstanceSettings;
|
2023-11-16 20:48:25 +01:00
|
|
|
use App\Models\Server;
|
2023-10-24 10:10:55 +02:00
|
|
|
use App\Models\Service;
|
2023-11-06 18:04:18 +01:00
|
|
|
use App\Models\ServiceApplication;
|
2023-11-06 20:58:03 +01:00
|
|
|
use App\Models\ServiceDatabase;
|
2023-11-06 18:04:18 +01:00
|
|
|
use App\Models\StandaloneMariadb;
|
2023-10-24 10:10:55 +02:00
|
|
|
use App\Models\StandaloneMongodb;
|
2023-10-25 11:43:18 +02:00
|
|
|
use App\Models\StandaloneMysql;
|
2023-10-24 10:10:55 +02:00
|
|
|
use App\Models\StandalonePostgresql;
|
|
|
|
use App\Models\StandaloneRedis;
|
2023-06-30 11:42:59 +02:00
|
|
|
use Illuminate\Console\Command;
|
2023-11-15 10:18:41 +01:00
|
|
|
use Illuminate\Support\Facades\Http;
|
2023-10-25 09:41:41 +02:00
|
|
|
use Illuminate\Support\Facades\Storage;
|
2023-06-30 11:42:59 +02:00
|
|
|
|
|
|
|
class Init extends Command
|
|
|
|
{
|
2023-11-06 21:08:02 +01:00
|
|
|
protected $signature = 'app:init {--cleanup}';
|
2023-06-30 11:42:59 +02:00
|
|
|
protected $description = 'Cleanup instance related stuffs';
|
2023-08-08 11:51:36 +02:00
|
|
|
|
2023-06-30 11:42:59 +02:00
|
|
|
public function handle()
|
|
|
|
{
|
2023-11-15 10:18:41 +01:00
|
|
|
$this->alive();
|
2023-11-06 21:08:02 +01:00
|
|
|
$cleanup = $this->option('cleanup');
|
|
|
|
if ($cleanup) {
|
2023-11-29 15:03:21 +01:00
|
|
|
echo "Running cleanup\n";
|
2023-11-06 21:08:02 +01:00
|
|
|
$this->cleanup_stucked_resources();
|
2023-11-29 15:23:03 +01:00
|
|
|
// $this->cleanup_ssh();
|
2023-11-06 21:08:02 +01:00
|
|
|
}
|
2023-06-30 22:26:40 +02:00
|
|
|
$this->cleanup_in_progress_application_deployments();
|
2023-11-16 20:48:25 +01:00
|
|
|
$this->cleanup_stucked_helper_containers();
|
2023-12-11 18:06:29 +01:00
|
|
|
setup_dynamic_configuration();
|
2023-11-16 20:48:25 +01:00
|
|
|
}
|
2023-11-29 16:19:40 +01:00
|
|
|
private function cleanup_stucked_helper_containers()
|
|
|
|
{
|
2023-11-16 20:48:25 +01:00
|
|
|
$servers = Server::all();
|
|
|
|
foreach ($servers as $server) {
|
|
|
|
if ($server->isFunctional()) {
|
|
|
|
CleanupHelperContainersJob::dispatch($server);
|
|
|
|
}
|
|
|
|
}
|
2023-06-30 22:26:40 +02:00
|
|
|
}
|
2023-11-15 10:18:41 +01:00
|
|
|
private function alive()
|
|
|
|
{
|
|
|
|
$id = config('app.id');
|
2023-11-17 13:59:45 +01:00
|
|
|
$version = config('version');
|
2023-11-15 10:20:48 +01:00
|
|
|
$settings = InstanceSettings::get();
|
|
|
|
$do_not_track = data_get($settings, 'do_not_track');
|
2023-11-15 10:26:31 +01:00
|
|
|
if ($do_not_track == true) {
|
2023-11-15 10:37:02 +01:00
|
|
|
echo "Skipping alive as do_not_track is enabled\n";
|
2023-11-15 10:20:48 +01:00
|
|
|
return;
|
|
|
|
}
|
2023-11-15 10:18:41 +01:00
|
|
|
try {
|
2023-11-17 13:53:56 +01:00
|
|
|
Http::get("https://get.coollabs.io/coolify/v4/alive?appId=$id&version=$version");
|
2023-11-15 10:37:02 +01:00
|
|
|
echo "I am alive!\n";
|
2023-11-15 10:18:41 +01:00
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Error in alive: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
}
|
2023-11-29 15:23:03 +01:00
|
|
|
// private function cleanup_ssh()
|
|
|
|
// {
|
|
|
|
|
2023-11-29 16:19:40 +01:00
|
|
|
// TODO: it will cleanup id.root@host.docker.internal
|
2023-11-29 15:23:03 +01: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 22:26:40 +02:00
|
|
|
private function cleanup_in_progress_application_deployments()
|
|
|
|
{
|
|
|
|
// Cleanup any failed deployments
|
|
|
|
|
2023-06-30 11:42:59 +02:00
|
|
|
try {
|
|
|
|
$halted_deployments = ApplicationDeploymentQueue::where('status', '==', 'in_progress')->get();
|
2023-06-30 22:26:40 +02:00
|
|
|
foreach ($halted_deployments as $deployment) {
|
|
|
|
$deployment->status = ApplicationDeploymentStatus::FAILED->value;
|
|
|
|
$deployment->save();
|
|
|
|
}
|
2023-09-11 17:36:30 +02:00
|
|
|
} catch (\Throwable $e) {
|
2023-06-30 11:42:59 +02:00
|
|
|
echo "Error: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
}
|
2023-10-25 11:43:18 +02:00
|
|
|
private function cleanup_stucked_resources()
|
|
|
|
{
|
2023-10-24 10:10:55 +02:00
|
|
|
// Cleanup any resources that are not attached to any environment or destination or server
|
|
|
|
try {
|
|
|
|
$applications = Application::all();
|
2023-10-25 11:43:18 +02:00
|
|
|
foreach ($applications as $application) {
|
2023-11-06 18:04:18 +01:00
|
|
|
if (!data_get($application, 'environment')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Application without environment' . $application->name . 'deleting\n';
|
2023-10-24 10:10:55 +02:00
|
|
|
$application->delete();
|
|
|
|
}
|
|
|
|
if (!$application->destination()) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Application without destination' . $application->name . 'deleting\n';
|
2023-10-24 10:10:55 +02:00
|
|
|
$application->delete();
|
|
|
|
}
|
2023-11-29 15:03:21 +01:00
|
|
|
if (!data_get($application, 'destination.server')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Application without server' . $application->name . 'deleting\n';
|
2023-11-29 15:03:21 +01:00
|
|
|
$application->delete();
|
|
|
|
}
|
2023-10-24 10:10:55 +02:00
|
|
|
}
|
2023-11-06 18:04:18 +01:00
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Error in application: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
try {
|
2023-10-24 10:10:55 +02:00
|
|
|
$postgresqls = StandalonePostgresql::all();
|
2023-10-25 11:43:18 +02:00
|
|
|
foreach ($postgresqls as $postgresql) {
|
2023-11-06 18:04:18 +01:00
|
|
|
if (!data_get($postgresql, 'environment')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Postgresql without environment' . $postgresql->name . 'deleting\n';
|
2023-10-24 10:10:55 +02:00
|
|
|
$postgresql->delete();
|
|
|
|
}
|
|
|
|
if (!$postgresql->destination()) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Postgresql without destination' . $postgresql->name . 'deleting\n';
|
2023-10-24 10:10:55 +02:00
|
|
|
$postgresql->delete();
|
|
|
|
}
|
2023-11-29 15:03:21 +01:00
|
|
|
if (!data_get($postgresql, 'destination.server')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Postgresql without server' . $postgresql->name . 'deleting\n';
|
2023-11-29 15:03:21 +01:00
|
|
|
$postgresql->delete();
|
|
|
|
}
|
2023-10-24 10:10:55 +02:00
|
|
|
}
|
2023-11-06 18:04:18 +01:00
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Error in postgresql: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
try {
|
2023-10-24 10:10:55 +02:00
|
|
|
$redis = StandaloneRedis::all();
|
2023-10-25 11:43:18 +02:00
|
|
|
foreach ($redis as $redis) {
|
2023-11-06 18:04:18 +01:00
|
|
|
if (!data_get($redis, 'environment')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Redis without environment' . $redis->name . 'deleting\n';
|
2023-10-24 10:10:55 +02:00
|
|
|
$redis->delete();
|
|
|
|
}
|
|
|
|
if (!$redis->destination()) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Redis without destination' . $redis->name . 'deleting\n';
|
2023-10-24 10:10:55 +02:00
|
|
|
$redis->delete();
|
|
|
|
}
|
2023-11-29 15:03:21 +01:00
|
|
|
if (!data_get($redis, 'destination.server')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Redis without server' . $redis->name . 'deleting\n';
|
2023-11-29 15:03:21 +01:00
|
|
|
$redis->delete();
|
|
|
|
}
|
2023-10-24 10:10:55 +02:00
|
|
|
}
|
2023-11-06 18:04:18 +01:00
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Error in redis: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
2023-10-24 10:10:55 +02:00
|
|
|
$mongodbs = StandaloneMongodb::all();
|
2023-10-25 11:43:18 +02:00
|
|
|
foreach ($mongodbs as $mongodb) {
|
2023-11-06 18:04:18 +01:00
|
|
|
if (!data_get($mongodb, 'environment')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Mongodb without environment' . $mongodb->name . 'deleting\n';
|
2023-10-24 10:10:55 +02:00
|
|
|
$mongodb->delete();
|
|
|
|
}
|
|
|
|
if (!$mongodb->destination()) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Mongodb without destination' . $mongodb->name . 'deleting\n';
|
2023-10-24 10:10:55 +02:00
|
|
|
$mongodb->delete();
|
|
|
|
}
|
2023-11-29 15:03:21 +01:00
|
|
|
if (!data_get($mongodb, 'destination.server')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Mongodb without server' . $mongodb->name . 'deleting\n';
|
2023-11-29 15:03:21 +01:00
|
|
|
$mongodb->delete();
|
|
|
|
}
|
2023-10-24 10:10:55 +02:00
|
|
|
}
|
2023-11-06 18:04:18 +01:00
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Error in mongodb: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
2023-10-25 11:43:18 +02:00
|
|
|
$mysqls = StandaloneMysql::all();
|
|
|
|
foreach ($mysqls as $mysql) {
|
2023-11-06 18:04:18 +01:00
|
|
|
if (!data_get($mysql, 'environment')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Mysql without environment' . $mysql->name . 'deleting\n';
|
2023-10-25 11:43:18 +02:00
|
|
|
$mysql->delete();
|
|
|
|
}
|
|
|
|
if (!$mysql->destination()) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Mysql without destination' . $mysql->name . 'deleting\n';
|
2023-10-25 11:43:18 +02:00
|
|
|
$mysql->delete();
|
|
|
|
}
|
2023-11-29 15:03:21 +01:00
|
|
|
if (!data_get($mysql, 'destination.server')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Mysql without server' . $mysql->name . 'deleting\n';
|
2023-11-29 15:03:21 +01:00
|
|
|
$mysql->delete();
|
|
|
|
}
|
2023-10-25 11:43:18 +02:00
|
|
|
}
|
2023-11-06 18:04:18 +01:00
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Error in mysql: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
$mariadbs = StandaloneMariadb::all();
|
2023-10-25 11:43:18 +02:00
|
|
|
foreach ($mariadbs as $mariadb) {
|
2023-11-06 18:04:18 +01:00
|
|
|
if (!data_get($mariadb, 'environment')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Mariadb without environment' . $mariadb->name . 'deleting\n';
|
2023-10-25 11:43:18 +02:00
|
|
|
$mariadb->delete();
|
|
|
|
}
|
|
|
|
if (!$mariadb->destination()) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Mariadb without destination' . $mariadb->name . 'deleting\n';
|
2023-10-25 11:43:18 +02:00
|
|
|
$mariadb->delete();
|
|
|
|
}
|
2023-11-29 15:03:21 +01:00
|
|
|
if (!data_get($mariadb, 'destination.server')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Mariadb without server' . $mariadb->name . 'deleting\n';
|
2023-11-29 15:03:21 +01:00
|
|
|
$mariadb->delete();
|
|
|
|
}
|
2023-10-25 11:43:18 +02:00
|
|
|
}
|
2023-11-06 18:04:18 +01:00
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Error in mariadb: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
2023-10-24 10:10:55 +02:00
|
|
|
$services = Service::all();
|
2023-10-25 11:43:18 +02:00
|
|
|
foreach ($services as $service) {
|
2023-11-06 18:04:18 +01:00
|
|
|
if (!data_get($service, 'environment')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Service without environment' . $service->name . 'deleting\n';
|
2023-10-24 10:10:55 +02:00
|
|
|
$service->delete();
|
|
|
|
}
|
|
|
|
if (!$service->destination()) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Service without destination' . $service->name . 'deleting\n';
|
2023-10-24 10:10:55 +02:00
|
|
|
$service->delete();
|
|
|
|
}
|
2023-11-29 15:03:21 +01:00
|
|
|
if (!data_get($service, 'server')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'Service without server' . $service->name . 'deleting\n';
|
2023-11-29 15:03:21 +01:00
|
|
|
$service->delete();
|
|
|
|
}
|
2023-10-24 10:10:55 +02:00
|
|
|
}
|
|
|
|
} catch (\Throwable $e) {
|
2023-11-06 18:04:18 +01:00
|
|
|
echo "Error in service: {$e->getMessage()}\n";
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
$serviceApplications = ServiceApplication::all();
|
|
|
|
foreach ($serviceApplications as $service) {
|
|
|
|
if (!data_get($service, 'service')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'ServiceApplication without service' . $service->name . 'deleting\n';
|
2023-11-06 18:04:18 +01:00
|
|
|
$service->delete();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Error in serviceApplications: {$e->getMessage()}\n";
|
2023-10-24 10:10:55 +02:00
|
|
|
}
|
2023-11-06 20:58:03 +01:00
|
|
|
try {
|
|
|
|
$serviceDatabases = ServiceDatabase::all();
|
|
|
|
foreach ($serviceDatabases as $service) {
|
|
|
|
if (!data_get($service, 'service')) {
|
2023-11-29 16:19:40 +01:00
|
|
|
echo 'ServiceDatabase without service' . $service->name . 'deleting\n';
|
2023-11-06 20:58:03 +01:00
|
|
|
$service->delete();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (\Throwable $e) {
|
|
|
|
echo "Error in ServiceDatabases: {$e->getMessage()}\n";
|
|
|
|
}
|
2023-10-24 10:10:55 +02:00
|
|
|
}
|
2023-06-30 11:42:59 +02:00
|
|
|
}
|