const actors = data.data.map(v => v.VideoChannel.Account.Actor)
actors.push(actor)
- const followersMatrix = await ActorModel.getActorsFollowerSharedInboxUrls(actors, undefined)
-
for (const video of data.data) {
const byActor = video.VideoChannel.Account.Actor
- const createActivityAudience = buildAudience(followersMatrix[byActor.id], video.privacy === VideoPrivacy.PUBLIC)
+ const createActivityAudience = buildAudience([ byActor.followersUrl ], video.privacy === VideoPrivacy.PUBLIC)
// This is a shared video
if (video.VideoShares !== undefined && video.VideoShares.length !== 0) {
const videoShare = video.VideoShares[0]
- const announceAudience = buildAudience(followersMatrix[actor.id], video.privacy === VideoPrivacy.PUBLIC)
- const announceActivity = await announceActivityData(videoShare.url, actor, video.url, undefined, announceAudience)
+ const announceActivity = await announceActivityData(videoShare.url, actor, video.url, undefined, createActivityAudience)
activities.push(announceActivity)
} else {
return buildAudience([ actorSender.followersUrl ], isPublic)
}
-function buildAudience (followerInboxUrls: string[], isPublic = true) {
- // Thanks Mastodon: https://github.com/tootsuite/mastodon/blob/master/app/lib/activitypub/tag_manager.rb#L47
+function buildAudience (followerUrls: string[], isPublic = true) {
let to = []
let cc = []
if (isPublic) {
to = [ ACTIVITY_PUB.PUBLIC ]
- cc = followerInboxUrls
+ cc = followerUrls
} else { // Unlisted
to = [ ]
cc = [ ]
attributes: [ 'id', 'url' ],
model: VideoShareModel.unscoped(),
required: false,
+ // We only want videos shared by this actor
+ where: {
+ [Sequelize.Op.and]: [
+ {
+ id: {
+ [Sequelize.Op.not]: null
+ }
+ },
+ {
+ actorId
+ }
+ ]
+ },
include: [
{
attributes: [ 'id', 'url' ],
required: true,
include: [
{
- attributes: [ 'id', 'url' ],
+ attributes: [ 'id', 'url', 'followersUrl' ],
model: ActorModel.unscoped(),
required: true
}
]
},
{
- attributes: [ 'id', 'url' ],
+ attributes: [ 'id', 'url', 'followersUrl' ],
model: ActorModel.unscoped(),
required: true
}