daily/Router/UserRouter.py

93 lines
4.4 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
from Utils.AuthUtils import token_data_depend, create_token
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
from Crud.AuthCrud import get_user_auth
2023-02-28 13:52:51 +08:00
router = APIRouter(
tags=["用户接口"],
2023-03-02 15:19:14 +08:00
prefix="/api/daily/user"
2023-02-28 13:52:51 +08:00
)
2023-03-01 16:04:43 +08:00
department_crud = auto_create_crud(Department, 'department', "部门", auto_create_keys=['id'])
post_crud = auto_create_crud(Post, 'post', "职务", auto_create_keys=['id'])
department_crud.mount(router)
post_crud.mount(router)
2023-02-28 13:52:51 +08:00
# 授权登录后调用的接口,
2023-03-01 16:04:43 +08:00
@router.post('/login_to_app', summary="应用登录", 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)
user = UserCrud.get_user_info(db, openid)
2023-02-28 13:52:51 +08:00
if not user:
2023-03-01 16:04:43 +08:00
user = UserCrud.create_user(db, openid)
auth_data = AuthCrud.get_user_auth(db, openid)
2023-03-02 15:19:14 +08:00
user_data = user.to_dict()
user_data["auth_data"] = auth_data
token_data = TokenData(**user_data)
2023-03-01 16:04:43 +08:00
token = create_token(token_data.dict())
2023-02-28 13:52:51 +08:00
return UserSchemas.LoginToAppRes(**user.to_dict(), token=token)
2023-03-01 16:04:43 +08:00
@router.post('/get_user_info', summary='获取用户信息', response_model=UserSchemas.GetUserInfoRes)
2023-02-28 13:52:51 +08:00
def get_user_info(token_data: TokenData = Depends(token_data_depend), db: Session = Depends(get_db)):
user = UserCrud.get_user_info(db, token_data.openid)
return UserSchemas.GetUserInfoRes(**user.to_dict())
# 修改用户的邮箱、姓名、部门信息,需要进行邮箱验证码验证
2023-03-01 16:04:43 +08:00
@router.post('/change_user_info_and_email', summary='修改用户信息及email')
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-01 16:04:43 +08:00
token = create_token(new_token_data.dict(), auth_data=auth_data)
return {'msg': "修改成功", 'state': 1, 'data': {'token': token}}
@router.post('/change_user_info', 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}
@router.post('/bind_email', summary='绑定email')
def bind_email(req: UserSchemas.BindEmailReq, token_data: TokenData = Depends(token_data_depend),
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-02 09:27:05 +08:00
UserCrud.update_user_info_from_email(db, token_data.openid, req.email)
2023-03-01 16:04:43 +08:00
auth_data = AuthCrud.get_user_auth(db, token_data.openid)
token = create_token({'openid': token_data.openid, 'registered': True, 'auth_data': auth_data})
2023-02-28 13:52:51 +08:00
return {'msg': "修改成功", 'state': 1, 'data': {'token': token}}
@router.post("/get_email_verify_code", summary="获取邮箱验证码")
def get_email_verify_code(body: UserSchemas.EmailSendReqBody):
email = body.email
EmailVerifyCode.send_change_code(email)
return {"msg": "验证码已发送至邮箱,请查看", "state": 1}