Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

@osoverflow/serverless-plugin-lambda-dead-letter

medisoft19MIT1.0.1

serverless plugin that can configure a lambda with a dead letter queue or topic. From the repo Kayyow/serverless-plugin-lambda-dead-letter and https://github.com/digitalmaas/serverless-plugin-lambda-dead-letter#readme

serverless, serverless framework, serverless plugin, serverless plugins, lambda, aws, aws lambda, amazon, amazon web services, dead letter, dead letter config, DeadLetterConfig, sqs queue, queue, DLQ, sns topic, topic

readme

Serverless Lambda Dead Letter Queue Plugin

serverless NPM version digitalmaas NPM downloads standardjs

A Serverless plugin that can assign a dead letter SQS queue to a Lambda function. Works with serverless v1.4+, v2 and v3.

What is it?

Assigns a DeadLetterConfig to a Lambda function and optionally create a new SQS queue or SNS Topic with a simple syntax.

Failed asynchronous messages for Amazon Lambda can be be sent to an SQS queue or an SNS topic by setting the DeadLetterConfig. Lambda Dead Letter Queues are documented here.

At the time this plugin was developed AWS Cloudformation (and serverless) did not support the DeadLetterConfig property of the Lambda so we have introduced a plugin that calls UpdateFunctionConfiguration on the lambda after serverless deploys the CloudFormation stack.

Installation

From your target serverless project, run:

npm install @digitalmaas/serverless-plugin-lambda-dead-letter --save-dev

Basic Setup

Add the plugin to your serverless.yml:

plugins:
  - '@digitalmaas/serverless-plugin-lambda-dead-letter'

How do I use it?

Dead letter settings are assigned via a new deadLetter property nested under a function in a serverless.yml file.

There are several methods to configure the Lambda deadLetterConfig.

Method-1

DeadLetter Queue

Use the deadLetter.sqs to create a new dead letter queue for the function.

The resulting cloudformation stack will contain an SQS Queue and it's respective QueuePolicy.

Create new dead-letter queue by name

# 'functions' in serverless.yml

functions:
  createUser: # Function name
    handler: handler.createUser # Reference to function 'createUser' in code
    deadLetter:
      sqs:  createUser-dl-queue  # New Queue with this name

Create new dead-letter queue with properties

# 'functions' in serverless.yml

functions:
  createUser: # Function name
    handler: handler.createUser # Reference to function 'createUser' in code
    deadLetter:
      sqs:      # New Queue with these properties
        queueName: createUser-dl-queue
        delaySeconds: 60
        maximumMessageSize: 2048
        messageRetentionPeriod: 200000
        receiveMessageWaitTimeSeconds: 15
        visibilityTimeout: 300

DeadLetter Topic

Use the deadLetter.sns to create a new dead letter topic for the function.

The resulting cloudformation stack will contain an SQS Topic resource.

# 'functions' in serverless.yml

functions:
  createUser: # Function name
    handler: handler.createUser # Reference to function 'createUser' in code

    deadLetter:
      sns:  createUser-dl-topic

Method-2

Use the targetArn property to specify the exact SQS queue or SNS topic to use for Lambda dead letter messages. In this case the queue\topic must already exist as must the queue\topic policy.

Reference the ARN of an existing queue createUser-dl-queue

# 'functions' in serverless.yml

functions:
  createUser: # Function name
    handler: handler.createUser # Reference to function 'createUser' in code

    deadLetter:
      targetArn: arn:aws:sqs:us-west-2:123456789012:createUser-dl-queue

Method-3

If you created a queue\topic in the resource section you can reference it using the GetResourceArn pseudo method.

This will use the arn of the resource referenced by {logicalId}

    deadLetter:
      targetArn:
        GetResourceArn: {logicalId}

Note:

  • At present this only works for SQS queues or SNS Topics.
  • If a queue\topic is created in the resources section you will still need to add a resource for the respective queue\topic policy so that that lambda has permissions to write to the dead letter queue\topic.

In this example the createUser lambda function is using the new CreateUserDeadLetterQueue SQS queue defined in the resources section.

# 'functions' in serverless.yml

functions:
  createUser: # Function name

    handler: handler.createUser # Reference to function 'createUser' in code

    # ...

    deadLetter:
      targetArn:
        GetResourceArn: CreateUserDeadLetterQueue

resources:
    Resources:
      CreateUserDeadLetterQueue:
        Type: AWS::SQS::Queue
        Properties:
          QueueName: create-user-lambda-dl-queue

      CreateUserDeadLetterQueuePolicy:
        Type: AWS::SQS::QueuePolicy
        Properties:
          Queues:
            - Ref: CreateUserDeadLetterQueue

            # Policy properties abbreviated but you need more here ...

Remove DeadLetter Resource

If you previously had a DeadLetter target and want to remove it such that there is no dead letter queue or topic you can supply the deadLetter object with an empty targetArn. Upon deploy the plugin will run the Lambda UpdateFunctionConfiguration and set an empty TargetArn.

# 'functions' in serverless.yml

functions:
  createUser: # Function name

    handler: handler.createUser # Reference to function 'createUser' in code

    # ...

    # Set an empty targetArn to erase previous DLQ settings.
    deadLetter:
      targetArn:

License

MIT License.

This project has been forked from the original serverless-plugin-lambda-dead-letter and published under a different name, as the original has been abandoned.

For the complete information, please refer to the license file.

changelog

1.0.0 (2023-02-24)

Bug Fixes

  • Add configuration schema to plugin (d51ac0c)
  • updated lifecycle hook for v3 required changes (59618f5)

1.2.1 (2017-01-31)

Bug Fixes

  • Removed the plugin command setLambdaDeadLetterConfig because it didn't work in all scenarios.

Meta

1.2.0 (2017-01-30)

Features

  • Dead Letter Queue properties #12

Meta

1.1.0 (2017-01-29)

Features

  • Simplified syntax to create new SQS queue and use it in the function's DeadLetterConfig.TargetArn #10
  • Simplified syntax to create a new SNS topic and use it in the function's DeadLetterConfig.TargetArn #11
  • Validate function deadLetter object before deploy #26

    Bug Fixes

    • Do not call UpdateFunctionConfiguration when --noDeploy option is specified #19

    Meta

1.0.0 (2017-01-15)

Features

  • Basic support to assign the Lambda DeadLetterConfig using after serverless Cloudformation stack is deployed. Amazon Docs
    • Plugin makes a call to the Lambda Api UpdateFunctionConfiguration
  • Using a pre-existing SQS Queue or SNS Topic as a dead letter target.
  • Using an SNS Queue or SNS Topic created in the resources section.
  • Remove a previously existing dead letter targetArn by specifying a blank targetArn