diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2019-09-29 16:23:13 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-09-29 16:23:13 +0200 |
commit | 368a87755b4b12c37deb415e10e03c709012f698 (patch) | |
tree | f76c97df7f3ea63122af24f6181dd5d9eb6f1c56 /app/workers | |
parent | bd9685f7980838ecc675af20cf52ef1e686d98d6 (diff) |
Fix account migration not affecting followers on origin server (#11980)
Diffstat (limited to 'app/workers')
-rw-r--r-- | app/workers/move_worker.rb | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/app/workers/move_worker.rb b/app/workers/move_worker.rb new file mode 100644 index 000000000..22788716f --- /dev/null +++ b/app/workers/move_worker.rb @@ -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 |