Skip to content

Commit c4e398b

Browse files
author
Lan
committed
fix: share auth
1 parent 39264cc commit c4e398b

File tree

2 files changed

+39
-6
lines changed

2 files changed

+39
-6
lines changed

apps/admin/dependencies.py

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -95,6 +95,39 @@ async def admin_required(
9595
raise HTTPException(status_code=401, detail=str(e))
9696

9797

98+
async def share_required_login(
99+
authorization: str = Header(default=None), request: Request = None
100+
):
101+
"""
102+
验证分享上传权限
103+
104+
当settings.openUpload为False时,要求用户必须登录并具有管理员权限
105+
当settings.openUpload为True时,允许游客上传
106+
107+
:param authorization: 认证头信息
108+
:param request: 请求对象
109+
:return: 验证结果
110+
"""
111+
if not settings.openUpload:
112+
try:
113+
if not authorization or not authorization.startswith("Bearer "):
114+
raise HTTPException(
115+
status_code=403, detail="本站未开启游客上传,如需上传请先登录后台"
116+
)
117+
118+
token = authorization.split(" ")[1]
119+
try:
120+
payload = verify_token(token)
121+
if not payload.get("is_admin", False):
122+
raise HTTPException(status_code=401, detail="未授权或授权校验失败")
123+
except ValueError as e:
124+
raise HTTPException(status_code=401, detail=str(e))
125+
except Exception as e:
126+
raise HTTPException(status_code=401, detail="认证失败:" + str(e))
127+
128+
return True
129+
130+
98131
async def get_file_service():
99132
return FileService()
100133

apps/base/views.py

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,7 @@
44
from fastapi import APIRouter, Form, UploadFile, File, Depends, HTTPException
55
from starlette import status
66

7-
from apps.admin.dependencies import admin_required
7+
from apps.admin.dependencies import share_required_login
88
from apps.base.models import FileCodes, UploadChunk
99
from apps.base.schemas import SelectFileModel, InitChunkUploadModel, CompleteUploadModel
1010
from apps.base.utils import get_expire_info, get_file_path_name, ip_limit, get_chunk_file_path_name
@@ -28,7 +28,7 @@ async def create_file_code(code, **kwargs):
2828
return await FileCodes.create(code=code, **kwargs)
2929

3030

31-
@share_api.post("/text/", dependencies=[Depends(admin_required)])
31+
@share_api.post("/text/", dependencies=[Depends(share_required_login)])
3232
async def share_text(
3333
text: str = Form(...),
3434
expire_value: int = Form(default=1, gt=0),
@@ -56,7 +56,7 @@ async def share_text(
5656
return APIResponse(detail={"code": code})
5757

5858

59-
@share_api.post("/file/", dependencies=[Depends(admin_required)])
59+
@share_api.post("/file/", dependencies=[Depends(share_required_login)])
6060
async def share_file(
6161
expire_value: int = Form(default=1, gt=0),
6262
expire_style: str = Form(default="day"),
@@ -160,7 +160,7 @@ async def download_file(key: str, code: str, ip: str = Depends(ip_limit["error"]
160160
chunk_api = APIRouter(prefix="/chunk", tags=["切片"])
161161

162162

163-
@chunk_api.post("/upload/init/")
163+
@chunk_api.post("/upload/init/", dependencies=[Depends(share_required_login)])
164164
async def init_chunk_upload(data: InitChunkUploadModel):
165165
# 秒传检查
166166
existing = await FileCodes.filter(file_hash=data.file_hash).first()
@@ -203,7 +203,7 @@ async def init_chunk_upload(data: InitChunkUploadModel):
203203
})
204204

205205

206-
@chunk_api.post("/upload/chunk/{upload_id}/{chunk_index}")
206+
@chunk_api.post("/upload/chunk/{upload_id}/{chunk_index}", dependencies=[Depends(share_required_login)])
207207
async def upload_chunk(
208208
upload_id: str,
209209
chunk_index: int,
@@ -243,7 +243,7 @@ async def upload_chunk(
243243
return APIResponse(detail={"chunk_hash": chunk_hash})
244244

245245

246-
@chunk_api.post("/upload/complete/{upload_id}")
246+
@chunk_api.post("/upload/complete/{upload_id}", dependencies=[Depends(share_required_login)])
247247
async def complete_upload(upload_id: str, data: CompleteUploadModel, ip: str = Depends(ip_limit["upload"])):
248248
# 获取上传基本信息
249249
chunk_info = await UploadChunk.filter(upload_id=upload_id, chunk_index=-1).first()

0 commit comments

Comments
 (0)