UNPKG

@aws-cdk/aws-apigateway

Version:

The CDK Construct Library for AWS::ApiGateway

199 lines 19.2 kB
"use strict"; var _a, _b, _c, _d; Object.defineProperty(exports, "__esModule", { value: true }); exports.AssetApiDefinition = exports.InlineApiDefinition = exports.S3ApiDefinition = exports.ApiDefinition = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const s3_assets = require("@aws-cdk/aws-s3-assets"); // keep this import separate from other imports to reduce chance for merge conflicts with v2-main // eslint-disable-next-line no-duplicate-imports, import/order const cxapi = require("@aws-cdk/cx-api"); const constructs_1 = require("constructs"); /** * Represents an OpenAPI definition asset. */ class ApiDefinition { /** * Creates an API definition from a specification file in an S3 bucket */ static fromBucket(bucket, key, objectVersion) { return new S3ApiDefinition(bucket, key, objectVersion); } /** * Create an API definition from an inline object. The inline object must follow the * schema of OpenAPI 2.0 or OpenAPI 3.0 * * @example * * apigateway.ApiDefinition.fromInline({ * openapi: '3.0.2', * paths: { * '/pets': { * get: { * 'responses': { * 200: { * content: { * 'application/json': { * schema: { * $ref: '#/components/schemas/Empty', * }, * }, * }, * }, * }, * 'x-amazon-apigateway-integration': { * responses: { * default: { * statusCode: '200', * }, * }, * requestTemplates: { * 'application/json': '{"statusCode": 200}', * }, * passthroughBehavior: 'when_no_match', * type: 'mock', * }, * }, * }, * }, * components: { * schemas: { * Empty: { * title: 'Empty Schema', * type: 'object', * }, * }, * }, * }); */ static fromInline(definition) { return new InlineApiDefinition(definition); } /** * Loads the API specification from a local disk asset. */ static fromAsset(file, options) { return new AssetApiDefinition(file, options); } /** * Called after the CFN RestApi resource has been created to allow the Api * Definition to bind to it. Specifically it's required to allow assets to add * metadata for tooling like SAM CLI to be able to find their origins. */ bindAfterCreate(_scope, _restApi) { try { jsiiDeprecationWarnings._aws_cdk_aws_apigateway_IRestApi(_restApi); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.bindAfterCreate); } throw error; } return; } } exports.ApiDefinition = ApiDefinition; _a = JSII_RTTI_SYMBOL_1; ApiDefinition[_a] = { fqn: "@aws-cdk/aws-apigateway.ApiDefinition", version: "1.204.0" }; /** * OpenAPI specification from an S3 archive. */ class S3ApiDefinition extends ApiDefinition { constructor(bucket, key, objectVersion) { super(); this.key = key; this.objectVersion = objectVersion; if (!bucket.bucketName) { throw new Error('bucketName is undefined for the provided bucket'); } this.bucketName = bucket.bucketName; } bind(_scope) { return { s3Location: { bucket: this.bucketName, key: this.key, version: this.objectVersion, }, }; } } exports.S3ApiDefinition = S3ApiDefinition; _b = JSII_RTTI_SYMBOL_1; S3ApiDefinition[_b] = { fqn: "@aws-cdk/aws-apigateway.S3ApiDefinition", version: "1.204.0" }; /** * OpenAPI specification from an inline JSON object. */ class InlineApiDefinition extends ApiDefinition { constructor(definition) { super(); this.definition = definition; if (typeof (definition) !== 'object') { throw new Error('definition should be of type object'); } if (Object.keys(definition).length === 0) { throw new Error('JSON definition cannot be empty'); } } bind(_scope) { return { inlineDefinition: this.definition, }; } } exports.InlineApiDefinition = InlineApiDefinition; _c = JSII_RTTI_SYMBOL_1; InlineApiDefinition[_c] = { fqn: "@aws-cdk/aws-apigateway.InlineApiDefinition", version: "1.204.0" }; /** * OpenAPI specification from a local file. */ class AssetApiDefinition extends ApiDefinition { constructor(path, options = {}) { super(); this.path = path; this.options = options; } bind(scope) { // If the same AssetAPIDefinition is used multiple times, retain only the first instantiation. if (this.asset === undefined) { this.asset = new s3_assets.Asset(scope, 'APIDefinition', { path: this.path, ...this.options, }); } if (this.asset.isZipArchive) { throw new Error(`Asset cannot be a .zip file or a directory (${this.path})`); } return { s3Location: { bucket: this.asset.s3BucketName, key: this.asset.s3ObjectKey, }, }; } bindAfterCreate(scope, restApi) { try { jsiiDeprecationWarnings._aws_cdk_aws_apigateway_IRestApi(restApi); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.bindAfterCreate); } throw error; } if (!scope.node.tryGetContext(cxapi.ASSET_RESOURCE_METADATA_ENABLED_CONTEXT)) { return; // not enabled } if (!this.asset) { throw new Error('bindToResource() must be called after bind()'); } const child = constructs_1.Node.of(restApi).defaultChild; child.addMetadata(cxapi.ASSET_RESOURCE_METADATA_PATH_KEY, this.asset.assetPath); child.addMetadata(cxapi.ASSET_RESOURCE_METADATA_PROPERTY_KEY, 'BodyS3Location'); } } exports.AssetApiDefinition = AssetApiDefinition; _d = JSII_RTTI_SYMBOL_1; AssetApiDefinition[_d] = { fqn: "@aws-cdk/aws-apigateway.AssetApiDefinition", version: "1.204.0" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-definition.js","sourceRoot":"","sources":["api-definition.ts"],"names":[],"mappings":";;;;;;AACA,oDAAoD;AAEpD,iGAAiG;AACjG,8DAA8D;AAC9D,yCAAyC;AACzC,2CAAkC;AAKlC;;GAEG;AACH,MAAsB,aAAa;IACjC;;OAEG;IACI,MAAM,CAAC,UAAU,CAAC,MAAkB,EAAE,GAAW,EAAE,aAAsB;QAC9E,OAAO,IAAI,eAAe,CAAC,MAAM,EAAE,GAAG,EAAE,aAAa,CAAC,CAAC;KACxD;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA8CG;IACI,MAAM,CAAC,UAAU,CAAC,UAAe;QACtC,OAAO,IAAI,mBAAmB,CAAC,UAAU,CAAC,CAAC;KAC5C;IAED;;OAEG;IACI,MAAM,CAAC,SAAS,CAAC,IAAY,EAAE,OAAgC;QACpE,OAAO,IAAI,kBAAkB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;KAC9C;IAWD;;;;OAIG;IACI,eAAe,CAAC,MAAiB,EAAE,QAAkB;;;;;;;;;;QAC1D,OAAO;KACR;;AAlFH,sCAmFC;;;AAoCD;;GAEG;AACH,MAAa,eAAgB,SAAQ,aAAa;IAGhD,YAAY,MAAkB,EAAU,GAAW,EAAU,aAAsB;QACjF,KAAK,EAAE,CAAC;QAD8B,QAAG,GAAH,GAAG,CAAQ;QAAU,kBAAa,GAAb,aAAa,CAAS;QAGjF,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YACtB,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;SACpE;QAED,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;KACrC;IAEM,IAAI,CAAC,MAAiB;QAC3B,OAAO;YACL,UAAU,EAAE;gBACV,MAAM,EAAE,IAAI,CAAC,UAAU;gBACvB,GAAG,EAAE,IAAI,CAAC,GAAG;gBACb,OAAO,EAAE,IAAI,CAAC,aAAa;aAC5B;SACF,CAAC;KACH;;AArBH,0CAsBC;;;AAED;;GAEG;AACH,MAAa,mBAAoB,SAAQ,aAAa;IACpD,YAAoB,UAAe;QACjC,KAAK,EAAE,CAAC;QADU,eAAU,GAAV,UAAU,CAAK;QAGjC,IAAI,OAAM,CAAC,UAAU,CAAC,KAAK,QAAQ,EAAE;YACnC,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;SACxD;QAED,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;YACxC,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;SACpD;KACF;IAEM,IAAI,CAAC,MAAiB;QAC3B,OAAO;YACL,gBAAgB,EAAE,IAAI,CAAC,UAAU;SAClC,CAAC;KACH;;AAjBH,kDAkBC;;;AAED;;GAEG;AACH,MAAa,kBAAmB,SAAQ,aAAa;IAGnD,YAA6B,IAAY,EAAmB,UAAkC,EAAG;QAC/F,KAAK,EAAE,CAAC;QADmB,SAAI,GAAJ,IAAI,CAAQ;QAAmB,YAAO,GAAP,OAAO,CAA8B;KAEhG;IAEM,IAAI,CAAC,KAAgB;QAC1B,8FAA8F;QAC9F,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE;YAC5B,IAAI,CAAC,KAAK,GAAG,IAAI,SAAS,CAAC,KAAK,CAAC,KAAK,EAAE,eAAe,EAAE;gBACvD,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,GAAG,IAAI,CAAC,OAAO;aAChB,CAAC,CAAC;SACJ;QAED,IAAI,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,+CAA+C,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;SAC9E;QAED,OAAO;YACL,UAAU,EAAE;gBACV,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY;gBAC/B,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW;aAC5B;SACF,CAAC;KACH;IAEM,eAAe,CAAC,KAAgB,EAAE,OAAiB;;;;;;;;;;QACxD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,uCAAuC,CAAC,EAAE;YAC5E,OAAO,CAAC,cAAc;SACvB;QAED,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;SACjE;QAED,MAAM,KAAK,GAAG,iBAAI,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,YAA0B,CAAC;QAC1D,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,gCAAgC,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAChF,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,oCAAoC,EAAE,gBAAgB,CAAC,CAAC;KACjF;;AAxCH,gDAyCC","sourcesContent":["import * as s3 from '@aws-cdk/aws-s3';\nimport * as s3_assets from '@aws-cdk/aws-s3-assets';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { Node } from 'constructs';\nimport { CfnRestApi } from './apigateway.generated';\nimport { IRestApi } from './restapi';\nimport { Construct } from '@aws-cdk/core';\n\n/**\n * Represents an OpenAPI definition asset.\n */\nexport abstract class ApiDefinition {\n  /**\n   * Creates an API definition from a specification file in an S3 bucket\n   */\n  public static fromBucket(bucket: s3.IBucket, key: string, objectVersion?: string): S3ApiDefinition {\n    return new S3ApiDefinition(bucket, key, objectVersion);\n  }\n\n  /**\n   * Create an API definition from an inline object. The inline object must follow the\n   * schema of OpenAPI 2.0 or OpenAPI 3.0\n   *\n   * @example\n   *\n   *   apigateway.ApiDefinition.fromInline({\n   *     openapi: '3.0.2',\n   *     paths: {\n   *       '/pets': {\n   *         get: {\n   *           'responses': {\n   *             200: {\n   *               content: {\n   *                 'application/json': {\n   *                   schema: {\n   *                     $ref: '#/components/schemas/Empty',\n   *                   },\n   *                 },\n   *               },\n   *             },\n   *           },\n   *           'x-amazon-apigateway-integration': {\n   *             responses: {\n   *               default: {\n   *                 statusCode: '200',\n   *               },\n   *             },\n   *             requestTemplates: {\n   *               'application/json': '{\"statusCode\": 200}',\n   *             },\n   *             passthroughBehavior: 'when_no_match',\n   *             type: 'mock',\n   *           },\n   *         },\n   *       },\n   *     },\n   *     components: {\n   *       schemas: {\n   *         Empty: {\n   *           title: 'Empty Schema',\n   *           type: 'object',\n   *         },\n   *       },\n   *     },\n   *   });\n   */\n  public static fromInline(definition: any): InlineApiDefinition {\n    return new InlineApiDefinition(definition);\n  }\n\n  /**\n   * Loads the API specification from a local disk asset.\n   */\n  public static fromAsset(file: string, options?: s3_assets.AssetOptions): AssetApiDefinition {\n    return new AssetApiDefinition(file, options);\n  }\n\n  /**\n   * Called when the specification is initialized to allow this object to bind\n   * to the stack, add resources and have fun.\n   *\n   * @param scope The binding scope. Don't be smart about trying to down-cast or\n   * assume it's initialized. You may just use it as a construct scope.\n   */\n  public abstract bind(scope: Construct): ApiDefinitionConfig;\n\n  /**\n   * Called after the CFN RestApi resource has been created to allow the Api\n   * Definition to bind to it. Specifically it's required to allow assets to add\n   * metadata for tooling like SAM CLI to be able to find their origins.\n   */\n  public bindAfterCreate(_scope: Construct, _restApi: IRestApi) {\n    return;\n  }\n}\n\n/**\n * S3 location of the API definition file\n */\nexport interface ApiDefinitionS3Location {\n  /** The S3 bucket */\n  readonly bucket: string;\n  /** The S3 key */\n  readonly key: string;\n  /**\n   * An optional version\n   * @default - latest version\n   */\n  readonly version?: string;\n}\n\n/**\n * Post-Binding Configuration for a CDK construct\n */\nexport interface ApiDefinitionConfig {\n  /**\n   * The location of the specification in S3 (mutually exclusive with `inlineDefinition`).\n   *\n   * @default - API definition is not an S3 location\n   */\n  readonly s3Location?: ApiDefinitionS3Location;\n\n  /**\n   * Inline specification (mutually exclusive with `s3Location`).\n   *\n   * @default - API definition is not defined inline\n   */\n  readonly inlineDefinition?: any;\n}\n\n/**\n * OpenAPI specification from an S3 archive.\n */\nexport class S3ApiDefinition extends ApiDefinition {\n  private bucketName: string;\n\n  constructor(bucket: s3.IBucket, private key: string, private objectVersion?: string) {\n    super();\n\n    if (!bucket.bucketName) {\n      throw new Error('bucketName is undefined for the provided bucket');\n    }\n\n    this.bucketName = bucket.bucketName;\n  }\n\n  public bind(_scope: Construct): ApiDefinitionConfig {\n    return {\n      s3Location: {\n        bucket: this.bucketName,\n        key: this.key,\n        version: this.objectVersion,\n      },\n    };\n  }\n}\n\n/**\n * OpenAPI specification from an inline JSON object.\n */\nexport class InlineApiDefinition extends ApiDefinition {\n  constructor(private definition: any) {\n    super();\n\n    if (typeof(definition) !== 'object') {\n      throw new Error('definition should be of type object');\n    }\n\n    if (Object.keys(definition).length === 0) {\n      throw new Error('JSON definition cannot be empty');\n    }\n  }\n\n  public bind(_scope: Construct): ApiDefinitionConfig {\n    return {\n      inlineDefinition: this.definition,\n    };\n  }\n}\n\n/**\n * OpenAPI specification from a local file.\n */\nexport class AssetApiDefinition extends ApiDefinition {\n  private asset?: s3_assets.Asset;\n\n  constructor(private readonly path: string, private readonly options: s3_assets.AssetOptions = { }) {\n    super();\n  }\n\n  public bind(scope: Construct): ApiDefinitionConfig {\n    // If the same AssetAPIDefinition is used multiple times, retain only the first instantiation.\n    if (this.asset === undefined) {\n      this.asset = new s3_assets.Asset(scope, 'APIDefinition', {\n        path: this.path,\n        ...this.options,\n      });\n    }\n\n    if (this.asset.isZipArchive) {\n      throw new Error(`Asset cannot be a .zip file or a directory (${this.path})`);\n    }\n\n    return {\n      s3Location: {\n        bucket: this.asset.s3BucketName,\n        key: this.asset.s3ObjectKey,\n      },\n    };\n  }\n\n  public bindAfterCreate(scope: Construct, restApi: IRestApi) {\n    if (!scope.node.tryGetContext(cxapi.ASSET_RESOURCE_METADATA_ENABLED_CONTEXT)) {\n      return; // not enabled\n    }\n\n    if (!this.asset) {\n      throw new Error('bindToResource() must be called after bind()');\n    }\n\n    const child = Node.of(restApi).defaultChild as CfnRestApi;\n    child.addMetadata(cxapi.ASSET_RESOURCE_METADATA_PATH_KEY, this.asset.assetPath);\n    child.addMetadata(cxapi.ASSET_RESOURCE_METADATA_PROPERTY_KEY, 'BodyS3Location');\n  }\n}"]}