1
0
Fork 0
peertube/server/controllers/activitypub/outbox.ts

79 lines
2.9 KiB
TypeScript
Raw Normal View History

2017-11-21 12:23:10 -05:00
import * as express from 'express'
2017-11-22 12:31:40 -05:00
import { Activity } from '../../../shared/models/activitypub/activity'
import { VideoPrivacy } from '../../../shared/models/videos'
import { activityPubCollectionPagination, activityPubContextify } from '../../helpers/activitypub'
2018-02-27 05:06:43 -05:00
import { logger } from '../../helpers/logger'
2018-09-11 10:27:07 -04:00
import { buildAnnounceActivity, buildCreateActivity } from '../../lib/activitypub/send'
2018-05-25 05:32:36 -04:00
import { buildAudience } from '../../lib/activitypub/audience'
import { asyncMiddleware, localAccountValidator, localVideoChannelValidator } from '../../middlewares'
2017-12-12 11:53:50 -05:00
import { AccountModel } from '../../models/account/account'
import { ActorModel } from '../../models/activitypub/actor'
2017-12-12 11:53:50 -05:00
import { VideoModel } from '../../models/video/video'
import { activityPubResponse } from './utils'
import { VideoChannelModel } from '../../models/video/video-channel'
2017-11-21 12:23:10 -05:00
const outboxRouter = express.Router()
2018-01-03 05:36:03 -05:00
outboxRouter.get('/accounts/:name/outbox',
2017-11-21 12:23:10 -05:00
localAccountValidator,
asyncMiddleware(outboxController)
)
outboxRouter.get('/video-channels/:name/outbox',
localVideoChannelValidator,
asyncMiddleware(outboxController)
)
2017-11-21 12:23:10 -05:00
// ---------------------------------------------------------------------------
export {
outboxRouter
}
// ---------------------------------------------------------------------------
2019-02-26 04:55:40 -05:00
async function outboxController (req: express.Request, res: express.Response) {
2019-03-19 05:35:15 -04:00
const accountOrVideoChannel = res.locals.account || res.locals.videoChannel
const actor = accountOrVideoChannel.Actor
const actorOutboxUrl = actor.url + '/outbox'
logger.info('Receiving outbox request for %s.', actorOutboxUrl)
2017-11-21 12:23:10 -05:00
const handler = (start: number, count: number) => buildActivities(actor, start, count)
const json = await activityPubCollectionPagination(actorOutboxUrl, handler, req.query.page)
return activityPubResponse(activityPubContextify(json), res)
}
2017-11-21 12:23:10 -05:00
async function buildActivities (actor: ActorModel, start: number, count: number) {
2017-12-14 11:38:41 -05:00
const data = await VideoModel.listAllAndSharedByActorForOutbox(actor.id, start, count)
2017-11-21 12:23:10 -05:00
const activities: Activity[] = []
// Avoid too many SQL requests
const actors = data.data.map(v => v.VideoChannel.Account.Actor)
actors.push(actor)
2017-11-21 12:23:10 -05:00
for (const video of data.data) {
const byActor = video.VideoChannel.Account.Actor
2018-05-28 06:13:00 -04:00
const createActivityAudience = buildAudience([ byActor.followersUrl ], video.privacy === VideoPrivacy.PUBLIC)
2017-12-14 11:38:41 -05:00
// This is a shared video
2017-11-22 10:25:03 -05:00
if (video.VideoShares !== undefined && video.VideoShares.length !== 0) {
const videoShare = video.VideoShares[0]
2018-09-11 10:27:07 -04:00
const announceActivity = buildAnnounceActivity(videoShare.url, actor, video.url, createActivityAudience)
2017-11-22 10:25:03 -05:00
2017-11-21 12:23:10 -05:00
activities.push(announceActivity)
} else {
2018-01-26 06:02:18 -05:00
const videoObject = video.toActivityPubObject()
2018-09-11 10:27:07 -04:00
const createActivity = buildCreateActivity(video.url, byActor, videoObject, createActivityAudience)
2017-11-22 10:25:03 -05:00
2017-12-14 11:38:41 -05:00
activities.push(createActivity)
2017-11-21 12:23:10 -05:00
}
}
return {
2017-11-21 12:23:10 -05:00
data: activities,
total: data.total
}
}