Implement contact form on server side
[oweals/peertube.git] / server / middlewares / validators / config.ts
1 import * as express from 'express'
2 import { body } from 'express-validator/check'
3 import { isUserNSFWPolicyValid, isUserVideoQuotaValid, isUserVideoQuotaDailyValid } from '../../helpers/custom-validators/users'
4 import { logger } from '../../helpers/logger'
5 import { areValidationErrors } from './utils'
6
7 const customConfigUpdateValidator = [
8   body('instance.name').exists().withMessage('Should have a valid instance name'),
9   body('instance.shortDescription').exists().withMessage('Should have a valid instance short description'),
10   body('instance.description').exists().withMessage('Should have a valid instance description'),
11   body('instance.terms').exists().withMessage('Should have a valid instance terms'),
12   body('instance.defaultClientRoute').exists().withMessage('Should have a valid instance default client route'),
13   body('instance.defaultNSFWPolicy').custom(isUserNSFWPolicyValid).withMessage('Should have a valid NSFW policy'),
14   body('instance.customizations.css').exists().withMessage('Should have a valid instance CSS customization'),
15   body('instance.customizations.javascript').exists().withMessage('Should have a valid instance JavaScript customization'),
16
17   body('services.twitter.username').exists().withMessage('Should have a valid twitter username'),
18   body('services.twitter.whitelisted').isBoolean().withMessage('Should have a valid twitter whitelisted boolean'),
19
20   body('cache.previews.size').isInt().withMessage('Should have a valid previews cache size'),
21   body('cache.captions.size').isInt().withMessage('Should have a valid captions cache size'),
22
23   body('signup.enabled').isBoolean().withMessage('Should have a valid signup enabled boolean'),
24   body('signup.limit').isInt().withMessage('Should have a valid signup limit'),
25   body('signup.requiresEmailVerification').isBoolean().withMessage('Should have a valid requiresEmailVerification boolean'),
26
27   body('admin.email').isEmail().withMessage('Should have a valid administrator email'),
28   body('contactForm.enabled').isBoolean().withMessage('Should have a valid contact form enabled boolean'),
29
30   body('user.videoQuota').custom(isUserVideoQuotaValid).withMessage('Should have a valid video quota'),
31   body('user.videoQuotaDaily').custom(isUserVideoQuotaDailyValid).withMessage('Should have a valid daily video quota'),
32
33   body('transcoding.enabled').isBoolean().withMessage('Should have a valid transcoding enabled boolean'),
34   body('transcoding.allowAdditionalExtensions').isBoolean().withMessage('Should have a valid additional extensions boolean'),
35   body('transcoding.threads').isInt().withMessage('Should have a valid transcoding threads number'),
36   body('transcoding.resolutions.240p').isBoolean().withMessage('Should have a valid transcoding 240p resolution enabled boolean'),
37   body('transcoding.resolutions.360p').isBoolean().withMessage('Should have a valid transcoding 360p resolution enabled boolean'),
38   body('transcoding.resolutions.480p').isBoolean().withMessage('Should have a valid transcoding 480p resolution enabled boolean'),
39   body('transcoding.resolutions.720p').isBoolean().withMessage('Should have a valid transcoding 720p resolution enabled boolean'),
40   body('transcoding.resolutions.1080p').isBoolean().withMessage('Should have a valid transcoding 1080p resolution enabled boolean'),
41
42   body('import.videos.http.enabled').isBoolean().withMessage('Should have a valid import video http enabled boolean'),
43   body('import.videos.torrent.enabled').isBoolean().withMessage('Should have a valid import video torrent enabled boolean'),
44
45   async (req: express.Request, res: express.Response, next: express.NextFunction) => {
46     logger.debug('Checking customConfigUpdateValidator parameters', { parameters: req.body })
47
48     if (areValidationErrors(req, res)) return
49
50     return next()
51   }
52 ]
53
54 export {
55   customConfigUpdateValidator
56 }