169 lines
2.9 KiB
Caddyfile
169 lines
2.9 KiB
Caddyfile
(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 https://stats.uptimerobot.com/PMoGJHK8W9 permanent
|
|
}
|
|
|
|
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 https://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
|
|
# }
|
|
# }
|