X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Factivitypub%2Foutbox.ts;h=e060affb2aa7af292572f74adc5dff9863280625;hb=e65c0c5b1fab9c3d93f51721b2458cf5cf471f20;hp=ae7adcd4c30aad11ab782c97261009fd0442f587;hpb=2186386cca113506791583cb07d6ccacba7af4e0;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/activitypub/outbox.ts b/server/controllers/activitypub/outbox.ts index ae7adcd4c..e060affb2 100644 --- a/server/controllers/activitypub/outbox.ts +++ b/server/controllers/activitypub/outbox.ts @@ -3,13 +3,14 @@ import { Activity } from '../../../shared/models/activitypub/activity' 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 { buildAnnounceActivity, buildCreateActivity } from '../../lib/activitypub/send' import { buildAudience } from '../../lib/activitypub/audience' -import { asyncMiddleware, localAccountValidator } from '../../middlewares' +import { asyncMiddleware, localAccountValidator, localVideoChannelValidator } from '../../middlewares' import { AccountModel } from '../../models/account/account' import { ActorModel } from '../../models/activitypub/actor' import { VideoModel } from '../../models/video/video' import { activityPubResponse } from './utils' +import { VideoChannelModel } from '../../models/video/video-channel' const outboxRouter = express.Router() @@ -18,6 +19,11 @@ outboxRouter.get('/accounts/:name/outbox', asyncMiddleware(outboxController) ) +outboxRouter.get('/video-channels/:name/outbox', + localVideoChannelValidator, + asyncMiddleware(outboxController) +) + // --------------------------------------------------------------------------- export { @@ -26,10 +32,10 @@ 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' +async function outboxController (req: express.Request, res: express.Response) { + const accountOrVideoChannel: AccountModel | VideoChannelModel = res.locals.account || res.locals.videoChannel + const actor = accountOrVideoChannel.Actor + const actorOutboxUrl = actor.url + '/outbox' logger.info('Receiving outbox request for %s.', actorOutboxUrl) @@ -54,12 +60,12 @@ async function buildActivities (actor: ActorModel, start: number, count: number) // This is a shared video if (video.VideoShares !== undefined && video.VideoShares.length !== 0) { const videoShare = video.VideoShares[0] - const announceActivity = announceActivityData(videoShare.url, actor, video.url, createActivityAudience) + const announceActivity = buildAnnounceActivity(videoShare.url, actor, video.url, createActivityAudience) activities.push(announceActivity) } else { const videoObject = video.toActivityPubObject() - const createActivity = createActivityData(video.url, byActor, videoObject, createActivityAudience) + const createActivity = buildCreateActivity(video.url, byActor, videoObject, createActivityAudience) activities.push(createActivity) }