From 3545e72c686ff1725bbdfd8d16d693e2f4aa75a3 Mon Sep 17 00:00:00 2001 From: Chocobozzz Date: Wed, 12 Oct 2022 16:09:02 +0200 Subject: Put private videos under a specific subdirectory --- server/lib/schedulers/update-videos-scheduler.ts | 66 ++++++++++++++++-------- 1 file changed, 44 insertions(+), 22 deletions(-) (limited to 'server/lib/schedulers/update-videos-scheduler.ts') diff --git a/server/lib/schedulers/update-videos-scheduler.ts b/server/lib/schedulers/update-videos-scheduler.ts index 5bfbc3cd2..30bf189db 100644 --- a/server/lib/schedulers/update-videos-scheduler.ts +++ b/server/lib/schedulers/update-videos-scheduler.ts @@ -1,11 +1,14 @@ import { VideoModel } from '@server/models/video/video' -import { MVideoFullLight } from '@server/types/models' +import { MScheduleVideoUpdate } from '@server/types/models' +import { VideoPrivacy, VideoState } from '@shared/models' import { logger } from '../../helpers/logger' import { SCHEDULER_INTERVALS_MS } from '../../initializers/constants' import { sequelizeTypescript } from '../../initializers/database' import { ScheduleVideoUpdateModel } from '../../models/video/schedule-video-update' -import { federateVideoIfNeeded } from '../activitypub/videos' import { Notifier } from '../notifier' +import { addVideoJobsAfterUpdate } from '../video' +import { VideoPathManager } from '../video-path-manager' +import { setVideoPrivacy } from '../video-privacy' import { AbstractScheduler } from './abstract-scheduler' export class UpdateVideosScheduler extends AbstractScheduler { @@ -26,35 +29,54 @@ export class UpdateVideosScheduler extends AbstractScheduler { if (!await ScheduleVideoUpdateModel.areVideosToUpdate()) return undefined const schedules = await ScheduleVideoUpdateModel.listVideosToUpdate() - const publishedVideos: MVideoFullLight[] = [] for (const schedule of schedules) { - await sequelizeTypescript.transaction(async t => { - const video = await VideoModel.loadFull(schedule.videoId, t) + const videoOnly = await VideoModel.load(schedule.videoId) + const mutexReleaser = await VideoPathManager.Instance.lockFiles(videoOnly.uuid) - logger.info('Executing scheduled video update on %s.', video.uuid) + try { + const { video, published } = await this.updateAVideo(schedule) - if (schedule.privacy) { - const wasConfidentialVideo = video.isConfidential() - const isNewVideo = video.isNewVideo(schedule.privacy) + if (published) Notifier.Instance.notifyOnVideoPublishedAfterScheduledUpdate(video) + } catch (err) { + logger.error('Cannot update video', { err }) + } - video.setPrivacy(schedule.privacy) - await video.save({ transaction: t }) - await federateVideoIfNeeded(video, isNewVideo, t) + mutexReleaser() + } + } + + private async updateAVideo (schedule: MScheduleVideoUpdate) { + let oldPrivacy: VideoPrivacy + let isNewVideo: boolean + let published = false + + const video = await sequelizeTypescript.transaction(async t => { + const video = await VideoModel.loadFull(schedule.videoId, t) + if (video.state === VideoState.TO_TRANSCODE) return + + logger.info('Executing scheduled video update on %s.', video.uuid) + + if (schedule.privacy) { + isNewVideo = video.isNewVideo(schedule.privacy) + oldPrivacy = video.privacy - if (wasConfidentialVideo) { - publishedVideos.push(video) - } + setVideoPrivacy(video, schedule.privacy) + await video.save({ transaction: t }) + + if (oldPrivacy === VideoPrivacy.PRIVATE) { + published = true } + } - await schedule.destroy({ transaction: t }) - }) - } + await schedule.destroy({ transaction: t }) - for (const v of publishedVideos) { - Notifier.Instance.notifyOnNewVideoIfNeeded(v) - Notifier.Instance.notifyOnVideoPublishedAfterScheduledUpdate(v) - } + return video + }) + + await addVideoJobsAfterUpdate({ video, oldPrivacy, isNewVideo, nameChanged: false }) + + return { video, published } } static get Instance () { -- cgit v1.2.3