123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291 |
- import os
- import random
- import string
- from .base import *
- DEBUG = False
- if "DJANGO_SECRET_KEY" in os.environ:
- SECRET_KEY = os.environ["DJANGO_SECRET_KEY"]
- else:
-
- print(
- "WARNING: DJANGO_SECRET_KEY not found in os.environ. Generating ephemeral SECRET_KEY."
- )
- SECRET_KEY = "".join(
- [random.SystemRandom().choice(string.printable) for i in range(50)]
- )
- SECURE_PROXY_SSL_HEADER = ("HTTP_X_FORWARDED_PROTO", "https")
- ALLOWED_HOSTS = os.getenv("DJANGO_ALLOWED_HOSTS", "*").split(",")
- EMAIL_BACKEND = "django.core.mail.backends.console.EmailBackend"
- if "PRIMARY_HOST" in os.environ:
- WAGTAILADMIN_BASE_URL = "https://{}".format(os.environ["PRIMARY_HOST"])
- AWS_ACCESS_KEY_ID = os.getenv("AWS_ACCESS_KEY_ID", "")
- AWS_SECRET_ACCESS_KEY = os.getenv("AWS_SECRET_ACCESS_KEY", "")
- AWS_REGION = os.getenv("AWS_REGION", "")
- REDIS_URL = os.environ.get("REDIS_TLS_URL", os.environ.get("REDIS_URL"))
- if REDIS_URL:
- connection_pool_kwargs = {}
- if REDIS_URL.startswith("rediss"):
-
-
- connection_pool_kwargs["ssl_cert_reqs"] = None
- redis_options = {
- "IGNORE_EXCEPTIONS": True,
- "SOCKET_CONNECT_TIMEOUT": 2,
- "SOCKET_TIMEOUT": 2,
- "CONNECTION_POOL_KWARGS": connection_pool_kwargs,
- }
- CACHES = {
- "default": {
- "BACKEND": "django_redis.cache.RedisCache",
- "LOCATION": REDIS_URL + "/0",
- "OPTIONS": redis_options,
- },
- "renditions": {
- "BACKEND": "django_redis.cache.RedisCache",
- "LOCATION": REDIS_URL + "/1",
- "OPTIONS": redis_options,
- },
- }
- DJANGO_REDIS_LOG_IGNORED_EXCEPTIONS = True
- else:
- CACHES = {
- "default": {
- "BACKEND": "django.core.cache.backends.locmem.LocMemCache",
- "LOCATION": "bakerydemo",
- }
- }
- ELASTICSEARCH_ENDPOINT = os.getenv("ELASTICSEARCH_ENDPOINT", "")
- if ELASTICSEARCH_ENDPOINT:
- from elasticsearch import RequestsHttpConnection
- WAGTAILSEARCH_BACKENDS = {
- "default": {
- "BACKEND": "wagtail.search.backends.elasticsearch5",
- "HOSTS": [
- {
- "host": ELASTICSEARCH_ENDPOINT,
- "port": int(os.getenv("ELASTICSEARCH_PORT", "9200")),
- "use_ssl": os.getenv("ELASTICSEARCH_USE_SSL", "off") == "on",
- "verify_certs": os.getenv("ELASTICSEARCH_VERIFY_CERTS", "off")
- == "on",
- }
- ],
- "OPTIONS": {
- "connection_class": RequestsHttpConnection,
- },
- }
- }
- if AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY:
- from aws_requests_auth.aws_auth import AWSRequestsAuth
- WAGTAILSEARCH_BACKENDS["default"]["HOSTS"][0]["http_auth"] = AWSRequestsAuth(
- aws_access_key=AWS_ACCESS_KEY_ID,
- aws_secret_access_key=AWS_SECRET_ACCESS_KEY,
- aws_token=os.getenv("AWS_SESSION_TOKEN", ""),
- aws_host=ELASTICSEARCH_ENDPOINT,
- aws_region=AWS_REGION,
- aws_service="es",
- )
- elif AWS_REGION:
-
-
-
- from aws_requests_auth.boto_utils import BotoAWSRequestsAuth
- WAGTAILSEARCH_BACKENDS["default"]["HOSTS"][0][
- "http_auth"
- ] = BotoAWSRequestsAuth(
- aws_host=ELASTICSEARCH_ENDPOINT,
- aws_region=AWS_REGION,
- aws_service="es",
- )
- MIDDLEWARE.append("whitenoise.middleware.WhiteNoiseMiddleware")
- STATICFILES_STORAGE = "whitenoise.storage.CompressedManifestStaticFilesStorage"
- if "AWS_STORAGE_BUCKET_NAME" in os.environ:
- AWS_STORAGE_BUCKET_NAME = os.getenv("AWS_STORAGE_BUCKET_NAME")
- AWS_QUERYSTRING_AUTH = False
- INSTALLED_APPS.append("storages")
- DEFAULT_FILE_STORAGE = "storages.backends.s3boto3.S3Boto3Storage"
- AWS_S3_FILE_OVERWRITE = False
- AWS_DEFAULT_ACL = "private"
- if "AWS_S3_CUSTOM_DOMAIN" in os.environ:
- AWS_S3_CUSTOM_DOMAIN = os.environ["AWS_S3_CUSTOM_DOMAIN"]
- if "AWS_S3_REGION_NAME" in os.environ:
- AWS_S3_REGION_NAME = os.environ["AWS_S3_REGION_NAME"]
- if "GS_BUCKET_NAME" in os.environ:
- GS_BUCKET_NAME = os.getenv("GS_BUCKET_NAME")
- GS_PROJECT_ID = os.getenv("GS_PROJECT_ID")
- GS_DEFAULT_ACL = "publicRead"
- GS_AUTO_CREATE_BUCKET = True
- INSTALLED_APPS.append("storages")
- DEFAULT_FILE_STORAGE = "storages.backends.gcloud.GoogleCloudStorage"
- LOGGING = {
- "version": 1,
- "disable_existing_loggers": False,
- "handlers": {
- "console": {
- "class": "logging.StreamHandler",
- },
- },
- "loggers": {
- "django": {
- "handlers": ["console"],
- "level": os.getenv("DJANGO_LOG_LEVEL", "INFO"),
- },
- },
- }
- if (
- "FRONTEND_CACHE_CLOUDFLARE_TOKEN" in os.environ
- or "FRONTEND_CACHE_CLOUDFLARE_BEARER_TOKEN" in os.environ
- ):
- INSTALLED_APPS.append("wagtail.contrib.frontend_cache")
- WAGTAILFRONTENDCACHE = {
- "default": {
- "BACKEND": "wagtail.contrib.frontend_cache.backends.CloudflareBackend",
- "ZONEID": os.environ["FRONTEND_CACHE_CLOUDFLARE_ZONEID"],
- }
- }
- if "FRONTEND_CACHE_CLOUDFLARE_TOKEN" in os.environ:
-
-
-
-
-
- WAGTAILFRONTENDCACHE["default"].update(
- {
- "EMAIL": os.environ["FRONTEND_CACHE_CLOUDFLARE_EMAIL"],
- "TOKEN": os.environ["FRONTEND_CACHE_CLOUDFLARE_TOKEN"],
- }
- )
- else:
-
-
-
- WAGTAILFRONTENDCACHE["default"].update(
- {"BEARER_TOKEN": os.environ["FRONTEND_CACHE_CLOUDFLARE_BEARER_TOKEN"]}
- )
- if os.environ.get("BASIC_AUTH_ENABLED", "false").lower().strip() == "true":
-
-
- MIDDLEWARE.insert(0, "baipw.middleware.BasicAuthIPWhitelistMiddleware")
-
- BASIC_AUTH_LOGIN = os.environ.get("BASIC_AUTH_LOGIN", "wagtail")
- BASIC_AUTH_PASSWORD = os.environ.get("BASIC_AUTH_PASSWORD", "wagtail")
-
- BASIC_AUTH_DISABLE_CONSUMING_AUTHORIZATION_HEADER = True
-
-
- if "BASIC_AUTH_WHITELISTED_HTTP_HOSTS" in os.environ:
- BASIC_AUTH_WHITELISTED_HTTP_HOSTS = os.environ[
- "BASIC_AUTH_WHITELISTED_HTTP_HOSTS"
- ].split(",")
- BASIC_AUTH_RESPONSE_TEMPLATE = "base/basic_auth.html"
- SECURE_SSL_REDIRECT = True
- SECURE_PROXY_SSL_HEADER = ("HTTP_X_FORWARDED_PROTO", "https")
- DEFAULT_HSTS_SECONDS = 30 * 24 * 60 * 60
- SECURE_HSTS_SECONDS = int(
- os.environ.get("SECURE_HSTS_SECONDS", DEFAULT_HSTS_SECONDS)
- )
- SECURE_HSTS_INCLUDE_SUBDOMAINS = False
- SECURE_BROWSER_XSS_FILTER = True
- SECURE_CONTENT_TYPE_NOSNIFF = True
- REFERRER_POLICY = os.environ.get(
- "SECURE_REFERRER_POLICY", "no-referrer-when-downgrade"
- ).strip()
- WAGTAIL_REDIRECTS_FILE_STORAGE = "cache"
|