Merge pull request #1711 from coollabsio/next
Refactor server validation and installation logic
This commit is contained in:
		| @@ -17,16 +17,22 @@ class ValidateAndInstall extends Component | ||||
|     public $docker_version = null; | ||||
|     public $error = null; | ||||
| 
 | ||||
|     protected $listeners = ['validateServer', 'validateDockerEngine']; | ||||
|     protected $listeners = ['validateServer' => 'init', 'validateDockerEngine', 'validateServerNow' => 'validateServer']; | ||||
| 
 | ||||
|     public function validateServer(bool $install = true) | ||||
|     public function init(bool $install = true) | ||||
|     { | ||||
|         $this->install = $install; | ||||
|         $this->uptime = null; | ||||
|         $this->supported_os_type = null; | ||||
|         $this->docker_installed = null; | ||||
|         $this->docker_version = null; | ||||
|         $this->error = null; | ||||
|         $this->number_of_tries = 0; | ||||
|         $this->dispatch('validateServerNow'); | ||||
|     } | ||||
| 
 | ||||
|     public function validateServer() | ||||
|     { | ||||
|         try { | ||||
|             $this->validateConnection(); | ||||
|             $this->validateOS(); | ||||
| @@ -46,7 +52,7 @@ class ValidateAndInstall extends Component | ||||
|     { | ||||
|         $this->uptime = $this->server->validateConnection(); | ||||
|         if (!$this->uptime) { | ||||
|             $this->dispatch('error', 'Server is not reachable.', 'Please validate your configuration and connection.<br><br>Check this <a target="_blank" class="underline" href="https://coolify.io/docs/server/openssh">documentation</a> for further help.'); | ||||
|             $this->error = 'Server is not reachable. Please validate your configuration and connection.<br><br>Check this <a target="_blank" class="underline" href="https://coolify.io/docs/server/openssh">documentation</a> for further help.'; | ||||
|             return; | ||||
|         } | ||||
|     } | ||||
| @@ -54,7 +60,7 @@ class ValidateAndInstall extends Component | ||||
|     { | ||||
|         $this->supported_os_type = $this->server->validateOS(); | ||||
|         if (!$this->supported_os_type) { | ||||
|             $this->dispatch('error', 'Server OS type is not supported.', 'Please install Docker manually before continuing: <a target="_blank" class="underline" href="https://docs.docker.com/engine/install/#server">documentation</a>.'); | ||||
|             $this->error = 'Server OS type is not supported. Please install Docker manually before continuing: <a target="_blank" class="underline" href="https://docs.docker.com/engine/install/#server">documentation</a>.'; | ||||
|             return; | ||||
|         } | ||||
|     } | ||||
| @@ -72,10 +78,9 @@ class ValidateAndInstall extends Component | ||||
|                     $this->number_of_tries++; | ||||
|                     $this->dispatch('newActivityMonitor', $activity->id, 'validateDockerEngine'); | ||||
|                     return; | ||||
| 
 | ||||
|                 } | ||||
|             } else { | ||||
|                 $this->dispatch('error', 'Docker Engine is not installed.', 'Please install Docker manually before continuing: <a target="_blank" class="underline" href="https://docs.docker.com/engine/install/#server">documentation</a>.'); | ||||
|                 $this->error = 'Docker Engine is not installed. Please install Docker manually before continuing: <a target="_blank" class="underline" href="https://docs.docker.com/engine/install/#server">documentation</a>.'; | ||||
|                 return; | ||||
|             } | ||||
|         } else { | ||||
| @@ -89,7 +94,7 @@ class ValidateAndInstall extends Component | ||||
|             $this->dispatch('serverInstalled'); | ||||
|             $this->dispatch('success', 'Server validated successfully.'); | ||||
|         } else { | ||||
|             $this->dispatch('error', 'Docker Engine version is not 22+.', 'Please install Docker manually before continuing: <a target="_blank" class="underline" href="https://docs.docker.com/engine/install/#server">documentation</a>.'); | ||||
|             $this->error = 'Docker Engine version is not 22+. Please install Docker manually before continuing: <a target="_blank" class="underline" href="https://docs.docker.com/engine/install/#server">documentation</a>.'; | ||||
|             return; | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -11,9 +11,18 @@ | ||||
|                 </g> | ||||
|             </svg></div> | ||||
|     @else | ||||
|         <div class="w-64"><x-loading text="Server is reachable" /></div> | ||||
|         @if ($error) | ||||
|             <div class="flex w-64 gap-2">Server is reachable: <svg class="w-5 h-5 text-error" viewBox="0 0 256 256" | ||||
|                     xmlns="http://www.w3.org/2000/svg"> | ||||
|                     <path fill="currentColor" | ||||
|                         d="M208.49 191.51a12 12 0 0 1-17 17L128 145l-63.51 63.49a12 12 0 0 1-17-17L111 128L47.51 64.49a12 12 0 0 1 17-17L128 111l63.51-63.52a12 12 0 0 1 17 17L145 128Z" /> | ||||
|                 </svg></div> | ||||
|         @else | ||||
|             <div class="w-64"><x-loading text="Server is reachable: " /></div> | ||||
|         @endif | ||||
|     @isset($supported_os_type) | ||||
|     @endif | ||||
|     @if ($uptime) | ||||
|         @if ($supported_os_type) | ||||
|             <div class="flex w-64 gap-2">Supported OS type: <svg class="w-5 h-5 text-success" viewBox="0 0 256 256" | ||||
|                     xmlns="http://www.w3.org/2000/svg"> | ||||
|                     <g fill="currentColor"> | ||||
| @@ -24,7 +33,19 @@ | ||||
|                             d="m243.28 68.24l-24-23.56a16 16 0 0 0-22.58 0L104 136l-.11-.11l-36.64-35.27a16 16 0 0 0-22.57.06l-24 24a16 16 0 0 0 0 22.61l71.62 72a16 16 0 0 0 22.63 0l128.4-128.38a16 16 0 0 0-.05-22.67M103.62 208L32 136l24-24l.11.11l36.64 35.27a16 16 0 0 0 22.52 0L208.06 56L232 79.6Z" /> | ||||
|                     </g> | ||||
|                 </svg></div> | ||||
|     @endisset | ||||
|         @else | ||||
|             @if ($error) | ||||
|                 <div class="flex w-64 gap-2">Server is reachable: <svg class="w-5 h-5 text-error" viewBox="0 0 256 256" | ||||
|                         xmlns="http://www.w3.org/2000/svg"> | ||||
|                         <path fill="currentColor" | ||||
|                             d="M208.49 191.51a12 12 0 0 1-17 17L128 145l-63.51 63.49a12 12 0 0 1-17-17L111 128L47.51 64.49a12 12 0 0 1 17-17L128 111l63.51-63.52a12 12 0 0 1 17 17L145 128Z" /> | ||||
|                     </svg></div> | ||||
|             @else | ||||
|                 <div class="w-64"><x-loading text="Server is reachable:" /></div> | ||||
|             @endif | ||||
|         @endif | ||||
|     @endif | ||||
|     @if ($uptime && $supported_os_type) | ||||
|         @if ($docker_installed) | ||||
|             <div class="flex w-64 gap-2">Docker is installed: <svg class="w-5 h-5 text-success" viewBox="0 0 256 256" | ||||
|                     xmlns="http://www.w3.org/2000/svg"> | ||||
| @@ -36,6 +57,17 @@ | ||||
|                             d="m243.28 68.24l-24-23.56a16 16 0 0 0-22.58 0L104 136l-.11-.11l-36.64-35.27a16 16 0 0 0-22.57.06l-24 24a16 16 0 0 0 0 22.61l71.62 72a16 16 0 0 0 22.63 0l128.4-128.38a16 16 0 0 0-.05-22.67M103.62 208L32 136l24-24l.11.11l36.64 35.27a16 16 0 0 0 22.52 0L208.06 56L232 79.6Z" /> | ||||
|                     </g> | ||||
|                 </svg></div> | ||||
|         @else | ||||
|             @if ($error) | ||||
|                 <div class="flex w-64 gap-2">Docker is installed: <svg class="w-5 h-5 text-error" viewBox="0 0 256 256" | ||||
|                         xmlns="http://www.w3.org/2000/svg"> | ||||
|                         <path fill="currentColor" | ||||
|                             d="M208.49 191.51a12 12 0 0 1-17 17L128 145l-63.51 63.49a12 12 0 0 1-17-17L111 128L47.51 64.49a12 12 0 0 1 17-17L128 111l63.51-63.52a12 12 0 0 1 17 17L145 128Z" /> | ||||
|                     </svg></div> | ||||
|             @else | ||||
|                 <div class="w-64"><x-loading text="Docker is installed:" /></div> | ||||
|             @endif | ||||
|         @endif | ||||
|     @endif | ||||
|     @isset($docker_version) | ||||
|         <div class="flex w-64 gap-2">Minimum Docker version installed: <svg class="w-5 h-5 text-success" | ||||
| @@ -49,7 +81,7 @@ | ||||
|                 </g> | ||||
|             </svg></div> | ||||
|     @endisset | ||||
|     <livewire:new-activity-monitor header="Docker Installation" /> | ||||
|     <livewire:new-activity-monitor header="Logs" /> | ||||
|     @isset($error) | ||||
|         <pre class="font-bold whitespace-pre-line text-error">{!! $error !!}</pre> | ||||
|     @endisset | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Andras Bacsai
					Andras Bacsai