fastapi/docs/ja/docs/tutorial/schema-extra-example.md

11 KiB
Raw Blame History

リクエストのExampleデータの宣言

アプリが受け取れるデータの例を宣言できます。

ここでは、それを行ういくつかの方法を紹介します。

Pydanticモデルでの追加JSON Schemaデータ

生成されるJSON Schemaに追加されるPydanticモデルのexamplesを宣言できます。

{* ../../docs_src/schema_extra_example/tutorial001_py310.py hl[13:24] *}

その追加情報は、そのモデルの出力JSON Schemaにそのまま追加され、APIドキュメントで使用されます。

Pydanticのドキュメント: Configurationで説明されているように、dictを受け取る属性model_configを使用できます。

生成されるJSON Schemaに表示したい追加データexamplesを含む)を含むdictを使って、"json_schema_extra"を設定できます。

/// tip | 豆知識

同じ手法を使ってJSON Schemaを拡張し、独自のカスタム追加情報を追加できます。

例えば、フロントエンドのユーザーインターフェースのためのメタデータを追加する、などに使えます。

///

/// info | 情報

OpenAPI 3.1.0FastAPI 0.99.0以降で使用)では、JSON Schema標準の一部であるexamplesがサポートされました。

それ以前は、単一の例を持つキーワードexampleのみがサポートされていました。これはOpenAPI 3.1.0でも引き続きサポートされていますが、非推奨であり、JSON Schema標準の一部ではありません。そのため、exampleからexamplesへの移行が推奨されます。🤓

詳細はこのページの最後で読めます。

///

Fieldの追加引数

PydanticモデルでField()を使う場合、追加のexamplesも宣言できます:

{* ../../docs_src/schema_extra_example/tutorial002_py310.py hl[2,8:11] *}

JSON Schema内のexamples - OpenAPI

以下のいずれかを使用する場合:

  • Path()
  • Query()
  • Header()
  • Cookie()
  • Body()
  • Form()
  • File()

追加情報を含むexamplesのグループを宣言でき、それらはOpenAPI内のそれぞれのJSON Schemasに追加されます。

examplesを使うBody

ここでは、Body()で期待されるデータの例を1つ含むexamplesを渡します:

{* ../../docs_src/schema_extra_example/tutorial003_an_py310.py hl[22:29] *}

ドキュメントUIでの例

上記のいずれの方法でも、/docsの中では以下のようになります:

複数のexamplesを使うBody

もちろん、複数のexamplesを渡すこともできます:

{* ../../docs_src/schema_extra_example/tutorial004_an_py310.py hl[23:38] *}

この場合、examplesはそのボディデータの内部JSON Schemaの一部になります。

それでも、執筆時点では、ドキュメントUIの表示を担当するツールであるSwagger UIは、JSON Schema内のデータに対して複数の例を表示することをサポートしていません。しかし、回避策については以下を読んでください。

OpenAPI固有のexamples

JSON Schemaexamplesをサポートする前から、OpenAPIは同じくexamplesという別のフィールドをサポートしていました。

このOpenAPI固有examplesは、OpenAPI仕様の別のセクションに入ります。各JSON Schemaの中ではなく、path operationの詳細に入ります。

そしてSwagger UIは、この特定のexamplesフィールドを以前からサポートしています。そのため、これを使ってドキュメントUIに異なる例を表示できます。

このOpenAPI固有フィールドexamplesの形は複数の例listではなく)を持つdictであり、それぞれに追加情報が含まれ、その追加情報はOpenAPIにも追加されます。

これはOpenAPIに含まれる各JSON Schemaの中には入らず、外側の、path operationに直接入ります。

openapi_examplesパラメータの使用

FastAPIでは、以下に対してパラメータopenapi_examplesを使って、OpenAPI固有のexamplesを宣言できます:

  • Path()
  • Query()
  • Header()
  • Cookie()
  • Body()
  • Form()
  • File()

dictのキーは各例を識別し、各値は別のdictです。

examples内の各特定の例dictには、次の内容を含められます:

  • summary: 例の短い説明。
  • description: Markdownテキストを含められる長い説明。
  • value: 実際に表示される例(例: dict)。
  • externalValue: valueの代替で、例を指すURLです。ただし、valueほど多くのツールでサポートされていない可能性があります。

次のように使えます:

{* ../../docs_src/schema_extra_example/tutorial005_an_py310.py hl[23:49] *}

ドキュメントUIのOpenAPI Examples

Body()openapi_examplesを追加すると、/docsは次のようになります:

技術詳細

/// tip | 豆知識

すでにFastAPIバージョン0.99.0以上を使用している場合、おそらくこれらの詳細はスキップできます。

これらは、OpenAPI 3.1.0が利用可能になる前の古いバージョンにより関連します。

これは簡単なOpenAPIとJSON Schemaの歴史の授業だと考えられます。🤓

///

/// warning | 注意

ここでは、標準であるJSON SchemaOpenAPIについての非常に技術的な詳細を扱います。

上のアイデアがすでにうまく動いているなら、それで十分かもしれませんし、おそらくこの詳細は不要です。気軽にスキップしてください。

///

OpenAPI 3.1.0より前は、OpenAPIは古く改変されたバージョンのJSON Schemaを使用していました。

JSON Schemaにはexamplesがなかったため、OpenAPIは自身が改変したバージョンに独自のexampleフィールドを追加しました。

OpenAPIは、仕様の他の部分にもexampleexamplesフィールドを追加しました:

/// info | 情報

この古いOpenAPI固有のexamplesパラメータは、FastAPI 0.103.0以降はopenapi_examplesになりました。

///

JSON Schemaのexamplesフィールド

しかしその後、JSON Schemaは新しいバージョンの仕様にexamplesフィールドを追加しました。

そして、新しいOpenAPI 3.1.0は、この新しいフィールドexamplesを含む最新バージョンJSON Schema 2020-12に基づくようになりました。

そして現在、この新しいexamplesフィールドは、古い単一(かつカスタム)のexampleフィールドより優先され、exampleは現在非推奨です。

JSON Schemaのこの新しいexamplesフィールドは、OpenAPIの他の場所上で説明にあるような追加メタデータを持つdictではなく、**単なる例のlist**です。

/// info | 情報

OpenAPI 3.1.0がこのJSON Schemaとの新しいよりシンプルな統合とともにリリースされた後も、しばらくの間、自動ドキュメントを提供するツールであるSwagger UIはOpenAPI 3.1.0をサポートしていませんでしたバージョン5.0.0からサポートされています🎉)。

そのため、FastAPI 0.99.0より前のバージョンは、OpenAPI 3.1.0より低いバージョンのOpenAPIをまだ使用していました。

///

PydanticとFastAPIのexamples

Pydanticモデル内で、schema_extraまたはField(examples=["something"])を使ってexamplesを追加すると、その例はそのPydanticモデルのJSON Schemaに追加されます。

そしてそのPydanticモデルのJSON SchemaはAPIのOpenAPIに含まれ、ドキュメントUIで使用されます。

FastAPI 0.99.0より前のバージョン0.99.0以上は新しいOpenAPI 3.1.0を使用)では、他のユーティリティ(Query()Body()など)でexampleまたはexamplesを使っても、それらの例はそのデータを説明するJSON SchemaOpenAPI独自版のJSON Schemaでさえには追加されず、OpenAPI内のpath operation宣言に直接追加されていましたJSON Schemaを使用するOpenAPIの部分の外側

しかし、FastAPI 0.99.0以上ではOpenAPI 3.1.0を使用し、それはJSON Schema 2020-12とSwagger UI 5.0.0以上を使うため、すべてがより一貫し、例はJSON Schemaに含まれます。

Swagger UIとOpenAPI固有のexamples

Swagger UIは複数のJSON Schema examplesをサポートしていなかった2023-08-26時点ため、ユーザーはドキュメントで複数の例を表示する手段がありませんでした。

それを解決するため、FastAPI 0.103.0は、新しいパラメータopenapi_examplesで、同じ古いOpenAPI固有examplesフィールドを宣言するためのサポートを追加しました。🤓

まとめ

昔は歴史があまり好きではないと言っていました...が、今の私は「技術の歴史」の授業をしています。😅

要するに、FastAPI 0.99.0以上にアップグレードしてください。そうすれば、物事はもっとシンプルで一貫性があり直感的になり、これらの歴史的詳細を知る必要もありません。😎