@aws-solutions-constructs/aws-eventbridge-sqs 2.5.0 → 2.8.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.5.0",
12
- "aws-cdk-lib": "^2.15.0",
11
+ "@aws-solutions-constructs/core": "2.8.0",
12
+ "aws-cdk-lib": "^2.23.0",
13
13
  "constructs": "^10.0.0"
14
14
  },
15
15
  "dependencyClosure": {
@@ -403,6 +403,19 @@
403
403
  }
404
404
  }
405
405
  },
406
+ "aws-cdk-lib.aws_billingconductor": {
407
+ "targets": {
408
+ "dotnet": {
409
+ "namespace": "Amazon.CDK.AWS.BillingConductor"
410
+ },
411
+ "java": {
412
+ "package": "software.amazon.awscdk.services.billingconductor"
413
+ },
414
+ "python": {
415
+ "module": "aws_cdk.aws_billingconductor"
416
+ }
417
+ }
418
+ },
406
419
  "aws-cdk-lib.aws_budgets": {
407
420
  "targets": {
408
421
  "dotnet": {
@@ -1522,6 +1535,19 @@
1522
1535
  }
1523
1536
  }
1524
1537
  },
1538
+ "aws-cdk-lib.aws_iottwinmaker": {
1539
+ "targets": {
1540
+ "dotnet": {
1541
+ "namespace": "Amazon.CDK.AWS.IoTTwinMaker"
1542
+ },
1543
+ "java": {
1544
+ "package": "software.amazon.awscdk.services.iottwinmaker"
1545
+ },
1546
+ "python": {
1547
+ "module": "aws_cdk.aws_iottwinmaker"
1548
+ }
1549
+ }
1550
+ },
1525
1551
  "aws-cdk-lib.aws_iotwireless": {
1526
1552
  "targets": {
1527
1553
  "dotnet": {
@@ -1925,6 +1951,19 @@
1925
1951
  }
1926
1952
  }
1927
1953
  },
1954
+ "aws-cdk-lib.aws_mediatailor": {
1955
+ "targets": {
1956
+ "dotnet": {
1957
+ "namespace": "Amazon.CDK.AWS.MediaTailor"
1958
+ },
1959
+ "java": {
1960
+ "package": "software.amazon.awscdk.services.mediatailor"
1961
+ },
1962
+ "python": {
1963
+ "module": "aws_cdk.aws_mediatailor"
1964
+ }
1965
+ }
1966
+ },
1928
1967
  "aws-cdk-lib.aws_memorydb": {
1929
1968
  "targets": {
1930
1969
  "dotnet": {
@@ -2068,6 +2107,19 @@
2068
2107
  }
2069
2108
  }
2070
2109
  },
2110
+ "aws-cdk-lib.aws_personalize": {
2111
+ "targets": {
2112
+ "dotnet": {
2113
+ "namespace": "Amazon.CDK.AWS.Personalize"
2114
+ },
2115
+ "java": {
2116
+ "package": "software.amazon.awscdk.services.personalize"
2117
+ },
2118
+ "python": {
2119
+ "module": "aws_cdk.aws_personalize"
2120
+ }
2121
+ }
2122
+ },
2071
2123
  "aws-cdk-lib.aws_pinpoint": {
2072
2124
  "targets": {
2073
2125
  "dotnet": {
@@ -2955,7 +3007,7 @@
2955
3007
  },
2956
3008
  "description": "CDK Constructs for deploying AWS Eventbridge that invokes AWS SQS",
2957
3009
  "homepage": "https://github.com/awslabs/aws-solutions-constructs.git",
2958
- "jsiiVersion": "1.55.1 (build 07d2d90)",
3010
+ "jsiiVersion": "1.59.0 (build eb02c92)",
2959
3011
  "keywords": [
2960
3012
  "aws",
2961
3013
  "cdk",
@@ -2974,7 +3026,7 @@
2974
3026
  },
2975
3027
  "name": "@aws-solutions-constructs/aws-eventbridge-sqs",
2976
3028
  "readme": {
2977
- "markdown": "# aws-eventbridge-sqs 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_sqs`|\n|![Typescript Logo](https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png) Typescript|`@aws-solutions-constructs/aws-eventbridge-sqs`|\n|![Java Logo](https://docs.aws.amazon.com/cdk/api/latest/img/java32.png) Java|`software.amazon.awsconstructs.services.eventbridgesqs`|\n\nThis AWS Solutions Construct implements an Amazon EventBridge rule and an AWS SQS Queue.\n\nHere is a minimal deployable pattern definition in Typescript:\n\n``` typescript\nimport { Duration } from '@aws-cdk/core';\nimport * as events from '@aws-cdk/aws-events';\nimport * as iam from '@aws-cdk/aws-iam';\nimport { EventbridgeToSqsProps, EventbridgeToSqs } from \"@aws-solutions-constructs/aws-eventbridge-sqs\";\n\nconst props: EventbridgeToSqsProps = {\n eventRuleProps: {\n schedule: events.Schedule.rate(Duration.minutes(5))\n }\n};\n\nconst constructStack = new EventbridgeToSqs(this, 'test-construct', props);\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\n## Initializer\n\n``` text\nnew EventbridgeToSqs(scope: Construct, id: string, props: EventbridgeToSqsProps);\n```\n\n_Parameters_\n\n* scope [`Construct`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_core.Construct.html)\n* id `string`\n* props [`EventbridgeToSqsProps`](#pattern-construct-props)\n\n## Pattern Construct Props\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n|existingEventBusInterface?|[`events.IEventBus`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_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/latest/docs/@aws-cdk_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|eventRuleProps|[`events.RuleProps`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-events.RuleProps.html)|User provided eventRuleProps to override the defaults. |\n|existingQueueObj?|[`sqs.Queue`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-sqs.Queue.html)|An optional, existing SQS queue to be used instead of the default queue. Providing both this and `queueProps` will cause an error.|\n|queueProps?|[`sqs.QueueProps`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-sqs.QueueProps.html)|User provided props to override the default props for the SQS Queue. |\n|enableQueuePurging?|`boolean`|Whether to grant additional permissions to the Lambda function enabling it to purge the SQS queue. Defaults to `false`.|\n|deployDeadLetterQueue?|`boolean`|Whether to create a secondary queue to be used as a dead letter queue. Defaults to `true`.|\n|deadLetterQueueProps?|[`sqs.QueueProps`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-sqs.QueueProps.html)|Optional user-provided props to override the default props for the dead letter queue. Only used if the `deployDeadLetterQueue` property is set to true.|\n|maxReceiveCount?|`number`|The number of times a message can be unsuccessfully dequeued before being moved to the dead letter queue. Defaults to `15`.|\n|enableEncryptionWithCustomerManagedKey?|`boolean`|Use a KMS Key, either managed by this CDK app, or imported. If importing an encryption key, it must be specified in the encryptionKey property for this construct.|\n|encryptionKey?|[`kms.Key`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-kms.Key.html)|An optional, imported encryption key to encrypt the SQS queue.|\n|encryptionKeyProps?|[`kms.KeyProps`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-kms.KeyProps.html)|An optional, user provided properties to override the default properties for the KMS encryption key.|\n\n## Pattern Properties\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n|eventBus?|[`events.IEventBus`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_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/latest/docs/@aws-cdk_aws-events.Rule.html)|Returns an instance of events.Rule created by the construct|\n|sqsQueue|[`sqs.Queue`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-sqs.Queue.html)|Returns an instance of sqs.Queue created by the construct|\n|encryptionKey?|[`kms.Key`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-kms.Key.html)|Returns an instance of kms Key used for the SQS queue.|\n|deadLetterQueue?|[`sqs.Queue`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-sqs.Queue.html)|Returns an instance of the dead-letter SQS queue created by the pattern.|\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 SQS Queue.\n\n### Amazon SQS Queue\n* Deploy SQS dead-letter queue for the source SQS Queue.\n* Enable server-side encryption for source SQS Queue 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 2021 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n"
3029
+ "markdown": "# aws-eventbridge-sqs 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_sqs`|\n|![Typescript Logo](https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png) Typescript|`@aws-solutions-constructs/aws-eventbridge-sqs`|\n|![Java Logo](https://docs.aws.amazon.com/cdk/api/latest/img/java32.png) Java|`software.amazon.awsconstructs.services.eventbridgesqs`|\n\nThis AWS Solutions Construct implements an Amazon EventBridge rule and an AWS SQS Queue.\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 { EventbridgeToSqsProps, EventbridgeToSqs } from \"@aws-solutions-constructs/aws-eventbridge-sqs\";\n\nconst constructProps: EventbridgeToSqsProps = {\n eventRuleProps: {\n schedule: events.Schedule.rate(Duration.minutes(5))\n }\n};\n\nconst constructStack = new EventbridgeToSqs(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_sqs import EventbridgeToSqsProps, EventbridgeToSqs\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 = EventbridgeToSqs(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.eventbridgesqs.*;\n\nfinal EventbridgeToSqs constructStack = new EventbridgeToSqs(this, \"test-construct\",\n new EventbridgeToSqsProps.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|existingEventBusInterface?|[`events.IEventBus`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_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/latest/docs/@aws-cdk_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|eventRuleProps|[`events.RuleProps`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-events.RuleProps.html)|User provided eventRuleProps to override the defaults. |\n|existingQueueObj?|[`sqs.Queue`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-sqs.Queue.html)|An optional, existing SQS queue to be used instead of the default queue. Providing both this and `queueProps` will cause an error.|\n|queueProps?|[`sqs.QueueProps`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-sqs.QueueProps.html)|User provided props to override the default props for the SQS Queue. |\n|enableQueuePurging?|`boolean`|Whether to grant additional permissions to the Lambda function enabling it to purge the SQS queue. Defaults to `false`.|\n|deployDeadLetterQueue?|`boolean`|Whether to create a secondary queue to be used as a dead letter queue. Defaults to `true`.|\n|deadLetterQueueProps?|[`sqs.QueueProps`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-sqs.QueueProps.html)|Optional user-provided props to override the default props for the dead letter queue. Only used if the `deployDeadLetterQueue` property is set to true.|\n|maxReceiveCount?|`number`|The number of times a message can be unsuccessfully dequeued before being moved to the dead letter queue. Defaults to `15`.|\n|enableEncryptionWithCustomerManagedKey?|`boolean`|Use a KMS Key, either managed by this CDK app, or imported. If importing an encryption key, it must be specified in the encryptionKey property for this construct.|\n|encryptionKey?|[`kms.Key`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-kms.Key.html)|An optional, imported encryption key to encrypt the SQS queue.|\n|encryptionKeyProps?|[`kms.KeyProps`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-kms.KeyProps.html)|An optional, user provided properties to override the default properties for the KMS encryption key.|\n\n## Pattern Properties\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n|eventBus?|[`events.IEventBus`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_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/latest/docs/@aws-cdk_aws-events.Rule.html)|Returns an instance of events.Rule created by the construct|\n|sqsQueue|[`sqs.Queue`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-sqs.Queue.html)|Returns an instance of sqs.Queue created by the construct|\n|encryptionKey?|[`kms.Key`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-kms.Key.html)|Returns an instance of kms Key used for the SQS queue.|\n|deadLetterQueue?|[`sqs.Queue`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_aws-sqs.Queue.html)|Returns an instance of the dead-letter SQS queue created by the pattern.|\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 SQS Queue.\n\n### Amazon SQS Queue\n* Deploy SQS dead-letter queue for the source SQS Queue.\n* Enable server-side encryption for source SQS Queue 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 2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n"
2978
3030
  },
2979
3031
  "repository": {
2980
3032
  "directory": "source/patterns/@aws-solutions-constructs/aws-eventbridge-sqs",
@@ -3343,6 +3395,6 @@
3343
3395
  "symbolId": "lib/index:EventbridgeToSqsProps"
3344
3396
  }
3345
3397
  },
3346
- "version": "2.5.0",
3347
- "fingerprint": "lAdKJMBhHaJLX/CxXhgfS/CmDV4hR0M6gxPMiIqJvPw="
3398
+ "version": "2.8.0",
3399
+ "fingerprint": "T0vog/fKMVicjHhF/TXjaGKNSuo3kULjeFiItpRHmWE="
3348
3400
  }
package/README.md CHANGED
@@ -20,44 +20,92 @@
20
20
 
21
21
  This AWS Solutions Construct implements an Amazon EventBridge rule and an AWS SQS Queue.
22
22
 
23
- Here is a minimal deployable pattern definition in Typescript:
23
+ Here is a minimal deployable pattern definition:
24
24
 
25
+ Typescript
25
26
  ``` typescript
26
- import { Duration } from '@aws-cdk/core';
27
- import * as events from '@aws-cdk/aws-events';
28
- import * as iam from '@aws-cdk/aws-iam';
27
+ import { Construct } from 'constructs';
28
+ import { Stack, StackProps, Duration } from 'aws-cdk-lib';
29
+ import * as events from 'aws-cdk-lib/aws-events';
30
+ import * as iam from 'aws-cdk-lib/aws-iam';
29
31
  import { EventbridgeToSqsProps, EventbridgeToSqs } from "@aws-solutions-constructs/aws-eventbridge-sqs";
30
32
 
31
- const props: EventbridgeToSqsProps = {
33
+ const constructProps: EventbridgeToSqsProps = {
32
34
  eventRuleProps: {
33
35
  schedule: events.Schedule.rate(Duration.minutes(5))
34
36
  }
35
37
  };
36
38
 
37
- const constructStack = new EventbridgeToSqs(this, 'test-construct', props);
39
+ const constructStack = new EventbridgeToSqs(this, 'test-construct', constructProps);
38
40
 
39
41
  // Grant yourself permissions to use the Customer Managed KMS Key
40
42
  const policyStatement = new iam.PolicyStatement({
41
43
  actions: ["kms:Encrypt", "kms:Decrypt"],
42
44
  effect: iam.Effect.ALLOW,
43
- principals: [ new iam.AccountRootPrincipal() ],
44
- resources: [ "*" ]
45
+ principals: [new iam.AccountRootPrincipal()],
46
+ resources: ["*"]
45
47
  });
46
48
 
47
49
  constructStack.encryptionKey?.addToResourcePolicy(policyStatement);
48
50
  ```
49
51
 
50
- ## Initializer
51
-
52
- ``` text
53
- new EventbridgeToSqs(scope: Construct, id: string, props: EventbridgeToSqsProps);
52
+ Python
53
+ ``` Python
54
+ from aws_solutions_constructs.aws_eventbridge_sqs import EventbridgeToSqsProps, EventbridgeToSqs
55
+ from aws_cdk import (
56
+ aws_events as events,
57
+ aws_iam as iam,
58
+ Duration,
59
+ Stack
60
+ )
61
+ from constructs import Construct
62
+
63
+ construct_stack = EventbridgeToSqs(self, 'test-construct',
64
+ event_rule_props=events.RuleProps(
65
+ schedule=events.Schedule.rate(
66
+ Duration.minutes(5))
67
+ ))
68
+
69
+ # Grant yourself permissions to use the Customer Managed KMS Key
70
+ policy_statement = iam.PolicyStatement(
71
+ actions=["kms:Encrypt", "kms:Decrypt"],
72
+ effect=iam.Effect.ALLOW,
73
+ principals=[iam.AccountRootPrincipal()],
74
+ resources=["*"]
75
+ )
76
+
77
+ construct_stack.encryption_key.add_to_resource_policy(policy_statement)
54
78
  ```
55
79
 
56
- _Parameters_
80
+ Java
81
+ ``` java
82
+ import software.constructs.Construct;
83
+ import java.util.List;
84
+
85
+ import software.amazon.awscdk.Stack;
86
+ import software.amazon.awscdk.StackProps;
87
+ import software.amazon.awscdk.Duration;
88
+ import software.amazon.awscdk.services.events.*;
89
+ import software.amazon.awscdk.services.iam.*;
90
+ import software.amazon.awsconstructs.services.eventbridgesqs.*;
91
+
92
+ final EventbridgeToSqs constructStack = new EventbridgeToSqs(this, "test-construct",
93
+ new EventbridgeToSqsProps.Builder()
94
+ .eventRuleProps(new RuleProps.Builder()
95
+ .schedule(Schedule.rate(Duration.minutes(5)))
96
+ .build())
97
+ .build());
57
98
 
58
- * scope [`Construct`](https://docs.aws.amazon.com/cdk/api/latest/docs/@aws-cdk_core.Construct.html)
59
- * id `string`
60
- * props [`EventbridgeToSqsProps`](#pattern-construct-props)
99
+ // Grant yourself permissions to use the Customer Managed KMS Key
100
+ final PolicyStatement policyStatement = PolicyStatement.Builder.create()
101
+ .actions(List.of("kms:Encrypt", "kms:Decrypt"))
102
+ .effect(Effect.ALLOW)
103
+ .principals(List.of(new AccountRootPrincipal()))
104
+ .resources(List.of("*"))
105
+ .build();
106
+
107
+ constructStack.getEncryptionKey().addToResourcePolicy(policyStatement);
108
+ ```
61
109
 
62
110
  ## Pattern Construct Props
63
111
 
@@ -102,4 +150,4 @@ Out of the box implementation of the Construct without any override will set the
102
150
  ![Architecture Diagram](architecture.png)
103
151
 
104
152
  ***
105
- &copy; Copyright 2021 Amazon.com, Inc. or its affiliates. All Rights Reserved.
153
+ &copy; Copyright 2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.
package/lib/index.d.ts CHANGED
@@ -108,3 +108,4 @@ export declare class EventbridgeToSqs extends Construct {
108
108
  */
109
109
  constructor(scope: Construct, id: string, props: EventbridgeToSqsProps);
110
110
  }
111
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAC3C,OAAO,KAAK,MAAM,MAAM,wBAAwB,CAAC;AACjD,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAI3C,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAGvC;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC;;;;OAIG;IACH,QAAQ,CAAC,yBAAyB,CAAC,EAAE,MAAM,CAAC,SAAS,CAAC;IACtD;;;;OAIG;IACH,QAAQ,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC,aAAa,CAAC;IAC9C;;;;OAIG;IACH,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC,SAAS,CAAC;IAC1C;;;;OAIG;IACH,QAAQ,CAAC,gBAAgB,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC;IACtC;;;;OAIG;IACH,QAAQ,CAAC,UAAU,CAAC,EAAE,GAAG,CAAC,UAAU,CAAC;IACrC;;;;OAIG;IACH,QAAQ,CAAC,kBAAkB,CAAC,EAAE,OAAO,CAAC;IACtC;;;;OAIG;IACH,QAAQ,CAAC,oBAAoB,CAAC,EAAE,GAAG,CAAC,UAAU,CAAC;IAC/C;;;;OAIG;IACH,QAAQ,CAAC,qBAAqB,CAAC,EAAE,OAAO,CAAC;IACzC;;;;OAIG;IACH,QAAQ,CAAC,eAAe,CAAC,EAAE,MAAM,CAAC;IAClC;;;;;OAKG;IACH,QAAQ,CAAC,sCAAsC,CAAC,EAAE,OAAO,CAAC;IAC1D;;;;OAIG;IACH,QAAQ,CAAC,aAAa,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC;IACjC;;;;OAIG;IACH,QAAQ,CAAC,kBAAkB,CAAC,EAAE,GAAG,CAAC,QAAQ,CAAC;CAC5C;AAED,qBAAa,gBAAiB,SAAQ,SAAS;IAC7C,SAAgB,QAAQ,EAAE,GAAG,CAAC,KAAK,CAAC;IACpC,SAAgB,eAAe,CAAC,EAAE,GAAG,CAAC,eAAe,CAAC;IACtD,SAAgB,QAAQ,CAAC,EAAE,MAAM,CAAC,SAAS,CAAC;IAC5C,SAAgB,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC;IACxC,SAAgB,aAAa,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC;IAEzC;;;;;;;OAOG;gBACS,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,qBAAqB;CAsDvE"}
package/lib/index.js CHANGED
@@ -66,5 +66,5 @@ class EventbridgeToSqs extends constructs_1.Construct {
66
66
  }
67
67
  exports.EventbridgeToSqs = EventbridgeToSqs;
68
68
  _a = JSII_RTTI_SYMBOL_1;
69
- EventbridgeToSqs[_a] = { fqn: "@aws-solutions-constructs/aws-eventbridge-sqs.EventbridgeToSqs", version: "2.5.0" };
69
+ EventbridgeToSqs[_a] = { fqn: "@aws-solutions-constructs/aws-eventbridge-sqs.EventbridgeToSqs", version: "2.8.0" };
70
70
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAcA,iDAAiD;AAEjD,2DAA2D;AAC3D,iDAAuD;AACvD,wFAAwF;AACxF,2CAAuC;AACvC,yDAA+D;AAiF/D,MAAa,gBAAiB,SAAQ,sBAAS;IAO7C;;;;;;;OAOG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA4B;QACpE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAE3B,6CAA6C;QAC7C,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,oBAAoB,CAAC,IAAI,EAAE;YACzD,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;YACxC,qBAAqB,EAAE,KAAK,CAAC,qBAAqB;YAClD,oBAAoB,EAAE,KAAK,CAAC,oBAAoB;YAChD,eAAe,EAAE,KAAK,CAAC,eAAe;SACvC,CAAC,CAAC;QAEH,IAAI,qBAAqB,GAAG,KAAK,CAAC,sCAAsC,CAAC;QACzE,IAAI,KAAK,CAAC,sCAAsC,KAAK,SAAS;YAC5D,KAAK,CAAC,sCAAsC,KAAK,IAAI,EAAE;YACvD,qBAAqB,GAAG,IAAI,CAAC;SAC9B;QAED,kBAAkB;QAClB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,QAAQ,CAAC,UAAU,CAAC,IAAI,EAAE,OAAO,EAAE;YACvE,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;YACxC,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,sCAAsC,EAAE,qBAAqB;YAC7D,aAAa,EAAE,KAAK,CAAC,aAAa;YAClC,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;SAC7C,CAAC,CAAC;QAEH,MAAM,cAAc,GAAuB;YACzC,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;gBACX,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS;gBAC3B,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,MAAM,sBAAsB,GAAG,QAAQ,CAAC,sBAAsB,CAAC,CAAC,cAAc,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAChG,MAAM,eAAe,GAAG,oBAAa,CAAC,sBAAsB,EAAE,KAAK,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;QAE1F,IAAI,CAAC,UAAU,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,YAAY,EAAE,eAAe,CAAC,CAAC;QAEvE,kEAAkE;QAClE,IAAI,KAAK,CAAC,kBAAkB,EAAE;YAC5B,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,0BAAgB,CAAC,sBAAsB,CAAC,CAAC,CAAC;SACxE;QAED,kIAAkI;QAClI,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,0BAAgB,CAAC,sBAAsB,CAAC,CAAC,CAAC;IAChF,CAAC;;AApEH,4CAqEC","sourcesContent":["/**\n *  Copyright 2022 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 sqs from 'aws-cdk-lib/aws-sqs';\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 { ServicePrincipal } from 'aws-cdk-lib/aws-iam';\n// Note: To ensure CDKv2 compatibility, keep the import statement for Construct separate\nimport { Construct } from 'constructs';\nimport { overrideProps } from '@aws-solutions-constructs/core';\n\n/**\n * @summary The properties for the EventbridgeToSqs Construct\n */\nexport interface EventbridgeToSqsProps {\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 SQS queue object, providing both this and queueProps will cause an error.\n   *\n   * @default - None\n   */\n  readonly existingQueueObj?: sqs.Queue;\n  /**\n   * User provided props to override the default props for the SQS queue.\n   *\n   * @default - Default props are used\n   */\n  readonly queueProps?: sqs.QueueProps;\n  /**\n   * Whether to grant additional permissions to the Lambda function enabling it to purge the SQS queue.\n   *\n   * @default - \"false\", disabled by default.\n   */\n  readonly enableQueuePurging?: boolean;\n  /**\n   * Optional user provided properties for the dead letter queue\n   *\n   * @default - Default props are used\n   */\n  readonly deadLetterQueueProps?: sqs.QueueProps;\n  /**\n   * Whether to deploy a secondary queue to be used as a dead letter queue.\n   *\n   * @default - true.\n   */\n  readonly deployDeadLetterQueue?: boolean;\n  /**\n   * The number of times a message can be unsuccessfully dequeued before being moved to the dead-letter queue.\n   *\n   * @default - required field if deployDeadLetterQueue=true.\n   */\n  readonly maxReceiveCount?: number;\n  /**\n   * Use a KMS Key, either managed by this CDK app, or imported. If importing an encryption key, it must be specified in\n   * the encryptionKey property for this construct.\n   *\n   * @default - true (encryption enabled, managed by this CDK app).\n   */\n  readonly enableEncryptionWithCustomerManagedKey?: boolean;\n  /**\n   * An optional, imported encryption key to encrypt the SQS queue, and SNS Topic.\n   *\n   * @default - not specified.\n   */\n  readonly encryptionKey?: kms.Key;\n  /**\n   * Optional user-provided props to override the default props for the encryption key.\n   *\n   * @default - Default props are used.\n   */\n  readonly encryptionKeyProps?: kms.KeyProps;\n}\n\nexport class EventbridgeToSqs extends Construct {\n  public readonly sqsQueue: sqs.Queue;\n  public readonly deadLetterQueue?: sqs.DeadLetterQueue;\n  public readonly eventBus?: events.IEventBus;\n  public readonly eventsRule: events.Rule;\n  public readonly encryptionKey?: kms.IKey;\n\n  /**\n   * @summary Constructs a new instance of the EventbridgeToSqs 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 {EventbridgeToSqsProps} props - user provided props for the construct\n   * @since 1.62.0\n   * @access public\n   */\n  constructor(scope: Construct, id: string, props: EventbridgeToSqsProps) {\n    super(scope, id);\n    defaults.CheckProps(props);\n\n    // Setup the dead letter queue, if applicable\n    this.deadLetterQueue = defaults.buildDeadLetterQueue(this, {\n      existingQueueObj: props.existingQueueObj,\n      deployDeadLetterQueue: props.deployDeadLetterQueue,\n      deadLetterQueueProps: props.deadLetterQueueProps,\n      maxReceiveCount: props.maxReceiveCount\n    });\n\n    let enableEncryptionParam = props.enableEncryptionWithCustomerManagedKey;\n    if (props.enableEncryptionWithCustomerManagedKey === undefined ||\n      props.enableEncryptionWithCustomerManagedKey === true) {\n      enableEncryptionParam = true;\n    }\n\n    // Setup the queue\n    [this.sqsQueue, this.encryptionKey] = defaults.buildQueue(this, 'queue', {\n      existingQueueObj: props.existingQueueObj,\n      queueProps: props.queueProps,\n      deadLetterQueue: this.deadLetterQueue,\n      enableEncryptionWithCustomerManagedKey: enableEncryptionParam,\n      encryptionKey: props.encryptionKey,\n      encryptionKeyProps: props.encryptionKeyProps\n    });\n\n    const sqsEventTarget: events.IRuleTarget = {\n      bind: () => ({\n        id: this.sqsQueue.queueName,\n        arn: this.sqsQueue.queueArn\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    const defaultEventsRuleProps = defaults.DefaultEventsRuleProps([sqsEventTarget], this.eventBus);\n    const eventsRuleProps = overrideProps(defaultEventsRuleProps, props.eventRuleProps, true);\n\n    this.eventsRule = new events.Rule(this, 'EventsRule', eventsRuleProps);\n\n    // Enable queue purging permissions for the event rule, if enabled\n    if (props.enableQueuePurging) {\n      this.sqsQueue.grantPurge(new ServicePrincipal('events.amazonaws.com'));\n    }\n\n    // Policy for event to be able to send messages to the queue and Grant Event Bridge service access to the SQS queue encryption key\n    this.sqsQueue.grantSendMessages(new ServicePrincipal('events.amazonaws.com'));\n  }\n}"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-solutions-constructs/aws-eventbridge-sqs",
3
- "version": "2.5.0",
3
+ "version": "2.8.0",
4
4
  "description": "CDK Constructs for deploying AWS Eventbridge that invokes AWS SQS",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
@@ -53,13 +53,13 @@
53
53
  }
54
54
  },
55
55
  "dependencies": {
56
- "@aws-solutions-constructs/core": "2.5.0"
56
+ "@aws-solutions-constructs/core": "2.8.0"
57
57
  },
58
58
  "devDependencies": {
59
- "@aws-cdk/assert": "2.15.0",
59
+ "@aws-cdk/assert": "2.23.0",
60
60
  "@types/jest": "^27.4.0",
61
61
  "@types/node": "^10.3.0",
62
- "aws-cdk-lib": "2.15.0",
62
+ "aws-cdk-lib": "2.23.0",
63
63
  "constructs": "^10.0.0"
64
64
  },
65
65
  "jest": {
@@ -77,8 +77,8 @@
77
77
  ]
78
78
  },
79
79
  "peerDependencies": {
80
- "@aws-solutions-constructs/core": "2.5.0",
81
- "aws-cdk-lib": "^2.15.0",
80
+ "@aws-solutions-constructs/core": "2.8.0",
81
+ "aws-cdk-lib": "^2.23.0",
82
82
  "constructs": "^10.0.0"
83
83
  },
84
84
  "keywords": [
@@ -11,3 +11,4 @@
11
11
  * and limitations under the License.
12
12
  */
13
13
  import '@aws-cdk/assert/jest';
14
+ //# sourceMappingURL=eventbridge-sqs-queue.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eventbridge-sqs-queue.test.d.ts","sourceRoot":"","sources":["eventbridge-sqs-queue.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAKH,OAAO,sBAAsB,CAAC"}
@@ -11,3 +11,4 @@
11
11
  * and limitations under the License.
12
12
  */
13
13
  export {};
14
+ //# sourceMappingURL=integ.exist-bus.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"integ.exist-bus.d.ts","sourceRoot":"","sources":["integ.exist-bus.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG"}
@@ -11,3 +11,4 @@
11
11
  * and limitations under the License.
12
12
  */
13
13
  export {};
14
+ //# sourceMappingURL=integ.exist-queue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"integ.exist-queue.d.ts","sourceRoot":"","sources":["integ.exist-queue.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG"}
@@ -11,3 +11,4 @@
11
11
  * and limitations under the License.
12
12
  */
13
13
  export {};
14
+ //# sourceMappingURL=integ.new-bus.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"integ.new-bus.d.ts","sourceRoot":"","sources":["integ.new-bus.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG"}
@@ -11,3 +11,4 @@
11
11
  * and limitations under the License.
12
12
  */
13
13
  export {};
14
+ //# sourceMappingURL=integ.no-arg.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"integ.no-arg.d.ts","sourceRoot":"","sources":["integ.no-arg.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG"}