'use strict'
-const async = require('async')
+const each = require('async/each')
+const eachSeries = require('async/eachSeries')
const express = require('express')
const mongoose = require('mongoose')
const middlewares = require('../../../middlewares')
const secureMiddleware = middlewares.secure
-const reqValidator = middlewares.reqValidators.remote
+const validators = middlewares.validators.remote
const logger = require('../../../helpers/logger')
const router = express.Router()
const Video = mongoose.model('Video')
router.post('/videos',
- reqValidator.signature,
- reqValidator.dataToDecrypt,
+ validators.signature,
+ validators.dataToDecrypt,
secureMiddleware.decryptBody,
- reqValidator.remoteVideos,
+ validators.remoteVideos,
remoteVideos
)
// We need to process in the same order to keep consistency
// TODO: optimization
- async.eachSeries(requests, function (request, callbackEach) {
+ eachSeries(requests, function (request, callbackEach) {
const videoData = request.data
if (request.type === 'add') {
addRemoteVideo(videoData, callbackEach)
} else if (request.type === 'remove') {
removeRemoteVideo(videoData, fromUrl, callbackEach)
+ } else {
+ logger.error('Unkown remote request type %s.', request.type)
}
}, function (err) {
if (err) logger.error('Error managing remote videos.', { error: err })
}
function addRemoteVideo (videoToCreateData, callback) {
+ logger.debug('Adding remote video %s.', videoToCreateData.magnetUri)
+
// Mongoose pre hook will automatically create the thumbnail on disk
videoToCreateData.thumbnail = videoToCreateData.thumbnailBase64
return callback(err)
}
- async.each(videosList, function (video, callbackEach) {
+ if (videosList.length === 0) {
+ logger.error('No remote video was found for this pod.', { magnetUri: videoToRemoveData.magnetUri, podUrl: fromUrl })
+ }
+
+ each(videosList, function (video, callbackEach) {
+ logger.debug('Removing remote video %s.', video.magnetUri)
+
video.remove(callbackEach)
}, callback)
})