mirror of
https://github.com/rzmk/learnhouse.git
synced 2025-12-19 04:19:25 +00:00
feat: auth exceptions + roles with user object
This commit is contained in:
parent
23c4224b2b
commit
143f21b70b
11 changed files with 74 additions and 68 deletions
|
|
@ -24,6 +24,13 @@ async def api_get_current_user(current_user: User = Depends(get_current_user)):
|
|||
"""
|
||||
return current_user.dict()
|
||||
|
||||
@router.get("/profile_metadata")
|
||||
async def api_get_current_user(current_user: User = Depends(get_current_user)):
|
||||
"""
|
||||
Get current user
|
||||
"""
|
||||
return await get_profile_metadata(current_user.dict())
|
||||
|
||||
|
||||
@router.get("/username/{username}")
|
||||
async def api_get_user_by_username(username: str):
|
||||
|
|
|
|||
|
|
@ -35,6 +35,18 @@ class UserInDB(UserWithPassword):
|
|||
creationDate: str
|
||||
updateDate: str
|
||||
|
||||
|
||||
class UserProfileMetadata(BaseModel):
|
||||
user_object: PublicUser
|
||||
roles = list
|
||||
|
||||
# TODO : terrible, export role classes from one single source of truth
|
||||
class Role(BaseModel):
|
||||
name: str
|
||||
description: str
|
||||
permissions: object
|
||||
elements: object
|
||||
|
||||
#### Classes ####################################################
|
||||
|
||||
# TODO : user actions security
|
||||
|
|
@ -55,6 +67,31 @@ async def get_user(username: str):
|
|||
return user
|
||||
|
||||
|
||||
async def get_profile_metadata(user):
|
||||
await check_database()
|
||||
users = learnhouseDB["users"]
|
||||
roles = learnhouseDB["roles"]
|
||||
|
||||
user = users.find_one({"user_id": user['user_id']})
|
||||
|
||||
if not user:
|
||||
raise HTTPException(
|
||||
status_code=status.HTTP_409_CONFLICT, detail="User does not exist")
|
||||
|
||||
# get roles
|
||||
user_roles = roles.find({"linked_users": user['user_id']})
|
||||
|
||||
user_roles_list = []
|
||||
for role in user_roles:
|
||||
print(role)
|
||||
user_roles_list.append(Role(**role))
|
||||
|
||||
return {
|
||||
"user_object": PublicUser(**user),
|
||||
"roles": user_roles_list
|
||||
}
|
||||
|
||||
|
||||
async def get_user_by_userid(user_id: str):
|
||||
await check_database()
|
||||
users = learnhouseDB["users"]
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue