UNPKG

@aws-cdk/aws-apigateway

Version:

The CDK Construct Library for AWS::ApiGateway

161 lines 19.8 kB
"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"]}