]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blobdiff - server/controllers/api/index.ts
replace numbers with typed http status codes (#3409)
[github/Chocobozzz/PeerTube.git] / server / controllers / api / index.ts
index 18bef2d3d3777604d819a7f91d50a2e7709e4b8a..7ade1df3a9a3a84b42cb44e6ff83f5f045532f92 100644 (file)
@@ -1,24 +1,52 @@
-import express = require('express')
-
-import { badRequest } from '../../helpers'
-
-import { clientsRouter } from './clients'
+import * as cors from 'cors'
+import * as express from 'express'
+import * as RateLimit from 'express-rate-limit'
+import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
+import { badRequest } from '../../helpers/express-utils'
+import { CONFIG } from '../../initializers/config'
+import { abuseRouter } from './abuse'
+import { accountsRouter } from './accounts'
+import { bulkRouter } from './bulk'
 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 { overviewsRouter } from './overviews'
+import { pluginRouter } from './plugins'
+import { searchRouter } from './search'
+import { serverRouter } from './server'
 import { usersRouter } from './users'
+import { videoChannelRouter } from './video-channel'
+import { videoPlaylistRouter } from './video-playlist'
 import { videosRouter } from './videos'
 
 const apiRouter = express.Router()
 
-apiRouter.use('/clients', clientsRouter)
+apiRouter.use(cors({
+  origin: '*',
+  exposedHeaders: 'Retry-After',
+  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('/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 +56,6 @@ export { apiRouter }
 
 // ---------------------------------------------------------------------------
 
-function pong (req, res, next) {
-  return res.send('pong').status(200).end()
+function pong (req: express.Request, res: express.Response) {
+  return res.send('pong').status(HttpStatusCode.OK_200).end()
 }