Skip to content

Commit e421ab9

Browse files
committed
update:存储改成单例模式,修复读取问题
1 parent 8afae1f commit e421ab9

File tree

4 files changed

+20
-6
lines changed

4 files changed

+20
-6
lines changed

apps/admin/views.py

+3-1
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@
1111
from apps.base.models import FileCodes, KeyValue
1212
from core.response import APIResponse
1313
from core.settings import settings
14-
from core.storage import file_storage
14+
from core.storage import FileStorageInterface, storages
1515

1616
admin_api = APIRouter(
1717
prefix='/admin',
@@ -26,6 +26,7 @@ async def login():
2626

2727
@admin_api.delete('/file/delete', dependencies=[Depends(admin_required)])
2828
async def file_delete(data: IDData):
29+
file_storage: FileStorageInterface = storages[settings.file_storage]()
2930
file_code = await FileCodes.get(id=data.id)
3031
await file_storage.delete_file(file_code)
3132
await file_code.delete()
@@ -79,6 +80,7 @@ async def get_file_by_id(id):
7980

8081
@admin_api.get('/file/download', dependencies=[Depends(admin_required)])
8182
async def file_download(id: int):
83+
file_storage: FileStorageInterface = storages[settings.file_storage]()
8284
has, file_code = await get_file_by_id(id)
8385
# 检查文件是否存在
8486
if not has:

apps/base/views.py

+5-1
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@
1010
from apps.base.utils import get_expire_info, get_file_path_name, error_ip_limit, upload_ip_limit
1111
from core.response import APIResponse
1212
from core.settings import settings
13-
from core.storage import file_storage
13+
from core.storage import storages, FileStorageInterface
1414
from core.utils import get_select_token
1515

1616
# 创建一个API路由
@@ -56,6 +56,7 @@ async def share_file(expire_value: int = Form(default=1, gt=0), expire_style: st
5656
# 获取文件路径和名称
5757
path, suffix, prefix, uuid_file_name, save_path = await get_file_path_name(file)
5858
# 保存文件
59+
file_storage: FileStorageInterface = storages[settings.file_storage]()
5960
await file_storage.save_file(file, save_path)
6061
# 创建一个新的FileCodes实例
6162
await FileCodes.create(
@@ -94,6 +95,7 @@ async def get_code_file_by_code(code, check=True):
9495
# 获取文件的API
9596
@share_api.get('/select/')
9697
async def get_code_file(code: str, ip: str = Depends(error_ip_limit)):
98+
file_storage: FileStorageInterface = storages[settings.file_storage]()
9799
# 获取文件
98100
has, file_code = await get_code_file_by_code(code)
99101
# 检查文件是否存在
@@ -115,6 +117,7 @@ async def get_code_file(code: str, ip: str = Depends(error_ip_limit)):
115117
# 选择文件的API
116118
@share_api.post('/select/')
117119
async def select_file(data: SelectFileModel, ip: str = Depends(error_ip_limit)):
120+
file_storage: FileStorageInterface = storages[settings.file_storage]()
118121
# 获取文件
119122
has, file_code = await get_code_file_by_code(data.code)
120123
# 检查文件是否存在
@@ -141,6 +144,7 @@ async def select_file(data: SelectFileModel, ip: str = Depends(error_ip_limit)):
141144
# 下载文件的API
142145
@share_api.get('/download')
143146
async def download_file(key: str, code: str, ip: str = Depends(error_ip_limit)):
147+
file_storage: FileStorageInterface = storages[settings.file_storage]()
144148
# 检查token是否有效
145149
is_valid = await get_select_token(code) == key
146150
if not is_valid:

core/storage.py

+9-3
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,8 @@
22
# @Author : Lan
33
# @File : storage.py
44
# @Software: PyCharm
5+
from typing import Optional
6+
57
import aiohttp
68
import asyncio
79
from pathlib import Path
@@ -20,6 +22,12 @@
2022

2123

2224
class FileStorageInterface:
25+
_instance: Optional['FileStorageInterface'] = None
26+
27+
def __new__(cls, *args, **kwargs):
28+
if cls._instance is None:
29+
cls._instance = super(FileStorageInterface, cls).__new__(cls, *args, **kwargs)
30+
return cls._instance
2331

2432
async def save_file(self, file: UploadFile, save_path: str):
2533
"""
@@ -79,7 +87,7 @@ async def get_file_url(self, file_code: FileCodes):
7987
return await get_file_url(file_code.code)
8088

8189
async def get_file_response(self, file_code: FileCodes):
82-
file_path = file_storage.root_path / await file_code.get_file_path()
90+
file_path = self.root_path / await file_code.get_file_path()
8391
if not file_path.exists():
8492
return APIResponse(code=404, detail='文件已过期删除')
8593
return FileResponse(file_path, filename=file_code.prefix + file_code.suffix)
@@ -288,5 +296,3 @@ async def get_file_response(self, file_code: FileCodes):
288296
'onedrive': OneDriveFileStorage,
289297
'opendal': OpenDALFileStorage,
290298
}
291-
292-
file_storage: FileStorageInterface = storages[settings.file_storage]()

core/tasks.py

+3-1
Original file line numberDiff line numberDiff line change
@@ -8,11 +8,13 @@
88

99
from apps.base.models import FileCodes
1010
from apps.base.utils import error_ip_limit, upload_ip_limit
11-
from core.storage import file_storage
11+
from core.settings import settings
12+
from core.storage import FileStorageInterface, storages
1213
from core.utils import get_now
1314

1415

1516
async def delete_expire_files():
17+
file_storage: FileStorageInterface = storages[settings.file_storage]()
1618
while True:
1719
try:
1820
await error_ip_limit.remove_expired_ip()

0 commit comments

Comments
 (0)