All checks were successful
- **Caddyfile:** OPTIONS-Handling optimiert: Hinzufügen spezifischer Header (`X-Requested-With`), Entfernen von `*` und leere Response (`respond "" 204`) eingeführt. - **UI:** Aktualisierung des Versionsmarkers auf `v2026-04-23.24 - CADDY CORS FINAL BOSS`. - **Docs:** Erweiterung der Analyse um Lösung und Status für Version 24.
84 lines
2.0 KiB
Caddyfile
84 lines
2.0 KiB
Caddyfile
{
|
|
auto_https off
|
|
metrics
|
|
}
|
|
|
|
:80 {
|
|
root * /usr/share/caddy
|
|
log {
|
|
output stdout
|
|
format json
|
|
}
|
|
|
|
header {
|
|
Cross-Origin-Embedder-Policy "require-corp"
|
|
Cross-Origin-Opener-Policy "same-origin"
|
|
}
|
|
|
|
encode gzip zstd
|
|
|
|
# Reverse Proxy: Plan-B leitet nur /api/mail an den Mail-Service weiter
|
|
handle /api/mail/* {
|
|
@options method OPTIONS
|
|
handle @options {
|
|
header {
|
|
Access-Control-Allow-Origin "https://app.mo-code.at"
|
|
Access-Control-Allow-Methods "GET, POST, PUT, DELETE, OPTIONS"
|
|
Access-Control-Allow-Headers "Content-Type, Authorization, X-Requested-With"
|
|
Access-Control-Allow-Credentials "true"
|
|
Access-Control-Max-Age "3600"
|
|
X-Caddy-CORS "preflight"
|
|
}
|
|
respond "" 204
|
|
}
|
|
|
|
header {
|
|
Access-Control-Allow-Origin "https://app.mo-code.at"
|
|
Access-Control-Allow-Methods "GET, POST, PUT, DELETE, OPTIONS"
|
|
Access-Control-Allow-Headers "Content-Type, Authorization, X-Requested-With"
|
|
Access-Control-Allow-Credentials "true"
|
|
X-Caddy-CORS "forward"
|
|
defer
|
|
}
|
|
|
|
reverse_proxy mail-service:8085
|
|
}
|
|
|
|
handle /health {
|
|
respond "healthy" 200
|
|
}
|
|
|
|
# Korrekte MIME für .wasm sicherstellen (Caddy erkennt es i. d. R. automatisch; hier explizit)
|
|
@wasm {
|
|
path *.wasm
|
|
}
|
|
header @wasm Content-Type "application/wasm"
|
|
|
|
# Caching-Strategie: Immutable Assets (hash-Dateien)
|
|
# WICHTIG: .wasm und .js werden hier gecached. Falls die Dateinamen gleich bleiben,
|
|
# wird der Browser sie NICHT neu laden.
|
|
@immutable {
|
|
path *.png *.svg *.ico *.woff2 *.map
|
|
}
|
|
header @immutable Cache-Control "public, max-age=31536000, immutable"
|
|
|
|
# Wasm und JS Dateien: Kein Cache während der aktiven Entwicklungsphase (Plan-B)
|
|
# um "Alte Seite" Probleme zu vermeiden.
|
|
@wasm_js {
|
|
path *.wasm *.js
|
|
}
|
|
header @wasm_js Cache-Control "no-store, no-cache, must-revalidate"
|
|
|
|
# Keine Cache-Header für SPA-Einstieg und Laufzeitkonfig
|
|
@nocache {
|
|
path /index.html /config.json
|
|
}
|
|
header @nocache Cache-Control "no-store"
|
|
|
|
# Static file serving mit SPA-Fallback
|
|
handle {
|
|
try_files {path} /index.html
|
|
file_server
|
|
}
|
|
}
|