X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Fapi%2Findex.ts;h=5f49336b13c886ad39820c0adc98ee2cef461b94;hb=d0800f7661f13fabe7bb6f4aa0ea50764f106405;hp=ed4b33deaace637a0957158c11e8360c9ec0af92;hpb=418d092afa81e2c8fe8ac6838fc4b5eb0af6a782;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/api/index.ts b/server/controllers/api/index.ts index ed4b33dea..5f49336b1 100644 --- a/server/controllers/api/index.ts +++ b/server/controllers/api/index.ts @@ -1,17 +1,25 @@ -import * as express from 'express' +import cors from 'cors' +import express from 'express' +import RateLimit from 'express-rate-limit' +import { HttpStatusCode } from '../../../shared/models' +import { badRequest } from '../../helpers/express-utils' +import { CONFIG } from '../../initializers/config' +import { abuseRouter } from './abuse' +import { accountsRouter } from './accounts' +import { blocklistRouter } from './blocklist' +import { bulkRouter } from './bulk' import { configRouter } from './config' +import { customPageRouter } from './custom-page' import { jobsRouter } from './jobs' import { oauthClientsRouter } from './oauth-clients' +import { overviewsRouter } from './overviews' +import { pluginRouter } from './plugins' +import { searchRouter } from './search' import { serverRouter } from './server' import { usersRouter } from './users' -import { accountsRouter } from './accounts' -import { videosRouter } from './videos' -import { badRequest } from '../../helpers/express-utils' import { videoChannelRouter } from './video-channel' -import * as cors from 'cors' -import { searchRouter } from './search' -import { overviewsRouter } from './overviews' import { videoPlaylistRouter } from './video-playlist' +import { videosRouter } from './videos' const apiRouter = express.Router() @@ -21,7 +29,15 @@ apiRouter.use(cors({ credentials: true })) +const apiRateLimiter = RateLimit({ + windowMs: CONFIG.RATES_LIMIT.API.WINDOW_MS, + max: CONFIG.RATES_LIMIT.API.MAX +}) +apiRouter.use(apiRateLimiter) + apiRouter.use('/server', serverRouter) +apiRouter.use('/abuses', abuseRouter) +apiRouter.use('/bulk', bulkRouter) apiRouter.use('/oauth-clients', oauthClientsRouter) apiRouter.use('/config', configRouter) apiRouter.use('/users', usersRouter) @@ -32,6 +48,9 @@ apiRouter.use('/videos', videosRouter) apiRouter.use('/jobs', jobsRouter) apiRouter.use('/search', searchRouter) apiRouter.use('/overviews', overviewsRouter) +apiRouter.use('/plugins', pluginRouter) +apiRouter.use('/custom-pages', customPageRouter) +apiRouter.use('/blocklist', blocklistRouter) apiRouter.use('/ping', pong) apiRouter.use('/*', badRequest) @@ -41,6 +60,6 @@ export { apiRouter } // --------------------------------------------------------------------------- -function pong (req: express.Request, res: express.Response, next: express.NextFunction) { - return res.send('pong').status(200).end() +function pong (req: express.Request, res: express.Response) { + return res.send('pong').status(HttpStatusCode.OK_200).end() }