@aws-cdk/aws-apigateway
Version:
The CDK Construct Library for AWS::ApiGateway
161 lines • 19.8 kB
JavaScript
"use strict";
var _a, _b;
Object.defineProperty(exports, "__esModule", { value: true });
exports.ResponseType = exports.GatewayResponse = void 0;
const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const core_1 = require("@aws-cdk/core");
const apigateway_generated_1 = require("./apigateway.generated");
/**
* Configure the response received by clients, produced from the API Gateway backend.
*
* @resource AWS::ApiGateway::GatewayResponse
*/
class GatewayResponse extends core_1.Resource {
constructor(scope, id, props) {
super(scope, id);
try {
jsiiDeprecationWarnings._aws_cdk_aws_apigateway_GatewayResponseProps(props);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, GatewayResponse);
}
throw error;
}
const gatewayResponseProps = {
restApiId: props.restApi.restApiId,
responseType: props.type.responseType,
responseParameters: this.buildResponseParameters(props.responseHeaders),
responseTemplates: props.templates,
statusCode: props.statusCode,
};
const resource = new apigateway_generated_1.CfnGatewayResponse(this, 'Resource', gatewayResponseProps);
const deployment = props.restApi.latestDeployment;
if (deployment) {
deployment.node.addDependency(resource);
deployment.addToLogicalId({
gatewayResponse: {
...gatewayResponseProps,
},
});
}
this.node.defaultChild = resource;
}
buildResponseParameters(responseHeaders) {
if (!responseHeaders) {
return undefined;
}
const responseParameters = {};
for (const [header, value] of Object.entries(responseHeaders)) {
responseParameters[`gatewayresponse.header.${header}`] = value;
}
return responseParameters;
}
}
exports.GatewayResponse = GatewayResponse;
_a = JSII_RTTI_SYMBOL_1;
GatewayResponse[_a] = { fqn: "@aws-cdk/aws-apigateway.GatewayResponse", version: "1.204.0" };
/**
* Supported types of gateway responses.
* @see https://docs.aws.amazon.com/apigateway/latest/developerguide/supported-gateway-response-types.html
*/
class ResponseType {
constructor(type) {
this.responseType = type;
}
/** A custom response type to support future cases. */
static of(type) {
return new ResponseType(type.toUpperCase());
}
}
exports.ResponseType = ResponseType;
_b = JSII_RTTI_SYMBOL_1;
ResponseType[_b] = { fqn: "@aws-cdk/aws-apigateway.ResponseType", version: "1.204.0" };
/**
* The gateway response for authorization failure.
*/
ResponseType.ACCESS_DENIED = new ResponseType('ACCESS_DENIED');
/**
* The gateway response for an invalid API configuration.
*/
ResponseType.API_CONFIGURATION_ERROR = new ResponseType('API_CONFIGURATION_ERROR');
/**
* The gateway response when a custom or Amazon Cognito authorizer failed to authenticate the caller.
*/
ResponseType.AUTHORIZER_FAILURE = new ResponseType('AUTHORIZER_FAILURE');
/**
* The gateway response for failing to connect to a custom or Amazon Cognito authorizer.
*/
ResponseType.AUTHORIZER_CONFIGURATION_ERROR = new ResponseType('AUTHORIZER_CONFIGURATION_ERROR');
/**
* The gateway response when the request parameter cannot be validated according to an enabled request validator.
*/
ResponseType.BAD_REQUEST_PARAMETERS = new ResponseType('BAD_REQUEST_PARAMETERS');
/**
* The gateway response when the request body cannot be validated according to an enabled request validator.
*/
ResponseType.BAD_REQUEST_BODY = new ResponseType('BAD_REQUEST_BODY');
/**
* The default gateway response for an unspecified response type with the status code of 4XX.
*/
ResponseType.DEFAULT_4XX = new ResponseType('DEFAULT_4XX');
/**
* The default gateway response for an unspecified response type with a status code of 5XX.
*/
ResponseType.DEFAULT_5XX = new ResponseType('DEFAULT_5XX');
/**
* The gateway response for an AWS authentication token expired error.
*/
ResponseType.EXPIRED_TOKEN = new ResponseType('EXPIRED_TOKEN');
/**
* The gateway response for an invalid AWS signature error.
*/
ResponseType.INVALID_SIGNATURE = new ResponseType('INVALID_SIGNATURE');
/**
* The gateway response for an integration failed error.
*/
ResponseType.INTEGRATION_FAILURE = new ResponseType('INTEGRATION_FAILURE');
/**
* The gateway response for an integration timed out error.
*/
ResponseType.INTEGRATION_TIMEOUT = new ResponseType('INTEGRATION_TIMEOUT');
/**
* The gateway response for an invalid API key submitted for a method requiring an API key.
*/
ResponseType.INVALID_API_KEY = new ResponseType('INVALID_API_KEY');
/**
* The gateway response for a missing authentication token error,
* including the cases when the client attempts to invoke an unsupported API method or resource.
*/
ResponseType.MISSING_AUTHENTICATION_TOKEN = new ResponseType('MISSING_AUTHENTICATION_TOKEN');
/**
* The gateway response for the usage plan quota exceeded error.
*/
ResponseType.QUOTA_EXCEEDED = new ResponseType('QUOTA_EXCEEDED');
/**
* The gateway response for the request too large error.
*/
ResponseType.REQUEST_TOO_LARGE = new ResponseType('REQUEST_TOO_LARGE');
/**
* The gateway response when API Gateway cannot find the specified resource
* after an API request passes authentication and authorization.
*/
ResponseType.RESOURCE_NOT_FOUND = new ResponseType('RESOURCE_NOT_FOUND');
/**
* The gateway response when usage plan, method, stage, or account level throttling limits exceeded.
*/
ResponseType.THROTTLED = new ResponseType('THROTTLED');
/**
* The gateway response when the custom or Amazon Cognito authorizer failed to authenticate the caller.
*/
ResponseType.UNAUTHORIZED = new ResponseType('UNAUTHORIZED');
/**
* The gateway response when a payload is of an unsupported media type, if strict passthrough behavior is enabled.
*/
ResponseType.UNSUPPORTED_MEDIA_TYPE = new ResponseType('UNSUPPORTED_MEDIA_TYPE');
/**
* The gateway response when a request is blocked by AWS WAF.
*/
ResponseType.WAF_FILTERED = new ResponseType('WAF_FILTERED');
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gateway-response.js","sourceRoot":"","sources":["gateway-response.ts"],"names":[],"mappings":"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","sourcesContent":["import { IResource, Resource } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnGatewayResponse, CfnGatewayResponseProps } from './apigateway.generated';\nimport { IRestApi } from './restapi';\n\n/**\n * Represents gateway response resource.\n */\nexport interface IGatewayResponse extends IResource {\n}\n\n/**\n * Properties for a new gateway response.\n */\nexport interface GatewayResponseProps extends GatewayResponseOptions {\n  /**\n   * Rest api resource to target.\n   */\n  readonly restApi: IRestApi;\n}\n\n/**\n * Options to add gateway response.\n */\nexport interface GatewayResponseOptions {\n  /**\n   * Response type to associate with gateway response.\n   * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/supported-gateway-response-types.html\n   */\n  readonly type: ResponseType;\n\n  /**\n   * Http status code for response.\n   * @default - standard http status code for the response type.\n   */\n  readonly statusCode?: string;\n\n  /**\n   * Custom headers parameters for response.\n   * @default - no headers\n   */\n  readonly responseHeaders?: { [key: string]: string };\n\n  /**\n   * Custom templates to get mapped as response.\n   * @default - Response from api will be returned without applying any transformation.\n   */\n  readonly templates?: { [key: string]: string };\n\n}\n\n/**\n * Configure the response received by clients, produced from the API Gateway backend.\n *\n * @resource AWS::ApiGateway::GatewayResponse\n */\nexport class GatewayResponse extends Resource implements IGatewayResponse {\n  constructor(scope: Construct, id: string, props: GatewayResponseProps) {\n    super(scope, id);\n\n    const gatewayResponseProps: CfnGatewayResponseProps = {\n      restApiId: props.restApi.restApiId,\n      responseType: props.type.responseType,\n      responseParameters: this.buildResponseParameters(props.responseHeaders),\n      responseTemplates: props.templates,\n      statusCode: props.statusCode,\n    };\n\n    const resource = new CfnGatewayResponse(this, 'Resource', gatewayResponseProps);\n\n    const deployment = props.restApi.latestDeployment;\n    if (deployment) {\n      deployment.node.addDependency(resource);\n      deployment.addToLogicalId({\n        gatewayResponse: {\n          ...gatewayResponseProps,\n        },\n      });\n    }\n\n    this.node.defaultChild = resource;\n  }\n\n  private buildResponseParameters(responseHeaders?: { [key: string]: string }): { [key: string]: string } | undefined {\n    if (!responseHeaders) {\n      return undefined;\n    }\n\n    const responseParameters: { [key: string]: string } = {};\n    for (const [header, value] of Object.entries(responseHeaders)) {\n      responseParameters[`gatewayresponse.header.${header}`] = value;\n    }\n    return responseParameters;\n  }\n}\n\n/**\n * Supported types of gateway responses.\n * @see https://docs.aws.amazon.com/apigateway/latest/developerguide/supported-gateway-response-types.html\n */\nexport class ResponseType {\n  /**\n   * The gateway response for authorization failure.\n   */\n  public static readonly ACCESS_DENIED = new ResponseType('ACCESS_DENIED');\n\n  /**\n   * The gateway response for an invalid API configuration.\n   */\n  public static readonly API_CONFIGURATION_ERROR = new ResponseType('API_CONFIGURATION_ERROR');\n\n  /**\n   * The gateway response when a custom or Amazon Cognito authorizer failed to authenticate the caller.\n   */\n  public static readonly AUTHORIZER_FAILURE = new ResponseType('AUTHORIZER_FAILURE');\n\n  /**\n   * The gateway response for failing to connect to a custom or Amazon Cognito authorizer.\n   */\n  public static readonly AUTHORIZER_CONFIGURATION_ERROR = new ResponseType('AUTHORIZER_CONFIGURATION_ERROR');\n\n  /**\n   * The gateway response when the request parameter cannot be validated according to an enabled request validator.\n   */\n  public static readonly BAD_REQUEST_PARAMETERS = new ResponseType('BAD_REQUEST_PARAMETERS');\n\n  /**\n   * The gateway response when the request body cannot be validated according to an enabled request validator.\n   */\n  public static readonly BAD_REQUEST_BODY = new ResponseType('BAD_REQUEST_BODY');\n\n  /**\n   * The default gateway response for an unspecified response type with the status code of 4XX.\n   */\n  public static readonly DEFAULT_4XX = new ResponseType('DEFAULT_4XX');\n\n  /**\n   * The default gateway response for an unspecified response type with a status code of 5XX.\n   */\n  public static readonly DEFAULT_5XX = new ResponseType('DEFAULT_5XX');\n\n  /**\n   * The gateway response for an AWS authentication token expired error.\n   */\n  public static readonly EXPIRED_TOKEN = new ResponseType('EXPIRED_TOKEN');\n\n  /**\n   * The gateway response for an invalid AWS signature error.\n   */\n  public static readonly INVALID_SIGNATURE = new ResponseType('INVALID_SIGNATURE');\n\n  /**\n   * The gateway response for an integration failed error.\n   */\n  public static readonly INTEGRATION_FAILURE = new ResponseType('INTEGRATION_FAILURE');\n\n  /**\n   * The gateway response for an integration timed out error.\n   */\n  public static readonly INTEGRATION_TIMEOUT = new ResponseType('INTEGRATION_TIMEOUT');\n\n  /**\n   * The gateway response for an invalid API key submitted for a method requiring an API key.\n   */\n  public static readonly INVALID_API_KEY = new ResponseType('INVALID_API_KEY');\n\n  /**\n   * The gateway response for a missing authentication token error,\n   * including the cases when the client attempts to invoke an unsupported API method or resource.\n   */\n  public static readonly MISSING_AUTHENTICATION_TOKEN = new ResponseType('MISSING_AUTHENTICATION_TOKEN');\n\n  /**\n   * The gateway response for the usage plan quota exceeded error.\n   */\n  public static readonly QUOTA_EXCEEDED = new ResponseType('QUOTA_EXCEEDED');\n\n  /**\n   * The gateway response for the request too large error.\n   */\n  public static readonly REQUEST_TOO_LARGE = new ResponseType('REQUEST_TOO_LARGE');\n\n  /**\n   * The gateway response when API Gateway cannot find the specified resource\n   * after an API request passes authentication and authorization.\n   */\n  public static readonly RESOURCE_NOT_FOUND = new ResponseType('RESOURCE_NOT_FOUND');\n\n  /**\n   * The gateway response when usage plan, method, stage, or account level throttling limits exceeded.\n   */\n  public static readonly THROTTLED = new ResponseType('THROTTLED');\n\n  /**\n   * The gateway response when the custom or Amazon Cognito authorizer failed to authenticate the caller.\n   */\n  public static readonly UNAUTHORIZED = new ResponseType('UNAUTHORIZED');\n\n  /**\n   * The gateway response when a payload is of an unsupported media type, if strict passthrough behavior is enabled.\n   */\n  public static readonly UNSUPPORTED_MEDIA_TYPE = new ResponseType('UNSUPPORTED_MEDIA_TYPE');\n\n  /**\n   * The gateway response when a request is blocked by AWS WAF.\n   */\n  public static readonly WAF_FILTERED = new ResponseType('WAF_FILTERED');\n\n  /** A custom response type to support future cases. */\n  public static of(type: string): ResponseType {\n    return new ResponseType(type.toUpperCase());\n  }\n\n  /**\n   * Valid value of response type.\n   */\n  public readonly responseType: string;\n\n  private constructor(type: string) {\n    this.responseType = type;\n  }\n\n}\n"]}