users.py 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. from fastapi import Response
  2. from fastapi import Depends, FastAPI, HTTPException, status
  3. from datetime import datetime, timedelta
  4. from typing import List, Union, Optional
  5. from fastapi import APIRouter
  6. from pydantic import BaseModel
  7. import time
  8. import uuid
  9. from apps.web.models.users import UserModel, UserUpdateForm, UserRoleUpdateForm, Users
  10. from apps.web.models.auths import Auths
  11. from utils.utils import get_current_user, get_password_hash
  12. from constants import ERROR_MESSAGES
  13. router = APIRouter()
  14. ############################
  15. # GetUsers
  16. ############################
  17. @router.get("/", response_model=List[UserModel])
  18. async def get_users(skip: int = 0, limit: int = 50, user=Depends(get_current_user)):
  19. if user.role != "admin":
  20. raise HTTPException(
  21. status_code=status.HTTP_403_FORBIDDEN,
  22. detail=ERROR_MESSAGES.ACCESS_PROHIBITED,
  23. )
  24. return Users.get_users(skip, limit)
  25. ############################
  26. # UpdateUserRole
  27. ############################
  28. @router.post("/update/role", response_model=Optional[UserModel])
  29. async def update_user_role(
  30. form_data: UserRoleUpdateForm, user=Depends(get_current_user)
  31. ):
  32. if user.role != "admin":
  33. raise HTTPException(
  34. status_code=status.HTTP_403_FORBIDDEN,
  35. detail=ERROR_MESSAGES.ACCESS_PROHIBITED,
  36. )
  37. if user.id != form_data.id:
  38. return Users.update_user_role_by_id(form_data.id, form_data.role)
  39. else:
  40. raise HTTPException(
  41. status_code=status.HTTP_403_FORBIDDEN,
  42. detail=ERROR_MESSAGES.ACTION_PROHIBITED,
  43. )
  44. ############################
  45. # UpdateUserById
  46. ############################
  47. @router.post("/{user_id}/update", response_model=Optional[UserModel])
  48. async def update_user_by_id(
  49. user_id: str, form_data: UserUpdateForm, session_user=Depends(get_current_user)
  50. ):
  51. if session_user.role != "admin":
  52. raise HTTPException(
  53. status_code=status.HTTP_403_FORBIDDEN,
  54. detail=ERROR_MESSAGES.ACCESS_PROHIBITED,
  55. )
  56. user = Users.get_user_by_id(user_id)
  57. if user:
  58. if form_data.email.lower() != user.email:
  59. email_user = Users.get_user_by_email(form_data.email.lower())
  60. if email_user:
  61. raise HTTPException(
  62. status_code=status.HTTP_400_BAD_REQUEST,
  63. detail=ERROR_MESSAGES.EMAIL_TAKEN,
  64. )
  65. if form_data.password:
  66. hashed = get_password_hash(form_data.password)
  67. print(hashed)
  68. Auths.update_user_password_by_id(user_id, hashed)
  69. Auths.update_email_by_id(user_id, form_data.email.lower())
  70. updated_user = Users.update_user_by_id(
  71. user_id,
  72. {
  73. "name": form_data.name,
  74. "email": form_data.email.lower(),
  75. "profile_image_url": form_data.profile_image_url,
  76. },
  77. )
  78. if updated_user:
  79. return updated_user
  80. else:
  81. raise HTTPException(
  82. status_code=status.HTTP_400_BAD_REQUEST,
  83. detail=ERROR_MESSAGES.DEFAULT(),
  84. )
  85. else:
  86. raise HTTPException(
  87. status_code=status.HTTP_400_BAD_REQUEST,
  88. detail=ERROR_MESSAGES.USER_NOT_FOUND,
  89. )
  90. ############################
  91. # DeleteUserById
  92. ############################
  93. @router.delete("/{user_id}", response_model=bool)
  94. async def delete_user_by_id(user_id: str, user=Depends(get_current_user)):
  95. if user.role == "admin":
  96. if user.id != user_id:
  97. result = Auths.delete_auth_by_id(user_id)
  98. if result:
  99. return True
  100. else:
  101. raise HTTPException(
  102. status_code=status.HTTP_500_INTERNAL_SERVER_ERROR,
  103. detail=ERROR_MESSAGES.DELETE_USER_ERROR,
  104. )
  105. else:
  106. raise HTTPException(
  107. status_code=status.HTTP_403_FORBIDDEN,
  108. detail=ERROR_MESSAGES.ACTION_PROHIBITED,
  109. )
  110. else:
  111. raise HTTPException(
  112. status_code=status.HTTP_403_FORBIDDEN,
  113. detail=ERROR_MESSAGES.ACCESS_PROHIBITED,
  114. )