Aller au contenu

Dépendances globales

🌐 Traduction par IA et humains

Cette traduction a été réalisée par une IA guidée par des humains. 🤝

Elle peut contenir des erreurs d'interprétation du sens original, ou paraître peu naturelle, etc. 🤖

Vous pouvez améliorer cette traduction en nous aidant à mieux guider le LLM d'IA.

Version anglaise

Pour certains types d'applications, vous pourriez vouloir ajouter des dépendances à l'application entière.

Comme vous pouvez ajouter des dependencies aux décorateurs de chemin d'accès, vous pouvez les ajouter à l'application FastAPI.

Dans ce cas, elles seront appliquées à tous les chemins d'accès de l'application :

from typing import Annotated

from fastapi import Depends, FastAPI, Header, HTTPException


async def verify_token(x_token: Annotated[str, Header()]):
    if x_token != "fake-super-secret-token":
        raise HTTPException(status_code=400, detail="X-Token header invalid")


async def verify_key(x_key: Annotated[str, Header()]):
    if x_key != "fake-super-secret-key":
        raise HTTPException(status_code=400, detail="X-Key header invalid")
    return x_key


app = FastAPI(dependencies=[Depends(verify_token), Depends(verify_key)])


@app.get("/items/")
async def read_items():
    return [{"item": "Portal Gun"}, {"item": "Plumbus"}]


@app.get("/users/")
async def read_users():
    return [{"username": "Rick"}, {"username": "Morty"}]
🤓 Other versions and variants

Tip

Prefer to use the Annotated version if possible.

from fastapi import Depends, FastAPI, Header, HTTPException


async def verify_token(x_token: str = Header()):
    if x_token != "fake-super-secret-token":
        raise HTTPException(status_code=400, detail="X-Token header invalid")


async def verify_key(x_key: str = Header()):
    if x_key != "fake-super-secret-key":
        raise HTTPException(status_code=400, detail="X-Key header invalid")
    return x_key


app = FastAPI(dependencies=[Depends(verify_token), Depends(verify_key)])


@app.get("/items/")
async def read_items():
    return [{"item": "Portal Gun"}, {"item": "Plumbus"}]


@app.get("/users/")
async def read_users():
    return [{"username": "Rick"}, {"username": "Morty"}]

Et toutes les idées de la section sur l'ajout de dependencies aux décorateurs de chemin d'accès s'appliquent toujours, mais dans ce cas à tous les chemins d'accès de l'application.

Dépendances pour des groupes de chemins d'accès

Plus tard, en lisant comment structurer des applications plus grandes (Applications plus grandes - Plusieurs fichiers), éventuellement avec plusieurs fichiers, vous apprendrez comment déclarer un unique paramètre dependencies pour un groupe de chemins d'accès.