soney / rate-limit-redis

A rate limiting store for express-rate-limit with Redis

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Rate Limit Redis

Build Status NPM version Dependency Status Development Dependency Status

Redis client for the express-rate-limit middleware.

Install

$ npm install --save rate-limit-redis

Usage

const RateLimit = require('express-rate-limit');
const RedisStore = require('rate-limit-redis');

const limiter = new RateLimit({
  store: new RedisStore({
    // see Configuration
  }),
  max: 100, // limit each IP to 100 requests per windowMs
  delayMs: 0 // disable delaying - full speed until the max limit is reached
});

//  apply to all requests
app.use(limiter);

Connect to UDP Socket

const RateLimit = require('express-rate-limit');
const RedisStore = require('rate-limit-redis');
const Redis = require('ioredis');
const client = new Redis('/tmp/redis.sock');

const limiter = new RateLimit({
  store: new RedisStore({
    client: client
  }),
  max: 100, // limit each IP to 100 requests per windowMs
  delayMs: 0 // disable delaying - full speed until the max limit is reached
});

Configuration

  • expiry: seconds - how long each rate limiting window exists for. Defaults to 60.
  • resetExpiryOnChange: boolean - if the expiry time should be reset every time a key is incremented/decremented. This means that when the limit is reached and the user is given a 429 response, the rate limit window is extended. Defaults to false.
  • prefix: string - prefix to add to entries in Redis. Defaults to rl:.
  • client: Redis Client or ioredis Client- A Redis Client to use. Defaults to require('redis').createClient();.
  • redisURL: string - a Redis connection string to be used for the default client connection. Ignored when the client option is provided. Redis Client connection string format and options.

License

MIT © Wyatt Johnson, Nathan Friedly

About

A rate limiting store for express-rate-limit with Redis


Languages

Language:JavaScript 100.0%