@middy/do-not-wait-for-empty-event-loop

Middleware for the middy framework that allows to easily disable the wait for empty event loop in a Lambda function

Stats

StarsIssuesVersionUpdatedCreatedSize
@middy/do-not-wait-for-empty-event-loop
2,383192.5.1a month ago3 years agoMinified + gzip package size for @middy/do-not-wait-for-empty-event-loop in KB

Readme

Middy do-not-wait-for-empty-event-loop middleware

Middy logo

"Do not wait for empty event loop" middleware for the middy framework, the stylish Node.js middleware engine for AWS Lambda

This middleware sets context.callbackWaitsForEmptyEventLoop property to false. This will prevent Lambda from timing out because of open database connections, etc.

Install

To install this middleware you can use NPM:

npm install --save @middy/do-not-wait-for-empty-event-loop

Options

By default the middleware sets the callbackWaitsForEmptyEventLoop property to false only in the before phase, meaning you can override it in handler to true if needed. You can set it in all steps with the options:

  • runOnBefore (defaults to true) - sets property before running your handler
  • runOnAfter (defaults to false)
  • runOnError (defaults to false)

Sample usage

import middy from '@middy/core'
import doNotWaitForEmptyEventLoop from '@middy/do-not-wait-for-empty-event-loop'

const handler = middy((event, context) => {
  return {}
})

handler.use(doNotWaitForEmptyEventLoop({runOnError: true}))

// When Lambda runs the handler it gets context with callbackWaitsForEmptyEventLoop property set to false

handler(event, context, (_, response) => {
  t.is(context.callbackWaitsForEmptyEventLoop,false)
})

Middy documentation and examples

For more documentation and examples, refers to the main Middy monorepo on GitHub or Middy official website.

Contributing

Everyone is very welcome to contribute to this repository. Feel free to raise issues or to submit Pull Requests.

License

Licensed under MIT License. Copyright (c) 2017-2021 Luciano Mammino, will Farrell, and the Middy team.

FOSSA Status

If you find any bugs or have a feature request, please open an issue on github!

The npm package download data comes from npm's download counts api and package details come from npms.io.