|
|
@ -40,6 +40,7 @@ class OStatus::Activity::Creation < OStatus::Activity::Base |
|
|
|
text: content, |
|
|
|
text: content, |
|
|
|
spoiler_text: content_warning, |
|
|
|
spoiler_text: content_warning, |
|
|
|
created_at: published, |
|
|
|
created_at: published, |
|
|
|
|
|
|
|
override_timestamps: @options[:override_timestamps], |
|
|
|
reply: thread?, |
|
|
|
reply: thread?, |
|
|
|
language: content_language, |
|
|
|
language: content_language, |
|
|
|
visibility: visibility_scope, |
|
|
|
visibility: visibility_scope, |
|
|
@ -61,7 +62,14 @@ class OStatus::Activity::Creation < OStatus::Activity::Base |
|
|
|
Rails.logger.debug "Queuing remote status #{status.id} (#{id}) for distribution" |
|
|
|
Rails.logger.debug "Queuing remote status #{status.id} (#{id}) for distribution" |
|
|
|
|
|
|
|
|
|
|
|
LinkCrawlWorker.perform_async(status.id) unless status.spoiler_text? |
|
|
|
LinkCrawlWorker.perform_async(status.id) unless status.spoiler_text? |
|
|
|
DistributionWorker.perform_async(status.id) if status.within_realtime_window? |
|
|
|
|
|
|
|
|
|
|
|
# Only continue if the status is supposed to have arrived in real-time. |
|
|
|
|
|
|
|
# Note that if @options[:override_timestamps] isn't set, the status |
|
|
|
|
|
|
|
# may have a lower snowflake id than other existing statuses, potentially |
|
|
|
|
|
|
|
# "hiding" it from paginated API calls |
|
|
|
|
|
|
|
return status unless @options[:override_timestamps] || status.within_realtime_window? |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DistributionWorker.perform_async(status.id) |
|
|
|
|
|
|
|
|
|
|
|
status |
|
|
|
status |
|
|
|
end |
|
|
|
end |
|
|
|