import { ActivityAccept } from '../../../../shared/models/activitypub'
import { ActorModel } from '../../../models/activitypub/actor'
import { ActorFollowModel } from '../../../models/activitypub/actor-follow'
-import { addFetchOutboxJob } from '../fetch'
+import { addFetchOutboxJob } from '../actor'
-async function processAcceptActivity (activity: ActivityAccept, inboxActor?: ActorModel) {
+async function processAcceptActivity (activity: ActivityAccept, targetActor: ActorModel, inboxActor?: ActorModel) {
if (inboxActor === undefined) throw new Error('Need to accept on explicit inbox.')
- const targetActor = await ActorModel.loadByUrl(activity.actor)
-
return processAccept(inboxActor, targetActor)
}
if (follow.state !== 'accepted') {
follow.set('state', 'accepted')
await follow.save()
+
await addFetchOutboxJob(targetActor)
}
}