ensure correct client ip is used for rate limiting as described on the GitHub repo of 'express-rate-limit'
This commit is contained in:
parent
58a32d43b3
commit
49e7281092
1 changed files with 4 additions and 1 deletions
5
index.js
5
index.js
|
@ -58,13 +58,16 @@ const app = express();
|
||||||
if (process.argv.includes('--rate-limit')) {
|
if (process.argv.includes('--rate-limit')) {
|
||||||
const limiter = RateLimit({
|
const limiter = RateLimit({
|
||||||
windowMs: 5 * 60 * 1000, // 5 minutes
|
windowMs: 5 * 60 * 1000, // 5 minutes
|
||||||
max: 1000, // Limit each IP to 100 requests per `window` (here, per 5 minutes)
|
max: 1000, // Limit each IP to 1000 requests per `window` (here, per 5 minutes)
|
||||||
message: 'Too many requests from this IP Address, please try again after 5 minutes.',
|
message: 'Too many requests from this IP Address, please try again after 5 minutes.',
|
||||||
standardHeaders: true, // Return rate limit info in the `RateLimit-*` headers
|
standardHeaders: true, // Return rate limit info in the `RateLimit-*` headers
|
||||||
legacyHeaders: false, // Disable the `X-RateLimit-*` headers
|
legacyHeaders: false, // Disable the `X-RateLimit-*` headers
|
||||||
})
|
})
|
||||||
|
|
||||||
app.use(limiter);
|
app.use(limiter);
|
||||||
|
// ensure correct client ip and not the ip of the reverse proxy is used for rate limiting on render.com
|
||||||
|
// see https://github.com/express-rate-limit/express-rate-limit#troubleshooting-proxy-issues
|
||||||
|
app.set('trust proxy', 5);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.argv.includes('--include-ws-fallback')) {
|
if (process.argv.includes('--include-ws-fallback')) {
|
||||||
|
|
Loading…
Reference in a new issue