X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Flib%2Factivitypub%2Fprocess%2Fprocess-follow.ts;h=38d684512e1ccbdc6f25b2a5b151cf43eb7c06c5;hb=213e30ef90806369529684ac9c247d73b8dc7928;hp=7eb7e828d00b91d87b6d45571ad3e94746768b5e;hpb=26d6bf6533023326fa017812cf31bbe20c752d36;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/lib/activitypub/process/process-follow.ts b/server/lib/activitypub/process/process-follow.ts index 7eb7e828d..38d684512 100644 --- a/server/lib/activitypub/process/process-follow.ts +++ b/server/lib/activitypub/process/process-follow.ts @@ -15,9 +15,11 @@ import { getServerActor } from '@server/models/application/application' async function processFollowActivity (options: APProcessorOptions) { const { activity, byActor } = options - const activityObject = getAPId(activity.object) - return retryTransactionWrapper(processFollow, byActor, activityObject) + const activityId = activity.id + const objectId = getAPId(activity.object) + + return retryTransactionWrapper(processFollow, byActor, activityId, objectId) } // --------------------------------------------------------------------------- @@ -28,7 +30,7 @@ export { // --------------------------------------------------------------------------- -async function processFollow (byActor: MActorSignature, targetActorURL: string) { +async function processFollow (byActor: MActorSignature, activityId: string, targetActorURL: string) { const { actorFollow, created, isFollowingInstance, targetActor } = await sequelizeTypescript.transaction(async t => { const targetActor = await ActorModel.loadByUrlAndPopulateAccountAndChannel(targetActorURL, t) @@ -41,7 +43,7 @@ async function processFollow (byActor: MActorSignature, targetActorURL: string) if (isFollowingInstance && CONFIG.FOLLOWERS.INSTANCE.ENABLED === false) { logger.info('Rejecting %s because instance followers are disabled.', targetActor.url) - await sendReject(byActor, targetActor) + await sendReject(activityId, byActor, targetActor) return { actorFollow: undefined as MActorFollowActors } } @@ -54,7 +56,11 @@ async function processFollow (byActor: MActorSignature, targetActorURL: string) defaults: { actorId: byActor.id, targetActorId: targetActor.id, - state: CONFIG.FOLLOWERS.INSTANCE.MANUAL_APPROVAL ? 'pending' : 'accepted' + url: activityId, + + state: CONFIG.FOLLOWERS.INSTANCE.MANUAL_APPROVAL + ? 'pending' + : 'accepted' }, transaction: t }) @@ -63,6 +69,13 @@ async function processFollow (byActor: MActorSignature, targetActorURL: string) // Or if the instance automatically accepts followers if (actorFollow.state !== 'accepted' && (isFollowingInstance === false || CONFIG.FOLLOWERS.INSTANCE.MANUAL_APPROVAL === false)) { actorFollow.state = 'accepted' + + await actorFollow.save({ transaction: t }) + } + + // Before PeerTube V3 we did not save the follow ID. Try to fix these old follows + if (!actorFollow.url) { + actorFollow.url = activityId await actorFollow.save({ transaction: t }) }