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