]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame_incremental - server/middlewares/user-right.ts
Merge branch 'develop' into shorter-URLs-channels-accounts
[github/Chocobozzz/PeerTube.git] / server / middlewares / user-right.ts
... / ...
CommitLineData
1import * as express from 'express'
2import { UserRight } from '../../shared'
3import { logger } from '../helpers/logger'
4import { HttpStatusCode } from '../../shared/core-utils/miscs/http-error-codes'
5
6function ensureUserHasRight (userRight: UserRight) {
7 return function (req: express.Request, res: express.Response, next: express.NextFunction) {
8 const user = res.locals.oauth.token.user
9 if (user.hasRight(userRight) === false) {
10 const message = `User ${user.username} does not have right ${userRight} to access to ${req.path}.`
11 logger.info(message)
12
13 return res.status(HttpStatusCode.FORBIDDEN_403)
14 .json({ error: message })
15 }
16
17 return next()
18 }
19}
20
21// ---------------------------------------------------------------------------
22
23export {
24 ensureUserHasRight
25}