46 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Repositories\Eloquent;
 | |
| 
 | |
| use Carbon\Carbon;
 | |
| use App\Models\Backup;
 | |
| use App\Models\Server;
 | |
| use Illuminate\Support\Collection;
 | |
| use Illuminate\Database\Eloquent\Relations\HasMany;
 | |
| 
 | |
| class BackupRepository extends EloquentRepository
 | |
| {
 | |
|     public function model(): string
 | |
|     {
 | |
|         return Backup::class;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Determines if too many backups have been generated by the server.
 | |
|      */
 | |
|     public function getBackupsGeneratedDuringTimespan(int $server, int $seconds = 600): array|Collection
 | |
|     {
 | |
|         return $this->getBuilder()
 | |
|             ->withTrashed()
 | |
|             ->where('server_id', $server)
 | |
|             ->where(function ($query) {
 | |
|                 $query->whereNull('completed_at')
 | |
|                     ->orWhere('is_successful', '=', true);
 | |
|             })
 | |
|             ->where('created_at', '>=', Carbon::now()->subSeconds($seconds)->toDateTimeString())
 | |
|             ->get()
 | |
|             ->toBase();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns a query filtering only non-failed backups for a specific server.
 | |
|      */
 | |
|     public function getNonFailedBackups(Server $server): HasMany
 | |
|     {
 | |
|         return $server->backups()->where(function ($query) {
 | |
|             $query->whereNull('completed_at')
 | |
|                 ->orWhere('is_successful', true);
 | |
|         });
 | |
|     }
 | |
| }
 | 
