Taskflow / src /utils /deps.py
NirmaQureshi's picture
code
e650b33
from typing import Generator
from fastapi import Depends, HTTPException, status, Request
from sqlalchemy.orm import Session
from uuid import UUID
from src.database import get_db_session
from src.models.user import User
from src.utils.security import verify_token
def get_db() -> Generator[Session, None, None]:
db = next(get_db_session())
try:
yield db
finally:
db.close()
def get_current_user(
request: Request,
db: Session = Depends(get_db)
) -> User:
"""
Get the currently authenticated user.
Supports BOTH:
- HTTP-only cookies (preferred)
- Authorization: Bearer header (fallback)
"""
token = None
# 1️⃣ Try cookie first
token = request.cookies.get("access_token")
# 2️⃣ Fallback to Authorization header
if not token:
auth_header = request.headers.get("Authorization")
if auth_header and auth_header.startswith("Bearer "):
token = auth_header.split(" ")[1]
if not token:
raise HTTPException(
status_code=status.HTTP_401_UNAUTHORIZED,
detail="Not authenticated",
)
payload = verify_token(token)
if not payload or "sub" not in payload:
raise HTTPException(
status_code=status.HTTP_401_UNAUTHORIZED,
detail="Invalid or expired token",
)
user_id = payload["sub"]
user = db.query(User).filter(User.id == UUID(user_id)).first()
if not user:
raise HTTPException(
status_code=status.HTTP_401_UNAUTHORIZED,
detail="User not found",
)
return user