diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2016-03-19 00:41:29 +0100 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2016-03-19 00:41:29 +0100 |
commit | f97fc9744f7879246ecc04e3f5ec4f358a9d71a2 (patch) | |
tree | 21e1fd4e2ae33fd49e1b76d4d1e6964f1b6284b7 | |
parent | 47d1cb4e2183949e50488187a74e3ce9b3d7d3b8 (diff) |
Use FanOutOnWriteService AFTER processing mentions
-rw-r--r-- | app/models/status.rb | 1 | ||||
-rw-r--r-- | app/services/post_status_service.rb | 5 | ||||
-rw-r--r-- | app/services/process_feed_service.rb | 7 | ||||
-rw-r--r-- | app/services/reblog_service.rb | 5 |
4 files changed, 17 insertions, 1 deletions
diff --git a/app/models/status.rb b/app/models/status.rb index 10f0444e9..7c5cd2f8a 100644 --- a/app/models/status.rb +++ b/app/models/status.rb @@ -78,6 +78,5 @@ class Status < ActiveRecord::Base after_create do self.account.stream_entries.create!(activity: self) - FanOutOnWriteService.new.(self) end end diff --git a/app/services/post_status_service.rb b/app/services/post_status_service.rb index 388639175..e8335639c 100644 --- a/app/services/post_status_service.rb +++ b/app/services/post_status_service.rb @@ -7,6 +7,7 @@ class PostStatusService < BaseService def call(account, text, in_reply_to = nil) status = account.statuses.create!(text: text, thread: in_reply_to) process_mentions_service.(status) + fan_out_on_write_service.(status) account.ping!(account_url(account, format: 'atom'), [Rails.configuration.x.hub_url]) status end @@ -16,4 +17,8 @@ class PostStatusService < BaseService def process_mentions_service @process_mentions_service ||= ProcessMentionsService.new end + + def fan_out_on_write_service + @fan_out_on_write_service ||= FanOutOnWriteService.new + end end diff --git a/app/services/process_feed_service.rb b/app/services/process_feed_service.rb index 9b342499d..7f72ea251 100644 --- a/app/services/process_feed_service.rb +++ b/app/services/process_feed_service.rb @@ -52,6 +52,9 @@ class ProcessFeedService < BaseService end end end + + + fan_out_on_write_service.(status) end end end @@ -166,4 +169,8 @@ class ProcessFeedService < BaseService def update_remote_profile_service @update_remote_profile_service ||= UpdateRemoteProfileService.new end + + def fan_out_on_write_service + @fan_out_on_write_service ||= FanOutOnWriteService.new + end end diff --git a/app/services/reblog_service.rb b/app/services/reblog_service.rb index 086f297f4..7078e3aff 100644 --- a/app/services/reblog_service.rb +++ b/app/services/reblog_service.rb @@ -5,6 +5,7 @@ class ReblogService < BaseService # @return [Status] def call(account, reblogged_status) reblog = account.statuses.create!(reblog: reblogged_status, text: '') + fan_out_on_write_service.(reblog) account.ping!(account_url(account, format: 'atom'), [Rails.configuration.x.hub_url]) return reblog if reblogged_status.local? send_interaction_service.(reblog.stream_entry, reblogged_status.account) @@ -16,4 +17,8 @@ class ReblogService < BaseService def send_interaction_service @send_interaction_service ||= SendInteractionService.new end + + def fan_out_on_write_service + @fan_out_on_write_service ||= FanOutOnWriteService.new + end end |