]>
Commit | Line | Data |
---|---|---|
136d7efd | 1 | import { StatsManager } from '@server/lib/stat-manager' |
3fd3ab2d | 2 | import { Activity, ActivityType } from '../../../../shared/models/activitypub' |
da854ddd | 3 | import { logger } from '../../../helpers/logger' |
136d7efd C |
4 | import { APProcessorOptions } from '../../../types/activitypub-processor.model' |
5 | import { MActorDefault, MActorSignature } from '../../../types/models' | |
7e98a7df | 6 | import { getAPId } from '../activity' |
136d7efd | 7 | import { getOrCreateAPActor } from '../actors' |
7e98a7df | 8 | import { checkUrlsSameHost } from '../url' |
c986175d | 9 | import { processAcceptActivity } from './process-accept' |
c986175d C |
10 | import { processAnnounceActivity } from './process-announce' |
11 | import { processCreateActivity } from './process-create' | |
12 | import { processDeleteActivity } from './process-delete' | |
136d7efd C |
13 | import { processDislikeActivity } from './process-dislike' |
14 | import { processFlagActivity } from './process-flag' | |
c986175d | 15 | import { processFollowActivity } from './process-follow' |
0032ebe9 | 16 | import { processLikeActivity } from './process-like' |
4bbc373f | 17 | import { processRejectActivity } from './process-reject' |
c986175d C |
18 | import { processUndoActivity } from './process-undo' |
19 | import { processUpdateActivity } from './process-update' | |
848f499d | 20 | import { processViewActivity } from './process-view' |
c986175d | 21 | |
1198edf4 | 22 | const processActivity: { [ P in ActivityType ]: (options: APProcessorOptions<Activity>) => Promise<any> } = { |
c986175d | 23 | Create: processCreateActivity, |
c986175d C |
24 | Update: processUpdateActivity, |
25 | Delete: processDeleteActivity, | |
26 | Follow: processFollowActivity, | |
27 | Accept: processAcceptActivity, | |
4bbc373f | 28 | Reject: processRejectActivity, |
c986175d | 29 | Announce: processAnnounceActivity, |
0032ebe9 | 30 | Undo: processUndoActivity, |
848f499d C |
31 | Like: processLikeActivity, |
32 | Dislike: processDislikeActivity, | |
33 | Flag: processFlagActivity, | |
34 | View: processViewActivity | |
c986175d C |
35 | } |
36 | ||
5c6d985f C |
37 | async function processActivities ( |
38 | activities: Activity[], | |
39 | options: { | |
453e83ea C |
40 | signatureActor?: MActorSignature |
41 | inboxActor?: MActorDefault | |
5c6d985f | 42 | outboxUrl?: string |
1198edf4 C |
43 | fromFetch?: boolean |
44 | } = {} | |
45 | ) { | |
46 | const { outboxUrl, signatureActor, inboxActor, fromFetch = false } = options | |
47 | ||
453e83ea | 48 | const actorsCache: { [ url: string ]: MActorSignature } = {} |
e587e0ec | 49 | |
c986175d | 50 | for (const activity of activities) { |
1198edf4 | 51 | if (!signatureActor && [ 'Create', 'Announce', 'Like' ].includes(activity.type) === false) { |
12ba460e C |
52 | logger.error('Cannot process activity %s (type: %s) without the actor signature.', activity.id, activity.type) |
53 | continue | |
54 | } | |
55 | ||
848f499d | 56 | const actorUrl = getAPId(activity.actor) |
6be84cbc | 57 | |
f10336ca | 58 | // When we fetch remote data, we don't have signature |
1198edf4 C |
59 | if (signatureActor && actorUrl !== signatureActor.url) { |
60 | logger.warn('Signature mismatch between %s and %s, skipping.', actorUrl, signatureActor.url) | |
f10336ca C |
61 | continue |
62 | } | |
63 | ||
1198edf4 C |
64 | if (outboxUrl && checkUrlsSameHost(outboxUrl, actorUrl) !== true) { |
65 | logger.warn('Host mismatch between outbox URL %s and actor URL %s, skipping.', outboxUrl, actorUrl) | |
5c6d985f C |
66 | continue |
67 | } | |
68 | ||
136d7efd | 69 | const byActor = signatureActor || actorsCache[actorUrl] || await getOrCreateAPActor(actorUrl) |
e587e0ec C |
70 | actorsCache[actorUrl] = byActor |
71 | ||
c986175d C |
72 | const activityProcessor = processActivity[activity.type] |
73 | if (activityProcessor === undefined) { | |
74 | logger.warn('Unknown activity type %s.', activity.type, { activityId: activity.id }) | |
75 | continue | |
76 | } | |
77 | ||
16b90975 | 78 | try { |
453e83ea | 79 | await activityProcessor({ activity, byActor, inboxActor, fromFetch }) |
543442a3 C |
80 | |
81 | StatsManager.Instance.addInboxProcessedSuccess(activity.type) | |
16b90975 | 82 | } catch (err) { |
c73e83da | 83 | logger.warn('Cannot process activity %s.', activity.type, { err }) |
543442a3 C |
84 | |
85 | StatsManager.Instance.addInboxProcessedError(activity.type) | |
16b90975 | 86 | } |
c986175d C |
87 | } |
88 | } | |
89 | ||
90 | export { | |
91 | processActivities | |
92 | } |