@aws-cdk/aws-apigateway
Version:
The CDK Construct Library for AWS::ApiGateway
199 lines • 19.2 kB
JavaScript
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":"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","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}"]}
;