]>
Commit | Line | Data |
---|---|---|
3fd3ab2d | 1 | import { Activity, ActivityType } from '../../../../shared/models/activitypub' |
da854ddd | 2 | import { logger } from '../../../helpers/logger' |
50d6de9c | 3 | import { ActorModel } from '../../../models/activitypub/actor' |
c986175d | 4 | import { processAcceptActivity } from './process-accept' |
c986175d C |
5 | import { processAnnounceActivity } from './process-announce' |
6 | import { processCreateActivity } from './process-create' | |
7 | import { processDeleteActivity } from './process-delete' | |
8 | import { processFollowActivity } from './process-follow' | |
0032ebe9 | 9 | import { processLikeActivity } from './process-like' |
4bbc373f | 10 | import { processRejectActivity } from './process-reject' |
c986175d C |
11 | import { processUndoActivity } from './process-undo' |
12 | import { processUpdateActivity } from './process-update' | |
c986175d | 13 | |
50d6de9c | 14 | const processActivity: { [ P in ActivityType ]: (activity: Activity, inboxActor?: ActorModel) => Promise<any> } = { |
c986175d | 15 | Create: processCreateActivity, |
c986175d C |
16 | Update: processUpdateActivity, |
17 | Delete: processDeleteActivity, | |
18 | Follow: processFollowActivity, | |
19 | Accept: processAcceptActivity, | |
4bbc373f | 20 | Reject: processRejectActivity, |
c986175d | 21 | Announce: processAnnounceActivity, |
0032ebe9 C |
22 | Undo: processUndoActivity, |
23 | Like: processLikeActivity | |
c986175d C |
24 | } |
25 | ||
50d6de9c | 26 | async function processActivities (activities: Activity[], signatureActor?: ActorModel, inboxActor?: ActorModel) { |
c986175d | 27 | for (const activity of activities) { |
f10336ca | 28 | // When we fetch remote data, we don't have signature |
50d6de9c C |
29 | if (signatureActor && activity.actor !== signatureActor.url) { |
30 | logger.warn('Signature mismatch between %s and %s.', activity.actor, signatureActor.url) | |
f10336ca C |
31 | continue |
32 | } | |
33 | ||
c986175d C |
34 | const activityProcessor = processActivity[activity.type] |
35 | if (activityProcessor === undefined) { | |
36 | logger.warn('Unknown activity type %s.', activity.type, { activityId: activity.id }) | |
37 | continue | |
38 | } | |
39 | ||
16b90975 | 40 | try { |
50d6de9c | 41 | await activityProcessor(activity, inboxActor) |
16b90975 | 42 | } catch (err) { |
5d00a3d7 | 43 | logger.warn(err.stack) |
16b90975 C |
44 | logger.warn('Cannot process activity %s.', activity.type, err) |
45 | } | |
c986175d C |
46 | } |
47 | } | |
48 | ||
49 | export { | |
50 | processActivities | |
51 | } |