Merge pull request #98 from openresearch/feature/no_rate_limit
introduce env variable DISABLE_RATE_LIMIT to disable rate limit
This commit is contained in:
		| @@ -67,12 +67,15 @@ export default class ChatServer { | |||||||
|         this.app.use(express.json({ limit: '1mb' })); |         this.app.use(express.json({ limit: '1mb' })); | ||||||
|         this.app.use(compression()); |         this.app.use(compression()); | ||||||
|  |  | ||||||
|  |          | ||||||
|  |         const rateLimitWindowMs = process.env.RATE_LIMIT_WINDOW_MS ? parseInt(process.env.RATE_LIMIT_WINDOW_MS, 10) : 15 * 60 * 1000; // 15 minutes | ||||||
|  |         const rateLimitMax = process.env.RATE_LIMIT_MAX ? parseInt(process.env.RATE_LIMIT_MAX, 10) : 100; // limit each IP to 100 requests per windowMs | ||||||
|  |  | ||||||
|         const { default: rateLimit } = await import('express-rate-limit'); // esm |         const { default: rateLimit } = await import('express-rate-limit'); // esm | ||||||
|         const limiter = rateLimit({ |         const limiter = rateLimit({ | ||||||
|             windowMs: 15 * 60 * 1000, // 15 minutes |             windowMs: rateLimitWindowMs, | ||||||
|             max: 100, // limit each IP to 100 requests per windowMs |             max: rateLimitMax, | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
|         this.app.use(limiter); |         this.app.use(limiter); | ||||||
|  |  | ||||||
|         this.app.get('/chatapi/health', (req, res) => new HealthRequestHandler(this, req, res)); |         this.app.get('/chatapi/health', (req, res) => new HealthRequestHandler(this, req, res)); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user