docs: 为已有的路由编写完整名称和文档

This commit is contained in:
2026-05-30 00:22:36 +08:00
parent 52f6904bef
commit 884cea53a1
7 changed files with 197 additions and 44 deletions
+25 -2
View File
@@ -13,11 +13,17 @@ from .auth import verify_token
file_router = APIRouter(tags=["File"], prefix="/file")
@file_router.get("/")
@file_router.get("/", name="获取文件列表")
async def get_files(
user: Annotated[ModelUser, Depends(verify_token)],
session: Annotated[Session, Depends(get_session)],
) -> Sequence[ModelUploadFile]:
"""
获取用户上传的文件列表。
Returns:
ModelUploadFile 列表。
"""
files: Sequence[ModelUploadFile] = session.exec(
select(ModelUploadFile).where(ModelUploadFile.uploader_id == user.id)
).all()
@@ -25,12 +31,29 @@ async def get_files(
return files
@file_router.post("/upload/")
@file_router.post("/upload/", name="上传文件")
async def file_upload(
file: Annotated[UploadFile, File()],
user: Annotated[ModelUser, Depends(verify_token)],
session: Annotated[Session, Depends(get_session)],
) -> ModelUploadFile:
"""
仅允许单文件上传。
文件存储在 `.nyahome/contents` 目录下,由 uuid4 重命名,保留原拓展名。
允许上传的文件拓展名由 NyaHome 设置 `allow_upload_file_extensions` 约束。
对于不允许上传的文件类型,将抛出 400 错误。
Args:
file: 文件对象
user: 经验证的用户
session: 数据库连接对象
Raises:
HTTPException: 400 表示上传的文件类型不允许。文件类型仅由拓展名判断,不检查 MIME。
Returns:
ModelUploadFile
"""
try:
safe_name = s_get_safe_filename(file.filename) # type: ignore[arg-type]
dest_path = UPLOAD_DIR / safe_name