2023-10-24 12:31:28 +00:00
< div >
2023-12-07 18:06:32 +00:00
< form wire : submit = " submit " class = " flex flex-col gap-2 " >
2023-10-24 12:31:28 +00:00
< div class = " flex items-center gap-2 " >
< h2 > General </ h2 >
< x - forms . button type = " submit " >
Save
</ x - forms . button >
</ div >
< div class = " flex gap-2 " >
2025-10-13 08:01:17 +00:00
< x - forms . input label = " Name " id = " name " canGate = " update " : canResource = " $database " />
< x - forms . input label = " Description " id = " description " canGate = " update " : canResource = " $database " />
< x - forms . input label = " Image " id = " image " required
2025-08-26 08:27:31 +00:00
helper = " For all available images, check here:<br><br><a target='_blank' href='https://hub.docker.com/_/mysql'>https://hub.docker.com/_/mysql</a> " canGate = " update " : canResource = " $database " />
2023-10-24 12:31:28 +00:00
</ div >
2024-06-05 09:44:25 +00:00
< div class = " pt-2 dark:text-warning " > If you change the values in the database , please sync it here , otherwise
automations ( like backups ) won ' t work .
</ div >
2023-10-24 12:31:28 +00:00
@ if ( $database -> started_at )
2024-08-16 11:56:47 +00:00
< div class = " flex xl:flex-row flex-col gap-2 " >
2025-10-13 08:01:17 +00:00
< x - forms . input label = " Root Password " id = " mysqlRootPassword " type = " password " required
2025-08-26 08:27:31 +00:00
helper = " If you change this in the database, please sync it here, otherwise automations (like backups) won't work. " canGate = " update " : canResource = " $database " />
2025-10-13 08:01:17 +00:00
< x - forms . input label = " Normal User " id = " mysqlUser " required
2025-08-26 08:27:31 +00:00
helper = " If you change this in the database, please sync it here, otherwise automations (like backups) won't work. " canGate = " update " : canResource = " $database " />
2025-10-13 08:01:17 +00:00
< x - forms . input label = " Normal User Password " id = " mysqlPassword " type = " password " required
2025-08-26 08:27:31 +00:00
helper = " If you change this in the database, please sync it here, otherwise automations (like backups) won't work. " canGate = " update " : canResource = " $database " />
2024-08-16 11:56:47 +00:00
</ div >
< div class = " flex flex-col gap-2 " >
2025-10-13 08:01:17 +00:00
< x - forms . input label = " Initial Database " id = " mysqlDatabase "
2023-10-24 12:31:28 +00:00
placeholder = " If empty, it will be the same as Username. " readonly
2025-08-26 08:27:31 +00:00
helper = " You can only change this in the database. " canGate = " update " : canResource = " $database " />
2023-10-24 12:31:28 +00:00
</ div >
@ else
2024-08-16 11:56:47 +00:00
< div class = " flex xl:flex-row flex-col gap-4 pb-2 " >
2025-10-13 08:01:17 +00:00
< x - forms . input label = " Root Password " id = " mysqlRootPassword " type = " password "
2025-08-26 08:27:31 +00:00
helper = " You can only change this in the database. " canGate = " update " : canResource = " $database " />
2025-10-13 08:01:17 +00:00
< x - forms . input label = " Normal User " id = " mysqlUser " required
2025-08-26 08:27:31 +00:00
helper = " You can only change this in the database. " canGate = " update " : canResource = " $database " />
2025-10-13 08:01:17 +00:00
< x - forms . input label = " Normal User Password " id = " mysqlPassword " type = " password " required
2025-08-26 08:27:31 +00:00
helper = " You can only change this in the database. " canGate = " update " : canResource = " $database " />
2024-08-16 11:56:47 +00:00
</ div >
< div class = " flex flex-col gap-2 " >
2025-10-13 08:01:17 +00:00
< x - forms . input label = " Initial Database " id = " mysqlDatabase "
2023-10-24 12:31:28 +00:00
placeholder = " If empty, it will be the same as Username. "
2025-08-26 08:27:31 +00:00
helper = " You can only change this in the database. " canGate = " update " : canResource = " $database " />
2023-10-24 12:31:28 +00:00
</ div >
@ endif
2024-08-16 11:56:47 +00:00
< div class = " pt-2 " >
< x - forms . input
2025-12-17 12:25:27 +00:00
helper = " You can add custom docker run options that will be used when your container is started.<br>Note: Not all options are supported, as they could mess up Coolify's automation and could cause bad experience for users.<br><br>Check the <a class='underline dark:text-white' target='_blank' href='https://coolify.io/docs/knowledge-base/docker/custom-commands'>docs.</a> "
2024-08-16 11:56:47 +00:00
placeholder = " --cap-add SYS_ADMIN --device=/dev/fuse --security-opt apparmor:unconfined --ulimit nofile=1024:1024 --tmpfs /run:rw,noexec,nosuid,size=65536k "
2025-10-13 08:01:17 +00:00
id = " customDockerRunOptions " label = " Custom Docker Options " canGate = " update " : canResource = " $database " />
2024-08-16 11:56:47 +00:00
</ div >
2023-10-24 12:31:28 +00:00
< div class = " flex flex-col gap-2 " >
< h3 class = " py-2 " > Network </ h3 >
< div class = " flex items-end gap-2 " >
2025-10-13 08:01:17 +00:00
< x - forms . input placeholder = " 3000:5432 " id = " portsMappings " label = " Ports Mappings "
2025-08-26 08:27:31 +00:00
helper = " A comma separated list of ports you would like to map to the host system.<br><span class='inline-block font-bold dark:text-warning'>Example</span>3000:5432,3002:5433 " canGate = " update " : canResource = " $database " />
2023-10-24 12:31:28 +00:00
</ div >
2023-11-08 11:26:57 +00:00
< x - forms . input label = " MySQL URL (internal) "
2023-10-24 12:31:28 +00:00
helper = " If you change the user/password/port, this could be different. This is with the default values. "
type = " password " readonly wire : model = " db_url " />
2023-11-08 11:26:57 +00:00
@ if ( $db_url_public )
< x - forms . input label = " MySQL URL (public) "
helper = " If you change the user/password/port, this could be different. This is with the default values. "
type = " password " readonly wire : model = " db_url_public " />
@ endif
2023-10-24 12:31:28 +00:00
</ div >
2025-02-04 17:29:35 +00:00
< div class = " flex flex-col gap-2 " >
< div class = " flex items-center justify-between py-2 " >
< div class = " flex items-center justify-between w-full " >
< h3 > SSL Configuration </ h3 >
2025-10-13 08:01:17 +00:00
@ if ( $enableSsl && $certificateValidUntil )
2025-03-17 14:15:40 +00:00
< x - modal - confirmation title = " Regenerate SSL Certificates "
buttonTitle = " Regenerate SSL Certificates " : actions = " [
'The SSL certificate of this database will be regenerated.' ,
'You must restart the database after regenerating the certificate to start using the new certificate.' ,
] "
submitAction = " regenerateSslCertificate " : confirmWithText = " false " : confirmWithPassword = " false " />
2025-02-04 17:29:35 +00:00
@ endif
</ div >
</ div >
2025-10-13 08:01:17 +00:00
@ if ( $enableSsl && $certificateValidUntil )
2025-03-17 14:15:40 +00:00
< span class = " text-sm " > Valid until :
@ if ( now () -> gt ( $certificateValidUntil ))
< span class = " text-red-500 " > {{ $certificateValidUntil -> format ( 'd.m.Y H:i:s' ) }} - Expired </ span >
@ elseif ( now () -> addDays ( 30 ) -> gt ( $certificateValidUntil ))
< span class = " text-red-500 " > {{ $certificateValidUntil -> format ( 'd.m.Y H:i:s' ) }} - Expiring
soon </ span >
@ else
< span > {{ $certificateValidUntil -> format ( 'd.m.Y H:i:s' ) }} </ span >
@ endif
2025-02-04 17:29:35 +00:00
</ span >
@ endif
</ div >
< div class = " flex flex-col gap-2 " >
< div class = " flex flex-col gap-2 " >
2025-03-26 16:24:46 +00:00
< div class = " w-64 " >
@ if ( str ( $database -> status ) -> contains ( 'exited' ))
2025-10-13 08:01:17 +00:00
< x - forms . checkbox id = " enableSsl " label = " Enable SSL "
wire : model . live = " enableSsl " instantSave = " instantSaveSSL " canGate = " update " : canResource = " $database " />
2025-03-26 16:24:46 +00:00
@ else
2025-10-13 08:01:17 +00:00
< x - forms . checkbox id = " enableSsl " label = " Enable SSL "
wire : model . live = " enableSsl " instantSave = " instantSaveSSL " disabled
2025-03-26 16:24:46 +00:00
helper = " Database should be stopped to change this settings. " />
@ endif
</ div >
2025-10-13 08:01:17 +00:00
@ if ( $enableSsl )
2025-03-17 14:15:40 +00:00
< div class = " mx-2 " >
2025-03-26 16:24:46 +00:00
@ if ( str ( $database -> status ) -> contains ( 'exited' ))
2025-10-13 08:01:17 +00:00
< x - forms . select id = " sslMode " label = " SSL Mode " wire : model . live = " sslMode "
2025-03-26 16:24:46 +00:00
instantSave = " instantSaveSSL "
2025-08-26 08:27:31 +00:00
helper = " Choose the SSL verification mode for MySQL connections " canGate = " update " : canResource = " $database " >
2025-03-26 16:24:46 +00:00
< option value = " PREFERRED " title = " Prefer secure connections " > Prefer ( secure ) </ option >
< option value = " REQUIRED " title = " Require secure connections " > Require ( secure ) </ option >
< option value = " VERIFY_CA " title = " Verify CA certificate " > Verify CA ( secure ) </ option >
< option value = " VERIFY_IDENTITY " title = " Verify full certificate " > Verify Full ( secure )
</ option >
</ x - forms . select >
@ else
2025-10-13 08:01:17 +00:00
< x - forms . select id = " sslMode " label = " SSL Mode " instantSave = " instantSaveSSL "
2025-03-26 16:24:46 +00:00
disabled helper = " Database should be stopped to change this settings. " >
< option value = " PREFERRED " title = " Prefer secure connections " > Prefer ( secure ) </ option >
< option value = " REQUIRED " title = " Require secure connections " > Require ( secure ) </ option >
< option value = " VERIFY_CA " title = " Verify CA certificate " > Verify CA ( secure ) </ option >
< option value = " VERIFY_IDENTITY " title = " Verify full certificate " > Verify Full ( secure )
</ option >
</ x - forms . select >
@ endif
2025-03-17 14:15:40 +00:00
</ div >
2025-02-04 17:29:35 +00:00
@ endif
</ div >
</ div >
2024-06-09 19:33:17 +00:00
< div >
2024-11-07 11:32:44 +00:00
< div class = " flex flex-col py-2 w-64 " >
< div class = " flex items-center gap-2 pb-2 " >
< div class = " flex items-center " >
< h3 > Proxy </ h3 >
< x - loading wire : loading wire : target = " instantSave " />
</ div >
@ if ( data_get ( $database , 'is_public' ))
< x - slide - over fullScreen >
< x - slot : title > Proxy Logs </ x - slot : title >
< x - slot : content >
< livewire : project . shared . get - logs : server = " $server " : resource = " $database "
2025-12-04 14:37:14 +00:00
container = " { { data_get( $database , 'uuid') }}-proxy " : collapsible = " false " lazy />
2024-11-07 11:32:44 +00:00
</ x - slot : content >
< x - forms . button disabled = " { { !data_get( $database , 'is_public') }} "
@ click = " slideOverOpen=true " > Logs </ x - forms . button >
</ x - slide - over >
@ endif
</ div >
2025-10-13 08:01:17 +00:00
< x - forms . checkbox instantSave id = " isPublic " label = " Make it publicly available " canGate = " update " : canResource = " $database " />
2024-06-09 19:33:17 +00:00
</ div >
2025-10-13 08:01:17 +00:00
< x - forms . input placeholder = " 5432 " disabled = " { { $isPublic }} "
id = " publicPort " label = " Public Port " canGate = " update " : canResource = " $database " />
2026-02-27 22:24:04 +00:00
< x - forms . input placeholder = " 3600 " disabled = " { { $isPublic }} " id = " publicPortTimeout "
label = " Proxy Timeout (seconds) " helper = " Timeout for the public TCP proxy connection in seconds. Default: 3600 (1 hour). " canGate = " update " : canResource = " $database " />
2024-06-09 19:33:17 +00:00
</ div >
2025-10-13 08:01:17 +00:00
< x - forms . textarea label = " Custom Mysql Configuration " rows = " 10 " id = " mysqlConf " canGate = " update " : canResource = " $database " />
2023-11-17 19:08:21 +00:00
< h3 class = " pt-4 " > Advanced </ h3 >
< div class = " flex flex-col " >
< x - forms . checkbox helper = " Drain logs to your configured log drain endpoint in your Server settings. "
2025-10-13 08:01:17 +00:00
instantSave = " instantSaveAdvanced " id = " isLogDrainEnabled " label = " Drain Logs " canGate = " update " : canResource = " $database " />
2023-11-17 19:08:21 +00:00
</ div >
2023-10-24 12:31:28 +00:00
</ form >
</ div >