X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Fapi%2Findex.ts;h=6138a32de9305c0d1877ab3042a42d0377e80bcb;hb=51b34a11b298b466faef9c8d24beec4442d7add3;hp=a22c78cceb079010cbfcc09d658e7a59b33659f8;hpb=51548b31815c6f96f314ae96588a9adca150519d;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/api/index.ts b/server/controllers/api/index.ts index a22c78cce..6138a32de 100644 --- a/server/controllers/api/index.ts +++ b/server/controllers/api/index.ts @@ -1,20 +1,49 @@ import * as express from 'express' - -import { badRequest } from '../../helpers' - -import { oauthClientsRouter } from './oauth-clients' +import * as RateLimit from 'express-rate-limit' import { configRouter } from './config' -import { applicationRouter } from './application' +import { jobsRouter } from './jobs' +import { oauthClientsRouter } from './oauth-clients' +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 { CONFIG } from '../../initializers/config' +import { pluginRouter } from './plugins' const apiRouter = express.Router() -apiRouter.use('/application', applicationRouter) +apiRouter.use(cors({ + origin: '*', + exposedHeaders: 'Retry-After', + credentials: true +})) + +// FIXME: https://github.com/nfriedly/express-rate-limit/issues/138 +// @ts-ignore +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('/oauth-clients', oauthClientsRouter) apiRouter.use('/config', configRouter) apiRouter.use('/users', usersRouter) +apiRouter.use('/accounts', accountsRouter) +apiRouter.use('/video-channels', videoChannelRouter) +apiRouter.use('/video-playlists', videoPlaylistRouter) apiRouter.use('/videos', videosRouter) +apiRouter.use('/jobs', jobsRouter) +apiRouter.use('/search', searchRouter) +apiRouter.use('/overviews', overviewsRouter) +apiRouter.use('/plugins', pluginRouter) apiRouter.use('/ping', pong) apiRouter.use('/*', badRequest) @@ -24,6 +53,6 @@ export { apiRouter } // --------------------------------------------------------------------------- -function pong (req: express.Request, res: express.Response, next: express.NextFunction) { +function pong (req: express.Request, res: express.Response) { return res.send('pong').status(200).end() }