X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Factivitypub%2Foutbox.ts;h=620f9ee83c973fd71e8e90f89533e3b9a0e78b14;hb=e8e122002d5a6a2bedcf3d66d35657c9b9e1ebaf;hp=e2c4e9b1e67fd6342cd48489deff42fb2554332f;hpb=d52eb8f656242c7e34afdb2dee681861fb9bce35;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/activitypub/outbox.ts b/server/controllers/activitypub/outbox.ts index e2c4e9b1e..620f9ee83 100644 --- a/server/controllers/activitypub/outbox.ts +++ b/server/controllers/activitypub/outbox.ts @@ -2,17 +2,16 @@ import * as express from 'express' import { Activity } from '../../../shared/models/activitypub/activity' import { activityPubCollectionPagination } from '../../helpers/activitypub' import { pageToStartAndCount } from '../../helpers/core-utils' -import { database as db } from '../../initializers' import { ACTIVITY_PUB } from '../../initializers/constants' -import { addActivityData } from '../../lib/activitypub/send/send-add' +import { announceActivityData, createActivityData } from '../../lib/activitypub/send' import { getAnnounceActivityPubUrl } from '../../lib/activitypub/url' -import { announceActivityData } from '../../lib/index' import { asyncMiddleware, localAccountValidator } from '../../middlewares' -import { AccountInstance } from '../../models/account/account-interface' +import { AccountModel } from '../../models/account/account' +import { VideoModel } from '../../models/video/video' const outboxRouter = express.Router() -outboxRouter.get('/account/:name/outbox', +outboxRouter.get('/accounts/:name/outbox', localAccountValidator, asyncMiddleware(outboxController) ) @@ -26,29 +25,31 @@ export { // --------------------------------------------------------------------------- async function outboxController (req: express.Request, res: express.Response, next: express.NextFunction) { - const account: AccountInstance = res.locals.account + const account: AccountModel = res.locals.account + const actor = account.Actor const page = req.query.page || 1 const { start, count } = pageToStartAndCount(page, ACTIVITY_PUB.COLLECTION_ITEMS_PER_PAGE) - const data = await db.Video.listAllAndSharedByAccountForOutbox(account.id, start, count) + const data = await VideoModel.listAllAndSharedByActorForOutbox(actor.id, start, count) const activities: Activity[] = [] for (const video of data.data) { const videoObject = video.toActivityPubObject() + const videoChannel = video.VideoChannel // This is a shared video if (video.VideoShares !== undefined && video.VideoShares.length !== 0) { - const addActivity = await addActivityData(video.url, video.VideoChannel.Account, video, video.VideoChannel.url, videoObject) + const createActivity = await createActivityData(video.url, videoChannel.Account.Actor, videoObject, undefined) - const url = getAnnounceActivityPubUrl(video.url, account) - const announceActivity = await announceActivityData(url, account, addActivity) + const url = getAnnounceActivityPubUrl(video.url, actor) + const announceActivity = await announceActivityData(url, actor, createActivity, undefined) activities.push(announceActivity) } else { - const addActivity = await addActivityData(video.url, account, video, video.VideoChannel.url, videoObject) + const createActivity = await createActivityData(video.url, videoChannel.Account.Actor, videoObject, undefined) - activities.push(addActivity) + activities.push(createActivity) } } @@ -56,7 +57,7 @@ async function outboxController (req: express.Request, res: express.Response, ne data: activities, total: data.total } - const json = activityPubCollectionPagination(account.url + '/outbox', page, newResult) + const json = activityPubCollectionPagination(account.Actor.url + '/outbox', page, newResult) return res.json(json).end() }