Spaces:
Runtime error
Runtime error
File size: 1,474 Bytes
4986f6d 2c11b57 4986f6d 11213cb 4986f6d 2c11b57 0b4f36d aa881d5 2c11b57 55b3449 11213cb 55b3449 11213cb 55b3449 11213cb 4986f6d |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
from fastapi import Depends, HTTPException, status
from fastapi.security import HTTPAuthorizationCredentials, HTTPBearer
from firebase_admin.auth import (
ExpiredIdTokenError,
InvalidIdTokenError,
verify_id_token,
)
from . import db, logger
security = HTTPBearer()
def get_current_user(
credentials: HTTPAuthorizationCredentials = Depends(security),
):
try:
payload = verify_id_token(credentials.credentials)
user_doc_ref = db.collection("user").document(payload["sub"]).get()
if not user_doc_ref.exists:
raise HTTPException(
status_code=status.HTTP_403_FORBIDDEN, detail="User profile not exist"
)
except ExpiredIdTokenError as e:
logger.warning(e)
raise HTTPException(
status_code=status.HTTP_401_UNAUTHORIZED,
detail="Token expired",
headers={"WWW-Authenticate": "Bearer"},
)
except InvalidIdTokenError as e:
logger.warning(e)
raise HTTPException(
status_code=status.HTTP_401_UNAUTHORIZED,
detail="Invalid token",
headers={"WWW-Authenticate": "Bearer"},
)
except ValueError as e:
logger.warning(e)
raise HTTPException(
status_code=status.HTTP_401_UNAUTHORIZED,
detail="Invalid token",
headers={"WWW-Authenticate": "Bearer"},
)
return payload
|