commit
						67df166c20
					
				| @ -18,7 +18,6 @@ use App\Models\StandalonePostgresql; | |||||||
| use App\Models\StandaloneRedis; | use App\Models\StandaloneRedis; | ||||||
| use Illuminate\Console\Command; | use Illuminate\Console\Command; | ||||||
| use Illuminate\Support\Facades\Http; | use Illuminate\Support\Facades\Http; | ||||||
| use Illuminate\Support\Facades\Storage; |  | ||||||
| 
 | 
 | ||||||
| class Init extends Command | class Init extends Command | ||||||
| { | { | ||||||
| @ -36,6 +35,14 @@ class Init extends Command | |||||||
|         } |         } | ||||||
|         $this->cleanup_in_progress_application_deployments(); |         $this->cleanup_in_progress_application_deployments(); | ||||||
|         $this->cleanup_stucked_helper_containers(); |         $this->cleanup_stucked_helper_containers(); | ||||||
|  |         setup_dynamic_configuration(); | ||||||
|  | 
 | ||||||
|  |         $settings = InstanceSettings::get(); | ||||||
|  |         if (env('AUTOUPDATE') == true) { | ||||||
|  |             $settings->update(['is_auto_update_enabled' => true]); | ||||||
|  |         } else { | ||||||
|  |             $settings->update(['is_auto_update_enabled' => false]); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|     private function cleanup_stucked_helper_containers() |     private function cleanup_stucked_helper_containers() | ||||||
|     { |     { | ||||||
|  | |||||||
| @ -71,83 +71,7 @@ class Configuration extends Component | |||||||
| 
 | 
 | ||||||
|     private function setup_instance_fqdn() |     private function setup_instance_fqdn() | ||||||
|     { |     { | ||||||
|         $file = "$this->dynamic_config_path/coolify.yaml"; |         setup_dynamic_configuration(); | ||||||
|         if (empty($this->settings->fqdn)) { |  | ||||||
|             instant_remote_process([ |  | ||||||
|                 "rm -f $file", |  | ||||||
|             ], $this->server); |  | ||||||
|         } else { |  | ||||||
|             $url = Url::fromString($this->settings->fqdn); |  | ||||||
|             $host = $url->getHost(); |  | ||||||
|             $schema = $url->getScheme(); |  | ||||||
|             $traefik_dynamic_conf = [ |  | ||||||
|                 'http' => |  | ||||||
|                 [ |  | ||||||
|                     'routers' => |  | ||||||
|                     [ |  | ||||||
|                         'coolify-http' => |  | ||||||
|                         [ |  | ||||||
|                             'entryPoints' => [ |  | ||||||
|                                 0 => 'http', |  | ||||||
|                             ], |  | ||||||
|                             'service' => 'coolify', |  | ||||||
|                             'rule' => "Host(`{$host}`)", |  | ||||||
|                         ], |  | ||||||
|                     ], |  | ||||||
|                     'services' => |  | ||||||
|                     [ |  | ||||||
|                         'coolify' => |  | ||||||
|                         [ |  | ||||||
|                             'loadBalancer' => |  | ||||||
|                             [ |  | ||||||
|                                 'servers' => |  | ||||||
|                                 [ |  | ||||||
|                                     0 => |  | ||||||
|                                     [ |  | ||||||
|                                         'url' => 'http://coolify:80', |  | ||||||
|                                     ], |  | ||||||
|                                 ], |  | ||||||
|                             ], |  | ||||||
|                         ], |  | ||||||
|                     ], |  | ||||||
|                 ], |  | ||||||
|             ]; |  | ||||||
| 
 | 
 | ||||||
|             if ($schema === 'https') { |  | ||||||
|                 $traefik_dynamic_conf['http']['routers']['coolify-http']['middlewares'] = [ |  | ||||||
|                     0 => 'redirect-to-https@docker', |  | ||||||
|                 ]; |  | ||||||
|                 $traefik_dynamic_conf['http']['routers']['coolify-https'] = [ |  | ||||||
|                     'entryPoints' => [ |  | ||||||
|                         0 => 'https', |  | ||||||
|                     ], |  | ||||||
|                     'service' => 'coolify', |  | ||||||
|                     'rule' => "Host(`{$host}`)", |  | ||||||
|                     'tls' => [ |  | ||||||
|                         'certresolver' => 'letsencrypt', |  | ||||||
|                     ], |  | ||||||
|                 ]; |  | ||||||
|             } |  | ||||||
|             $this->save_configuration_to_disk($traefik_dynamic_conf, $file); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     private function save_configuration_to_disk(array $traefik_dynamic_conf, string $file) |  | ||||||
|     { |  | ||||||
|         $yaml = Yaml::dump($traefik_dynamic_conf, 12, 2); |  | ||||||
|         $yaml = |  | ||||||
|             "# This file is automatically generated by Coolify.\n" . |  | ||||||
|             "# Do not edit it manually (only if you know what are you doing).\n\n" . |  | ||||||
|             $yaml; |  | ||||||
| 
 |  | ||||||
|         $base64 = base64_encode($yaml); |  | ||||||
|         instant_remote_process([ |  | ||||||
|             "mkdir -p $this->dynamic_config_path", |  | ||||||
|             "echo '$base64' | base64 -d > $file", |  | ||||||
|         ], $this->server); |  | ||||||
| 
 |  | ||||||
|         if (config('app.env') == 'local') { |  | ||||||
|             ray($yaml); |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -6,6 +6,8 @@ use App\Notifications\Channels\SendsEmail; | |||||||
| use Illuminate\Database\Eloquent\Casts\Attribute; | use Illuminate\Database\Eloquent\Casts\Attribute; | ||||||
| use Illuminate\Database\Eloquent\Model; | use Illuminate\Database\Eloquent\Model; | ||||||
| use Illuminate\Notifications\Notifiable; | use Illuminate\Notifications\Notifiable; | ||||||
|  | use Illuminate\Support\Facades\Log; | ||||||
|  | use Illuminate\Support\Facades\Request; | ||||||
| use Spatie\Url\Url; | use Spatie\Url\Url; | ||||||
| 
 | 
 | ||||||
| class InstanceSettings extends Model implements SendsEmail | class InstanceSettings extends Model implements SendsEmail | ||||||
|  | |||||||
| @ -16,7 +16,6 @@ class AppServiceProvider extends ServiceProvider | |||||||
|     public function boot(): void |     public function boot(): void | ||||||
|     { |     { | ||||||
|         Sanctum::usePersonalAccessTokenModel(PersonalAccessToken::class); |         Sanctum::usePersonalAccessTokenModel(PersonalAccessToken::class); | ||||||
| 
 |  | ||||||
|         Http::macro('github', function (string $api_url, string|null $github_access_token = null) { |         Http::macro('github', function (string $api_url, string|null $github_access_token = null) { | ||||||
|             if ($github_access_token) { |             if ($github_access_token) { | ||||||
|                 return Http::withHeaders([ |                 return Http::withHeaders([ | ||||||
|  | |||||||
| @ -2,7 +2,9 @@ | |||||||
| 
 | 
 | ||||||
| use App\Actions\Proxy\SaveConfiguration; | use App\Actions\Proxy\SaveConfiguration; | ||||||
| use App\Models\Application; | use App\Models\Application; | ||||||
|  | use App\Models\InstanceSettings; | ||||||
| use App\Models\Server; | use App\Models\Server; | ||||||
|  | use Spatie\Url\Url; | ||||||
| use Symfony\Component\Yaml\Yaml; | use Symfony\Component\Yaml\Yaml; | ||||||
| 
 | 
 | ||||||
| function get_proxy_path() | function get_proxy_path() | ||||||
| @ -155,7 +157,117 @@ function generate_default_proxy_configuration(Server $server) | |||||||
|     SaveConfiguration::run($server, $config); |     SaveConfiguration::run($server, $config); | ||||||
|     return $config; |     return $config; | ||||||
| } | } | ||||||
|  | function setup_dynamic_configuration() | ||||||
|  | { | ||||||
|  |     $dynamic_config_path = get_proxy_path() . "/dynamic"; | ||||||
|  |     $settings = InstanceSettings::get(); | ||||||
|  |     $server = Server::findOrFail(0); | ||||||
|  |     $file = "$dynamic_config_path/coolify.yaml"; | ||||||
|  |     if (empty($settings->fqdn)) { | ||||||
|  |         instant_remote_process([ | ||||||
|  |             "rm -f $file", | ||||||
|  |         ], $server); | ||||||
|  |     } else { | ||||||
|  |         $url = Url::fromString($settings->fqdn); | ||||||
|  |         $host = $url->getHost(); | ||||||
|  |         $schema = $url->getScheme(); | ||||||
|  |         $traefik_dynamic_conf = [ | ||||||
|  |             'http' => | ||||||
|  |             [ | ||||||
|  |                 'routers' => | ||||||
|  |                 [ | ||||||
|  |                     'coolify-http' => | ||||||
|  |                     [ | ||||||
|  |                         'entryPoints' => [ | ||||||
|  |                             0 => 'http', | ||||||
|  |                         ], | ||||||
|  |                         'service' => 'coolify', | ||||||
|  |                         'rule' => "Host(`{$host}`)", | ||||||
|  |                     ], | ||||||
|  |                     'coolify-realtime-ws' => | ||||||
|  |                     [ | ||||||
|  |                         'entryPoints' => [ | ||||||
|  |                             0 => 'http', | ||||||
|  |                         ], | ||||||
|  |                         'service' => 'coolify-realtime', | ||||||
|  |                         'rule' => "Host(`{$host}`) && PathPrefix(`/app`)", | ||||||
|  |                     ], | ||||||
|  |                 ], | ||||||
|  |                 'services' => | ||||||
|  |                 [ | ||||||
|  |                     'coolify' => | ||||||
|  |                     [ | ||||||
|  |                         'loadBalancer' => | ||||||
|  |                         [ | ||||||
|  |                             'servers' => | ||||||
|  |                             [ | ||||||
|  |                                 0 => | ||||||
|  |                                 [ | ||||||
|  |                                     'url' => 'http://coolify:80', | ||||||
|  |                                 ], | ||||||
|  |                             ], | ||||||
|  |                         ], | ||||||
|  |                     ], | ||||||
|  |                     'coolify-realtime' => | ||||||
|  |                     [ | ||||||
|  |                         'loadBalancer' => | ||||||
|  |                         [ | ||||||
|  |                             'servers' => | ||||||
|  |                             [ | ||||||
|  |                                 0 => | ||||||
|  |                                 [ | ||||||
|  |                                     'url' => 'http://coolify-realtime:6001', | ||||||
|  |                                 ], | ||||||
|  |                             ], | ||||||
|  |                         ], | ||||||
|  |                     ], | ||||||
|  |                 ], | ||||||
|  |             ], | ||||||
|  |         ]; | ||||||
| 
 | 
 | ||||||
|  |         if ($schema === 'https') { | ||||||
|  |             $traefik_dynamic_conf['http']['routers']['coolify-http']['middlewares'] = [ | ||||||
|  |                 0 => 'redirect-to-https@docker', | ||||||
|  |             ]; | ||||||
|  | 
 | ||||||
|  |             $traefik_dynamic_conf['http']['routers']['coolify-https'] = [ | ||||||
|  |                 'entryPoints' => [ | ||||||
|  |                     0 => 'https', | ||||||
|  |                 ], | ||||||
|  |                 'service' => 'coolify', | ||||||
|  |                 'rule' => "Host(`{$host}`)", | ||||||
|  |                 'tls' => [ | ||||||
|  |                     'certresolver' => 'letsencrypt', | ||||||
|  |                 ], | ||||||
|  |             ]; | ||||||
|  |             $traefik_dynamic_conf['http']['routers']['coolify-realtime-wss'] = [ | ||||||
|  |                 'entryPoints' => [ | ||||||
|  |                     0 => 'https', | ||||||
|  |                 ], | ||||||
|  |                 'service' => 'coolify-realtime', | ||||||
|  |                 'rule' => "Host(`{$host}`) && PathPrefix(`/app`)", | ||||||
|  |                 'tls' => [ | ||||||
|  |                     'certresolver' => 'letsencrypt', | ||||||
|  |                 ], | ||||||
|  |             ]; | ||||||
|  |         } | ||||||
|  |         $yaml = Yaml::dump($traefik_dynamic_conf, 12, 2); | ||||||
|  |         $yaml = | ||||||
|  |             "# This file is automatically generated by Coolify.\n" . | ||||||
|  |             "# Do not edit it manually (only if you know what are you doing).\n\n" . | ||||||
|  |             $yaml; | ||||||
|  | 
 | ||||||
|  |         $base64 = base64_encode($yaml); | ||||||
|  |         instant_remote_process([ | ||||||
|  |             "mkdir -p $dynamic_config_path", | ||||||
|  |             "echo '$base64' | base64 -d > $file", | ||||||
|  |         ], $server); | ||||||
|  | 
 | ||||||
|  |         if (config('app.env') == 'local') { | ||||||
|  |             ray($yaml); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| function setup_default_redirect_404(string|null $redirect_url, Server $server) | function setup_default_redirect_404(string|null $redirect_url, Server $server) | ||||||
| { | { | ||||||
|     $traefik_dynamic_conf_path = get_proxy_path() . "/dynamic"; |     $traefik_dynamic_conf_path = get_proxy_path() . "/dynamic"; | ||||||
|  | |||||||
| @ -29,7 +29,9 @@ use Illuminate\Support\Collection; | |||||||
| use Illuminate\Support\Facades\Cache; | use Illuminate\Support\Facades\Cache; | ||||||
| use Illuminate\Support\Facades\File; | use Illuminate\Support\Facades\File; | ||||||
| use Illuminate\Support\Facades\Http; | use Illuminate\Support\Facades\Http; | ||||||
|  | use Illuminate\Support\Facades\Log; | ||||||
| use Illuminate\Support\Facades\Mail; | use Illuminate\Support\Facades\Mail; | ||||||
|  | use Illuminate\Support\Facades\Request; | ||||||
| use Illuminate\Support\Facades\Route; | use Illuminate\Support\Facades\Route; | ||||||
| use Illuminate\Support\Str; | use Illuminate\Support\Str; | ||||||
| use Illuminate\Support\Stringable; | use Illuminate\Support\Stringable; | ||||||
| @ -1545,3 +1547,19 @@ function generateEnvValue(string $command) | |||||||
|     } |     } | ||||||
|     return $generatedValue; |     return $generatedValue; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | function getRealtime() | ||||||
|  | { | ||||||
|  |     $envDefined = env('PUSHER_PORT'); | ||||||
|  |     if (empty($envDefined)) { | ||||||
|  |         $url = Url::fromString(Request::getSchemeAndHttpHost()); | ||||||
|  |         $port = $url->getPort(); | ||||||
|  |         if ($port) { | ||||||
|  |             return '6001'; | ||||||
|  |         } else { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |     } else { | ||||||
|  |         return $envDefined; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | |||||||
| @ -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.156', |     'release' => '4.0.0-beta.157', | ||||||
|     // 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.156'; | return '4.0.0-beta.157'; | ||||||
|  | |||||||
| @ -22,7 +22,7 @@ services: | |||||||
|       AUTORUN_LARAVEL_STORAGE_LINK: "false" |       AUTORUN_LARAVEL_STORAGE_LINK: "false" | ||||||
|       AUTORUN_LARAVEL_MIGRATION: "false" |       AUTORUN_LARAVEL_MIGRATION: "false" | ||||||
|       PUSHER_HOST: "${PUSHER_HOST}" |       PUSHER_HOST: "${PUSHER_HOST}" | ||||||
|       PUSHER_PORT: "${PUSHER_PORT:-6001}" |       PUSHER_PORT: "${PUSHER_PORT}" | ||||||
|       PUSHER_SCHEME: "${PUSHER_SCHEME:-http}" |       PUSHER_SCHEME: "${PUSHER_SCHEME:-http}" | ||||||
|       PUSHER_APP_ID: "${PUSHER_APP_ID:-coolify}" |       PUSHER_APP_ID: "${PUSHER_APP_ID:-coolify}" | ||||||
|       PUSHER_APP_KEY: "${PUSHER_APP_KEY:-coolify}" |       PUSHER_APP_KEY: "${PUSHER_APP_KEY:-coolify}" | ||||||
|  | |||||||
| @ -43,6 +43,7 @@ services: | |||||||
|       - PUSHER_APP_ID |       - PUSHER_APP_ID | ||||||
|       - PUSHER_APP_KEY |       - PUSHER_APP_KEY | ||||||
|       - PUSHER_APP_SECRET |       - PUSHER_APP_SECRET | ||||||
|  |       - AUTOUPDATE | ||||||
|       - SELF_HOSTED |       - SELF_HOSTED | ||||||
|       - WAITLIST |       - WAITLIST | ||||||
|       - SUBSCRIPTION_PROVIDER |       - SUBSCRIPTION_PROVIDER | ||||||
|  | |||||||
| @ -44,7 +44,6 @@ | |||||||
|         </dialog> |         </dialog> | ||||||
|         <x-toaster-hub /> |         <x-toaster-hub /> | ||||||
|         <x-version class="fixed left-2 bottom-1" /> |         <x-version class="fixed left-2 bottom-1" /> | ||||||
| 
 |  | ||||||
|         <script data-navigate-once> |         <script data-navigate-once> | ||||||
|             @auth |             @auth | ||||||
|             window.Pusher = Pusher; |             window.Pusher = Pusher; | ||||||
| @ -53,8 +52,8 @@ | |||||||
|                 cluster: "{{ env('PUSHER_HOST') }}" || window.location.hostname, |                 cluster: "{{ env('PUSHER_HOST') }}" || window.location.hostname, | ||||||
|                 key: "{{ env('PUSHER_APP_KEY') }}" || 'coolify', |                 key: "{{ env('PUSHER_APP_KEY') }}" || 'coolify', | ||||||
|                 wsHost: "{{ env('PUSHER_HOST') }}" || window.location.hostname, |                 wsHost: "{{ env('PUSHER_HOST') }}" || window.location.hostname, | ||||||
|                 wsPort: "{{ env('PUSHER_PORT') }}" || 6001, |                 wsPort: "{{ getRealtime() }}", | ||||||
|                 wssPort: "{{ env('PUSHER_PORT') }}" || 6001, |                 wssPort: "{{ getRealtime() }}", | ||||||
|                 forceTLS: false, |                 forceTLS: false, | ||||||
|                 encrypted: true, |                 encrypted: true, | ||||||
|                 enableStats: false, |                 enableStats: false, | ||||||
|  | |||||||
| @ -21,7 +21,12 @@ | |||||||
|     </form> |     </form> | ||||||
|     <h2 class="pt-6">Advanced</h2> |     <h2 class="pt-6">Advanced</h2> | ||||||
|     <div class="flex flex-col py-6 text-right w-80"> |     <div class="flex flex-col py-6 text-right w-80"> | ||||||
|  |         @if(!is_null(env('AUTOUPDATE', null))) | ||||||
|  |             <x-forms.checkbox instantSave helper="AUTOUPDATE is set in .env file, you need to modify it there." disabled | ||||||
|  |                 id="is_auto_update_enabled" label="Auto Update Coolify" /> | ||||||
|  |         @else | ||||||
|             <x-forms.checkbox instantSave id="is_auto_update_enabled" label="Auto Update Coolify" /> |             <x-forms.checkbox instantSave id="is_auto_update_enabled" label="Auto Update Coolify" /> | ||||||
|  |         @endif | ||||||
|         <x-forms.checkbox instantSave id="is_registration_enabled" label="Registration Allowed" /> |         <x-forms.checkbox instantSave id="is_registration_enabled" label="Registration Allowed" /> | ||||||
|         <x-forms.checkbox instantSave id="do_not_track" label="Do Not Track" /> |         <x-forms.checkbox instantSave id="do_not_track" label="Do Not Track" /> | ||||||
|         @if ($next_channel) |         @if ($next_channel) | ||||||
|  | |||||||
| @ -1,12 +1,17 @@ | |||||||
| #!/bin/bash | #!/bin/bash | ||||||
| ## Do not modify this file. You will lose the ability to install and auto-update! | ## Do not modify this file. You will lose the ability to install and auto-update! | ||||||
| 
 | 
 | ||||||
|  | set -e # Exit immediately if a command exits with a non-zero status | ||||||
|  | ## $1 could be empty, so we need to disable this check | ||||||
|  | #set -u # Treat unset variables as an error and exit | ||||||
|  | set -o pipefail # Cause a pipeline to return the status of the last command that exited with a non-zero status | ||||||
|  | 
 | ||||||
| VERSION="1.1.0" | VERSION="1.1.0" | ||||||
| DOCKER_VERSION="24.0" | DOCKER_VERSION="24.0" | ||||||
| 
 | 
 | ||||||
| CDN="https://cdn.coollabs.io/coolify" | CDN="https://cdn.coollabs.io/coolify" | ||||||
| OS_TYPE=$(cat /etc/os-release | grep -w "ID" | cut -d "=" -f 2 | tr -d '"') | OS_TYPE=$(grep -w "ID" /etc/os-release | cut -d "=" -f 2 | tr -d '"') | ||||||
| OS_VERSION=$(cat /etc/os-release | grep -w "VERSION_ID" | cut -d "=" -f 2 | tr -d '"') | OS_VERSION=$(grep -w "VERSION_ID" /etc/os-release | cut -d "=" -f 2 | tr -d '"') | ||||||
| LATEST_VERSION=$(curl --silent $CDN/versions.json | grep -i version | sed -n '2p' | xargs | awk '{print $2}' | tr -d ',') | LATEST_VERSION=$(curl --silent $CDN/versions.json | grep -i version | sed -n '2p' | xargs | awk '{print $2}' | tr -d ',') | ||||||
| DATE=$(date +"%Y%m%d-%H%M%S") | DATE=$(date +"%Y%m%d-%H%M%S") | ||||||
| 
 | 
 | ||||||
| @ -26,6 +31,8 @@ esac | |||||||
| # Ovewrite LATEST_VERSION if user pass a version number | # Ovewrite LATEST_VERSION if user pass a version number | ||||||
| if [ "$1" != "" ]; then | if [ "$1" != "" ]; then | ||||||
|     LATEST_VERSION=$1 |     LATEST_VERSION=$1 | ||||||
|  |     LATEST_VERSION="${LATEST_VERSION,,}" | ||||||
|  |     LATEST_VERSION="${LATEST_VERSION#v}" | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| echo -e "-------------" | echo -e "-------------" | ||||||
| @ -79,8 +86,8 @@ fi | |||||||
| echo -e "-------------" | echo -e "-------------" | ||||||
| echo -e "Check Docker Configuration..." | echo -e "Check Docker Configuration..." | ||||||
| mkdir -p /etc/docker | mkdir -p /etc/docker | ||||||
| 
 | # shellcheck disable=SC2015 | ||||||
| test -s /etc/docker/daemon.json && cp /etc/docker/daemon.json /etc/docker/daemon.json.original-$DATE || cat >/etc/docker/daemon.json <<EOL | test -s /etc/docker/daemon.json && cp /etc/docker/daemon.json /etc/docker/daemon.json.original-"$DATE" || cat >/etc/docker/daemon.json <<EOL | ||||||
| { | { | ||||||
|   "log-driver": "json-file", |   "log-driver": "json-file", | ||||||
|   "log-opts": { |   "log-opts": { | ||||||
| @ -98,11 +105,15 @@ cat >/etc/docker/daemon.json.coolify <<EOL | |||||||
|   } |   } | ||||||
| } | } | ||||||
| EOL | EOL | ||||||
| cat <<<$(jq . /etc/docker/daemon.json.coolify) >/etc/docker/daemon.json.coolify | TEMP_FILE=$(mktemp) | ||||||
| cat <<<$(jq -s '.[0] * .[1]' /etc/docker/daemon.json /etc/docker/daemon.json.coolify) >/etc/docker/daemon.json | if ! jq -s '.[0] * .[1]' /etc/docker/daemon.json /etc/docker/daemon.json.coolify >"$TEMP_FILE"; then | ||||||
|  |     echo "Error merging JSON files" | ||||||
|  |     exit 1 | ||||||
|  | fi | ||||||
|  | mv "$TEMP_FILE" /etc/docker/daemon.json | ||||||
| 
 | 
 | ||||||
| if [ -s /etc/docker/daemon.json.original-$DATE ]; then | if [ -s /etc/docker/daemon.json.original-"$DATE" ]; then | ||||||
|     DIFF=$(diff <(jq --sort-keys . /etc/docker/daemon.json) <(jq --sort-keys . /etc/docker/daemon.json.original-$DATE)) |     DIFF=$(diff <(jq --sort-keys . /etc/docker/daemon.json) <(jq --sort-keys . /etc/docker/daemon.json.original-"$DATE")) | ||||||
|     if [ "$DIFF" != "" ]; then |     if [ "$DIFF" != "" ]; then | ||||||
|         echo "Docker configuration updated, restart docker daemon..." |         echo "Docker configuration updated, restart docker daemon..." | ||||||
|         systemctl restart docker |         systemctl restart docker | ||||||
| @ -145,6 +156,14 @@ fi | |||||||
| # Merge .env and .env.production. New values will be added to .env | # Merge .env and .env.production. New values will be added to .env | ||||||
| sort -u -t '=' -k 1,1 /data/coolify/source/.env /data/coolify/source/.env.production | sed '/^$/d' >/data/coolify/source/.env.temp && mv /data/coolify/source/.env.temp /data/coolify/source/.env | sort -u -t '=' -k 1,1 /data/coolify/source/.env /data/coolify/source/.env.production | sed '/^$/d' >/data/coolify/source/.env.temp && mv /data/coolify/source/.env.temp /data/coolify/source/.env | ||||||
| 
 | 
 | ||||||
|  | if [ "$AUTOUPDATE" = "false" ]; then | ||||||
|  |     if ! grep -q "AUTOUPDATE=" /data/coolify/source/.env; then | ||||||
|  |         echo "AUTOUPDATE=false" >>/data/coolify/source/.env | ||||||
|  |     else | ||||||
|  |         sed -i "s|AUTOUPDATE=.*|AUTOUPDATE=false|g" /data/coolify/source/.env | ||||||
|  |     fi | ||||||
|  | fi | ||||||
|  | 
 | ||||||
| # Generate an ssh key (ed25519) at /data/coolify/ssh/keys/id.root@host.docker.internal | # Generate an ssh key (ed25519) at /data/coolify/ssh/keys/id.root@host.docker.internal | ||||||
| if [ ! -f /data/coolify/ssh/keys/id.root@host.docker.internal ]; then | if [ ! -f /data/coolify/ssh/keys/id.root@host.docker.internal ]; then | ||||||
|     ssh-keygen -t ed25519 -a 100 -f /data/coolify/ssh/keys/id.root@host.docker.internal -q -N "" -C root@coolify |     ssh-keygen -t ed25519 -a 100 -f /data/coolify/ssh/keys/id.root@host.docker.internal -q -N "" -C root@coolify | ||||||
| @ -163,11 +182,11 @@ if [ ! -f ~/.ssh/authorized_keys ]; then | |||||||
|     addSshKey |     addSshKey | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| if [ -z "$(grep -w "root@coolify" ~/.ssh/authorized_keys)" ]; then | if ! grep -qw "root@coolify" ~/.ssh/authorized_keys; then | ||||||
|     addSshKey |     addSshKey | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| bash /data/coolify/source/upgrade.sh ${LATEST_VERSION:-latest} | bash /data/coolify/source/upgrade.sh "${LATEST_VERSION:-latest}" | ||||||
| 
 | 
 | ||||||
| echo -e "\nCongratulations! Your Coolify instance is ready to use.\n" | echo -e "\nCongratulations! Your Coolify instance is ready to use.\n" | ||||||
| echo "Please visit http://$(curl -4s https://ifconfig.io):8000 to get started." | echo "Please visit http://$(curl -4s https://ifconfig.io):8000 to get started." | ||||||
|  | |||||||
| @ -4,7 +4,7 @@ | |||||||
|             "version": "3.12.36" |             "version": "3.12.36" | ||||||
|         }, |         }, | ||||||
|         "v4": { |         "v4": { | ||||||
|             "version": "4.0.0-beta.156" |             "version": "4.0.0-beta.157" | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user