data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
こんな悩みを解決できる記事を書きました!
僕は現役フリーランスエンジニア(歴9年)で、資格は13個保有しています。
結論、API GatewayのゲートウェイレスポンスをCloudFormationで設定するのは非常に簡単です。
具体的なソースコードを載せているので安心してくださいね。
data:image/s3,"s3://crabby-images/d7e20/d7e20f7a7b0fe19454ff1230eb28f017b5db617f" alt=""
data:image/s3,"s3://crabby-images/d7e20/d7e20f7a7b0fe19454ff1230eb28f017b5db617f" alt=""
本記事を読めば、API GatewayのゲートウェイレスポンスをCloudFormationで設定する方法が理解できるので早速見ていきましょう。
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
すぐ読み終わるので、ぜひ最後まで読んでくださいね♪
ゲートウェイレスポンスをCloudFormationで設定する方法
早速ですが、ゲートウェイレスポンスをCloudFormationで設定する方法を解説します。
AWSTemplateFormatVersion: 2010-09-09
Resources:
RestApi:
Type: AWS::ApiGateway::RestApi
Properties:
Name: hello-world
GatewayResponse:
Type: AWS::ApiGateway::GatewayResponse
Properties:
ResponseParameters:
gatewayresponse.header.Access-Control-Allow-Origin: "'*'"
ResponseType: EXPIRED_TOKEN
RestApiId: !Ref RestApi
StatusCode: '403'
yamlファイルを用意します。
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
今回は、hello-worldというAPI Gatewayにゲートウェイレスポンスの設定を追加します。
EXPIRED_TOKEN(期限切れのトークン)のレスポンスヘッダに「Access-Control-Allow-Origin」を設定します。
data:image/s3,"s3://crabby-images/d2c38/d2c386ae92fcda947070304dd39a9790c05ba41e" alt=""
data:image/s3,"s3://crabby-images/d2c38/d2c386ae92fcda947070304dd39a9790c05ba41e" alt=""
CloudFormationを開き、スタックの作成をクリックします。
data:image/s3,"s3://crabby-images/a3717/a3717361eaf4793382be0d342f9b391b5c137679" alt=""
data:image/s3,"s3://crabby-images/a3717/a3717361eaf4793382be0d342f9b391b5c137679" alt=""
先ほど作成したyamlファイルをアップロードし、次へをクリックします。
data:image/s3,"s3://crabby-images/5d4d0/5d4d04c63f913b1f11fb6946863f26c4a49e0738" alt=""
data:image/s3,"s3://crabby-images/5d4d0/5d4d04c63f913b1f11fb6946863f26c4a49e0738" alt=""
スタックの名前を入力し、次へをクリックします。
data:image/s3,"s3://crabby-images/dfdb7/dfdb76f8b0c16915f9a4428323378221e878ec6c" alt=""
data:image/s3,"s3://crabby-images/dfdb7/dfdb76f8b0c16915f9a4428323378221e878ec6c" alt=""
デフォルトのまま、次へをクリックします。
data:image/s3,"s3://crabby-images/f11a3/f11a3785cacf21cf3b4d6bb817cbd1729ce711e6" alt=""
data:image/s3,"s3://crabby-images/f11a3/f11a3785cacf21cf3b4d6bb817cbd1729ce711e6" alt=""
デフォルトのまま、送信をクリックします。
data:image/s3,"s3://crabby-images/989ea/989ea4718e67b6d86b4109d2ced72b821603d578" alt=""
data:image/s3,"s3://crabby-images/989ea/989ea4718e67b6d86b4109d2ced72b821603d578" alt=""
スタックのステータスが「CREATE_COMPLETE」になればOKです。
data:image/s3,"s3://crabby-images/5046a/5046a9521c4d8dc48d8b40c334238582129a63ea" alt=""
data:image/s3,"s3://crabby-images/5046a/5046a9521c4d8dc48d8b40c334238582129a63ea" alt=""
API Gatewayのゲートウェイレスポンスにレスポンスヘッダが設定されていれば完了です。
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
簡単でしたね。
ゲートウェイレスポンスのレスポンスタイプ
ゲートウェイレスポンスのレスポンスタイプ(responseType)は以下になります。
- DEFAULT_4XX
- DEFAULT_5XX
- RESOURCE_NOT_FOUND
- UNAUTHORIZED
- INVALID_API_KEY
- ACCESS_DENIED
- AUTHORIZER_FAILURE
- AUTHORIZER_CONFIGURATION_ERROR
- INVALID_SIGNATURE
- EXPIRED_TOKEN
- MISSING_AUTHENTICATION_TOKEN
- INTEGRATION_FAILURE
- INTEGRATION_TIMEOUT
- API_CONFIGURATION_ERROR
- UNSUPPORTED_MEDIA_TYPE
- BAD_REQUEST_PARAMETERS
- BAD_REQUEST_BODY
- REQUEST_TOO_LARGE
- THROTTLED
- QUOTA_EXCEEDED
よくある質問
GatewayResponseの公式ドキュメントはありますか?
下記になります。
まとめ
今回は、API GatewayのゲートウェイレスポンスをCloudFormationで設定する方法について解説しました。
以下が本記事のまとめになります。
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
最後までお読みいただき、ありがとうございました!
- クソおすすめ本
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
data:image/s3,"s3://crabby-images/da893/da893c5ca4ad23a28de80f4ce77f6ddf8ef7bea7" alt=""
海外のエンジニアがどういった思考で働いているかが理解できます。
海外に行く気はないけど海外エンジニアの動向が気になる雑魚エンジニアにおすすめです(本当におすすめな本しか紹介しないのでご安心を)。