glitch-social/app/services/fan_out_on_write_service.rb

59 lines
1.9 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
class FanOutOnWriteService < BaseService
# Push a status into home and mentions feeds
# @param [Status] status
def call(status)
deliver_to_self(status) if status.account.local?
deliver_to_followers(status)
deliver_to_mentioned(status)
2016-11-05 14:20:05 +00:00
return if status.account.silenced? || !status.public_visibility?
2016-11-05 14:20:05 +00:00
deliver_to_hashtags(status)
2016-10-07 15:00:11 +01:00
deliver_to_public(status)
end
private
def deliver_to_self(status)
2016-11-06 14:56:34 +00:00
Rails.logger.debug "Delivering status #{status.id} to author"
FeedManager.instance.push(:home, status.account, status)
end
def deliver_to_followers(status)
2016-11-06 14:56:34 +00:00
Rails.logger.debug "Delivering status #{status.id} to followers"
status.account.followers.where(domain: nil).joins(:user).where('users.current_sign_in_at > ?', 14.days.ago).find_each do |follower|
next if FeedManager.instance.filter?(:home, status, follower)
FeedManager.instance.push(:home, follower, status)
end
end
def deliver_to_mentioned(status)
2016-11-06 14:56:34 +00:00
Rails.logger.debug "Delivering status #{status.id} to mentioned accounts"
status.mentions.includes(:account).each do |mention|
mentioned_account = mention.account
2016-11-08 01:08:32 +00:00
next if !mentioned_account.local? || FeedManager.instance.filter?(:mentions, status, mentioned_account)
FeedManager.instance.push(:mentions, mentioned_account, status)
end
end
2016-10-07 15:00:11 +01:00
2016-11-05 14:20:05 +00:00
def deliver_to_hashtags(status)
return if status.reblog? || status.reply?
2016-11-06 14:56:34 +00:00
Rails.logger.debug "Delivering status #{status.id} to hashtags"
2016-11-05 14:20:05 +00:00
status.tags.find_each do |tag|
FeedManager.instance.broadcast("hashtag:#{tag.name}", type: 'update', id: status.id)
2016-11-05 14:20:05 +00:00
end
end
2016-10-07 15:00:11 +01:00
def deliver_to_public(status)
return if status.reblog? || status.reply?
2016-11-06 14:56:34 +00:00
Rails.logger.debug "Delivering status #{status.id} to public timeline"
FeedManager.instance.broadcast(:public, type: 'update', id: status.id)
2016-10-07 15:00:11 +01:00
end
end