config.py 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. import os
  2. import dotenv
  3. DEFAULTS = {
  4. 'DB_USERNAME': 'postgres',
  5. 'DB_PASSWORD': '',
  6. 'DB_HOST': 'localhost',
  7. 'DB_PORT': '5432',
  8. 'DB_DATABASE': 'dify',
  9. 'DB_CHARSET': '',
  10. 'SQLALCHEMY_DATABASE_URI_SCHEME': 'postgresql',
  11. 'SQLALCHEMY_POOL_SIZE': 30,
  12. 'SQLALCHEMY_MAX_OVERFLOW': 10,
  13. 'SQLALCHEMY_POOL_RECYCLE': 3600,
  14. 'SQLALCHEMY_POOL_PRE_PING': 'False',
  15. 'SQLALCHEMY_ECHO': 'False',
  16. 'CELERY_BACKEND': 'database',
  17. 'HOSTED_OPENAI_QUOTA_LIMIT': 200,
  18. 'HOSTED_OPENAI_TRIAL_ENABLED': 'False',
  19. 'HOSTED_OPENAI_TRIAL_MODELS': 'gpt-3.5-turbo,gpt-3.5-turbo-1106,gpt-3.5-turbo-instruct,gpt-3.5-turbo-16k,gpt-3.5-turbo-16k-0613,gpt-3.5-turbo-0613,gpt-3.5-turbo-0125,text-davinci-003',
  20. 'HOSTED_OPENAI_PAID_ENABLED': 'False',
  21. 'HOSTED_OPENAI_PAID_MODELS': 'gpt-4,gpt-4-turbo-preview,gpt-4-turbo-2024-04-09,gpt-4-1106-preview,gpt-4-0125-preview,gpt-3.5-turbo,gpt-3.5-turbo-16k,gpt-3.5-turbo-16k-0613,gpt-3.5-turbo-1106,gpt-3.5-turbo-0613,gpt-3.5-turbo-0125,gpt-3.5-turbo-instruct,text-davinci-003',
  22. 'HOSTED_AZURE_OPENAI_ENABLED': 'False',
  23. 'HOSTED_AZURE_OPENAI_QUOTA_LIMIT': 200,
  24. 'HOSTED_ANTHROPIC_QUOTA_LIMIT': 600000,
  25. 'HOSTED_ANTHROPIC_TRIAL_ENABLED': 'False',
  26. 'HOSTED_ANTHROPIC_PAID_ENABLED': 'False',
  27. 'HOSTED_MODERATION_ENABLED': 'False',
  28. 'HOSTED_MODERATION_PROVIDERS': '',
  29. 'HOSTED_FETCH_APP_TEMPLATES_MODE': 'remote',
  30. 'HOSTED_FETCH_APP_TEMPLATES_REMOTE_DOMAIN': 'https://tmpl.dify.ai',
  31. }
  32. def get_env(key):
  33. return os.environ.get(key, DEFAULTS.get(key))
  34. def get_bool_env(key):
  35. value = get_env(key)
  36. return value.lower() == 'true' if value is not None else False
  37. def get_cors_allow_origins(env, default):
  38. cors_allow_origins = []
  39. if get_env(env):
  40. for origin in get_env(env).split(','):
  41. cors_allow_origins.append(origin)
  42. else:
  43. cors_allow_origins = [default]
  44. return cors_allow_origins
  45. class Config:
  46. """Application configuration class."""
  47. def __init__(self):
  48. dotenv.load_dotenv()
  49. self.TESTING = False
  50. # cors settings
  51. self.CONSOLE_CORS_ALLOW_ORIGINS = get_cors_allow_origins(
  52. 'CONSOLE_CORS_ALLOW_ORIGINS', get_env('CONSOLE_WEB_URL'))
  53. self.WEB_API_CORS_ALLOW_ORIGINS = get_cors_allow_origins(
  54. 'WEB_API_CORS_ALLOW_ORIGINS', '*')
  55. # ------------------------
  56. # Database Configurations.
  57. # ------------------------
  58. db_credentials = {
  59. key: get_env(key) for key in
  60. ['DB_USERNAME', 'DB_PASSWORD', 'DB_HOST', 'DB_PORT', 'DB_DATABASE', 'DB_CHARSET']
  61. }
  62. self.SQLALCHEMY_DATABASE_URI_SCHEME = get_env('SQLALCHEMY_DATABASE_URI_SCHEME')
  63. db_extras = f"?client_encoding={db_credentials['DB_CHARSET']}" if db_credentials['DB_CHARSET'] else ""
  64. self.SQLALCHEMY_DATABASE_URI = f"{self.SQLALCHEMY_DATABASE_URI_SCHEME}://{db_credentials['DB_USERNAME']}:{db_credentials['DB_PASSWORD']}@{db_credentials['DB_HOST']}:{db_credentials['DB_PORT']}/{db_credentials['DB_DATABASE']}{db_extras}"
  65. self.SQLALCHEMY_ENGINE_OPTIONS = {
  66. 'pool_size': int(get_env('SQLALCHEMY_POOL_SIZE')),
  67. 'max_overflow': int(get_env('SQLALCHEMY_MAX_OVERFLOW')),
  68. 'pool_recycle': int(get_env('SQLALCHEMY_POOL_RECYCLE')),
  69. 'pool_pre_ping': get_bool_env('SQLALCHEMY_POOL_PRE_PING'),
  70. 'connect_args': {'options': '-c timezone=UTC'},
  71. }
  72. self.SQLALCHEMY_ECHO = get_bool_env('SQLALCHEMY_ECHO')
  73. # ------------------------
  74. # Celery worker Configurations.
  75. # ------------------------
  76. self.CELERY_BROKER_URL = get_env('CELERY_BROKER_URL')
  77. self.CELERY_BACKEND = get_env('CELERY_BACKEND')
  78. self.CELERY_RESULT_BACKEND = 'db+{}'.format(self.SQLALCHEMY_DATABASE_URI) \
  79. if self.CELERY_BACKEND == 'database' else self.CELERY_BROKER_URL
  80. self.BROKER_USE_SSL = self.CELERY_BROKER_URL.startswith('rediss://') if self.CELERY_BROKER_URL else False
  81. # ------------------------
  82. # Platform Configurations.
  83. # ------------------------
  84. self.HOSTED_OPENAI_API_KEY = get_env('HOSTED_OPENAI_API_KEY')
  85. self.HOSTED_OPENAI_API_BASE = get_env('HOSTED_OPENAI_API_BASE')
  86. self.HOSTED_OPENAI_API_ORGANIZATION = get_env('HOSTED_OPENAI_API_ORGANIZATION')
  87. self.HOSTED_OPENAI_TRIAL_ENABLED = get_bool_env('HOSTED_OPENAI_TRIAL_ENABLED')
  88. self.HOSTED_OPENAI_TRIAL_MODELS = get_env('HOSTED_OPENAI_TRIAL_MODELS')
  89. self.HOSTED_OPENAI_QUOTA_LIMIT = int(get_env('HOSTED_OPENAI_QUOTA_LIMIT'))
  90. self.HOSTED_OPENAI_PAID_ENABLED = get_bool_env('HOSTED_OPENAI_PAID_ENABLED')
  91. self.HOSTED_OPENAI_PAID_MODELS = get_env('HOSTED_OPENAI_PAID_MODELS')
  92. self.HOSTED_AZURE_OPENAI_ENABLED = get_bool_env('HOSTED_AZURE_OPENAI_ENABLED')
  93. self.HOSTED_AZURE_OPENAI_API_KEY = get_env('HOSTED_AZURE_OPENAI_API_KEY')
  94. self.HOSTED_AZURE_OPENAI_API_BASE = get_env('HOSTED_AZURE_OPENAI_API_BASE')
  95. self.HOSTED_AZURE_OPENAI_QUOTA_LIMIT = int(get_env('HOSTED_AZURE_OPENAI_QUOTA_LIMIT'))
  96. self.HOSTED_ANTHROPIC_API_BASE = get_env('HOSTED_ANTHROPIC_API_BASE')
  97. self.HOSTED_ANTHROPIC_API_KEY = get_env('HOSTED_ANTHROPIC_API_KEY')
  98. self.HOSTED_ANTHROPIC_TRIAL_ENABLED = get_bool_env('HOSTED_ANTHROPIC_TRIAL_ENABLED')
  99. self.HOSTED_ANTHROPIC_QUOTA_LIMIT = int(get_env('HOSTED_ANTHROPIC_QUOTA_LIMIT'))
  100. self.HOSTED_ANTHROPIC_PAID_ENABLED = get_bool_env('HOSTED_ANTHROPIC_PAID_ENABLED')
  101. self.HOSTED_MINIMAX_ENABLED = get_bool_env('HOSTED_MINIMAX_ENABLED')
  102. self.HOSTED_SPARK_ENABLED = get_bool_env('HOSTED_SPARK_ENABLED')
  103. self.HOSTED_ZHIPUAI_ENABLED = get_bool_env('HOSTED_ZHIPUAI_ENABLED')
  104. self.HOSTED_MODERATION_ENABLED = get_bool_env('HOSTED_MODERATION_ENABLED')
  105. self.HOSTED_MODERATION_PROVIDERS = get_env('HOSTED_MODERATION_PROVIDERS')
  106. # fetch app templates mode, remote, builtin, db(only for dify SaaS), default: remote
  107. self.HOSTED_FETCH_APP_TEMPLATES_MODE = get_env('HOSTED_FETCH_APP_TEMPLATES_MODE')
  108. self.HOSTED_FETCH_APP_TEMPLATES_REMOTE_DOMAIN = get_env('HOSTED_FETCH_APP_TEMPLATES_REMOTE_DOMAIN')