123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- import * as express from 'express'
- import { body } from 'express-validator/check'
- import { isIdValid } from '../../../helpers/custom-validators/misc'
- import { logger } from '../../../helpers/logger'
- import { areValidationErrors } from '../utils'
- import { getCommonVideoEditAttributes } from './videos'
- import { isVideoImportTargetUrlValid, isVideoImportTorrentFile } from '../../../helpers/custom-validators/video-imports'
- import { cleanUpReqFiles } from '../../../helpers/express-utils'
- import { doesVideoChannelOfAccountExist, isVideoMagnetUriValid, isVideoNameValid } from '../../../helpers/custom-validators/videos'
- import { CONFIG } from '../../../initializers/config'
- import { CONSTRAINTS_FIELDS } from '../../../initializers/constants'
- const videoImportAddValidator = getCommonVideoEditAttributes().concat([
- body('channelId')
- .toInt()
- .custom(isIdValid).withMessage('Should have correct video channel id'),
- body('targetUrl')
- .optional()
- .custom(isVideoImportTargetUrlValid).withMessage('Should have a valid video import target URL'),
- body('magnetUri')
- .optional()
- .custom(isVideoMagnetUriValid).withMessage('Should have a valid video magnet URI'),
- body('torrentfile')
- .custom((value, { req }) => isVideoImportTorrentFile(req.files)).withMessage(
- 'This torrent file is not supported or too large. Please, make sure it is of the following type: '
- + CONSTRAINTS_FIELDS.VIDEO_IMPORTS.TORRENT_FILE.EXTNAME.join(', ')
- ),
- body('name')
- .optional()
- .custom(isVideoNameValid).withMessage('Should have a valid name'),
- async (req: express.Request, res: express.Response, next: express.NextFunction) => {
- logger.debug('Checking videoImportAddValidator parameters', { parameters: req.body })
- const user = res.locals.oauth.token.User
- const torrentFile = req.files && req.files['torrentfile'] ? req.files['torrentfile'][0] : undefined
- if (areValidationErrors(req, res)) return cleanUpReqFiles(req)
- if (req.body.targetUrl && CONFIG.IMPORT.VIDEOS.HTTP.ENABLED !== true) {
- cleanUpReqFiles(req)
- return res.status(409)
- .json({ error: 'HTTP import is not enabled on this instance.' })
- .end()
- }
- if (CONFIG.IMPORT.VIDEOS.TORRENT.ENABLED !== true && (req.body.magnetUri || torrentFile)) {
- cleanUpReqFiles(req)
- return res.status(409)
- .json({ error: 'Torrent/magnet URI import is not enabled on this instance.' })
- .end()
- }
- if (!await doesVideoChannelOfAccountExist(req.body.channelId, user, res)) return cleanUpReqFiles(req)
- // Check we have at least 1 required param
- if (!req.body.targetUrl && !req.body.magnetUri && !torrentFile) {
- cleanUpReqFiles(req)
- return res.status(400)
- .json({ error: 'Should have a magnetUri or a targetUrl or a torrent file.' })
- .end()
- }
- return next()
- }
- ])
- // ---------------------------------------------------------------------------
- export {
- videoImportAddValidator
- }
- // ---------------------------------------------------------------------------
|