@aws-solutions-constructs/aws-eventbridge-sns 2.85.1 → 2.85.3

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,7 +8,7 @@
8
8
  "url": "https://aws.amazon.com"
9
9
  },
10
10
  "dependencies": {
11
- "@aws-solutions-constructs/core": "2.85.1",
11
+ "@aws-solutions-constructs/core": "2.85.3",
12
12
  "aws-cdk-lib": "^2.193.0",
13
13
  "constructs": "^10.0.0"
14
14
  },
@@ -3993,7 +3993,7 @@
3993
3993
  },
3994
3994
  "name": "@aws-solutions-constructs/aws-eventbridge-sns",
3995
3995
  "readme": {
3996
- "markdown": "# aws-eventbridge-sns module\n<!--BEGIN STABILITY BANNER-->\n\n---\n\n![Stability: Stable](https://img.shields.io/badge/cfn--resources-stable-success.svg?style=for-the-badge)\n\n---\n<!--END STABILITY BANNER-->\n\n| **Reference Documentation**:| <span style=\"font-weight: normal\">https://docs.aws.amazon.com/solutions/latest/constructs/</span>|\n|:-------------|:-------------|\n<div style=\"height:8px\"></div>\n\n| **Language** | **Package** |\n|:-------------|-----------------|\n|![Python Logo](https://docs.aws.amazon.com/cdk/api/latest/img/python32.png) Python|`aws_solutions_constructs.aws_eventbridge_sns`|\n|![Typescript Logo](https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png) Typescript|`@aws-solutions-constructs/aws-eventbridge-sns`|\n|![Java Logo](https://docs.aws.amazon.com/cdk/api/latest/img/java32.png) Java|`software.amazon.awsconstructs.services.eventbridgesns`|\n\n## Overview\nThis AWS Solutions Construct implements an AWS Events rule and an AWS SNS Topic.\n\nHere is a minimal deployable pattern definition:\n\nTypescript\n``` typescript\nimport { Construct } from 'constructs';\nimport { Stack, StackProps, Duration } from 'aws-cdk-lib';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { EventbridgeToSnsProps, EventbridgeToSns } from \"@aws-solutions-constructs/aws-eventbridge-sns\";\n\nconst constructProps: EventbridgeToSnsProps = {\n eventRuleProps: {\n schedule: events.Schedule.rate(Duration.minutes(5))\n }\n};\n\nconst constructStack = new EventbridgeToSns(this, 'test-construct', constructProps);\n\n// Grant yourself permissions to use the Customer Managed KMS Key\nconst policyStatement = new iam.PolicyStatement({\n actions: [\"kms:Encrypt\", \"kms:Decrypt\"],\n effect: iam.Effect.ALLOW,\n principals: [new iam.AccountRootPrincipal()],\n resources: [\"*\"]\n});\n\nconstructStack.encryptionKey?.addToResourcePolicy(policyStatement);\n```\n\nPython\n``` Python\nfrom aws_solutions_constructs.aws_eventbridge_sns import EventbridgeToSns, EventbridgeToSnsProps\nfrom aws_cdk import (\n aws_events as events,\n aws_iam as iam,\n Duration,\n Stack\n)\nfrom constructs import Construct\n\nconstruct_stack = EventbridgeToSns(self, 'test-construct',\n event_rule_props=events.RuleProps(\n schedule=events.Schedule.rate(\n Duration.minutes(5))\n ))\n\n# Grant yourself permissions to use the Customer Managed KMS Key\npolicy_statement = iam.PolicyStatement(\n actions=[\"kms:Encrypt\", \"kms:Decrypt\"],\n effect=iam.Effect.ALLOW,\n principals=[iam.AccountRootPrincipal()],\n resources=[\"*\"]\n)\n\nconstruct_stack.encryption_key.add_to_resource_policy(policy_statement)\n```\n\nJava\n``` java\nimport software.constructs.Construct;\nimport java.util.List;\n\nimport software.amazon.awscdk.Stack;\nimport software.amazon.awscdk.StackProps;\nimport software.amazon.awscdk.Duration;\nimport software.amazon.awscdk.services.events.*;\nimport software.amazon.awscdk.services.iam.*;\nimport software.amazon.awsconstructs.services.eventbridgesns.*;\n\nfinal EventbridgeToSns constructStack = new EventbridgeToSns(this, \"test-construct\",\n new EventbridgeToSnsProps.Builder()\n .eventRuleProps(new RuleProps.Builder()\n .schedule(Schedule.rate(Duration.minutes(5)))\n .build())\n .build());\n\n// Grant yourself permissions to use the Customer Managed KMS Key\nfinal PolicyStatement policyStatement = PolicyStatement.Builder.create()\n .actions(List.of(\"kms:Encrypt\", \"kms:Decrypt\"))\n .effect(Effect.ALLOW)\n .principals(List.of(new AccountRootPrincipal()))\n .resources(List.of(\"*\"))\n .build();\n\nconstructStack.getEncryptionKey().addToResourcePolicy(policyStatement);\n```\n\n## Pattern Construct Props\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n|eventRuleProps|[`events.RuleProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.RuleProps.html)|User provided eventRuleProps to override the defaults. |\n|existingTopicObj?|[`sns.Topic`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.Function.html)|Existing instance of SNS Topic object, providing both this and `topicProps` will cause an error.|\n|topicProps?|[`sns.TopicProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_sns.TopicProps.html)|User provided props to override the default props for the SNS Topic. |\n|existingEventBusInterface?|[`events.IEventBus`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.IEventBus.html)| Optional user-provided custom EventBus for construct to use. Providing both this and `eventBusProps` results an error.|\n|eventBusProps?|[`events.EventBusProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.EventBusProps.html)|Optional user-provided properties to override the default properties when creating a custom EventBus. Setting this value to `{}` will create a custom EventBus using all default properties. If neither this nor `existingEventBusInterface` is provided the construct will use the `default` EventBus. Providing both this and `existingEventBusInterface` results an error.|\n|enableEncryptionWithCustomerManagedKey?|`boolean`|If no key is provided, this flag determines whether the SNS Topic is encrypted with a new CMK or an AWS managed key. This flag is ignored if any of the following are defined: topicProps.masterKey, encryptionKey or encryptionKeyProps.|\n|encryptionKey?|[`kms.Key`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_kms.Key.html)|An optional, imported encryption key to encrypt the SNS Topic with.|\n|encryptionKeyProps?|[`kms.KeyProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_kms.Key.html#construct-props)|Optional user provided properties to override the default properties for the KMS encryption key used to encrypt the SNS Topic with.|\n\n## Pattern Properties\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n|eventBus?|[`events.IEventBus`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.IEventBus.html)|Returns the instance of events.IEventBus used by the construct|\n|eventsRule|[`events.Rule`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.Rule.html)|Returns an instance of events.Rule created by the construct|\n|snsTopic|[`sns.Topic`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_sns.Topic.html)|Returns an instance of sns.Topic created by the construct|\n|encryptionKey?|[`kms.Key`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_kms.Key.html)|Returns an instance of kms Key used for the SNS Topic.|\n\n## Default settings\n\nOut of the box implementation of the Construct without any override will set the following defaults:\n\n### Amazon EventBridge Rule\n* Grant least privilege permissions to EventBridge Rule to publish to the SNS Topic.\n\n### Amazon SNS Topic\n* Configure least privilege access permissions for SNS Topic.\n* Enable server-side encryption forSNS Topic using Customer managed KMS Key.\n* Enforce encryption of data in transit.\n\n## Architecture\n![Architecture Diagram](architecture.png)\n\n***\n&copy; Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n"
3996
+ "markdown": "Documentation for this pattern can be found [here](https://github.com/awslabs/aws-solutions-constructs/blob/main/source/patterns/%40aws-solutions-constructs/aws-eventbridge-sns/README.adoc)\n"
3997
3997
  },
3998
3998
  "repository": {
3999
3999
  "directory": "source/patterns/@aws-solutions-constructs/aws-eventbridge-sns",
@@ -4276,6 +4276,6 @@
4276
4276
  "symbolId": "lib/index:EventbridgeToSnsProps"
4277
4277
  }
4278
4278
  },
4279
- "version": "2.85.1",
4280
- "fingerprint": "1FVp0QpgZPaIwBc1yaxz+BPg0PlAwCBShdET13pPA88="
4279
+ "version": "2.85.3",
4280
+ "fingerprint": "0ieHhrOy/rBFJGNuKMBBdOvom+ey2qBEi3QBaljWNfE="
4281
4281
  }
package/README.adoc ADDED
@@ -0,0 +1,229 @@
1
+ //!!NODE_ROOT <section>
2
+ //== aws-eventbridge-sns module
3
+
4
+ [.topic]
5
+ = aws-eventbridge-sns
6
+ :info_doctype: section
7
+ :info_title: aws-eventbridge-sns
8
+
9
+
10
+ image:https://img.shields.io/badge/cfn--resources-stable-success.svg?style=for-the-badge[Stability:Stable]
11
+
12
+ [width="100%",cols="<50%,<50%",options="header",]
13
+ |===
14
+ |*Reference Documentation*:
15
+ |https://docs.aws.amazon.com/solutions/latest/constructs/
16
+ |===
17
+
18
+ [width="100%",cols="<46%,54%",options="header",]
19
+ |===
20
+ |*Language* |*Package*
21
+ |image:https://docs.aws.amazon.com/cdk/api/latest/img/python32.png[Python
22
+ Logo] Python
23
+ |`aws_solutions_constructs.aws_eventbridge_sns`
24
+
25
+ |image:https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png[Typescript
26
+ Logo] Typescript |`@aws-solutions-constructs/aws-eventbridge-sns`
27
+
28
+ |image:https://docs.aws.amazon.com/cdk/api/latest/img/java32.png[Java
29
+ Logo] Java |`software.amazon.awsconstructs.services.eventbridgesns`
30
+ |===
31
+
32
+ == Overview
33
+
34
+ This AWS Solutions Construct implements an AWS Events rule and an AWS
35
+ SNS Topic.
36
+
37
+ Here is a minimal deployable pattern definition:
38
+
39
+ ====
40
+ [role="tablist"]
41
+ Typescript::
42
+ +
43
+ [source,typescript]
44
+ ----
45
+ import { Construct } from 'constructs';
46
+ import { Stack, StackProps, Duration } from 'aws-cdk-lib';
47
+ import * as events from 'aws-cdk-lib/aws-events';
48
+ import * as iam from 'aws-cdk-lib/aws-iam';
49
+ import { EventbridgeToSnsProps, EventbridgeToSns } from "@aws-solutions-constructs/aws-eventbridge-sns";
50
+
51
+ const constructProps: EventbridgeToSnsProps = {
52
+ eventRuleProps: {
53
+ schedule: events.Schedule.rate(Duration.minutes(5))
54
+ }
55
+ };
56
+
57
+ const constructStack = new EventbridgeToSns(this, 'test-construct', constructProps);
58
+
59
+ // Grant yourself permissions to use the Customer Managed KMS Key
60
+ const policyStatement = new iam.PolicyStatement({
61
+ actions: ["kms:Encrypt", "kms:Decrypt"],
62
+ effect: iam.Effect.ALLOW,
63
+ principals: [new iam.AccountRootPrincipal()],
64
+ resources: ["*"]
65
+ });
66
+
67
+ constructStack.encryptionKey?.addToResourcePolicy(policyStatement);
68
+ ----
69
+
70
+ Python::
71
+ +
72
+ [source,python]
73
+ ----
74
+ from aws_solutions_constructs.aws_eventbridge_sns import EventbridgeToSns, EventbridgeToSnsProps
75
+ from aws_cdk import (
76
+ aws_events as events,
77
+ aws_iam as iam,
78
+ Duration,
79
+ Stack
80
+ )
81
+ from constructs import Construct
82
+
83
+ construct_stack = EventbridgeToSns(self, 'test-construct',
84
+ event_rule_props=events.RuleProps(
85
+ schedule=events.Schedule.rate(
86
+ Duration.minutes(5))
87
+ ))
88
+
89
+ # Grant yourself permissions to use the Customer Managed KMS Key
90
+ policy_statement = iam.PolicyStatement(
91
+ actions=["kms:Encrypt", "kms:Decrypt"],
92
+ effect=iam.Effect.ALLOW,
93
+ principals=[iam.AccountRootPrincipal()],
94
+ resources=["*"]
95
+ )
96
+
97
+ construct_stack.encryption_key.add_to_resource_policy(policy_statement)
98
+ ----
99
+
100
+ Java::
101
+ +
102
+ [source,java]
103
+ ----
104
+ import software.constructs.Construct;
105
+ import java.util.List;
106
+
107
+ import software.amazon.awscdk.Stack;
108
+ import software.amazon.awscdk.StackProps;
109
+ import software.amazon.awscdk.Duration;
110
+ import software.amazon.awscdk.services.events.*;
111
+ import software.amazon.awscdk.services.iam.*;
112
+ import software.amazon.awsconstructs.services.eventbridgesns.*;
113
+
114
+ final EventbridgeToSns constructStack = new EventbridgeToSns(this, "test-construct",
115
+ new EventbridgeToSnsProps.Builder()
116
+ .eventRuleProps(new RuleProps.Builder()
117
+ .schedule(Schedule.rate(Duration.minutes(5)))
118
+ .build())
119
+ .build());
120
+
121
+ // Grant yourself permissions to use the Customer Managed KMS Key
122
+ final PolicyStatement policyStatement = PolicyStatement.Builder.create()
123
+ .actions(List.of("kms:Encrypt", "kms:Decrypt"))
124
+ .effect(Effect.ALLOW)
125
+ .principals(List.of(new AccountRootPrincipal()))
126
+ .resources(List.of("*"))
127
+ .build();
128
+
129
+ constructStack.getEncryptionKey().addToResourcePolicy(policyStatement);
130
+ ----
131
+ ====
132
+
133
+ == Pattern Construct Props
134
+
135
+ [width="100%",cols="<30%,<35%,35%",options="header",]
136
+ |===
137
+ |*Name* |*Type* |*Description*
138
+ |eventRuleProps
139
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.RuleProps.html[`events.RuleProps`]
140
+ |User provided eventRuleProps to override the defaults.
141
+
142
+ |existingTopicObj?
143
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.Function.html[`sns.Topic`]
144
+ |Existing instance of SNS Topic object, providing both this and
145
+ `topicProps` will cause an error.
146
+
147
+ |topicProps?
148
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_sns.TopicProps.html[`sns.TopicProps`]
149
+ |User provided props to override the default props for the SNS Topic.
150
+
151
+ |existingEventBusInterface?
152
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.IEventBus.html[`events.IEventBus`]
153
+ |Optional user-provided custom EventBus for construct to use. Providing
154
+ both this and `eventBusProps` results an error.
155
+
156
+ |eventBusProps?
157
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.EventBusProps.html[`events.EventBusProps`]
158
+ |Optional user-provided properties to override the default properties
159
+ when creating a custom EventBus. Setting this value to `{}` will
160
+ create a custom EventBus using all default properties. If neither this
161
+ nor `existingEventBusInterface` is provided the construct will use the
162
+ `default` EventBus. Providing both this and `existingEventBusInterface`
163
+ results an error.
164
+
165
+ |enableEncryptionWithCustomerManagedKey? |`boolean` |If no key is
166
+ provided, this flag determines whether the SNS Topic is encrypted with a
167
+ new CMK or an AWS managed key. This flag is ignored if any of the
168
+ following are defined: topicProps.masterKey, encryptionKey or
169
+ encryptionKeyProps.
170
+
171
+ |encryptionKey?
172
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_kms.Key.html[`kms.Key`]
173
+ |An optional, imported encryption key to encrypt the SNS Topic with.
174
+
175
+ |encryptionKeyProps?
176
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_kms.Key.html#construct-props[`kms.KeyProps`]
177
+ |Optional user provided properties to override the default properties
178
+ for the KMS encryption key used to encrypt the SNS Topic with.
179
+ |===
180
+
181
+ == Pattern Properties
182
+
183
+ [width="100%",cols="<30%,<35%,35%",options="header",]
184
+ |===
185
+ |*Name* |*Type* |*Description*
186
+ |eventBus?
187
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.IEventBus.html[`events.IEventBus`]
188
+ |Returns the instance of events.IEventBus used by the construct
189
+
190
+ |eventsRule
191
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.Rule.html[`events.Rule`]
192
+ |Returns an instance of events.Rule created by the construct
193
+
194
+ |snsTopic
195
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_sns.Topic.html[`sns.Topic`]
196
+ |Returns an instance of sns.Topic created by the construct
197
+
198
+ |encryptionKey?
199
+ |https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_kms.Key.html[`kms.Key`]
200
+ |Returns an instance of kms Key used for the SNS Topic.
201
+ |===
202
+
203
+ == Default settings
204
+
205
+ Out of the box implementation of the Construct without any override will
206
+ set the following defaults:
207
+
208
+ === Amazon EventBridge Rule
209
+
210
+ * Grant least privilege permissions to EventBridge Rule to publish to
211
+ the SNS Topic.
212
+
213
+ === Amazon SNS Topic
214
+
215
+ * Configure least privilege access permissions for SNS Topic.
216
+ * Enable server-side encryption forSNS Topic using Customer managed KMS
217
+ Key.
218
+ * Enforce encryption of data in transit.
219
+
220
+ == Architecture
221
+
222
+
223
+ image::aws-eventbridge-sns.png["Diagram showing the EventBridge rule, SNS topic, and IAM role created by the construct",scaledwidth=100%]
224
+
225
+ // github block
226
+
227
+ '''''
228
+
229
+ © Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
package/README.md CHANGED
@@ -1,149 +1 @@
1
- # aws-eventbridge-sns module
2
- <!--BEGIN STABILITY BANNER-->
3
-
4
- ---
5
-
6
- ![Stability: Stable](https://img.shields.io/badge/cfn--resources-stable-success.svg?style=for-the-badge)
7
-
8
- ---
9
- <!--END STABILITY BANNER-->
10
-
11
- | **Reference Documentation**:| <span style="font-weight: normal">https://docs.aws.amazon.com/solutions/latest/constructs/</span>|
12
- |:-------------|:-------------|
13
- <div style="height:8px"></div>
14
-
15
- | **Language** | **Package** |
16
- |:-------------|-----------------|
17
- |![Python Logo](https://docs.aws.amazon.com/cdk/api/latest/img/python32.png) Python|`aws_solutions_constructs.aws_eventbridge_sns`|
18
- |![Typescript Logo](https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png) Typescript|`@aws-solutions-constructs/aws-eventbridge-sns`|
19
- |![Java Logo](https://docs.aws.amazon.com/cdk/api/latest/img/java32.png) Java|`software.amazon.awsconstructs.services.eventbridgesns`|
20
-
21
- ## Overview
22
- This AWS Solutions Construct implements an AWS Events rule and an AWS SNS Topic.
23
-
24
- Here is a minimal deployable pattern definition:
25
-
26
- Typescript
27
- ``` typescript
28
- import { Construct } from 'constructs';
29
- import { Stack, StackProps, Duration } from 'aws-cdk-lib';
30
- import * as events from 'aws-cdk-lib/aws-events';
31
- import * as iam from 'aws-cdk-lib/aws-iam';
32
- import { EventbridgeToSnsProps, EventbridgeToSns } from "@aws-solutions-constructs/aws-eventbridge-sns";
33
-
34
- const constructProps: EventbridgeToSnsProps = {
35
- eventRuleProps: {
36
- schedule: events.Schedule.rate(Duration.minutes(5))
37
- }
38
- };
39
-
40
- const constructStack = new EventbridgeToSns(this, 'test-construct', constructProps);
41
-
42
- // Grant yourself permissions to use the Customer Managed KMS Key
43
- const policyStatement = new iam.PolicyStatement({
44
- actions: ["kms:Encrypt", "kms:Decrypt"],
45
- effect: iam.Effect.ALLOW,
46
- principals: [new iam.AccountRootPrincipal()],
47
- resources: ["*"]
48
- });
49
-
50
- constructStack.encryptionKey?.addToResourcePolicy(policyStatement);
51
- ```
52
-
53
- Python
54
- ``` Python
55
- from aws_solutions_constructs.aws_eventbridge_sns import EventbridgeToSns, EventbridgeToSnsProps
56
- from aws_cdk import (
57
- aws_events as events,
58
- aws_iam as iam,
59
- Duration,
60
- Stack
61
- )
62
- from constructs import Construct
63
-
64
- construct_stack = EventbridgeToSns(self, 'test-construct',
65
- event_rule_props=events.RuleProps(
66
- schedule=events.Schedule.rate(
67
- Duration.minutes(5))
68
- ))
69
-
70
- # Grant yourself permissions to use the Customer Managed KMS Key
71
- policy_statement = iam.PolicyStatement(
72
- actions=["kms:Encrypt", "kms:Decrypt"],
73
- effect=iam.Effect.ALLOW,
74
- principals=[iam.AccountRootPrincipal()],
75
- resources=["*"]
76
- )
77
-
78
- construct_stack.encryption_key.add_to_resource_policy(policy_statement)
79
- ```
80
-
81
- Java
82
- ``` java
83
- import software.constructs.Construct;
84
- import java.util.List;
85
-
86
- import software.amazon.awscdk.Stack;
87
- import software.amazon.awscdk.StackProps;
88
- import software.amazon.awscdk.Duration;
89
- import software.amazon.awscdk.services.events.*;
90
- import software.amazon.awscdk.services.iam.*;
91
- import software.amazon.awsconstructs.services.eventbridgesns.*;
92
-
93
- final EventbridgeToSns constructStack = new EventbridgeToSns(this, "test-construct",
94
- new EventbridgeToSnsProps.Builder()
95
- .eventRuleProps(new RuleProps.Builder()
96
- .schedule(Schedule.rate(Duration.minutes(5)))
97
- .build())
98
- .build());
99
-
100
- // Grant yourself permissions to use the Customer Managed KMS Key
101
- final PolicyStatement policyStatement = PolicyStatement.Builder.create()
102
- .actions(List.of("kms:Encrypt", "kms:Decrypt"))
103
- .effect(Effect.ALLOW)
104
- .principals(List.of(new AccountRootPrincipal()))
105
- .resources(List.of("*"))
106
- .build();
107
-
108
- constructStack.getEncryptionKey().addToResourcePolicy(policyStatement);
109
- ```
110
-
111
- ## Pattern Construct Props
112
-
113
- | **Name** | **Type** | **Description** |
114
- |:-------------|:----------------|-----------------|
115
- |eventRuleProps|[`events.RuleProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.RuleProps.html)|User provided eventRuleProps to override the defaults. |
116
- |existingTopicObj?|[`sns.Topic`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.Function.html)|Existing instance of SNS Topic object, providing both this and `topicProps` will cause an error.|
117
- |topicProps?|[`sns.TopicProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_sns.TopicProps.html)|User provided props to override the default props for the SNS Topic. |
118
- |existingEventBusInterface?|[`events.IEventBus`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.IEventBus.html)| Optional user-provided custom EventBus for construct to use. Providing both this and `eventBusProps` results an error.|
119
- |eventBusProps?|[`events.EventBusProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.EventBusProps.html)|Optional user-provided properties to override the default properties when creating a custom EventBus. Setting this value to `{}` will create a custom EventBus using all default properties. If neither this nor `existingEventBusInterface` is provided the construct will use the `default` EventBus. Providing both this and `existingEventBusInterface` results an error.|
120
- |enableEncryptionWithCustomerManagedKey?|`boolean`|If no key is provided, this flag determines whether the SNS Topic is encrypted with a new CMK or an AWS managed key. This flag is ignored if any of the following are defined: topicProps.masterKey, encryptionKey or encryptionKeyProps.|
121
- |encryptionKey?|[`kms.Key`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_kms.Key.html)|An optional, imported encryption key to encrypt the SNS Topic with.|
122
- |encryptionKeyProps?|[`kms.KeyProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_kms.Key.html#construct-props)|Optional user provided properties to override the default properties for the KMS encryption key used to encrypt the SNS Topic with.|
123
-
124
- ## Pattern Properties
125
-
126
- | **Name** | **Type** | **Description** |
127
- |:-------------|:----------------|-----------------|
128
- |eventBus?|[`events.IEventBus`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.IEventBus.html)|Returns the instance of events.IEventBus used by the construct|
129
- |eventsRule|[`events.Rule`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_events.Rule.html)|Returns an instance of events.Rule created by the construct|
130
- |snsTopic|[`sns.Topic`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_sns.Topic.html)|Returns an instance of sns.Topic created by the construct|
131
- |encryptionKey?|[`kms.Key`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_kms.Key.html)|Returns an instance of kms Key used for the SNS Topic.|
132
-
133
- ## Default settings
134
-
135
- Out of the box implementation of the Construct without any override will set the following defaults:
136
-
137
- ### Amazon EventBridge Rule
138
- * Grant least privilege permissions to EventBridge Rule to publish to the SNS Topic.
139
-
140
- ### Amazon SNS Topic
141
- * Configure least privilege access permissions for SNS Topic.
142
- * Enable server-side encryption forSNS Topic using Customer managed KMS Key.
143
- * Enforce encryption of data in transit.
144
-
145
- ## Architecture
146
- ![Architecture Diagram](architecture.png)
147
-
148
- ***
149
- &copy; Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
1
+ Documentation for this pattern can be found [here](https://github.com/awslabs/aws-solutions-constructs/blob/main/source/patterns/%40aws-solutions-constructs/aws-eventbridge-sns/README.adoc)
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.85.1" };
74
+ EventbridgeToSns[_a] = { fqn: "@aws-solutions-constructs/aws-eventbridge-sns.EventbridgeToSns", version: "2.85.3" };
75
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;AAsDvD,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     * Existing instance of a custom EventBus.\n     *\n     * @default - None\n     */\n    readonly existingEventBusInterface?: events.IEventBus;\n    /**\n     * A new custom EventBus is created with provided props.\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.85.1",
3
+ "version": "2.85.3",
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",
@@ -11,12 +11,13 @@
11
11
  "test": "jest --coverage",
12
12
  "clean": "tsc -b --clean",
13
13
  "watch": "tsc -b -w",
14
+ "asciidoc": "asciidoctor --failure-level WARNING -o /dev/null README.adoc",
14
15
  "integ": "integ-runner --update-on-failed",
15
16
  "integ-no-clean": "integ-runner --update-on-failed --no-clean",
16
17
  "integ-assert": "integ-runner",
17
18
  "jsii": "jsii",
18
19
  "jsii-pacmak": "jsii-pacmak",
19
- "build+lint+test": "npm run jsii && npm run lint && npm test && npm run integ-assert",
20
+ "build+lint+test": "npm run jsii && npm run lint && npm run asciidoc && npm test && npm run integ-assert",
20
21
  "blt": "npm run build+lint+test",
21
22
  "snapshot-update": "npm run jsii && npm test -- -u && npm run integ-assert"
22
23
  },
@@ -54,7 +55,7 @@
54
55
  }
55
56
  },
56
57
  "dependencies": {
57
- "@aws-solutions-constructs/core": "2.85.1",
58
+ "@aws-solutions-constructs/core": "2.85.3",
58
59
  "constructs": "^10.0.0"
59
60
  },
60
61
  "devDependencies": {
@@ -78,7 +79,7 @@
78
79
  ]
79
80
  },
80
81
  "peerDependencies": {
81
- "@aws-solutions-constructs/core": "2.85.1",
82
+ "@aws-solutions-constructs/core": "2.85.3",
82
83
  "constructs": "^10.0.0",
83
84
  "aws-cdk-lib": "^2.193.0"
84
85
  },
File without changes