import * as express from 'express'
-
-import {
- processCreateActivity,
- processUpdateActivity,
- processFlagActivity
-} from '../../lib'
-import {
- Activity,
- ActivityType,
- RootActivity,
- ActivityPubCollection,
- ActivityPubOrderedCollection
-} from '../../../shared'
-import {
- signatureValidator,
- checkSignature,
- asyncMiddleware
-} from '../../middlewares'
+import { Activity, ActivityPubCollection, ActivityPubOrderedCollection, RootActivity } from '../../../shared'
import { logger } from '../../helpers'
-
-const processActivity: { [ P in ActivityType ]: (activity: Activity) => Promise<any> } = {
- Create: processCreateActivity,
- Update: processUpdateActivity,
- Flag: processFlagActivity
-}
+import { isActivityValid } from '../../helpers/custom-validators/activitypub/activity'
+import { processActivities } from '../../lib/activitypub/process/process'
+import { asyncMiddleware, checkSignature, localAccountValidator, signatureValidator } from '../../middlewares'
+import { activityPubValidator } from '../../middlewares/validators/activitypub/activity'
const inboxRouter = express.Router()
-inboxRouter.post('/',
+inboxRouter.post('/inbox',
+ signatureValidator,
+ asyncMiddleware(checkSignature),
+ activityPubValidator,
+ asyncMiddleware(inboxController)
+)
+
+inboxRouter.post('/account/:name/inbox',
signatureValidator,
asyncMiddleware(checkSignature),
- // inboxValidator,
+ localAccountValidator,
+ activityPubValidator,
asyncMiddleware(inboxController)
)
activities = [ rootActivity as Activity ]
}
- await processActivities(activities)
+ // Only keep activities we are able to process
+ logger.debug('Filtering activities...', { activities })
+ activities = activities.filter(a => isActivityValid(a))
+ logger.debug('We keep %d activities.', activities.length, { activities })
- res.status(204).end()
-}
+ await processActivities(activities, res.locals.account)
-async function processActivities (activities: Activity[]) {
- for (const activity of activities) {
- const activityProcessor = processActivity[activity.type]
- if (activityProcessor === undefined) {
- logger.warn('Unknown activity type %s.', activity.type, { activityId: activity.id })
- continue
- }
-
- await activityProcessor(activity)
- }
+ res.status(204).end()
}