PeerTube/server/lib/activitypub/send/send-update.ts

159 lines
5.4 KiB
TypeScript
Raw Normal View History

2017-11-20 09:43:39 +01:00
import { Transaction } from 'sequelize'
import { getServerActor } from '@server/models/application/application'
import { ActivityAudience, ActivityUpdate, VideoPlaylistPrivacy, VideoPrivacy } from '@shared/models'
import { logger } from '../../../helpers/logger'
import { AccountModel } from '../../../models/account/account'
2017-12-12 17:53:50 +01:00
import { VideoModel } from '../../../models/video/video'
import { VideoShareModel } from '../../../models/video/video-share'
2019-08-15 11:53:26 +02:00
import {
2019-08-21 14:31:57 +02:00
MAccountDefault,
2019-08-15 11:53:26 +02:00
MActor,
MActorLight,
2019-08-21 14:31:57 +02:00
MChannelDefault,
2019-08-15 11:53:26 +02:00
MVideoAP,
MVideoAPWithoutCaption,
MVideoPlaylistFull,
MVideoRedundancyVideo
2020-06-18 10:45:25 +02:00
} from '../../../types/models'
import { audiencify, getAudience } from '../audience'
import { getUpdateActivityPubUrl } from '../url'
import { getActorsInvolvedInVideo } from './shared'
import { broadcastToFollowers, sendVideoRelatedActivity } from './shared/send-utils'
2019-08-15 11:53:26 +02:00
2022-03-23 16:14:33 +01:00
async function sendUpdateVideo (videoArg: MVideoAPWithoutCaption, transaction: Transaction, overriddenByActor?: MActor) {
2019-08-15 11:53:26 +02:00
const video = videoArg as MVideoAP
2017-11-20 09:43:39 +01:00
2019-12-12 15:47:47 +01:00
if (!video.hasPrivacyForFederation()) return undefined
2019-02-26 10:55:40 +01:00
2018-07-30 17:02:40 +02:00
logger.info('Creating job to update video %s.', video.url)
2022-03-23 16:14:33 +01:00
const byActor = overriddenByActor || video.VideoChannel.Account.Actor
2017-11-20 09:43:39 +01:00
const url = getUpdateActivityPubUrl(video.url, video.updatedAt.toISOString())
2018-09-04 10:22:10 +02:00
// Needed to build the AP object
2019-07-29 11:59:29 +02:00
if (!video.VideoCaptions) {
2022-03-23 16:14:33 +01:00
video.VideoCaptions = await video.$get('VideoCaptions', { transaction })
2019-07-29 11:59:29 +02:00
}
2018-09-04 10:22:10 +02:00
2017-11-20 09:43:39 +01:00
const videoObject = video.toActivityPubObject()
const audience = getAudience(byActor, video.privacy === VideoPrivacy.PUBLIC)
2017-12-14 17:38:41 +01:00
2018-09-11 16:27:07 +02:00
const updateActivity = buildUpdateActivity(url, byActor, videoObject, audience)
2017-11-20 09:43:39 +01:00
2022-03-23 16:14:33 +01:00
const actorsInvolved = await getActorsInvolvedInVideo(video, transaction)
if (overriddenByActor) actorsInvolved.push(overriddenByActor)
2017-11-20 09:43:39 +01:00
2022-03-23 16:14:33 +01:00
return broadcastToFollowers({
data: updateActivity,
byActor,
toFollowersOf: actorsInvolved,
contextType: 'Video',
transaction
})
2017-11-20 09:43:39 +01:00
}
2022-03-23 16:14:33 +01:00
async function sendUpdateActor (accountOrChannel: MChannelDefault | MAccountDefault, transaction: Transaction) {
const byActor = accountOrChannel.Actor
2018-01-03 16:38:50 +01:00
2018-07-30 17:02:40 +02:00
logger.info('Creating job to update actor %s.', byActor.url)
2018-01-03 16:38:50 +01:00
const url = getUpdateActivityPubUrl(byActor.url, byActor.updatedAt.toISOString())
2019-10-21 14:50:55 +02:00
const accountOrChannelObject = (accountOrChannel as any).toActivityPubObject() // FIXME: typescript bug?
const audience = getAudience(byActor)
2018-09-11 16:27:07 +02:00
const updateActivity = buildUpdateActivity(url, byActor, accountOrChannelObject, audience)
2019-08-15 11:53:26 +02:00
let actorsInvolved: MActor[]
if (accountOrChannel instanceof AccountModel) {
// Actors that shared my videos are involved too
2022-03-23 16:14:33 +01:00
actorsInvolved = await VideoShareModel.loadActorsWhoSharedVideosOf(byActor.id, transaction)
} else {
// Actors that shared videos of my channel are involved too
2022-03-23 16:14:33 +01:00
actorsInvolved = await VideoShareModel.loadActorsByVideoChannel(accountOrChannel.id, transaction)
}
2018-01-03 16:38:50 +01:00
actorsInvolved.push(byActor)
2022-03-23 16:14:33 +01:00
return broadcastToFollowers({
data: updateActivity,
byActor,
toFollowersOf: actorsInvolved,
transaction,
contextType: 'Actor'
})
2018-09-11 16:27:07 +02:00
}
2019-08-15 11:53:26 +02:00
async function sendUpdateCacheFile (byActor: MActorLight, redundancyModel: MVideoRedundancyVideo) {
2018-09-11 16:27:07 +02:00
logger.info('Creating job to update cache file %s.', redundancyModel.url)
const associatedVideo = redundancyModel.getVideo()
if (!associatedVideo) {
logger.warn('Cannot send update activity for redundancy %s: no video files associated.', redundancyModel.url)
return
}
2022-06-28 14:57:51 +02:00
const video = await VideoModel.loadFull(associatedVideo.id)
2018-09-11 16:27:07 +02:00
2018-09-14 16:51:35 +02:00
const activityBuilder = (audience: ActivityAudience) => {
const redundancyObject = redundancyModel.toActivityPubObject()
const url = getUpdateActivityPubUrl(redundancyModel.url, redundancyModel.updatedAt.toISOString())
2018-09-11 16:27:07 +02:00
2018-09-14 16:51:35 +02:00
return buildUpdateActivity(url, byActor, redundancyObject, audience)
}
2018-09-11 16:27:07 +02:00
2020-02-04 16:34:46 +01:00
return sendVideoRelatedActivity(activityBuilder, { byActor, video, contextType: 'CacheFile' })
2018-01-03 16:38:50 +01:00
}
2022-03-23 16:14:33 +01:00
async function sendUpdateVideoPlaylist (videoPlaylist: MVideoPlaylistFull, transaction: Transaction) {
2019-02-26 10:55:40 +01:00
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())
2022-03-23 16:14:33 +01:00
const object = await videoPlaylist.toActivityPubObject(null, transaction)
2019-02-26 10:55:40 +01:00
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)
2022-03-23 16:14:33 +01:00
return broadcastToFollowers({
data: updateActivity,
byActor,
toFollowersOf,
transaction,
contextType: 'Playlist'
})
2019-02-26 10:55:40 +01:00
}
2017-11-20 09:43:39 +01:00
// ---------------------------------------------------------------------------
export {
sendUpdateActor,
2018-09-11 16:27:07 +02:00
sendUpdateVideo,
2019-02-26 10:55:40 +01:00
sendUpdateCacheFile,
sendUpdateVideoPlaylist
2017-11-20 09:43:39 +01:00
}
// ---------------------------------------------------------------------------
2019-08-15 11:53:26 +02:00
function buildUpdateActivity (url: string, byActor: MActorLight, object: any, audience?: ActivityAudience): ActivityUpdate {
if (!audience) audience = getAudience(byActor)
2017-12-14 17:38:41 +01:00
return audiencify(
{
type: 'Update' as 'Update',
id: url,
actor: byActor.url,
2021-12-13 17:33:59 +01:00
object: audiencify(object, audience)
},
audience
)
2017-11-20 09:43:39 +01:00
}