--- /dev/null
+class RejectFollowingBlockedUsers < ActiveRecord::Migration[5.2]
+ disable_ddl_transaction!
+
+ def up
+ blocked_follows = Follow.find_by_sql(<<-SQL)
+ select f.* from follows f
+ inner join blocks b on
+ f.account_id = b.target_account_id and
+ f.target_account_id = b.account_id
+ SQL
+
+ domain_blocked_follows = Follow.find_by_sql(<<-SQL)
+ select f.* from follows f
+ inner join accounts following on f.account_id = following.id
+ inner join account_domain_blocks b on
+ lower(b.domain) = lower(following.domain) and
+ f.target_account_id = b.account_id
+ SQL
+
+ follows = (blocked_follows + domain_blocked_follows).uniq
+ say "Destroying #{follows.size} blocked follow relationships..."
+
+ follows.each do |follow|
+ blocked_account = follow.account
+ followed_acccount = follow.target_account
+
+ next follow.destroy! if blocked_account.local?
+
+ reject_follow_json = Oj.dump(ActivityPub::LinkedDataSignature.new(ActiveModelSerializers::SerializableResource.new(follow, serializer: ActivityPub::RejectFollowSerializer, adapter: ActivityPub::Adapter).as_json).sign!(followed_acccount))
+
+ ActivityPub::DeliveryWorker.perform_async(reject_follow_json, followed_acccount, blocked_account.inbox_url)
+
+ follow.destroy!
+ end
+ end
+
+ def down
+ raise ActiveRecord::IrreversibleMigration
+ end
+end