CDK Constructs for AWS SNS to AWS Lambda integration
Project description
aws-sns-lambda module
---Reference Documentation: | https://docs.aws.amazon.com/solutions/latest/constructs/ |
---|
Language | Package |
---|---|
aws_solutions_constructs.aws_sns_lambda |
|
@aws-solutions-constructs/aws-sns-lambda |
|
software.amazon.awsconstructs.services.snslambda |
This AWS Solutions Construct implements an Amazon SNS connected to an AWS Lambda function.
Here is a minimal deployable pattern definition in Typescript:
# Example automatically generated from non-compiling source. May contain errors.
import { SnsToLambda, SnsToLambdaProps } from "@aws-solutions-constructs/aws-sns-lambda";
new SnsToLambda(this, 'test-sns-lambda', {
lambdaFunctionProps: {
runtime: lambda.Runtime.NODEJS_12_X,
handler: 'index.handler',
code: lambda.Code.fromAsset(`${__dirname}/lambda`)
}
});
Initializer
new SnsToLambda(scope: Construct, id: string, props: SnsToLambdaProps);
Parameters
- scope
Construct
- id
string
- props
SnsToLambdaProps
Pattern Construct Props
Name | Type | Description |
---|---|---|
existingLambdaObj? | lambda.Function |
Existing instance of Lambda Function object, providing both this and lambdaFunctionProps will cause an error. |
lambdaFunctionProps? | lambda.FunctionProps |
User provided props to override the default props for the Lambda function. |
existingTopicObj? | sns.Topic |
Existing instance of SNS Topic object, providing both this and topicProps will cause an error. |
topicProps? | sns.TopicProps |
Optional user provided properties to override the default properties for the SNS topic. |
Pattern Properties
Name | Type | Description |
---|---|---|
lambdaFunction | lambda.Function |
Returns an instance of the Lambda function created by the pattern. |
snsTopic | sns.Topic |
Returns an instance of the SNS topic created by the pattern. |
Default settings
Out of the box implementation of the Construct without any override will set the following defaults:
Amazon SNS Topic
- Configure least privilege access permissions for SNS Topic
- Enable server-side encryption for SNS Topic using AWS managed KMS Key
- Enforce encryption of data in transit
AWS Lambda Function
-
Configure limited privilege access IAM role for Lambda function
-
Enable reusing connections with Keep-Alive for NodeJs Lambda function
-
Enable X-Ray Tracing
-
Set Environment Variables
- AWS_NODEJS_CONNECTION_REUSE_ENABLED (for Node 10.x and higher functions)
Architecture
© Copyright 2021 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
Close
Hashes for aws-solutions-constructs.aws-sns-lambda-1.133.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1e8fe06b3ee6d9e57b2d6871314e0f3e25aebaf62fcec25a148fcee7f08e5763 |
|
MD5 | 77808306b411aa2224b8200fda9db57e |
|
BLAKE2b-256 | c4ba1df2cfbb68bc85bfb0df93b82fa7690e49d88952718278347af406a3e583 |
Close
Hashes for aws_solutions_constructs.aws_sns_lambda-1.133.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 994363ab7f98790897b54782cec01e9e183d3e7ae0eec16f100fd39a3ee25673 |
|
MD5 | f70a2457255c20a9a9176e02c55ffe52 |
|
BLAKE2b-256 | d1fe475b64e77099418a7a014c201afb573943807a8c9f4320335aad0e84bb1d |