mirror of https://github.com/mastodon/mastodon
Change lists to reflect added and removed users retroactively (#32930)
parent
f2976ec9a4
commit
2b5faa2ba3
@ -0,0 +1,33 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
class AddAccountsToListService < BaseService
|
||||||
|
def call(list, accounts)
|
||||||
|
@list = list
|
||||||
|
@accounts = accounts
|
||||||
|
|
||||||
|
return if @accounts.empty?
|
||||||
|
|
||||||
|
update_list!
|
||||||
|
merge_into_list!
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def update_list!
|
||||||
|
ApplicationRecord.transaction do
|
||||||
|
@accounts.each do |account|
|
||||||
|
@list.accounts << account
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def merge_into_list!
|
||||||
|
MergeWorker.push_bulk(merge_account_ids) do |account_id|
|
||||||
|
[account_id, @list.id, 'list']
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def merge_account_ids
|
||||||
|
ListAccount.where(list: @list, account: @accounts).where.not(follow_id: nil).pluck(:account_id)
|
||||||
|
end
|
||||||
|
end
|
@ -0,0 +1,29 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
class RemoveAccountsFromListService < BaseService
|
||||||
|
def call(list, accounts)
|
||||||
|
@list = list
|
||||||
|
@accounts = accounts
|
||||||
|
|
||||||
|
return if @accounts.empty?
|
||||||
|
|
||||||
|
unmerge_from_list!
|
||||||
|
update_list!
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def update_list!
|
||||||
|
ListAccount.where(list: @list, account: @accounts).destroy_all
|
||||||
|
end
|
||||||
|
|
||||||
|
def unmerge_from_list!
|
||||||
|
UnmergeWorker.push_bulk(unmerge_account_ids) do |account_id|
|
||||||
|
[account_id, @list.id, 'list']
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def unmerge_account_ids
|
||||||
|
ListAccount.where(list: @list, account: @accounts).where.not(follow_id: nil).pluck(:account_id)
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue