| @@ -16,7 +16,7 @@ class SettingsBackup extends Component | |||||||
| 
 | 
 | ||||||
|     public $s3s; |     public $s3s; | ||||||
| 
 | 
 | ||||||
|     public StandalonePostgresql|null|array $database = []; |     public ?StandalonePostgresql $database = null; | ||||||
| 
 | 
 | ||||||
|     public ScheduledDatabaseBackup|null|array $backup = []; |     public ScheduledDatabaseBackup|null|array $backup = []; | ||||||
| 
 | 
 | ||||||
| @@ -43,19 +43,19 @@ class SettingsBackup extends Component | |||||||
|     { |     { | ||||||
|         if (isInstanceAdmin()) { |         if (isInstanceAdmin()) { | ||||||
|             $settings = InstanceSettings::get(); |             $settings = InstanceSettings::get(); | ||||||
|             $database = StandalonePostgresql::whereName('coolify-db')->first(); |             $this->database = StandalonePostgresql::whereName('coolify-db')->first(); | ||||||
|             $s3s = S3Storage::whereTeamId(0)->get() ?? []; |             $s3s = S3Storage::whereTeamId(0)->get() ?? []; | ||||||
|             if ($database) { |             if ($this->database) { | ||||||
|                 if ($database->status !== 'running') { |                 if ($this->database->status !== 'running') { | ||||||
|                     $database->status = 'running'; |                     $this->database->status = 'running'; | ||||||
|                     $database->save(); |                     $this->database->save(); | ||||||
|                 } |                 } | ||||||
|                 $this->database = $database; |                 $this->backup = $this->database->scheduledBackups->first(); | ||||||
|  |                 $this->executions = $this->backup->executions; | ||||||
|             } |             } | ||||||
|             $this->settings = $settings; |             $this->settings = $settings; | ||||||
|             $this->s3s = $s3s; |             $this->s3s = $s3s; | ||||||
|             $this->backup = $this->database?->scheduledBackups?->first() ?? null; | 
 | ||||||
|             $this->executions = $this->backup?->executions ?? []; |  | ||||||
|         } else { |         } else { | ||||||
|             return redirect()->route('dashboard'); |             return redirect()->route('dashboard'); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -9,6 +9,11 @@ const VALID_CRON_STRINGS = [ | |||||||
|     'weekly' => '0 0 * * 0', |     'weekly' => '0 0 * * 0', | ||||||
|     'monthly' => '0 0 1 * *', |     'monthly' => '0 0 1 * *', | ||||||
|     'yearly' => '0 0 1 1 *', |     'yearly' => '0 0 1 1 *', | ||||||
|  |     '@hourly' => '0 * * * *', | ||||||
|  |     '@daily' => '0 0 * * *', | ||||||
|  |     '@weekly' => '0 0 * * 0', | ||||||
|  |     '@monthly' => '0 0 1 * *', | ||||||
|  |     '@yearly' => '0 0 1 1 *', | ||||||
| ]; | ]; | ||||||
| const RESTART_MODE = 'unless-stopped'; | const RESTART_MODE = 'unless-stopped'; | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ return [ | |||||||
| 
 | 
 | ||||||
|     // The release version of your application
 |     // The release version of your application
 | ||||||
|     // Example with dynamic git hash: trim(exec('git --git-dir ' . base_path('.git') . ' log --pretty="%h" -n1 HEAD'))
 |     // Example with dynamic git hash: trim(exec('git --git-dir ' . base_path('.git') . ' log --pretty="%h" -n1 HEAD'))
 | ||||||
|     'release' => '4.0.0-beta.320', |     'release' => '4.0.0-beta.321', | ||||||
|     // When left empty or `null` the Laravel environment will be used
 |     // When left empty or `null` the Laravel environment will be used
 | ||||||
|     'environment' => config('app.env'), |     'environment' => config('app.env'), | ||||||
| 
 | 
 | ||||||
|   | |||||||
| @@ -1,3 +1,3 @@ | |||||||
| <?php | <?php | ||||||
| 
 | 
 | ||||||
| return '4.0.0-beta.320'; | return '4.0.0-beta.321'; | ||||||
|   | |||||||
| @@ -1,5 +1,7 @@ | |||||||
| <form class="flex flex-col w-full gap-2 rounded" wire:submit='submit'> | <form class="flex flex-col w-full gap-2 rounded" wire:submit='submit'> | ||||||
|     <x-forms.input autofocus placeholder="0 0 * * * or daily" id="frequency" label="Frequency" required /> |     <x-forms.input autofocus placeholder="0 0 * * * or daily" id="frequency" | ||||||
|  |         helper="You can use every_minute, hourly, daily, weekly, monthly, yearly or a cron expression." label="Frequency" | ||||||
|  |         required /> | ||||||
|     <x-forms.checkbox id="save_s3" label="Save to S3" /> |     <x-forms.checkbox id="save_s3" label="Save to S3" /> | ||||||
|     <x-forms.select id="selected_storage_id"> |     <x-forms.select id="selected_storage_id"> | ||||||
|         @if ($s3s->count() === 0) |         @if ($s3s->count() === 0) | ||||||
|   | |||||||
| @@ -1,7 +1,9 @@ | |||||||
| <form class="flex flex-col w-full gap-2 rounded" wire:submit='submit'> | <form class="flex flex-col w-full gap-2 rounded" wire:submit='submit'> | ||||||
|     <x-forms.input autofocus placeholder="Run cron" id="name" label="Name" /> |     <x-forms.input autofocus placeholder="Run cron" id="name" label="Name" /> | ||||||
|     <x-forms.input placeholder="php artisan schedule:run" id="command" label="Command" /> |     <x-forms.input placeholder="php artisan schedule:run" id="command" label="Command" /> | ||||||
|     <x-forms.input placeholder="0 0 * * * or daily" id="frequency" label="Frequency" /> |     <x-forms.input placeholder="0 0 * * * or daily" | ||||||
|  |         helper="You can use every_minute, hourly, daily, weekly, monthly, yearly or a cron expression." id="frequency" | ||||||
|  |         label="Frequency" /> | ||||||
|     @if ($type === 'application') |     @if ($type === 'application') | ||||||
|         @if ($containerNames->count() > 1) |         @if ($containerNames->count() > 1) | ||||||
|             <x-forms.select id="container" label="Container name"> |             <x-forms.select id="container" label="Container name"> | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ | |||||||
|         </div> |         </div> | ||||||
|         <div class="pb-4">Backup configuration for Coolify instance.</div> |         <div class="pb-4">Backup configuration for Coolify instance.</div> | ||||||
|         <div> |         <div> | ||||||
|             @if (isset($database)) |             @if (isset($database) && isset($backup)) | ||||||
|                 <div class="flex flex-col gap-3 pb-4"> |                 <div class="flex flex-col gap-3 pb-4"> | ||||||
|                     <div class="flex gap-2"> |                     <div class="flex gap-2"> | ||||||
|                         <x-forms.input label="UUID" readonly id="database.uuid" /> |                         <x-forms.input label="UUID" readonly id="database.uuid" /> | ||||||
| @@ -27,14 +27,15 @@ | |||||||
|                     </div> |                     </div> | ||||||
|                 </div> |                 </div> | ||||||
|                 <livewire:project.database.backup-edit :backup="$backup" :s3s="$s3s" :status="data_get($database, 'status')" /> |                 <livewire:project.database.backup-edit :backup="$backup" :s3s="$s3s" :status="data_get($database, 'status')" /> | ||||||
|  |                 <div class="py-4"> | ||||||
|  |                     <livewire:project.database.backup-executions :backup="$backup" /> | ||||||
|  |                 </div> | ||||||
|             @else |             @else | ||||||
|                 To configure automatic backup for your Coolify instance, you first need to add a database resource |                 To configure automatic backup for your Coolify instance, you first need to add a database resource | ||||||
|                 into Coolify. |                 into Coolify. | ||||||
|                 <x-forms.button class="mt-2" wire:click="add_coolify_database">Add Database</x-forms.button> |                 <x-forms.button class="mt-2" wire:click="add_coolify_database">Add Database</x-forms.button> | ||||||
|             @endif |             @endif | ||||||
|         </div> |         </div> | ||||||
|         <div class="py-4"> | 
 | ||||||
|             <livewire:project.database.backup-executions :backup="$backup" /> |  | ||||||
|         </div> |  | ||||||
|     </div> |     </div> | ||||||
| </div> | </div> | ||||||
|   | |||||||
| @@ -60,13 +60,13 @@ | |||||||
|             <div class="flex items-end gap-2"> |             <div class="flex items-end gap-2"> | ||||||
|                 <x-forms.input required id="update_check_frequency" label="Update Check Frequency" |                 <x-forms.input required id="update_check_frequency" label="Update Check Frequency" | ||||||
|                     placeholder="0 * * * *" |                     placeholder="0 * * * *" | ||||||
|                     helper="Cron expression for update check frequency (check for new Coolify versions and pull new Service Templates from CDN). Default is every hour." /> |                     helper="Cron expression for update check frequency (check for new Coolify versions and pull new Service Templates from CDN).<br>You can use every_minute, hourly, daily, weekly, monthly, yearly.<br><br>Default is every hour." /> | ||||||
|                 <x-forms.button wire:click='checkManually'>Check Manually</x-forms.button> |                 <x-forms.button wire:click='checkManually'>Check Manually</x-forms.button> | ||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
|             @if (is_null(env('AUTOUPDATE', null)) && $is_auto_update_enabled) |             @if (is_null(env('AUTOUPDATE', null)) && $is_auto_update_enabled) | ||||||
|                 <x-forms.input required id="auto_update_frequency" label="Auto Update Frequency" placeholder="0 0 * * *" |                 <x-forms.input required id="auto_update_frequency" label="Auto Update Frequency" placeholder="0 0 * * *" | ||||||
|                     helper="Cron expression for auto update frequency (automatically update coolify). Default is every day at 00:00" /> |                     helper="Cron expression for auto update frequency (automatically update coolify).<br>You can use every_minute, hourly, daily, weekly, monthly, yearly.<br><br>Default is every day at 00:00" /> | ||||||
|             @endif |             @endif | ||||||
|         </div> |         </div> | ||||||
|     </form> |     </form> | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| { | { | ||||||
|     "coolify": { |     "coolify": { | ||||||
|         "v4": { |         "v4": { | ||||||
|             "version": "4.0.0-beta.320" |             "version": "4.0.0-beta.321" | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Andras Bacsai
					Andras Bacsai