From 513c090c3a45bf5d671f37eb9db892e0ea93044b Mon Sep 17 00:00:00 2001 From: Reinout van Rees Date: Wed, 3 Apr 2024 16:25:48 +0200 Subject: [PATCH 1/3] using settings as settings default --- brostar_api/celery.py | 3 +++ 1 file changed, 3 insertions(+) diff --git a/brostar_api/celery.py b/brostar_api/celery.py index 982e532..6df2041 100644 --- a/brostar_api/celery.py +++ b/brostar_api/celery.py @@ -1,5 +1,8 @@ +import os + from celery import Celery +os.environ.setdefault("DJANGO_SETTINGS_MODULE", "brostar_api.settings") app = Celery("brostar_api") # Using a string here means the worker doesn't have to serialize From 6071474cda7f2c030ab953bee4c20cd1e7965487 Mon Sep 17 00:00:00 2001 From: Reinout van Rees Date: Wed, 3 Apr 2024 16:26:33 +0200 Subject: [PATCH 2/3] Moved setting defaults to settings.py --- brostar_api/settings.py | 27 +++++++++++++-------------- docker-compose.yml | 24 ++++++++++-------------- 2 files changed, 23 insertions(+), 28 deletions(-) diff --git a/brostar_api/settings.py b/brostar_api/settings.py index 3f19d15..ae30ea2 100644 --- a/brostar_api/settings.py +++ b/brostar_api/settings.py @@ -1,31 +1,30 @@ import os from pathlib import Path -FIELD_ENCRYPTION_KEY = os.getenv("FIELD_ENCRYPTION_KEY") +# Environment variables can get a default value from an .env file via docker-compose. +FIELD_ENCRYPTION_KEY = os.getenv( + "FIELD_ENCRYPTION_KEY", default="DUMMY-NEEDS-PROD-SETTING-Xgb1GczqZe909UMNc4=" +) +SECRET_KEY = os.getenv( + "SECRET_KEY", + default="django-insecure-r4_51z=)9re0wxnj(fwanhzi($42k#usdr37z!o2c-a04*4p06", +) NENS_AUTH_ISSUER = os.getenv("NENS_AUTH_ISSUER") NENS_AUTH_CLIENT_ID = os.getenv("NENS_AUTH_CLIENT_ID") NENS_AUTH_CLIENT_SECRET = os.getenv("NENS_AUTH_CLIENT_SECRET") -# Environment variables can get a default value from docker-compose itself *or* from a -# `.env` file, as docker-compose automatically reads that (if the environment variable -# itself is mentioned in the compose file). +DEBUG_ENV = os.getenv("DEBUG", default="true") + +# Convert the environment variable (which is a string) to a boolean. +DEBUG = (DEBUG_ENV.lower() == "true") # True is the default + TIME_ZONE = "CET" USE_TZ = True - # Build paths inside the project like this: BASE_DIR / 'subdir'. BASE_DIR = Path(__file__).resolve().parent.parent -# Quick-start development settings - unsuitable for production -# See https://docs.djangoproject.com/en/5.0/howto/deployment/checklist/ - -# SECURITY WARNING: keep the secret key used in production secret! -SECRET_KEY = "django-insecure-r4_51z=)9re0wxnj(fwanhzi($42k#usdr37z!o2c-a04*4p06" - -# SECURITY WARNING: don't run with debug turned on in production! -DEBUG = True - ALLOWED_HOSTS = [] CSRF_TRUSTED_ORIGINS = [ diff --git a/docker-compose.yml b/docker-compose.yml index eb0a74e..a95f742 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -10,7 +10,6 @@ services: POSTGRES_DB: 'brostar' volumes: - pgdata:/var/lib/postgresql/data - restart: unless-stopped redis: image: redis:latest @@ -19,8 +18,9 @@ services: celery: environment: - - DJANGO_SETTINGS_MODULE=brostar_api.settings - - FIELD_ENCRYPTION_KEY="DUMMY-NEEDS-PROD-SETTING-Xgb1GczqZe909UMNc4=" + # # Can be set in .env, we'll pass them on. settings.py has some defaults. + - FIELD_ENCRYPTION_KEY + - SECRET_KEY - NENS_AUTH_ISSUER - NENS_AUTH_CLIENT_ID - NENS_AUTH_CLIENT_SECRET @@ -35,6 +35,13 @@ services: - redis web: + environment: + # # Can be set in .env, we'll pass them on. settings.py has some defaults. + - FIELD_ENCRYPTION_KEY + - SECRET_KEY + - NENS_AUTH_ISSUER + - NENS_AUTH_CLIENT_ID + - NENS_AUTH_CLIENT_SECRET build: . # command: "bin/gunicorn -b 0.0.0.0:${PORT:-5000} --workers=3 --timeout 90 --preload --max-requests=10000 trs.wsgi" command: "python manage.py runserver 0.0.0.0:8000" @@ -44,22 +51,11 @@ services: - "8000:8000" volumes: - .:/code - restart: unless-stopped - environment: - # # Can be set in .env, we'll pass them on. - # - SECRET_KEY - - DEBUG - - FIELD_ENCRYPTION_KEY="DUMMY-NEEDS-PROD-SETTING-Xgb1GczqZe909UMNc4=" - # - SENTRY_DSN - - NENS_AUTH_ISSUER - - NENS_AUTH_CLIENT_ID - - NENS_AUTH_CLIENT_SECRET depends_on: - db - redis - celery - volumes: pgdata: From 2621acc35d841589fb04ca59360288de693297e3 Mon Sep 17 00:00:00 2001 From: Reinout van Rees Date: Wed, 3 Apr 2024 16:27:04 +0200 Subject: [PATCH 3/3] ruff --- brostar_api/settings.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/brostar_api/settings.py b/brostar_api/settings.py index ae30ea2..ac16e4b 100644 --- a/brostar_api/settings.py +++ b/brostar_api/settings.py @@ -15,7 +15,7 @@ DEBUG_ENV = os.getenv("DEBUG", default="true") # Convert the environment variable (which is a string) to a boolean. -DEBUG = (DEBUG_ENV.lower() == "true") # True is the default +DEBUG = DEBUG_ENV.lower() == "true" # True is the default TIME_ZONE = "CET"