]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/controllers/activitypub/inbox.ts
Merge branch 'release/1.4.0' into develop
[github/Chocobozzz/PeerTube.git] / server / controllers / activitypub / inbox.ts
CommitLineData
e4f97bab 1import * as express from 'express'
c986175d 2import { Activity, ActivityPubCollection, ActivityPubOrderedCollection, RootActivity } from '../../../shared'
0d0e8dd0 3import { isActivityValid } from '../../helpers/custom-validators/activitypub/activity'
da854ddd 4import { logger } from '../../helpers/logger'
c986175d 5import { processActivities } from '../../lib/activitypub/process/process'
06a05d5f 6import { asyncMiddleware, checkSignature, localAccountValidator, localVideoChannelValidator, signatureValidator } from '../../middlewares'
0d0e8dd0 7import { activityPubValidator } from '../../middlewares/validators/activitypub/activity'
d61b8178
C
8import { queue } from 'async'
9import { ActorModel } from '../../models/activitypub/actor'
453e83ea 10import { MActorDefault, MActorSignature } from '../../typings/models'
e4f97bab
C
11
12const inboxRouter = express.Router()
13
7a7724e6 14inboxRouter.post('/inbox',
e4f97bab
C
15 signatureValidator,
16 asyncMiddleware(checkSignature),
285fe7c9 17 asyncMiddleware(activityPubValidator),
d61b8178 18 inboxController
e4f97bab
C
19)
20
e8e12200 21inboxRouter.post('/accounts/:name/inbox',
7a7724e6
C
22 signatureValidator,
23 asyncMiddleware(checkSignature),
ee28cdf1 24 asyncMiddleware(localAccountValidator),
285fe7c9 25 asyncMiddleware(activityPubValidator),
d61b8178 26 inboxController
7a7724e6 27)
06a05d5f
C
28inboxRouter.post('/video-channels/:name/inbox',
29 signatureValidator,
30 asyncMiddleware(checkSignature),
31 asyncMiddleware(localVideoChannelValidator),
32 asyncMiddleware(activityPubValidator),
d61b8178 33 inboxController
06a05d5f 34)
7a7724e6 35
e4f97bab
C
36// ---------------------------------------------------------------------------
37
38export {
39 inboxRouter
40}
41
42// ---------------------------------------------------------------------------
43
453e83ea
C
44type QueueParam = { activities: Activity[], signatureActor?: MActorSignature, inboxActor?: MActorDefault }
45const inboxQueue = queue<QueueParam, Error>((task, cb) => {
5c6d985f
C
46 const options = { signatureActor: task.signatureActor, inboxActor: task.inboxActor }
47
48 processActivities(task.activities, options)
d61b8178
C
49 .then(() => cb())
50})
51
5c6d985f 52function inboxController (req: express.Request, res: express.Response) {
e4f97bab
C
53 const rootActivity: RootActivity = req.body
54 let activities: Activity[] = []
55
56 if ([ 'Collection', 'CollectionPage' ].indexOf(rootActivity.type) !== -1) {
57 activities = (rootActivity as ActivityPubCollection).items
58 } else if ([ 'OrderedCollection', 'OrderedCollectionPage' ].indexOf(rootActivity.type) !== -1) {
16b90975 59 activities = (rootActivity as ActivityPubOrderedCollection<Activity>).orderedItems
e4f97bab
C
60 } else {
61 activities = [ rootActivity as Activity ]
62 }
63
0d0e8dd0 64 // Only keep activities we are able to process
fef2c716 65 logger.debug('Filtering %d activities...', activities.length)
0d0e8dd0 66 activities = activities.filter(a => isActivityValid(a))
350e31d6 67 logger.debug('We keep %d activities.', activities.length, { activities })
0d0e8dd0 68
dae86118 69 const accountOrChannel = res.locals.account || res.locals.videoChannel
50d6de9c 70
a7977280 71 logger.info('Receiving inbox requests for %d activities by %s.', activities.length, res.locals.signature.actor.url)
09cababd 72
d61b8178
C
73 inboxQueue.push({
74 activities,
75 signatureActor: res.locals.signature.actor,
76 inboxActor: accountOrChannel ? accountOrChannel.Actor : undefined
77 })
e4f97bab 78
d61b8178 79 return res.status(204).end()
e4f97bab 80}