UNPKG

14.9 kBJavaScriptView Raw
1"use strict";
2var _a, _b;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.CustomResource = exports.CustomResourceProvider = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const core = require("@aws-cdk/core");
8/**
9 * Represents a provider for an AWS CloudFormation custom resources.
10 *
11 * @deprecated use core.CustomResource instead
12 */
13class CustomResourceProvider {
14 /**
15 * @param serviceToken the ServiceToken which contains the ARN for this provider.
16 */
17 constructor(serviceToken) {
18 this.serviceToken = serviceToken;
19 }
20 /**
21 * The Lambda provider that implements this custom resource.
22 *
23 * We recommend using a lambda.SingletonFunction for this.
24 */
25 static fromLambda(handler) {
26 try {
27 jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResourceProvider#fromLambda", "use core.CustomResource instead");
28 }
29 catch (error) {
30 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
31 Error.captureStackTrace(error, this.fromLambda);
32 }
33 throw error;
34 }
35 return new CustomResourceProvider(handler.functionArn);
36 }
37 /**
38 * The SNS Topic for the provider that implements this custom resource.
39 */
40 static fromTopic(topic) {
41 try {
42 jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResourceProvider#fromTopic", "use core.CustomResource instead");
43 }
44 catch (error) {
45 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
46 Error.captureStackTrace(error, this.fromTopic);
47 }
48 throw error;
49 }
50 return new CustomResourceProvider(topic.topicArn);
51 }
52 /**
53 * Use AWS Lambda as a provider.
54 * @deprecated use `fromLambda`
55 */
56 static lambda(handler) { try {
57 jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResourceProvider#lambda", "use `fromLambda`");
58 }
59 catch (error) {
60 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
61 Error.captureStackTrace(error, this.lambda);
62 }
63 throw error;
64 } return this.fromLambda(handler); }
65 /**
66 * Use an SNS topic as the provider.
67 * @deprecated use `fromTopic`
68 */
69 static topic(topic) { try {
70 jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResourceProvider#topic", "use `fromTopic`");
71 }
72 catch (error) {
73 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
74 Error.captureStackTrace(error, this.topic);
75 }
76 throw error;
77 } return this.fromTopic(topic); }
78 bind(_) {
79 try {
80 jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResourceProvider#bind", "use core.CustomResource instead");
81 }
82 catch (error) {
83 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
84 Error.captureStackTrace(error, this.bind);
85 }
86 throw error;
87 }
88 return { serviceToken: this.serviceToken };
89 }
90}
91exports.CustomResourceProvider = CustomResourceProvider;
92_a = JSII_RTTI_SYMBOL_1;
93CustomResourceProvider[_a] = { fqn: "@aws-cdk/aws-cloudformation.CustomResourceProvider", version: "1.174.0" };
94/**
95 * Deprecated.
96 * @deprecated use `core.CustomResource`
97 */
98class CustomResource extends core.CustomResource {
99 constructor(scope, id, props) {
100 super(scope, id, {
101 pascalCaseProperties: true,
102 properties: props.properties,
103 removalPolicy: props.removalPolicy,
104 resourceType: props.resourceType,
105 serviceToken: core.Lazy.string({ produce: () => props.provider.bind(this).serviceToken }),
106 });
107 try {
108 jsiiDeprecationWarnings.print("@aws-cdk/aws-cloudformation.CustomResource", "use `core.CustomResource`");
109 jsiiDeprecationWarnings._aws_cdk_aws_cloudformation_CustomResourceProps(props);
110 }
111 catch (error) {
112 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
113 Error.captureStackTrace(error, CustomResource);
114 }
115 throw error;
116 }
117 }
118}
119exports.CustomResource = CustomResource;
120_b = JSII_RTTI_SYMBOL_1;
121CustomResource[_b] = { fqn: "@aws-cdk/aws-cloudformation.CustomResource", version: "1.174.0" };
122//# 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"]}
\No newline at end of file