X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Fapi%2Findex.ts;h=e1d197c8a4ea43c96b1d1175e5c04bf9c3bc5b26;hb=a68ccaead667f1b976e0fb10c8b1087af25547f2;hp=e928a747846bab5b6fc1de2a6869c010149c2809;hpb=57c36b277e68b764dd34cb2e449f6e2ca3d1e9b6;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/api/index.ts b/server/controllers/api/index.ts index e928a7478..e1d197c8a 100644 --- a/server/controllers/api/index.ts +++ b/server/controllers/api/index.ts @@ -1,15 +1,27 @@ -import * as express from 'express' +import cors from 'cors' +import express from 'express' +import { buildRateLimiter } from '@server/middlewares' +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 { metricsRouter } from './metrics' 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 { videoChannelSyncRouter } from './video-channel-sync' +import { videoPlaylistRouter } from './video-playlist' +import { videosRouter } from './videos' const apiRouter = express.Router() @@ -19,15 +31,30 @@ apiRouter.use(cors({ credentials: true })) +const apiRateLimiter = buildRateLimiter({ + 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) apiRouter.use('/accounts', accountsRouter) apiRouter.use('/video-channels', videoChannelRouter) +apiRouter.use('/video-channel-syncs', videoChannelSyncRouter) +apiRouter.use('/video-playlists', videoPlaylistRouter) apiRouter.use('/videos', videosRouter) apiRouter.use('/jobs', jobsRouter) +apiRouter.use('/metrics', metricsRouter) 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) @@ -37,6 +64,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() }