coolify/app/Jobs/UpdateCoolifyJob.php

52 lines
1.5 KiB
PHP
Raw Normal View History

<?php
namespace App\Jobs;
2024-08-06 14:04:23 +02:00
use App\Actions\Server\UpdateCoolify;
use App\Models\InstanceSettings;
use App\Models\Server;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldBeEncrypted;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
use Illuminate\Support\Facades\Log;
class UpdateCoolifyJob implements ShouldBeEncrypted, ShouldQueue
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
public $timeout = 600;
public function handle(): void
{
try {
CheckForUpdatesJob::dispatchSync();
$settings = InstanceSettings::get();
2024-08-06 14:04:23 +02:00
if (! $settings->new_version_available) {
Log::info('No new version available. Skipping update.');
2024-08-06 14:04:23 +02:00
return;
}
$server = Server::findOrFail(0);
2024-08-06 14:04:23 +02:00
if (! $server) {
Log::error('Server not found. Cannot proceed with update.');
2024-08-06 14:04:23 +02:00
return;
}
Log::info('Starting Coolify update process...');
UpdateCoolify::run(false); // false means it's not a manual update
$settings->update(['new_version_available' => false]);
Log::info('Coolify update completed successfully.');
} catch (\Throwable $e) {
2024-08-06 14:04:23 +02:00
Log::error('UpdateCoolifyJob failed: '.$e->getMessage());
// Consider implementing a notification to administrators
}
}
2024-08-06 14:04:23 +02:00
}