2023-08-29 16:31:46 +02:00
@ php use App\Enums\ProxyTypes ; @ endphp
< div >
2023-08-30 11:06:44 +02:00
< div >
@ if ( $currentState === 'welcome' )
< h1 class = " text-5xl font-bold " > Welcome to Coolify </ h1 >
< p class = " py-6 text-xl text-center " > Let me help you to set the basics .</ p >
< div class = " flex justify-center " >
2023-09-14 10:39:05 +02:00
< x - forms . button class = " justify-center box " wire : click = " $set ('currentState','explanation') " > Get Started
2023-08-30 14:46:51 +02:00
</ x - forms . button >
2023-08-30 11:06:44 +02:00
</ div >
@ endif
</ div >
< div >
2023-09-14 10:39:05 +02:00
@ if ( $currentState === 'explanation' )
< x - boarding - step title = " What is Coolify? " >
< x - slot : question >
Coolify is an all - in - one application to automate tasks on your servers , deploy application with Git
integrations , deploy databases and services , monitor these resources with notifications and alerts
without vendor lock - in
and < a href = " https://coolify.io " class = " text-white hover:underline " > much much more </ a >.
< br >< br >
< span class = " text-xl " >
< x - highlighted text = " Self-hosting with superpowers! " /></ span >
</ x - slot : question >
< x - slot : explanation >
2023-09-18 11:21:10 +02:00
< p >< x - highlighted text = " Task automation: " /> You do not to manage your servers too much . Coolify do
it for you .</ p >
< p >< x - highlighted text = " No vendor lock-in: " /> All configurations are stored on your server , so
everything works without Coolify ( except integrations and automations ) .</ p >
< p >< x - highlighted text = " Monitoring: " /> You will get notified on your favourite platform ( Discord ,
Telegram , Email , etc . ) when something goes wrong , or an action needed from your side .</ p >
2023-09-14 10:39:05 +02:00
</ x - slot : explanation >
< x - slot : actions >
< x - forms . button class = " justify-center box " wire : click = " explanation " > Next
</ x - forms . button >
</ x - slot : actions >
</ x - boarding - step >
@ endif
2023-08-30 11:06:44 +02:00
@ if ( $currentState === 'select-server-type' )
< x - boarding - step title = " Server " >
< x - slot : question >
Do you want to deploy your resources on your < x - highlighted text = " Localhost " />
2023-10-01 19:16:37 -04:00
or on a < x - highlighted text = " Remote Server " /> ?
2023-08-30 11:06:44 +02:00
</ x - slot : question >
< x - slot : actions >
2023-09-14 10:39:05 +02:00
< x - forms . button class = " justify-center box " wire : target = " setServerType('localhost') "
wire : click = " setServerType('localhost') " > Localhost
2023-08-30 14:46:51 +02:00
</ x - forms . button >
2023-09-18 13:01:01 +02:00
2023-09-14 10:39:05 +02:00
< x - forms . button class = " justify-center box " wire : target = " setServerType('remote') "
wire : click = " setServerType('remote') " > Remote Server
2023-08-30 14:46:51 +02:00
</ x - forms . button >
2023-09-18 14:41:31 +02:00
@ if ( ! $serverReachable )
2023-09-18 13:01:01 +02:00
Localhost is not reachable with the following public key .
< br /> < br />
Please make sure you have the correct public key in your ~/. ssh / authorized_keys file for user
'root' or skip the boarding process and add a new private key manually to Coolify and to the
server .
2024-01-15 11:00:09 +01:00
< br />
2024-01-18 11:24:07 +01:00
Check this < a target = " _blank " class = " underline " href = " https://coolify.io/docs/server/openssh " > documentation </ a > for further help .
2023-09-18 14:41:31 +02:00
< x - forms . input readonly id = " serverPublicKey " ></ x - forms . input >
2023-09-18 13:01:01 +02:00
< x - forms . button class = " box " wire : target = " setServerType('localhost') "
wire : click = " setServerType('localhost') " > Check again
</ x - forms . button >
@ endif
2023-08-30 11:06:44 +02:00
</ x - slot : actions >
< x - slot : explanation >
< p > Servers are the main building blocks , as they will host your applications , databases ,
services , called resources . Any CPU intensive process will use the server ' s CPU where you
are deploying your resources .</ p >
< p > Localhost is the server where Coolify is running on . It is not recommended to use one server
2023-11-12 19:30:20 +00:00
for everything .</ p >
2023-08-30 11:06:44 +02:00
< p > Remote Server is a server reachable through SSH . It can be hosted at home , or from any cloud
provider .</ p >
</ x - slot : explanation >
</ x - boarding - step >
@ endif
</ div >
< div >
@ if ( $currentState === 'private-key' )
< x - boarding - step title = " SSH Key " >
< x - slot : question >
Do you have your own SSH Private Key ?
</ x - slot : question >
< x - slot : actions >
2023-09-14 10:39:05 +02:00
< x - forms . button class = " justify-center box " wire : target = " setPrivateKey('own') "
wire : click = " setPrivateKey('own') " > Yes
2023-08-30 14:46:51 +02:00
</ x - forms . button >
2023-09-14 10:39:05 +02:00
< x - forms . button class = " justify-center box " wire : target = " setPrivateKey('create') "
wire : click = " setPrivateKey('create') " > No ( create one for me )
2023-08-30 14:46:51 +02:00
</ x - forms . button >
2023-08-30 11:06:44 +02:00
@ if ( count ( $privateKeys ) > 0 )
2023-12-07 19:06:32 +01:00
< form wire : submit = 'selectExistingPrivateKey' class = " flex flex-col w-full gap-4 pr-10 " >
2023-08-30 11:06:44 +02:00
< x - forms . select label = " Existing SSH Keys " id = 'selectedExistingPrivateKey' >
@ foreach ( $privateKeys as $privateKey )
< option wire : key = " { { $loop->index }} " value = " { { $privateKey->id }} " >
{{ $privateKey -> name }} </ option >
@ endforeach
</ x - forms . select >
< x - forms . button type = " submit " > Use this SSH Key </ x - forms . button >
</ form >
2023-08-29 16:31:46 +02:00
@ endif
2023-08-30 11:06:44 +02:00
</ x - slot : actions >
< x - slot : explanation >
< p > SSH Keys are used to connect to a remote server through a secure shell , called SSH .</ p >
< p > You can use your own ssh private key , or you can let Coolify to create one for you .</ p >
< p > In both ways , you need to add the public version of your ssh private key to the remote
server ' s
< code class = " text-warning " >~/. ssh / authorized_keys </ code > file .
</ p >
</ x - slot : explanation >
</ x - boarding - step >
@ endif
</ div >
< div >
@ if ( $currentState === 'select-existing-server' )
< x - boarding - step title = " Select a server " >
< x - slot : question >
There are already servers available for your Team . Do you want to use one of them ?
</ x - slot : question >
< x - slot : actions >
2023-08-30 14:46:51 +02:00
< x - forms . button class = " justify-center box " wire : click = " createNewServer " > No ( create one for me )
</ x - forms . button >
2023-08-30 11:06:44 +02:00
< div >
2023-12-07 19:06:32 +01:00
< form wire : submit = 'selectExistingServer' class = " flex flex-col w-full gap-4 lg:w-96 " >
2023-08-30 11:06:44 +02:00
< x - forms . select label = " Existing servers " class = " w-96 " id = 'selectedExistingServer' >
@ foreach ( $servers as $server )
< option wire : key = " { { $loop->index }} " value = " { { $server->id }} " >
{{ $server -> name }} </ option >
@ endforeach
</ x - forms . select >
< x - forms . button type = " submit " > Use this Server </ x - forms . button >
</ form >
2023-08-29 16:31:46 +02:00
</ div >
2023-09-18 14:41:31 +02:00
@ if ( ! $serverReachable )
2023-11-28 15:49:24 +01:00
This server is not reachable with the following public key .
< br /> < br />
Please make sure you have the correct public key in your ~/. ssh / authorized_keys file for user
'root' or skip the boarding process and add a new private key manually to Coolify and to the
server .
< x - forms . input readonly id = " serverPublicKey " ></ x - forms . input >
< x - forms . button class = " box " wire : target = " validateServer " wire : click = " validateServer " > Check
again
</ x - forms . button >
@ endif
2023-08-30 11:06:44 +02:00
</ x - slot : actions >
< x - slot : explanation >
< p > Private Keys are used to connect to a remote server through a secure shell , called SSH .</ p >
< p > You can use your own private key , or you can let Coolify to create one for you .</ p >
< p > In both ways , you need to add the public version of your private key to the remote server ' s
< code >~/. ssh / authorized_keys </ code > file .
</ p >
</ x - slot : explanation >
</ x - boarding - step >
@ endif
</ div >
< div >
@ if ( $currentState === 'create-private-key' )
< x - boarding - step title = " Create Private Key " >
< x - slot : question >
Please let me know your key details .
</ x - slot : question >
< x - slot : actions >
2023-12-07 19:06:32 +01:00
< form wire : submit = 'savePrivateKey' class = " flex flex-col w-full gap-4 pr-10 " >
2023-08-30 11:06:44 +02:00
< x - forms . input required placeholder = " Choose a name for your Private Key. Could be anything. "
label = " Name " id = " privateKeyName " />
< x - forms . input placeholder = " Description, so others will know more about this. "
label = " Description " id = " privateKeyDescription " />
< x - forms . textarea required placeholder = " -----BEGIN OPENSSH PRIVATE KEY----- " label = " Private Key "
id = " privateKey " />
2023-09-11 10:15:45 +02:00
@ if ( $privateKeyType === 'create' )
2023-09-14 10:39:05 +02:00
< x - forms . textarea rows = " 7 " readonly label = " Public Key " id = " publicKey " />
< span class = " font-bold text-warning " > ACTION REQUIRED : Copy the 'Public Key' to your server ' s
~/. ssh / authorized_keys
file .</ span >
2023-08-30 11:06:44 +02:00
@ endif
< x - forms . button type = " submit " > Save </ x - forms . button >
</ form >
</ x - slot : actions >
< x - slot : explanation >
< p > Private Keys are used to connect to a remote server through a secure shell , called SSH .</ p >
< p > You can use your own private key , or you can let Coolify to create one for you .</ p >
< p > In both ways , you need to add the public version of your private key to the remote server ' s
< code >~/. ssh / authorized_keys </ code > file .
</ p >
</ x - slot : explanation >
</ x - boarding - step >
@ endif
</ div >
< div >
@ if ( $currentState === 'create-server' )
< x - boarding - step title = " Create Server " >
< x - slot : question >
Please let me know your server details .
</ x - slot : question >
< x - slot : actions >
2023-12-07 19:06:32 +01:00
< form wire : submit = 'saveServer' class = " flex flex-col w-full gap-4 pr-10 " >
2023-08-30 11:06:44 +02:00
< div class = " flex gap-2 " >
< x - forms . input required placeholder = " Choose a name for your Server. Could be anything. "
label = " Name " id = " remoteServerName " />
< x - forms . input placeholder = " Description, so others will know more about this. "
label = " Description " id = " remoteServerDescription " />
</ div >
< div class = " flex gap-2 " >
2023-11-28 15:49:24 +01:00
< x - forms . input required placeholder = " 127.0.0.1 " label = " IP Address " id = " remoteServerHost " />
2023-08-30 11:06:44 +02:00
< x - forms . input required placeholder = " Port number of your server. Default is 22. "
label = " Port " id = " remoteServerPort " />
< x - forms . input required readonly
placeholder = " Username to connect to your server. Default is root. " label = " Username "
id = " remoteServerUser " />
</ div >
2023-12-04 09:29:55 +01:00
< div class = " w-64 " >
< x - forms . checkbox
helper = " If you are using Cloudflare Tunnels, enable this. It will proxy all ssh requests to your server through Cloudflare.<br><span class='text-warning'>Coolify does not install/setup Cloudflare (cloudflared) on your server.</span> "
id = " isCloudflareTunnel " label = " Cloudflare Tunnel " />
</ div >
2023-09-15 15:34:25 +02:00
< x - forms . button type = " submit " > Check Connection </ x - forms . button >
2023-08-30 11:06:44 +02:00
</ form >
</ x - slot : actions >
< x - slot : explanation >
< p > Username should be < x - highlighted text = " root " /> for now . We are working on to use
non - root users .</ p >
</ x - slot : explanation >
</ x - boarding - step >
@ endif
</ div >
< div >
@ if ( $currentState === 'install-docker' )
< x - boarding - step title = " Install Docker " >
< x - slot : question >
Could not find Docker Engine on your server . Do you want me to install it for you ?
</ x - slot : question >
< x - slot : actions >
2023-11-21 12:07:06 +01:00
< x - forms . button class = " justify-center box " wire : click = " installDocker " >
2023-11-28 15:49:24 +01:00
Let ' s do it !</ x - forms . button >
2023-10-20 18:15:25 +02:00
@ if ( $dockerInstallationStarted )
2023-09-18 11:21:10 +02:00
< x - forms . button class = " justify-center box " wire : click = " dockerInstalledOrSkipped " >
2023-10-20 18:16:47 +02:00
Validate Server & Continue </ x - forms . button >
2023-09-18 11:21:10 +02:00
@ endif
2023-08-30 11:06:44 +02:00
</ x - slot : actions >
< x - slot : explanation >
< p > This will install the latest Docker Engine on your server , configure a few things to be able
2023-11-28 15:49:24 +01:00
to run optimal .< br >< br > Minimum Docker Engine version is : 22 < br >< br > To manually install Docker
Engine , check < a target = " _blank " class = " underline text-warning "
2024-01-18 11:24:07 +01:00
href = " https://docs.docker.com/engine/install/#server " > this
2023-11-28 15:49:24 +01:00
documentation </ a >.</ p >
2023-08-30 11:06:44 +02:00
</ x - slot : explanation >
</ x - boarding - step >
2023-11-21 12:07:06 +01:00
2023-08-30 11:06:44 +02:00
@ endif
</ div >
< div >
@ if ( $currentState === 'select-proxy' )
< x - boarding - step title = " Select a Proxy " >
< x - slot : question >
If you would like to attach any kind of domain to your resources , you need a proxy .
</ x - slot : question >
< x - slot : actions >
< x - forms . button wire : click = " selectProxy " class = " w-64 box " >
Decide later
</ x - forms . button >
< x - forms . button class = " w-32 box " wire : click = " selectProxy(' { { ProxyTypes::TRAEFIK_V2 }}') " >
Traefik
v2
</ x - forms . button >
< x - forms . button disabled class = " w-32 box " >
Nginx
</ x - forms . button >
< x - forms . button disabled class = " w-32 box " >
Caddy
</ x - forms . button >
</ x - slot : actions >
< x - slot : explanation >
< p > This will install the latest Docker Engine on your server , configure a few things to be able
to run optimal .</ p >
</ x - slot : explanation >
</ x - boarding - step >
@ endif
</ div >
< div >
@ if ( $currentState === 'create-project' )
< x - boarding - step title = " Project " >
< x - slot : question >
@ if ( count ( $projects ) > 0 )
You already have some projects . Do you want to use one of them or should I create a new one for
you ?
@ else
I will create an initial project for you . You can change all the details later on .
@ endif
</ x - slot : question >
< x - slot : actions >
2023-09-14 10:39:05 +02:00
< x - forms . button class = " justify-center box " wire : click = " createNewProject " > Let ' s create a new
one !</ x - forms . button >
2023-08-30 11:06:44 +02:00
< div >
@ if ( count ( $projects ) > 0 )
2023-12-07 19:06:32 +01:00
< form wire : submit = 'selectExistingProject' class = " flex flex-col w-full gap-4 lg:w-96 " >
2023-09-14 10:39:05 +02:00
< x - forms . select label = " Existing projects " class = " w-96 "
id = 'selectedExistingProject' >
2023-08-30 11:06:44 +02:00
@ foreach ( $projects as $project )
< option wire : key = " { { $loop->index }} " value = " { { $project->id }} " >
{{ $project -> name }} </ option >
@ endforeach
</ x - forms . select >
< x - forms . button type = " submit " > Use this Project </ x - forms . button >
</ form >
@ endif
</ div >
</ x - slot : actions >
< x - slot : explanation >
< p > Projects are bound together several resources into one virtual group . There are no
limitations on the number of projects you could have .</ p >
< p > Each project should have at least one environment . This helps you to create a production &
staging version of the same application , but grouped separately .</ p >
</ x - slot : explanation >
</ x - boarding - step >
@ endif
</ div >
< div >
@ if ( $currentState === 'create-resource' )
< x - boarding - step title = " Resources " >
< x - slot : question >
I will redirect you to the new resource page , where you can create your first resource .
</ x - slot : question >
< x - slot : actions >
2023-10-20 18:15:25 +02:00
< div class = " items-center justify-center box " wire : click = " showNewResource " > Let ' s do
2023-08-30 11:06:44 +02:00
it !</ div >
</ x - slot : actions >
< x - slot : explanation >
< p > A resource could be an application , a database or a service ( like WordPress ) .</ p >
</ x - slot : explanation >
</ x - boarding - step >
@ endif
</ div >
2023-08-29 16:31:46 +02:00
< div class = " flex justify-center gap-2 pt-4 " >
< a wire : click = 'skipBoarding' > Skip boarding process </ a >
< a wire : click = 'restartBoarding' > Restart boarding process </ a >
</ div >
</ div >