UNPKG

@aws-cdk/aws-cloudformation

Version:

The CDK Construct Library for AWS::CloudFormation

122 lines 14.9 kB
"use strict"; var _a, _b; Object.defineProperty(exports, "__esModule", { value: true }); exports.CustomResource = exports.CustomResourceProvider = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const core = require("@aws-cdk/core"); /** * Represents a provider for an AWS CloudFormation custom resources. * * @deprecated use core.CustomResource instead */ class CustomResourceProvider { /** * @param serviceToken the ServiceToken which contains the ARN for this provider. */ constructor(serviceToken) { this.serviceToken = serviceToken; } /** * The Lambda provider that implements this custom resource. * * We recommend using a lambda.SingletonFunction for this. */ static fromLambda(handler) { try { jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResourceProvider#fromLambda", "use core.CustomResource instead"); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromLambda); } throw error; } return new CustomResourceProvider(handler.functionArn); } /** * The SNS Topic for the provider that implements this custom resource. */ static fromTopic(topic) { try { jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResourceProvider#fromTopic", "use core.CustomResource instead"); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromTopic); } throw error; } return new CustomResourceProvider(topic.topicArn); } /** * Use AWS Lambda as a provider. * @deprecated use `fromLambda` */ static lambda(handler) { try { jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResourceProvider#lambda", "use `fromLambda`"); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.lambda); } throw error; } return this.fromLambda(handler); } /** * Use an SNS topic as the provider. * @deprecated use `fromTopic` */ static topic(topic) { try { jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResourceProvider#topic", "use `fromTopic`"); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.topic); } throw error; } return this.fromTopic(topic); } bind(_) { try { jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResourceProvider#bind", "use core.CustomResource instead"); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.bind); } throw error; } return { serviceToken: this.serviceToken }; } } exports.CustomResourceProvider = CustomResourceProvider; _a = JSII_RTTI_SYMBOL_1; CustomResourceProvider[_a] = { fqn: "@aws-cdk/aws-cloudformation.CustomResourceProvider", version: "1.203.0" }; /** * Deprecated. * @deprecated use `core.CustomResource` */ class CustomResource extends core.CustomResource { constructor(scope, id, props) { super(scope, id, { pascalCaseProperties: true, properties: props.properties, removalPolicy: props.removalPolicy, resourceType: props.resourceType, serviceToken: core.Lazy.string({ produce: () => props.provider.bind(this).serviceToken }), }); try { jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResource", "use `core.CustomResource`"); jsiiDeprecationWarnings._aws_cdk_aws_cloudformation_CustomResourceProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, CustomResource); } throw error; } } } exports.CustomResource = CustomResource; _b = JSII_RTTI_SYMBOL_1; CustomResource[_b] = { fqn: "@aws-cdk/aws-cloudformation.CustomResource", version: "1.203.0" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-resource.js","sourceRoot":"","sources":["custom-resource.ts"],"names":[],"mappings":";;;;;;AAEA,sCAAsC;AAuCtC;;;;GAIG;AACH,MAAa,sBAAsB;IA6BjC;;OAEG;IACH,YAAoC,YAAoB;QAApB,iBAAY,GAAZ,YAAY,CAAQ;KAAK;IA/B7D;;;;OAIG;IACI,MAAM,CAAC,UAAU,CAAC,OAAyB;;;;;;;;;;QAChD,OAAO,IAAI,sBAAsB,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;KACxD;IAED;;OAEG;IACI,MAAM,CAAC,SAAS,CAAC,KAAiB;;;;;;;;;;QACvC,OAAO,IAAI,sBAAsB,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;KACnD;IAED;;;OAGG;IACI,MAAM,CAAC,MAAM,CAAC,OAAyB;;;;;;;;MAAI,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE;IAEpF;;;OAGG;IACI,MAAM,CAAC,KAAK,CAAC,KAAiB;;;;;;;;MAAI,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE;IAOjE,IAAI,CAAC,CAAY;;;;;;;;;;QACtB,OAAO,EAAE,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;KAC5C;;AApCH,wDAqCC;;;AAyFD;;;GAGG;AACH,MAAa,cAAe,SAAQ,IAAI,CAAC,cAAc;IACrD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0B;QAClE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,oBAAoB,EAAE,IAAI;YAC1B,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,aAAa,EAAE,KAAK,CAAC,aAAa;YAClC,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,YAAY,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,YAAY,EAAE,CAAC;SAC1F,CAAC,CAAC;;;;;;;+CARM,cAAc;;;;KASxB;;AATH,wCAUC","sourcesContent":["import * as lambda from '@aws-cdk/aws-lambda';\nimport * as sns from '@aws-cdk/aws-sns';\nimport * as core from '@aws-cdk/core';\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 { Construct } from '@aws-cdk/core';\n\n/**\n * Collection of arbitrary properties\n *\n * @deprecated this type has been deprecated in favor of using a key-value type directly\n */\nexport type Properties = {[key: string]: any};\n\n/**\n * Configuration options for custom resource providers.\n *\n * @deprecated used in {@link ICustomResourceProvider} which is now deprecated\n */\nexport interface CustomResourceProviderConfig {\n  /**\n   * The ARN of the SNS topic or the AWS Lambda function which implements this\n   * provider.\n   */\n  readonly serviceToken: string;\n}\n\n/**\n * Represents a provider for an AWS CloudFormation custom resources.\n * @deprecated use `core.ICustomResourceProvider`\n */\nexport interface ICustomResourceProvider {\n  /**\n   * Called when this provider is used by a `CustomResource`.\n   * @param scope The resource that uses this provider.\n   * @returns provider configuration\n   */\n  bind(scope: Construct): CustomResourceProviderConfig;\n}\n\n/**\n * Represents a provider for an AWS CloudFormation custom resources.\n *\n * @deprecated use core.CustomResource instead\n */\nexport class CustomResourceProvider implements ICustomResourceProvider {\n  /**\n   * The Lambda provider that implements this custom resource.\n   *\n   * We recommend using a lambda.SingletonFunction for this.\n   */\n  public static fromLambda(handler: lambda.IFunction): CustomResourceProvider {\n    return new CustomResourceProvider(handler.functionArn);\n  }\n\n  /**\n   * The SNS Topic for the provider that implements this custom resource.\n   */\n  public static fromTopic(topic: sns.ITopic): CustomResourceProvider {\n    return new CustomResourceProvider(topic.topicArn);\n  }\n\n  /**\n   * Use AWS Lambda as a provider.\n   * @deprecated use `fromLambda`\n   */\n  public static lambda(handler: lambda.IFunction) { return this.fromLambda(handler); }\n\n  /**\n   * Use an SNS topic as the provider.\n   * @deprecated use `fromTopic`\n   */\n  public static topic(topic: sns.ITopic) { return this.fromTopic(topic); }\n\n  /**\n   * @param serviceToken the ServiceToken which contains the ARN for this provider.\n   */\n  private constructor(public readonly serviceToken: string) { }\n\n  public bind(_: Construct): CustomResourceProviderConfig {\n    return { serviceToken: this.serviceToken };\n  }\n}\n\n/**\n * Properties to provide a Lambda-backed custom resource\n * @deprecated use `core.CustomResourceProps`\n */\nexport interface CustomResourceProps {\n  /**\n   * The provider which implements the custom resource.\n   *\n   * You can implement a provider by listening to raw AWS CloudFormation events\n   * through an SNS topic or an AWS Lambda function or use the CDK's custom\n   * [resource provider framework] which makes it easier to implement robust\n   * providers.\n   *\n   * [resource provider framework]: https://docs.aws.amazon.com/cdk/api/latest/docs/custom-resources-readme.html\n   *\n   * ```ts\n   * import * as custom_resources from '@aws-cdk/custom-resources';\n   * import * as lambda from '@aws-cdk/aws-lambda';\n   * import { Stack } from '@aws-cdk/core';\n   * declare const myOnEventLambda: lambda.Function;\n   * declare const myIsCompleteLambda: lambda.Function;\n   * const stack = new Stack();\n   *\n   * const provider = new custom_resources.Provider(stack, 'myProvider', {\n   *   onEventHandler: myOnEventLambda,\n   *   isCompleteHandler: myIsCompleteLambda, // optional\n   * });\n   * ```\n   *\n   * ```ts\n   * import * as cloudformation from '@aws-cdk/aws-cloudformation';\n   * import * as lambda from '@aws-cdk/aws-lambda';\n   * declare const myFunction: lambda.Function;\n   *\n   * // invoke an AWS Lambda function when a lifecycle event occurs:\n   * const provider = cloudformation.CustomResourceProvider.fromLambda(myFunction);\n   * ```\n   *\n   * ```ts\n   * import * as cloudformation from '@aws-cdk/aws-cloudformation';\n   * import * as sns from '@aws-cdk/aws-sns';\n   * declare const myTopic: sns.Topic;\n   *\n   * // publish lifecycle events to an SNS topic:\n   * const provider = cloudformation.CustomResourceProvider.fromTopic(myTopic);\n   * ```\n   */\n  readonly provider: ICustomResourceProvider;\n\n  /**\n   * Properties to pass to the Lambda\n   *\n   * @default - No properties.\n   */\n  readonly properties?: Properties;\n\n  /**\n   * For custom resources, you can specify AWS::CloudFormation::CustomResource\n   * (the default) as the resource type, or you can specify your own resource\n   * type name. For example, you can use \"Custom::MyCustomResourceTypeName\".\n   *\n   * Custom resource type names must begin with \"Custom::\" and can include\n   * alphanumeric characters and the following characters: _@-. You can specify\n   * a custom resource type name up to a maximum length of 60 characters. You\n   * cannot change the type during an update.\n   *\n   * Using your own resource type names helps you quickly differentiate the\n   * types of custom resources in your stack. For example, if you had two custom\n   * resources that conduct two different ping tests, you could name their type\n   * as Custom::PingTester to make them easily identifiable as ping testers\n   * (instead of using AWS::CloudFormation::CustomResource).\n   *\n   * @see\n   * https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cfn-customresource.html#aws-cfn-resource-type-name\n   *\n   * @default - AWS::CloudFormation::CustomResource\n   */\n  readonly resourceType?: string;\n\n  /**\n   * The policy to apply when this resource is removed from the application.\n   *\n   * @default cdk.RemovalPolicy.Destroy\n   */\n  readonly removalPolicy?: core.RemovalPolicy;\n}\n\n/**\n * Deprecated.\n * @deprecated use `core.CustomResource`\n */\nexport class CustomResource extends core.CustomResource {\n  constructor(scope: Construct, id: string, props: CustomResourceProps) {\n    super(scope, id, {\n      pascalCaseProperties: true,\n      properties: props.properties,\n      removalPolicy: props.removalPolicy,\n      resourceType: props.resourceType,\n      serviceToken: core.Lazy.string({ produce: () => props.provider.bind(this).serviceToken }),\n    });\n  }\n}\n"]}