123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- import * as Bull from 'bull'
- import { logger } from '../../../helpers/logger'
- import { fetchVideoByUrl } from '../../../helpers/video'
- import { refreshActorIfNeeded } from '../../activitypub/actor'
- import { refreshVideoIfNeeded } from '../../activitypub/videos'
- import { ActorModel } from '../../../models/activitypub/actor'
- import { VideoPlaylistModel } from '../../../models/video/video-playlist'
- import { RefreshPayload } from '@shared/models'
- import { refreshVideoPlaylistIfNeeded } from '@server/lib/activitypub/playlist'
- async function refreshAPObject (job: Bull.Job) {
- const payload = job.data as RefreshPayload
- logger.info('Processing AP refresher in job %d for %s.', job.id, payload.url)
- if (payload.type === 'video') return refreshVideo(payload.url)
- if (payload.type === 'video-playlist') return refreshVideoPlaylist(payload.url)
- if (payload.type === 'actor') return refreshActor(payload.url)
- }
- // ---------------------------------------------------------------------------
- export {
- refreshAPObject
- }
- // ---------------------------------------------------------------------------
- async function refreshVideo (videoUrl: string) {
- const fetchType = 'all' as 'all'
- const syncParam = { likes: true, dislikes: true, shares: true, comments: true, thumbnail: true }
- const videoFromDatabase = await fetchVideoByUrl(videoUrl, fetchType)
- if (videoFromDatabase) {
- const refreshOptions = {
- video: videoFromDatabase,
- fetchedType: fetchType,
- syncParam
- }
- await refreshVideoIfNeeded(refreshOptions)
- }
- }
- async function refreshActor (actorUrl: string) {
- const fetchType = 'all' as 'all'
- const actor = await ActorModel.loadByUrlAndPopulateAccountAndChannel(actorUrl)
- if (actor) {
- await refreshActorIfNeeded(actor, fetchType)
- }
- }
- async function refreshVideoPlaylist (playlistUrl: string) {
- const playlist = await VideoPlaylistModel.loadByUrlAndPopulateAccount(playlistUrl)
- if (playlist) {
- await refreshVideoPlaylistIfNeeded(playlist)
- }
- }
|