web.py 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  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. 'plugin.apps.PluginConfig',
  43. 'sso',
  44. ]
  45. MIDDLEWARE = [
  46. 'django.middleware.locale.LocaleMiddleware',
  47. 'django.middleware.security.SecurityMiddleware',
  48. 'django.contrib.sessions.middleware.SessionMiddleware',
  49. 'django.middleware.common.CommonMiddleware',
  50. 'common.middleware.gzip.GZipMiddleware',
  51. 'common.middleware.chat_headers_middleware.ChatHeadersMiddleware',
  52. 'common.middleware.cross_domain_middleware.CrossDomainMiddleware',
  53. 'common.middleware.doc_headers_middleware.DocHeadersMiddleware',
  54. 'application.middleware.rate_limit.RateLimitMiddleware',
  55. ]
  56. REST_FRAMEWORK = {
  57. 'EXCEPTION_HANDLER': 'common.exception.handle_exception.handle_exception',
  58. 'DEFAULT_SCHEMA_CLASS': 'drf_spectacular.openapi.AutoSchema',
  59. 'DEFAULT_AUTHENTICATION_CLASSES': ['common.auth.authenticate.AnonymousAuthentication'],
  60. 'UNAUTHENTICATED_USER': None,
  61. }
  62. STATICFILES_DIRS = [(os.path.join(PROJECT_DIR, 'ui', 'dist'))]
  63. STATIC_ROOT = os.path.join(BASE_DIR.parent, 'static')
  64. ROOT_URLCONF = 'maxkb.urls'
  65. APPS_DIR = os.path.join(PROJECT_DIR, 'apps')
  66. TEMPLATES = [
  67. {
  68. 'BACKEND': 'django.template.backends.django.DjangoTemplates',
  69. 'DIRS': ["apps/static/admin"],
  70. 'APP_DIRS': True,
  71. 'OPTIONS': {
  72. 'context_processors': [
  73. 'django.template.context_processors.debug',
  74. 'django.template.context_processors.request',
  75. 'django.contrib.auth.context_processors.auth',
  76. 'django.contrib.messages.context_processors.messages',
  77. ],
  78. },
  79. },
  80. {"NAME": "CHAT",
  81. 'BACKEND': 'django.template.backends.django.DjangoTemplates',
  82. 'DIRS': ["apps/static/chat"],
  83. 'APP_DIRS': True,
  84. 'OPTIONS': {
  85. 'context_processors': [
  86. 'django.template.context_processors.debug',
  87. 'django.template.context_processors.request',
  88. 'django.contrib.auth.context_processors.auth',
  89. 'django.contrib.messages.context_processors.messages',
  90. ],
  91. },
  92. },
  93. {"NAME": "DOC",
  94. 'BACKEND': 'django.template.backends.django.DjangoTemplates',
  95. 'DIRS': ["apps/static/drf_spectacular_sidecar"],
  96. 'APP_DIRS': True,
  97. 'OPTIONS': {
  98. 'context_processors': [
  99. 'django.template.context_processors.debug',
  100. 'django.template.context_processors.request',
  101. 'django.contrib.auth.context_processors.auth',
  102. 'django.contrib.messages.context_processors.messages',
  103. ],
  104. },
  105. },
  106. ]
  107. SPECTACULAR_SETTINGS = {
  108. 'TITLE': '网讯智能体平台 API',
  109. 'DESCRIPTION': _('Intelligent customer service platform'),
  110. 'VERSION': 'v2',
  111. 'SERVE_INCLUDE_SCHEMA': False,
  112. # OTHER SETTINGS
  113. 'SWAGGER_UI_DIST': f'{CONFIG.get_admin_path()}/api-doc/swagger-ui-dist', # shorthand to use the sidecar instead
  114. 'SWAGGER_UI_FAVICON_HREF': f'{CONFIG.get_admin_path()}/api-doc/swagger-ui-dist/favicon-32x32.png',
  115. 'REDOC_DIST': f'{CONFIG.get_admin_path()}/api-doc/redoc',
  116. 'SECURITY_DEFINITIONS': {
  117. 'Bearer': {
  118. 'type': 'apiKey',
  119. 'name': 'AUTHORIZATION',
  120. 'in': 'header',
  121. }
  122. }
  123. }
  124. WSGI_APPLICATION = 'maxkb.wsgi.application'
  125. # Database
  126. # https://docs.djangoproject.com/en/4.2/ref/settings/#databases
  127. DATABASES = {'default': CONFIG.get_db_setting()}
  128. CACHES = CONFIG.get_cache_setting()
  129. # Password validation
  130. # https://docs.djangoproject.com/en/4.2/ref/settings/#auth-password-validators
  131. AUTH_PASSWORD_VALIDATORS = [
  132. {
  133. 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
  134. },
  135. {
  136. 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
  137. },
  138. {
  139. 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
  140. },
  141. {
  142. 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
  143. },
  144. ]
  145. # Internationalization
  146. # https://docs.djangoproject.com/en/4.2/topics/i18n/
  147. LANGUAGE_CODE = CONFIG.get("LANGUAGE_CODE")
  148. TIME_ZONE = CONFIG.get_time_zone()
  149. USE_I18N = True
  150. USE_TZ = True
  151. # 文件上传配置
  152. DATA_UPLOAD_MAX_NUMBER_FILES = 1000
  153. # 支持的语言
  154. LANGUAGES = [
  155. ('en', 'English'),
  156. ('zh', '中文简体'),
  157. ('zh-hant', '中文繁体')
  158. ]
  159. # 翻译文件路径
  160. LOCALE_PATHS = [
  161. os.path.join(BASE_DIR.parent, 'locales')
  162. ]
  163. # Static files (CSS, JavaScript, Images)
  164. # https://docs.djangoproject.com/en/4.2/howto/static-files/
  165. STATIC_URL = 'static/'
  166. # Default primary key field type
  167. # https://docs.djangoproject.com/en/4.2/ref/settings/#default-auto-field
  168. DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
  169. edition = 'CE'
  170. if os.environ.get('MAXKB_REDIS_SENTINEL_SENTINELS') is not None:
  171. DJANGO_REDIS_CONNECTION_FACTORY = "django_redis.pool.SentinelConnectionFactory"
  172. # SSO 统一认证配置(从 config.yml 或环境变量读取)
  173. SSO_BASE_URL = CONFIG.get("SSO_BASE_URL") or ""
  174. SSO_CLIENT_ID = CONFIG.get("SSO_CLIENT_ID") or ""
  175. SSO_CLIENT_SECRET = CONFIG.get("SSO_CLIENT_SECRET") or ""
  176. SSO_REDIRECT_URI = CONFIG.get("SSO_REDIRECT_URI") or ""
  177. SSO_LOGOUT_REDIRECT_URL = CONFIG.get("SSO_LOGOUT_REDIRECT_URL") or ""
  178. # 样本中心配置(从 config.yml 或环境变量读取)
  179. SAMPLE_CENTER_BASE_URL = CONFIG.get("SAMPLE_CENTER_BASE_URL") or ""
  180. SAMPLE_CENTER_APP_ID = CONFIG.get("SAMPLE_CENTER_APP_ID") or ""
  181. SAMPLE_CENTER_APP_SECRET = CONFIG.get("SAMPLE_CENTER_APP_SECRET") or ""