]> cat aescling's git repositories - mastodon.git/commitdiff
Forward ActivityPub deletes to followers of rebloggers (#4706)
authorEugen Rochko <eugen@zeonfederated.com>
Sat, 26 Aug 2017 16:52:53 +0000 (18:52 +0200)
committerGitHub <noreply@github.com>
Sat, 26 Aug 2017 16:52:53 +0000 (18:52 +0200)
app/lib/activitypub/activity/delete.rb
app/workers/activitypub/raw_distribution_worker.rb [new file with mode: 0644]

index a1598dfd32a99fc3049a6f1b2e86819f952260c3..e7eb53a02076e0f10a596df841b6376b02f4dadc 100644 (file)
@@ -8,7 +8,24 @@ class ActivityPub::Activity::Delete < ActivityPub::Activity
     if status.nil?
       delete_later!(object_uri)
     else
-      RemoveStatusService.new.call(status)
+      forward_for_reblogs(status)
+      delete_now!(status)
     end
   end
+
+  private
+
+  def forward_for_reblogs(status)
+    ActivityPub::RawDistributionWorker.push_bulk(status.reblogs.includes(:account).references(:account).merge(Account.local).pluck(:account_id)) do |account|
+      [payload, account.id]
+    end
+  end
+
+  def delete_now!(status)
+    RemoveStatusService.new.call(status)
+  end
+
+  def payload
+    @payload ||= Oj.dump(@json)
+  end
 end
diff --git a/app/workers/activitypub/raw_distribution_worker.rb b/app/workers/activitypub/raw_distribution_worker.rb
new file mode 100644 (file)
index 0000000..d73466f
--- /dev/null
@@ -0,0 +1,23 @@
+# frozen_string_literal: true
+
+class ActivityPub::RawDistributionWorker
+  include Sidekiq::Worker
+
+  sidekiq_options queue: 'push'
+
+  def perform(json, source_account_id)
+    @account = Account.find(source_account_id)
+
+    ActivityPub::DeliveryWorker.push_bulk(inboxes) do |inbox_url|
+      [json, @account.id, inbox_url]
+    end
+  rescue ActiveRecord::RecordNotFound
+    true
+  end
+
+  private
+
+  def inboxes
+    @inboxes ||= @account.followers.inboxes
+  end
+end