Feat/why is the dlr shut #1

Merged
lyrathorpe merged 7 commits from feat/why-is-the-dlr-shut into main 2026-06-11 16:26:33 +01:00
3 changed files with 63 additions and 0 deletions
Showing only changes of commit d2bac6b8d3 - Show all commits
+12
View File
@@ -0,0 +1,12 @@
# Keep the build context minimal; only the site assets and nginx config
# referenced by the Dockerfile are needed.
.git
.gitea
.github
.idea
.vscode
*.md
renovate.json
.renovaterc*
Dockerfile
.dockerignore
+9
View File
@@ -0,0 +1,9 @@
# Lightweight, non-root nginx serving the static site.
# Runs as user "nginx" and listens on 8080, ready to sit behind an
# external reverse proxy that terminates TLS and forwards requests.
FROM nginxinc/nginx-unprivileged:1.27-alpine-slim
COPY default.conf /etc/nginx/conf.d/default.conf
COPY --chown=nginx:nginx index.html styles.css script.js messages.js /usr/share/nginx/html/
EXPOSE 8080
+42
View File
@@ -0,0 +1,42 @@
# Static file serving for "Why is the DLR shut today?".
# Intended to run behind an external reverse proxy (e.g. NGINX) which
# handles TLS, host routing and any X-Forwarded-* headers.
server {
listen 8080;
listen [::]:8080;
server_name _;
root /usr/share/nginx/html;
index index.html;
gzip on;
gzip_vary on;
gzip_types text/css application/javascript;
location / {
try_files $uri $uri/ =404;
}
# HTML should always be revalidated so deploys are picked up promptly.
location = /index.html {
add_header Cache-Control "no-cache";
}
# The message list is edited frequently; do not cache it.
location = /messages.js {
add_header Cache-Control "no-cache";
}
# Other static assets may be cached for a short period.
location ~* \.(?:css|js)$ {
add_header Cache-Control "public, max-age=3600";
}
# Health endpoint for the proxy / orchestrator.
location = /healthz {
access_log off;
default_type text/plain;
return 200 "ok\n";
}
}