From 354d5977e0ceac54376479750d45eb960abfb552 Mon Sep 17 00:00:00 2001 From: jxxghp Date: Tue, 18 Jun 2024 19:19:32 +0800 Subject: [PATCH] fix api path --- app/api/apiv1.py | 4 +- app/api/endpoints/aliyun.py | 161 ++++++++++++++++- .../endpoints/{filebrowser.py => local.py} | 167 +----------------- 3 files changed, 168 insertions(+), 164 deletions(-) rename app/api/endpoints/{filebrowser.py => local.py} (54%) diff --git a/app/api/apiv1.py b/app/api/apiv1.py index 51b1495b..8336e190 100644 --- a/app/api/apiv1.py +++ b/app/api/apiv1.py @@ -2,7 +2,7 @@ from fastapi import APIRouter from app.api.endpoints import login, user, site, message, webhook, subscribe, \ media, douban, search, plugin, tmdb, history, system, download, dashboard, \ - filebrowser, transfer, mediaserver, bangumi, aliyun + local, transfer, mediaserver, bangumi, aliyun api_router = APIRouter() api_router.include_router(login.router, prefix="/login", tags=["login"]) @@ -20,7 +20,7 @@ api_router.include_router(system.router, prefix="/system", tags=["system"]) api_router.include_router(plugin.router, prefix="/plugin", tags=["plugin"]) api_router.include_router(download.router, prefix="/download", tags=["download"]) api_router.include_router(dashboard.router, prefix="/dashboard", tags=["dashboard"]) -api_router.include_router(filebrowser.router, prefix="/filebrowser", tags=["filebrowser"]) +api_router.include_router(local.router, prefix="/local", tags=["local"]) api_router.include_router(transfer.router, prefix="/transfer", tags=["transfer"]) api_router.include_router(mediaserver.router, prefix="/mediaserver", tags=["mediaserver"]) api_router.include_router(bangumi.router, prefix="/bangumi", tags=["bangumi"]) diff --git a/app/api/endpoints/aliyun.py b/app/api/endpoints/aliyun.py index 365d790c..23d86773 100644 --- a/app/api/endpoints/aliyun.py +++ b/app/api/endpoints/aliyun.py @@ -1,10 +1,16 @@ -from typing import Any +from pathlib import Path +from typing import Any, List from fastapi import APIRouter, Depends +from starlette.responses import Response from app import schemas -from app.core.security import verify_token +from app.chain.transfer import TransferChain +from app.core.config import settings +from app.core.metainfo import MetaInfoPath +from app.core.security import verify_token, verify_uri_token from app.helper.aliyun import AliyunHelper +from app.utils.string import StringUtils router = APIRouter() @@ -46,3 +52,154 @@ def userinfo(_: schemas.TokenPayload = Depends(verify_token)) -> Any: if info: return schemas.Response(success=True, data=info) return schemas.Response(success=False) + + +@router.get("/list", summary="所有目录和文件(阿里云盘)", response_model=List[schemas.FileItem]) +def list_aliyun(path: str, + fileid: str, + filetype: str = "dir", + sort: str = 'updated_at', + _: schemas.TokenPayload = Depends(verify_token)) -> Any: + """ + 查询当前目录下所有目录和文件 + :param path: 当前路径 + :param fileid: 文件ID + :param filetype: 文件类型 + :param sort: 排序方式,name:按名称排序,time:按修改时间排序 + :param _: token + :return: 所有目录和文件 + """ + if not fileid: + return [] + if not path: + path = "/" + if sort == "time": + sort = "updated_at" + if filetype == "file": + fileinfo = AliyunHelper().get_file_detail(fileid) + if fileinfo: + return [schemas.FileItem( + fileid=fileinfo.get("file_id"), + parent_fileid=fileinfo.get("parent_file_id"), + type="file", + path=f"{path}{fileinfo.get('name')}", + name=fileinfo.get("name"), + size=fileinfo.get("size"), + extension=fileinfo.get("file_extension"), + modify_time=StringUtils.str_to_timestamp(fileinfo.get("updated_at")), + thumbnail=fileinfo.get("thumbnail") + )] + return [] + items = AliyunHelper().list_files(parent_file_id=fileid, order_by=sort) + if not items: + return [] + return [schemas.FileItem( + fileid=item.get("file_id"), + parent_fileid=item.get("parent_file_id"), + type="dir" if item.get("type") == "folder" else "file", + path=f"{path}{item.get('name')}" + "/" if item.get("type") == "folder" else "", + name=item.get("name"), + size=item.get("size"), + extension=item.get("file_extension"), + modify_time=StringUtils.str_to_timestamp(item.get("updated_at")), + thumbnail=item.get("thumbnail") + ) for item in items] + + +@router.get("/mkdir", summary="创建目录(阿里云盘)", response_model=schemas.Response) +def mkdir_aliyun(fileid: str, + name: str, + _: schemas.TokenPayload = Depends(verify_token)) -> Any: + """ + 创建目录 + """ + if not fileid or not name: + return schemas.Response(success=False) + result = AliyunHelper().create_folder(parent_file_id=fileid, name=name) + if result: + return schemas.Response(success=True) + return schemas.Response(success=False) + + +@router.get("/delete", summary="删除文件或目录(阿里云盘)", response_model=schemas.Response) +def delete_aliyun(fileid: str, + _: schemas.TokenPayload = Depends(verify_token)) -> Any: + """ + 删除文件或目录 + """ + if not fileid: + return schemas.Response(success=False) + result = AliyunHelper().delete_file(fileid) + if result: + return schemas.Response(success=True) + return schemas.Response(success=False) + + +@router.get("/download", summary="下载文件(阿里云盘)") +def download_aliyun(fileid: str, + _: schemas.TokenPayload = Depends(verify_uri_token)) -> Any: + """ + 下载文件或目录 + """ + if not fileid: + return schemas.Response(success=False) + url = AliyunHelper().get_download_url(fileid) + if url: + # 重定向 + return Response(status_code=302, headers={"Location": url}) + return schemas.Response(success=False) + + +@router.get("/rename", summary="重命名文件或目录(阿里云盘)", response_model=schemas.Response) +def rename_aliyun(fileid: str, new_name: str, path: str, + recursive: bool = False, + _: schemas.TokenPayload = Depends(verify_token)) -> Any: + """ + 重命名文件或目录 + """ + if not fileid or not new_name: + return schemas.Response(success=False) + result = AliyunHelper().rename_file(fileid, new_name) + if result: + if recursive: + transferchain = TransferChain() + media_exts = settings.RMT_MEDIAEXT + settings.RMT_SUBEXT + settings.RMT_AUDIO_TRACK_EXT + # 递归修改目录内文件(智能识别命名) + sub_files: List[schemas.FileItem] = list_aliyun(path=path, fileid=fileid) + for sub_file in sub_files: + if sub_file.type == "dir": + continue + if not sub_file.extension: + continue + if f".{sub_file.extension.lower()}" not in media_exts: + continue + sub_path = Path(f"{path}{sub_file.name}") + meta = MetaInfoPath(sub_path) + mediainfo = transferchain.recognize_media(meta) + if not mediainfo: + return schemas.Response(success=False, message=f"{sub_path.name} 未识别到媒体信息") + new_path = transferchain.recommend_name(meta=meta, mediainfo=mediainfo) + if not new_path: + return schemas.Response(success=False, message=f"{sub_path.name} 未识别到新名称") + ret: schemas.Response = rename_aliyun(fileid=sub_file.fileid, + path=path, + new_name=Path(new_path).name, + recursive=False) + if not ret.success: + return schemas.Response(success=False, message=f"{sub_path.name} 重命名失败!") + return schemas.Response(success=True) + return schemas.Response(success=False) + + +@router.get("/image", summary="读取图片(阿里云盘)", response_model=schemas.Response) +def image_aliyun(fileid: str, _: schemas.TokenPayload = Depends(verify_uri_token)) -> Any: + """ + 读取图片 + """ + if not fileid: + return schemas.Response(success=False) + url = AliyunHelper().get_download_url(fileid) + if url: + # 重定向 + return Response(status_code=302, headers={"Location": url}) + return schemas.Response(success=False) diff --git a/app/api/endpoints/filebrowser.py b/app/api/endpoints/local.py similarity index 54% rename from app/api/endpoints/filebrowser.py rename to app/api/endpoints/local.py index f330c4c4..16fb0473 100644 --- a/app/api/endpoints/filebrowser.py +++ b/app/api/endpoints/local.py @@ -10,9 +10,7 @@ from app.chain.transfer import TransferChain from app.core.config import settings from app.core.metainfo import MetaInfoPath from app.core.security import verify_token, verify_uri_token -from app.helper.aliyun import AliyunHelper from app.log import logger -from app.utils.string import StringUtils from app.utils.system import SystemUtils router = APIRouter() @@ -20,7 +18,7 @@ router = APIRouter() IMAGE_TYPES = [".jpg", ".png", ".gif", ".bmp", ".jpeg", ".webp"] -@router.get("/local/list", summary="所有目录和文件(本地)", response_model=List[schemas.FileItem]) +@router.get("/list", summary="所有目录和文件(本地)", response_model=List[schemas.FileItem]) def list_local(path: str, sort: str = 'time', _: schemas.TokenPayload = Depends(verify_token)) -> Any: @@ -102,7 +100,7 @@ def list_local(path: str, return ret_items -@router.get("/local/listdir", summary="所有目录(本地,不含文件)", response_model=List[schemas.FileItem]) +@router.get("/listdir", summary="所有目录(本地,不含文件)", response_model=List[schemas.FileItem]) def list_local_dir(path: str, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 查询当前目录下所有目录 @@ -143,7 +141,7 @@ def list_local_dir(path: str, _: schemas.TokenPayload = Depends(verify_token)) - return ret_items -@router.get("/local/mkdir", summary="创建目录(本地)", response_model=schemas.Response) +@router.get("/mkdir", summary="创建目录(本地)", response_model=schemas.Response) def mkdir_local(path: str, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 创建目录 @@ -157,7 +155,7 @@ def mkdir_local(path: str, _: schemas.TokenPayload = Depends(verify_token)) -> A return schemas.Response(success=True) -@router.get("/local/delete", summary="删除文件或目录(本地)", response_model=schemas.Response) +@router.get("/delete", summary="删除文件或目录(本地)", response_model=schemas.Response) def delete_local(path: str, _: schemas.TokenPayload = Depends(verify_token)) -> Any: """ 删除文件或目录 @@ -174,7 +172,7 @@ def delete_local(path: str, _: schemas.TokenPayload = Depends(verify_token)) -> return schemas.Response(success=True) -@router.get("/local/download", summary="下载文件(本地)") +@router.get("/download", summary="下载文件(本地)") def download_local(path: str, _: schemas.TokenPayload = Depends(verify_uri_token)) -> Any: """ 下载文件或目录 @@ -196,7 +194,7 @@ def download_local(path: str, _: schemas.TokenPayload = Depends(verify_uri_token return reponse -@router.get("/local/rename", summary="重命名文件或目录(本地)", response_model=schemas.Response) +@router.get("/rename", summary="重命名文件或目录(本地)", response_model=schemas.Response) def rename_local(path: str, new_name: str, recursive: bool = False, _: schemas.TokenPayload = Depends(verify_token)) -> Any: @@ -235,7 +233,7 @@ def rename_local(path: str, new_name: str, return schemas.Response(success=True) -@router.get("/local/image", summary="读取图片(本地)") +@router.get("/image", summary="读取图片(本地)") def image_local(path: str, _: schemas.TokenPayload = Depends(verify_uri_token)) -> Any: """ 读取图片 @@ -251,154 +249,3 @@ def image_local(path: str, _: schemas.TokenPayload = Depends(verify_uri_token)) if path_obj.suffix.lower() not in IMAGE_TYPES: return None return Response(content=path_obj.read_bytes(), media_type="image/jpeg") - - -@router.get("/aliyun/list", summary="所有目录和文件(阿里云盘)", response_model=List[schemas.FileItem]) -def list_aliyun(path: str, - fileid: str, - filetype: str = "dir", - sort: str = 'updated_at', - _: schemas.TokenPayload = Depends(verify_token)) -> Any: - """ - 查询当前目录下所有目录和文件 - :param path: 当前路径 - :param fileid: 文件ID - :param filetype: 文件类型 - :param sort: 排序方式,name:按名称排序,time:按修改时间排序 - :param _: token - :return: 所有目录和文件 - """ - if not fileid: - return [] - if not path: - path = "/" - if sort == "time": - sort = "updated_at" - if filetype == "file": - fileinfo = AliyunHelper().get_file_detail(fileid) - if fileinfo: - return [schemas.FileItem( - fileid=fileinfo.get("file_id"), - parent_fileid=fileinfo.get("parent_file_id"), - type="file", - path=f"{path}{fileinfo.get('name')}", - name=fileinfo.get("name"), - size=fileinfo.get("size"), - extension=fileinfo.get("file_extension"), - modify_time=StringUtils.str_to_timestamp(fileinfo.get("updated_at")), - thumbnail=fileinfo.get("thumbnail") - )] - return [] - items = AliyunHelper().list_files(parent_file_id=fileid, order_by=sort) - if not items: - return [] - return [schemas.FileItem( - fileid=item.get("file_id"), - parent_fileid=item.get("parent_file_id"), - type="dir" if item.get("type") == "folder" else "file", - path=f"{path}{item.get('name')}" + "/" if item.get("type") == "folder" else "", - name=item.get("name"), - size=item.get("size"), - extension=item.get("file_extension"), - modify_time=StringUtils.str_to_timestamp(item.get("updated_at")), - thumbnail=item.get("thumbnail") - ) for item in items] - - -@router.get("/aliyun/mkdir", summary="创建目录(阿里云盘)", response_model=schemas.Response) -def mkdir_aliyun(fileid: str, - name: str, - _: schemas.TokenPayload = Depends(verify_token)) -> Any: - """ - 创建目录 - """ - if not fileid or not name: - return schemas.Response(success=False) - result = AliyunHelper().create_folder(parent_file_id=fileid, name=name) - if result: - return schemas.Response(success=True) - return schemas.Response(success=False) - - -@router.get("/aliyun/delete", summary="删除文件或目录(阿里云盘)", response_model=schemas.Response) -def delete_aliyun(fileid: str, - _: schemas.TokenPayload = Depends(verify_token)) -> Any: - """ - 删除文件或目录 - """ - if not fileid: - return schemas.Response(success=False) - result = AliyunHelper().delete_file(fileid) - if result: - return schemas.Response(success=True) - return schemas.Response(success=False) - - -@router.get("/aliyun/download", summary="下载文件(阿里云盘)") -def download_aliyun(fileid: str, - _: schemas.TokenPayload = Depends(verify_uri_token)) -> Any: - """ - 下载文件或目录 - """ - if not fileid: - return schemas.Response(success=False) - url = AliyunHelper().get_download_url(fileid) - if url: - # 重定向 - return Response(status_code=302, headers={"Location": url}) - return schemas.Response(success=False) - - -@router.get("/aliyun/rename", summary="重命名文件或目录(阿里云盘)", response_model=schemas.Response) -def rename_aliyun(fileid: str, new_name: str, path: str, - recursive: bool = False, - _: schemas.TokenPayload = Depends(verify_token)) -> Any: - """ - 重命名文件或目录 - """ - if not fileid or not new_name: - return schemas.Response(success=False) - result = AliyunHelper().rename_file(fileid, new_name) - if result: - if recursive: - transferchain = TransferChain() - media_exts = settings.RMT_MEDIAEXT + settings.RMT_SUBEXT + settings.RMT_AUDIO_TRACK_EXT - # 递归修改目录内文件(智能识别命名) - sub_files: List[schemas.FileItem] = list_aliyun(path=path, fileid=fileid) - for sub_file in sub_files: - if sub_file.type == "dir": - continue - if not sub_file.extension: - continue - if f".{sub_file.extension.lower()}" not in media_exts: - continue - sub_path = Path(f"{path}{sub_file.name}") - meta = MetaInfoPath(sub_path) - mediainfo = transferchain.recognize_media(meta) - if not mediainfo: - return schemas.Response(success=False, message=f"{sub_path.name} 未识别到媒体信息") - new_path = transferchain.recommend_name(meta=meta, mediainfo=mediainfo) - if not new_path: - return schemas.Response(success=False, message=f"{sub_path.name} 未识别到新名称") - ret: schemas.Response = rename_aliyun(fileid=sub_file.fileid, - path=path, - new_name=Path(new_path).name, - recursive=False) - if not ret.success: - return schemas.Response(success=False, message=f"{sub_path.name} 重命名失败!") - return schemas.Response(success=True) - return schemas.Response(success=False) - - -@router.get("/aliyun/image", summary="读取图片(阿里云盘)", response_model=schemas.Response) -def image_aliyun(fileid: str, _: schemas.TokenPayload = Depends(verify_uri_token)) -> Any: - """ - 读取图片 - """ - if not fileid: - return schemas.Response(success=False) - url = AliyunHelper().get_download_url(fileid) - if url: - # 重定向 - return Response(status_code=302, headers={"Location": url}) - return schemas.Response(success=False)