]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/controllers/activitypub/inbox.ts
Merge branch 'feature/design' 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'
e4f97bab 3import { logger } from '../../helpers'
0d0e8dd0 4import { isActivityValid } from '../../helpers/custom-validators/activitypub/activity'
c986175d 5import { processActivities } from '../../lib/activitypub/process/process'
7a7724e6 6import { asyncMiddleware, checkSignature, localAccountValidator, signatureValidator } from '../../middlewares'
0d0e8dd0 7import { activityPubValidator } from '../../middlewares/validators/activitypub/activity'
e4f97bab
C
8
9const inboxRouter = express.Router()
10
7a7724e6 11inboxRouter.post('/inbox',
e4f97bab
C
12 signatureValidator,
13 asyncMiddleware(checkSignature),
0d0e8dd0 14 activityPubValidator,
e4f97bab
C
15 asyncMiddleware(inboxController)
16)
17
350e31d6 18inboxRouter.post('/account/:name/inbox',
7a7724e6
C
19 signatureValidator,
20 asyncMiddleware(checkSignature),
21 localAccountValidator,
22 activityPubValidator,
23 asyncMiddleware(inboxController)
24)
25
e4f97bab
C
26// ---------------------------------------------------------------------------
27
28export {
29 inboxRouter
30}
31
32// ---------------------------------------------------------------------------
33
34async function inboxController (req: express.Request, res: express.Response, next: express.NextFunction) {
35 const rootActivity: RootActivity = req.body
36 let activities: Activity[] = []
37
38 if ([ 'Collection', 'CollectionPage' ].indexOf(rootActivity.type) !== -1) {
39 activities = (rootActivity as ActivityPubCollection).items
40 } else if ([ 'OrderedCollection', 'OrderedCollectionPage' ].indexOf(rootActivity.type) !== -1) {
16b90975 41 activities = (rootActivity as ActivityPubOrderedCollection<Activity>).orderedItems
e4f97bab
C
42 } else {
43 activities = [ rootActivity as Activity ]
44 }
45
0d0e8dd0 46 // Only keep activities we are able to process
fef2c716 47 logger.debug('Filtering %d activities...', activities.length)
0d0e8dd0 48 activities = activities.filter(a => isActivityValid(a))
350e31d6 49 logger.debug('We keep %d activities.', activities.length, { activities })
0d0e8dd0 50
f10336ca 51 await processActivities(activities, res.locals.signature.account, res.locals.account)
e4f97bab
C
52
53 res.status(204).end()
54}