mirror of
https://git.mirrors.martin98.com/https://github.com/langgenius/dify.git
synced 2025-08-11 12:59:02 +08:00
refactor: introduce storage factory and speed up api startup by importing storage client on demand (#9086)
This commit is contained in:
parent
5fcd614186
commit
b360feb4c1
@ -4,16 +4,9 @@ from typing import Union
|
|||||||
|
|
||||||
from flask import Flask
|
from flask import Flask
|
||||||
|
|
||||||
from extensions.storage.aliyun_storage import AliyunStorage
|
from configs import dify_config
|
||||||
from extensions.storage.azure_storage import AzureStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
from extensions.storage.baidu_storage import BaiduStorage
|
from extensions.storage.storage_type import StorageType
|
||||||
from extensions.storage.google_storage import GoogleStorage
|
|
||||||
from extensions.storage.huawei_storage import HuaweiStorage
|
|
||||||
from extensions.storage.local_storage import LocalStorage
|
|
||||||
from extensions.storage.oci_storage import OCIStorage
|
|
||||||
from extensions.storage.s3_storage import S3Storage
|
|
||||||
from extensions.storage.tencent_storage import TencentStorage
|
|
||||||
from extensions.storage.volcengine_storage import VolcengineStorage
|
|
||||||
|
|
||||||
|
|
||||||
class Storage:
|
class Storage:
|
||||||
@ -21,27 +14,52 @@ class Storage:
|
|||||||
self.storage_runner = None
|
self.storage_runner = None
|
||||||
|
|
||||||
def init_app(self, app: Flask):
|
def init_app(self, app: Flask):
|
||||||
storage_type = app.config.get("STORAGE_TYPE")
|
storage_factory = self.get_storage_factory(dify_config.STORAGE_TYPE)
|
||||||
if storage_type == "s3":
|
self.storage_runner = storage_factory(app=app)
|
||||||
self.storage_runner = S3Storage(app=app)
|
|
||||||
elif storage_type == "azure-blob":
|
@staticmethod
|
||||||
self.storage_runner = AzureStorage(app=app)
|
def get_storage_factory(storage_type: str) -> type[BaseStorage]:
|
||||||
elif storage_type == "aliyun-oss":
|
match storage_type:
|
||||||
self.storage_runner = AliyunStorage(app=app)
|
case StorageType.S3:
|
||||||
elif storage_type == "google-storage":
|
from extensions.storage.aws_s3_storage import AwsS3Storage
|
||||||
self.storage_runner = GoogleStorage(app=app)
|
|
||||||
elif storage_type == "tencent-cos":
|
return AwsS3Storage
|
||||||
self.storage_runner = TencentStorage(app=app)
|
case StorageType.AZURE_BLOB:
|
||||||
elif storage_type == "oci-storage":
|
from extensions.storage.azure_blob_storage import AzureBlobStorage
|
||||||
self.storage_runner = OCIStorage(app=app)
|
|
||||||
elif storage_type == "huawei-obs":
|
return AzureBlobStorage
|
||||||
self.storage_runner = HuaweiStorage(app=app)
|
case StorageType.ALIYUN_OSS:
|
||||||
elif storage_type == "baidu-obs":
|
from extensions.storage.aliyun_oss_storage import AliyunOssStorage
|
||||||
self.storage_runner = BaiduStorage(app=app)
|
|
||||||
elif storage_type == "volcengine-tos":
|
return AliyunOssStorage
|
||||||
self.storage_runner = VolcengineStorage(app=app)
|
case StorageType.GOOGLE_STORAGE:
|
||||||
else:
|
from extensions.storage.google_cloud_storage import GoogleCloudStorage
|
||||||
self.storage_runner = LocalStorage(app=app)
|
|
||||||
|
return GoogleCloudStorage
|
||||||
|
case StorageType.TENCENT_COS:
|
||||||
|
from extensions.storage.tencent_cos_storage import TencentCosStorage
|
||||||
|
|
||||||
|
return TencentCosStorage
|
||||||
|
case StorageType.OCI_STORAGE:
|
||||||
|
from extensions.storage.oracle_oci_storage import OracleOCIStorage
|
||||||
|
|
||||||
|
return OracleOCIStorage
|
||||||
|
case StorageType.HUAWEI_OBS:
|
||||||
|
from extensions.storage.huawei_obs_storage import HuaweiObsStorage
|
||||||
|
|
||||||
|
return HuaweiObsStorage
|
||||||
|
case StorageType.BAIDU_OBS:
|
||||||
|
from extensions.storage.baidu_obs_storage import BaiduObsStorage
|
||||||
|
|
||||||
|
return BaiduObsStorage
|
||||||
|
case StorageType.VOLCENGINE_TOS:
|
||||||
|
from extensions.storage.volcengine_tos_storage import VolcengineTosStorage
|
||||||
|
|
||||||
|
return VolcengineTosStorage
|
||||||
|
case StorageType.LOCAL | _:
|
||||||
|
from extensions.storage.local_fs_storage import LocalFsStorage
|
||||||
|
|
||||||
|
return LocalFsStorage
|
||||||
|
|
||||||
def save(self, filename, data):
|
def save(self, filename, data):
|
||||||
try:
|
try:
|
||||||
|
@ -7,8 +7,8 @@ from flask import Flask
|
|||||||
from extensions.storage.base_storage import BaseStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
|
|
||||||
|
|
||||||
class AliyunStorage(BaseStorage):
|
class AliyunOssStorage(BaseStorage):
|
||||||
"""Implementation for aliyun storage."""
|
"""Implementation for Aliyun OSS storage."""
|
||||||
|
|
||||||
def __init__(self, app: Flask):
|
def __init__(self, app: Flask):
|
||||||
super().__init__(app)
|
super().__init__(app)
|
@ -9,8 +9,8 @@ from flask import Flask
|
|||||||
from extensions.storage.base_storage import BaseStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
|
|
||||||
|
|
||||||
class S3Storage(BaseStorage):
|
class AwsS3Storage(BaseStorage):
|
||||||
"""Implementation for s3 storage."""
|
"""Implementation for Amazon Web Services S3 storage."""
|
||||||
|
|
||||||
def __init__(self, app: Flask):
|
def __init__(self, app: Flask):
|
||||||
super().__init__(app)
|
super().__init__(app)
|
@ -8,8 +8,8 @@ from extensions.ext_redis import redis_client
|
|||||||
from extensions.storage.base_storage import BaseStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
|
|
||||||
|
|
||||||
class AzureStorage(BaseStorage):
|
class AzureBlobStorage(BaseStorage):
|
||||||
"""Implementation for azure storage."""
|
"""Implementation for Azure Blob storage."""
|
||||||
|
|
||||||
def __init__(self, app: Flask):
|
def __init__(self, app: Flask):
|
||||||
super().__init__(app)
|
super().__init__(app)
|
@ -10,8 +10,8 @@ from flask import Flask
|
|||||||
from extensions.storage.base_storage import BaseStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
|
|
||||||
|
|
||||||
class BaiduStorage(BaseStorage):
|
class BaiduObsStorage(BaseStorage):
|
||||||
"""Implementation for baidu obs storage."""
|
"""Implementation for Baidu OBS storage."""
|
||||||
|
|
||||||
def __init__(self, app: Flask):
|
def __init__(self, app: Flask):
|
||||||
super().__init__(app)
|
super().__init__(app)
|
@ -10,8 +10,8 @@ from google.cloud import storage as google_cloud_storage
|
|||||||
from extensions.storage.base_storage import BaseStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
|
|
||||||
|
|
||||||
class GoogleStorage(BaseStorage):
|
class GoogleCloudStorage(BaseStorage):
|
||||||
"""Implementation for google storage."""
|
"""Implementation for Google Cloud storage."""
|
||||||
|
|
||||||
def __init__(self, app: Flask):
|
def __init__(self, app: Flask):
|
||||||
super().__init__(app)
|
super().__init__(app)
|
@ -6,8 +6,8 @@ from obs import ObsClient
|
|||||||
from extensions.storage.base_storage import BaseStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
|
|
||||||
|
|
||||||
class HuaweiStorage(BaseStorage):
|
class HuaweiObsStorage(BaseStorage):
|
||||||
"""Implementation for huawei obs storage."""
|
"""Implementation for Huawei OBS storage."""
|
||||||
|
|
||||||
def __init__(self, app: Flask):
|
def __init__(self, app: Flask):
|
||||||
super().__init__(app)
|
super().__init__(app)
|
@ -8,8 +8,8 @@ from flask import Flask
|
|||||||
from extensions.storage.base_storage import BaseStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
|
|
||||||
|
|
||||||
class LocalStorage(BaseStorage):
|
class LocalFsStorage(BaseStorage):
|
||||||
"""Implementation for local storage."""
|
"""Implementation for local filesystem storage."""
|
||||||
|
|
||||||
def __init__(self, app: Flask):
|
def __init__(self, app: Flask):
|
||||||
super().__init__(app)
|
super().__init__(app)
|
@ -8,7 +8,9 @@ from flask import Flask
|
|||||||
from extensions.storage.base_storage import BaseStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
|
|
||||||
|
|
||||||
class OCIStorage(BaseStorage):
|
class OracleOCIStorage(BaseStorage):
|
||||||
|
"""Implementation for Oracle OCI storage."""
|
||||||
|
|
||||||
def __init__(self, app: Flask):
|
def __init__(self, app: Flask):
|
||||||
super().__init__(app)
|
super().__init__(app)
|
||||||
app_config = self.app.config
|
app_config = self.app.config
|
14
api/extensions/storage/storage_type.py
Normal file
14
api/extensions/storage/storage_type.py
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
from enum import Enum
|
||||||
|
|
||||||
|
|
||||||
|
class StorageType(str, Enum):
|
||||||
|
ALIYUN_OSS = "aliyun-oss"
|
||||||
|
AZURE_BLOB = "azure-blob"
|
||||||
|
BAIDU_OBS = "baidu-obs"
|
||||||
|
GOOGLE_STORAGE = "google-storage"
|
||||||
|
HUAWEI_OBS = "huawei-obs"
|
||||||
|
LOCAL = "local"
|
||||||
|
OCI_STORAGE = "oci-storage"
|
||||||
|
S3 = "s3"
|
||||||
|
TENCENT_COS = "tencent-cos"
|
||||||
|
VOLCENGINE_TOS = "volcengine-tos"
|
@ -6,8 +6,8 @@ from qcloud_cos import CosConfig, CosS3Client
|
|||||||
from extensions.storage.base_storage import BaseStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
|
|
||||||
|
|
||||||
class TencentStorage(BaseStorage):
|
class TencentCosStorage(BaseStorage):
|
||||||
"""Implementation for tencent cos storage."""
|
"""Implementation for Tencent Cloud COS storage."""
|
||||||
|
|
||||||
def __init__(self, app: Flask):
|
def __init__(self, app: Flask):
|
||||||
super().__init__(app)
|
super().__init__(app)
|
@ -6,7 +6,7 @@ from flask import Flask
|
|||||||
from extensions.storage.base_storage import BaseStorage
|
from extensions.storage.base_storage import BaseStorage
|
||||||
|
|
||||||
|
|
||||||
class VolcengineStorage(BaseStorage):
|
class VolcengineTosStorage(BaseStorage):
|
||||||
"""Implementation for Volcengine TOS storage."""
|
"""Implementation for Volcengine TOS storage."""
|
||||||
|
|
||||||
def __init__(self, app: Flask):
|
def __init__(self, app: Flask):
|
2
api/poetry.lock
generated
2
api/poetry.lock
generated
@ -10595,4 +10595,4 @@ cffi = ["cffi (>=1.11)"]
|
|||||||
[metadata]
|
[metadata]
|
||||||
lock-version = "2.0"
|
lock-version = "2.0"
|
||||||
python-versions = ">=3.10,<3.13"
|
python-versions = ">=3.10,<3.13"
|
||||||
content-hash = "fd183812f910faf4e840267501c571db5d758ad6eb328d106ba6f79a0322a555"
|
content-hash = "34ba8efcc67da342036ef075b693f59fdc67d246f40b857c9c1bd6f80c7283bd"
|
||||||
|
@ -113,7 +113,6 @@ authlib = "1.3.1"
|
|||||||
azure-ai-inference = "~1.0.0b3"
|
azure-ai-inference = "~1.0.0b3"
|
||||||
azure-ai-ml = "~1.20.0"
|
azure-ai-ml = "~1.20.0"
|
||||||
azure-identity = "1.16.1"
|
azure-identity = "1.16.1"
|
||||||
azure-storage-blob = "12.13.0"
|
|
||||||
beautifulsoup4 = "4.12.2"
|
beautifulsoup4 = "4.12.2"
|
||||||
boto3 = "1.35.17"
|
boto3 = "1.35.17"
|
||||||
bs4 = "~0.0.1"
|
bs4 = "~0.0.1"
|
||||||
@ -221,6 +220,7 @@ yfinance = "~0.2.40"
|
|||||||
# Required for storage clients
|
# Required for storage clients
|
||||||
############################################################
|
############################################################
|
||||||
[tool.poetry.group.storage.dependencies]
|
[tool.poetry.group.storage.dependencies]
|
||||||
|
azure-storage-blob = "12.13.0"
|
||||||
bce-python-sdk = "~0.9.23"
|
bce-python-sdk = "~0.9.23"
|
||||||
cos-python-sdk-v5 = "1.9.30"
|
cos-python-sdk-v5 = "1.9.30"
|
||||||
esdk-obs-python = "3.24.6.1"
|
esdk-obs-python = "3.24.6.1"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user