X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Fapi%2Findex.ts;h=6138a32de9305c0d1877ab3042a42d0377e80bcb;hb=51b34a11b298b466faef9c8d24beec4442d7add3;hp=18bef2d3d3777604d819a7f91d50a2e7709e4b8a;hpb=65fcc3119c334b75dd13bcfdebf186afdc580a8f;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/api/index.ts b/server/controllers/api/index.ts index 18bef2d3d..6138a32de 100644 --- a/server/controllers/api/index.ts +++ b/server/controllers/api/index.ts @@ -1,24 +1,49 @@ -import express = require('express') - -import { badRequest } from '../../helpers' - -import { clientsRouter } from './clients' +import * as express from 'express' +import * as RateLimit from 'express-rate-limit' import { configRouter } from './config' -import { podsRouter } from './pods' -import { remoteRouter } from './remote' -import { requestsRouter } from './requests' +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('/clients', clientsRouter) +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('/pods', podsRouter) -apiRouter.use('/remote', remoteRouter) -apiRouter.use('/requests', requestsRouter) 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) @@ -28,6 +53,6 @@ export { apiRouter } // --------------------------------------------------------------------------- -function pong (req, res, next) { +function pong (req: express.Request, res: express.Response) { return res.send('pong').status(200).end() }