X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fmiddlewares%2Fvalidators%2Fconfig.ts;h=3a7daa57329e8fc2a5f88e4bf67be31cd0bd043e;hb=9972ace3a3bc65865fb3aaaa865a400386e49252;hp=90108fa825d9cb57070d3248b31bd92fc4501186;hpb=a4101923e699e49ceb9ff36e971c75417fafc9f0;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/middlewares/validators/config.ts b/server/middlewares/validators/config.ts index 90108fa82..3a7daa573 100644 --- a/server/middlewares/validators/config.ts +++ b/server/middlewares/validators/config.ts @@ -1,56 +1,186 @@ -import * as express from 'express' -import { body } from 'express-validator/check' -import { isUserNSFWPolicyValid, isUserVideoQuotaValid, isUserVideoQuotaDailyValid } from '../../helpers/custom-validators/users' -import { logger } from '../../helpers/logger' -import { areValidationErrors } from './utils' +import express from 'express' +import { body } from 'express-validator' +import { isIntOrNull } from '@server/helpers/custom-validators/misc' +import { CONFIG, isEmailEnabled } from '@server/initializers/config' +import { HttpStatusCode } from '@shared/models/http/http-error-codes' +import { CustomConfig } from '../../../shared/models/server/custom-config.model' +import { isThemeNameValid } from '../../helpers/custom-validators/plugins' +import { isUserNSFWPolicyValid, isUserVideoQuotaDailyValid, isUserVideoQuotaValid } from '../../helpers/custom-validators/users' +import { isThemeRegistered } from '../../lib/plugins/theme-utils' +import { areValidationErrors } from './shared' const customConfigUpdateValidator = [ - body('instance.name').exists().withMessage('Should have a valid instance name'), - body('instance.shortDescription').exists().withMessage('Should have a valid instance short description'), - body('instance.description').exists().withMessage('Should have a valid instance description'), - body('instance.terms').exists().withMessage('Should have a valid instance terms'), - body('instance.defaultClientRoute').exists().withMessage('Should have a valid instance default client route'), - body('instance.defaultNSFWPolicy').custom(isUserNSFWPolicyValid).withMessage('Should have a valid NSFW policy'), - body('instance.customizations.css').exists().withMessage('Should have a valid instance CSS customization'), - body('instance.customizations.javascript').exists().withMessage('Should have a valid instance JavaScript customization'), - - body('services.twitter.username').exists().withMessage('Should have a valid twitter username'), - body('services.twitter.whitelisted').isBoolean().withMessage('Should have a valid twitter whitelisted boolean'), - - body('cache.previews.size').isInt().withMessage('Should have a valid previews cache size'), - body('cache.captions.size').isInt().withMessage('Should have a valid captions cache size'), - - body('signup.enabled').isBoolean().withMessage('Should have a valid signup enabled boolean'), - body('signup.limit').isInt().withMessage('Should have a valid signup limit'), - body('signup.requiresEmailVerification').isBoolean().withMessage('Should have a valid requiresEmailVerification boolean'), - - body('admin.email').isEmail().withMessage('Should have a valid administrator email'), - body('contactForm.enabled').isBoolean().withMessage('Should have a valid contact form enabled boolean'), - - body('user.videoQuota').custom(isUserVideoQuotaValid).withMessage('Should have a valid video quota'), - body('user.videoQuotaDaily').custom(isUserVideoQuotaDailyValid).withMessage('Should have a valid daily video quota'), - - body('transcoding.enabled').isBoolean().withMessage('Should have a valid transcoding enabled boolean'), - body('transcoding.allowAdditionalExtensions').isBoolean().withMessage('Should have a valid additional extensions boolean'), - body('transcoding.threads').isInt().withMessage('Should have a valid transcoding threads number'), - body('transcoding.resolutions.240p').isBoolean().withMessage('Should have a valid transcoding 240p resolution enabled boolean'), - body('transcoding.resolutions.360p').isBoolean().withMessage('Should have a valid transcoding 360p resolution enabled boolean'), - body('transcoding.resolutions.480p').isBoolean().withMessage('Should have a valid transcoding 480p resolution enabled boolean'), - body('transcoding.resolutions.720p').isBoolean().withMessage('Should have a valid transcoding 720p resolution enabled boolean'), - body('transcoding.resolutions.1080p').isBoolean().withMessage('Should have a valid transcoding 1080p resolution enabled boolean'), - - body('import.videos.http.enabled').isBoolean().withMessage('Should have a valid import video http enabled boolean'), - body('import.videos.torrent.enabled').isBoolean().withMessage('Should have a valid import video torrent enabled boolean'), - - async (req: express.Request, res: express.Response, next: express.NextFunction) => { - logger.debug('Checking customConfigUpdateValidator parameters', { parameters: req.body }) + body('instance.name').exists(), + body('instance.shortDescription').exists(), + body('instance.description').exists(), + body('instance.terms').exists(), + body('instance.defaultNSFWPolicy').custom(isUserNSFWPolicyValid), + body('instance.defaultClientRoute').exists(), + body('instance.customizations.css').exists(), + body('instance.customizations.javascript').exists(), + body('services.twitter.username').exists(), + body('services.twitter.whitelisted').isBoolean(), + + body('cache.previews.size').isInt(), + body('cache.captions.size').isInt(), + body('cache.torrents.size').isInt(), + + body('signup.enabled').isBoolean(), + body('signup.limit').isInt(), + body('signup.requiresEmailVerification').isBoolean(), + body('signup.minimumAge').isInt(), + + body('admin.email').isEmail(), + body('contactForm.enabled').isBoolean(), + + body('user.videoQuota').custom(isUserVideoQuotaValid), + body('user.videoQuotaDaily').custom(isUserVideoQuotaDailyValid), + + body('videoChannels.maxPerUser').isInt(), + + body('transcoding.enabled').isBoolean(), + body('transcoding.allowAdditionalExtensions').isBoolean(), + body('transcoding.threads').isInt(), + body('transcoding.concurrency').isInt({ min: 1 }), + body('transcoding.resolutions.0p').isBoolean(), + body('transcoding.resolutions.144p').isBoolean(), + body('transcoding.resolutions.240p').isBoolean(), + body('transcoding.resolutions.360p').isBoolean(), + body('transcoding.resolutions.480p').isBoolean(), + body('transcoding.resolutions.720p').isBoolean(), + body('transcoding.resolutions.1080p').isBoolean(), + body('transcoding.resolutions.1440p').isBoolean(), + body('transcoding.resolutions.2160p').isBoolean(), + + body('transcoding.alwaysTranscodeOriginalResolution').isBoolean(), + + body('transcoding.webtorrent.enabled').isBoolean(), + body('transcoding.hls.enabled').isBoolean(), + + body('videoStudio.enabled').isBoolean(), + + body('import.videos.concurrency').isInt({ min: 0 }), + body('import.videos.http.enabled').isBoolean(), + body('import.videos.torrent.enabled').isBoolean(), + + body('import.videoChannelSynchronization.enabled').isBoolean(), + + body('trending.videos.algorithms.default').exists(), + body('trending.videos.algorithms.enabled').exists(), + + body('followers.instance.enabled').isBoolean(), + body('followers.instance.manualApproval').isBoolean(), + + body('theme.default').custom(v => isThemeNameValid(v) && isThemeRegistered(v)), + + body('broadcastMessage.enabled').isBoolean(), + body('broadcastMessage.message').exists(), + body('broadcastMessage.level').exists(), + body('broadcastMessage.dismissable').isBoolean(), + + body('live.enabled').isBoolean(), + body('live.allowReplay').isBoolean(), + body('live.maxDuration').isInt(), + body('live.maxInstanceLives').custom(isIntOrNull), + body('live.maxUserLives').custom(isIntOrNull), + body('live.transcoding.enabled').isBoolean(), + body('live.transcoding.threads').isInt(), + body('live.transcoding.resolutions.144p').isBoolean(), + body('live.transcoding.resolutions.240p').isBoolean(), + body('live.transcoding.resolutions.360p').isBoolean(), + body('live.transcoding.resolutions.480p').isBoolean(), + body('live.transcoding.resolutions.720p').isBoolean(), + body('live.transcoding.resolutions.1080p').isBoolean(), + body('live.transcoding.resolutions.1440p').isBoolean(), + body('live.transcoding.resolutions.2160p').isBoolean(), + body('live.transcoding.alwaysTranscodeOriginalResolution').isBoolean(), + + body('search.remoteUri.users').isBoolean(), + body('search.remoteUri.anonymous').isBoolean(), + body('search.searchIndex.enabled').isBoolean(), + body('search.searchIndex.url').exists(), + body('search.searchIndex.disableLocalSearch').isBoolean(), + body('search.searchIndex.isDefaultSearch').isBoolean(), + + (req: express.Request, res: express.Response, next: express.NextFunction) => { if (areValidationErrors(req, res)) return + if (!checkInvalidConfigIfEmailDisabled(req.body, res)) return + if (!checkInvalidTranscodingConfig(req.body, res)) return + if (!checkInvalidSynchronizationConfig(req.body, res)) return + if (!checkInvalidLiveConfig(req.body, res)) return + if (!checkInvalidVideoStudioConfig(req.body, res)) return return next() } ] +function ensureConfigIsEditable (req: express.Request, res: express.Response, next: express.NextFunction) { + if (!CONFIG.WEBADMIN.CONFIGURATION.EDITION.ALLOWED) { + return res.fail({ + status: HttpStatusCode.METHOD_NOT_ALLOWED_405, + message: 'Server configuration is static and cannot be edited' + }) + } + + return next() +} + +// --------------------------------------------------------------------------- + export { - customConfigUpdateValidator + customConfigUpdateValidator, + ensureConfigIsEditable +} + +function checkInvalidConfigIfEmailDisabled (customConfig: CustomConfig, res: express.Response) { + if (isEmailEnabled()) return true + + if (customConfig.signup.requiresEmailVerification === true) { + res.fail({ message: 'Emailer is disabled but you require signup email verification.' }) + return false + } + + return true +} + +function checkInvalidTranscodingConfig (customConfig: CustomConfig, res: express.Response) { + if (customConfig.transcoding.enabled === false) return true + + if (customConfig.transcoding.webtorrent.enabled === false && customConfig.transcoding.hls.enabled === false) { + res.fail({ message: 'You need to enable at least webtorrent transcoding or hls transcoding' }) + return false + } + + return true +} + +function checkInvalidSynchronizationConfig (customConfig: CustomConfig, res: express.Response) { + if (customConfig.import.videoChannelSynchronization.enabled && !customConfig.import.videos.http.enabled) { + res.fail({ message: 'You need to enable HTTP video import in order to enable channel synchronization' }) + return false + } + return true +} + +function checkInvalidLiveConfig (customConfig: CustomConfig, res: express.Response) { + if (customConfig.live.enabled === false) return true + + if (customConfig.live.allowReplay === true && customConfig.transcoding.enabled === false) { + res.fail({ message: 'You cannot allow live replay if transcoding is not enabled' }) + return false + } + + return true +} + +function checkInvalidVideoStudioConfig (customConfig: CustomConfig, res: express.Response) { + if (customConfig.videoStudio.enabled === false) return true + + if (customConfig.videoStudio.enabled === true && customConfig.transcoding.enabled === false) { + res.fail({ message: 'You cannot enable video studio if transcoding is not enabled' }) + return false + } + + return true }