]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/middlewares/validators/video-imports.ts
Correctly handle video import errors
[github/Chocobozzz/PeerTube.git] / server / middlewares / validators / video-imports.ts
CommitLineData
fbad87b0
C
1import * as express from 'express'
2import { body, param } from 'express-validator/check'
3import { isIdValid } from '../../helpers/custom-validators/misc'
4import { logger } from '../../helpers/logger'
5import { areValidationErrors } from './utils'
6import { getCommonVideoAttributes } from './videos'
299474e8 7import { isVideoImportTargetUrlValid, isVideoImportExist } from '../../helpers/custom-validators/video-imports'
fbad87b0 8import { cleanUpReqFiles } from '../../helpers/utils'
299474e8
C
9import { isVideoChannelOfAccountExist, isVideoNameValid, checkUserCanManageVideo } from '../../helpers/custom-validators/videos'
10import { VideoImportModel } from '../../models/video/video-import'
11import { UserRight } from '../../../shared'
fbad87b0
C
12
13const videoImportAddValidator = getCommonVideoAttributes().concat([
14 body('targetUrl').custom(isVideoImportTargetUrlValid).withMessage('Should have a valid video import target URL'),
15 body('channelId')
16 .toInt()
17 .custom(isIdValid).withMessage('Should have correct video channel id'),
18 body('name')
19 .optional()
20 .custom(isVideoNameValid).withMessage('Should have a valid name'),
21
22 async (req: express.Request, res: express.Response, next: express.NextFunction) => {
23 logger.debug('Checking videoImportAddValidator parameters', { parameters: req.body })
24
25 const user = res.locals.oauth.token.User
26
27 if (areValidationErrors(req, res)) return cleanUpReqFiles(req)
28 if (!await isVideoChannelOfAccountExist(req.body.channelId, user, res)) return cleanUpReqFiles(req)
29
30 return next()
31 }
32])
33
34const videoImportDeleteValidator = [
35 param('id').custom(isIdValid).not().isEmpty().withMessage('Should have a valid id'),
36
299474e8 37 async (req: express.Request, res: express.Response, next: express.NextFunction) => {
fbad87b0
C
38 logger.debug('Checking videoImportDeleteValidator parameters', { parameters: req.body })
39
40 if (areValidationErrors(req, res)) return
299474e8
C
41 if (!await isVideoImportExist(req.params.id, res)) return
42
43 const user = res.locals.oauth.token.User
44 const videoImport: VideoImportModel = res.locals.videoImport
45
46 if (!await checkUserCanManageVideo(user, videoImport.Video, UserRight.UPDATE_ANY_VIDEO, res)) return
fbad87b0
C
47
48 return next()
49 }
50]
51
52// ---------------------------------------------------------------------------
53
54export {
55 videoImportAddValidator,
56 videoImportDeleteValidator
57}
58
59// ---------------------------------------------------------------------------