Skip to main content

CDK Constructs for AWS IoT to AWS SQS integration

Project description

aws-iot-sqs module

---

Stability: Experimental

All classes are under active development and subject to non-backward compatible changes or removal in any future version. These are not subject to the Semantic Versioning model. This means that while you may use them, you may need to update your source code when upgrading to a newer version of this package.


Reference Documentation: https://docs.aws.amazon.com/solutions/latest/constructs/
Language Package
Python Logo Python aws_solutions_constructs.aws_iot_sqs
Typescript Logo Typescript @aws-solutions-constructs/aws-iot-sqs
Java Logo Java software.amazon.awsconstructs.services.iotsqs

Overview

This AWS Solutions Construct implements an AWS IoT MQTT topic rule and an AWS SQS Queue pattern.

Here is a minimal deployable pattern definition:

Typescript

import { Construct } from 'constructs';
import { Stack, StackProps } from 'aws-cdk-lib';
import { IotToSqsProps, IotToSqs } from '@aws-solutions-constructs/aws-iot-sqs';

const constructProps: IotToSqsProps = {
  iotTopicRuleProps: {
    topicRulePayload: {
      ruleDisabled: false,
      description: "Testing the IotToSqs Pattern",
      sql: "SELECT * FROM 'iot/sqs/#'",
      actions: []
    }
  }
};

new IotToSqs(this, 'test-iot-sqs-integration', constructProps);

Python

from aws_solutions_constructs.aws_iot_sqs import IotToSqs
from aws_cdk import (
    aws_iot as iot,
    Stack
)
from constructs import Construct

IotToSqs(self, 'test_iot_sqs',
    iot_topic_rule_props=iot.CfnTopicRuleProps(
        topic_rule_payload=iot.CfnTopicRule.TopicRulePayloadProperty(
            rule_disabled=False,
            description="Testing the IotToSqs Pattern",
            sql="SELECT * FROM 'iot/sqs/#'",
            actions=[]
        )
    ))

Java

import software.constructs.Construct;
import java.util.List;

import software.amazon.awscdk.Stack;
import software.amazon.awscdk.StackProps;
import software.amazon.awscdk.services.iot.*;
import software.amazon.awscdk.services.iot.CfnTopicRule.TopicRulePayloadProperty;
import software.amazon.awsconstructs.services.iotsqs.*;

new IotToSqs(this, "test_iot_sqs", new IotToSqsProps.Builder()
        .iotTopicRuleProps(new CfnTopicRuleProps.Builder()
                .topicRulePayload(new TopicRulePayloadProperty.Builder()
                        .ruleDisabled(false)
                        .description("Testing the IotToSqs Pattern")
                        .sql("SELECT * FROM 'iot/sqs/#'")
                        .actions(List.of())
                        .build())
                .build())
        .build());

Pattern Construct Props

Name Type Description
iotTopicRuleProps iot.CfnTopicRuleProps User provided CfnTopicRuleProps to override the defaults
existingQueueObj? sqs.Queue Existing instance of SQS queue object, providing both this and queueProps will cause an error.
queueProps? sqs.QueueProps User provided props to override the default props for the SQS queue.
deadLetterQueueProps? sqs.QueueProps Optional user provided properties for the dead letter queue.
deployDeadLetterQueue? boolean Whether to deploy a secondary queue to be used as a dead letter queue. Default true.
maxReceiveCount? number The number of times a message can be unsuccessfully dequeued before being moved to the dead-letter queue. Required field if deployDeadLetterQueue=true.
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.
encryptionKey? kms.Key An optional, imported encryption key to encrypt the SQS Queue with.
encryptionKeyProps? kms.KeyProps Optional user provided properties to override the default properties for the KMS encryption key used to encrypt the SQS queue with.

Pattern Properties

Name Type Description
encryptionKey? kms.Key Returns an instance of kms.Key used for the SQS queue.
iotActionsRole iam.Role Returns an instance of iam.Role created by the construct, which allows IoT to publish messages to the SQS Queue
sqsQueue sqs.Queue Returns an instance of sqs.Queue created by the construct
deadLetterQueue? sqs.Queue Returns an instance of the dead-letter SQS queue created by the pattern.
iotTopicRule iot.CfnTopicRule Returns an instance of iot.CfnTopicRule created by the construct

Default settings

Out of the box implementation of the Construct without any override will set the following defaults:

Amazon IoT Rule

  • Configure an IoT Rule to send messages to the SQS Queue

Amazon IAM Role

  • Configure least privilege access IAM role for Amazon IoT to be able to publish messages to the SQS Queue

Amazon SQS Queue

  • Deploy a dead-letter queue for the source queue.
  • Enable server-side encryption for the source queue using a customer-managed AWS KMS key.
  • Enforce encryption of data in transit.

Architecture

Architecture Diagram


© Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Built Distribution

File details

Details for the file aws_solutions_constructs_aws_iot_sqs-2.72.0.tar.gz.

File metadata

File hashes

Hashes for aws_solutions_constructs_aws_iot_sqs-2.72.0.tar.gz
Algorithm Hash digest
SHA256 f39d9390b35f7e74c66ab727747f91cdde5da32c291b70884fe3905993db742b
MD5 a4fd3f154b8afcb9b45e268d4b66c38b
BLAKE2b-256 1e4f09c0f7cd0eaff17f682a46276069c23b2a8c0b769f1541fba63c8536ab99

See more details on using hashes here.

File details

Details for the file aws_solutions_constructs.aws_iot_sqs-2.72.0-py3-none-any.whl.

File metadata

File hashes

Hashes for aws_solutions_constructs.aws_iot_sqs-2.72.0-py3-none-any.whl
Algorithm Hash digest
SHA256 dc38c5e265b1cc854d9a19da6961e88842ee0cf3b0aee8893cde68b8118ef0f4
MD5 326bf6275bbe643607237eb377b6a395
BLAKE2b-256 35c3ef4c21f2f7e5062d2f189cc7b972b2324dd035f5fa37794de780084e82d1

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page