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-05-20 18:37:36 +09:00
|
|
|
ScheduledStatus.where(scheduled_at: ..Time.now.utc + PostStatusService::MIN_SCHEDULE_OFFSET)
|
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
|
|
|
|
Announcement.unpublished.where('scheduled_at IS NOT NULL AND scheduled_at <= ?', Time.now.utc + PostStatusService::MIN_SCHEDULE_OFFSET)
|
|
|
|
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
|
2019-01-05 20:43:28 +09:00
|
|
|
end
|