- return retryTransactionWrapper(updateRemoteVideo, options)
-}
-
-async function updateRemoteVideo (actor: ActorModel, activity: ActivityUpdate) {
- const videoAttributesToUpdate = activity.object as VideoTorrentObject
-
- const res = await getOrCreateAccountAndVideoAndChannel(videoAttributesToUpdate.id)
-
- // Fetch video channel outside the transaction
- const newVideoChannelActor = await getOrCreateVideoChannel(videoAttributesToUpdate)
- const newVideoChannel = newVideoChannelActor.VideoChannel
-
- logger.debug('Updating remote video "%s".', videoAttributesToUpdate.uuid)
- let videoInstance = res.video
- let videoFieldsSave: any
-
- try {
- await sequelizeTypescript.transaction(async t => {
- const sequelizeOptions = {
- transaction: t
- }
-
- videoFieldsSave = videoInstance.toJSON()
-
- // Check actor has the right to update the video
- const videoChannel = videoInstance.VideoChannel
- if (videoChannel.Account.Actor.id !== actor.id) {
- throw new Error('Account ' + actor.url + ' does not own video channel ' + videoChannel.Actor.url)
- }
-
- const videoData = await videoActivityObjectToDBAttributes(newVideoChannel, videoAttributesToUpdate, activity.to)
- videoInstance.set('name', videoData.name)
- videoInstance.set('uuid', videoData.uuid)
- videoInstance.set('url', videoData.url)
- videoInstance.set('category', videoData.category)
- videoInstance.set('licence', videoData.licence)
- videoInstance.set('language', videoData.language)
- videoInstance.set('description', videoData.description)
- videoInstance.set('support', videoData.support)
- videoInstance.set('nsfw', videoData.nsfw)
- videoInstance.set('commentsEnabled', videoData.commentsEnabled)
- videoInstance.set('duration', videoData.duration)
- videoInstance.set('createdAt', videoData.createdAt)
- videoInstance.set('updatedAt', videoData.updatedAt)
- videoInstance.set('views', videoData.views)
- videoInstance.set('privacy', videoData.privacy)
- videoInstance.set('channelId', videoData.channelId)
-
- await videoInstance.save(sequelizeOptions)
-
- // Don't block on request
- generateThumbnailFromUrl(videoInstance, videoAttributesToUpdate.icon)
- .catch(err => logger.warn('Cannot generate thumbnail of %s.', videoAttributesToUpdate.id, { err }))
-
- // Remove old video files
- const videoFileDestroyTasks: Bluebird<void>[] = []
- for (const videoFile of videoInstance.VideoFiles) {
- videoFileDestroyTasks.push(videoFile.destroy(sequelizeOptions))
- }
- await Promise.all(videoFileDestroyTasks)
-
- const videoFileAttributes = videoFileActivityUrlToDBAttributes(videoInstance, videoAttributesToUpdate)
- const tasks = videoFileAttributes.map(f => VideoFileModel.create(f))
- await Promise.all(tasks)
-
- const tags = videoAttributesToUpdate.tag.map(t => t.name)
- const tagInstances = await TagModel.findOrCreateTags(tags, t)
- await videoInstance.$set('Tags', tagInstances, sequelizeOptions)
- })
-
- logger.info('Remote video with uuid %s updated', videoAttributesToUpdate.uuid)
- } catch (err) {
- if (videoInstance !== undefined && videoFieldsSave !== undefined) {
- resetSequelizeInstance(videoInstance, videoFieldsSave)
- }
-
- // This is just a debug because we will retry the insert
- logger.debug('Cannot update the remote video.', { err })
- throw err