From f2c43713b16e821f4a1ae97804c60f18734d5f6a Mon Sep 17 00:00:00 2001
From: zhaoqingang <zhaoqg0118@163.com>
Date: 星期五, 13 十二月 2024 17:25:12 +0800
Subject: [PATCH] 问题优化

---
 app/api/user.py |   33 ++++++++++++++++++++++++++++-----
 1 files changed, 28 insertions(+), 5 deletions(-)

diff --git a/app/api/user.py b/app/api/user.py
index 506c1b4..78666b4 100644
--- a/app/api/user.py
+++ b/app/api/user.py
@@ -1,12 +1,12 @@
 from fastapi import APIRouter, Depends
 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 import PageParameter, UserStatus, UserInfo, LoginData, UserPassword
 from app.models.user_model import UserModel
-from app.service.auth import is_valid_password
+from app.service.auth import is_valid_password, verify_password
 from app.service.user import get_user_list, edit_user_status, delete_user_data, create_user, edit_user_data, \
-    edit_user_pwd, get_user_info, get_user_routers, get_user_menus, get_user_permission, get_user_dept
+    edit_user_pwd, get_user_info, get_user_routers, get_user_menus, get_user_permission, get_user_dept, change_user_pwd, \
+    user_data_service
 
 user_router = APIRouter()
 
@@ -86,6 +86,21 @@
     return Response(code=200, msg="user pwd reset successfully", data={})
 
 
+@user_router.put("/change_password", response_model=Response)
+async def change_user_password(user: UserPassword,  current_user: UserModel = Depends(get_current_user),db=Depends(get_db)):
+    user_info = db.query(UserModel).filter(UserModel.id==current_user.id).first()
+    if not user_info:
+        return Response(code=401, msg="Incorrect change password !")
+    if not verify_password(user.oldPassword, user_info.hashed_password):
+        return Response(code=400, msg="Incorrect password !")
+    if not is_valid_password(user.newPassword):
+        return Response(code=400, msg="The password must be at least 8 and contain both numbers and letters")
+    is_edit = await change_user_pwd(db, user_info.id, user.newPassword)
+    if not is_edit:
+        return Response(code=500, msg="user pwd change failure", data={})
+    return Response(code=200, msg="user pwd change success", 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)
@@ -119,4 +134,12 @@
 @user_router.get("/dept", response_model=Response)
 async def user_dept_api(userId:int, current_user: UserModel = Depends(get_current_user),db=Depends(get_db)):
     menus = await get_user_dept(db, userId)
-    return Response(code=200, msg="successfully", data=menus)
\ No newline at end of file
+    return Response(code=200, msg="successfully", data=menus)
+
+
+@user_router.get("/user_data", response_model=Response)
+async def user_data_api(userId, current_user: UserModel = Depends(get_current_user),db=Depends(get_db)):
+    user_info = await user_data_service(db, userId)
+    if not user_info:
+        return Response(code=500, msg="user get failure", data={})
+    return Response(code=200, msg="successfully", data=user_info)
\ No newline at end of file

--
Gitblit v1.8.0