coolify/app/Models/ScheduledDatabaseBackup.php

104 lines
2.9 KiB
PHP
Raw Normal View History

2023-08-08 15:28:36 +00:00
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Relations\HasMany;
use Illuminate\Database\Eloquent\Relations\HasOne;
use Illuminate\Database\Eloquent\Relations\MorphTo;
2023-08-09 14:47:24 +00:00
class ScheduledDatabaseBackup extends BaseModel
2023-08-08 15:28:36 +00:00
{
protected $fillable = [
'uuid',
'team_id',
'description',
'enabled',
'save_s3',
'frequency',
'database_backup_retention_amount_locally',
'database_type',
'database_id',
's3_storage_id',
'databases_to_backup',
'dump_all',
'database_backup_retention_days_locally',
'database_backup_retention_max_storage_locally',
'database_backup_retention_amount_s3',
'database_backup_retention_days_s3',
'database_backup_retention_max_storage_s3',
'timeout',
'disable_local_backup',
];
2023-08-08 15:28:36 +00:00
public static function ownedByCurrentTeam()
{
return ScheduledDatabaseBackup::whereRelation('team', 'id', currentTeam()->id)->orderBy('created_at', 'desc');
}
public static function ownedByCurrentTeamAPI(int $teamId)
{
return ScheduledDatabaseBackup::whereRelation('team', 'id', $teamId)->orderBy('created_at', 'desc');
}
public function team()
{
return $this->belongsTo(Team::class);
}
public function database(): MorphTo
2023-08-08 15:28:36 +00:00
{
return $this->morphTo();
}
public function latest_log(): HasOne
{
return $this->hasOne(ScheduledDatabaseBackupExecution::class)->latest();
}
public function executions(): HasMany
{
2024-09-03 15:35:18 +00:00
// Last execution first
return $this->hasMany(ScheduledDatabaseBackupExecution::class)->orderBy('created_at', 'desc');
}
2023-08-11 14:13:53 +00:00
public function s3()
{
return $this->belongsTo(S3Storage::class, 's3_storage_id');
}
2024-06-10 20:43:34 +00:00
public function get_last_days_backup_status($days = 7)
{
return $this->hasMany(ScheduledDatabaseBackupExecution::class)->where('created_at', '>=', now()->subDays($days))->get();
}
2024-09-23 17:51:31 +00:00
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,
];
}
2024-08-16 14:01:41 +00:00
public function server()
{
2024-08-16 17:29:44 +00:00
if ($this->database) {
2024-10-10 10:42:34 +00:00
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) {
2024-08-16 17:29:44 +00:00
return $server;
}
2024-08-16 14:01:41 +00:00
}
2024-09-23 17:51:31 +00:00
2024-08-16 14:01:41 +00:00
return null;
}
2024-08-16 17:29:44 +00:00
}