]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/lib/activitypub/process/process-follow.ts
Add state and moderationComment for abuses on server side
[github/Chocobozzz/PeerTube.git] / server / lib / activitypub / process / process-follow.ts
CommitLineData
3fd3ab2d 1import { ActivityFollow } from '../../../../shared/models/activitypub'
da854ddd
C
2import { retryTransactionWrapper } from '../../../helpers/database-utils'
3import { logger } from '../../../helpers/logger'
3fd3ab2d 4import { sequelizeTypescript } from '../../../initializers'
50d6de9c
C
5import { ActorModel } from '../../../models/activitypub/actor'
6import { ActorFollowModel } from '../../../models/activitypub/actor-follow'
7import { getOrCreateActorAndServerAndModel } from '../actor'
3fd3ab2d 8import { sendAccept } from '../send'
7a7724e6
C
9
10async function processFollowActivity (activity: ActivityFollow) {
11 const activityObject = activity.object
50d6de9c 12 const actor = await getOrCreateActorAndServerAndModel(activity.actor)
7a7724e6 13
90d4bb81 14 return retryTransactionWrapper(processFollow, actor, activityObject)
7a7724e6
C
15}
16
17// ---------------------------------------------------------------------------
18
19export {
20 processFollowActivity
21}
22
23// ---------------------------------------------------------------------------
24
90d4bb81 25async function processFollow (actor: ActorModel, targetActorURL: string) {
3fd3ab2d 26 await sequelizeTypescript.transaction(async t => {
50d6de9c 27 const targetActor = await ActorModel.loadByUrl(targetActorURL, t)
ce548a10 28
50d6de9c
C
29 if (!targetActor) throw new Error('Unknown actor')
30 if (targetActor.isOwned() === false) throw new Error('This is not a local actor.')
7a7724e6 31
50d6de9c 32 const [ actorFollow ] = await ActorFollowModel.findOrCreate({
350e31d6 33 where: {
50d6de9c
C
34 actorId: actor.id,
35 targetActorId: targetActor.id
350e31d6
C
36 },
37 defaults: {
50d6de9c
C
38 actorId: actor.id,
39 targetActorId: targetActor.id,
350e31d6
C
40 state: 'accepted'
41 },
ce548a10 42 transaction: t
350e31d6 43 })
40ff5707 44
32b2b43c
C
45 actorFollow.ActorFollower = actor
46 actorFollow.ActorFollowing = targetActor
47
50d6de9c
C
48 if (actorFollow.state !== 'accepted') {
49 actorFollow.state = 'accepted'
50 await actorFollow.save({ transaction: t })
40ff5707
C
51 }
52
50d6de9c
C
53 actorFollow.ActorFollower = actor
54 actorFollow.ActorFollowing = targetActor
ce548a10 55
50d6de9c 56 // Target sends to actor he accepted the follow request
94a5ff8a 57 return sendAccept(actorFollow)
7a7724e6 58 })
ce548a10 59
85414add 60 logger.info('Actor %s is followed by actor %s.', targetActorURL, actor.url)
7a7724e6 61}