52 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Jobs;
 | |
| 
 | |
| 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();
 | |
|             if (! $settings->new_version_available) {
 | |
|                 Log::info('No new version available. Skipping update.');
 | |
| 
 | |
|                 return;
 | |
|             }
 | |
| 
 | |
|             $server = Server::findOrFail(0);
 | |
|             if (! $server) {
 | |
|                 Log::error('Server not found. Cannot proceed with update.');
 | |
| 
 | |
|                 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) {
 | |
|             Log::error('UpdateCoolifyJob failed: '.$e->getMessage());
 | |
|             // Consider implementing a notification to administrators
 | |
|         }
 | |
|     }
 | |
| }
 | 
