From 08c8e8c9a4d65677de6a493446a605d70efee631 Mon Sep 17 00:00:00 2001 From: zhaoqingang <zhaoqg0118@163.com> Date: 星期二, 10 十二月 2024 16:32:07 +0800 Subject: [PATCH] 12.10 16 --- app/api/user.py | 49 +++++++++++++++++++++++++++++++++++++------------ 1 files changed, 37 insertions(+), 12 deletions(-) diff --git a/app/api/user.py b/app/api/user.py index 4390296..b5bd520 100644 --- a/app/api/user.py +++ b/app/api/user.py @@ -1,17 +1,20 @@ from fastapi import APIRouter, Depends -from app.api import Response, pwd_context, get_current_user +from app.api import Response, pwd_context, get_current_user, ResponseList +from app.models.public_api_model import AppRegisterModel from app.models.base_model import get_db from app.models.user import PageParameter, UserStatus, UserInfo, LoginData from app.models.user_model import UserModel from app.service.user import get_user_list, edit_user_status, delete_user_data, create_user, edit_user_data, \ - edit_user_pwd + edit_user_pwd, get_user_info, get_user_routers, get_user_menus user_router = APIRouter() @user_router.get("/list", response_model=Response) -async def user_list(paras: PageParameter,current_user: UserModel = Depends(get_current_user), db=Depends(get_db)): - return Response(code=200, msg="", data=await get_user_list(db, paras.page_size, paras.page_index, paras.keyword)) +async def user_list(current:int, pageSize:int, keyword="", current_user: UserModel = Depends(get_current_user), + db=Depends(get_db)): + return Response(code=200, msg="", data=await get_user_list(db, current, pageSize, keyword, + current_user.permission, current_user.id)) @user_router.post("/add_user", response_model=Response) @@ -24,7 +27,8 @@ pwd = user.pwd if not pwd: pwd = "000000" - is_create = await create_user(db, user.userName, user.email, user.phone, user.loginName, pwd, user.roles, user.groups) + is_create = await create_user(db, user.userName, user.email, user.phone, user.loginName, pwd, user.roles, + user.groups, current_user.id) if not is_create: return Response(code=500, msg="user create failure", data={}) return Response(code=200, msg="user create successfully", data={}) @@ -53,7 +57,7 @@ db_user = db.query(UserModel).filter(UserModel.id == user.userId).first() if not db_user: return Response(code=200, msg="user does not exist") - is_edit = await edit_user_status(db, user.status,user.userId) + is_edit = await edit_user_status(db, user.status, user.userId) if not is_edit: return Response(code=500, msg="user status edit failure", data={}) return Response(code=200, msg="user status edit successfully", data={}) @@ -71,11 +75,32 @@ @user_router.put("/reset_pwd", response_model=Response) -async def reset_user_pwd(user: UserStatus, current_user: UserModel = Depends(get_current_user), db=Depends(get_db)): - db_user = db.query(UserModel).filter(UserModel.id == user.userId).first() - if not db_user: - return Response(code=200, msg="user does not exist") - is_edit = await edit_user_pwd(db, user.userId) +async def reset_user_pwd(user: UserStatus, current_user: UserModel = Depends(get_current_user),db=Depends(get_db)): + is_edit = await edit_user_pwd(db, user.userId, current_user.id) if not is_edit: return Response(code=500, msg="user pwd reset failure", data={}) - return Response(code=200, msg="user pwd reset successfully", data={}) \ No newline at end of file + return Response(code=200, msg="user pwd reset successfully", data={}) + + +@user_router.get("/user_info", response_model=Response) +async def user_info(current_user: UserModel = Depends(get_current_user),db=Depends(get_db)): + user_info = await get_user_info(db, current_user.id) + if not user_info: + return Response(code=500, msg="user get failure", data={}) + return Response(code=200, msg="successfully", data=user_info) + + +@user_router.get("/user_routers", response_model=Response) +async def user_routers(current_user: UserModel = Depends(get_current_user),db=Depends(get_db)): + routers = await get_user_routers(db, current_user.id) + if not routers: + return Response(code=500, msg="user get failure", data={}) + return Response(code=200, msg="successfully", data=routers) + + +@user_router.get("/menus", response_model=ResponseList) +async def user_menus(current_user: UserModel = Depends(get_current_user),db=Depends(get_db)): + menus = await get_user_menus(db, current_user.id) + # return Response(code=200, msg="successfully", data=menus) + # result = [item.to_dict() for item in agents] + return ResponseList(code=200, msg="successfully", data=menus) \ No newline at end of file -- Gitblit v1.8.0