2018-06-14 18:06:56 +02:00
|
|
|
import { logger } from '../../helpers/logger'
|
|
|
|
import { AbstractScheduler } from './abstract-scheduler'
|
|
|
|
import { ScheduleVideoUpdateModel } from '../../models/video/schedule-video-update'
|
|
|
|
import { retryTransactionWrapper } from '../../helpers/database-utils'
|
2020-04-23 09:32:53 +02:00
|
|
|
import { federateVideoIfNeeded } from '../activitypub/videos'
|
2019-04-11 14:26:41 +02:00
|
|
|
import { SCHEDULER_INTERVALS_MS } from '../../initializers/constants'
|
2018-12-26 10:36:24 +01:00
|
|
|
import { Notifier } from '../notifier'
|
2019-04-11 14:26:41 +02:00
|
|
|
import { sequelizeTypescript } from '../../initializers/database'
|
2019-11-15 15:06:03 +01:00
|
|
|
import { MVideoFullLight } from '@server/typings/models'
|
2018-06-14 18:06:56 +02:00
|
|
|
|
|
|
|
export class UpdateVideosScheduler extends AbstractScheduler {
|
|
|
|
|
|
|
|
private static instance: AbstractScheduler
|
|
|
|
|
|
|
|
protected schedulerIntervalMs = SCHEDULER_INTERVALS_MS.updateVideos
|
|
|
|
|
|
|
|
private constructor () {
|
|
|
|
super()
|
|
|
|
}
|
|
|
|
|
2018-12-20 14:31:11 +01:00
|
|
|
protected async internalExecute () {
|
|
|
|
return retryTransactionWrapper(this.updateVideos.bind(this))
|
2018-06-14 18:06:56 +02:00
|
|
|
}
|
|
|
|
|
2018-06-15 16:52:15 +02:00
|
|
|
private async updateVideos () {
|
|
|
|
if (!await ScheduleVideoUpdateModel.areVideosToUpdate()) return undefined
|
|
|
|
|
2019-01-02 16:37:43 +01:00
|
|
|
const publishedVideos = await sequelizeTypescript.transaction(async t => {
|
2018-06-14 18:06:56 +02:00
|
|
|
const schedules = await ScheduleVideoUpdateModel.listVideosToUpdate(t)
|
2019-11-15 15:06:03 +01:00
|
|
|
const publishedVideos: MVideoFullLight[] = []
|
2018-06-14 18:06:56 +02:00
|
|
|
|
|
|
|
for (const schedule of schedules) {
|
|
|
|
const video = schedule.Video
|
|
|
|
logger.info('Executing scheduled video update on %s.', video.uuid)
|
|
|
|
|
|
|
|
if (schedule.privacy) {
|
2019-12-12 15:47:47 +01:00
|
|
|
const wasConfidentialVideo = video.isConfidential()
|
|
|
|
const isNewVideo = video.isNewVideo(schedule.privacy)
|
2018-06-14 18:06:56 +02:00
|
|
|
|
2019-12-12 15:47:47 +01:00
|
|
|
video.setPrivacy(schedule.privacy)
|
2018-07-24 15:11:28 +02:00
|
|
|
await video.save({ transaction: t })
|
2018-06-14 18:06:56 +02:00
|
|
|
await federateVideoIfNeeded(video, isNewVideo, t)
|
2018-12-26 10:36:24 +01:00
|
|
|
|
2019-12-12 15:47:47 +01:00
|
|
|
if (wasConfidentialVideo) {
|
2019-11-15 15:06:03 +01:00
|
|
|
const videoToPublish: MVideoFullLight = Object.assign(video, { ScheduleVideoUpdate: schedule, UserVideoHistories: [] })
|
|
|
|
publishedVideos.push(videoToPublish)
|
2018-12-26 10:36:24 +01:00
|
|
|
}
|
2018-06-14 18:06:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
await schedule.destroy({ transaction: t })
|
|
|
|
}
|
2019-01-02 16:37:43 +01:00
|
|
|
|
|
|
|
return publishedVideos
|
2018-06-14 18:06:56 +02:00
|
|
|
})
|
2019-01-02 16:37:43 +01:00
|
|
|
|
|
|
|
for (const v of publishedVideos) {
|
2019-07-23 12:04:15 +02:00
|
|
|
Notifier.Instance.notifyOnNewVideoIfNeeded(v)
|
2019-04-02 11:26:47 +02:00
|
|
|
Notifier.Instance.notifyOnVideoPublishedAfterScheduledUpdate(v)
|
2019-01-02 16:37:43 +01:00
|
|
|
}
|
2018-06-14 18:06:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static get Instance () {
|
|
|
|
return this.instance || (this.instance = new this())
|
|
|
|
}
|
|
|
|
}
|