- Modified backup retrieval logic in DatabasesController to utilize the new ownedByCurrentTeamAPI method for improved access control based on team ID. - Enhanced code consistency and maintainability by centralizing team-based filtering in the ScheduledDatabaseBackup model.
		
			
				
	
	
		
			84 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Models;
 | 
						|
 | 
						|
use Illuminate\Database\Eloquent\Relations\HasMany;
 | 
						|
use Illuminate\Database\Eloquent\Relations\HasOne;
 | 
						|
use Illuminate\Database\Eloquent\Relations\MorphTo;
 | 
						|
 | 
						|
class ScheduledDatabaseBackup extends BaseModel
 | 
						|
{
 | 
						|
    protected $guarded = [];
 | 
						|
 | 
						|
    public static function ownedByCurrentTeam()
 | 
						|
    {
 | 
						|
        return ScheduledDatabaseBackup::whereRelation('team', 'id', currentTeam()->id)->orderBy('name');
 | 
						|
    }
 | 
						|
 | 
						|
    public static function ownedByCurrentTeamAPI(int $teamId)
 | 
						|
    {
 | 
						|
        return ScheduledDatabaseBackup::whereRelation('team', 'id', $teamId)->orderBy('name');
 | 
						|
    }
 | 
						|
 | 
						|
    public function team()
 | 
						|
    {
 | 
						|
        return $this->belongsTo(Team::class);
 | 
						|
    }
 | 
						|
 | 
						|
    public function database(): MorphTo
 | 
						|
    {
 | 
						|
        return $this->morphTo();
 | 
						|
    }
 | 
						|
 | 
						|
    public function latest_log(): HasOne
 | 
						|
    {
 | 
						|
        return $this->hasOne(ScheduledDatabaseBackupExecution::class)->latest();
 | 
						|
    }
 | 
						|
 | 
						|
    public function executions(): HasMany
 | 
						|
    {
 | 
						|
        // Last execution first
 | 
						|
        return $this->hasMany(ScheduledDatabaseBackupExecution::class)->orderBy('created_at', 'desc');
 | 
						|
    }
 | 
						|
 | 
						|
    public function s3()
 | 
						|
    {
 | 
						|
        return $this->belongsTo(S3Storage::class, 's3_storage_id');
 | 
						|
    }
 | 
						|
 | 
						|
    public function get_last_days_backup_status($days = 7)
 | 
						|
    {
 | 
						|
        return $this->hasMany(ScheduledDatabaseBackupExecution::class)->where('created_at', '>=', now()->subDays($days))->get();
 | 
						|
    }
 | 
						|
 | 
						|
    public function executionsPaginated(int $skip = 0, int $take = 10)
 | 
						|
    {
 | 
						|
        $executions = $this->hasMany(ScheduledDatabaseBackupExecution::class)->orderBy('created_at', 'desc');
 | 
						|
        $count = $executions->count();
 | 
						|
        $executions = $executions->skip($skip)->take($take)->get();
 | 
						|
 | 
						|
        return [
 | 
						|
            'count' => $count,
 | 
						|
            'executions' => $executions,
 | 
						|
        ];
 | 
						|
    }
 | 
						|
 | 
						|
    public function server()
 | 
						|
    {
 | 
						|
        if ($this->database) {
 | 
						|
            if ($this->database instanceof ServiceDatabase) {
 | 
						|
                $destination = data_get($this->database->service, 'destination');
 | 
						|
                $server = data_get($destination, 'server');
 | 
						|
            } else {
 | 
						|
                $destination = data_get($this->database, 'destination');
 | 
						|
                $server = data_get($destination, 'server');
 | 
						|
            }
 | 
						|
            if ($server) {
 | 
						|
                return $server;
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        return null;
 | 
						|
    }
 | 
						|
}
 |