@node-idempotency/express
v1.0.7
Published
Express middleware to provide Race-Condition free idempotency for HTTP requests, preventing unintended duplicate operations.
Downloads
340
Maintainers
Keywords
Readme
@node-idempotency/express
An Express middleware that makes requests idempotent
Implements @node-idempotency/core as express middleware.
Why?
Network requests are unpredictable; clients/proxies may send duplicate or concurrent requests due to retries or network issues. To ensure smooth operation, servers must process each request only once. This package detects and handles duplicates, preventing issues like double charging the customer. It's:
- Race Condition free: Ensures consistent behavior even during concurrent requests.
- Modular: Easily integrates with your storage or existing implementation.(as simple as registering a middleware)
- Customizable: options to tweak the library as per your need.
- RFC compliant: Adheres to standards for compatibility with other systems/clients.
How?
instal
npm i @node-idempotency/expressusage
import * as express from "express";
//server.ts
export default async (): Promise<express.Application> => {
const app = express();
const middleware = await idempotencyAsMiddleware({
storage:{
adapter: StorageAdapterEnum.memory
options: ...adapterOptions
},
...idempotencyOptions
});
app.use(middleware);
//register routes here
app.use(errorHandler); //your custom error handler
return app;
};storage.adaptercan either bememory,redisor an instance ofStorageinterface.storage.optionsare options to the storage client, required forredis, is client options of redis client.idempotencyOptionsare theIdempotencyOptionspassed to@node-idempotency/core/Idempotency

