-import { Transaction } from 'sequelize'
-import { ActivityAccept } from '../../../../shared/models/activitypub/activity'
-import { AccountInstance } from '../../../models'
-import { AccountFollowInstance } from '../../../models/account/account-follow-interface'
-import { unicastTo } from './misc'
-import { getAccountFollowAcceptActivityPubUrl } from '../../../helpers/activitypub'
+import { ActivityAccept, ActivityFollow } from '@shared/models'
+import { logger } from '../../../helpers/logger'
+import { MActor, MActorFollowActors } from '../../../types/models'
+import { getLocalActorFollowAcceptActivityPubUrl } from '../url'
+import { buildFollowActivity } from './send-follow'
+import { unicastTo } from './shared/send-utils'
+
+function sendAccept (actorFollow: MActorFollowActors) {
+ const follower = actorFollow.ActorFollower
+ const me = actorFollow.ActorFollowing
+
+ if (!follower.serverId) { // This should never happen
+ logger.warn('Do not sending accept to local follower.')
+ return
+ }
+
+ logger.info('Creating job to accept follower %s.', follower.url)
-async function sendAccept (accountFollow: AccountFollowInstance, t: Transaction) {
- const follower = accountFollow.AccountFollower
- const me = accountFollow.AccountFollowing
+ const followData = buildFollowActivity(actorFollow.url, follower, me)
- const url = getAccountFollowAcceptActivityPubUrl(accountFollow)
- const data = await acceptActivityData(url, me)
+ const url = getLocalActorFollowAcceptActivityPubUrl(actorFollow)
+ const data = buildAcceptActivity(url, me, followData)
- return unicastTo(data, me, follower.inboxUrl, t)
+ return unicastTo({
+ data,
+ byActor: me,
+ toActorUrl: follower.inboxUrl,
+ contextType: 'Accept'
+ })
}
// ---------------------------------------------------------------------------
// ---------------------------------------------------------------------------
-async function acceptActivityData (url: string, byAccount: AccountInstance) {
- const activity: ActivityAccept = {
+function buildAcceptActivity (url: string, byActor: MActor, followActivityData: ActivityFollow): ActivityAccept {
+ return {
type: 'Accept',
id: url,
- actor: byAccount.url
+ actor: byActor.url,
+ object: followActivityData
}
-
- return activity
}