feat: auth exceptions + roles with user object

This commit is contained in:
swve 2022-11-19 20:19:56 +01:00
parent 23c4224b2b
commit 143f21b70b
11 changed files with 74 additions and 68 deletions

View file

@ -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):

View file

@ -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"]