@aws-solutions-constructs/aws-eventbridge-sqs 2.27.0 → 2.29.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 +130 -13
- package/README.md +3 -3
- package/lib/index.d.ts +7 -7
- package/lib/index.js +2 -2
- package/package.json +6 -6
- package/test/eventbridge-sqs-queue.test.js +178 -1
package/.jsii
CHANGED
|
@@ -8,11 +8,89 @@
|
|
|
8
8
|
"url": "https://aws.amazon.com"
|
|
9
9
|
},
|
|
10
10
|
"dependencies": {
|
|
11
|
-
"@aws-solutions-constructs/core": "2.
|
|
12
|
-
"aws-cdk-lib": "^2.
|
|
11
|
+
"@aws-solutions-constructs/core": "2.29.0",
|
|
12
|
+
"aws-cdk-lib": "^2.53.0",
|
|
13
13
|
"constructs": "^10.0.0"
|
|
14
14
|
},
|
|
15
15
|
"dependencyClosure": {
|
|
16
|
+
"@aws-cdk/asset-awscli-v1": {
|
|
17
|
+
"targets": {
|
|
18
|
+
"dotnet": {
|
|
19
|
+
"namespace": "Amazon.CDK.Asset.AwsCliV1",
|
|
20
|
+
"packageId": "Amazon.CDK.Asset.AwsCliV1"
|
|
21
|
+
},
|
|
22
|
+
"go": {
|
|
23
|
+
"moduleName": "github.com/cdklabs/awscdk-asset-awscli-go",
|
|
24
|
+
"packageName": "awscliv1"
|
|
25
|
+
},
|
|
26
|
+
"java": {
|
|
27
|
+
"maven": {
|
|
28
|
+
"artifactId": "cdk-asset-awscli-v1",
|
|
29
|
+
"groupId": "software.amazon.awscdk"
|
|
30
|
+
},
|
|
31
|
+
"package": "software.amazon.awscdk.cdk.asset.awscli.v1"
|
|
32
|
+
},
|
|
33
|
+
"js": {
|
|
34
|
+
"npm": "@aws-cdk/asset-awscli-v1"
|
|
35
|
+
},
|
|
36
|
+
"python": {
|
|
37
|
+
"distName": "aws-cdk.asset-awscli-v1",
|
|
38
|
+
"module": "aws_cdk.asset_awscli_v1"
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
"@aws-cdk/asset-kubectl-v20": {
|
|
43
|
+
"targets": {
|
|
44
|
+
"dotnet": {
|
|
45
|
+
"namespace": "Amazon.CDK.Asset.KubectlV20",
|
|
46
|
+
"packageId": "Amazon.CDK.Asset.KubectlV20"
|
|
47
|
+
},
|
|
48
|
+
"go": {
|
|
49
|
+
"moduleName": "github.com/cdklabs/awscdk-asset-kubectl-go",
|
|
50
|
+
"packageName": "kubectlv20"
|
|
51
|
+
},
|
|
52
|
+
"java": {
|
|
53
|
+
"maven": {
|
|
54
|
+
"artifactId": "cdk-asset-kubectl-v20",
|
|
55
|
+
"groupId": "software.amazon.awscdk"
|
|
56
|
+
},
|
|
57
|
+
"package": "software.amazon.awscdk.cdk.asset.kubectl.v20"
|
|
58
|
+
},
|
|
59
|
+
"js": {
|
|
60
|
+
"npm": "@aws-cdk/asset-kubectl-v20"
|
|
61
|
+
},
|
|
62
|
+
"python": {
|
|
63
|
+
"distName": "aws-cdk.asset-kubectl-v20",
|
|
64
|
+
"module": "aws_cdk.asset_kubectl_v20"
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
"@aws-cdk/asset-node-proxy-agent-v5": {
|
|
69
|
+
"targets": {
|
|
70
|
+
"dotnet": {
|
|
71
|
+
"namespace": "Amazon.CDK.Asset.NodeProxyAgentV5",
|
|
72
|
+
"packageId": "Amazon.CDK.Asset.NodeProxyAgentV5"
|
|
73
|
+
},
|
|
74
|
+
"go": {
|
|
75
|
+
"moduleName": "github.com/cdklabs/awscdk-asset-node-proxy-agent-go",
|
|
76
|
+
"packageName": "nodeproxyagentv5"
|
|
77
|
+
},
|
|
78
|
+
"java": {
|
|
79
|
+
"maven": {
|
|
80
|
+
"artifactId": "cdk-asset-node-proxy-agent-v5",
|
|
81
|
+
"groupId": "software.amazon.awscdk"
|
|
82
|
+
},
|
|
83
|
+
"package": "software.amazon.awscdk.cdk.asset.node.proxy.agent.v5"
|
|
84
|
+
},
|
|
85
|
+
"js": {
|
|
86
|
+
"npm": "@aws-cdk/asset-node-proxy-agent-v5"
|
|
87
|
+
},
|
|
88
|
+
"python": {
|
|
89
|
+
"distName": "aws-cdk.asset-node-proxy-agent-v5",
|
|
90
|
+
"module": "aws_cdk.asset_node_proxy_agent_v5"
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
},
|
|
16
94
|
"@aws-solutions-constructs/core": {
|
|
17
95
|
"targets": {
|
|
18
96
|
"dotnet": {
|
|
@@ -2172,6 +2250,19 @@
|
|
|
2172
2250
|
}
|
|
2173
2251
|
}
|
|
2174
2252
|
},
|
|
2253
|
+
"aws-cdk-lib.aws_organizations": {
|
|
2254
|
+
"targets": {
|
|
2255
|
+
"dotnet": {
|
|
2256
|
+
"namespace": "Amazon.CDK.AWS.Organizations"
|
|
2257
|
+
},
|
|
2258
|
+
"java": {
|
|
2259
|
+
"package": "software.amazon.awscdk.services.organizations"
|
|
2260
|
+
},
|
|
2261
|
+
"python": {
|
|
2262
|
+
"module": "aws_cdk.aws_organizations"
|
|
2263
|
+
}
|
|
2264
|
+
}
|
|
2265
|
+
},
|
|
2175
2266
|
"aws-cdk-lib.aws_panorama": {
|
|
2176
2267
|
"targets": {
|
|
2177
2268
|
"dotnet": {
|
|
@@ -2341,6 +2432,19 @@
|
|
|
2341
2432
|
}
|
|
2342
2433
|
}
|
|
2343
2434
|
},
|
|
2435
|
+
"aws-cdk-lib.aws_resourceexplorer2": {
|
|
2436
|
+
"targets": {
|
|
2437
|
+
"dotnet": {
|
|
2438
|
+
"namespace": "Amazon.CDK.AWS.ResourceExplorer2"
|
|
2439
|
+
},
|
|
2440
|
+
"java": {
|
|
2441
|
+
"package": "software.amazon.awscdk.services.resourceexplorer2"
|
|
2442
|
+
},
|
|
2443
|
+
"python": {
|
|
2444
|
+
"module": "aws_cdk.aws_resourceexplorer2"
|
|
2445
|
+
}
|
|
2446
|
+
}
|
|
2447
|
+
},
|
|
2344
2448
|
"aws-cdk-lib.aws_resourcegroups": {
|
|
2345
2449
|
"targets": {
|
|
2346
2450
|
"dotnet": {
|
|
@@ -2575,6 +2679,19 @@
|
|
|
2575
2679
|
}
|
|
2576
2680
|
}
|
|
2577
2681
|
},
|
|
2682
|
+
"aws-cdk-lib.aws_scheduler": {
|
|
2683
|
+
"targets": {
|
|
2684
|
+
"dotnet": {
|
|
2685
|
+
"namespace": "Amazon.CDK.AWS.Scheduler"
|
|
2686
|
+
},
|
|
2687
|
+
"java": {
|
|
2688
|
+
"package": "software.amazon.awscdk.services.scheduler"
|
|
2689
|
+
},
|
|
2690
|
+
"python": {
|
|
2691
|
+
"module": "aws_cdk.aws_scheduler"
|
|
2692
|
+
}
|
|
2693
|
+
}
|
|
2694
|
+
},
|
|
2578
2695
|
"aws-cdk-lib.aws_sdb": {
|
|
2579
2696
|
"targets": {
|
|
2580
2697
|
"dotnet": {
|
|
@@ -3137,7 +3254,7 @@
|
|
|
3137
3254
|
},
|
|
3138
3255
|
"description": "CDK Constructs for deploying AWS Eventbridge that invokes AWS SQS",
|
|
3139
3256
|
"homepage": "https://github.com/awslabs/aws-solutions-constructs.git",
|
|
3140
|
-
"jsiiVersion": "1.
|
|
3257
|
+
"jsiiVersion": "1.71.0 (build f1f58ae)",
|
|
3141
3258
|
"keywords": [
|
|
3142
3259
|
"aws",
|
|
3143
3260
|
"cdk",
|
|
@@ -3156,7 +3273,7 @@
|
|
|
3156
3273
|
},
|
|
3157
3274
|
"name": "@aws-solutions-constructs/aws-eventbridge-sqs",
|
|
3158
3275
|
"readme": {
|
|
3159
|
-
"markdown": "# aws-eventbridge-sqs module\n<!--BEGIN STABILITY BANNER-->\n\n---\n\n\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|`aws_solutions_constructs.aws_eventbridge_sqs`|\n| Typescript|`@aws-solutions-constructs/aws-eventbridge-sqs`|\n| Java|`software.amazon.awsconstructs.services.eventbridgesqs`|\n\n## Overview\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/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|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|existingQueueObj?|[`sqs.Queue`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.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/v2/docs/aws-cdk-lib.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/v2/docs/aws-cdk-lib.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`|
|
|
3276
|
+
"markdown": "# aws-eventbridge-sqs module\n<!--BEGIN STABILITY BANNER-->\n\n---\n\n\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|`aws_solutions_constructs.aws_eventbridge_sqs`|\n| Typescript|`@aws-solutions-constructs/aws-eventbridge-sqs`|\n| Java|`software.amazon.awsconstructs.services.eventbridgesqs`|\n\n## Overview\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/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|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|existingQueueObj?|[`sqs.Queue`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.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/v2/docs/aws-cdk-lib.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/v2/docs/aws-cdk-lib.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`|If no key is provided, this flag determines whether the queue is encrypted with a new CMK or an AWS managed key. This flag is ignored if any of the following are defined: queueProps.encryptionMasterKey, 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 SQS Queue 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 SQS queue 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|sqsQueue|[`sqs.Queue`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.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/v2/docs/aws-cdk-lib.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/v2/docs/aws-cdk-lib.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\n\n***\n© Copyright 2022 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n"
|
|
3160
3277
|
},
|
|
3161
3278
|
"repository": {
|
|
3162
3279
|
"directory": "source/patterns/@aws-solutions-constructs/aws-eventbridge-sqs",
|
|
@@ -3370,9 +3487,9 @@
|
|
|
3370
3487
|
{
|
|
3371
3488
|
"abstract": true,
|
|
3372
3489
|
"docs": {
|
|
3373
|
-
"default": "-
|
|
3374
|
-
"remarks": "
|
|
3375
|
-
"summary": "
|
|
3490
|
+
"default": "- True if queueProps.encryptionMasterKey, encryptionKey, and encryptionKeyProps are all undefined.",
|
|
3491
|
+
"remarks": "This flag is ignored if any of the following are defined: queueProps.encryptionMasterKey, encryptionKey or encryptionKeyProps.",
|
|
3492
|
+
"summary": "If no key is provided, this flag determines whether the queue is encrypted with a new CMK or an AWS managed key."
|
|
3376
3493
|
},
|
|
3377
3494
|
"immutable": true,
|
|
3378
3495
|
"locationInModule": {
|
|
@@ -3405,8 +3522,8 @@
|
|
|
3405
3522
|
{
|
|
3406
3523
|
"abstract": true,
|
|
3407
3524
|
"docs": {
|
|
3408
|
-
"default": "-
|
|
3409
|
-
"summary": "An optional, imported encryption key to encrypt the SQS queue
|
|
3525
|
+
"default": "- None",
|
|
3526
|
+
"summary": "An optional, imported encryption key to encrypt the SQS queue with."
|
|
3410
3527
|
},
|
|
3411
3528
|
"immutable": true,
|
|
3412
3529
|
"locationInModule": {
|
|
@@ -3422,8 +3539,8 @@
|
|
|
3422
3539
|
{
|
|
3423
3540
|
"abstract": true,
|
|
3424
3541
|
"docs": {
|
|
3425
|
-
"default": "-
|
|
3426
|
-
"summary": "Optional user
|
|
3542
|
+
"default": "- None",
|
|
3543
|
+
"summary": "Optional user provided properties to override the default properties for the KMS encryption key used to encrypt the SQS queue with."
|
|
3427
3544
|
},
|
|
3428
3545
|
"immutable": true,
|
|
3429
3546
|
"locationInModule": {
|
|
@@ -3525,6 +3642,6 @@
|
|
|
3525
3642
|
"symbolId": "lib/index:EventbridgeToSqsProps"
|
|
3526
3643
|
}
|
|
3527
3644
|
},
|
|
3528
|
-
"version": "2.
|
|
3529
|
-
"fingerprint": "
|
|
3645
|
+
"version": "2.29.0",
|
|
3646
|
+
"fingerprint": "TEAO5GjggZe7HUThxblF82keA8gpLC1OFU36RX6U03o="
|
|
3530
3647
|
}
|
package/README.md
CHANGED
|
@@ -121,9 +121,9 @@ constructStack.getEncryptionKey().addToResourcePolicy(policyStatement);
|
|
|
121
121
|
|deployDeadLetterQueue?|`boolean`|Whether to create a secondary queue to be used as a dead letter queue. Defaults to `true`.|
|
|
122
122
|
|deadLetterQueueProps?|[`sqs.QueueProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.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.|
|
|
123
123
|
|maxReceiveCount?|`number`|The number of times a message can be unsuccessfully dequeued before being moved to the dead letter queue. Defaults to `15`.|
|
|
124
|
-
|enableEncryptionWithCustomerManagedKey?|`boolean`|
|
|
125
|
-
|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 SQS
|
|
126
|
-
|encryptionKeyProps?|[`kms.KeyProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_kms.
|
|
124
|
+
|enableEncryptionWithCustomerManagedKey?|`boolean`|If no key is provided, this flag determines whether the queue is encrypted with a new CMK or an AWS managed key. This flag is ignored if any of the following are defined: queueProps.encryptionMasterKey, encryptionKey or encryptionKeyProps.|
|
|
125
|
+
|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 SQS Queue with.|
|
|
126
|
+
|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 SQS queue with.|
|
|
127
127
|
|
|
128
128
|
## Pattern Properties
|
|
129
129
|
|
package/lib/index.d.ts
CHANGED
|
@@ -73,22 +73,22 @@ export interface EventbridgeToSqsProps {
|
|
|
73
73
|
*/
|
|
74
74
|
readonly maxReceiveCount?: number;
|
|
75
75
|
/**
|
|
76
|
-
*
|
|
77
|
-
* the
|
|
76
|
+
* If no key is provided, this flag determines whether the queue is encrypted with a new CMK or an AWS managed key.
|
|
77
|
+
* This flag is ignored if any of the following are defined: queueProps.encryptionMasterKey, encryptionKey or encryptionKeyProps.
|
|
78
78
|
*
|
|
79
|
-
* @default -
|
|
79
|
+
* @default - True if queueProps.encryptionMasterKey, encryptionKey, and encryptionKeyProps are all undefined.
|
|
80
80
|
*/
|
|
81
81
|
readonly enableEncryptionWithCustomerManagedKey?: boolean;
|
|
82
82
|
/**
|
|
83
|
-
* An optional, imported encryption key to encrypt the SQS queue
|
|
83
|
+
* An optional, imported encryption key to encrypt the SQS queue with.
|
|
84
84
|
*
|
|
85
|
-
* @default -
|
|
85
|
+
* @default - None
|
|
86
86
|
*/
|
|
87
87
|
readonly encryptionKey?: kms.Key;
|
|
88
88
|
/**
|
|
89
|
-
* Optional user
|
|
89
|
+
* Optional user provided properties to override the default properties for the KMS encryption key used to encrypt the SQS queue with.
|
|
90
90
|
*
|
|
91
|
-
* @default -
|
|
91
|
+
* @default - None
|
|
92
92
|
*/
|
|
93
93
|
readonly encryptionKeyProps?: kms.KeyProps;
|
|
94
94
|
}
|
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.
|
|
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}"]}
|
|
69
|
+
EventbridgeToSqs[_a] = { fqn: "@aws-solutions-constructs/aws-eventbridge-sqs.EventbridgeToSqs", version: "2.29.0" };
|
|
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   * If no key is provided, this flag determines whether the queue is encrypted with a new CMK or an AWS managed key.\n   * This flag is ignored if any of the following are defined: queueProps.encryptionMasterKey, encryptionKey or encryptionKeyProps.\n   *\n   * @default - True if queueProps.encryptionMasterKey, encryptionKey, and encryptionKeyProps are all undefined.\n   */\n  readonly enableEncryptionWithCustomerManagedKey?: boolean;\n  /**\n   * An optional, imported encryption key to encrypt the SQS queue 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 SQS queue with.\n   *\n   * @default - None\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.
|
|
3
|
+
"version": "2.29.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.
|
|
56
|
+
"@aws-solutions-constructs/core": "2.29.0"
|
|
57
57
|
},
|
|
58
58
|
"devDependencies": {
|
|
59
|
-
"@aws-cdk/assert": "2.
|
|
59
|
+
"@aws-cdk/assert": "2.53.0",
|
|
60
60
|
"@types/jest": "^27.4.0",
|
|
61
61
|
"@types/node": "^10.3.0",
|
|
62
|
-
"aws-cdk-lib": "2.
|
|
62
|
+
"aws-cdk-lib": "2.53.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.
|
|
81
|
-
"aws-cdk-lib": "^2.
|
|
80
|
+
"@aws-solutions-constructs/core": "2.29.0",
|
|
81
|
+
"aws-cdk-lib": "^2.53.0",
|
|
82
82
|
"constructs": "^10.0.0"
|
|
83
83
|
},
|
|
84
84
|
"keywords": [
|
|
@@ -304,4 +304,181 @@ test('check custom event bus resource with props when deploy:true', () => {
|
|
|
304
304
|
Name: 'testcustomeventbus'
|
|
305
305
|
});
|
|
306
306
|
});
|
|
307
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eventbridge-sqs-queue.test.js","sourceRoot":"","sources":["eventbridge-sqs-queue.test.ts"],"names":[],"mappings":"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","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 cdk from 'aws-cdk-lib';\nimport { EventbridgeToSqs, EventbridgeToSqsProps } from '../lib';\nimport * as events from \"aws-cdk-lib/aws-events\";\nimport '@aws-cdk/assert/jest';\nimport * as defaults from '@aws-solutions-constructs/core';\n\nfunction deployNewStack(stack: cdk.Stack) {\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      schedule: events.Schedule.rate(cdk.Duration.minutes(5))\n    }\n  };\n  return new EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);\n}\n\nfunction deployStackWithNewEventBus(stack: cdk.Stack) {\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      eventPattern: {\n        source: ['solutionsconstructs']\n      }\n    },\n    eventBusProps: { eventBusName: 'test' }\n  };\n  return new EventbridgeToSqs(stack, 'test-eventbridge-sqs-new-bus', props);\n}\n\ntest('check the sqs queue properties', () => {\n  const stack = new cdk.Stack();\n  deployNewStack(stack);\n  expect(stack).toHaveResource('AWS::SQS::Queue', {\n    KmsMasterKeyId: {\n      \"Fn::GetAtt\": [\n        \"testeventbridgesqsEncryptionKey811BDC23\",\n        \"Arn\"\n      ]\n    },\n    RedrivePolicy: {\n      deadLetterTargetArn: {\n        \"Fn::GetAtt\": [\n          \"testeventbridgesqsdeadLetterQueueF5B377E2\",\n          \"Arn\"\n        ]\n      },\n      maxReceiveCount: 15\n    }\n  });\n});\n\ntest('check the sqs queue properties with existing KMS key', () => {\n  const stack = new cdk.Stack();\n  const key = defaults.buildEncryptionKey(stack, {\n    description: 'my-key'\n  });\n\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      schedule: events.Schedule.rate(cdk.Duration.minutes(5))\n    },\n    encryptionKey: key\n  };\n\n  new EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);\n\n  expect(stack).toHaveResource('AWS::SQS::Queue', {\n    KmsMasterKeyId: {\n      \"Fn::GetAtt\": [\n        \"EncryptionKey1B843E66\",\n        \"Arn\"\n      ]\n    },\n    RedrivePolicy: {\n      deadLetterTargetArn: {\n        \"Fn::GetAtt\": [\n          \"testeventbridgesqsdeadLetterQueueF5B377E2\",\n          \"Arn\"\n        ]\n      },\n      maxReceiveCount: 15\n    }\n  });\n\n  expect(stack).toHaveResource('AWS::KMS::Key', {\n    Description: \"my-key\",\n    EnableKeyRotation: true\n  });\n});\n\ntest('check if the event rule has permission/policy in place in sqs queue for it to be able to send messages to the queue.', () => {\n  const stack = new cdk.Stack();\n  deployNewStack(stack);\n  expect(stack).toHaveResource('AWS::SQS::QueuePolicy', {\n    PolicyDocument:  {\n      Statement: [\n        {\n          Action: [\n            \"sqs:DeleteMessage\",\n            \"sqs:ReceiveMessage\",\n            \"sqs:SendMessage\",\n            \"sqs:GetQueueAttributes\",\n            \"sqs:RemovePermission\",\n            \"sqs:AddPermission\",\n            \"sqs:SetQueueAttributes\",\n          ],\n          Effect: \"Allow\",\n          Principal:  {\n            AWS:  {\n              \"Fn::Join\": [\n                \"\",\n                [\n                  \"arn:\",\n                  {\n                    Ref: \"AWS::Partition\",\n                  },\n                  \":iam::\",\n                  {\n                    Ref: \"AWS::AccountId\",\n                  },\n                  \":root\"\n                ],\n              ],\n            },\n          },\n          Resource:  {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsqueue21FF6EBA\",\n              \"Arn\",\n            ],\n          },\n          Sid: \"QueueOwnerOnlyAccess\",\n        },\n        {\n          Action: \"SQS:*\",\n          Condition:  {\n            Bool:  {\n              \"aws:SecureTransport\": \"false\",\n            },\n          },\n          Effect: \"Deny\",\n          Principal: {\n            AWS: \"*\"\n          },\n          Resource:  {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsqueue21FF6EBA\",\n              \"Arn\",\n            ],\n          },\n          Sid: \"HttpsOnly\",\n        },\n        {\n          Action: [\n            \"sqs:SendMessage\",\n            \"sqs:GetQueueAttributes\",\n            \"sqs:GetQueueUrl\"\n          ],\n          Effect: \"Allow\",\n          Principal: {\n            Service: \"events.amazonaws.com\"\n          },\n          Resource: {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsqueue21FF6EBA\",\n              \"Arn\"\n            ]\n          }\n        }\n      ],\n      Version: \"2012-10-17\"\n    },\n    Queues: [\n      {\n        Ref: \"testeventbridgesqsqueue21FF6EBA\",\n      }\n    ]\n  });\n});\n\ntest('check if the dead letter queue policy is setup', () => {\n  const stack = new cdk.Stack();\n  deployNewStack(stack);\n  expect(stack).toHaveResource('AWS::SQS::QueuePolicy', {\n    PolicyDocument:  {\n      Statement: [\n        {\n          Action: [\n            \"sqs:DeleteMessage\",\n            \"sqs:ReceiveMessage\",\n            \"sqs:SendMessage\",\n            \"sqs:GetQueueAttributes\",\n            \"sqs:RemovePermission\",\n            \"sqs:AddPermission\",\n            \"sqs:SetQueueAttributes\",\n          ],\n          Effect: \"Allow\",\n          Principal:  {\n            AWS:  {\n              \"Fn::Join\": [\n                \"\",\n                [\n                  \"arn:\",\n                  {\n                    Ref: \"AWS::Partition\",\n                  },\n                  \":iam::\",\n                  {\n                    Ref: \"AWS::AccountId\"\n                  },\n                  \":root\"\n                ],\n              ],\n            },\n          },\n          Resource:  {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsdeadLetterQueueF5B377E2\",\n              \"Arn\",\n            ],\n          },\n          Sid: \"QueueOwnerOnlyAccess\",\n        },\n        {\n          Action: \"SQS:*\",\n          Condition:  {\n            Bool:  {\n              \"aws:SecureTransport\": \"false\",\n            },\n          },\n          Effect: \"Deny\",\n          Principal: {\n            AWS: \"*\"\n          },\n          Resource:  {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsdeadLetterQueueF5B377E2\",\n              \"Arn\",\n            ],\n          },\n          Sid: \"HttpsOnly\",\n        },\n      ],\n      Version: \"2012-10-17\",\n    },\n    Queues: [\n      {\n        Ref: \"testeventbridgesqsdeadLetterQueueF5B377E2\",\n      },\n    ]\n  });\n});\n\ntest('check properties', () => {\n  const stack = new cdk.Stack();\n  const construct: EventbridgeToSqs = deployNewStack(stack);\n\n  expect(construct.eventsRule !== null);\n  expect(construct.sqsQueue !== null);\n  expect(construct.encryptionKey !== null);\n  expect(construct.deadLetterQueue !== null);\n});\n\ntest('check eventbus property, snapshot & eventbus exists', () => {\n  const stack = new cdk.Stack();\n  const construct: EventbridgeToSqs = deployStackWithNewEventBus(stack);\n\n  expect(construct.eventsRule !== null);\n  expect(construct.sqsQueue !== null);\n  expect(construct.encryptionKey !== null);\n  expect(construct.deadLetterQueue !== null);\n  expect(construct.eventBus !== null);\n\n  // Check whether eventbus exists\n  expect(stack).toHaveResource('AWS::Events::EventBus');\n});\n\ntest('check exception while passing existingEventBus & eventBusProps', () => {\n  const stack = new cdk.Stack();\n\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      eventPattern: {\n        source: ['solutionsconstructs']\n      }\n    },\n    eventBusProps: { eventBusName: 'test' },\n    existingEventBusInterface: new events.EventBus(stack, `test-existing-new-eventbus`, {  eventBusName: 'test'  })\n  };\n\n  const app = () => {\n    new EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);\n  };\n  expect(app).toThrowError();\n});\n\ntest('check custom event bus resource with props when deploy:true', () => {\n  const stack = new cdk.Stack();\n\n  const props: EventbridgeToSqsProps = {\n    eventBusProps: {\n      eventBusName: 'testcustomeventbus'\n    },\n    eventRuleProps: {\n      eventPattern: {\n        source: ['solutionsconstructs']\n      }\n    }\n  };\n  new EventbridgeToSqs(stack, 'test-new-eventbridge-sqs', props);\n\n  expect(stack).toHaveResource('AWS::Events::EventBus', {\n    Name: 'testcustomeventbus'\n  });\n});"]}
|
|
307
|
+
test('Queue is encrypted when key is provided on queueProps.encryptionMasterKey prop', () => {
|
|
308
|
+
const stack = new cdk.Stack();
|
|
309
|
+
const key = defaults.buildEncryptionKey(stack, {
|
|
310
|
+
description: 'my-key'
|
|
311
|
+
});
|
|
312
|
+
const props = {
|
|
313
|
+
eventRuleProps: {
|
|
314
|
+
schedule: events.Schedule.rate(cdk.Duration.minutes(5))
|
|
315
|
+
},
|
|
316
|
+
queueProps: {
|
|
317
|
+
encryptionMasterKey: key
|
|
318
|
+
}
|
|
319
|
+
};
|
|
320
|
+
new lib_1.EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);
|
|
321
|
+
expect(stack).toHaveResource('AWS::SQS::Queue', {
|
|
322
|
+
KmsMasterKeyId: {
|
|
323
|
+
"Fn::GetAtt": [
|
|
324
|
+
"EncryptionKey1B843E66",
|
|
325
|
+
"Arn"
|
|
326
|
+
]
|
|
327
|
+
}
|
|
328
|
+
});
|
|
329
|
+
expect(stack).toHaveResource('AWS::KMS::Key', {
|
|
330
|
+
Description: "my-key",
|
|
331
|
+
EnableKeyRotation: true
|
|
332
|
+
});
|
|
333
|
+
});
|
|
334
|
+
test('Queue is encrypted when key keyProps are provided', () => {
|
|
335
|
+
const stack = new cdk.Stack();
|
|
336
|
+
const props = {
|
|
337
|
+
eventRuleProps: {
|
|
338
|
+
schedule: events.Schedule.rate(cdk.Duration.minutes(5))
|
|
339
|
+
},
|
|
340
|
+
encryptionKeyProps: {
|
|
341
|
+
description: 'my-key'
|
|
342
|
+
}
|
|
343
|
+
};
|
|
344
|
+
new lib_1.EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);
|
|
345
|
+
expect(stack).toHaveResource('AWS::SQS::Queue', {
|
|
346
|
+
KmsMasterKeyId: {
|
|
347
|
+
"Fn::GetAtt": [
|
|
348
|
+
"testeventbridgesqsEncryptionKey811BDC23",
|
|
349
|
+
"Arn"
|
|
350
|
+
]
|
|
351
|
+
}
|
|
352
|
+
});
|
|
353
|
+
expect(stack).toHaveResource('AWS::KMS::Key', {
|
|
354
|
+
Description: "my-key",
|
|
355
|
+
EnableKeyRotation: true
|
|
356
|
+
});
|
|
357
|
+
});
|
|
358
|
+
test('Queue is encrypted with SQS-managed KMS key when enableEncryptionWithCustomerManagedKey property is false', () => {
|
|
359
|
+
const stack = new cdk.Stack();
|
|
360
|
+
const props = {
|
|
361
|
+
eventRuleProps: {
|
|
362
|
+
schedule: events.Schedule.rate(cdk.Duration.minutes(5))
|
|
363
|
+
},
|
|
364
|
+
enableEncryptionWithCustomerManagedKey: false
|
|
365
|
+
};
|
|
366
|
+
new lib_1.EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);
|
|
367
|
+
expect(stack).toHaveResource('AWS::SQS::Queue', {
|
|
368
|
+
KmsMasterKeyId: "alias/aws/sqs"
|
|
369
|
+
});
|
|
370
|
+
});
|
|
371
|
+
test('Queue purging flag grants correct permissions', () => {
|
|
372
|
+
const stack = new cdk.Stack();
|
|
373
|
+
const props = {
|
|
374
|
+
eventRuleProps: {
|
|
375
|
+
schedule: events.Schedule.rate(cdk.Duration.minutes(5))
|
|
376
|
+
},
|
|
377
|
+
enableQueuePurging: true,
|
|
378
|
+
deployDeadLetterQueue: false
|
|
379
|
+
};
|
|
380
|
+
new lib_1.EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);
|
|
381
|
+
expect(stack).toHaveResource('AWS::SQS::QueuePolicy', {
|
|
382
|
+
PolicyDocument: {
|
|
383
|
+
Statement: [
|
|
384
|
+
{
|
|
385
|
+
Action: [
|
|
386
|
+
"sqs:DeleteMessage",
|
|
387
|
+
"sqs:ReceiveMessage",
|
|
388
|
+
"sqs:SendMessage",
|
|
389
|
+
"sqs:GetQueueAttributes",
|
|
390
|
+
"sqs:RemovePermission",
|
|
391
|
+
"sqs:AddPermission",
|
|
392
|
+
"sqs:SetQueueAttributes",
|
|
393
|
+
],
|
|
394
|
+
Effect: "Allow",
|
|
395
|
+
Principal: {
|
|
396
|
+
AWS: {
|
|
397
|
+
"Fn::Join": [
|
|
398
|
+
"",
|
|
399
|
+
[
|
|
400
|
+
"arn:",
|
|
401
|
+
{
|
|
402
|
+
Ref: "AWS::Partition",
|
|
403
|
+
},
|
|
404
|
+
":iam::",
|
|
405
|
+
{
|
|
406
|
+
Ref: "AWS::AccountId",
|
|
407
|
+
},
|
|
408
|
+
":root"
|
|
409
|
+
],
|
|
410
|
+
],
|
|
411
|
+
},
|
|
412
|
+
},
|
|
413
|
+
Resource: {
|
|
414
|
+
"Fn::GetAtt": [
|
|
415
|
+
"testeventbridgesqsqueue21FF6EBA",
|
|
416
|
+
"Arn",
|
|
417
|
+
],
|
|
418
|
+
},
|
|
419
|
+
Sid: "QueueOwnerOnlyAccess",
|
|
420
|
+
},
|
|
421
|
+
{
|
|
422
|
+
Action: "SQS:*",
|
|
423
|
+
Condition: {
|
|
424
|
+
Bool: {
|
|
425
|
+
"aws:SecureTransport": "false",
|
|
426
|
+
},
|
|
427
|
+
},
|
|
428
|
+
Effect: "Deny",
|
|
429
|
+
Principal: {
|
|
430
|
+
AWS: "*"
|
|
431
|
+
},
|
|
432
|
+
Resource: {
|
|
433
|
+
"Fn::GetAtt": [
|
|
434
|
+
"testeventbridgesqsqueue21FF6EBA",
|
|
435
|
+
"Arn",
|
|
436
|
+
],
|
|
437
|
+
},
|
|
438
|
+
Sid: "HttpsOnly",
|
|
439
|
+
},
|
|
440
|
+
{
|
|
441
|
+
Action: [
|
|
442
|
+
"sqs:PurgeQueue",
|
|
443
|
+
"sqs:GetQueueAttributes",
|
|
444
|
+
"sqs:GetQueueUrl"
|
|
445
|
+
],
|
|
446
|
+
Effect: "Allow",
|
|
447
|
+
Principal: {
|
|
448
|
+
Service: "events.amazonaws.com"
|
|
449
|
+
},
|
|
450
|
+
Resource: {
|
|
451
|
+
"Fn::GetAtt": [
|
|
452
|
+
"testeventbridgesqsqueue21FF6EBA",
|
|
453
|
+
"Arn"
|
|
454
|
+
]
|
|
455
|
+
}
|
|
456
|
+
},
|
|
457
|
+
{
|
|
458
|
+
Action: [
|
|
459
|
+
"sqs:SendMessage",
|
|
460
|
+
"sqs:GetQueueAttributes",
|
|
461
|
+
"sqs:GetQueueUrl"
|
|
462
|
+
],
|
|
463
|
+
Effect: "Allow",
|
|
464
|
+
Principal: {
|
|
465
|
+
Service: "events.amazonaws.com"
|
|
466
|
+
},
|
|
467
|
+
Resource: {
|
|
468
|
+
"Fn::GetAtt": [
|
|
469
|
+
"testeventbridgesqsqueue21FF6EBA",
|
|
470
|
+
"Arn"
|
|
471
|
+
]
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
],
|
|
475
|
+
Version: "2012-10-17"
|
|
476
|
+
},
|
|
477
|
+
Queues: [
|
|
478
|
+
{
|
|
479
|
+
Ref: "testeventbridgesqsqueue21FF6EBA",
|
|
480
|
+
}
|
|
481
|
+
]
|
|
482
|
+
});
|
|
483
|
+
});
|
|
484
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eventbridge-sqs-queue.test.js","sourceRoot":"","sources":["eventbridge-sqs-queue.test.ts"],"names":[],"mappings":"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","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 cdk from 'aws-cdk-lib';\nimport { EventbridgeToSqs, EventbridgeToSqsProps } from '../lib';\nimport * as events from \"aws-cdk-lib/aws-events\";\nimport '@aws-cdk/assert/jest';\nimport * as defaults from '@aws-solutions-constructs/core';\n\nfunction deployNewStack(stack: cdk.Stack) {\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      schedule: events.Schedule.rate(cdk.Duration.minutes(5))\n    }\n  };\n  return new EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);\n}\n\nfunction deployStackWithNewEventBus(stack: cdk.Stack) {\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      eventPattern: {\n        source: ['solutionsconstructs']\n      }\n    },\n    eventBusProps: { eventBusName: 'test' }\n  };\n  return new EventbridgeToSqs(stack, 'test-eventbridge-sqs-new-bus', props);\n}\n\ntest('check the sqs queue properties', () => {\n  const stack = new cdk.Stack();\n  deployNewStack(stack);\n  expect(stack).toHaveResource('AWS::SQS::Queue', {\n    KmsMasterKeyId: {\n      \"Fn::GetAtt\": [\n        \"testeventbridgesqsEncryptionKey811BDC23\",\n        \"Arn\"\n      ]\n    },\n    RedrivePolicy: {\n      deadLetterTargetArn: {\n        \"Fn::GetAtt\": [\n          \"testeventbridgesqsdeadLetterQueueF5B377E2\",\n          \"Arn\"\n        ]\n      },\n      maxReceiveCount: 15\n    }\n  });\n});\n\ntest('check the sqs queue properties with existing KMS key', () => {\n  const stack = new cdk.Stack();\n  const key = defaults.buildEncryptionKey(stack, {\n    description: 'my-key'\n  });\n\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      schedule: events.Schedule.rate(cdk.Duration.minutes(5))\n    },\n    encryptionKey: key\n  };\n\n  new EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);\n\n  expect(stack).toHaveResource('AWS::SQS::Queue', {\n    KmsMasterKeyId: {\n      \"Fn::GetAtt\": [\n        \"EncryptionKey1B843E66\",\n        \"Arn\"\n      ]\n    },\n    RedrivePolicy: {\n      deadLetterTargetArn: {\n        \"Fn::GetAtt\": [\n          \"testeventbridgesqsdeadLetterQueueF5B377E2\",\n          \"Arn\"\n        ]\n      },\n      maxReceiveCount: 15\n    }\n  });\n\n  expect(stack).toHaveResource('AWS::KMS::Key', {\n    Description: \"my-key\",\n    EnableKeyRotation: true\n  });\n});\n\ntest('check if the event rule has permission/policy in place in sqs queue for it to be able to send messages to the queue.', () => {\n  const stack = new cdk.Stack();\n  deployNewStack(stack);\n  expect(stack).toHaveResource('AWS::SQS::QueuePolicy', {\n    PolicyDocument:  {\n      Statement: [\n        {\n          Action: [\n            \"sqs:DeleteMessage\",\n            \"sqs:ReceiveMessage\",\n            \"sqs:SendMessage\",\n            \"sqs:GetQueueAttributes\",\n            \"sqs:RemovePermission\",\n            \"sqs:AddPermission\",\n            \"sqs:SetQueueAttributes\",\n          ],\n          Effect: \"Allow\",\n          Principal:  {\n            AWS:  {\n              \"Fn::Join\": [\n                \"\",\n                [\n                  \"arn:\",\n                  {\n                    Ref: \"AWS::Partition\",\n                  },\n                  \":iam::\",\n                  {\n                    Ref: \"AWS::AccountId\",\n                  },\n                  \":root\"\n                ],\n              ],\n            },\n          },\n          Resource:  {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsqueue21FF6EBA\",\n              \"Arn\",\n            ],\n          },\n          Sid: \"QueueOwnerOnlyAccess\",\n        },\n        {\n          Action: \"SQS:*\",\n          Condition:  {\n            Bool:  {\n              \"aws:SecureTransport\": \"false\",\n            },\n          },\n          Effect: \"Deny\",\n          Principal: {\n            AWS: \"*\"\n          },\n          Resource:  {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsqueue21FF6EBA\",\n              \"Arn\",\n            ],\n          },\n          Sid: \"HttpsOnly\",\n        },\n        {\n          Action: [\n            \"sqs:SendMessage\",\n            \"sqs:GetQueueAttributes\",\n            \"sqs:GetQueueUrl\"\n          ],\n          Effect: \"Allow\",\n          Principal: {\n            Service: \"events.amazonaws.com\"\n          },\n          Resource: {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsqueue21FF6EBA\",\n              \"Arn\"\n            ]\n          }\n        }\n      ],\n      Version: \"2012-10-17\"\n    },\n    Queues: [\n      {\n        Ref: \"testeventbridgesqsqueue21FF6EBA\",\n      }\n    ]\n  });\n});\n\ntest('check if the dead letter queue policy is setup', () => {\n  const stack = new cdk.Stack();\n  deployNewStack(stack);\n  expect(stack).toHaveResource('AWS::SQS::QueuePolicy', {\n    PolicyDocument:  {\n      Statement: [\n        {\n          Action: [\n            \"sqs:DeleteMessage\",\n            \"sqs:ReceiveMessage\",\n            \"sqs:SendMessage\",\n            \"sqs:GetQueueAttributes\",\n            \"sqs:RemovePermission\",\n            \"sqs:AddPermission\",\n            \"sqs:SetQueueAttributes\",\n          ],\n          Effect: \"Allow\",\n          Principal:  {\n            AWS:  {\n              \"Fn::Join\": [\n                \"\",\n                [\n                  \"arn:\",\n                  {\n                    Ref: \"AWS::Partition\",\n                  },\n                  \":iam::\",\n                  {\n                    Ref: \"AWS::AccountId\"\n                  },\n                  \":root\"\n                ],\n              ],\n            },\n          },\n          Resource:  {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsdeadLetterQueueF5B377E2\",\n              \"Arn\",\n            ],\n          },\n          Sid: \"QueueOwnerOnlyAccess\",\n        },\n        {\n          Action: \"SQS:*\",\n          Condition:  {\n            Bool:  {\n              \"aws:SecureTransport\": \"false\",\n            },\n          },\n          Effect: \"Deny\",\n          Principal: {\n            AWS: \"*\"\n          },\n          Resource:  {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsdeadLetterQueueF5B377E2\",\n              \"Arn\",\n            ],\n          },\n          Sid: \"HttpsOnly\",\n        },\n      ],\n      Version: \"2012-10-17\",\n    },\n    Queues: [\n      {\n        Ref: \"testeventbridgesqsdeadLetterQueueF5B377E2\",\n      },\n    ]\n  });\n});\n\ntest('check properties', () => {\n  const stack = new cdk.Stack();\n  const construct: EventbridgeToSqs = deployNewStack(stack);\n\n  expect(construct.eventsRule !== null);\n  expect(construct.sqsQueue !== null);\n  expect(construct.encryptionKey !== null);\n  expect(construct.deadLetterQueue !== null);\n});\n\ntest('check eventbus property, snapshot & eventbus exists', () => {\n  const stack = new cdk.Stack();\n  const construct: EventbridgeToSqs = deployStackWithNewEventBus(stack);\n\n  expect(construct.eventsRule !== null);\n  expect(construct.sqsQueue !== null);\n  expect(construct.encryptionKey !== null);\n  expect(construct.deadLetterQueue !== null);\n  expect(construct.eventBus !== null);\n\n  // Check whether eventbus exists\n  expect(stack).toHaveResource('AWS::Events::EventBus');\n});\n\ntest('check exception while passing existingEventBus & eventBusProps', () => {\n  const stack = new cdk.Stack();\n\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      eventPattern: {\n        source: ['solutionsconstructs']\n      }\n    },\n    eventBusProps: { eventBusName: 'test' },\n    existingEventBusInterface: new events.EventBus(stack, `test-existing-new-eventbus`, {  eventBusName: 'test'  })\n  };\n\n  const app = () => {\n    new EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);\n  };\n  expect(app).toThrowError();\n});\n\ntest('check custom event bus resource with props when deploy:true', () => {\n  const stack = new cdk.Stack();\n\n  const props: EventbridgeToSqsProps = {\n    eventBusProps: {\n      eventBusName: 'testcustomeventbus'\n    },\n    eventRuleProps: {\n      eventPattern: {\n        source: ['solutionsconstructs']\n      }\n    }\n  };\n  new EventbridgeToSqs(stack, 'test-new-eventbridge-sqs', props);\n\n  expect(stack).toHaveResource('AWS::Events::EventBus', {\n    Name: 'testcustomeventbus'\n  });\n});\n\ntest('Queue is encrypted when key is provided on queueProps.encryptionMasterKey prop', () => {\n  const stack = new cdk.Stack();\n  const key = defaults.buildEncryptionKey(stack, {\n    description: 'my-key'\n  });\n\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      schedule: events.Schedule.rate(cdk.Duration.minutes(5))\n    },\n    queueProps: {\n      encryptionMasterKey: key\n    }\n  };\n\n  new EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);\n\n  expect(stack).toHaveResource('AWS::SQS::Queue', {\n    KmsMasterKeyId: {\n      \"Fn::GetAtt\": [\n        \"EncryptionKey1B843E66\",\n        \"Arn\"\n      ]\n    }\n  });\n\n  expect(stack).toHaveResource('AWS::KMS::Key', {\n    Description: \"my-key\",\n    EnableKeyRotation: true\n  });\n});\n\ntest('Queue is encrypted when key keyProps are provided', () => {\n  const stack = new cdk.Stack();\n\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      schedule: events.Schedule.rate(cdk.Duration.minutes(5))\n    },\n    encryptionKeyProps: {\n      description: 'my-key'\n    }\n  };\n\n  new EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);\n\n  expect(stack).toHaveResource('AWS::SQS::Queue', {\n    KmsMasterKeyId: {\n      \"Fn::GetAtt\": [\n        \"testeventbridgesqsEncryptionKey811BDC23\",\n        \"Arn\"\n      ]\n    }\n  });\n\n  expect(stack).toHaveResource('AWS::KMS::Key', {\n    Description: \"my-key\",\n    EnableKeyRotation: true\n  });\n});\n\ntest('Queue is encrypted with SQS-managed KMS key when enableEncryptionWithCustomerManagedKey property is false', () => {\n  const stack = new cdk.Stack();\n\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      schedule: events.Schedule.rate(cdk.Duration.minutes(5))\n    },\n    enableEncryptionWithCustomerManagedKey: false\n  };\n\n  new EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);\n\n  expect(stack).toHaveResource('AWS::SQS::Queue', {\n    KmsMasterKeyId: \"alias/aws/sqs\"\n  });\n});\n\ntest('Queue purging flag grants correct permissions', () => {\n  const stack = new cdk.Stack();\n\n  const props: EventbridgeToSqsProps = {\n    eventRuleProps: {\n      schedule: events.Schedule.rate(cdk.Duration.minutes(5))\n    },\n    enableQueuePurging: true,\n    deployDeadLetterQueue: false\n  };\n\n  new EventbridgeToSqs(stack, 'test-eventbridge-sqs', props);\n\n  expect(stack).toHaveResource('AWS::SQS::QueuePolicy', {\n    PolicyDocument:  {\n      Statement: [\n        {\n          Action: [\n            \"sqs:DeleteMessage\",\n            \"sqs:ReceiveMessage\",\n            \"sqs:SendMessage\",\n            \"sqs:GetQueueAttributes\",\n            \"sqs:RemovePermission\",\n            \"sqs:AddPermission\",\n            \"sqs:SetQueueAttributes\",\n          ],\n          Effect: \"Allow\",\n          Principal:  {\n            AWS:  {\n              \"Fn::Join\": [\n                \"\",\n                [\n                  \"arn:\",\n                  {\n                    Ref: \"AWS::Partition\",\n                  },\n                  \":iam::\",\n                  {\n                    Ref: \"AWS::AccountId\",\n                  },\n                  \":root\"\n                ],\n              ],\n            },\n          },\n          Resource:  {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsqueue21FF6EBA\",\n              \"Arn\",\n            ],\n          },\n          Sid: \"QueueOwnerOnlyAccess\",\n        },\n        {\n          Action: \"SQS:*\",\n          Condition:  {\n            Bool:  {\n              \"aws:SecureTransport\": \"false\",\n            },\n          },\n          Effect: \"Deny\",\n          Principal: {\n            AWS: \"*\"\n          },\n          Resource:  {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsqueue21FF6EBA\",\n              \"Arn\",\n            ],\n          },\n          Sid: \"HttpsOnly\",\n        },\n        {\n          Action: [\n            \"sqs:PurgeQueue\",\n            \"sqs:GetQueueAttributes\",\n            \"sqs:GetQueueUrl\"\n          ],\n          Effect: \"Allow\",\n          Principal: {\n            Service: \"events.amazonaws.com\"\n          },\n          Resource: {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsqueue21FF6EBA\",\n              \"Arn\"\n            ]\n          }\n        },\n        {\n          Action: [\n            \"sqs:SendMessage\",\n            \"sqs:GetQueueAttributes\",\n            \"sqs:GetQueueUrl\"\n          ],\n          Effect: \"Allow\",\n          Principal: {\n            Service: \"events.amazonaws.com\"\n          },\n          Resource: {\n            \"Fn::GetAtt\": [\n              \"testeventbridgesqsqueue21FF6EBA\",\n              \"Arn\"\n            ]\n          }\n        }\n      ],\n      Version: \"2012-10-17\"\n    },\n    Queues: [\n      {\n        Ref: \"testeventbridgesqsqueue21FF6EBA\",\n      }\n    ]\n  });\n});"]}
|