Rate limiter middleware for koa.
npm install koa-ratelimitconst Koa = require('koa');
const ratelimit = require('koa-ratelimit');
const Redis = require('ioredis');
const app = new Koa();
// apply rate limit
app.use(ratelimit({
  driver: 'redis',
  db: new Redis(),
  duration: 60000,
  errorMessage: 'Sometimes You Just Have to Slow Down.',
  id: (ctx) => ctx.ip,
  headers: {
    remaining: 'Rate-Limit-Remaining',
    reset: 'Rate-Limit-Reset',
    total: 'Rate-Limit-Total'
  },
  max: 100,
  disableHeader: false,
  whitelist: (ctx) => {
    // some logic that returns a boolean
  },
  blacklist: (ctx) => {
    // some logic that returns a boolean
  },
  onLimited: (ctx) => {
    // optional function to run when a user is rate limited
  }
}));
// response middleware
app.use(async (ctx) => {
  ctx.body = 'Stuff!';
});
// run server
app.listen(
  3000,
  () => console.log('listening on port 3000')
);const Koa = require('koa');
const ratelimit = require('koa-ratelimit');
const app = new Koa();
// apply rate limit
const db = new Map();
app.use(ratelimit({
  driver: 'memory',
  db: db,
  duration: 60000,
  errorMessage: 'Sometimes You Just Have to Slow Down.',
  id: (ctx) => ctx.ip,
  headers: {
    remaining: 'Rate-Limit-Remaining',
    reset: 'Rate-Limit-Reset',
    total: 'Rate-Limit-Total'
  },
  max: 100,
  disableHeader: false,
  whitelist: (ctx) => {
    // some logic that returns a boolean
  },
  blacklist: (ctx) => {
    // some logic that returns a boolean
  }
}));
// response middleware
app.use(async (ctx) => {
  ctx.body = 'Stuff!';
});
// run server
app.listen(
  3000,
  () => console.log('listening on port 3000')
);drivermemory or redis [redis]dbredis connection instance or Map instance (memory)durationof limit in milliseconds [3600000]errorMessagecustom error messageidid to compare requests [ip]namespaceprefix for storage driver key name [limit]headerscustom header namesmaxmax requests withinduration[2500]disableHeaderset whether send theremaining, reset, totalheaders [false]remainingremaining number of requests ['X-RateLimit-Remaining']resetreset timestamp ['X-RateLimit-Reset']totaltotal number of requests ['X-RateLimit-Limit']whitelistif function returns true, middleware exits before limitingblacklistif function returns true,403error is thrownthrowcall ctx.throw if true
Example 200 with header fields:
HTTP/1.1 200 OK
X-Powered-By: koa
X-RateLimit-Limit: 100
X-RateLimit-Remaining: 99
X-RateLimit-Reset: 1384377793
Content-Type: text/plain; charset=utf-8
Content-Length: 6
Date: Wed, 13 Nov 2013 21:22:13 GMT
Connection: keep-alive
Stuff!Example 429 response:
HTTP/1.1 429 Too Many Requests
X-Powered-By: koa
X-RateLimit-Limit: 100
X-RateLimit-Remaining: 0
X-RateLimit-Reset: 1384377716
Content-Type: text/plain; charset=utf-8
Content-Length: 39
Retry-After: 7
Date: Wed, 13 Nov 2013 21:21:48 GMT
Connection: keep-alive
Rate limit exceeded, retry in 8 secondsMIT © Koa.js contributors