]>
Commit | Line | Data |
---|---|---|
e12a0092 | 1 | import { ActivityAccept, ActivityFollow } from '../../../../shared/models/activitypub' |
e12a0092 | 2 | import { getActorFollowAcceptActivityPubUrl, getActorFollowActivityPubUrl } from '../url' |
e251f170 | 3 | import { unicastTo } from './utils' |
c48e82b5 | 4 | import { buildFollowActivity } from './send-follow' |
8e0fd45e | 5 | import { logger } from '../../../helpers/logger' |
453e83ea | 6 | import { MActor, MActorFollowActors } from '../../../typings/models' |
54141398 | 7 | |
453e83ea | 8 | async function sendAccept (actorFollow: MActorFollowActors) { |
50d6de9c C |
9 | const follower = actorFollow.ActorFollower |
10 | const me = actorFollow.ActorFollowing | |
54141398 | 11 | |
06a05d5f C |
12 | if (!follower.serverId) { // This should never happen |
13 | logger.warn('Do not sending accept to local follower.') | |
14 | return | |
15 | } | |
16 | ||
8e0fd45e C |
17 | logger.info('Creating job to accept follower %s.', follower.url) |
18 | ||
5b9c965d | 19 | const followUrl = getActorFollowActivityPubUrl(follower, me) |
c48e82b5 | 20 | const followData = buildFollowActivity(followUrl, follower, me) |
e12a0092 | 21 | |
50d6de9c | 22 | const url = getActorFollowAcceptActivityPubUrl(actorFollow) |
c48e82b5 | 23 | const data = buildAcceptActivity(url, me, followData) |
54141398 | 24 | |
94a5ff8a | 25 | return unicastTo(data, me, follower.inboxUrl) |
54141398 C |
26 | } |
27 | ||
28 | // --------------------------------------------------------------------------- | |
29 | ||
30 | export { | |
31 | sendAccept | |
32 | } | |
33 | ||
34 | // --------------------------------------------------------------------------- | |
35 | ||
453e83ea | 36 | function buildAcceptActivity (url: string, byActor: MActor, followActivityData: ActivityFollow): ActivityAccept { |
50d6de9c | 37 | return { |
54141398 C |
38 | type: 'Accept', |
39 | id: url, | |
e12a0092 C |
40 | actor: byActor.url, |
41 | object: followActivityData | |
54141398 | 42 | } |
54141398 | 43 | } |