generated from coulomb/repo-seed
prod.py never read the CSRF_TRUSTED_ORIGINS env var the deployment already injects, so Django's setting stayed empty. Behind traefik's TLS termination Django saw requests as HTTP and rejected the browser's https:// Origin on every POST with a CSRF failure (403) — forms could not be saved and the DB stayed empty. - Read CSRF_TRUSTED_ORIGINS from env (filtering empties). - Set SECURE_PROXY_SSL_HEADER so Django recognizes HTTPS via X-Forwarded-Proto. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
26 lines
939 B
Python
26 lines
939 B
Python
from decouple import config
|
|
|
|
from .base import * # noqa: F401, F403
|
|
|
|
DEBUG = False
|
|
ALLOWED_HOSTS = config('ALLOWED_HOSTS', default='').split(',')
|
|
|
|
# Behind traefik (TLS terminated at the proxy). Without these, Django sees the
|
|
# request as plain HTTP and rejects the browser's https:// Origin on every POST
|
|
# with a CSRF failure (403) — the request never reaches the view, so saves fail
|
|
# silently and the DB stays empty. The deployment already injects
|
|
# CSRF_TRUSTED_ORIGINS via env; this reads it.
|
|
CSRF_TRUSTED_ORIGINS = [
|
|
o for o in config('CSRF_TRUSTED_ORIGINS', default='').split(',') if o
|
|
]
|
|
SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', 'https')
|
|
|
|
STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'
|
|
|
|
SECURE_BROWSER_XSS_FILTER = True
|
|
SECURE_CONTENT_TYPE_NOSNIFF = True
|
|
SECURE_HSTS_SECONDS = 31536000
|
|
SECURE_HSTS_INCLUDE_SUBDOMAINS = True
|
|
SESSION_COOKIE_SECURE = True
|
|
CSRF_COOKIE_SECURE = True
|