daily/Router/UserRouter.py

175 lines
8.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
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
2023-03-17 16:29:13 +08:00
from Utils.VerifyCodeUtils import EmailVerifyCode, EmailVerifyType, PhoneVerifyCode, PhoneVerifyType
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-07 12:03:06 +08:00
user_data = UserCrud.get_full_user_info(db, token_data.email)
2023-03-06 14:48:41 +08:00
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']]
2023-03-07 10:13:13 +08:00
user_data["auth_data"] = token_data.auth_data
2023-03-06 14:48:41 +08:00
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)
2023-03-07 12:03:06 +08:00
if token_data.email != req.email:
2023-03-01 16:04:43 +08:00
raise HTTPException(detail="无权限的操作", status_code=303)
2023-03-07 12:03:06 +08:00
user = UserCrud.change_user_info(db, token_data.email, UserSchemas.UserInfoChange(**req.dict(), registered=True))
auth_data = AuthCrud.get_user_auth(db, token_data.email)
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-07 12:03:06 +08:00
if token_data.email != req.email:
2023-03-01 16:04:43 +08:00
raise HTTPException(detail="无权限的操作", status_code=303)
2023-03-07 12:03:06 +08:00
UserCrud.change_user_info(db, token_data.email, UserSchemas.UserInfoChange(**req.dict()))
2023-03-01 16:04:43 +08:00
return {'msg': "修改成功", 'state': 1}
2023-03-07 12:03:06 +08:00
@router.post('/bind_email', tags=["用户接口"], summary='邮箱登录')
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-03-17 16:29:13 +08:00
email = req.email.replace(" ", "")
2023-03-17 15:30:40 +08:00
checked = EmailVerifyCode.check_code(email, req.email_code, EmailVerifyType.change)
2023-02-28 13:52:51 +08:00
if not checked:
raise HTTPException(detail="邮箱验证码错误", status_code=303)
2023-03-17 15:30:40 +08:00
user = UserCrud.get_user_info(db, email)
2023-03-07 12:03:06 +08:00
# if user:
# # 邮箱已绑定
# if user.email and user.email != req.email:
# raise HTTPException(detail="该微信已绑定邮箱,请使用该微信号绑定的邮箱登录", status_code=403)
2023-03-06 14:48:41 +08:00
if not user:
2023-03-17 15:30:40 +08:00
user = UserCrud.create_user(db, email)
2023-03-06 14:48:41 +08:00
if not user.registered:
2023-03-17 15:30:40 +08:00
UserCrud.update_user_info_from_email(db, email)
auth_data = AuthCrud.get_user_auth(db, email)
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-17 16:29:13 +08:00
@router.post("/get_phone_verify_code", tags=["用户接口"], summary="获取短信验证码")
def get_phone_verify_code(body: UserSchemas.GetPhoneVerifyCodeReq, db=Depends(get_db)):
phone = body.phone
user = UserCrud.get_user_info_by_phone(db, phone)
if not user:
raise HTTPException(detail="手机号未录入系统", status_code=303)
try:
PhoneVerifyCode.send_code(phone, PhoneVerifyType.login)
except Exception as e:
print(e)
raise HTTPException(detail="验证码发送失败", status_code=403)
return {"msg": "验证码已发送至手机,请查看", "state": 1}
@router.post('/login_by_phone', tags=["用户接口"], summary='手机号登录')
def login_by_phone(req: UserSchemas.LoginByPhoneReq,
db: Session = Depends(get_db)):
phone = req.phone.replace(" ", "")
checked = PhoneVerifyCode.check_code(phone, req.code, PhoneVerifyType.login)
if not checked:
raise HTTPException(detail="验证码错误", status_code=303)
user = UserCrud.get_user_info_by_phone(db, phone)
if not user:
raise HTTPException(detail="手机号未录入系统", status_code=303)
auth_data = AuthCrud.get_user_auth(db, user.email)
user_data = user.to_dict()
user_data["auth_data"] = auth_data
token_data = TokenData(**user_data).dict()
token = create_token(token_data)
return {'msg': "成功", 'state': 1, 'data': {'token': token}}
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):
2023-03-09 16:33:39 +08:00
print(body)
2023-03-07 10:13:13 +08:00
try:
email = body.email
EmailVerifyCode.send_change_code(email)
except Exception as e:
print(e)
raise HTTPException(detail="邮箱验证码发送失败", status_code=403)
2023-02-28 13:52:51 +08:00
return {"msg": "验证码已发送至邮箱,请查看", "state": 1}
2023-03-03 10:01:21 +08:00
2023-03-07 12:03:06 +08:00
@router.post("/refresh_token", tags=["用户接口"], summary="重新获取token")
def refresh_token(token_data: TokenData = Depends(token_data_depend), db: Session = Depends(get_db)):
auth_data = AuthCrud.get_user_auth(db, token_data.email)
user = UserCrud.get_user_info(db, token_data.email)
user_data = user.to_dict()
user_data["auth_data"] = auth_data
token_data = TokenData(**user_data)
token = create_token(token_data)
return {'token': token}
@router.post("/get_user_by_department", tags=["用户接口"], summary=["根据部门列表获取用户信息"],
response_model=UserSchemas.GetUserByDepartmentRes)
def get_user_by_department(body: UserSchemas.GetUserByDepartmentReq, token_data: TokenData = Depends(token_data_depend),
db: Session = Depends(get_db)):
users = UserCrud.get_user_by_departments(db, body.departments)
return UserSchemas.GetUserByDepartmentRes(users=[UserSchemas.UserInfo(**user) for user in users])
@router.post("/get_user_by_department_type", tags=["用户接口"], summary=["根据部门类型获取用户信息"],
response_model=UserSchemas.GetUserByDepartmentTypeRes)
def get_user_by_department_type(body: UserSchemas.GetUserByDepartmentTypeReq,
token_data: TokenData = Depends(token_data_depend),
db: Session = Depends(get_db)):
users = UserCrud.get_user_by_department_type(db, body.department_type)
return UserSchemas.GetUserByDepartmentTypeRes(users=[UserSchemas.UserFullInfo(**user) for user in users])
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)