Fix account migration not affecting followers on origin server (#11980)
This commit is contained in:
parent
bd9685f798
commit
368a87755b
|
@ -18,9 +18,7 @@ class Settings::MigrationsController < Settings::BaseController
|
||||||
@migration = current_account.migrations.build(resource_params)
|
@migration = current_account.migrations.build(resource_params)
|
||||||
|
|
||||||
if @migration.save_with_challenge(current_user)
|
if @migration.save_with_challenge(current_user)
|
||||||
current_account.update!(moved_to_account: @migration.target_account)
|
MoveService.new.call(@migration)
|
||||||
ActivityPub::UpdateDistributionWorker.perform_async(current_account.id)
|
|
||||||
ActivityPub::MoveDistributionWorker.perform_async(@migration.id)
|
|
||||||
redirect_to settings_migration_path, notice: I18n.t('migrations.moved_msg', acct: current_account.moved_to_account.acct)
|
redirect_to settings_migration_path, notice: I18n.t('migrations.moved_msg', acct: current_account.moved_to_account.acct)
|
||||||
else
|
else
|
||||||
render :show
|
render :show
|
||||||
|
|
|
@ -19,11 +19,7 @@ class ActivityPub::Activity::Move < ActivityPub::Activity
|
||||||
origin_account.update(moved_to_account: target_account)
|
origin_account.update(moved_to_account: target_account)
|
||||||
|
|
||||||
# Initiate a re-follow for each follower
|
# Initiate a re-follow for each follower
|
||||||
origin_account.followers.local.select(:id).find_in_batches do |follower_accounts|
|
MoveWorker.perform_async(origin_account.id, target_account.id)
|
||||||
UnfollowFollowWorker.push_bulk(follower_accounts.map(&:id)) do |follower_account_id|
|
|
||||||
[follower_account_id, origin_account.id, target_account.id]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
|
@ -0,0 +1,32 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
class MoveService < BaseService
|
||||||
|
def call(migration)
|
||||||
|
@migration = migration
|
||||||
|
@source_account = migration.account
|
||||||
|
@target_account = migration.target_account
|
||||||
|
|
||||||
|
update_redirect!
|
||||||
|
process_local_relationships!
|
||||||
|
distribute_update!
|
||||||
|
distribute_move!
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def update_redirect!
|
||||||
|
@source_account.update!(moved_to_account: @target_account)
|
||||||
|
end
|
||||||
|
|
||||||
|
def process_local_relationships!
|
||||||
|
MoveWorker.perform_async(@source_account.id, @target_account.id)
|
||||||
|
end
|
||||||
|
|
||||||
|
def distribute_update!
|
||||||
|
ActivityPub::UpdateDistributionWorker.perform_async(@source_account.id)
|
||||||
|
end
|
||||||
|
|
||||||
|
def distribute_move!
|
||||||
|
ActivityPub::MoveDistributionWorker.perform_async(@migration.id)
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,33 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
class MoveWorker
|
||||||
|
include Sidekiq::Worker
|
||||||
|
|
||||||
|
def perform(source_account_id, target_account_id)
|
||||||
|
@source_account = Account.find(source_account_id)
|
||||||
|
@target_account = Account.find(target_account_id)
|
||||||
|
|
||||||
|
if @target_account.local?
|
||||||
|
rewrite_follows!
|
||||||
|
else
|
||||||
|
queue_follow_unfollows!
|
||||||
|
end
|
||||||
|
rescue ActiveRecord::RecordNotFound
|
||||||
|
true
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def rewrite_follows!
|
||||||
|
@source_account.passive_relationships
|
||||||
|
.where(account: Account.local)
|
||||||
|
.in_batches
|
||||||
|
.update_all(target_account: @target_account)
|
||||||
|
end
|
||||||
|
|
||||||
|
def queue_follow_unfollows!
|
||||||
|
@source_account.followers.local.select(:id).find_in_batches do |accounts|
|
||||||
|
UnfollowFollowWorker.push_bulk(accounts.map(&:id)) { |follower_id| [follower_id, @source_account.id, @target_account.id] }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Reference in New Issue