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 |   36 +++++++++++++++++++++++++++++-------
 1 files changed, 29 insertions(+), 7 deletions(-)

diff --git a/app/api/user.py b/app/api/user.py
index 850d815..b5bd520 100644
--- a/app/api/user.py
+++ b/app/api/user.py
@@ -1,10 +1,11 @@
 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()
 
@@ -74,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={})
+
+
+@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