settings.py 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. """
  2. Django settings for content_quality_tool project.
  3. Generated by 'django-admin startproject' using Django 5.2.7.
  4. For more information on this file, see
  5. https://docs.djangoproject.com/en/5.2/topics/settings/
  6. For the full list of settings and their values, see
  7. https://docs.djangoproject.com/en/5.2/ref/settings/
  8. """
  9. import sys
  10. import io
  11. sys.stdout = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8')
  12. sys.stderr = io.TextIOWrapper(sys.stderr.buffer, encoding='utf-8')
  13. from pathlib import Path
  14. import os
  15. from django.contrib.messages import constants as messages
  16. # Build paths inside the project like this: BASE_DIR / 'subdir'.
  17. BASE_DIR = Path(__file__).resolve().parent.parent
  18. # Quick-start development settings - unsuitable for production
  19. # See https://docs.djangoproject.com/en/5.2/howto/deployment/checklist/
  20. # SECURITY WARNING: keep the secret key used in production secret!
  21. SECRET_KEY = 'django-insecure-$6far8v=798or1wru24=zq&k*9&frm+dk%c!*w!a4wfb#z1_+3'
  22. # SECURITY WARNING: don't run with debug turned on in production!
  23. MINIMAX_API_KEY = 'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJHcm91cE5hbWUiOiJBYmh5dWRheSBBbmR1Z3VsYSIsIlVzZXJOYW1lIjoiQWJoeXVkYXkgQW5kdWd1bGEiLCJBY2NvdW50IjoiIiwiU3ViamVjdElEIjoiMTk3NjIwMTUxODMxOTE0OTMxMyIsIlBob25lIjoiIiwiR3JvdXBJRCI6IjE5NzYyMDE1MTgzMTA3NTY3NzUiLCJQYWdlTmFtZSI6IiIsIk1haWwiOiJhYmh5dWRheWFuZHVndWxhMjEzQGdtYWlsLmNvbSIsIkNyZWF0ZVRpbWUiOiIyMDI1LTEwLTA5IDIxOjAyOjE0IiwiVG9rZW5UeXBlIjoxLCJpc3MiOiJtaW5pbWF4In0.Dw6ug5FCzz_E0MOoBQ4fNN-ksaCJrwfscP5_fpmL7nxhlPJraoDHDFiznoqd5skLtIOKgsLsMNJMcutXyKTBxqqaKVGgKesZ_0JU8bAPwuPqe0MJ7ko3sZ0i858lFIqi8vH2rfgwqvvu9np2a2pQh2zvD-7LAZG4xCwcMHY7_19037s5EgONPYP7Lc_5caiF4DmNR4u7U4cunFfwGEGydpNSBP2xlk_dCRblsRNZFp-l9IkXtgi9EGOCzophhJvP8YiTMVZ2vtitt4c7YACqxtAjXT9774p299CqHAuuHcEv3MXiv0f1Zp4ERkfbsjYawYIewlfPgyw3bmFdm1py_Q'
  24. DEBUG = True
  25. ALLOWED_HOSTS = ['*', '172.29.7.103','https://incubator.luminad.com']
  26. # Application definition
  27. INSTALLED_APPS = [
  28. 'django.contrib.admin',
  29. 'django.contrib.auth',
  30. 'django.contrib.contenttypes',
  31. 'django.contrib.sessions',
  32. 'django.contrib.messages',
  33. 'django.contrib.staticfiles',
  34. 'core',
  35. 'title_creator_app',
  36. 'rest_framework',
  37. 'bg_remover',
  38. # 'attr_extraction',
  39. 'attr_extraction.apps.AttrExtractionConfig',
  40. # 'attr_extraction.apps.ProductAttributesConfig', # Full path
  41. ]
  42. MIDDLEWARE = [
  43. 'django.middleware.security.SecurityMiddleware',
  44. 'whitenoise.middleware.WhiteNoiseMiddleware',
  45. 'django.contrib.sessions.middleware.SessionMiddleware',
  46. 'django.middleware.common.CommonMiddleware',
  47. 'django.middleware.csrf.CsrfViewMiddleware',
  48. 'django.contrib.auth.middleware.AuthenticationMiddleware',
  49. 'django.contrib.messages.middleware.MessageMiddleware',
  50. 'django.middleware.clickjacking.XFrameOptionsMiddleware',
  51. ]
  52. # settings.py
  53. TIME_ZONE = 'Asia/Kolkata' # Change to your specific timezone
  54. USE_TZ = True
  55. ROOT_URLCONF = 'content_quality_tool.urls'
  56. TEMPLATES = [
  57. {
  58. 'BACKEND': 'django.template.backends.django.DjangoTemplates',
  59. 'DIRS': [BASE_DIR / "templates", BASE_DIR/ 'content_quality_tool_public/templates', BASE_DIR/ 'video_generator/templates', BASE_DIR/ 'ca/templates'],
  60. 'APP_DIRS': True,
  61. 'OPTIONS': {
  62. 'context_processors': [
  63. 'django.template.context_processors.request',
  64. 'django.contrib.auth.context_processors.auth',
  65. 'django.contrib.messages.context_processors.messages',
  66. ],
  67. },
  68. },
  69. ]
  70. WSGI_APPLICATION = 'content_quality_tool.wsgi.application'
  71. # Database
  72. # https://docs.djangoproject.com/en/5.2/ref/settings/#databases
  73. DATABASES = {
  74. 'default': {
  75. 'ENGINE': 'django.db.backends.sqlite3',
  76. 'NAME': BASE_DIR / 'db.sqlite3',
  77. }
  78. }
  79. # Password validation
  80. # https://docs.djangoproject.com/en/5.2/ref/settings/#auth-password-validators
  81. AUTH_PASSWORD_VALIDATORS = [
  82. {
  83. 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
  84. },
  85. {
  86. 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
  87. },
  88. {
  89. 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
  90. },
  91. {
  92. 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
  93. },
  94. ]
  95. # Internationalization
  96. # https://docs.djangoproject.com/en/5.2/topics/i18n/
  97. LANGUAGE_CODE = 'en-us'
  98. #TIME_ZONE = 'UTC'
  99. TIME_ZONE = 'Asia/Kolkata'
  100. USE_I18N = True
  101. USE_TZ = True
  102. # Static files (CSS, JavaScript, Images)
  103. # https://docs.djangoproject.com/en/5.2/howto/static-files/
  104. STATIC_URL = 'static/'
  105. STATICFILES_DIRS = [
  106. os.path.join(BASE_DIR, "content_quality_tool_public/static"),
  107. os.path.join(BASE_DIR, "video_generator/static"),
  108. os.path.join(BASE_DIR, "ca/static"),
  109. os.path.join(BASE_DIR, "api/static")
  110. ]
  111. # Default primary key field type
  112. # https://docs.djangoproject.com/en/5.2/ref/settings/#default-auto-field
  113. DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
  114. # Gemini API Configuration
  115. GEMINI_API_KEY = os.environ.get('GEMINI_API_KEY', 'AIzaSyBCoVdOMbB5u7BJglqjvVUfpgeYEHhI208')
  116. #AIzaSyAyxp26jdVFlocHVsMYR6Weq2GCB5rblGs, AIzaSyDxsW5DoaZP7evNE5b9Gcj8b3_GjoYk-9M
  117. MEDIA_ROOT = BASE_DIR / 'media'
  118. MEDIA_URL = '/media/'
  119. from django.conf import settings
  120. from django.conf.urls.static import static
  121. urlpatterns = [
  122. # ... your routes
  123. ] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
  124. MESSAGE_TAGS = {
  125. messages.ERROR: 'danger', # Map Django's error to Bootstrap's danger
  126. messages.SUCCESS: 'success',
  127. messages.INFO: 'info',
  128. messages.WARNING: 'warning',
  129. messages.DEBUG: 'debug',
  130. }
  131. OPENAI_API_KEY = "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"
  132. GROQ_API_KEY = "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"
  133. GROQ_API_URL = "https://api.groq.com/openai/v1/chat/completions"
  134. SUPPORTED_MODELS = ["llama-3.1-8b-instant", "llama-3.3-70b-versatile", "mixtral-8x7b-32768"]
  135. MAX_BATCH_SIZE = 100 # Maximum products per batch request
  136. CSRF_TRUSTED_ORIGINS = [
  137. 'https://incubator.luminad.com/',
  138. 'https://incubator.luminad.com',
  139. ]
  140. # ==================== settings.py ====================
  141. LOGGING = {
  142. 'version': 1,
  143. 'disable_existing_loggers': False,
  144. 'handlers': {
  145. 'console': {
  146. 'class': 'logging.StreamHandler',
  147. },
  148. },
  149. 'root': {
  150. 'handlers': ['console'],
  151. 'level': 'INFO',
  152. },
  153. 'loggers': {
  154. 'attr_extraction': {
  155. 'handlers': ['console'],
  156. 'level': 'INFO',
  157. 'propagate': False,
  158. },
  159. },
  160. }
  161. GROQ_API_KEY2 = "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"
  162. GROQ_API_KEY3 = "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",
  163. GROQ_API_KEY4 = "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"
  164. GROQ_API_KEYS = [
  165. {
  166. 'key': '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',
  167. 'name': 'groq_key_1'
  168. },
  169. {
  170. 'key': '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',
  171. 'name': 'groq_key_2'
  172. },
  173. {
  174. 'key': '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',
  175. 'name': 'groq_key_3'
  176. },
  177. {
  178. 'key': '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',
  179. 'name': 'groq_key_4'
  180. },
  181. ]
  182. LLM_LOAD_BALANCER_STRATEGY = 'round_robin'
  183. # ==================== PERFORMANCE TUNING ====================
  184. # Per-key rate limiting (requests per minute)
  185. # Groq free tier typically allows 30 RPM per key
  186. # Adjust based on your plan: Free=30, Pay-as-you-go=60+
  187. GROQ_PER_KEY_RPM = 30
  188. # Thread pool configuration
  189. # With 4 keys and image processing
  190. MAX_WORKERS_WITH_IMAGES = 6
  191. # With 4 keys and no image processing
  192. MAX_WORKERS_NO_IMAGES = 12
  193. # ==================== MONITORING & DEBUGGING ====================
  194. # Enable detailed debugging for load balancer
  195. DEBUG_LOAD_BALANCER = False # Set to True for troubleshooting
  196. # Track API usage statistics
  197. ENABLE_API_USAGE_TRACKING = True
  198. # Alert thresholds
  199. ALERT_FAILURE_RATE_THRESHOLD = 0.1 # Alert if >10% requests fail
  200. ALERT_KEY_UNAVAILABLE_THRESHOLD = 2 # Alert if >2 keys unavailable
  201. # # ==================== LOGGING CONFIGURATION ====================
  202. # LOGGING = {
  203. # 'version': 1,
  204. # 'disable_existing_loggers': False,
  205. # 'formatters': {
  206. # 'verbose': {
  207. # 'format': '{levelname} {asctime} {module} {message}',
  208. # 'style': '{',
  209. # },
  210. # 'simple': {
  211. # 'format': '{levelname} {message}',
  212. # 'style': '{',
  213. # },
  214. # },
  215. # 'handlers': {
  216. # 'console': {
  217. # 'class': 'logging.StreamHandler',
  218. # 'formatter': 'verbose',
  219. # },
  220. # 'file': {
  221. # 'class': 'logging.handlers.RotatingFileHandler',
  222. # 'filename': 'logs/product_attributes.log',
  223. # 'maxBytes': 1024 * 1024 * 10, # 10MB
  224. # 'backupCount': 5,
  225. # 'formatter': 'verbose',
  226. # },
  227. # },
  228. # 'loggers': {
  229. # 'attr_extraction.services': {
  230. # 'handlers': ['console', 'file'],
  231. # 'level': 'INFO',
  232. # 'propagate': False,
  233. # },
  234. # 'attr_extraction.llm_load_balancer': {
  235. # 'handlers': ['console', 'file'],
  236. # 'level': 'INFO',
  237. # 'propagate': False,
  238. # },
  239. # 'attr_extraction.views': {
  240. # 'handlers': ['console', 'file'],
  241. # 'level': 'INFO',
  242. # 'propagate': False,
  243. # },
  244. # },
  245. # }