このページの内容は Apigee と Apigee ハイブリッドに該当します。
Apigee Edge のドキュメントを表示する。
OASValidation ポリシーについて
OASValidation(OpenAPI 仕様の検証)ポリシーを使用すると、OpenAPI 3.0 仕様(JSON または YAML 形式)と照合して受信リクエストまたはレスポンス メッセージを検証できます。検証するコンテンツをご覧ください。
OASValidation ポリシーでは、ポリシーが接続された手順が実施されるときに検証に使用する OpenAPI 仕様の名前を指定します。OpenAPI 仕様は、API プロキシ バンドル内の標準の場所(apiproxy/resources/oas
)にリソースとして保存されます。OpenAPI 仕様ドキュメントには、拡張機能 .json
、.yml
、.yaml
が必要です。
リソースの管理で説明しているように、UI または API を使用して、OpenAPI 仕様をリソースとして API プロキシ バンドルに追加します。
このポリシーは、標準ポリシーであり、任意の環境タイプにデプロイできます。ポリシータイプと各環境タイプで使用可能かどうかは、ポリシータイプをご覧ください。
検証するコンテンツ
次の表に、OASValidation ポリシーによって検証されるリクエスト メッセージの内容をコンポーネント別に示します。
コンポーネント | リクエストの検証 |
---|---|
ベースパス | API プロキシによって定義されたベースパスを検証します。OpenAPI 仕様で指定されたベースパスは無視されます。 |
パス | リクエストパス(ベースパスを除く)が OpenAPI 仕様で定義されているパスパターンのいずれかと一致していることを検証します。 |
動詞 | OpenAPI 仕様のパスに対して動詞が定義されていることを検証します。 |
リクエスト メッセージの本文 |
注: このポリシーは、Content-Type が |
パラメータ |
|
次の表に、OASValidation ポリシーによって検証されるレスポンス メッセージの内容をコンポーネント別に示します。
コンポーネント | レスポンスの検証 |
---|---|
パス | リクエストパス(ベースパスを除く)が OpenAPI 仕様で定義されているパスパターンのいずれかと一致していることを検証します。 |
動詞 | OpenAPI 仕様のパスに対して動詞が定義されていることを検証します。 |
レスポンス メッセージの本文 |
|
サンプル
次の例は、OASValidation ポリシーを使用して OpenAPI 3.0 仕様に照らしてメッセージを検証する方法の一部を示しています。
リクエスト メッセージを検証する
次の例では、myoaspolicy
ポリシーを使用して、my-spec.json
OpenAPI 仕様で定義されたオペレーションのリクエスト メッセージ本文のスキーマに照らしてリクエスト メッセージの本文を検証します。
<OASValidation name="myoaspolicy"> <OASResource>oas://my-spec.json</OASResource> <Options> <ValidateMessageBody>true</ValidateMessageBody> </Options> <Source>request</Source> </OASValidation>
メッセージ本文が OpenAPI 仕様に準拠していない場合は、policies.oasvalidation.Failed
エラーが返されます。
パラメータを検証する
次の例では、OpenAPI 仕様で定義されていないヘッダー、クエリ、Cookie パラメータがリクエストで指定されている場合、ポリシーは失敗するように構成されています。
<OASValidation name="myoaspolicy"> <OASResource>oas://my-spec.yaml</OASResource> <Options> <AllowUnspecifiedParameters> <Header>false</Header> <Query>false</Query> <Cookie>false</Cookie> </AllowUnspecifiedParameters> </Options> </OASValidation>
<OASValidation>
要素
OpenAPI Specification Validation ポリシーを定義します。
デフォルト値 | 下記の [デフォルト ポリシー] タブをご覧ください。 |
必須かどうか | 必須 |
型 | 複合オブジェクト |
親要素 | なし |
子要素 |
<DisplayName> <OASResource> <Source> <Options> <Source> |
構文
<OASValidation>
要素の構文は次のとおりです。
<OASValidation continueOnError="[true|false]" enabled="[true|false]" name="policy_name" > <!-- All OASValidation child elements are optional except OASResource --> <DisplayName>policy_display_name</DisplayName> <OASResource>validation_JSON_or_YAML</OASResource> <Options> <ValidateMessageBody>[true|false]</ValidateMessageBody> <AllowUnspecifiedParameters> <Header>[true|false]</Header> <Query>[true|false]</Query> <Cookie>[true|false]</Cookie> </AllowUnspecifiedParameters> </Options> <Source>message_to_validate</Source> </OASValidation>
デフォルト ポリシー
次の例は、Apigee UI でフローに OAS Validation ポリシーを追加する場合のデフォルト設定を示しています。
<OASValidation continueOnError="false" enabled="true" name="OpenAPI-Spec-Validation-1"> <DisplayName>OpenAPI Spec Validation-1</DisplayName> <Properties/> <Source>request</Source> <OASResource>oas://OpenAPI-Spec-Validation-1.yaml</OASResource> </OASValidation>
この要素には、すべてのポリシーに共通する次の属性があります。
属性 | デフォルト | 必須かどうか | 説明 |
---|---|---|---|
name |
なし | 必須 |
ポリシーの内部名。 管理 UI プロキシ エディタで |
continueOnError |
false | 省略可 | ポリシーが失敗したときにエラーを返す場合は、false に設定します。これは、ほとんどのポリシーで想定される動作です。ポリシーが失敗した後もフローの実行を続行する場合は、true に設定します。関連情報:
|
enabled |
true | 省略可 | ポリシーを適用するには、true に設定します。ポリシーを無効にするには、false に設定します。ポリシーがフローに接続されている場合でも適用されません。 |
async |
false | 非推奨 | この属性は非推奨となりました。 |
子要素のリファレンス
このセクションでは、<OASValidation>
の子要素について説明します。
<DisplayName>
name
属性に加えて、管理 UI プロキシ エディタでポリシーを別の、より自然な響きの名前でラベル付けするために使います。
<DisplayName>
要素はすべてのポリシーに共通です。
デフォルト値 | なし |
必須かどうか | 省略可。<DisplayName> を省略した場合、ポリシーの name 属性の値が使用されます。 |
型 | 文字列 |
親要素 | <PolicyElement> |
子要素 | なし |
<DisplayName>
要素の構文は次のとおりです。
構文
<PolicyElement> <DisplayName>POLICY_DISPLAY_NAME</DisplayName> ... </PolicyElement>
例
<PolicyElement> <DisplayName>My Validation Policy</DisplayName> </PolicyElement>
<DisplayName>
要素に属性や子要素はありません。
<OASResource>
検証する OpenAPI 仕様を指定します。このファイルは次の場所に保存できます。
- API プロキシ バンドルの
/apiproxy/resources/oas
の下にある API プロキシ スコープ - API プロキシ エディタの [Navigator] ビューの [
Resources
] セクション
詳しくは、リソースの管理をご覧ください。
メッセージ テンプレート({oas.resource.url}
など)を使用して OpenAPI 仕様を指定できます。この場合、フロー変数 oas.resource.url
の値(中かっこ内)が評価され、ランタイム時にペイロード文字列に置き換えられます。詳しくは、メッセージ テンプレートをご覧ください。
デフォルト値 | なし |
必須かどうか | 必須 |
型 | 文字列 |
親要素 |
<OASValidation>
|
子要素 | なし |
構文
<OASResource>
要素の構文は次のとおりです。
<OASValidation name="policy_name"> <OASResource>oas://specname[.json|.yaml|.yml]</OASResource> ... </OASValidation>
例
次の例では、API プロキシ バンドルの /apiproxy/resources/oas
に保存されている my-spec.yaml
仕様を参照します。
<OASValidation name="myoaspolicy"> <OASResource>oas://my-spec.yaml</OASResource> </OASValidation>
<OASResource>
要素に属性や子要素はありません。
<Options>
ポリシーのオプションを構成します。
デフォルト値 | なし |
必須かどうか | 省略可 |
型 | 複合型 |
親要素 |
<OASValidation>
|
子要素 |
<ValidateMessageBody> <AllowUnspecifiedParameters> |
構文
<Options>
要素の構文は次のとおりです。
<OASValidation name="policy_name"> <OASResource>oas://specname[.json|.yaml|.yml]</OASResource> <Options> <ValidateMessageBody>[true|false]</ValidateMessageBody> <AllowUnspecifiedParameters> <Header>[true|false]</Header> <Query>[true|false]</Query> <Cookie>[true|false]</Cookie> </AllowUnspecifiedParameters> </Options> ... </OASValidation>
例
次の例では、ポリシーのオプションを構成しています。各オプションの詳細については、以下をご覧ください。
<OASValidation name="myoaspolicy"> <OASResource>oas://my-spec.yaml</OASResource> <Options> <ValidateMessageBody>false</ValidateMessageBody> <AllowUnspecifiedParameters> <Header>false</Header> <Query>false</Query> <Cookie>false</Cookie> </AllowUnspecifiedParameters> </Options> </OASValidation>
<ValidateMessageBody>
ポリシーを使用して、OpenAPI 仕様のオペレーションのリクエスト本文スキーマに照らしてメッセージ本文を検証する必要があるかどうかを指定します。メッセージ本文の内容を検証するには、true に設定します。メッセージ本文が存在するかどうかだけを検証する場合は false に設定します。
<OASValidation>
要素の continueOnError
属性を true に設定すると、検証エラーの後にフローの実行を継続するかどうかを制御できます。
デフォルト値 | false |
必須かどうか | 省略可 |
型 | ブール値 |
親要素 |
<Options>
|
子要素 | なし |
構文
<ValidateMessageBody>
要素の構文は次のとおりです。
<OASValidation name="policy_name"> <OASResource>oas://specname[.json|.yaml|.yml]</OASResource> <Options> <ValidateMessageBody>[true|false]</ValidateMessageBody> </Options> ... </OASValidation>
例
次の例では、メッセージ本文の内容の検証を有効にしています。
<OASValidation name="myoaspolicy"> <OASResource>oas://my-spec.yaml</OASResource> <Options> <ValidateMessageBody>true</ValidateMessageBody> </Options> </OASValidation>
<AllowUnspecifiedParameters>
OpenAPI 仕様で定義されていないヘッダー、クエリ、Cookie パラメータがリクエストに存在している場合のポリシーの動作を構成します。
デフォルト値 | なし |
必須かどうか | 省略可 |
型 | 複合型 |
親要素 |
<Options>
|
子要素 |
<Header> <Query> <Cookie> |
構文
<AllowUnspecifiedParameters>
要素の構文は次のとおりです。
<OASValidation name="policy_name"> <OASResource>oas://specname[.json|.yaml|.yml]</OASResource> <Options> <AllowUnspecifiedParameters> <Header>[true|false]</Header> <Query>[true|false]</Query> <Cookie>[true|false]</Cookie> </AllowUnspecifiedParameters> </Options> ... </OASValidation>
例
次の例では、OpenAPI 仕様で定義されていないヘッダー、クエリ、Cookie パラメータがリクエストで指定されている場合、ポリシーは失敗するように構成されています。
<OASValidation name="myoaspolicy"> <OASResource>oas://my-spec.yaml</OASResource> <Options> <AllowUnspecifiedParameters> <Header>false</Header> <Query>false</Query> <Cookie>false</Cookie> </AllowUnspecifiedParameters> </Options> </OASValidation>
<Header>
(<AllowUnspecifiedParameters>
の子)
OpenAPI 仕様で定義されていないヘッダー パラメータがリクエストに存在している場合のポリシーの動作を構成します。
OpenAPI 仕様で定義されていないヘッダー パラメータをリクエストで指定できるようにするには、このパラメータを true に設定します。それ以外の場合は、このパラメータを false に設定してポリシーの実行が失敗するようにします。
デフォルト値 | true |
必須かどうか | ブール値 |
型 | 複合型 |
親要素 |
<AllowUnspecifiedParameters>
|
子要素 | なし |
構文
<Header>
要素の構文は次のとおりです。
<OASValidation name="policy_name"> <OASResource>oas://specname[.json|.yaml|.yml]</OASResource> <Options> <AllowUnspecifiedParameters> <Header>[true|false]</Header> </AllowUnspecifiedParameters> </Options> ... </OASValidation>
例
次の例では、OpenAPI 仕様で定義されていないヘッダー パラメータがリクエストで指定されている場合、ポリシーは失敗するように構成されています。
<OASValidation name="myoaspolicy"> <OASResource>oas://my-spec.yaml</OASResource> <Options> <AllowUnspecifiedParameters> <Header>false</Header> </AllowUnspecifiedParameters> </Options> </OASValidation>
<Query>
(<AllowUnspecifiedParameters>
の子)
OpenAPI 仕様で定義されていないクエリ パラメータがリクエストに存在する場合のポリシーの動作を構成します。
OpenAPI 仕様で定義されていないクエリ パラメータをリクエストで指定できるようにするには、このパラメータを true に設定します。それ以外の場合は、このパラメータを false に設定してポリシーの実行が失敗するようにします。
デフォルト値 | true |
必須かどうか | ブール値 |
型 | 複合型 |
親要素 |
<AllowUnspecifiedParameters>
|
子要素 | なし |
構文
<Query>
要素の構文は次のとおりです。
<OASValidation name="policy_name"> <OASResource>oas://specname[.json|.yaml|.yml]</OASResource> <Options> <AllowUnspecifiedParameters> <Query>[true|false]</Query> </AllowUnspecifiedParameters> </Options> ... </OASValidation>
例
次の例では、OpenAPI 仕様で定義されていないクエリ パラメータがリクエストで指定されている場合、ポリシーは失敗するように構成されています。
<OASValidation name="myoaspolicy"> <OASResource>oas://my-spec.yaml</OASResource> <Options> <AllowUnspecifiedParameters> <Query>false</Query> </AllowUnspecifiedParameters> </Options> </OASValidation>
OpenAPI 仕様で定義されていない Cookie パラメータがリクエストに存在する場合のポリシーの動作を構成します。
OpenAPI 仕様で定義されていない Cookie パラメータをリクエストで指定できるようにするには、このパラメータを true に設定します。それ以外の場合は、このパラメータを false に設定してポリシーの実行が失敗するようにします。
デフォルト値 | true |
必須かどうか | ブール値 |
型 | 複合型 |
親要素 |
<AllowUnspecifiedParameters>
|
子要素 | なし |
構文
<Cookie>
要素の構文は次のとおりです。
<OASValidation name="policy_name"> <OASResource>oas://specname[.json|.yaml|.yml]</OASResource> <Options> <AllowUnspecifiedParameters> <Query>[true|false]</Query> </AllowUnspecifiedParameters> </Options> ... </OASValidation>
例
次の例では、OpenAPI 仕様で定義されていないクエリ パラメータがリクエストで指定されている場合、ポリシーは失敗するように構成されています。
<OASValidation name="myoaspolicy"> <OASResource>oas://my-spec.yaml</OASResource> <Options> <AllowUnspecifiedParameters> <Cookie>false</Cookie> </AllowUnspecifiedParameters> </Options> </OASValidation>
<Source>
JSON ペイロード攻撃に対して評価される JSON メッセージ。通常はクライアント アプリからの受信リクエストを評価する必要があるため、これは一般的に request
に設定されます。レスポンス メッセージを評価するには、response に設定します。message に設定すると、ポリシーがリクエスト フローに接続されたときはリクエスト メッセージを自動的に評価し、ポリシーがレスポンス フローに接続されたときはレスポンス メッセージを評価します。
デフォルト値 | リクエスト |
必須かどうか | 省略可 |
型 | 文字列 |
親要素 |
<Source>
|
子要素 | なし |
構文
<Source>
要素の構文は次のとおりです。
<OASValidation name="policy_name"> <OASResource>oas://specname[.json|.yaml|.yml]</OASResource> <Source>[message|request|response]</Source> ... </OASValidation>
例
次の例では、ポリシーがリクエスト フローに接続されたときはリクエスト メッセージを自動的に評価し、ポリシーがレスポンス フローに接続されたときはレスポンス メッセージを評価します。
<OASValidation name="myoaspolicy"> <OASResource>oas://my-spec.yaml</OASResource> <Source>message</Source> </OASValidation>
<Source>
要素に属性や子要素はありません。
このポリシーのスキーマ
各ポリシータイプは XML スキーマ(.xsd
)によって定義されます。参照用のポリシー スキーマは GitHub から入手できます。
エラーコード
This section describes the fault codes and error messages that are returned and fault variables that are set by Apigee when this policy triggers an error. This information is important to know if you are developing fault rules to handle faults. To learn more, see What you need to know about policy errors and Handling faults.
Runtime errors
These errors can occur when the policy executes.
Fault code | HTTP status | Cause |
---|---|---|
steps.oasvalidation.Failed |
400 |
The Request message body cannot be validated against the provided OpenAPI Specification. |
steps.oasvalidation.Failed |
500 |
The Response message body cannot be validated against the provided OpenAPI Specification. |
steps.oasvalidation.SourceMessageNotAvailable |
500 |
Variable specified in the |
steps.oasvalidation.NonMessageVariable |
500 |
|
Deployment errors
These errors can occur when you deploy a proxy containing this policy.
Error name | Cause | |
---|---|---|
ResourceDoesNotExist |
OpenAPI Specification referenced in the <OASResource> element does not exist.
|
|
ResourceCompileFailed |
OpenAPI Specification that is included in the deployment contains errors that prevent it from being compiled. This generally indicates that the specification is not a well-formed OpenAPI Specification 3.0. | |
BadResourceURL |
OpenAPI Specification referenced in the <OASResource> element cannot be processed. This can occur if the file is not a JSON or YAML file or the
file URL is not specified correctly.
|
Fault variables
These variables are set when this policy triggers an error at runtime. For more information, see What you need to know about policy errors.
Variable | Description | Example |
---|---|---|
fault.category |
The category of the fault. When the policy rejects a request, this will always hold Step . |
fault.category = "Step" |
fault.name |
The name of the fault, as listed in the Runtime errors table above. The fault name is the last part of the fault code. | fault.name Matches "ResourceDoesNotExist" |
fault.reason |
The reason for the fault. It is a human-readable string explaining the reason for the fault. | OASValidation OAS-1 with resource "oas://my-spec1.yaml": failed with reason: "[ERROR - POST operation not allowed on path '/persons/13'.: []]" |
fault.subcategory |
The subcategory of the fault. When the policy rejects a request, this will always hold OASValidationFailure . |
fault.subcategory = "OASValidationFailure" |
OASValidation.policy_name.failed |
policy_name is the user-specified name of the policy that threw the fault. | OASValidation.myoaspolicy.failed = true |
サポートされる OpenAPI 仕様の機能
OASValidation ポリシーは、次の表にカテゴリ別にまとめられている OpenAPI 仕様の機能に対応しています。サポート対象外の機能も表示されています。
カテゴリ | サポート対象 | サポート対象外 |
---|---|---|
データ型の形式 | boolean date date-time double float int32/int64 ipv4/ipv6 md5 sha1/sha256/sha512 string uri uri-template uuid |
binary byte password |
識別オブジェクト | mapping propertyName |
なし |
メディアタイプ オブジェクト | schema | encoding example examples |
オペレーション オブジェクト | parameters requestBody responses security(部分サポート) |
callbacks deprecated servers |
パラメータ オブジェクト | allowEmptyValue in( query 、header 、path )required responses schema style( deepObject 、form 、formmatrix 、label 、pipeDelimited 、simple 、spaceDelimited )注: deepObject では文字列パラメータのみがサポートされ、配列やネストされたオブジェクトはサポートされません。 |
allowReserved deprecated example examples content |
パス オブジェクト | delete get head options parameters patch post put trace variables |
servers |
リクエスト本文オブジェクト | application/json application/hal+json application/x-www-form-urlencoded( encoding オブジェクトは対象外)content required |
application/xml multipart/form-data text/plain text/xml |
レスポンス オブジェクト | application/json application/hal+json application/x-www-form-urlencoded( encoding オブジェクトは対象外)content headers |
application/xml links text/plain text/xml |
レスポンス オブジェクト | default HTTP ステータス コード |
なし |
スキーマ オブジェクト | $ref additionalProperties(ブール値のフラグ バリアントのみ) allOf( additionalProperties が false の場合は無視)anyOf enum exclusiveMaximum/exclusiveMinimum format items maximum/minimum maxItems/minItems maxLength/minLength maxProperties/minProperties multipleOf not nullable oneOf pattern properties required title type uniqueItems |
deprecated example readOnly writeOnly xml |
セキュリティ スキーマ オブジェクト | in(header 、query )(type が http の場合は無視)name type( apiKey 、http )
|
bearerFormat flows openIdConnectUrl scheme |
サーバー オブジェクト | url variables |
複数サーバーの定義 |
スキーマでのパターンの使用
OpenAPI 仕様標準では、仕様で schema
を指定して、パラメータまたはフィールドのデータ型を記述できます。文字列タイプのパラメータまたはフィールドの場合、スキーマで pattern
を定義することもできます。これは、文字列の有効な形式を定義する正規表現(regex)です。
たとえば、次の OpenAPI 仕様について考えてみましょう。
paths: /products/{product-id}: get: operationId: getProduct summary: Get product by id description: returns information regarding a product, by id parameters: - name: product-id in: path description: id of the product required: true schema: type: string pattern: '^\w{3}-\d{4}$'
この仕様では、getProduct
オペレーションの product-id
パラメータが、3 つの単語、ダッシュ、4 桁の数字のシーケンスを規定する正規表現に準拠している必要があります。
OpenAPI 仕様は、文字列値の検証におけるパターンの動作を正式に定義している JSON Schema Validation 標準と、正規表現構文の制限付きセットに関するスキーマ作成者への推奨事項である JSON Schema Core 標準に準拠しています。この後者の標準では、OpenAPI 仕様ドキュメント内のパターンで、ルックアラウンド(先読みと後読み)、後方参照、オクテット文字の式などの使用を避けることが推奨されています。
デフォルトでは、Apigee は OASValidation ポリシーで参照される OpenAPI 仕様ドキュメントを検証し、仕様ドキュメントの形式が適切でない場合はエラーを報告します。また、Apigee は仕様書内の正規表現パターンを検証し、問題が見つかった場合は報告します。
推奨サブセットに含まれていない正規表現機能を使用した場合、Apigee は正規表現を検証しません。また、OpenAPI 仕様ドキュメントの追加の検証も停止します。ドキュメントにエラーがある場合、推奨サブセットに含まれていない機能を使用する正規表現にエラーがある場合、または正規表現機能が Apigee ランタイムでサポートされていない場合、これらのエラーは、ポリシーが実行されるランタイムでのみ検出されます。
次の表に例を示します。
パターン | 動作 |
---|---|
^\w{3}-\d{4}$ |
パターンは有効です。推奨サブセットに含まれる正規表現機能のみを使用しています。Apigee は、プロキシの保存またはインポートを許可します。ランタイムで OASValidation ポリシーが意図したとおりに機能し、パターンと照合してパラメータを検証します。 |
^([a-z]\w{3}-\d{4}$ |
パターンが無効です。閉じかっこがありません。パターンで、推奨サブセットに含まれていない正規表現機能は使用されていません。Apigee は、API プロキシのインポートまたは保存時にこのエラーを報告します。 |
^(?![a-z]\w{3}-\d{4}$ |
パターンが無効です。前の例と同様に、閉じかっこがありません。ただし、正規表現で否定先読みが使用されているため、Apigee は API プロキシの保存またはインポート時にこのエラーを報告しません。これは、正規表現機能の推奨サブセットに含まれていません。このエラーは、ポリシーの実行時にのみ検出されます。 |
^(?![a-z])\w{3}-\d{4}$ |
パターンは有効ですが、否定先読みが使用されています。これは、正規表現機能の推奨サブセットに含まれていません。Apigee は、OpenAPI 仕様ドキュメントの検証を停止します。ランタイムに、このパターンを使用して仕様を参照する OASValidation ポリシーを実行した場合、Apigee ランタイムは否定先読みをサポートしているため、Apigee はこの正規表現を正しく適用し、パラメータ値を検証します。 |
^(a)?b(?(1)c|d)$ |
このパターンは有効ですが、キャプチャ グループの条件が使用されています。これは、正規表現機能の推奨サブセットに含まれていません。Apigee は、OpenAPI 仕様ドキュメントの検証を停止します。ランタイムで、このパターンを使用して仕様を参照する OASValidation ポリシーを実行した場合、Apigee ランタイムはこの正規表現機能をサポートしていないため、Apigee はエラーを返します。 |
ランタイム エラーを防ぐため、推奨サブセットに含まれる正規表現機能のみを使用することをおすすめします。