X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Factivitypub%2Foutbox.ts;h=ae7adcd4c30aad11ab782c97261009fd0442f587;hb=0c237b19fdf9c614293c1442f0ab95a81ce05735;hp=ab12a7c4b96a324b21b9cb225e5b8384cf4ff608;hpb=54e740594bc2eacd8026b5d2d6cfdfc06416a65b;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/activitypub/outbox.ts b/server/controllers/activitypub/outbox.ts index ab12a7c4b..ae7adcd4c 100644 --- a/server/controllers/activitypub/outbox.ts +++ b/server/controllers/activitypub/outbox.ts @@ -1,15 +1,15 @@ import * as express from 'express' import { Activity } from '../../../shared/models/activitypub/activity' -import { activityPubCollectionPagination } from '../../helpers/activitypub' -import { pageToStartAndCount } from '../../helpers/core-utils' -import { ACTIVITY_PUB } from '../../initializers/constants' +import { VideoPrivacy } from '../../../shared/models/videos' +import { activityPubCollectionPagination, activityPubContextify } from '../../helpers/activitypub' +import { logger } from '../../helpers/logger' import { announceActivityData, createActivityData } from '../../lib/activitypub/send' -import { buildAudience } from '../../lib/activitypub/send/misc' -import { getAnnounceActivityPubUrl } from '../../lib/activitypub/url' +import { buildAudience } from '../../lib/activitypub/audience' import { asyncMiddleware, localAccountValidator } from '../../middlewares' import { AccountModel } from '../../models/account/account' import { ActorModel } from '../../models/activitypub/actor' import { VideoModel } from '../../models/video/video' +import { activityPubResponse } from './utils' const outboxRouter = express.Router() @@ -29,10 +29,17 @@ export { async function outboxController (req: express.Request, res: express.Response, next: express.NextFunction) { const account: AccountModel = res.locals.account const actor = account.Actor + const actorOutboxUrl = account.Actor.url + '/outbox' - const page = req.query.page || 1 - const { start, count } = pageToStartAndCount(page, ACTIVITY_PUB.COLLECTION_ITEMS_PER_PAGE) + logger.info('Receiving outbox request for %s.', actorOutboxUrl) + const handler = (start: number, count: number) => buildActivities(actor, start, count) + const json = await activityPubCollectionPagination(actorOutboxUrl, handler, req.query.page) + + return activityPubResponse(activityPubContextify(json), res) +} + +async function buildActivities (actor: ActorModel, start: number, count: number) { const data = await VideoModel.listAllAndSharedByActorForOutbox(actor.id, start, count) const activities: Activity[] = [] @@ -40,35 +47,26 @@ async function outboxController (req: express.Request, res: express.Response, ne 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 videoObject = video.toActivityPubObject() - const byActor = video.VideoChannel.Account.Actor - const createActivityAudience = buildAudience(followersMatrix[byActor.id]) + const createActivityAudience = buildAudience([ byActor.followersUrl ], video.privacy === VideoPrivacy.PUBLIC) // This is a shared video if (video.VideoShares !== undefined && video.VideoShares.length !== 0) { - const createActivity = await createActivityData(video.url, byActor, videoObject, undefined, createActivityAudience) - - const announceAudience = buildAudience(followersMatrix[actor.id]) - const url = getAnnounceActivityPubUrl(video.url, actor) - const announceActivity = await announceActivityData(url, actor, createActivity, undefined, announceAudience) + const videoShare = video.VideoShares[0] + const announceActivity = announceActivityData(videoShare.url, actor, video.url, createActivityAudience) activities.push(announceActivity) } else { - const createActivity = await createActivityData(video.url, byActor, videoObject, undefined, createActivityAudience) + const videoObject = video.toActivityPubObject() + const createActivity = createActivityData(video.url, byActor, videoObject, createActivityAudience) activities.push(createActivity) } } - const newResult = { + return { data: activities, total: data.total } - const json = activityPubCollectionPagination(account.Actor.url + '/outbox', page, newResult) - - return res.json(json).end() }