X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Factivitypub%2Foutbox.ts;h=f385c9927ee5967683a01d289c590f5cf3be5dab;hb=38a3ccc7f8ad0ea94362b58c732af7c387ab46be;hp=74d3997631a7e0d63b5f9b1ca90c3b459f40b519;hpb=c46edbc2f6ca310b2f0331f979ac6caf27f6eb92;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/activitypub/outbox.ts b/server/controllers/activitypub/outbox.ts index 74d399763..f385c9927 100644 --- a/server/controllers/activitypub/outbox.ts +++ b/server/controllers/activitypub/outbox.ts @@ -1,22 +1,32 @@ -import * as express from 'express' -import { Activity, ActivityAdd } from '../../../shared/models/activitypub/activity' -import { activityPubCollectionPagination, activityPubContextify } from '../../helpers/activitypub' -import { database as db } from '../../initializers' -import { addActivityData } from '../../lib/activitypub/send/send-add' -import { getAnnounceActivityPubUrl } from '../../lib/activitypub/url' -import { announceActivityData } from '../../lib/index' -import { asyncMiddleware, localAccountValidator } from '../../middlewares' -import { AccountInstance } from '../../models/account/account-interface' -import { pageToStartAndCount } from '../../helpers/core-utils' -import { ACTIVITY_PUB } from '../../initializers/constants' +import express from 'express' +import { activityPubCollectionPagination } from '@server/lib/activitypub/collection' +import { activityPubContextify } from '@server/lib/activitypub/context' +import { MActorLight } from '@server/types/models' +import { Activity } from '../../../shared/models/activitypub/activity' +import { VideoPrivacy } from '../../../shared/models/videos' +import { logger } from '../../helpers/logger' +import { buildAudience } from '../../lib/activitypub/audience' +import { buildAnnounceActivity, buildCreateActivity } from '../../lib/activitypub/send' +import { asyncMiddleware, ensureIsLocalChannel, localAccountValidator, videoChannelsNameWithHostValidator } from '../../middlewares' +import { apPaginationValidator } from '../../middlewares/validators/activitypub' +import { VideoModel } from '../../models/video/video' +import { activityPubResponse } from './utils' const outboxRouter = express.Router() -outboxRouter.get('/account/:name/outbox', +outboxRouter.get('/accounts/:name/outbox', + apPaginationValidator, localAccountValidator, asyncMiddleware(outboxController) ) +outboxRouter.get('/video-channels/:nameWithHost/outbox', + apPaginationValidator, + asyncMiddleware(videoChannelsNameWithHostValidator), + ensureIsLocalChannel, + asyncMiddleware(outboxController) +) + // --------------------------------------------------------------------------- export { @@ -25,34 +35,43 @@ export { // --------------------------------------------------------------------------- -async function outboxController (req: express.Request, res: express.Response, next: express.NextFunction) { - const account: AccountInstance = res.locals.account +async function outboxController (req: express.Request, res: express.Response) { + const accountOrVideoChannel = res.locals.account || res.locals.videoChannel + const actor = accountOrVideoChannel.Actor + const actorOutboxUrl = 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 data = await db.Video.listAllAndSharedByAccountForOutbox(account.id, start, count) + const handler = (start: number, count: number) => buildActivities(actor, start, count) + const json = await activityPubCollectionPagination(actorOutboxUrl, handler, req.query.page, req.query.size) + + return activityPubResponse(activityPubContextify(json, 'Collection'), res) +} + +async function buildActivities (actor: MActorLight, start: number, count: number) { + const data = await VideoModel.listAllAndSharedByActorForOutbox(actor.id, start, count) const activities: Activity[] = [] for (const video of data.data) { - const videoObject = video.toActivityPubObject() - let addActivity: ActivityAdd = await addActivityData(video.url, account, video, video.VideoChannel.url, videoObject) + const byActor = video.VideoChannel.Account.Actor + const createActivityAudience = buildAudience([ byActor.followersUrl ], video.privacy === VideoPrivacy.PUBLIC) // This is a shared video - if (video.VideoShare !== undefined) { - const url = getAnnounceActivityPubUrl(video.url, account) - const announceActivity = await announceActivityData(url, account, addActivity) + if (video.VideoShares !== undefined && video.VideoShares.length !== 0) { + const videoShare = video.VideoShares[0] + const announceActivity = buildAnnounceActivity(videoShare.url, actor, video.url, createActivityAudience) + activities.push(announceActivity) } else { - activities.push(addActivity) + const videoObject = video.toActivityPubObject() + const createActivity = buildCreateActivity(video.url, byActor, videoObject, createActivityAudience) + + activities.push(createActivity) } } - const newResult = { + return { data: activities, total: data.total } - const json = activityPubCollectionPagination(account.url + '/outbox', page, newResult) - - return res.json(json).end() }