@optimuspay/express-idempotency
v1.1.1
Published
Express middleware to make requests idempotent
Downloads
26
Readme
Express Idempotency
Express Middleware to allow requests to be made idempotent if client passes an idempotency key header.
Code Example
const idempotency = require("@optimuspay/express-idempotency");
app.use(idempotency());
// if requests have the header "Idempotency-Key" header set, the middleware will check to see whether a cached response to this request has been stored
// if so, the cached response will be returned, setting the header "X-Cache": "HIT"
// if not, the request will pass to the next middleware, and the response will be stored in the cache, in order that subsequent responses with the same idempotency key can be returned from the cache.
Example using options:
app.use(
idempotency({
requestHeaderName: "My-Idempotency-Key",
generateCacheKey: (req, idempotencyKey) => {
return `${req.user.id}_${idempotencyKey}`;
},
lruCacheOptions: {
max: 9999,
},
})
);
Middleware options
requestHeaderName
(string) - default: "Idempotency-Key"responseHeaderName
(string) - default: "X-Cache"generateCacheKey
(function) - takes 2 arguments: req (Express request object), idempotencyKey (string)lruCacheOptions
(object) see lru-cache docs - default:max
(integer) - default: 500ttl
(ingeger) - default: 172800000 (48 hours in milliseconds)
Motivation
Sometimes, it's important to ensure an HTTP request is idempotent, even if you're not using a naturally idempotent HTTP verb (like PUT
or DELETE
). For example, if your API charges somebody's credit card when a POST /orders
request is made, it's important to ensure that the request is only processed once. However, gremlins like network faults etc. may cause the client to fail to receive a response. Using an Idempotency Key is one solution to this problem. Stripe describe their solution in a blog post which provided the inspiration for this package.
Installation
npm install --save @optimuspay/express-idempotency
Debugging
Package uses the node debug module. Set DEBUG=express-idempotency:*
when running your code.
Tests
npm test
Contributors
Package developed by Optimus Pay, principally by Chris Jamieson
License
MIT License
Roadmap
~~- Allow different headers to be checked for Idempotency Key~~ ~~- Allow cache options to be passed to LRU cache module~~