| @@ -2,41 +2,50 @@ | ||||
| 
 | ||||
| namespace App\Actions\Proxy; | ||||
| 
 | ||||
| use App\Enums\ProxyTypes; | ||||
| use App\Models\Server; | ||||
| use Illuminate\Support\Str; | ||||
| use Lorisleiva\Actions\Concerns\AsAction; | ||||
| use Spatie\Activitylog\Models\Activity; | ||||
| 
 | ||||
| class CheckProxy | ||||
| { | ||||
|     use AsAction; | ||||
|     public function handle(Server $server) | ||||
|     public function handle(Server $server, $fromUI = false) | ||||
|     { | ||||
|         if (!$server->isProxyShouldRun()) { | ||||
|             throw new \Exception("Proxy should not run"); | ||||
|             if ($fromUI) { | ||||
|                 throw new \Exception("Proxy should not run. You selected the Custom Proxy."); | ||||
|             } else { | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
|         $status = getContainerStatus($server, 'coolify-proxy'); | ||||
|         if ($status === 'running') { | ||||
|             $server->proxy->set('status', 'running'); | ||||
|             $server->save(); | ||||
|             return 'OK'; | ||||
|             return false; | ||||
|         } | ||||
|         $ip = $server->ip; | ||||
|         if ($server->id === 0) { | ||||
|             $ip = 'host.docker.internal'; | ||||
|         } | ||||
| 
 | ||||
|         $connection = @fsockopen($ip, '80'); | ||||
|         $connection = @fsockopen($ip, '443'); | ||||
|         $port80 = is_resource($connection) && fclose($connection); | ||||
|         $port443 = is_resource($connection) && fclose($connection); | ||||
|         ray($ip); | ||||
|         $connection80 = @fsockopen($ip, '80'); | ||||
|         $connection443 = @fsockopen($ip, '443'); | ||||
|         $port80 = is_resource($connection80) && fclose($connection80); | ||||
|         $port443 = is_resource($connection443) && fclose($connection443); | ||||
|         if ($port80) { | ||||
|             if ($fromUI) { | ||||
|                 throw new \Exception("Port 80 is in use.<br>You must stop the process using this port.<br>Docs: <a target='_blank' href='https://coolify.io/docs'>https://coolify.io/docs</a> <br> Discord: <a target='_blank'  href='https://coollabs.io/discord'>https://coollabs.io/discord</a>"); | ||||
|             } else { | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
|         if ($port443) { | ||||
|             throw new \Exception("Port 443 is in use.<br>You must stop the process using this port.<br>Docs: <a target='_blank' href='https://coolify.io/docs'>https://coolify.io/docs</a> <br> Discord: <a target='_blank'  href='https://coollabs.io/discord'>https://coollabs.io/discord</a>>"); | ||||
|             if ($fromUI) { | ||||
|                 throw new \Exception("Port 443 is in use.<br>You must stop the process using this port.<br>Docs: <a target='_blank' href='https://coolify.io/docs'>https://coolify.io/docs</a> <br> Discord: <a target='_blank'  href='https://coollabs.io/discord'>https://coollabs.io/discord</a>"); | ||||
|             } else { | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -13,8 +13,6 @@ class StartProxy | ||||
|     public function handle(Server $server, bool $async = true): string|Activity | ||||
|     { | ||||
|         try { | ||||
|             CheckProxy::run($server); | ||||
| 
 | ||||
|             $proxyType = $server->proxyType(); | ||||
|             $commands = collect([]); | ||||
|             $proxy_path = get_proxy_path(); | ||||
|   | ||||
| @@ -28,6 +28,7 @@ class Kernel extends ConsoleKernel | ||||
|             // $this->check_scheduled_backups($schedule);
 | ||||
|             $this->check_resources($schedule); | ||||
|             $this->cleanup_servers($schedule); | ||||
|             $this->check_scheduled_backups($schedule); | ||||
|         } else { | ||||
|             $schedule->command('horizon:snapshot')->everyFiveMinutes(); | ||||
|             $schedule->job(new CleanupInstanceStuffsJob)->everyTwoMinutes()->onOneServer(); | ||||
|   | ||||
| @@ -39,7 +39,7 @@ class Deploy extends Component | ||||
|     public function checkProxy() | ||||
|     { | ||||
|         try { | ||||
|             CheckProxy::run($this->server); | ||||
|             CheckProxy::run($this->server, true); | ||||
|             $this->emit('startProxyPolling'); | ||||
|             $this->emit('proxyChecked'); | ||||
|         } catch (\Throwable $e) { | ||||
|   | ||||
| @@ -34,7 +34,7 @@ class Status extends Component | ||||
|                 } | ||||
|                 $this->numberOfPolls++; | ||||
|             } | ||||
|             CheckProxy::run($this->server); | ||||
|             CheckProxy::run($this->server, true); | ||||
|             $this->emit('proxyStatusUpdated'); | ||||
|             if ($this->server->proxy->status === 'running') { | ||||
|                 $this->polling = false; | ||||
|   | ||||
| @@ -2,6 +2,7 @@ | ||||
| 
 | ||||
| namespace App\Jobs; | ||||
| 
 | ||||
| use App\Actions\Proxy\CheckProxy; | ||||
| use App\Actions\Proxy\StartProxy; | ||||
| use App\Models\ApplicationPreview; | ||||
| use App\Models\Server; | ||||
| @@ -117,10 +118,18 @@ class ContainerStatusJob implements ShouldQueue, ShouldBeEncrypted | ||||
|                 return data_get($value, 'Name') === '/coolify-proxy'; | ||||
|             })->first(); | ||||
|             if (!$foundProxyContainer) { | ||||
|                 if ($this->server->isProxyShouldRun()) { | ||||
|                 try { | ||||
|                     $shouldStart = CheckProxy::run($this->server); | ||||
|                     if ($shouldStart) { | ||||
|                         StartProxy::run($this->server, false); | ||||
|                         $this->server->team->notify(new ContainerRestarted('coolify-proxy', $this->server)); | ||||
|                     } else { | ||||
|                         ray('Proxy could not be started.'); | ||||
|                     } | ||||
|                 } catch (\Throwable $e) { | ||||
|                     ray($e); | ||||
|                 } | ||||
| 
 | ||||
|             } else { | ||||
|                 $this->server->proxy->status = data_get($foundProxyContainer, 'State.Status'); | ||||
|                 $this->server->save(); | ||||
|   | ||||
| @@ -7,7 +7,7 @@ return [ | ||||
| 
 | ||||
|     // The release version of your application
 | ||||
|     // Example with dynamic git hash: trim(exec('git --git-dir ' . base_path('.git') . ' log --pretty="%h" -n1 HEAD'))
 | ||||
|     'release' => '4.0.0-beta.91', | ||||
|     'release' => '4.0.0-beta.92', | ||||
|     // When left empty or `null` the Laravel environment will be used
 | ||||
|     'environment' => config('app.env'), | ||||
| 
 | ||||
|   | ||||
| @@ -1,3 +1,3 @@ | ||||
| <?php | ||||
| 
 | ||||
| return '4.0.0-beta.91'; | ||||
| return '4.0.0-beta.92'; | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|             "version": "3.12.36" | ||||
|         }, | ||||
|         "v4": { | ||||
|             "version": "4.0.0-beta.91" | ||||
|             "version": "4.0.0-beta.92" | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Andras Bacsai
					Andras Bacsai