auth.py 1.2 KB

123456789101112131415161718192021222324252627282930
  1. from fastapi import HTTPException, Query, Depends
  2. from fastapi.security import OAuth2PasswordBearer
  3. from typing import Optional, Annotated
  4. import jwt
  5. from ..routers.users import SECRET_KEY, ALGORITHM
  6. from ..db.redis_client import get_app_user
  7. oauth2_scheme_optional = OAuth2PasswordBearer(tokenUrl="/users/token", auto_error=False)
  8. async def resolve_username(
  9. jwt_token: Annotated[Optional[str], Depends(oauth2_scheme_optional)] = None,
  10. source: Optional[str] = Query(default=None),
  11. token: Optional[str] = Query(default=None),
  12. ) -> str:
  13. if source == "app" and token:
  14. app_user = get_app_user(token)
  15. if not app_user:
  16. raise HTTPException(status_code=401, detail="无效的 App token")
  17. return f"app_{app_user['userId']}"
  18. if not jwt_token:
  19. raise HTTPException(status_code=401, detail="未提供认证令牌")
  20. try:
  21. payload = jwt.decode(jwt_token, SECRET_KEY, algorithms=[ALGORITHM])
  22. sub = payload.get("sub")
  23. if not sub:
  24. raise HTTPException(status_code=401, detail="无效的令牌")
  25. return sub
  26. except jwt.PyJWTError:
  27. raise HTTPException(status_code=401, detail="无效的令牌")