mirror of
https://git.bsd.gay/fef/nyastodon.git
synced 2025-01-01 07:54:41 +01:00
cd87d7dcef
- `.env.production.sample`: Our sample config file is very different from upstream since it is much more complete. Upstream added documentation for a few env variables. Copied the new variables/documentation from upstream. - `app/lib/feed_manager.rb`: Upstream added a timeline type (hashtags), while glitch-soc already had an extra one (direct messages). Not really a conflict but textually close changes. Ported upstream's changes. - `app/models/custom_emoji.rb`: Upstream upped the custom emoji size limit, while glitch-soc had configurable limits. Upped the default limits accordingly. - `streaming/index.js`: Upstream reworked how hastags were normalized. Minor conflict due to glitch-soc's handling of instance-local posts. Ported upstream's changes.
85 lines
2.1 KiB
Ruby
85 lines
2.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class FeedInsertWorker
|
|
include Sidekiq::Worker
|
|
|
|
def perform(status_id, id, type = 'home', options = {})
|
|
@type = type.to_sym
|
|
@status = Status.find(status_id)
|
|
@options = options.symbolize_keys
|
|
|
|
case @type
|
|
when :home, :tags
|
|
@follower = Account.find(id)
|
|
when :list
|
|
@list = List.find(id)
|
|
@follower = @list.account
|
|
when :direct
|
|
@account = Account.find(id)
|
|
end
|
|
|
|
check_and_insert
|
|
rescue ActiveRecord::RecordNotFound
|
|
true
|
|
end
|
|
|
|
private
|
|
|
|
def check_and_insert
|
|
if feed_filtered?
|
|
perform_unpush if update?
|
|
else
|
|
perform_push
|
|
perform_notify if notify?
|
|
end
|
|
end
|
|
|
|
def feed_filtered?
|
|
case @type
|
|
when :home
|
|
FeedManager.instance.filter?(:home, @status, @follower)
|
|
when :tags
|
|
FeedManager.instance.filter?(:tags, @status, @follower)
|
|
when :list
|
|
FeedManager.instance.filter?(:list, @status, @list)
|
|
when :direct
|
|
FeedManager.instance.filter?(:direct, @status, @account)
|
|
end
|
|
end
|
|
|
|
def notify?
|
|
return false if @type != :home || @status.reblog? || (@status.reply? && @status.in_reply_to_account_id != @status.account_id)
|
|
|
|
Follow.find_by(account: @follower, target_account: @status.account)&.notify?
|
|
end
|
|
|
|
def perform_push
|
|
case @type
|
|
when :home, :tags
|
|
FeedManager.instance.push_to_home(@follower, @status, update: update?)
|
|
when :list
|
|
FeedManager.instance.push_to_list(@list, @status, update: update?)
|
|
when :direct
|
|
FeedManager.instance.push_to_direct(@account, @status, update: update?)
|
|
end
|
|
end
|
|
|
|
def perform_unpush
|
|
case @type
|
|
when :home, :tags
|
|
FeedManager.instance.unpush_from_home(@follower, @status, update: true)
|
|
when :list
|
|
FeedManager.instance.unpush_from_list(@list, @status, update: true)
|
|
when :direct
|
|
FeedManager.instance.unpush_from_direct(@account, @status, update: true)
|
|
end
|
|
end
|
|
|
|
def perform_notify
|
|
LocalNotificationWorker.perform_async(@follower.id, @status.id, 'Status', 'status')
|
|
end
|
|
|
|
def update?
|
|
@options[:update]
|
|
end
|
|
end
|