(logging) { log { output stdout } } { # local_certs email {$TLS_EMAIL} acme_ca {$CA_URL} } (errorpages) { handle_errors { rewrite * /{http.error.status_code}.html file_server { root /srv/errorpages } } } (maintenance) { @denied not remote_ip forwarded {$CADDY_BYPASS_IP} handle @denied { rewrite * /maintenance.html file_server { root /srv/errorpages status 503 } } } {$BASE_DOMAIN} { import logging import errorpages @matrix { path /_matrix/* /_synapse/* } reverse_proxy @matrix matrix:8008 root * /srv/homepage file_server } {$BASE_DOMAIN}:8448 { import logging import errorpages reverse_proxy matrix:8008 } # needs to be http! autoconfig.{$BASE_DOMAIN}, autoconfig.{$SECOND_MAIL_DOMAIN} { file_server { root /srv/autoconfig } } status.{$BASE_DOMAIN} { import errorpages import logging redir stats.uptimerobot.com/PMoGJHK8W9 } post.{$BASE_DOMAIN} { import errorpages import logging reverse_proxy echo:8000 } account.{$BASE_DOMAIN} { import logging import errorpages reverse_proxy authentik:80 } cloud.{$BASE_DOMAIN} { import logging import errorpages redir /.well-known/carddav /remote.php/dav redir /.well-known/caldav /remote.php/dav redir /.well-known/webfinger /index.php/.well-known/webfinger redir /.well-known/nodeinfo /index.php/.well-known/nodeinfo reverse_proxy nextcloud:80 } git.{$BASE_DOMAIN} { import logging import errorpages reverse_proxy forgejo:3000 } home.{$BASE_DOMAIN} { import logging import errorpages reverse_proxy doge6m1146mivr5g789a5tbjo0re3lrv.ui.nabu.casa } stuff.{$BASE_DOMAIN} { import logging import errorpages root * /srv/public_html file_server browse } md.{$BASE_DOMAIN} { import logging import errorpages reverse_proxy hedgedoc:3000 } # echo.{$BASE_DOMAIN} { # import logging # import errorpages # reverse_proxy echo:8000 # } # ci.{$BASE_DOMAIN} { # import logging # import errorpages # reverse_proxy woodpecker:8000 # } # passwords.{$BASE_DOMAIN} { # import logging # import errorpages # reverse_proxy /notifications/hub/negotiate* vaultwarden:80 # reverse_proxy /notifications/hub* vaultwarden:3012 # reverse_proxy vaultwarden:80 # } # ci-demo.{$BASE_DOMAIN} { # import logging # import errorpages # reverse_proxy docker-ci-demo:8000 # } # hackmd-next.{$BASE_DOMAIN} { # import logging # import errorpages # reverse_proxy codimd:3000 # } # amp.{$BASE_DOMAIN} { # import logging # import errorpages # reverse_proxy minecraft:8080 # } # map.amp.{$BASE_DOMAIN} { # import logging # import errorpages # root * /srv/bluemap # file_server # reverse_proxy /live/* minecraft:8123 # @JSONgz { # path *.json # file { # try_files {path}.gz # } # } # route @JSONgz { # rewrite {http.matchers.file.relative} # header Content-Type application/json # header Content-Encoding gzip # } # }