Conflicts: - `.github/workflows/build-image.yml`: Upstream switched to pushing to both DockerHub and GitHub Container Repository, while glitch-soc was already pushing to the latter only. Updated our configuration to be slightly more consistent with upstream's naming and styling, but kept our behavior. - `Gemfile.lock`: Updated dependencies textually too close to glitch-soc only hcaptcha dependency. Updated dependencies as upstream did. - `README.md`: Upstream updated its README, but we have a completely different one. Kept our README, though it probably should be reworked at some point. - `app/views/auth/sessions/two_factor.html.haml`: Minor style fix upstream that's on a line glitch-soc removed because of its different theming system. Kept our file as is. - `spec/controllers/health_controller_spec.rb`: This file apparently did not exist upstream, upstream created it with different contents but it is functionally the same. Switched to upstream's version of the file. - `spec/presenters/instance_presenter_spec.rb`: Upstream changed the specs around `GITHUB_REPOSITORY`, while glitch-soc had its own code because it's a fork and does not have the same default source URL. Took upstream's change, but with glitch-soc's repo as the default case. - `yarn.lock`: Upstream dependencies textually too close to a glitch-soc only one. Updated dependencies as upstream did.
55 lines
1.4 KiB
Ruby
55 lines
1.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class ActivityPub::DistributePollUpdateWorker
|
|
include Sidekiq::Worker
|
|
include Payloadable
|
|
|
|
sidekiq_options queue: 'push', lock: :until_executed, retry: 0
|
|
|
|
def perform(status_id)
|
|
@status = Status.find(status_id)
|
|
@account = @status.account
|
|
|
|
return if @status.preloadable_poll.nil? || @status.local_only?
|
|
|
|
ActivityPub::DeliveryWorker.push_bulk(inboxes, limit: 1_000) do |inbox_url|
|
|
[payload, @account.id, inbox_url]
|
|
end
|
|
|
|
relay! if relayable?
|
|
rescue ActiveRecord::RecordNotFound
|
|
true
|
|
end
|
|
|
|
private
|
|
|
|
def relayable?
|
|
@status.public_visibility?
|
|
end
|
|
|
|
def inboxes
|
|
return @inboxes if defined?(@inboxes)
|
|
|
|
@inboxes = [@status.mentions, @status.reblogs, @status.preloadable_poll.votes].flat_map do |relation|
|
|
relation.includes(:account).map do |record|
|
|
record.account.preferred_inbox_url if !record.account.local? && record.account.activitypub?
|
|
end
|
|
end
|
|
|
|
@inboxes.concat(@account.followers.inboxes) unless @status.direct_visibility?
|
|
@inboxes.uniq!
|
|
@inboxes.compact!
|
|
@inboxes
|
|
end
|
|
|
|
def payload
|
|
@payload ||= Oj.dump(serialize_payload(@status, ActivityPub::UpdatePollSerializer, signer: @account))
|
|
end
|
|
|
|
def relay!
|
|
ActivityPub::DeliveryWorker.push_bulk(Relay.enabled.pluck(:inbox_url)) do |inbox_url|
|
|
[payload, @account.id, inbox_url]
|
|
end
|
|
end
|
|
end
|