6.9 KiB
Metadaten und Dokumentations-URLs
Sie können mehrere Metadaten-Konfigurationen in Ihrer FastAPI-Anwendung anpassen.
Metadaten für die API
Sie können die folgenden Felder festlegen, die in der OpenAPI-Spezifikation und in den Benutzeroberflächen der automatischen API-Dokumentation verwendet werden:
| Parameter | Typ | Beschreibung | ||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
title |
str |
Der Titel der API. | ||||||||||||
summary |
str |
Eine kurze Zusammenfassung der API. Verfügbar seit OpenAPI 3.1.0, FastAPI 0.99.0. | ||||||||||||
description |
str |
Eine kurze Beschreibung der API. Kann Markdown verwenden. | ||||||||||||
version |
string |
Die Version der API. Das ist die Version Ihrer eigenen Anwendung, nicht die von OpenAPI. Zum Beispiel 2.5.0. |
||||||||||||
terms_of_service |
str |
Eine URL zu den Nutzungsbedingungen für die API. Falls angegeben, muss es sich um eine URL handeln. | ||||||||||||
contact |
dict |
Die Kontaktinformationen für die freigegebene API. Kann mehrere Felder enthalten.
|
| Parameter | Typ | Beschreibung |
|---|---|---|
name | str | Der identifizierende Name der Kontaktperson/Organisation. |
url | str | Die URL, die auf die Kontaktinformationen verweist. MUSS im Format einer URL vorliegen. |
email | str | Die E-Mail-Adresse der Kontaktperson/Organisation. MUSS im Format einer E-Mail-Adresse vorliegen. |
license_infodictlicense_info-Felder
| Parameter | Typ | Beschreibung |
|---|---|---|
name | str | ERFORDERLICH (wenn eine license_info festgelegt ist). Der für die API verwendete Lizenzname. |
identifier | str | Ein SPDX-Lizenzausdruck für die API. Das Feld identifier und das Feld url schließen sich gegenseitig aus. Verfügbar seit OpenAPI 3.1.0, FastAPI 0.99.0. |
url | str | Eine URL zur Lizenz, die für die API verwendet wird. MUSS im Format einer URL vorliegen. |
Sie können diese wie folgt setzen:
{* ../../docs_src/metadata/tutorial001.py hl[3:16, 19:32] *}
/// tip | Tipp
Sie können Markdown im Feld description verwenden, und es wird in der Ausgabe gerendert.
///
Mit dieser Konfiguration würde die automatische API-Dokumentation wie folgt aussehen:
Lizenzkennung
Seit OpenAPI 3.1.0 und FastAPI 0.99.0 können Sie die license_info auch mit einem identifier anstelle einer url festlegen.
Zum Beispiel:
{* ../../docs_src/metadata/tutorial001_1.py hl[31] *}
Metadaten für Tags
Sie können auch zusätzliche Metadaten für die verschiedenen Tags hinzufügen, die zum Gruppieren Ihrer Pfadoperationen verwendet werden, mit dem Parameter openapi_tags.
Er nimmt eine Liste entgegen, die für jeden Tag ein Dictionary enthält.
Jedes Dictionary kann Folgendes enthalten:
name(erforderlich): einstrmit demselben Tag-Namen, den Sie im Parametertagsin Ihren Pfadoperationen undAPIRoutern verwenden.description: einstrmit einer kurzen Beschreibung für das Tag. Sie kann Markdown enthalten und wird in der Benutzeroberfläche der Dokumentation angezeigt.externalDocs: eindict, das externe Dokumentation beschreibt mit:description: einstrmit einer kurzen Beschreibung für die externe Dokumentation.url(erforderlich): einstrmit der URL für die externe Dokumentation.
Metadaten für Tags erstellen
Versuchen wir es mit einem Beispiel mit Tags für users und items.
Erstellen Sie Metadaten für Ihre Tags und übergeben Sie diese an den Parameter openapi_tags:
{* ../../docs_src/metadata/tutorial004.py hl[3:16,18] *}
Beachten Sie, dass Sie Markdown innerhalb der Beschreibungen verwenden können. Zum Beispiel wird „login“ in Fettschrift (login) und „fancy“ in Kursivschrift (fancy) angezeigt.
/// tip | Tipp
Sie müssen nicht für alle von Ihnen verwendeten Tags Metadaten hinzufügen.
///
Ihre Tags verwenden
Verwenden Sie den Parameter tags mit Ihren Pfadoperationen (und APIRoutern), um diese verschiedenen Tags zuzuweisen:
{* ../../docs_src/metadata/tutorial004.py hl[21,26] *}
/// info | Info
Lesen Sie mehr zu Tags unter Pfadoperation-Konfiguration{.internal-link target=_blank}.
///
Die Dokumentation testen
Wenn Sie nun die Dokumentation ansehen, werden dort alle zusätzlichen Metadaten angezeigt:
Reihenfolge der Tags
Die Reihenfolge der Tag-Metadaten-Dictionarys definiert auch die Reihenfolge, in der diese in der Benutzeroberfläche der Dokumentation angezeigt werden.
Auch wenn beispielsweise users im Alphabet nach items kommt, wird es vor diesen angezeigt, da wir deren Metadaten als erstes Dictionary der Liste hinzugefügt haben.
OpenAPI-URL
Standardmäßig wird das OpenAPI-Schema unter /openapi.json bereitgestellt.
Sie können das aber mit dem Parameter openapi_url konfigurieren.
Um beispielsweise festzulegen, dass es unter /api/v1/openapi.json bereitgestellt wird:
{* ../../docs_src/metadata/tutorial002.py hl[3] *}
Wenn Sie das OpenAPI-Schema vollständig deaktivieren möchten, können Sie openapi_url=None festlegen, wodurch auch die Dokumentationsbenutzeroberflächen deaktiviert werden, die es verwenden.
Dokumentations-URLs
Sie können die beiden enthaltenen Dokumentationsbenutzeroberflächen konfigurieren:
- Swagger UI: bereitgestellt unter
/docs.- Sie können deren URL mit dem Parameter
docs_urlfestlegen. - Sie können sie deaktivieren, indem Sie
docs_url=Nonefestlegen.
- Sie können deren URL mit dem Parameter
- ReDoc: bereitgestellt unter
/redoc.- Sie können deren URL mit dem Parameter
redoc_urlfestlegen. - Sie können sie deaktivieren, indem Sie
redoc_url=Nonefestlegen.
- Sie können deren URL mit dem Parameter
Um beispielsweise Swagger UI so einzustellen, dass sie unter /documentation bereitgestellt wird, und ReDoc zu deaktivieren:
{* ../../docs_src/metadata/tutorial003.py hl[3] *}