__init__.py 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. from typing import Any, Optional
  2. from pydantic import BaseModel, Field, NonNegativeInt, PositiveInt, computed_field
  3. from configs.middleware.redis_config import RedisConfig
  4. from configs.middleware.storage.aliyun_oss_storage_config import AliyunOSSStorageConfig
  5. from configs.middleware.storage.amazon_s3_storage_config import S3StorageConfig
  6. from configs.middleware.storage.azure_blob_storage_config import AzureBlobStorageConfig
  7. from configs.middleware.storage.google_cloud_storage_config import GoogleCloudStorageConfig
  8. from configs.middleware.storage.tencent_cos_storage_config import TencentCloudCOSStorageConfig
  9. from configs.middleware.vdb.chroma_configs import ChromaConfigs
  10. from configs.middleware.vdb.milvus_configs import MilvusConfigs
  11. from configs.middleware.vdb.opensearch_configs import OpenSearchConfigs
  12. from configs.middleware.vdb.oracle_configs import OracleConfigs
  13. from configs.middleware.vdb.pgvector_configs import PGVectorConfigs
  14. from configs.middleware.vdb.pgvectors_configs import PGVectoRSConfigs
  15. from configs.middleware.vdb.qdrant_configs import QdrantConfigs
  16. from configs.middleware.vdb.relyt_configs import RelytConfigs
  17. from configs.middleware.vdb.tencent_vector_configs import TencentVectorDBConfigs
  18. from configs.middleware.vdb.tidb_vector_configs import TiDBVectorConfigs
  19. from configs.middleware.vdb.weaviate_configs import WeaviateConfigs
  20. class StorageConfigs(BaseModel):
  21. STORAGE_TYPE: str = Field(
  22. description='storage type,'
  23. ' default to `local`,'
  24. ' available values are `local`, `s3`, `azure-blob`, `aliyun-oss`, `google-storage`.',
  25. default='local',
  26. )
  27. STORAGE_LOCAL_PATH: str = Field(
  28. description='local storage path',
  29. default='storage',
  30. )
  31. class VectorStoreConfigs(BaseModel):
  32. VECTOR_STORE: Optional[str] = Field(
  33. description='vector store type',
  34. default=None,
  35. )
  36. class KeywordStoreConfigs(BaseModel):
  37. KEYWORD_STORE: str = Field(
  38. description='keyword store type',
  39. default='jieba',
  40. )
  41. class DatabaseConfigs:
  42. DB_HOST: str = Field(
  43. description='db host',
  44. default='localhost',
  45. )
  46. DB_PORT: PositiveInt = Field(
  47. description='db port',
  48. default=5432,
  49. )
  50. DB_USERNAME: str = Field(
  51. description='db username',
  52. default='postgres',
  53. )
  54. DB_PASSWORD: str = Field(
  55. description='db password',
  56. default='',
  57. )
  58. DB_DATABASE: str = Field(
  59. description='db database',
  60. default='dify',
  61. )
  62. DB_CHARSET: str = Field(
  63. description='db charset',
  64. default='',
  65. )
  66. SQLALCHEMY_DATABASE_URI_SCHEME: str = Field(
  67. description='db uri scheme',
  68. default='postgresql',
  69. )
  70. @computed_field
  71. @property
  72. def SQLALCHEMY_DATABASE_URI(self) -> str:
  73. db_extras = f"?client_encoding={self.DB_CHARSET}" if self.DB_CHARSET else ""
  74. return (f"{self.SQLALCHEMY_DATABASE_URI_SCHEME}://"
  75. f"{self.DB_USERNAME}:{self.DB_PASSWORD}@{self.DB_HOST}:{self.DB_PORT}/{self.DB_DATABASE}"
  76. f"{db_extras}")
  77. SQLALCHEMY_POOL_SIZE: NonNegativeInt = Field(
  78. description='pool size of SqlAlchemy',
  79. default=30,
  80. )
  81. SQLALCHEMY_MAX_OVERFLOW: NonNegativeInt = Field(
  82. description='max overflows for SqlAlchemy',
  83. default=10,
  84. )
  85. SQLALCHEMY_POOL_RECYCLE: NonNegativeInt = Field(
  86. description='SqlAlchemy pool recycle',
  87. default=3600,
  88. )
  89. SQLALCHEMY_POOL_PRE_PING: bool = Field(
  90. description='whether to enable pool pre-ping in SqlAlchemy',
  91. default=False,
  92. )
  93. SQLALCHEMY_ECHO: bool = Field(
  94. description='whether to enable SqlAlchemy echo',
  95. default=False,
  96. )
  97. @computed_field
  98. @property
  99. def SQLALCHEMY_ENGINE_OPTIONS(self) -> dict[str, Any]:
  100. return {
  101. 'pool_size': self.SQLALCHEMY_POOL_SIZE,
  102. 'max_overflow': self.SQLALCHEMY_MAX_OVERFLOW,
  103. 'pool_recycle': self.SQLALCHEMY_POOL_RECYCLE,
  104. 'pool_pre_ping': self.SQLALCHEMY_POOL_PRE_PING,
  105. 'connect_args': {'options': '-c timezone=UTC'},
  106. }
  107. class CeleryConfigs(DatabaseConfigs):
  108. CELERY_BACKEND: str = Field(
  109. description='Celery backend, available values are `database`, `redis`',
  110. default='database',
  111. )
  112. CELERY_BROKER_URL: Optional[str] = Field(
  113. description='CELERY_BROKER_URL',
  114. default=None,
  115. )
  116. @computed_field
  117. @property
  118. def CELERY_RESULT_BACKEND(self) -> str:
  119. return 'db+{}'.format(self.SQLALCHEMY_DATABASE_URI) \
  120. if self.CELERY_BACKEND == 'database' else self.CELERY_BROKER_URL
  121. @computed_field
  122. @property
  123. def BROKER_USE_SSL(self) -> bool:
  124. return self.CELERY_BROKER_URL.startswith('rediss://') if self.CELERY_BROKER_URL else False
  125. class MiddlewareConfig(
  126. # place the configs in alphabet order
  127. CeleryConfigs,
  128. DatabaseConfigs,
  129. KeywordStoreConfigs,
  130. RedisConfig,
  131. # configs of storage and storage providers
  132. StorageConfigs,
  133. AliyunOSSStorageConfig,
  134. AzureBlobStorageConfig,
  135. GoogleCloudStorageConfig,
  136. TencentCloudCOSStorageConfig,
  137. S3StorageConfig,
  138. # configs of vdb and vdb providers
  139. VectorStoreConfigs,
  140. ChromaConfigs,
  141. MilvusConfigs,
  142. OpenSearchConfigs,
  143. OracleConfigs,
  144. PGVectorConfigs,
  145. PGVectoRSConfigs,
  146. QdrantConfigs,
  147. RelytConfigs,
  148. TencentVectorDBConfigs,
  149. TiDBVectorConfigs,
  150. WeaviateConfigs,
  151. ):
  152. pass