Files
hoerdle/Caddyfile

128 lines
3.6 KiB
Caddyfile

# Caddy-Konfiguration für Hördle
# Wildcard-Zertifikate für hoerdle.de und hördle.de (xn--hrdle-jua.de)
# DNS-01 Challenge für Wildcard-Zertifikate (GoDaddy)
# Die DNS-TXT-Records müssen manuell in GoDaddy gesetzt werden (siehe CADDY_SETUP.md)
# Domain 1: hoerdle.de (ASCII)
*.hoerdle.de, hoerdle.de {
# TLS mit DNS-01 Challenge für Wildcard
tls {
dns godaddy {env.GODADDY_API_KEY} {env.GODADDY_API_SECRET}
}
# Upload-Limit: 50MB (wie in nginx.conf.example)
request_body {
max_size 50MB
}
# Reverse Proxy zu hoerdle Container
reverse_proxy hoerdle:3010 {
# HTTP/1.1 für WebSocket Support
transport http {
versions 1.1
}
# Headers für Audio-Streaming (Range Requests)
header_up Range {http.request.header.Range}
header_up If-Range {http.request.header.If-Range}
# Kein Caching bei Range Requests
header_down Cache-Control "no-cache" {
when {http.request.header.Range}
}
# Timeouts für große Dateien (300s wie in nginx)
timeout 300s
# WebSocket Support
header_up Connection {>Connection}
header_up Upgrade {>Upgrade}
}
# Spezielle Behandlung für /uploads/ Route (Audio-Dateien)
handle /uploads/* {
reverse_proxy hoerdle:3010 {
# Range Requests für Audio-Streaming
header_up Range {http.request.header.Range}
header_up If-Range {http.request.header.If-Range}
# Buffering deaktivieren für große Dateien
# (Caddy hat kein explizites proxy_buffering, aber Timeouts setzen)
timeout 300s
# Kein Caching bei Range Requests
header_down Cache-Control "no-cache" {
when {http.request.header.Range}
}
}
}
# HTTP zu HTTPS Redirect
@http {
protocol http
}
redir @http https://{host}{uri} permanent
}
# Domain 2: hördle.de (Punycode: xn--hrdle-jua.de)
*.xn--hrdle-jua.de, xn--hrdle-jua.de {
# TLS mit DNS-01 Challenge für Wildcard
tls {
dns godaddy {env.GODADDY_API_KEY} {env.GODADDY_API_SECRET}
}
# Upload-Limit: 50MB
request_body {
max_size 50MB
}
# Reverse Proxy zu hoerdle Container
reverse_proxy hoerdle:3010 {
# HTTP/1.1 für WebSocket Support
transport http {
versions 1.1
}
# Headers für Audio-Streaming (Range Requests)
header_up Range {http.request.header.Range}
header_up If-Range {http.request.header.If-Range}
# Kein Caching bei Range Requests
header_down Cache-Control "no-cache" {
when {http.request.header.Range}
}
# Timeouts für große Dateien (300s)
timeout 300s
# WebSocket Support
header_up Connection {>Connection}
header_up Upgrade {>Upgrade}
}
# Spezielle Behandlung für /uploads/ Route (Audio-Dateien)
handle /uploads/* {
reverse_proxy hoerdle:3010 {
# Range Requests für Audio-Streaming
header_up Range {http.request.header.Range}
header_up If-Range {http.request.header.If-Range}
# Timeouts für große Dateien
timeout 300s
# Kein Caching bei Range Requests
header_down Cache-Control "no-cache" {
when {http.request.header.Range}
}
}
}
# HTTP zu HTTPS Redirect
@http {
protocol http
}
redir @http https://{host}{uri} permanent
}