Add state and moderationComment for abuses on server side
[oweals/peertube.git] / server / middlewares / validators / video-abuses.ts
1 import * as express from 'express'
2 import 'express-validator'
3 import { body, param } from 'express-validator/check'
4 import { isIdOrUUIDValid, isIdValid } from '../../helpers/custom-validators/misc'
5 import { isVideoExist } from '../../helpers/custom-validators/videos'
6 import { logger } from '../../helpers/logger'
7 import { areValidationErrors } from './utils'
8 import {
9   isVideoAbuseExist,
10   isVideoAbuseModerationCommentValid,
11   isVideoAbuseReasonValid,
12   isVideoAbuseStateValid
13 } from '../../helpers/custom-validators/video-abuses'
14
15 const videoAbuseReportValidator = [
16   param('videoId').custom(isIdOrUUIDValid).not().isEmpty().withMessage('Should have a valid videoId'),
17   body('reason').custom(isVideoAbuseReasonValid).withMessage('Should have a valid reason'),
18
19   async (req: express.Request, res: express.Response, next: express.NextFunction) => {
20     logger.debug('Checking videoAbuseReport parameters', { parameters: req.body })
21
22     if (areValidationErrors(req, res)) return
23     if (!await isVideoExist(req.params.videoId, res)) return
24
25     return next()
26   }
27 ]
28
29 const videoAbuseGetValidator = [
30   param('videoId').custom(isIdOrUUIDValid).not().isEmpty().withMessage('Should have a valid videoId'),
31   param('id').custom(isIdValid).not().isEmpty().withMessage('Should have a valid id'),
32
33   async (req: express.Request, res: express.Response, next: express.NextFunction) => {
34     logger.debug('Checking videoAbuseGetValidator parameters', { parameters: req.body })
35
36     if (areValidationErrors(req, res)) return
37     if (!await isVideoExist(req.params.videoId, res)) return
38     if (!await isVideoAbuseExist(req.params.id, res.locals.video.id, res)) return
39
40     return next()
41   }
42 ]
43
44 const videoAbuseUpdateValidator = [
45   param('videoId').custom(isIdOrUUIDValid).not().isEmpty().withMessage('Should have a valid videoId'),
46   param('id').custom(isIdValid).not().isEmpty().withMessage('Should have a valid id'),
47   body('state')
48     .optional()
49     .custom(isVideoAbuseStateValid).withMessage('Should have a valid video abuse state'),
50   body('moderationComment')
51     .optional()
52     .custom(isVideoAbuseModerationCommentValid).withMessage('Should have a valid video moderation comment'),
53
54   async (req: express.Request, res: express.Response, next: express.NextFunction) => {
55     logger.debug('Checking videoAbuseUpdateValidator parameters', { parameters: req.body })
56
57     if (areValidationErrors(req, res)) return
58     if (!await isVideoExist(req.params.videoId, res)) return
59     if (!await isVideoAbuseExist(req.params.id, res.locals.video.id, res)) return
60
61     return next()
62   }
63 ]
64
65 // ---------------------------------------------------------------------------
66
67 export {
68   videoAbuseReportValidator,
69   videoAbuseGetValidator,
70   videoAbuseUpdateValidator
71 }