1
0
Fork 0
peertube/server/controllers/api/v1/remoteVideos.js

67 lines
1.7 KiB
JavaScript
Raw Normal View History

'use strict'
2015-06-09 17:41:40 +02:00
2016-03-16 22:29:27 +01:00
const express = require('express')
2016-04-26 21:56:46 +02:00
const map = require('lodash/map')
const middlewares = require('../../../middlewares')
const secureMiddleware = middlewares.secure
const reqValidator = middlewares.reqValidators.remote
const logger = require('../../../helpers/logger')
const Videos = require('../../../models/videos')
const videos = require('../../../lib/videos')
2015-06-09 17:41:40 +02:00
2016-03-16 22:29:27 +01:00
const router = express.Router()
2016-01-31 11:23:52 +01:00
router.post('/add',
reqValidator.secureRequest,
secureMiddleware.decryptBody,
reqValidator.remoteVideosAdd,
addRemoteVideos
)
2016-01-31 11:23:52 +01:00
router.post('/remove',
reqValidator.secureRequest,
secureMiddleware.decryptBody,
reqValidator.remoteVideosRemove,
removeRemoteVideo
)
2016-01-31 11:23:52 +01: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 addRemoteVideos (req, res, next) {
const videosToCreate = req.body.data
videos.createRemoteVideos(videosToCreate, function (err, remoteVideos) {
if (err) {
logger.error('Cannot create remote videos.', { error: err })
return next(err)
}
2015-06-09 17:41:40 +02:00
res.type('json').status(201).end()
})
}
2015-06-09 17:41:40 +02:00
function removeRemoteVideo (req, res, next) {
const fromUrl = req.body.signature.url
2016-03-18 16:34:50 +01:00
const magnetUris = map(req.body.data, 'magnetUri')
2016-02-04 21:10:33 +01:00
Videos.listFromUrlAndMagnets(fromUrl, magnetUris, function (err, videosList) {
if (err) {
logger.error('Cannot list videos from url and magnets.', { error: err })
return next(err)
}
2015-06-09 17:41:40 +02:00
videos.removeRemoteVideos(videosList, function (err) {
if (err) {
logger.error('Cannot remove remote videos.', { error: err })
return next(err)
}
res.type('json').status(204).end()
})
})
}