PeerTube/server/controllers/api/v1/videos.js

169 lines
4.7 KiB
JavaScript
Raw Normal View History

'use strict'
2016-03-16 22:29:27 +01:00
const config = require('config')
const crypto = require('crypto')
const express = require('express')
const multer = require('multer')
const logger = require('../../../helpers/logger')
const friends = require('../../../lib/friends')
const middleware = require('../../../middlewares')
const cacheMiddleware = middleware.cache
const reqValidator = middleware.reqValidators.videos
const Videos = require('../../../models/videos') // model
const videos = require('../../../lib/videos')
const webtorrent = require('../../../lib/webtorrent')
const router = express.Router()
const uploads = config.get('storage.uploads')
// multer configuration
2016-03-16 22:29:27 +01:00
const storage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, uploads)
},
filename: function (req, file, cb) {
2016-03-16 22:29:27 +01:00
let extension = ''
if (file.mimetype === 'video/webm') extension = 'webm'
else if (file.mimetype === 'video/mp4') extension = 'mp4'
else if (file.mimetype === 'video/ogg') extension = 'ogv'
crypto.pseudoRandomBytes(16, function (err, raw) {
2016-03-16 22:29:27 +01:00
const fieldname = err ? undefined : raw.toString('hex')
cb(null, fieldname + '.' + extension)
})
}
})
2016-03-16 22:29:27 +01:00
const reqFiles = multer({ storage: storage }).fields([{ name: 'input_video', maxCount: 1 }])
2015-06-09 17:41:40 +02:00
router.get('/', cacheMiddleware.cache(false), listVideos)
router.post('/', reqFiles, reqValidator.videosAdd, cacheMiddleware.cache(false), addVideo)
router.get('/:id', reqValidator.videosGet, cacheMiddleware.cache(false), getVideos)
router.delete('/:id', reqValidator.videosRemove, cacheMiddleware.cache(false), removeVideo)
router.get('/search/:name', reqValidator.videosSearch, cacheMiddleware.cache(false), searchVideos)
2015-06-09 17:41:40 +02:00
// ---------------------------------------------------------------------------
2016-01-31 11:23:52 +01:00
module.exports = router
2016-01-31 11:23:52 +01:00
// ---------------------------------------------------------------------------
2016-01-31 11:23:52 +01:00
function addVideo (req, res, next) {
2016-03-16 22:29:27 +01:00
const video_file = req.files.input_video[0]
const video_infos = req.body
videos.seed(video_file.path, function (err, torrent) {
if (err) {
logger.error('Cannot seed this video.')
return next(err)
}
2015-06-09 17:41:40 +02:00
2016-03-16 22:29:27 +01:00
const video_data = {
name: video_infos.name,
namePath: video_file.filename,
description: video_infos.description,
magnetUri: torrent.magnetURI
}
2016-02-04 21:10:33 +01:00
Videos.add(video_data, function (err) {
2016-02-04 21:10:33 +01:00
if (err) {
// TODO unseed the video
logger.error('Cannot insert this video in the database.')
2016-02-04 21:10:33 +01:00
return next(err)
}
// Now we'll add the video's meta data to our friends
friends.addVideoToFriends(video_data)
2016-02-04 21:10:33 +01:00
2016-03-14 22:16:43 +01:00
// TODO : include Location of the new video -> 201
res.type('json').status(204).end()
2015-06-09 17:41:40 +02:00
})
})
}
2015-06-09 17:41:40 +02:00
function getVideos (req, res, next) {
2016-03-18 16:28:09 +01:00
Videos.get(req.params.id, function (err, video_obj) {
if (err) return next(err)
2015-06-09 17:41:40 +02:00
2016-03-18 16:28:09 +01:00
const state = videos.getVideoState(video_obj)
if (state.exist === false) {
return res.type('json').status(204).end()
}
2015-06-09 17:41:40 +02:00
2016-03-18 16:28:09 +01:00
res.json(getFormatedVideo(video_obj))
})
}
2015-06-09 17:41:40 +02:00
function listVideos (req, res, next) {
Videos.list(function (err, videos_list) {
if (err) return next(err)
2016-01-31 11:23:52 +01:00
2016-03-18 16:28:09 +01:00
res.json(getFormatedVideos(videos_list))
})
}
2016-01-31 11:23:52 +01:00
function removeVideo (req, res, next) {
2016-03-16 22:29:27 +01:00
const video_id = req.params.id
Videos.get(video_id, function (err, video) {
if (err) return next(err)
2015-06-09 17:41:40 +02:00
removeTorrent(video.magnetUri, function () {
Videos.removeOwned(req.params.id, function (err) {
if (err) return next(err)
2016-02-04 21:10:33 +01:00
2016-03-16 22:29:27 +01:00
const params = {
name: video.name,
magnetUri: video.magnetUri
}
2016-02-04 21:10:33 +01:00
friends.removeVideoToFriends(params)
2016-03-14 13:50:19 +01:00
res.type('json').status(204).end()
2016-02-04 21:10:33 +01:00
})
2015-06-09 17:41:40 +02:00
})
})
}
2015-06-09 17:41:40 +02:00
function searchVideos (req, res, next) {
Videos.search(req.params.name, function (err, videos_list) {
if (err) return next(err)
2015-06-09 17:41:40 +02:00
2016-03-18 16:28:09 +01:00
res.json(getFormatedVideos(videos_list))
})
}
2016-02-04 21:10:33 +01:00
// ---------------------------------------------------------------------------
2016-02-04 21:10:33 +01:00
2016-03-18 16:28:09 +01:00
function getFormatedVideo (video_obj) {
const formated_video = {
id: video_obj._id,
name: video_obj.name,
description: video_obj.description,
podUrl: video_obj.podUrl,
isLocal: videos.getVideoState(video_obj).owned,
magnetUri: video_obj.magnetUri
}
return formated_video
}
function getFormatedVideos (videos_obj) {
const formated_videos = []
videos_obj.forEach(function (video_obj) {
formated_videos.push(getFormatedVideo(video_obj))
})
return formated_videos
}
// Maybe the torrent is not seeded, but we catch the error to don't stop the removing process
function removeTorrent (magnetUri, callback) {
try {
webtorrent.remove(magnetUri, callback)
} catch (err) {
logger.warn('Cannot remove the torrent from WebTorrent', { err: err })
return callback(null)
2016-02-04 21:10:33 +01:00
}
}