2019-03-11 01:49:31 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class PollExpirationNotifyWorker
|
|
|
|
include Sidekiq::Worker
|
|
|
|
|
2020-03-31 22:59:03 +03:00
|
|
|
sidekiq_options lock: :until_executed
|
2019-03-11 01:49:31 +02:00
|
|
|
|
|
|
|
def perform(poll_id)
|
2022-01-19 23:37:27 +02:00
|
|
|
@poll = Poll.find(poll_id)
|
2019-03-11 01:49:31 +02:00
|
|
|
|
2022-01-19 23:37:27 +02:00
|
|
|
return if does_not_expire?
|
|
|
|
requeue! && return if not_due_yet?
|
2019-03-11 01:49:31 +02:00
|
|
|
|
2022-01-19 23:37:27 +02:00
|
|
|
notify_remote_voters_and_owner! if @poll.local?
|
|
|
|
notify_local_voters!
|
2019-03-11 01:49:31 +02:00
|
|
|
rescue ActiveRecord::RecordNotFound
|
|
|
|
true
|
|
|
|
end
|
2022-01-19 23:37:27 +02:00
|
|
|
|
|
|
|
def self.remove_from_scheduled(poll_id)
|
|
|
|
queue = Sidekiq::ScheduledSet.new
|
|
|
|
queue.select { |scheduled| scheduled.klass == name && scheduled.args[0] == poll_id }.map(&:delete)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def does_not_expire?
|
|
|
|
@poll.expires_at.nil?
|
|
|
|
end
|
|
|
|
|
|
|
|
def not_due_yet?
|
|
|
|
@poll.expires_at.present? && !@poll.expired?
|
|
|
|
end
|
|
|
|
|
|
|
|
def requeue!
|
|
|
|
PollExpirationNotifyWorker.perform_at(@poll.expires_at + 5.minutes, @poll.id)
|
|
|
|
end
|
|
|
|
|
|
|
|
def notify_remote_voters_and_owner!
|
|
|
|
ActivityPub::DistributePollUpdateWorker.perform_async(@poll.status.id)
|
2022-03-04 02:06:33 +02:00
|
|
|
LocalNotificationWorker.perform_async(@poll.account_id, @poll.id, 'Poll', 'poll')
|
2022-01-19 23:37:27 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def notify_local_voters!
|
2022-03-04 02:06:33 +02:00
|
|
|
@poll.voters.merge(Account.local).select(:id).find_in_batches do |accounts|
|
|
|
|
LocalNotificationWorker.push_bulk(accounts) do |account|
|
|
|
|
[account.id, @poll.id, 'Poll', 'poll']
|
|
|
|
end
|
2022-01-19 23:37:27 +02:00
|
|
|
end
|
|
|
|
end
|
2019-03-11 01:49:31 +02:00
|
|
|
end
|