2021-06-02 03:41:46 -05:00
|
|
|
|
2021-06-03 09:56:42 -05:00
|
|
|
import { logger, loggerTagsFactory, LoggerTagsFn } from '@server/helpers/logger'
|
2021-06-02 03:41:46 -05:00
|
|
|
import { sequelizeTypescript } from '@server/initializers/database'
|
2023-03-16 04:36:33 -05:00
|
|
|
import { Hooks } from '@server/lib/plugins/hooks'
|
2021-06-02 03:41:46 -05:00
|
|
|
import { autoBlacklistVideoIfNeeded } from '@server/lib/video-blacklist'
|
|
|
|
import { VideoModel } from '@server/models/video/video'
|
2023-06-07 01:53:14 -05:00
|
|
|
import { MVideoFullLight, MVideoThumbnail } from '@server/types/models'
|
2021-06-02 03:41:46 -05:00
|
|
|
import { VideoObject } from '@shared/models'
|
|
|
|
import { APVideoAbstractBuilder } from './abstract-builder'
|
|
|
|
import { getVideoAttributesFromObject } from './object-to-model-attributes'
|
|
|
|
|
|
|
|
export class APVideoCreator extends APVideoAbstractBuilder {
|
2021-06-03 09:56:42 -05:00
|
|
|
protected lTags: LoggerTagsFn
|
2021-06-02 03:41:46 -05:00
|
|
|
|
2021-06-02 04:54:29 -05:00
|
|
|
constructor (protected readonly videoObject: VideoObject) {
|
2021-06-02 03:41:46 -05:00
|
|
|
super()
|
2021-06-03 09:56:42 -05:00
|
|
|
|
|
|
|
this.lTags = loggerTagsFactory('ap', 'video', 'create', this.videoObject.uuid, this.videoObject.id)
|
2021-06-02 03:41:46 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
async create (waitThumbnail = false) {
|
2021-06-03 09:56:42 -05:00
|
|
|
logger.debug('Adding remote video %s.', this.videoObject.id, this.lTags())
|
2021-06-02 03:41:46 -05:00
|
|
|
|
2021-06-02 04:54:29 -05:00
|
|
|
const channelActor = await this.getOrCreateVideoChannelFromVideoObject()
|
|
|
|
const channel = channelActor.VideoChannel
|
|
|
|
|
2021-06-15 01:36:39 -05:00
|
|
|
const videoData = getVideoAttributesFromObject(channel, this.videoObject, this.videoObject.to)
|
2022-06-08 08:42:09 -05:00
|
|
|
const video = VideoModel.build({ ...videoData, likes: 0, dislikes: 0 }) as MVideoThumbnail
|
2021-06-02 03:41:46 -05:00
|
|
|
|
|
|
|
const { autoBlacklisted, videoCreated } = await sequelizeTypescript.transaction(async t => {
|
2023-06-07 01:53:14 -05:00
|
|
|
const videoCreated = await video.save({ transaction: t }) as MVideoFullLight
|
|
|
|
videoCreated.VideoChannel = channel
|
|
|
|
|
|
|
|
await this.setThumbnail(videoCreated, t)
|
|
|
|
await this.setPreview(videoCreated, t)
|
2023-07-11 02:21:13 -05:00
|
|
|
await this.setWebVideoFiles(videoCreated, t)
|
2023-06-07 01:53:14 -05:00
|
|
|
await this.setStreamingPlaylists(videoCreated, t)
|
|
|
|
await this.setTags(videoCreated, t)
|
|
|
|
await this.setTrackers(videoCreated, t)
|
|
|
|
await this.insertOrReplaceCaptions(videoCreated, t)
|
|
|
|
await this.insertOrReplaceLive(videoCreated, t)
|
|
|
|
await this.insertOrReplaceStoryboard(videoCreated, t)
|
|
|
|
|
|
|
|
// We added a video in this channel, set it as updated
|
|
|
|
await channel.setAsUpdated(t)
|
|
|
|
|
|
|
|
const autoBlacklisted = await autoBlacklistVideoIfNeeded({
|
|
|
|
video: videoCreated,
|
|
|
|
user: undefined,
|
|
|
|
isRemote: true,
|
|
|
|
isNew: true,
|
2023-07-19 09:02:49 -05:00
|
|
|
isNewFile: true,
|
2023-06-07 01:53:14 -05:00
|
|
|
transaction: t
|
|
|
|
})
|
2021-06-02 03:41:46 -05:00
|
|
|
|
2023-06-07 01:53:14 -05:00
|
|
|
logger.info('Remote video with uuid %s inserted.', this.videoObject.uuid, this.lTags())
|
2023-03-16 04:36:33 -05:00
|
|
|
|
2023-06-07 01:53:14 -05:00
|
|
|
Hooks.runAction('action:activity-pub.remote-video.created', { video: videoCreated, videoAPObject: this.videoObject })
|
2021-06-02 03:41:46 -05:00
|
|
|
|
2023-06-07 01:53:14 -05:00
|
|
|
return { autoBlacklisted, videoCreated }
|
2021-06-02 03:41:46 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
return { autoBlacklisted, videoCreated }
|
|
|
|
}
|
|
|
|
}
|