refactor create scheduled backup livewire

This commit is contained in:
Andras Bacsai
2024-11-04 11:53:32 +01:00
parent e30dcf1101
commit c11dfdee1f
3 changed files with 31 additions and 30 deletions

View File

@@ -4,44 +4,45 @@ namespace App\Livewire\Project\Database;
use App\Models\ScheduledDatabaseBackup; use App\Models\ScheduledDatabaseBackup;
use Illuminate\Support\Collection; use Illuminate\Support\Collection;
use Livewire\Attributes\Locked;
use Livewire\Attributes\Rule;
use Livewire\Component; use Livewire\Component;
class CreateScheduledBackup extends Component class CreateScheduledBackup extends Component
{ {
public $database; #[Rule(['required', 'string'])]
public $frequency; public $frequency;
#[Rule(['required', 'boolean'])]
public bool $saveToS3 = false;
#[Locked]
public $database;
public bool $enabled = true; public bool $enabled = true;
public bool $save_s3 = false; #[Rule(['required', 'integer'])]
public int $s3StorageId;
public $s3_storage_id; public Collection $definedS3s;
public Collection $s3s;
protected $rules = [
'frequency' => 'required|string',
'save_s3' => 'required|boolean',
];
protected $validationAttributes = [
'frequency' => 'Backup Frequency',
'save_s3' => 'Save to S3',
];
public function mount() public function mount()
{ {
$this->s3s = currentTeam()->s3s; try {
if ($this->s3s->count() > 0) { $this->definedS3s = currentTeam()->s3s;
$this->s3_storage_id = $this->s3s->first()->id; if ($this->definedS3s->count() > 0) {
$this->s3StorageId = $this->definedS3s->first()->id;
}
} catch (\Throwable $e) {
return handleError($e, $this);
} }
} }
public function submit(): void public function submit()
{ {
try { try {
$this->validate(); $this->validate();
$isValid = validate_cron_expression($this->frequency); $isValid = validate_cron_expression($this->frequency);
if (! $isValid) { if (! $isValid) {
$this->dispatch('error', 'Invalid Cron / Human expression.'); $this->dispatch('error', 'Invalid Cron / Human expression.');
@@ -51,8 +52,8 @@ class CreateScheduledBackup extends Component
$payload = [ $payload = [
'enabled' => true, 'enabled' => true,
'frequency' => $this->frequency, 'frequency' => $this->frequency,
'save_s3' => $this->save_s3, 'save_s3' => $this->saveToS3,
's3_storage_id' => $this->s3_storage_id, 's3_storage_id' => $this->s3StorageId,
'database_id' => $this->database->id, 'database_id' => $this->database->id,
'database_type' => $this->database->getMorphClass(), 'database_type' => $this->database->getMorphClass(),
'team_id' => currentTeam()->id, 'team_id' => currentTeam()->id,
@@ -72,10 +73,10 @@ class CreateScheduledBackup extends Component
$this->dispatch('refreshScheduledBackups'); $this->dispatch('refreshScheduledBackups');
} }
} catch (\Throwable $e) { } catch (\Throwable $e) {
handleError($e, $this); return handleError($e, $this);
} finally { } finally {
$this->frequency = ''; $this->frequency = '';
$this->save_s3 = true; $this->saveToS3 = true;
} }
} }
} }

View File

@@ -2,13 +2,13 @@
<x-forms.input placeholder="0 0 * * * or daily" id="frequency" <x-forms.input placeholder="0 0 * * * or daily" id="frequency"
helper="You can use every_minute, hourly, daily, weekly, monthly, yearly or a cron expression." label="Frequency" helper="You can use every_minute, hourly, daily, weekly, monthly, yearly or a cron expression." label="Frequency"
required /> required />
@if ($s3s->count() === 0) @if ($definedS3s->count() === 0)
<div class="text-red-500">No validated S3 Storages found.</div> <div class="text-red-500">No validated S3 Storages found.</div>
@else @else
<x-forms.checkbox wire:model.live="save_s3" label="Save to S3" /> <x-forms.checkbox wire:model.live="saveToS3" label="Save to S3" />
@if ($save_s3) @if ($saveToS3)
<x-forms.select id="selected_storage_id" label="Select a validated S3 storage"> <x-forms.select id="s3StorageId" label="Select a S3 Storage">
@foreach ($s3s as $s3) @foreach ($definedS3s as $s3)
<option value="{{ $s3->id }}">{{ $s3->name }}</option> <option value="{{ $s3->id }}">{{ $s3->name }}</option>
@endforeach @endforeach
</x-forms.select> </x-forms.select>

View File

@@ -38,7 +38,7 @@
<div class="flex gap-2 "> <div class="flex gap-2 ">
<h2 class="pb-4">Scheduled Backups</h2> <h2 class="pb-4">Scheduled Backups</h2>
<x-modal-input buttonTitle="+ Add" title="New Scheduled Backup"> <x-modal-input buttonTitle="+ Add" title="New Scheduled Backup">
<livewire:project.database.create-scheduled-backup :database="$serviceDatabase" :s3s="$s3s" /> <livewire:project.database.create-scheduled-backup :database="$serviceDatabase" />
</x-modal-input> </x-modal-input>
</div> </div>
<livewire:project.database.scheduled-backups :database="$serviceDatabase" /> <livewire:project.database.scheduled-backups :database="$serviceDatabase" />