Skip to content

Commit fafc56b

Browse files
committed
fix: issue #186
1 parent 8136c85 commit fafc56b

File tree

4 files changed

+25
-18
lines changed

4 files changed

+25
-18
lines changed

apps/base/utils.py

+4-4
Original file line numberDiff line numberDiff line change
@@ -86,7 +86,7 @@ async def get_random_code(style='num'):
8686
return code
8787

8888

89-
# 错误IP限制器
90-
error_ip_limit = IPRateLimit(count=settings.errorCount, minutes=settings.errorMinute)
91-
# 上传文件限制器
92-
upload_ip_limit = IPRateLimit(count=settings.uploadCount, minutes=settings.errorMinute)
89+
ip_limit = {
90+
'error': IPRateLimit(count=settings.uploadCount, minutes=settings.errorMinute),
91+
'upload': IPRateLimit(count=settings.errorCount, minutes=settings.errorMinute)
92+
}

apps/base/views.py

+12-11
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@
77
from apps.admin.depends import admin_required
88
from apps.base.models import FileCodes
99
from apps.base.pydantics import SelectFileModel
10-
from apps.base.utils import get_expire_info, get_file_path_name, error_ip_limit, upload_ip_limit
10+
from apps.base.utils import get_expire_info, get_file_path_name, ip_limit
1111
from core.response import APIResponse
1212
from core.settings import settings
1313
from core.storage import storages, FileStorageInterface
@@ -22,7 +22,7 @@
2222

2323
# 分享文本的API
2424
@share_api.post('/text/', dependencies=[Depends(admin_required)])
25-
async def share_text(text: str = Form(...), expire_value: int = Form(default=1, gt=0), expire_style: str = Form(default='day'), ip: str = Depends(upload_ip_limit)):
25+
async def share_text(text: str = Form(...), expire_value: int = Form(default=1, gt=0), expire_style: str = Form(default='day'), ip: str = Depends(ip_limit['upload'])):
2626
# 获取过期信息
2727
expired_at, expired_count, used_count, code = await get_expire_info(expire_value, expire_style)
2828
# 创建一个新的FileCodes实例
@@ -36,7 +36,7 @@ async def share_text(text: str = Form(...), expire_value: int = Form(default=1,
3636
prefix='文本分享'
3737
)
3838
# 添加IP到限制列表
39-
upload_ip_limit.add_ip(ip)
39+
ip_limit['upload'].add_ip(ip)
4040
# 返回API响应
4141
return APIResponse(detail={
4242
'code': code,
@@ -45,7 +45,8 @@ async def share_text(text: str = Form(...), expire_value: int = Form(default=1,
4545

4646
# 分享文件的API
4747
@share_api.post('/file/', dependencies=[Depends(admin_required)])
48-
async def share_file(expire_value: int = Form(default=1, gt=0), expire_style: str = Form(default='day'), file: UploadFile = File(...), ip: str = Depends(upload_ip_limit)):
48+
async def share_file(expire_value: int = Form(default=1, gt=0), expire_style: str = Form(default='day'), file: UploadFile = File(...),
49+
ip: str = Depends(ip_limit['upload'])):
4950
# 检查文件大小是否超过限制
5051
if file.size > int(settings.uploadSize):
5152
raise HTTPException(status_code=403, detail=f'文件大小超过限制,最大为{settings.uploadSize}字节')
@@ -71,7 +72,7 @@ async def share_file(expire_value: int = Form(default=1, gt=0), expire_style: st
7172
used_count=used_count,
7273
)
7374
# 添加IP到限制列表
74-
upload_ip_limit.add_ip(ip)
75+
ip_limit['upload'].add_ip(ip)
7576
# 返回API响应
7677
return APIResponse(detail={
7778
'code': code,
@@ -94,14 +95,14 @@ async def get_code_file_by_code(code, check=True):
9495

9596
# 获取文件的API
9697
@share_api.get('/select/')
97-
async def get_code_file(code: str, ip: str = Depends(error_ip_limit)):
98+
async def get_code_file(code: str, ip: str = Depends(ip_limit['error'])):
9899
file_storage: FileStorageInterface = storages[settings.file_storage]()
99100
# 获取文件
100101
has, file_code = await get_code_file_by_code(code)
101102
# 检查文件是否存在
102103
if not has:
103104
# 添加IP到限制列表
104-
error_ip_limit.add_ip(ip)
105+
ip_limit['error'].add_ip(ip)
105106
# 返回API响应
106107
return APIResponse(code=404, detail=file_code)
107108
# 更新文件的使用次数和过期次数
@@ -116,14 +117,14 @@ async def get_code_file(code: str, ip: str = Depends(error_ip_limit)):
116117

117118
# 选择文件的API
118119
@share_api.post('/select/')
119-
async def select_file(data: SelectFileModel, ip: str = Depends(error_ip_limit)):
120+
async def select_file(data: SelectFileModel, ip: str = Depends(ip_limit['error'])):
120121
file_storage: FileStorageInterface = storages[settings.file_storage]()
121122
# 获取文件
122123
has, file_code = await get_code_file_by_code(data.code)
123124
# 检查文件是否存在
124125
if not has:
125126
# 添加IP到限制列表
126-
error_ip_limit.add_ip(ip)
127+
ip_limit['error'].add_ip(ip)
127128
# 返回API响应
128129
return APIResponse(code=404, detail=file_code)
129130
# 更新文件的使用次数和过期次数
@@ -143,13 +144,13 @@ async def select_file(data: SelectFileModel, ip: str = Depends(error_ip_limit)):
143144

144145
# 下载文件的API
145146
@share_api.get('/download')
146-
async def download_file(key: str, code: str, ip: str = Depends(error_ip_limit)):
147+
async def download_file(key: str, code: str, ip: str = Depends(ip_limit['error'])):
147148
file_storage: FileStorageInterface = storages[settings.file_storage]()
148149
# 检查token是否有效
149150
is_valid = await get_select_token(code) == key
150151
if not is_valid:
151152
# 添加IP到限制列表
152-
error_ip_limit.add_ip(ip)
153+
ip_limit['error'].add_ip(ip)
153154
# 获取文件
154155
has, file_code = await get_code_file_by_code(code, False)
155156
# 检查文件是否存在

core/tasks.py

+3-3
Original file line numberDiff line numberDiff line change
@@ -7,7 +7,7 @@
77
from tortoise.expressions import Q
88

99
from apps.base.models import FileCodes
10-
from apps.base.utils import error_ip_limit, upload_ip_limit
10+
from apps.base.utils import ip_limit
1111
from core.settings import settings
1212
from core.storage import FileStorageInterface, storages
1313
from core.utils import get_now
@@ -17,8 +17,8 @@ async def delete_expire_files():
1717
file_storage: FileStorageInterface = storages[settings.file_storage]()
1818
while True:
1919
try:
20-
await error_ip_limit.remove_expired_ip()
21-
await upload_ip_limit.remove_expired_ip()
20+
await ip_limit['error'].remove_expired_ip()
21+
await ip_limit['upload'].remove_expired_ip()
2222
expire_data = await FileCodes.filter(Q(expired_at__lt=await get_now()) | Q(expired_count=0)).all()
2323
for exp in expire_data:
2424
await file_storage.delete_file(exp)

main.py

+6
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,9 @@
1010
from fastapi.staticfiles import StaticFiles
1111
from tortoise.contrib.fastapi import register_tortoise
1212

13+
from apps.base.depends import IPRateLimit
1314
from apps.base.models import KeyValue
15+
from apps.base.utils import ip_limit
1416
from apps.base.views import share_api
1517
from apps.admin.views import admin_api
1618
from core.response import APIResponse
@@ -59,6 +61,10 @@ async def startup_event():
5961
# 读取用户配置
6062
user_config, created = await KeyValue.get_or_create(key='settings', defaults={'value': DEFAULT_CONFIG})
6163
settings.user_config = user_config.value
64+
ip_limit['error'].minutes = settings.errorMinute
65+
ip_limit['error'].count = settings.errorCount
66+
ip_limit['upload'].minutes = settings.uploadMinute
67+
ip_limit['upload'].count = settings.uploadCount
6268

6369

6470
@app.get('/')

0 commit comments

Comments
 (0)