Problem mit der Keycloak-Middleware: Leerer „preferred_username“ im get_user-ObjektPython

Python-Programme
Anonymous
 Problem mit der Keycloak-Middleware: Leerer „preferred_username“ im get_user-Objekt

Post by Anonymous »

Problem mit der Keycloak-Middleware:

Leerer bevorzugter_Benutzername im get_user-Objekt

Ich verwende fastapi_keycloak_middleware, um meine FastAPI-App mit Keycloak zu sichern. Ich habe Probleme beim Zuordnen des „preferred_username“-Anspruchs vom JWT-Token zum FastApiUser-Objekt.
Obwohl in der Konfiguration explizit „preferred_username_claim="preferred_username" festgelegt wurde, ist das Attribut „user.preferred_username“ in meinem sicheren Endpunkt immer leer. Der Anspruch ist definitiv im Keycloak-Token vorhanden, und andere Ansprüche wie sub (zugeordnet zu user_id) funktionieren einwandfrei.
Wie kann ich den bevorzugten_Benutzernamen korrekt zuordnen, sodass er über user.preferred_username zugänglich ist?

Code: Select all

from fastapi import FastAPI
from fastapi_keycloak_middleware import KeycloakConfiguration, KeycloakMiddleware
from fastapi_keycloak_middleware import get_user
from fastapi import Depends

import logging

logging.basicConfig(level=logging.DEBUG)
logging.getLogger("fastapi_keycloak_middleware").setLevel(logging.DEBUG)
logging.getLogger("fastapi").setLevel(logging.DEBUG)

# 1. Keycloak Client Configuration
keycloak_config = KeycloakConfiguration(
url="http://keycloak:8080/",
realm="demo-realm",
client_id="fastapi-client",
client_secret="vSZr8BcWWO8TiN1IMxC12fYLgmAuZvlm",
authentication_scheme="Bearer",
# These claims MUST be present in the token (Check)
claims=["sub", "name", "email", "preferred_username", "given_name", "family_name"],
reject_on_missing_claim=True,
# 🔑 IMPORTANT: Explicit Mapping (The source of the issue?)
preferred_username_claim="preferred_username",  # Mapped claim
user_id_claim="sub",                            # This maps correctly
first_name_claim="given_name",
last_name_claim="family_name",
)

app = FastAPI()

# 2. Add Keycloak Middleware
app.add_middleware(
KeycloakMiddleware,
keycloak_configuration=keycloak_config
)

# Secure Endpoint
@app.get("/secure")
def secure(user=Depends(get_user)):
print("-----------------------------------------------------------------")
print("CONTENT OF THE 'user' OBJECT (FastApiUser):")

try:
# user.preferred_username is always empty/defaulted
user_id = getattr(user, "user_id", "Unknown ID")
username = getattr(user, "preferred_username", "Unknown User")

except Exception as e:
print(f"ERROR READING THE USER OBJECT: {e}")
username = "ERROR"

print("-----------------------------------------------------------------")

return {"message": f"Hello {username} ({user_id}), this endpoint is secured!"}

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post