58 lines
1.5 KiB
PHP
58 lines
1.5 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 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 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;
|
|
}
|
|
}
|