2018-06-09 23:46:54 +03:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class AfterBlockDomainFromAccountService < BaseService
|
2019-06-05 00:11:18 +03:00
|
|
|
include Payloadable
|
|
|
|
|
2018-06-09 23:46:54 +03:00
|
|
|
# This service does not create an AccountDomainBlock record,
|
|
|
|
# it's meant to be called after such a record has been created
|
|
|
|
# synchronously, to "clean up"
|
|
|
|
def call(account, domain)
|
|
|
|
@account = account
|
|
|
|
@domain = domain
|
|
|
|
|
|
|
|
reject_existing_followers!
|
|
|
|
reject_pending_follow_requests!
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def reject_existing_followers!
|
2018-08-21 13:25:50 +03:00
|
|
|
@account.passive_relationships.where(account: Account.where(domain: @domain)).includes(:account).reorder(nil).find_each do |follow|
|
2018-06-09 23:46:54 +03:00
|
|
|
reject_follow!(follow)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def reject_pending_follow_requests!
|
2018-08-21 13:25:50 +03:00
|
|
|
FollowRequest.where(target_account: @account).where(account: Account.where(domain: @domain)).includes(:account).reorder(nil).find_each do |follow_request|
|
2018-06-09 23:46:54 +03:00
|
|
|
reject_follow!(follow_request)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def reject_follow!(follow)
|
|
|
|
follow.destroy
|
|
|
|
|
|
|
|
return unless follow.account.activitypub?
|
|
|
|
|
2019-06-05 00:11:18 +03:00
|
|
|
ActivityPub::DeliveryWorker.perform_async(Oj.dump(serialize_payload(follow, ActivityPub::RejectFollowSerializer)), @account.id, follow.account.inbox_url)
|
2018-06-09 23:46:54 +03:00
|
|
|
end
|
|
|
|
end
|