import { AbstractScheduler } from './abstract-scheduler'
import { ScheduleVideoUpdateModel } from '../../models/video/schedule-video-update'
import { retryTransactionWrapper } from '../../helpers/database-utils'
-import { federateVideoIfNeeded } from '../activitypub'
-import { SCHEDULER_INTERVALS_MS, sequelizeTypescript } from '../../initializers'
-import { VideoPrivacy } from '../../../shared/models/videos'
+import { federateVideoIfNeeded } from '../activitypub/videos'
+import { SCHEDULER_INTERVALS_MS } from '../../initializers/constants'
import { Notifier } from '../notifier'
-import { VideoModel } from '../../models/video/video'
+import { sequelizeTypescript } from '../../initializers/database'
+import { MVideoFullLight } from '@server/types/models'
export class UpdateVideosScheduler extends AbstractScheduler {
const publishedVideos = await sequelizeTypescript.transaction(async t => {
const schedules = await ScheduleVideoUpdateModel.listVideosToUpdate(t)
- const publishedVideos: VideoModel[] = []
+ const publishedVideos: MVideoFullLight[] = []
for (const schedule of schedules) {
const video = schedule.Video
logger.info('Executing scheduled video update on %s.', video.uuid)
if (schedule.privacy) {
- const oldPrivacy = video.privacy
- const isNewVideo = oldPrivacy === VideoPrivacy.PRIVATE
-
- video.privacy = schedule.privacy
- if (isNewVideo === true) video.publishedAt = new Date()
+ const wasConfidentialVideo = video.isConfidential()
+ const isNewVideo = video.isNewVideo(schedule.privacy)
+ video.setPrivacy(schedule.privacy)
await video.save({ transaction: t })
await federateVideoIfNeeded(video, isNewVideo, t)
- if (oldPrivacy === VideoPrivacy.UNLISTED || oldPrivacy === VideoPrivacy.PRIVATE) {
- video.ScheduleVideoUpdate = schedule
- publishedVideos.push(video)
+ if (wasConfidentialVideo) {
+ const videoToPublish: MVideoFullLight = Object.assign(video, { ScheduleVideoUpdate: schedule, UserVideoHistories: [] })
+ publishedVideos.push(videoToPublish)
}
}
})
for (const v of publishedVideos) {
- Notifier.Instance.notifyOnNewVideo(v)
- Notifier.Instance.notifyOnPendingVideoPublished(v)
+ Notifier.Instance.notifyOnNewVideoIfNeeded(v)
+ Notifier.Instance.notifyOnVideoPublishedAfterScheduledUpdate(v)
}
}