diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2019-03-16 11:23:22 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-03-16 11:23:22 +0100 |
commit | 1c113fd72df18999de1d6f09fa3790dd1f715506 (patch) | |
tree | 6a2683eb7d63cca3e568f6f2786f77e606320bb1 /app/models/form | |
parent | 8da5b8e6695e3bcca8eb4bca754faef83a6656eb (diff) |
Add relationship manager UI (#10268)
Diffstat (limited to 'app/models/form')
-rw-r--r-- | app/models/form/account_batch.rb | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/app/models/form/account_batch.rb b/app/models/form/account_batch.rb new file mode 100644 index 000000000..60eaaf0e2 --- /dev/null +++ b/app/models/form/account_batch.rb @@ -0,0 +1,60 @@ +# frozen_string_literal: true + +class Form::AccountBatch + include ActiveModel::Model + + attr_accessor :account_ids, :action, :current_account + + def save + case action + when 'unfollow' + unfollow! + when 'remove_from_followers' + remove_from_followers! + when 'block_domains' + block_domains! + end + end + + private + + def unfollow! + accounts.find_each do |target_account| + UnfollowService.new.call(current_account, target_account) + end + end + + def remove_from_followers! + current_account.passive_relationships.where(account_id: account_ids).find_each do |follow| + reject_follow!(follow) + end + end + + def block_domains! + AfterAccountDomainBlockWorker.push_bulk(account_domains) do |domain| + [current_account.id, domain] + end + end + + def account_domains + accounts.pluck(Arel.sql('distinct domain')).compact + end + + def accounts + Account.where(id: account_ids) + end + + def reject_follow!(follow) + follow.destroy + + return unless follow.account.activitypub? + + json = ActiveModelSerializers::SerializableResource.new( + follow, + serializer: ActivityPub::RejectFollowSerializer, + adapter: ActivityPub::Adapter + ).to_json + + ActivityPub::DeliveryWorker.perform_async(json, current_account.id, follow.account.inbox_url) + end +end |