daily/Router/UserRouter.py

104 lines
5.0 KiB
Python
Raw Normal View History

2023-02-28 13:52:51 +08:00
from fastapi import APIRouter, Depends, HTTPException
from sqlalchemy.orm import Session
2023-03-01 16:04:43 +08:00
from Models.DepartmentModel import Department
from Models.PostModel import Post
2023-02-28 13:52:51 +08:00
from Schemas import UserSchemas
2023-03-01 16:04:43 +08:00
from Crud import UserCrud, AuthCrud
2023-02-28 13:52:51 +08:00
from Schemas.UserSchemas import TokenData
2023-03-06 09:45:17 +08:00
from Utils.AuthUtils import token_data_depend, create_token, registered_depend
2023-03-01 16:04:43 +08:00
from Utils.CrudUtils import auto_create_crud
2023-02-28 13:52:51 +08:00
from Utils.SqlAlchemyUtils import get_db
from Utils.VerifyCodeUtils import EmailVerifyCode, EmailVerifyType
2023-03-01 16:04:43 +08:00
from Utils.wxAppUtils import code2Session
2023-02-28 13:52:51 +08:00
router = APIRouter(
2023-03-02 15:19:14 +08:00
prefix="/api/daily/user"
2023-02-28 13:52:51 +08:00
)
# 授权登录后调用的接口,
2023-03-03 10:01:21 +08:00
@router.post('/login_to_app', summary="应用登录", tags=["用户接口"], response_model=UserSchemas.LoginToAppRes)
2023-02-28 13:52:51 +08:00
def login_to_app(req: UserSchemas.LoginToAppReq, db: Session = Depends(get_db)):
2023-03-01 16:04:43 +08:00
openid = code2Session(req.code).openid
if not openid:
raise HTTPException(detail="code无效", status_code=303)
2023-03-06 14:48:41 +08:00
# auth_data = AuthCrud.get_user_auth(db, openid)
# user_data = user.to_dict()
# user_data["auth_data"] = auth_data
# token_data = TokenData(**user_data)
# token = create_token(token_data.dict())
# return UserSchemas.LoginToAppRes(**user.to_dict(), token=token)
return UserSchemas.LoginToAppRes(openid=openid)
2023-02-28 13:52:51 +08:00
2023-03-03 10:01:21 +08:00
@router.post('/get_user_info', summary='获取用户信息', tags=["用户接口"], response_model=UserSchemas.GetUserInfoRes)
2023-03-06 09:45:17 +08:00
def get_user_info(token_data: TokenData = Depends(registered_depend), db: Session = Depends(get_db)):
2023-03-06 14:48:41 +08:00
user_data = UserCrud.get_full_user_info(db, token_data.openid)
if not user_data:
raise HTTPException(detail="用户未注册", status_code=403)
if not user_data['email']:
raise HTTPException(detail="用户未绑定邮箱", status_code=403)
user_data['post_list'] = [UserSchemas.PostInfo(**item) for item in user_data['post_list']]
user_data['department_list'] = [UserSchemas.DepartmentInfo(**item) for item in user_data['department_list']]
return UserSchemas.GetUserInfoRes(**user_data)
2023-02-28 13:52:51 +08:00
# 修改用户的邮箱、姓名、部门信息,需要进行邮箱验证码验证
2023-03-03 10:01:21 +08:00
@router.post('/change_user_info_and_email', tags=["用户接口"], summary='修改用户信息及email')
2023-03-01 16:04:43 +08:00
def change_user_info_and_email(req: UserSchemas.ChangeUserInfoReq, token_data: TokenData = Depends(token_data_depend),
db: Session = Depends(get_db)):
checked = EmailVerifyCode.check_code(req.email, req.email_code, EmailVerifyType.change)
if not checked:
raise HTTPException(detail="邮箱验证码错误", status_code=303)
if token_data.openid != req.openid:
raise HTTPException(detail="无权限的操作", status_code=303)
user = UserCrud.change_user_info(db, token_data.openid, UserSchemas.UserInfoChange(**req.dict(), registered=True))
auth_data = AuthCrud.get_user_auth(db, token_data.openid)
2023-03-02 15:19:14 +08:00
user_data = user.to_dict()
user_data["auth_data"] = auth_data
new_token_data = TokenData(**user_data)
2023-03-06 09:45:17 +08:00
token = create_token(new_token_data.dict())
2023-03-01 16:04:43 +08:00
return {'msg': "修改成功", 'state': 1, 'data': {'token': token}}
2023-03-03 10:01:21 +08:00
@router.post('/change_user_info', tags=["用户接口"], summary='修改用户信息')
2023-02-28 13:52:51 +08:00
def change_user_info(req: UserSchemas.ChangeUserInfoReq, token_data: TokenData = Depends(token_data_depend),
db: Session = Depends(get_db)):
2023-03-01 16:04:43 +08:00
if token_data.openid != req.openid:
raise HTTPException(detail="无权限的操作", status_code=303)
UserCrud.change_user_info(db, token_data.openid, UserSchemas.UserInfoChange(**req.dict()))
return {'msg': "修改成功", 'state': 1}
2023-03-03 10:01:21 +08:00
@router.post('/bind_email', tags=["用户接口"], summary='绑定email')
2023-03-06 14:48:41 +08:00
def bind_email(req: UserSchemas.BindEmailReq,
2023-03-01 16:04:43 +08:00
db: Session = Depends(get_db)):
2023-02-28 13:52:51 +08:00
checked = EmailVerifyCode.check_code(req.email, req.email_code, EmailVerifyType.change)
if not checked:
raise HTTPException(detail="邮箱验证码错误", status_code=303)
2023-03-06 14:48:41 +08:00
user = UserCrud.get_user_info(db, req.openid)
if not user:
user = UserCrud.create_user(db, req.openid)
if not user.registered:
UserCrud.update_user_info_from_email(db, req.openid, req.email)
auth_data = AuthCrud.get_user_auth(db, req.openid)
2023-03-02 16:24:35 +08:00
user_data = user.to_dict()
user_data["auth_data"] = auth_data
token_data = TokenData(**user_data)
token = create_token(token_data)
2023-03-06 14:48:41 +08:00
return {'msg': "成功", 'state': 1, 'data': {'token': token}}
2023-02-28 13:52:51 +08:00
2023-03-03 10:01:21 +08:00
@router.post("/get_email_verify_code", tags=["用户接口"], summary="获取邮箱验证码")
2023-02-28 13:52:51 +08:00
def get_email_verify_code(body: UserSchemas.EmailSendReqBody):
email = body.email
EmailVerifyCode.send_change_code(email)
return {"msg": "验证码已发送至邮箱,请查看", "state": 1}
2023-03-03 10:01:21 +08:00
department_crud = auto_create_crud(Department, 'department', "部门", auto_create_keys=['id'], tags=["部门职务操作"])
post_crud = auto_create_crud(Post, 'post', "职务", auto_create_keys=['id'], tags=["部门职务操作"])
department_crud.mount(router)
post_crud.mount(router)