PeerTube/server/middlewares/reqValidators/videos.js

94 lines
2.9 KiB
JavaScript
Raw Normal View History

'use strict'
2015-11-07 14:16:26 +01:00
2016-03-16 22:29:27 +01:00
const checkErrors = require('./utils').checkErrors
2016-05-16 19:49:10 +02:00
const constants = require('../../initializers/constants')
2016-03-16 22:29:27 +01:00
const logger = require('../../helpers/logger')
const videos = require('../../lib/videos')
const Videos = require('../../models/videos')
2015-11-07 14:16:26 +01:00
2016-03-16 22:29:27 +01:00
const reqValidatorsVideos = {
videosAdd: videosAdd,
videosGet: videosGet,
videosRemove: videosRemove,
videosSearch: videosSearch
}
2015-11-07 14:16:26 +01:00
function videosAdd (req, res, next) {
2016-03-18 16:34:50 +01:00
req.checkFiles('videofile[0].originalname', 'Should have an input video').notEmpty()
req.checkFiles('videofile[0].mimetype', 'Should have a correct mime type').matches(/video\/(webm)|(mp4)|(ogg)/i)
req.checkBody('name', 'Should have a name').isLength(1, 50)
req.checkBody('description', 'Should have a description').isLength(1, 250)
2015-11-07 14:16:26 +01:00
logger.debug('Checking videosAdd parameters', { parameters: req.body, files: req.files })
2015-11-07 14:16:26 +01:00
2016-05-16 19:49:10 +02:00
checkErrors(req, res, function () {
const videoFile = req.files.videofile[0]
videos.getVideoDuration(videoFile.path, function (err, duration) {
if (err) {
return res.status(400).send('Cannot retrieve metadata of the file.')
}
if (duration > constants.MAXIMUM_VIDEO_DURATION) {
return res.status(400).send('Duration of the video file is too big.')
}
videoFile.duration = duration
next()
})
})
}
2015-11-07 14:16:26 +01:00
function videosGet (req, res, next) {
req.checkParams('id', 'Should have a valid id').notEmpty().isMongoId()
2015-11-07 14:16:26 +01:00
logger.debug('Checking videosGet parameters', { parameters: req.params })
2015-11-07 14:16:26 +01:00
checkErrors(req, res, function () {
Videos.get(req.params.id, function (err, video) {
if (err) {
logger.error('Error in videosGet request validator.', { error: err })
res.sendStatus(500)
}
2016-02-04 21:10:33 +01:00
2016-03-18 16:28:09 +01:00
const state = videos.getVideoState(video)
if (state.exist === false) return res.status(404).send('Video not found')
2015-11-07 14:16:26 +01:00
2016-03-18 16:28:09 +01:00
next()
2015-11-07 14:16:26 +01:00
})
})
}
2015-11-07 14:16:26 +01:00
function videosRemove (req, res, next) {
req.checkParams('id', 'Should have a valid id').notEmpty().isMongoId()
2015-11-07 14:16:26 +01:00
logger.debug('Checking videosRemove parameters', { parameters: req.params })
2015-11-07 14:16:26 +01:00
checkErrors(req, res, function () {
Videos.get(req.params.id, function (err, video) {
if (err) {
logger.error('Error in videosRemove request validator.', { error: err })
res.sendStatus(500)
}
2016-02-04 21:10:33 +01:00
2016-03-18 16:28:09 +01:00
const state = videos.getVideoState(video)
if (state.exist === false) return res.status(404).send('Video not found')
else if (state.owned === false) return res.status(403).send('Cannot remove video of another pod')
2015-11-07 14:16:26 +01:00
2016-03-18 16:28:09 +01:00
next()
2015-11-07 14:16:26 +01:00
})
})
}
2015-11-07 14:16:26 +01:00
function videosSearch (req, res, next) {
req.checkParams('name', 'Should have a name').notEmpty()
2016-01-31 11:23:52 +01:00
logger.debug('Checking videosSearch parameters', { parameters: req.params })
2016-01-31 11:23:52 +01:00
checkErrors(req, res, next)
}
2016-01-31 11:23:52 +01:00
// ---------------------------------------------------------------------------
2016-01-31 11:23:52 +01:00
module.exports = reqValidatorsVideos