__init__.py 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  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_config import ChromaConfig
  10. from configs.middleware.vdb.milvus_config import MilvusConfig
  11. from configs.middleware.vdb.opensearch_config import OpenSearchConfig
  12. from configs.middleware.vdb.oracle_config import OracleConfig
  13. from configs.middleware.vdb.pgvector_config import PGVectorConfig
  14. from configs.middleware.vdb.pgvectors_config import PGVectoRSConfig
  15. from configs.middleware.vdb.qdrant_config import QdrantConfig
  16. from configs.middleware.vdb.relyt_config import RelytConfig
  17. from configs.middleware.vdb.tencent_vector_config import TencentVectorDBConfig
  18. from configs.middleware.vdb.tidb_vector_config import TiDBVectorConfig
  19. from configs.middleware.vdb.weaviate_config import WeaviateConfig
  20. class StorageConfig(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 VectorStoreConfig(BaseModel):
  32. VECTOR_STORE: Optional[str] = Field(
  33. description='vector store type',
  34. default=None,
  35. )
  36. class KeywordStoreConfig(BaseModel):
  37. KEYWORD_STORE: str = Field(
  38. description='keyword store type',
  39. default='jieba',
  40. )
  41. class DatabaseConfig:
  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 CeleryConfig(DatabaseConfig):
  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. CeleryConfig,
  128. DatabaseConfig,
  129. KeywordStoreConfig,
  130. RedisConfig,
  131. # configs of storage and storage providers
  132. StorageConfig,
  133. AliyunOSSStorageConfig,
  134. AzureBlobStorageConfig,
  135. GoogleCloudStorageConfig,
  136. TencentCloudCOSStorageConfig,
  137. S3StorageConfig,
  138. # configs of vdb and vdb providers
  139. VectorStoreConfig,
  140. ChromaConfig,
  141. MilvusConfig,
  142. OpenSearchConfig,
  143. OracleConfig,
  144. PGVectorConfig,
  145. PGVectoRSConfig,
  146. QdrantConfig,
  147. RelytConfig,
  148. TencentVectorDBConfig,
  149. TiDBVectorConfig,
  150. WeaviateConfig,
  151. ):
  152. pass