2019-01-05 20:43:28 +09:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class Scheduler::ScheduledStatusesScheduler
|
|
|
|
include Sidekiq::Worker
|
|
|
|
|
2023-10-03 17:09:00 +09:00
|
|
|
sidekiq_options retry: 0, lock: :until_executed, lock_ttl: 1.hour.to_i
|
2019-01-05 20:43:28 +09:00
|
|
|
|
|
|
|
def perform
|
2020-01-24 06:00:13 +09:00
|
|
|
publish_scheduled_statuses!
|
|
|
|
publish_scheduled_announcements!
|
|
|
|
unpublish_expired_announcements!
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def publish_scheduled_statuses!
|
2019-01-05 20:43:28 +09:00
|
|
|
due_statuses.find_each do |scheduled_status|
|
2019-01-06 17:21:16 +09:00
|
|
|
PublishScheduledStatusWorker.perform_at(scheduled_status.scheduled_at, scheduled_status.id)
|
2019-01-05 20:43:28 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def due_statuses
|
2024-11-07 19:28:59 +09:00
|
|
|
ScheduledStatus.where(scheduled_at: ..time_due_at)
|
2019-01-05 20:43:28 +09:00
|
|
|
end
|
2020-01-24 06:00:13 +09:00
|
|
|
|
|
|
|
def publish_scheduled_announcements!
|
|
|
|
due_announcements.find_each do |announcement|
|
|
|
|
PublishScheduledAnnouncementWorker.perform_at(announcement.scheduled_at, announcement.id)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def due_announcements
|
2024-11-07 19:28:59 +09:00
|
|
|
Announcement.unpublished.where('scheduled_at IS NOT NULL AND scheduled_at <= ?', time_due_at)
|
2020-01-24 06:00:13 +09:00
|
|
|
end
|
|
|
|
|
|
|
|
def unpublish_expired_announcements!
|
2020-01-27 06:43:18 +09:00
|
|
|
expired_announcements.in_batches.update_all(published: false, scheduled_at: nil)
|
2020-01-24 06:00:13 +09:00
|
|
|
end
|
|
|
|
|
|
|
|
def expired_announcements
|
|
|
|
Announcement.published.where('ends_at IS NOT NULL AND ends_at <= ?', Time.now.utc)
|
|
|
|
end
|
2024-11-07 19:28:59 +09:00
|
|
|
|
|
|
|
def time_due_at
|
|
|
|
Time.now.utc + ScheduledStatus::MINIMUM_OFFSET
|
|
|
|
end
|
2019-01-05 20:43:28 +09:00
|
|
|
end
|