2020-11-24 03:50:16 +11:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2023-12-01 22:00:41 +11:00
|
|
|
module Account::Merging
|
2020-11-24 03:50:16 +11:00
|
|
|
extend ActiveSupport::Concern
|
|
|
|
|
|
|
|
def merge_with!(other_account)
|
|
|
|
# Since it's the same remote resource, the remote resource likely
|
|
|
|
# already believes we are following/blocking, so it's safe to
|
|
|
|
# re-attribute the relationships too. However, during the presence
|
|
|
|
# of the index bug users could have *also* followed the reference
|
|
|
|
# account already, therefore mass update will not work and we need
|
|
|
|
# to check for (and skip past) uniqueness errors
|
|
|
|
|
|
|
|
owned_classes = [
|
|
|
|
Status, StatusPin, MediaAttachment, Poll, Report, Tombstone, Favourite,
|
2021-11-26 15:58:18 +11:00
|
|
|
Follow, FollowRequest, Block, Mute,
|
2020-11-24 03:50:16 +11:00
|
|
|
AccountModerationNote, AccountPin, AccountStat, ListAccount,
|
2022-03-12 18:33:11 +11:00
|
|
|
PollVote, Mention, AccountDeletionRequest, AccountNote, FollowRecommendationSuppression,
|
|
|
|
Appeal
|
2020-11-24 03:50:16 +11:00
|
|
|
]
|
|
|
|
|
|
|
|
owned_classes.each do |klass|
|
2023-09-05 23:37:23 +10:00
|
|
|
klass.where(account_id: other_account.id).reorder(nil).find_each do |record|
|
2023-02-19 09:09:40 +11:00
|
|
|
record.update_attribute(:account_id, id)
|
|
|
|
rescue ActiveRecord::RecordNotUnique
|
|
|
|
next
|
2020-11-24 03:50:16 +11:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2024-03-23 03:21:53 +11:00
|
|
|
[
|
|
|
|
Notification, NotificationPermission, NotificationRequest
|
|
|
|
].each do |klass|
|
|
|
|
klass.where(from_account_id: other_account.id).reorder(nil).find_each do |record|
|
|
|
|
record.update_attribute(:from_account_id, id)
|
|
|
|
rescue ActiveRecord::RecordNotUnique
|
|
|
|
next
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-12-04 12:23:51 +11:00
|
|
|
target_classes = [
|
|
|
|
Follow, FollowRequest, Block, Mute, AccountModerationNote, AccountPin,
|
|
|
|
AccountNote
|
|
|
|
]
|
2020-11-24 03:50:16 +11:00
|
|
|
|
|
|
|
target_classes.each do |klass|
|
2023-09-05 23:37:23 +10:00
|
|
|
klass.where(target_account_id: other_account.id).reorder(nil).find_each do |record|
|
2023-02-19 09:09:40 +11:00
|
|
|
record.update_attribute(:target_account_id, id)
|
|
|
|
rescue ActiveRecord::RecordNotUnique
|
|
|
|
next
|
2020-11-24 03:50:16 +11:00
|
|
|
end
|
|
|
|
end
|
2020-12-03 07:20:00 +11:00
|
|
|
|
2021-05-13 07:19:44 +10:00
|
|
|
CanonicalEmailBlock.where(reference_account_id: other_account.id).find_each do |record|
|
|
|
|
record.update_attribute(:reference_account_id, id)
|
|
|
|
end
|
|
|
|
|
2022-03-12 18:33:11 +11:00
|
|
|
Appeal.where(account_warning_id: other_account.id).find_each do |record|
|
|
|
|
record.update_attribute(:account_warning_id, id)
|
|
|
|
end
|
|
|
|
|
2024-03-21 19:36:49 +11:00
|
|
|
SeveredRelationship.about_local_account(other_account).reorder(nil).find_each do |record|
|
2024-03-21 02:37:21 +11:00
|
|
|
record.update_attribute(:local_account_id, id)
|
|
|
|
rescue ActiveRecord::RecordNotUnique
|
|
|
|
next
|
|
|
|
end
|
|
|
|
|
2024-03-21 19:36:49 +11:00
|
|
|
SeveredRelationship.about_remote_account(other_account).reorder(nil).find_each do |record|
|
2024-03-21 02:37:21 +11:00
|
|
|
record.update_attribute(:remote_account_id, id)
|
|
|
|
rescue ActiveRecord::RecordNotUnique
|
|
|
|
next
|
|
|
|
end
|
|
|
|
|
2020-12-03 07:20:00 +11:00
|
|
|
# Some follow relationships have moved, so the cache is stale
|
|
|
|
Rails.cache.delete_matched("followers_hash:#{id}:*")
|
|
|
|
Rails.cache.delete_matched("relationships:#{id}:*")
|
|
|
|
Rails.cache.delete_matched("relationships:*:#{id}")
|
2020-11-24 03:50:16 +11:00
|
|
|
end
|
|
|
|
end
|