From 1a81be210ac81f506aa7ef0c0a8cb1cdb8f83106 Mon Sep 17 00:00:00 2001 From: luxferre Date: Fri, 29 May 2026 14:15:50 +0100 Subject: [PATCH] fix: use dependency instead of db.next --- src/auth/service.py | 5 +++-- src/user/service.py | 12 +++++++----- 2 files changed, 10 insertions(+), 7 deletions(-) diff --git a/src/auth/service.py b/src/auth/service.py index 0417952..f156a9d 100644 --- a/src/auth/service.py +++ b/src/auth/service.py @@ -19,6 +19,7 @@ from fastapi.security import OpenIdConnect from src.auth.exceptions import UnauthorizedException from src.auth.config import auth_settings from src.user.service import add_user_to_db +from src.database import db_dependency oidc = OpenIdConnect(openIdConnectUrl=auth_settings.OIDC_CONFIG) @@ -28,7 +29,7 @@ def get_dev_user(): return {"db_id": 1} -async def get_current_user(oidc_auth_string: oidc_dependency) -> dict[str, Any]: +async def get_current_user(oidc_auth_string: oidc_dependency, db: db_dependency) -> dict[str, Any]: config_url = urlopen(auth_settings.OIDC_CONFIG) config = json.loads(config_url.read()) jwks_uri = config["jwks_uri"] @@ -51,7 +52,7 @@ async def get_current_user(oidc_auth_string: oidc_dependency) -> dict[str, Any]: claims_requests.validate(token.claims) except ExpiredTokenError: raise UnauthorizedException(message="Token is expired") - db_id = await add_user_to_db(token.claims) + db_id = await add_user_to_db(db, token.claims) token.claims["db_id"] = db_id diff --git a/src/user/service.py b/src/user/service.py index 3d42574..e072251 100644 --- a/src/user/service.py +++ b/src/user/service.py @@ -6,29 +6,31 @@ Exports: """ from typing import Any -from src.database import get_db +from sqlalchemy.orm import Session + from src.exceptions import UnprocessableContentException from src.user.schemas import OIDCUser from src.user.models import User -async def add_user_to_db(user_claims: dict[str, Any]) -> int: +async def add_user_to_db(db: Session, user_claims: dict[str, Any]) -> int: try: valid_user = OIDCUser(first_name=user_claims["given_name"], last_name=user_claims["family_name"], email=user_claims["email"], oidc_id=user_claims["sub"]) except Exception as e: print(e) raise UnprocessableContentException("Invalid or missing OIDC data") - db = next(get_db()) db_user = db.query(User).filter(User.oidc_id == valid_user.oidc_id).first() if not db_user: user_model = User(**valid_user.model_dump()) db.add(user_model) + user_id = user_model.id db.commit() - return user_model.id + return user_id else: + user_id = db_user.id change = False if db_user.first_name != valid_user.first_name: db_user.first_name = valid_user.first_name @@ -39,4 +41,4 @@ async def add_user_to_db(user_claims: dict[str, Any]) -> int: if change: db.add(db_user) db.commit() - return db_user.id + return user_id