mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-26 22:26:51 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			42 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Console\Commands\Maintenance;
 | |
| 
 | |
| use App\Models\Backup;
 | |
| use Carbon\CarbonImmutable;
 | |
| use Illuminate\Console\Command;
 | |
| 
 | |
| class PruneOrphanedBackupsCommand extends Command
 | |
| {
 | |
|     protected $signature = 'p:maintenance:prune-backups {--prune-age=}';
 | |
| 
 | |
|     protected $description = 'Marks all backups older than "n" minutes that have not yet completed as being failed.';
 | |
| 
 | |
|     public function handle(): void
 | |
|     {
 | |
|         $since = $this->option('prune-age') ?? config('backups.prune_age', 360);
 | |
|         if (!$since || !is_digit($since)) {
 | |
|             throw new \InvalidArgumentException('The "--prune-age" argument must be a value greater than 0.');
 | |
|         }
 | |
| 
 | |
|         $query = Backup::query()
 | |
|             ->whereNull('completed_at')
 | |
|             ->where('created_at', '<=', CarbonImmutable::now()->subMinutes($since)->toDateTimeString());
 | |
| 
 | |
|         $count = $query->count();
 | |
|         if (!$count) {
 | |
|             $this->info('There are no orphaned backups to be marked as failed.');
 | |
| 
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         $this->warn("Marking $count uncompleted backups that are older than $since minutes as failed.");
 | |
| 
 | |
|         $query->update([
 | |
|             'is_successful' => false,
 | |
|             'completed_at' => CarbonImmutable::now(),
 | |
|             'updated_at' => CarbonImmutable::now(),
 | |
|         ]);
 | |
|     }
 | |
| }
 | 
