From b1ecd01507dfaa98594ade4adeaa28cc04276c14 Mon Sep 17 00:00:00 2001 From: Viswamedha Nalabotu Date: Wed, 10 Dec 2025 13:44:56 +0000 Subject: [PATCH] Modified settings and added celery --- config/__init__.py | 3 ++ config/__pycache__/__init__.cpython-313.pyc | Bin 148 -> 224 bytes config/__pycache__/settings.cpython-313.pyc | Bin 4247 -> 5158 bytes config/celery.py | 8 +++ config/settings.py | 57 +++++++++++++++++--- 5 files changed, 60 insertions(+), 8 deletions(-) create mode 100644 config/celery.py diff --git a/config/__init__.py b/config/__init__.py index e69de29..fb989c4 100644 --- a/config/__init__.py +++ b/config/__init__.py @@ -0,0 +1,3 @@ +from .celery import app as celery_app + +__all__ = ('celery_app',) diff --git a/config/__pycache__/__init__.cpython-313.pyc b/config/__pycache__/__init__.cpython-313.pyc index 8f87f04d195e9a9a9fec5b0d60cf0f30c1d03850..b15c2cc6d349eab07e5660101c0202734a3b2644 100644 GIT binary patch delta 169 zcmbQj_<*tgGcPX}0}y;#WtO=PNIwQ~V1NnA_$&fsOl1gW2xjzV@M0`tQeX&XDq>D& z)?|6f2$a%fyv3YYPynR3l2db1iz?%RJU>mATWk<+5i?Lx5etyG#U3A@n3EG9zmnlI mkjpU9)+K^bOnNOQ$uQlZ|K$v%?gQuR4i22Efr`Q z>_6!61ACdYr#-KWG)>yewC!n{G$W=q^Ha4++bb(id)r9}tVp}kJ^tNuf9H2Tt`9?B zL?Wjij~l`IxinEoHY4;$<#4|0YT)!M+l$Ccx`9JDxI~do_;wg>rgNl|bmK141LrH? z?_KeE5$+zLNvMi?09~!3UO;^~gs&M|y`b?ao;uOBd(s7FP3lSQtR3LwL zk5$r`2y-G`vbhb- zvOUtbiUlY9k5=d0d{RouDlaQoO{UZGyTY6*D`HBNa5Pa;>jU&2i9s@}t(HI$@Nzn% zo|opUx%ni2SGe$=lao9zEM`Dm$_P@%YOj$qNxYz9K@pQ_@u8qtfy>%&-8AyTUbU}` zcu#mJOM(@ATO*^ugjAeKDj8w!vV0{#O^f%$jOF{k?tp#Kv&zGRK!H#XwnA9omlXkg zGR82AuF5b}c~OvHu8VS7*eWkcrj3t1^YsOoPvwW#XBgw9=Zx!*K7e6)$0-gu2vW39CTcHthD;PFxA^xP%U!)D3YLRl+h0qIzZ8BdnD0G(C2b!`+t112&cTiunmYDR zzw!%5e&M^^ul{-S!;h+pS0Ln1##xRG9`)M7Ck(Q={yAN;q2?5=H$czdCpyGd#}5HF G*na^wa=qzuU$5`zoH zwaaJXg1t+lnZ%7d@dsca1X!?f;fiEJS1e3?EpU^2a?Z&)xyk)(eM(u)XjDUD{_Re@ zD(VRRX^ERru1WK|^vyaVop2lCl&}Ovkl>n>c-PMc;0_xUdSC^!WVJ^}FgQ+Fs?Cyu zrQ0ke*bt;)2r>m+z$^p9qLYOYf!2y}z;K(eGr}T(=h{^fr&bLk7YgRkb1~IGA>m9(6mEgo$P4AE#5GlZZ)>w qJrzjAPy$Id$&MZve9!!qc&}eJD-w#$6R%So_*sh2_bPjRn!x`K?R#JV diff --git a/config/celery.py b/config/celery.py new file mode 100644 index 0000000..ffb15f1 --- /dev/null +++ b/config/celery.py @@ -0,0 +1,8 @@ +from celery import Celery +import os + +os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'config.settings') + +app = Celery('config') +app.config_from_object('django.conf:settings', namespace='CELERY') +app.autodiscover_tasks() diff --git a/config/settings.py b/config/settings.py index d695f52..855472b 100644 --- a/config/settings.py +++ b/config/settings.py @@ -6,7 +6,7 @@ BASE_DIR = Path(__file__).resolve().parent.parent load_dotenv(dotenv_path = BASE_DIR / '.env') -BUILD_DIR = os.getenv('DJANGO_BUILD_DIR', BASE_DIR / 'build') +BUILD_DIR = os.getenv('DJANGO_BUILD_DIR', BASE_DIR / 'build') SECRET_KEY = os.getenv('DJANGO_SECRET_KEY') DEBUG = str(os.getenv('DJANGO_DEBUG')).lower() in ('1', 'true', 'yes', 'on') @@ -35,6 +35,9 @@ DJANGO_APPS = [ THIRD_PARTY_APPS = [ 'rest_framework', 'channels', + 'django_celery_results', + 'django_celery_beat', + 'corsheaders', ] LOCAL_APPS = [ 'apps.users', @@ -49,6 +52,7 @@ DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField' MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'whitenoise.middleware.WhiteNoiseMiddleware', + 'corsheaders.middleware.CorsMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', @@ -63,8 +67,11 @@ ASGI_APPLICATION = f'{PARENT_NAME}.asgi.application' CHANNEL_LAYERS = { 'default': { - 'BACKEND': 'channels.layers.InMemoryChannelLayer' - } + 'BACKEND': 'channels_redis.core.RedisChannelLayer', + 'CONFIG': { + 'hosts': [os.getenv('CELERY_BROKER_URL')], + }, + }, } TEMPLATES = [ @@ -83,13 +90,32 @@ TEMPLATES = [ ] +DB_ENGINE = os.getenv('DJANGO_DB_ENGINE', 'django.db.backends.sqlite3') +DB_NAME = os.getenv('DJANGO_DB_NAME', BASE_DIR / 'db.sqlite3') +DB_USER = os.getenv('DJANGO_DB_USER') +DB_PASSWORD = os.getenv('DJANGO_DB_PASSWORD') +DB_HOST = os.getenv('DJANGO_DB_HOST') +DB_PORT = os.getenv('DJANGO_DB_PORT', 5432) + DATABASES = { - 'default': { - 'ENGINE': 'django.db.backends.sqlite3', - 'NAME': BASE_DIR / 'db.sqlite3', - } + 'default': { + 'ENGINE': DB_ENGINE, + 'NAME': DB_NAME, + 'USER': DB_USER, + 'PASSWORD': DB_PASSWORD, + 'HOST': DB_HOST, + 'PORT': DB_PORT, + 'CONN_MAX_AGE': 600, + } } +if DB_ENGINE == 'django.db.backends.sqlite3': + DATABASES['default'] = { + 'ENGINE': 'django.db.backends.sqlite3', + 'NAME': DB_NAME, + } + + STORAGES = { "staticfiles": { "BACKEND": "whitenoise.storage.CompressedManifestStaticFilesStorage", @@ -116,7 +142,6 @@ TIME_ZONE = 'UTC' USE_I18N = True USE_TZ = True - REST_FRAMEWORK = { 'DEFAULT_AUTHENTICATION_CLASSES': [ 'rest_framework.authentication.SessionAuthentication', @@ -126,3 +151,19 @@ REST_FRAMEWORK = { 'rest_framework.permissions.AllowAny', ], } + +CELERY_BROKER_URL = os.getenv('DJANGO_CELERY_BROKER_URL') +CELERY_RESULT_BACKEND = 'django-db' +CELERY_CACHE_BACKEND = 'django-cache' +CELERY_ACCEPT_CONTENT = ['json'] +CELERY_TASK_SERIALIZER = 'json' +CELERY_RESULT_SERIALIZER = 'json' +CELERY_TIMEZONE = 'UTC' +CELERY_TASK_TRACK_STARTED = True +CELERY_TASK_TIME_LIMIT = 30 * 60 + +CORS_ALLOWED_ORIGINS = os.getenv('DJANGO_CORS_ALLOWED_ORIGINS').split(',') if os.getenv('DJANGO_CORS_ALLOWED_ORIGINS') else [] +CORS_ALLOW_CREDENTIALS = True + +if DEBUG: + SECURE_CROSS_ORIGIN_OPENER_POLICY = None