Code Monkey home page Code Monkey logo

koa-redis-ratelimit's Introduction

koa-redis-ratelimit

Slack Status NPM version Build Status Code Coverage Standard JS Style MIT License

Rate limiting middleware backed by Redis for Koa v2+, built for CrocodileJS.


NOTE: Currently this package does not work due to an issue with ratelimiter, please use https://github.com/scttcper/koa-simple-ratelimit instead


Install

npm install --save koa-redis-ratelimit

Usage

import RateLimit from 'koa-redis-ratelimit';
import redis from 'redis';
import Koa from 'koa';

const app = new Koa();

// apply rate limit
app.use(new Ratelimit({
  db: redis.createClient(),
  duration: 60000,
  max: 100,
  id: (ctx) => ctx.ip,
  blacklist: [],
  whitelist: []
}).middleware);

// response middleware
app.use(ctx => {
  ctx.body = 'Stuff!';
});

app.listen(3000);
console.log('listening on port 3000');

Options

  • db - redis connection instance
  • max - max requests within duration (default is 2500)
  • duration - of limit in milliseconds (default is 3600000)
  • id - id to compare requests [ip]
  • whitelist - array of ids to whitelist
  • blacklist - array of ids to blacklist

Responses

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 seconds

License

MIT

koa-redis-ratelimit's People

Contributors

niftylettuce avatar

Stargazers

 avatar  avatar  avatar

Watchers

 avatar

Forkers

dvorovenko

koa-redis-ratelimit's Issues

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.