@aws-solutions-constructs/aws-eventbridge-sns 2.97.0 → 2.98.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.jsii CHANGED
@@ -8,8 +8,8 @@
8
8
  "url": "https://aws.amazon.com"
9
9
  },
10
10
  "dependencies": {
11
- "@aws-solutions-constructs/core": "2.97.0",
12
- "aws-cdk-lib": "^2.233.0",
11
+ "@aws-solutions-constructs/core": "2.98.0",
12
+ "aws-cdk-lib": "^2.234.0",
13
13
  "constructs": "^10.0.0"
14
14
  },
15
15
  "dependencyClosure": {
@@ -667,6 +667,19 @@
667
667
  }
668
668
  }
669
669
  },
670
+ "aws-cdk-lib.aws_cases": {
671
+ "targets": {
672
+ "dotnet": {
673
+ "namespace": "Amazon.CDK.AWS.Cases"
674
+ },
675
+ "java": {
676
+ "package": "software.amazon.awscdk.services.cases"
677
+ },
678
+ "python": {
679
+ "module": "aws_cdk.aws_cases"
680
+ }
681
+ }
682
+ },
670
683
  "aws-cdk-lib.aws_cassandra": {
671
684
  "targets": {
672
685
  "dotnet": {
@@ -4631,6 +4644,22 @@
4631
4644
  }
4632
4645
  }
4633
4646
  },
4647
+ "aws-cdk-lib.interfaces.aws_cases": {
4648
+ "targets": {
4649
+ "dotnet": {
4650
+ "namespace": "Amazon.CDK.Interfaces.Cases"
4651
+ },
4652
+ "go": {
4653
+ "packageName": "interfacesawscases"
4654
+ },
4655
+ "java": {
4656
+ "package": "software.amazon.awscdk.interfaces.cases"
4657
+ },
4658
+ "python": {
4659
+ "module": "aws_cdk.interfaces.aws_cases"
4660
+ }
4661
+ }
4662
+ },
4634
4663
  "aws-cdk-lib.interfaces.aws_cassandra": {
4635
4664
  "targets": {
4636
4665
  "dotnet": {
@@ -8697,7 +8726,7 @@
8697
8726
  "abstract": true,
8698
8727
  "docs": {
8699
8728
  "default": "- None",
8700
- "remarks": "Setting\nthis value to `{}` will create a custom EventBus using all default properties. If neither this nor\n`existingEventBusInterface` is provided the construct will use the default EventBus. Providing both this and\n`existingEventBusInterface` results an error.",
8729
+ "remarks": "Setting\nthis value to `{}` will create a custom EventBus using all default properties. If neither this nor\n`existingEventBusInterface` is provided the construct will use the default EventBus. Providing both this and\n`existingEventBusInterface` causes an error.",
8701
8730
  "summary": "Optional - user provided properties to override the default properties when creating a custom EventBus."
8702
8731
  },
8703
8732
  "immutable": true,
@@ -8715,8 +8744,8 @@
8715
8744
  "abstract": true,
8716
8745
  "docs": {
8717
8746
  "default": "- None",
8718
- "remarks": "Providing both this and `eventBusProps`\nis an error.",
8719
- "summary": "Optional - user provided custom event bus for this construct to use."
8747
+ "remarks": "Providing both this and `eventBusProps`\ncauses an error.",
8748
+ "summary": "Optional - user provided custom EventBus for this construct to use."
8720
8749
  },
8721
8750
  "immutable": true,
8722
8751
  "locationInModule": {
@@ -8767,6 +8796,6 @@
8767
8796
  "symbolId": "lib/index:EventbridgeToSnsProps"
8768
8797
  }
8769
8798
  },
8770
- "version": "2.97.0",
8771
- "fingerprint": "079jTdQek/eqFInXxa6VIl4GCIFbzrn+twdvL/zFgS4="
8799
+ "version": "2.98.0",
8800
+ "fingerprint": "09k8DyIZGFwbccJeJYx6V5Z7M8FfBC/rK299aHlWksw="
8772
8801
  }
package/README.adoc CHANGED
@@ -18,14 +18,14 @@ image:https://img.shields.io/badge/cfn--resources-stable-success.svg?style=for-t
18
18
  [width="100%",cols="<46%,54%",options="header",]
19
19
  |===
20
20
  |*Language* |*Package*
21
- |image:https://docs.aws.amazon.com/cdk/api/latest/img/python32.png[Python
21
+ |image:https://docs.aws.amazon.com/images/solutions/latest/constructs/images/python32.png[Python
22
22
  Logo] Python
23
23
  |`aws_solutions_constructs.aws_eventbridge_sns`
24
24
 
25
- |image:https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png[Typescript
25
+ |image:https://docs.aws.amazon.com/images/solutions/latest/constructs/images/typescript32.png[Typescript
26
26
  Logo] Typescript |`@aws-solutions-constructs/aws-eventbridge-sns`
27
27
 
28
- |image:https://docs.aws.amazon.com/cdk/api/latest/img/java32.png[Java
28
+ |image:https://docs.aws.amazon.com/images/solutions/latest/constructs/images/java32.png[Java
29
29
  Logo] Java |`software.amazon.awsconstructs.services.eventbridgesns`
30
30
  |===
31
31
 
@@ -150,15 +150,15 @@ constructStack.getEncryptionKey().addToResourcePolicy(policyStatement);
150
150
 
151
151
  |existingEventBusInterface?
152
152
  |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.IEventBus.html[`events.IEventBus`]
153
- |Optional - user provided custom event bus for this construct to use. Providing both this and `eventBusProps` is
154
- an error.
153
+ |Optional - user provided custom EventBus for this construct to use. Providing both this and `eventBusProps`
154
+ causes an error.
155
155
 
156
156
  |eventBusProps?
157
157
  |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.EventBusProps.html[`events.EventBusProps`]
158
158
  |Optional - user provided properties to override the default properties when creating a custom EventBus. Setting
159
159
  this value to `{}` will create a custom EventBus using all default properties. If neither this nor
160
160
  `existingEventBusInterface` is provided the construct will use the default EventBus. Providing both this and
161
- `existingEventBusInterface` results an error.
161
+ `existingEventBusInterface` causes an error.
162
162
 
163
163
  |enableEncryptionWithCustomerManagedKey? |`boolean` |If no key is
164
164
  provided, this flag determines whether the SNS Topic is encrypted with a
package/lib/index.d.ts CHANGED
@@ -22,8 +22,8 @@ export interface EventbridgeToSnsProps {
22
22
  */
23
23
  readonly topicProps?: sns.TopicProps;
24
24
  /**
25
- * Optional - user provided custom event bus for this construct to use. Providing both this and `eventBusProps`
26
- * is an error.
25
+ * Optional - user provided custom EventBus for this construct to use. Providing both this and `eventBusProps`
26
+ * causes an error.
27
27
  *
28
28
  * @default - None
29
29
  */
@@ -32,7 +32,7 @@ export interface EventbridgeToSnsProps {
32
32
  * Optional - user provided properties to override the default properties when creating a custom EventBus. Setting
33
33
  * this value to `{}` will create a custom EventBus using all default properties. If neither this nor
34
34
  * `existingEventBusInterface` is provided the construct will use the default EventBus. Providing both this and
35
- * `existingEventBusInterface` results an error.
35
+ * `existingEventBusInterface` causes an error.
36
36
  *
37
37
  * @default - None
38
38
  */
package/lib/index.js CHANGED
@@ -71,5 +71,5 @@ class EventbridgeToSns extends constructs_1.Construct {
71
71
  }
72
72
  exports.EventbridgeToSns = EventbridgeToSns;
73
73
  _a = JSII_RTTI_SYMBOL_1;
74
- EventbridgeToSns[_a] = { fqn: "@aws-solutions-constructs/aws-eventbridge-sns.EventbridgeToSns", version: "2.97.0" };
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAcA,iDAAiD;AAEjD,2DAA2D;AAC3D,mCAAmC;AACnC,wFAAwF;AACxF,2CAAuC;AACvC,yDAA+D;AAC/D,iDAAuD;AA0DvD,MAAa,gBAAiB,SAAQ,sBAAS;IAM3C;;;;;;OAMG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA4B;QACpE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,QAAQ,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAEtC,IAAI,qBAAqB,GAAG,KAAK,CAAC,sCAAsC,CAAC;QACzE,IAAI,KAAK,CAAC,sCAAsC,KAAK,SAAS;YAC1D,KAAK,CAAC,sCAAsC,KAAK,IAAI,EAAE,CAAC;YAC1D,qBAAqB,GAAG,IAAI,CAAC;QAC/B,CAAC;QAED,uBAAuB;QACvB,MAAM,kBAAkB,GAAG,QAAQ,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,EAAE;YACvD,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;YACxC,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,sCAAsC,EAAE,qBAAqB;YAC7D,aAAa,EAAE,KAAK,CAAC,aAAa;YAClC,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;SAC7C,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,GAAG,kBAAkB,CAAC,KAAK,CAAC;QACzC,IAAI,CAAC,aAAa,GAAG,kBAAkB,CAAC,GAAG,CAAC;QAE5C,4CAA4C;QAE5C,2IAA2I;QAC3I,8IAA8I;QAC9I,0CAA0C;QAC1C,MAAM,kBAAkB,GAAG,EAAE,CAAC;QAC9B,MAAM,SAAS,GAAa;YAC1B,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,SAAS,EAAE,oBAAoB;YACnD,EAAE,EAA6B,eAAe;SAC/C,CAAC;QACF,MAAM,kBAAkB,GAAG,QAAQ,CAAC,oBAAoB,CAAC,EAAE,EAAE,SAAS,EAAE,kBAAkB,CAAC,CAAC;QAE5F,MAAM,gBAAgB,GAAuB;YAC3C,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;gBACX,EAAE,EAAE,kBAAkB;gBACtB,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ;aAC5B,CAAC;SACH,CAAC;QAEF,mFAAmF;QACnF,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,IAAI,EAAE;YAC3C,yBAAyB,EAAE,KAAK,CAAC,yBAAyB;YAC1D,aAAa,EAAE,KAAK,CAAC,aAAa;SACnC,CAAC,CAAC;QAEH,oCAAoC;QACpC,MAAM,sBAAsB,GAAG,QAAQ,CAAC,sBAAsB,CAAC,CAAC,gBAAgB,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClG,MAAM,eAAe,GAAG,IAAA,oBAAa,EAAC,sBAAsB,EAAE,KAAK,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;QAE1F,2BAA2B;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,YAAY,EAAE,eAAe,CAAC,CAAC;QAEvE,8EAA8E;QAC9E,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,0BAAgB,CAAC,sBAAsB,CAAC,CAAC,CAAC;QAEzE,mEAAmE;QACnE,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,IAAI,0BAAgB,CAAC,sBAAsB,CAAC,EACpE,aAAa,EACb,aAAa,EACb,gBAAgB,EAChB,sBAAsB,CACvB,CAAC;IACJ,CAAC;;AA9EL,4CA+EC","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as kms from 'aws-cdk-lib/aws-kms';\nimport * as defaults from '@aws-solutions-constructs/core';\nimport * as cdk from 'aws-cdk-lib';\n// Note: To ensure CDKv2 compatibility, keep the import statement for Construct separate\nimport { Construct } from 'constructs';\nimport { overrideProps } from '@aws-solutions-constructs/core';\nimport { ServicePrincipal } from 'aws-cdk-lib/aws-iam';\n\nexport interface EventbridgeToSnsProps {\n    /**\n     * User provided props to override the default props for the SNS Topic.\n     *\n     * @default - Default props are used\n     */\n    readonly topicProps?: sns.TopicProps;\n    /**\n     * Optional - user provided custom event bus for this construct to use. Providing both this and `eventBusProps`\n     * is an error.\n     *\n     * @default - None\n     */\n    readonly existingEventBusInterface?: events.IEventBus;\n    /**\n     * Optional - user provided properties to override the default properties when creating a custom EventBus. Setting\n     * this value to `{}` will create a custom EventBus using all default properties. If neither this nor\n     * `existingEventBusInterface` is provided the construct will use the default EventBus. Providing both this and\n     * `existingEventBusInterface` results an error.\n     *\n     * @default - None\n     */\n    readonly eventBusProps?: events.EventBusProps;\n    /**\n     * User provided eventRuleProps to override the defaults\n     *\n     * @default - None\n     */\n    readonly eventRuleProps: events.RuleProps;\n    /**\n     * Existing instance of SNS Topic object, providing both this and topicProps will cause an error..\n     *\n     * @default - Default props are used\n     */\n    readonly existingTopicObj?: sns.Topic;\n    /**\n     * If no key is provided, this flag determines whether the topic is encrypted with a new CMK or an AWS managed key.\n     * This flag is ignored if any of the following are defined: topicProps.masterKey, encryptionKey or encryptionKeyProps.\n     *\n     * @default - True if topicProps.masterKey, encryptionKey, and encryptionKeyProps are all undefined.\n     */\n    readonly enableEncryptionWithCustomerManagedKey?: boolean;\n    /**\n     * An optional, imported encryption key to encrypt the SNS topic with.\n     *\n     * @default - None.\n     */\n    readonly encryptionKey?: kms.Key;\n    /**\n     * Optional user provided properties to override the default properties for the KMS encryption key used to  encrypt the SNS topic with.\n     *\n     * @default - None\n     */\n    readonly encryptionKeyProps?: kms.KeyProps;\n}\n\nexport class EventbridgeToSns extends Construct {\n    public readonly snsTopic: sns.Topic;\n    public readonly eventBus?: events.IEventBus;\n    public readonly eventsRule: events.Rule;\n    public readonly encryptionKey?: kms.Key;\n\n    /**\n     * @summary Constructs a new instance of the EventbridgeToSns class.\n     * @param {cdk.App} scope - represents the scope for all the resources.\n     * @param {string} id - this is a a scope-unique id.\n     * @param {EventbridgeToSnsProps} props - user provided props for the construct.\n     * @access public\n     */\n    constructor(scope: Construct, id: string, props: EventbridgeToSnsProps) {\n      super(scope, id);\n      defaults.CheckSnsProps(props);\n      defaults.CheckEventBridgeProps(props);\n\n      let enableEncryptionParam = props.enableEncryptionWithCustomerManagedKey;\n      if (props.enableEncryptionWithCustomerManagedKey === undefined ||\n          props.enableEncryptionWithCustomerManagedKey === true) {\n        enableEncryptionParam = true;\n      }\n\n      // Setup the sns topic.\n      const buildTopicResponse = defaults.buildTopic(this, id, {\n        existingTopicObj: props.existingTopicObj,\n        topicProps: props.topicProps,\n        enableEncryptionWithCustomerManagedKey: enableEncryptionParam,\n        encryptionKey: props.encryptionKey,\n        encryptionKeyProps: props.encryptionKeyProps\n      });\n\n      this.snsTopic = buildTopicResponse.topic;\n      this.encryptionKey = buildTopicResponse.key;\n\n      // Setup the event rule target as sns topic.\n\n      // The CDK generally avoids resource names that are too long, but in this case the maximum SNS topic name is 256 characters and the maximum\n      // binding id is 64 characters, so a long SNS topic name (driven by Stack id, Construct id, etc.) breaks upon launch. Because of this, we take\n      // control of the physical name ourselves.\n      const maxBindingIdLength = 64;\n      const nameParts: string[] = [\n        cdk.Stack.of(scope).stackName, // Name of the stack\n        id,                            // Construct ID\n      ];\n      const generatedTopicName = defaults.generatePhysicalName(\"\", nameParts, maxBindingIdLength);\n\n      const topicEventTarget: events.IRuleTarget = {\n        bind: () => ({\n          id: generatedTopicName,\n          arn: this.snsTopic.topicArn\n        })\n      };\n\n      // build an event bus if existingEventBus is provided or eventBusProps are provided\n      this.eventBus = defaults.buildEventBus(this, {\n        existingEventBusInterface: props.existingEventBusInterface,\n        eventBusProps: props.eventBusProps\n      });\n\n      // Setup up the event rule property.\n      const defaultEventsRuleProps = defaults.DefaultEventsRuleProps([topicEventTarget], this.eventBus);\n      const eventsRuleProps = overrideProps(defaultEventsRuleProps, props.eventRuleProps, true);\n\n      // Setup up the event rule.\n      this.eventsRule = new events.Rule(this, 'EventsRule', eventsRuleProps);\n\n      // Setup up the grant policy for event to be able to publish to the sns topic.\n      this.snsTopic.grantPublish(new ServicePrincipal('events.amazonaws.com'));\n\n      // Grant EventBridge service access to the SNS Topic encryption key\n      this.encryptionKey?.grant(new ServicePrincipal('events.amazonaws.com'),\n        \"kms:Decrypt\",\n        \"kms:Encrypt\",\n        \"kms:ReEncrypt*\",\n        \"kms:GenerateDataKey*\"\n      );\n    }\n}"]}
74
+ EventbridgeToSns[_a] = { fqn: "@aws-solutions-constructs/aws-eventbridge-sns.EventbridgeToSns", version: "2.98.0" };
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAcA,iDAAiD;AAEjD,2DAA2D;AAC3D,mCAAmC;AACnC,wFAAwF;AACxF,2CAAuC;AACvC,yDAA+D;AAC/D,iDAAuD;AA0DvD,MAAa,gBAAiB,SAAQ,sBAAS;IAM3C;;;;;;OAMG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA4B;QACpE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,QAAQ,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAEtC,IAAI,qBAAqB,GAAG,KAAK,CAAC,sCAAsC,CAAC;QACzE,IAAI,KAAK,CAAC,sCAAsC,KAAK,SAAS;YAC1D,KAAK,CAAC,sCAAsC,KAAK,IAAI,EAAE,CAAC;YAC1D,qBAAqB,GAAG,IAAI,CAAC;QAC/B,CAAC;QAED,uBAAuB;QACvB,MAAM,kBAAkB,GAAG,QAAQ,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,EAAE;YACvD,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;YACxC,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,sCAAsC,EAAE,qBAAqB;YAC7D,aAAa,EAAE,KAAK,CAAC,aAAa;YAClC,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;SAC7C,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,GAAG,kBAAkB,CAAC,KAAK,CAAC;QACzC,IAAI,CAAC,aAAa,GAAG,kBAAkB,CAAC,GAAG,CAAC;QAE5C,4CAA4C;QAE5C,2IAA2I;QAC3I,8IAA8I;QAC9I,0CAA0C;QAC1C,MAAM,kBAAkB,GAAG,EAAE,CAAC;QAC9B,MAAM,SAAS,GAAa;YAC1B,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,SAAS,EAAE,oBAAoB;YACnD,EAAE,EAA6B,eAAe;SAC/C,CAAC;QACF,MAAM,kBAAkB,GAAG,QAAQ,CAAC,oBAAoB,CAAC,EAAE,EAAE,SAAS,EAAE,kBAAkB,CAAC,CAAC;QAE5F,MAAM,gBAAgB,GAAuB;YAC3C,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;gBACX,EAAE,EAAE,kBAAkB;gBACtB,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ;aAC5B,CAAC;SACH,CAAC;QAEF,mFAAmF;QACnF,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,IAAI,EAAE;YAC3C,yBAAyB,EAAE,KAAK,CAAC,yBAAyB;YAC1D,aAAa,EAAE,KAAK,CAAC,aAAa;SACnC,CAAC,CAAC;QAEH,oCAAoC;QACpC,MAAM,sBAAsB,GAAG,QAAQ,CAAC,sBAAsB,CAAC,CAAC,gBAAgB,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClG,MAAM,eAAe,GAAG,IAAA,oBAAa,EAAC,sBAAsB,EAAE,KAAK,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;QAE1F,2BAA2B;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,YAAY,EAAE,eAAe,CAAC,CAAC;QAEvE,8EAA8E;QAC9E,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,0BAAgB,CAAC,sBAAsB,CAAC,CAAC,CAAC;QAEzE,mEAAmE;QACnE,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,IAAI,0BAAgB,CAAC,sBAAsB,CAAC,EACpE,aAAa,EACb,aAAa,EACb,gBAAgB,EAChB,sBAAsB,CACvB,CAAC;IACJ,CAAC;;AA9EL,4CA+EC","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as kms from 'aws-cdk-lib/aws-kms';\nimport * as defaults from '@aws-solutions-constructs/core';\nimport * as cdk from 'aws-cdk-lib';\n// Note: To ensure CDKv2 compatibility, keep the import statement for Construct separate\nimport { Construct } from 'constructs';\nimport { overrideProps } from '@aws-solutions-constructs/core';\nimport { ServicePrincipal } from 'aws-cdk-lib/aws-iam';\n\nexport interface EventbridgeToSnsProps {\n    /**\n     * User provided props to override the default props for the SNS Topic.\n     *\n     * @default - Default props are used\n     */\n    readonly topicProps?: sns.TopicProps;\n    /**\n     * Optional - user provided custom EventBus for this construct to use. Providing both this and `eventBusProps`\n     * causes an error.\n     *\n     * @default - None\n     */\n    readonly existingEventBusInterface?: events.IEventBus;\n    /**\n     * Optional - user provided properties to override the default properties when creating a custom EventBus. Setting\n     * this value to `{}` will create a custom EventBus using all default properties. If neither this nor\n     * `existingEventBusInterface` is provided the construct will use the default EventBus. Providing both this and\n     * `existingEventBusInterface` causes an error.\n     *\n     * @default - None\n     */\n    readonly eventBusProps?: events.EventBusProps;\n    /**\n     * User provided eventRuleProps to override the defaults\n     *\n     * @default - None\n     */\n    readonly eventRuleProps: events.RuleProps;\n    /**\n     * Existing instance of SNS Topic object, providing both this and topicProps will cause an error..\n     *\n     * @default - Default props are used\n     */\n    readonly existingTopicObj?: sns.Topic;\n    /**\n     * If no key is provided, this flag determines whether the topic is encrypted with a new CMK or an AWS managed key.\n     * This flag is ignored if any of the following are defined: topicProps.masterKey, encryptionKey or encryptionKeyProps.\n     *\n     * @default - True if topicProps.masterKey, encryptionKey, and encryptionKeyProps are all undefined.\n     */\n    readonly enableEncryptionWithCustomerManagedKey?: boolean;\n    /**\n     * An optional, imported encryption key to encrypt the SNS topic with.\n     *\n     * @default - None.\n     */\n    readonly encryptionKey?: kms.Key;\n    /**\n     * Optional user provided properties to override the default properties for the KMS encryption key used to  encrypt the SNS topic with.\n     *\n     * @default - None\n     */\n    readonly encryptionKeyProps?: kms.KeyProps;\n}\n\nexport class EventbridgeToSns extends Construct {\n    public readonly snsTopic: sns.Topic;\n    public readonly eventBus?: events.IEventBus;\n    public readonly eventsRule: events.Rule;\n    public readonly encryptionKey?: kms.Key;\n\n    /**\n     * @summary Constructs a new instance of the EventbridgeToSns class.\n     * @param {cdk.App} scope - represents the scope for all the resources.\n     * @param {string} id - this is a a scope-unique id.\n     * @param {EventbridgeToSnsProps} props - user provided props for the construct.\n     * @access public\n     */\n    constructor(scope: Construct, id: string, props: EventbridgeToSnsProps) {\n      super(scope, id);\n      defaults.CheckSnsProps(props);\n      defaults.CheckEventBridgeProps(props);\n\n      let enableEncryptionParam = props.enableEncryptionWithCustomerManagedKey;\n      if (props.enableEncryptionWithCustomerManagedKey === undefined ||\n          props.enableEncryptionWithCustomerManagedKey === true) {\n        enableEncryptionParam = true;\n      }\n\n      // Setup the sns topic.\n      const buildTopicResponse = defaults.buildTopic(this, id, {\n        existingTopicObj: props.existingTopicObj,\n        topicProps: props.topicProps,\n        enableEncryptionWithCustomerManagedKey: enableEncryptionParam,\n        encryptionKey: props.encryptionKey,\n        encryptionKeyProps: props.encryptionKeyProps\n      });\n\n      this.snsTopic = buildTopicResponse.topic;\n      this.encryptionKey = buildTopicResponse.key;\n\n      // Setup the event rule target as sns topic.\n\n      // The CDK generally avoids resource names that are too long, but in this case the maximum SNS topic name is 256 characters and the maximum\n      // binding id is 64 characters, so a long SNS topic name (driven by Stack id, Construct id, etc.) breaks upon launch. Because of this, we take\n      // control of the physical name ourselves.\n      const maxBindingIdLength = 64;\n      const nameParts: string[] = [\n        cdk.Stack.of(scope).stackName, // Name of the stack\n        id,                            // Construct ID\n      ];\n      const generatedTopicName = defaults.generatePhysicalName(\"\", nameParts, maxBindingIdLength);\n\n      const topicEventTarget: events.IRuleTarget = {\n        bind: () => ({\n          id: generatedTopicName,\n          arn: this.snsTopic.topicArn\n        })\n      };\n\n      // build an event bus if existingEventBus is provided or eventBusProps are provided\n      this.eventBus = defaults.buildEventBus(this, {\n        existingEventBusInterface: props.existingEventBusInterface,\n        eventBusProps: props.eventBusProps\n      });\n\n      // Setup up the event rule property.\n      const defaultEventsRuleProps = defaults.DefaultEventsRuleProps([topicEventTarget], this.eventBus);\n      const eventsRuleProps = overrideProps(defaultEventsRuleProps, props.eventRuleProps, true);\n\n      // Setup up the event rule.\n      this.eventsRule = new events.Rule(this, 'EventsRule', eventsRuleProps);\n\n      // Setup up the grant policy for event to be able to publish to the sns topic.\n      this.snsTopic.grantPublish(new ServicePrincipal('events.amazonaws.com'));\n\n      // Grant EventBridge service access to the SNS Topic encryption key\n      this.encryptionKey?.grant(new ServicePrincipal('events.amazonaws.com'),\n        \"kms:Decrypt\",\n        \"kms:Encrypt\",\n        \"kms:ReEncrypt*\",\n        \"kms:GenerateDataKey*\"\n      );\n    }\n}"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-solutions-constructs/aws-eventbridge-sns",
3
- "version": "2.97.0",
3
+ "version": "2.98.0",
4
4
  "description": "CDK Constructs for deploying AWS Events Rule that invokes AWS SNS",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
@@ -55,14 +55,14 @@
55
55
  }
56
56
  },
57
57
  "dependencies": {
58
- "@aws-solutions-constructs/core": "2.97.0",
58
+ "@aws-solutions-constructs/core": "2.98.0",
59
59
  "constructs": "^10.0.0"
60
60
  },
61
61
  "devDependencies": {
62
- "@aws-cdk/integ-tests-alpha": "2.233.0-alpha.0",
62
+ "@aws-cdk/integ-tests-alpha": "2.234.0-alpha.0",
63
63
  "@types/node": "^10.3.0",
64
64
  "constructs": "^10.0.0",
65
- "aws-cdk-lib": "2.233.0"
65
+ "aws-cdk-lib": "2.234.0"
66
66
  },
67
67
  "jest": {
68
68
  "moduleFileExtensions": [
@@ -79,9 +79,9 @@
79
79
  ]
80
80
  },
81
81
  "peerDependencies": {
82
- "@aws-solutions-constructs/core": "2.97.0",
82
+ "@aws-solutions-constructs/core": "2.98.0",
83
83
  "constructs": "^10.0.0",
84
- "aws-cdk-lib": "^2.233.0"
84
+ "aws-cdk-lib": "^2.234.0"
85
85
  },
86
86
  "keywords": [
87
87
  "aws",