1
0
Fork 0
peertube/server/middlewares/validators/videos.js

97 lines
3.3 KiB
JavaScript
Raw Normal View History

'use strict'
2015-11-07 08:16:26 -05:00
2016-03-16 17:29:27 -04:00
const checkErrors = require('./utils').checkErrors
2016-05-16 13:49:10 -04:00
const constants = require('../../initializers/constants')
2016-07-31 14:58:43 -04:00
const customVideosValidators = require('../../helpers/custom-validators').videos
2016-12-11 15:50:51 -05:00
const db = require('../../initializers/database')
2016-03-16 17:29:27 -04:00
const logger = require('../../helpers/logger')
2016-07-01 10:16:40 -04:00
const validatorsVideos = {
videosAdd,
videosGet,
videosRemove,
videosSearch
}
2015-11-07 08:16:26 -05:00
function videosAdd (req, res, next) {
2016-03-18 11:34:50 -04:00
req.checkFiles('videofile[0].originalname', 'Should have an input video').notEmpty()
// TODO: move to constants and function
2016-03-18 11:34:50 -04:00
req.checkFiles('videofile[0].mimetype', 'Should have a correct mime type').matches(/video\/(webm)|(mp4)|(ogg)/i)
2016-06-06 08:15:03 -04:00
req.checkBody('name', 'Should have a valid name').isVideoNameValid()
req.checkBody('description', 'Should have a valid description').isVideoDescriptionValid()
req.checkBody('tags', 'Should have correct tags').isVideoTagsValid()
2015-11-07 08:16:26 -05:00
logger.debug('Checking videosAdd parameters', { parameters: req.body, files: req.files })
2015-11-07 08:16:26 -05:00
2016-05-16 13:49:10 -04:00
checkErrors(req, res, function () {
const videoFile = req.files.videofile[0]
2016-12-11 15:50:51 -05:00
db.Video.getDurationFromFile(videoFile.path, function (err, duration) {
2016-05-16 13:49:10 -04:00
if (err) {
return res.status(400).send('Cannot retrieve metadata of the file.')
}
2016-07-31 14:58:43 -04:00
if (!customVideosValidators.isVideoDurationValid(duration)) {
return res.status(400).send('Duration of the video file is too big (max: ' + constants.CONSTRAINTS_FIELDS.VIDEOS.DURATION.max + 's).')
2016-05-16 13:49:10 -04:00
}
videoFile.duration = duration
next()
})
})
}
2015-11-07 08:16:26 -05:00
function videosGet (req, res, next) {
2016-12-11 15:50:51 -05:00
req.checkParams('id', 'Should have a valid id').notEmpty().isUUID(4)
2015-11-07 08:16:26 -05:00
logger.debug('Checking videosGet parameters', { parameters: req.params })
2015-11-07 08:16:26 -05:00
checkErrors(req, res, function () {
2016-12-11 15:50:51 -05:00
db.Video.load(req.params.id, function (err, video) {
if (err) {
logger.error('Error in videosGet request validator.', { error: err })
2016-06-06 08:15:03 -04:00
return res.sendStatus(500)
}
2016-02-04 15:10:33 -05:00
if (!video) return res.status(404).send('Video not found')
2015-11-07 08:16:26 -05:00
2016-03-18 11:28:09 -04:00
next()
2015-11-07 08:16:26 -05:00
})
})
}
2015-11-07 08:16:26 -05:00
function videosRemove (req, res, next) {
2016-12-11 15:50:51 -05:00
req.checkParams('id', 'Should have a valid id').notEmpty().isUUID(4)
2015-11-07 08:16:26 -05:00
logger.debug('Checking videosRemove parameters', { parameters: req.params })
2015-11-07 08:16:26 -05:00
checkErrors(req, res, function () {
2016-12-11 15:50:51 -05:00
db.Video.loadAndPopulateAuthor(req.params.id, function (err, video) {
if (err) {
logger.error('Error in videosRemove request validator.', { error: err })
2016-06-06 08:15:03 -04:00
return res.sendStatus(500)
}
2016-02-04 15:10:33 -05:00
if (!video) return res.status(404).send('Video not found')
else if (video.isOwned() === false) return res.status(403).send('Cannot remove video of another pod')
2016-12-11 15:50:51 -05:00
else if (video.Author.name !== res.locals.oauth.token.user.username) return res.status(403).send('Cannot remove video of another user')
2015-11-07 08:16:26 -05:00
2016-03-18 11:28:09 -04:00
next()
2015-11-07 08:16:26 -05:00
})
})
}
2015-11-07 08:16:26 -05:00
function videosSearch (req, res, next) {
const searchableColumns = constants.SEARCHABLE_COLUMNS.VIDEOS
2016-06-06 08:15:03 -04:00
req.checkParams('value', 'Should have a valid search').notEmpty()
req.checkQuery('field', 'Should have correct searchable column').optional().isIn(searchableColumns)
2016-01-31 05:23:52 -05:00
logger.debug('Checking videosSearch parameters', { parameters: req.params })
2016-01-31 05:23:52 -05:00
checkErrors(req, res, next)
}
2016-01-31 05:23:52 -05:00
// ---------------------------------------------------------------------------
2016-01-31 05:23:52 -05:00
2016-07-01 10:16:40 -04:00
module.exports = validatorsVideos