users.py 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. from fastapi import Response, Request
  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. import logging
  10. from apps.webui.models.users import (
  11. UserModel,
  12. UserUpdateForm,
  13. UserRoleUpdateForm,
  14. UserSettings,
  15. Users,
  16. )
  17. from apps.webui.models.auths import Auths
  18. from apps.webui.models.chats import Chats
  19. from utils.utils import (
  20. get_verified_user,
  21. get_password_hash,
  22. get_current_user,
  23. get_admin_user,
  24. )
  25. from constants import ERROR_MESSAGES
  26. from config import SRC_LOG_LEVELS
  27. log = logging.getLogger(__name__)
  28. log.setLevel(SRC_LOG_LEVELS["MODELS"])
  29. router = APIRouter()
  30. ############################
  31. # GetUsers
  32. ############################
  33. @router.get("/", response_model=List[UserModel])
  34. async def get_users(
  35. skip: int = 0, limit: int = 50, user=Depends(get_admin_user)
  36. ):
  37. return Users.get_users(skip, limit)
  38. ############################
  39. # User Permissions
  40. ############################
  41. @router.get("/permissions/user")
  42. async def get_user_permissions(request: Request, user=Depends(get_admin_user)):
  43. return request.app.state.config.USER_PERMISSIONS
  44. @router.post("/permissions/user")
  45. async def update_user_permissions(
  46. request: Request, form_data: dict, user=Depends(get_admin_user)
  47. ):
  48. request.app.state.config.USER_PERMISSIONS = form_data
  49. return request.app.state.config.USER_PERMISSIONS
  50. ############################
  51. # UpdateUserRole
  52. ############################
  53. @router.post("/update/role", response_model=Optional[UserModel])
  54. async def update_user_role(
  55. form_data: UserRoleUpdateForm, user=Depends(get_admin_user)
  56. ):
  57. if user.id != form_data.id and form_data.id != Users.get_first_user().id:
  58. return Users.update_user_role_by_id(form_data.id, form_data.role)
  59. raise HTTPException(
  60. status_code=status.HTTP_403_FORBIDDEN,
  61. detail=ERROR_MESSAGES.ACTION_PROHIBITED,
  62. )
  63. ############################
  64. # GetUserSettingsBySessionUser
  65. ############################
  66. @router.get("/user/settings", response_model=Optional[UserSettings])
  67. async def get_user_settings_by_session_user(
  68. user=Depends(get_verified_user)
  69. ):
  70. user = Users.get_user_by_id(user.id)
  71. if user:
  72. return user.settings
  73. else:
  74. raise HTTPException(
  75. status_code=status.HTTP_400_BAD_REQUEST,
  76. detail=ERROR_MESSAGES.USER_NOT_FOUND,
  77. )
  78. ############################
  79. # UpdateUserSettingsBySessionUser
  80. ############################
  81. @router.post("/user/settings/update", response_model=UserSettings)
  82. async def update_user_settings_by_session_user(
  83. form_data: UserSettings, user=Depends(get_verified_user)
  84. ):
  85. user = Users.update_user_by_id(user.id, {"settings": form_data.model_dump()})
  86. if user:
  87. return user.settings
  88. else:
  89. raise HTTPException(
  90. status_code=status.HTTP_400_BAD_REQUEST,
  91. detail=ERROR_MESSAGES.USER_NOT_FOUND,
  92. )
  93. ############################
  94. # GetUserInfoBySessionUser
  95. ############################
  96. @router.get("/user/info", response_model=Optional[dict])
  97. async def get_user_info_by_session_user(
  98. user=Depends(get_verified_user)
  99. ):
  100. user = Users.get_user_by_id(user.id)
  101. if user:
  102. return user.info
  103. else:
  104. raise HTTPException(
  105. status_code=status.HTTP_400_BAD_REQUEST,
  106. detail=ERROR_MESSAGES.USER_NOT_FOUND,
  107. )
  108. ############################
  109. # UpdateUserInfoBySessionUser
  110. ############################
  111. @router.post("/user/info/update", response_model=Optional[dict])
  112. async def update_user_info_by_session_user(
  113. form_data: dict, user=Depends(get_verified_user)
  114. ):
  115. user = Users.get_user_by_id(user.id)
  116. if user:
  117. if user.info is None:
  118. user.info = {}
  119. user = Users.update_user_by_id(
  120. user.id, {"info": {**user.info, **form_data}}
  121. )
  122. if user:
  123. return user.info
  124. else:
  125. raise HTTPException(
  126. status_code=status.HTTP_400_BAD_REQUEST,
  127. detail=ERROR_MESSAGES.USER_NOT_FOUND,
  128. )
  129. else:
  130. raise HTTPException(
  131. status_code=status.HTTP_400_BAD_REQUEST,
  132. detail=ERROR_MESSAGES.USER_NOT_FOUND,
  133. )
  134. ############################
  135. # GetUserById
  136. ############################
  137. class UserResponse(BaseModel):
  138. name: str
  139. profile_image_url: str
  140. @router.get("/{user_id}", response_model=UserResponse)
  141. async def get_user_by_id(
  142. user_id: str, user=Depends(get_verified_user)
  143. ):
  144. # Check if user_id is a shared chat
  145. # If it is, get the user_id from the chat
  146. if user_id.startswith("shared-"):
  147. chat_id = user_id.replace("shared-", "")
  148. chat = Chats.get_chat_by_id(chat_id)
  149. if chat:
  150. user_id = chat.user_id
  151. else:
  152. raise HTTPException(
  153. status_code=status.HTTP_400_BAD_REQUEST,
  154. detail=ERROR_MESSAGES.USER_NOT_FOUND,
  155. )
  156. user = Users.get_user_by_id(user_id)
  157. if user:
  158. return UserResponse(name=user.name, profile_image_url=user.profile_image_url)
  159. else:
  160. raise HTTPException(
  161. status_code=status.HTTP_400_BAD_REQUEST,
  162. detail=ERROR_MESSAGES.USER_NOT_FOUND,
  163. )
  164. ############################
  165. # UpdateUserById
  166. ############################
  167. @router.post("/{user_id}/update", response_model=Optional[UserModel])
  168. async def update_user_by_id(
  169. user_id: str,
  170. form_data: UserUpdateForm,
  171. session_user=Depends(get_admin_user),
  172. ):
  173. user = Users.get_user_by_id(user_id)
  174. if user:
  175. if form_data.email.lower() != user.email:
  176. email_user = Users.get_user_by_email(form_data.email.lower())
  177. if email_user:
  178. raise HTTPException(
  179. status_code=status.HTTP_400_BAD_REQUEST,
  180. detail=ERROR_MESSAGES.EMAIL_TAKEN,
  181. )
  182. if form_data.password:
  183. hashed = get_password_hash(form_data.password)
  184. log.debug(f"hashed: {hashed}")
  185. Auths.update_user_password_by_id(user_id, hashed)
  186. Auths.update_email_by_id(user_id, form_data.email.lower())
  187. updated_user = Users.update_user_by_id(
  188. user_id,
  189. {
  190. "name": form_data.name,
  191. "email": form_data.email.lower(),
  192. "profile_image_url": form_data.profile_image_url,
  193. },
  194. )
  195. if updated_user:
  196. return updated_user
  197. raise HTTPException(
  198. status_code=status.HTTP_400_BAD_REQUEST,
  199. detail=ERROR_MESSAGES.DEFAULT(),
  200. )
  201. raise HTTPException(
  202. status_code=status.HTTP_400_BAD_REQUEST,
  203. detail=ERROR_MESSAGES.USER_NOT_FOUND,
  204. )
  205. ############################
  206. # DeleteUserById
  207. ############################
  208. @router.delete("/{user_id}", response_model=bool)
  209. async def delete_user_by_id(
  210. user_id: str, user=Depends(get_admin_user)
  211. ):
  212. if user.id != user_id:
  213. result = Auths.delete_auth_by_id(user_id)
  214. if result:
  215. return True
  216. raise HTTPException(
  217. status_code=status.HTTP_500_INTERNAL_SERVER_ERROR,
  218. detail=ERROR_MESSAGES.DELETE_USER_ERROR,
  219. )
  220. raise HTTPException(
  221. status_code=status.HTTP_403_FORBIDDEN,
  222. detail=ERROR_MESSAGES.ACTION_PROHIBITED,
  223. )