mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-20 00:08:02 +01:00
1bba76413f
### What This PR makes the rate limit for user creation and simple login (our password based login) configurable in the same way you can do metricsRateLimiting. ### Worth noting In addition this PR adds a `rate_limit{endpoint, method}` prometheus gauge, which gets the data from the UnleashConfig.
60 lines
2.2 KiB
TypeScript
60 lines
2.2 KiB
TypeScript
import { BackstageController } from './backstage';
|
|
import ResetPasswordController from './auth/reset-password-controller';
|
|
import { SimplePasswordProvider } from './auth/simple-password-provider';
|
|
import { IUnleashConfig, IUnleashServices } from '../types';
|
|
import LogoutController from './logout';
|
|
import rateLimit from 'express-rate-limit';
|
|
|
|
const AdminApi = require('./admin-api');
|
|
const ClientApi = require('./client-api');
|
|
const Controller = require('./controller');
|
|
import { HealthCheckController } from './health-check';
|
|
import ProxyController from './proxy-api';
|
|
import EdgeController from './edge-api';
|
|
import { PublicInviteController } from './public-invite';
|
|
import { Db } from '../db/db';
|
|
import { minutesToMilliseconds } from 'date-fns';
|
|
|
|
class IndexRouter extends Controller {
|
|
constructor(config: IUnleashConfig, services: IUnleashServices, db: Db) {
|
|
super(config);
|
|
|
|
this.use('/health', new HealthCheckController(config, services).router);
|
|
this.use(
|
|
'/invite',
|
|
new PublicInviteController(config, services).router,
|
|
);
|
|
this.use('/internal-backstage', new BackstageController(config).router);
|
|
this.use('/logout', new LogoutController(config, services).router);
|
|
this.useWithMiddleware(
|
|
'/auth/simple',
|
|
new SimplePasswordProvider(config, services).router,
|
|
rateLimit({
|
|
windowMs: minutesToMilliseconds(1),
|
|
max: config.rateLimiting.simpleLoginMaxPerMinute,
|
|
validate: false,
|
|
standardHeaders: true,
|
|
legacyHeaders: false,
|
|
}),
|
|
);
|
|
this.use(
|
|
'/auth/reset',
|
|
new ResetPasswordController(config, services).router,
|
|
);
|
|
|
|
this.use('/api/admin', new AdminApi(config, services, db).router);
|
|
this.use('/api/client', new ClientApi(config, services).router);
|
|
|
|
this.use(
|
|
'/api/frontend',
|
|
new ProxyController(config, services, config.flagResolver).router,
|
|
);
|
|
|
|
this.use('/edge', new EdgeController(config, services).router);
|
|
}
|
|
}
|
|
|
|
export default IndexRouter;
|
|
|
|
module.exports = IndexRouter;
|