diff options
author | Thibaut Girka <thib@sitedethib.com> | 2018-12-06 12:44:38 +0100 |
---|---|---|
committer | Thibaut Girka <thib@sitedethib.com> | 2018-12-06 12:44:38 +0100 |
commit | 1df392819d544e62ae9f685020e462c960d31635 (patch) | |
tree | e43bc3a7addbcc044979dbbc1cb44a86d4502efc /app/services/batched_remove_status_service.rb | |
parent | fe9340d95e9ae9a1870e9951e9b00ad5df4cc257 (diff) | |
parent | 155cf126807ab25da4d0e5da55b2d598c981e2ab (diff) |
Merge branch 'master' into glitch-soc/merge-upstream
Diffstat (limited to 'app/services/batched_remove_status_service.rb')
-rw-r--r-- | app/services/batched_remove_status_service.rb | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/app/services/batched_remove_status_service.rb b/app/services/batched_remove_status_service.rb index fc412c7d4..61c408926 100644 --- a/app/services/batched_remove_status_service.rb +++ b/app/services/batched_remove_status_service.rb @@ -9,7 +9,9 @@ class BatchedRemoveStatusService < BaseService # Remove statuses from home feeds # Push delete events to streaming API for home feeds and public feeds # @param [Status] statuses A preferably batched array of statuses - def call(statuses) + # @param [Hash] options + # @option [Boolean] :skip_side_effects + def call(statuses, **options) statuses = Status.where(id: statuses.map(&:id)).includes(:account, :stream_entry).flat_map { |status| [status] + status.reblogs.includes(:account, :stream_entry).to_a } @mentions = statuses.each_with_object({}) { |s, h| h[s.id] = s.active_mentions.includes(:account).to_a } @@ -26,6 +28,8 @@ class BatchedRemoveStatusService < BaseService status.destroy end + return if options[:skip_side_effects] + # Batch by source account statuses.group_by(&:account_id).each_value do |account_statuses| account = account_statuses.first.account |