X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Flib%2Factivitypub%2Fsend%2Fsend-update.ts;h=5bf092894eba54a65b5d6548712f018f511b444b;hb=2284f202070aa2e49156cc52b3b1596a7d5aadec;hp=6f1d8089886511c1df7c3b645eb050d56cfb25d4;hpb=5cf84858d49f4231cc4efec5e3132f17f65f6cf6;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/lib/activitypub/send/send-update.ts b/server/lib/activitypub/send/send-update.ts index 6f1d80898..5bf092894 100644 --- a/server/lib/activitypub/send/send-update.ts +++ b/server/lib/activitypub/send/send-update.ts @@ -7,13 +7,18 @@ import { VideoModel } from '../../../models/video/video' import { VideoChannelModel } from '../../../models/video/video-channel' import { VideoShareModel } from '../../../models/video/video-share' import { getUpdateActivityPubUrl } from '../url' -import { broadcastToFollowers } from './utils' -import { audiencify, getAudience } from '../audience' +import { broadcastToFollowers, sendVideoRelatedActivity } from './utils' +import { audiencify, getActorsInvolvedInVideo, getAudience } from '../audience' import { logger } from '../../../helpers/logger' -import { videoFeedsValidator } from '../../../middlewares/validators' import { VideoCaptionModel } from '../../../models/video/video-caption' +import { VideoRedundancyModel } from '../../../models/redundancy/video-redundancy' +import { VideoPlaylistModel } from '../../../models/video/video-playlist' +import { VideoPlaylistPrivacy } from '../../../../shared/models/videos/playlist/video-playlist-privacy.model' +import { getServerActor } from '../../../helpers/utils' async function sendUpdateVideo (video: VideoModel, t: Transaction, overrodeByActor?: ActorModel) { + if (video.privacy === VideoPrivacy.PRIVATE) return undefined + logger.info('Creating job to update video %s.', video.url) const byActor = overrodeByActor ? overrodeByActor : video.VideoChannel.Account.Actor @@ -21,17 +26,19 @@ async function sendUpdateVideo (video: VideoModel, t: Transaction, overrodeByAct const url = getUpdateActivityPubUrl(video.url, video.updatedAt.toISOString()) // Needed to build the AP object - if (!video.VideoCaptions) video.VideoCaptions = await video.$get('VideoCaptions') as VideoCaptionModel[] + if (!video.VideoCaptions) { + video.VideoCaptions = await video.$get('VideoCaptions', { transaction: t }) as VideoCaptionModel[] + } const videoObject = video.toActivityPubObject() const audience = getAudience(byActor, video.privacy === VideoPrivacy.PUBLIC) - const data = updateActivityData(url, byActor, videoObject, audience) + const updateActivity = buildUpdateActivity(url, byActor, videoObject, audience) - const actorsInvolved = await VideoShareModel.loadActorsByShare(video.id, t) - actorsInvolved.push(byActor) + const actorsInvolved = await getActorsInvolvedInVideo(video, t) + if (overrodeByActor) actorsInvolved.push(overrodeByActor) - return broadcastToFollowers(data, byActor, actorsInvolved, t) + return broadcastToFollowers(updateActivity, byActor, actorsInvolved, t) } async function sendUpdateActor (accountOrChannel: AccountModel | VideoChannelModel, t: Transaction) { @@ -42,12 +49,12 @@ async function sendUpdateActor (accountOrChannel: AccountModel | VideoChannelMod const url = getUpdateActivityPubUrl(byActor.url, byActor.updatedAt.toISOString()) const accountOrChannelObject = accountOrChannel.toActivityPubObject() const audience = getAudience(byActor) - const data = updateActivityData(url, byActor, accountOrChannelObject, audience) + const updateActivity = buildUpdateActivity(url, byActor, accountOrChannelObject, audience) let actorsInvolved: ActorModel[] if (accountOrChannel instanceof AccountModel) { // Actors that shared my videos are involved too - actorsInvolved = await VideoShareModel.loadActorsByVideoOwner(byActor.id, t) + actorsInvolved = await VideoShareModel.loadActorsWhoSharedVideosOf(byActor.id, t) } else { // Actors that shared videos of my channel are involved too actorsInvolved = await VideoShareModel.loadActorsByVideoChannel(accountOrChannel.id, t) @@ -55,19 +62,58 @@ async function sendUpdateActor (accountOrChannel: AccountModel | VideoChannelMod actorsInvolved.push(byActor) - return broadcastToFollowers(data, byActor, actorsInvolved, t) + return broadcastToFollowers(updateActivity, byActor, actorsInvolved, t) +} + +async function sendUpdateCacheFile (byActor: ActorModel, redundancyModel: VideoRedundancyModel) { + logger.info('Creating job to update cache file %s.', redundancyModel.url) + + const video = await VideoModel.loadAndPopulateAccountAndServerAndTags(redundancyModel.getVideo().id) + + const activityBuilder = (audience: ActivityAudience) => { + const redundancyObject = redundancyModel.toActivityPubObject() + const url = getUpdateActivityPubUrl(redundancyModel.url, redundancyModel.updatedAt.toISOString()) + + return buildUpdateActivity(url, byActor, redundancyObject, audience) + } + + return sendVideoRelatedActivity(activityBuilder, { byActor, video }) +} + +async function sendUpdateVideoPlaylist (videoPlaylist: VideoPlaylistModel, t: Transaction) { + if (videoPlaylist.privacy === VideoPlaylistPrivacy.PRIVATE) return undefined + + const byActor = videoPlaylist.OwnerAccount.Actor + + logger.info('Creating job to update video playlist %s.', videoPlaylist.url) + + const url = getUpdateActivityPubUrl(videoPlaylist.url, videoPlaylist.updatedAt.toISOString()) + + const object = await videoPlaylist.toActivityPubObject(null, t) + const audience = getAudience(byActor, videoPlaylist.privacy === VideoPlaylistPrivacy.PUBLIC) + + const updateActivity = buildUpdateActivity(url, byActor, object, audience) + + const serverActor = await getServerActor() + const toFollowersOf = [ byActor, serverActor ] + + if (videoPlaylist.VideoChannel) toFollowersOf.push(videoPlaylist.VideoChannel.Actor) + + return broadcastToFollowers(updateActivity, byActor, toFollowersOf, t) } // --------------------------------------------------------------------------- export { sendUpdateActor, - sendUpdateVideo + sendUpdateVideo, + sendUpdateCacheFile, + sendUpdateVideoPlaylist } // --------------------------------------------------------------------------- -function updateActivityData (url: string, byActor: ActorModel, object: any, audience?: ActivityAudience): ActivityUpdate { +function buildUpdateActivity (url: string, byActor: ActorModel, object: any, audience?: ActivityAudience): ActivityUpdate { if (!audience) audience = getAudience(byActor) return audiencify(