web.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. # coding=utf-8
  2. """
  3. @project: MaxKB
  4. @Author:虎虎
  5. @file: web.py
  6. @date:2025/11/5 14:53
  7. @desc:
  8. """
  9. from pathlib import Path
  10. from ...const import CONFIG, PROJECT_DIR
  11. import os
  12. from django.utils.translation import gettext_lazy as _
  13. # Build paths inside the project like this: BASE_DIR / 'subdir'.
  14. BASE_DIR = Path(__file__).resolve().parent.parent.parent
  15. # Quick-start development settings - unsuitable for production
  16. # See https://docs.djangoproject.com/en/4.2/howto/deployment/checklist/
  17. # SECURITY WARNING: keep the secret key used in production secret!
  18. SECRET_KEY = CONFIG.get("SECRET_KEY") or 'django-insecure-zm^1_^i5)3gp^&0io6zg72&z!a*d=9kf9o2%uft+27l)+t(#3e'
  19. # SECURITY WARNING: don't run with debug turned on in production!
  20. DEBUG = CONFIG.get_debug()
  21. ALLOWED_HOSTS = ['*']
  22. # Application definition
  23. INSTALLED_APPS = [
  24. 'django.contrib.contenttypes',
  25. 'django.contrib.messages',
  26. 'django.contrib.staticfiles',
  27. 'rest_framework',
  28. 'drf_spectacular',
  29. 'drf_spectacular_sidecar',
  30. 'users.apps.UsersConfig',
  31. 'tools.apps.ToolConfig',
  32. 'knowledge',
  33. 'common',
  34. 'system_manage',
  35. 'models_provider',
  36. 'django_celery_beat',
  37. 'application',
  38. 'chat',
  39. 'oss',
  40. 'trigger',
  41. 'django_apscheduler',
  42. ]
  43. MIDDLEWARE = [
  44. 'django.middleware.locale.LocaleMiddleware',
  45. 'django.middleware.security.SecurityMiddleware',
  46. 'django.contrib.sessions.middleware.SessionMiddleware',
  47. 'django.middleware.common.CommonMiddleware',
  48. 'common.middleware.gzip.GZipMiddleware',
  49. 'common.middleware.chat_headers_middleware.ChatHeadersMiddleware',
  50. 'common.middleware.cross_domain_middleware.CrossDomainMiddleware',
  51. 'common.middleware.doc_headers_middleware.DocHeadersMiddleware',
  52. ]
  53. REST_FRAMEWORK = {
  54. 'EXCEPTION_HANDLER': 'common.exception.handle_exception.handle_exception',
  55. 'DEFAULT_SCHEMA_CLASS': 'drf_spectacular.openapi.AutoSchema',
  56. 'DEFAULT_AUTHENTICATION_CLASSES': ['common.auth.authenticate.AnonymousAuthentication']
  57. }
  58. STATICFILES_DIRS = [(os.path.join(PROJECT_DIR, 'ui', 'dist'))]
  59. STATIC_ROOT = os.path.join(BASE_DIR.parent, 'static')
  60. ROOT_URLCONF = 'maxkb.urls'
  61. APPS_DIR = os.path.join(PROJECT_DIR, 'apps')
  62. TEMPLATES = [
  63. {
  64. 'BACKEND': 'django.template.backends.django.DjangoTemplates',
  65. 'DIRS': ["apps/static/admin"],
  66. 'APP_DIRS': True,
  67. 'OPTIONS': {
  68. 'context_processors': [
  69. 'django.template.context_processors.debug',
  70. 'django.template.context_processors.request',
  71. 'django.contrib.auth.context_processors.auth',
  72. 'django.contrib.messages.context_processors.messages',
  73. ],
  74. },
  75. },
  76. {"NAME": "CHAT",
  77. 'BACKEND': 'django.template.backends.django.DjangoTemplates',
  78. 'DIRS': ["apps/static/chat"],
  79. 'APP_DIRS': True,
  80. 'OPTIONS': {
  81. 'context_processors': [
  82. 'django.template.context_processors.debug',
  83. 'django.template.context_processors.request',
  84. 'django.contrib.auth.context_processors.auth',
  85. 'django.contrib.messages.context_processors.messages',
  86. ],
  87. },
  88. },
  89. {"NAME": "DOC",
  90. 'BACKEND': 'django.template.backends.django.DjangoTemplates',
  91. 'DIRS': ["apps/static/drf_spectacular_sidecar"],
  92. 'APP_DIRS': True,
  93. 'OPTIONS': {
  94. 'context_processors': [
  95. 'django.template.context_processors.debug',
  96. 'django.template.context_processors.request',
  97. 'django.contrib.auth.context_processors.auth',
  98. 'django.contrib.messages.context_processors.messages',
  99. ],
  100. },
  101. },
  102. ]
  103. SPECTACULAR_SETTINGS = {
  104. 'TITLE': '四川路桥智能体平台 API',
  105. 'DESCRIPTION': _('Intelligent customer service platform'),
  106. 'VERSION': 'v2',
  107. 'SERVE_INCLUDE_SCHEMA': False,
  108. # OTHER SETTINGS
  109. 'SWAGGER_UI_DIST': f'{CONFIG.get_admin_path()}/api-doc/swagger-ui-dist', # shorthand to use the sidecar instead
  110. 'SWAGGER_UI_FAVICON_HREF': f'{CONFIG.get_admin_path()}/api-doc/swagger-ui-dist/favicon-32x32.png',
  111. 'REDOC_DIST': f'{CONFIG.get_admin_path()}/api-doc/redoc',
  112. 'SECURITY_DEFINITIONS': {
  113. 'Bearer': {
  114. 'type': 'apiKey',
  115. 'name': 'AUTHORIZATION',
  116. 'in': 'header',
  117. }
  118. }
  119. }
  120. WSGI_APPLICATION = 'maxkb.wsgi.application'
  121. # Database
  122. # https://docs.djangoproject.com/en/4.2/ref/settings/#databases
  123. DATABASES = {'default': CONFIG.get_db_setting()}
  124. CACHES = CONFIG.get_cache_setting()
  125. # Password validation
  126. # https://docs.djangoproject.com/en/4.2/ref/settings/#auth-password-validators
  127. AUTH_PASSWORD_VALIDATORS = [
  128. {
  129. 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
  130. },
  131. {
  132. 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
  133. },
  134. {
  135. 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
  136. },
  137. {
  138. 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
  139. },
  140. ]
  141. # Internationalization
  142. # https://docs.djangoproject.com/en/4.2/topics/i18n/
  143. LANGUAGE_CODE = CONFIG.get("LANGUAGE_CODE")
  144. TIME_ZONE = CONFIG.get_time_zone()
  145. USE_I18N = True
  146. USE_TZ = True
  147. # 文件上传配置
  148. DATA_UPLOAD_MAX_NUMBER_FILES = 1000
  149. # 支持的语言
  150. LANGUAGES = [
  151. ('en', 'English'),
  152. ('zh', '中文简体'),
  153. ('zh-hant', '中文繁体')
  154. ]
  155. # 翻译文件路径
  156. LOCALE_PATHS = [
  157. os.path.join(BASE_DIR.parent, 'locales')
  158. ]
  159. # Static files (CSS, JavaScript, Images)
  160. # https://docs.djangoproject.com/en/4.2/howto/static-files/
  161. STATIC_URL = 'static/'
  162. # Default primary key field type
  163. # https://docs.djangoproject.com/en/4.2/ref/settings/#default-auto-field
  164. DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
  165. edition = 'CE'
  166. if os.environ.get('MAXKB_REDIS_SENTINEL_SENTINELS') is not None:
  167. DJANGO_REDIS_CONNECTION_FACTORY = "django_redis.pool.SentinelConnectionFactory"