mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-11-04 10:46:51 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace Pterodactyl\Repositories\Eloquent;
 | 
						|
 | 
						|
use Carbon\Carbon;
 | 
						|
use Pterodactyl\Models\Backup;
 | 
						|
use Pterodactyl\Models\Server;
 | 
						|
use Illuminate\Database\Eloquent\Relations\HasMany;
 | 
						|
 | 
						|
class BackupRepository extends EloquentRepository
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * @return string
 | 
						|
     */
 | 
						|
    public function model()
 | 
						|
    {
 | 
						|
        return Backup::class;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Determines if too many backups have been generated by the server.
 | 
						|
     *
 | 
						|
     * @return \Pterodactyl\Models\Backup[]|\Illuminate\Support\Collection
 | 
						|
     */
 | 
						|
    public function getBackupsGeneratedDuringTimespan(int $server, int $seconds = 600)
 | 
						|
    {
 | 
						|
        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);
 | 
						|
        });
 | 
						|
    }
 | 
						|
}
 |