Merge pull request #4980 from tchak/human-readable-cron
Use human readable expressions instead of cron gibberish
This commit is contained in:
commit
d9015c4e3c
19 changed files with 39 additions and 16 deletions
1
Gemfile
1
Gemfile
|
@ -28,6 +28,7 @@ gem 'dotenv-rails', require: 'dotenv/rails-now' # dotenv should always be loaded
|
|||
gem 'flipper'
|
||||
gem 'flipper-active_record'
|
||||
gem 'flipper-ui'
|
||||
gem 'fugit'
|
||||
gem 'geocoder'
|
||||
gem 'gon'
|
||||
gem 'graphiql-rails'
|
||||
|
|
|
@ -203,6 +203,8 @@ GEM
|
|||
http_parser.rb (~> 0.6.0)
|
||||
erubi (1.9.0)
|
||||
erubis (2.7.0)
|
||||
et-orbi (1.2.4)
|
||||
tzinfo
|
||||
ethon (0.11.0)
|
||||
ffi (>= 1.3.0)
|
||||
eventmachine (1.2.7)
|
||||
|
@ -235,6 +237,9 @@ GEM
|
|||
fog-json (>= 1.0)
|
||||
ipaddress (>= 0.8)
|
||||
formatador (0.2.5)
|
||||
fugit (1.3.3)
|
||||
et-orbi (~> 1.1, >= 1.1.8)
|
||||
raabro (~> 1.1)
|
||||
geocoder (1.6.0)
|
||||
globalid (0.4.2)
|
||||
activesupport (>= 4.2.0)
|
||||
|
@ -452,6 +457,7 @@ GEM
|
|||
puma (3.12.4)
|
||||
pundit (2.0.1)
|
||||
activesupport (>= 3.0.0)
|
||||
raabro (1.1.6)
|
||||
rack (2.2.2)
|
||||
rack-attack (6.0.0)
|
||||
rack (>= 1.0, < 3)
|
||||
|
@ -746,6 +752,7 @@ DEPENDENCIES
|
|||
flipper
|
||||
flipper-active_record
|
||||
flipper-ui
|
||||
fugit
|
||||
geocoder
|
||||
gon
|
||||
graphiql-rails
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class AdministrateurActivateBeforeExpirationJob < CronJob
|
||||
self.cron_expression = "0 8 * * *"
|
||||
self.schedule_expression = "every day at 8 am"
|
||||
|
||||
def perform(*args)
|
||||
Administrateur
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class AutoArchiveProcedureJob < CronJob
|
||||
self.cron_expression = "* * * * *"
|
||||
self.schedule_expression = "every 1 minute"
|
||||
|
||||
def perform(*args)
|
||||
Procedure.publiees.where("auto_archive_on <= ?", Time.zone.today).each do |procedure|
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
class CronJob < ApplicationJob
|
||||
queue_as :cron
|
||||
class_attribute :cron_expression
|
||||
class_attribute :schedule_expression
|
||||
|
||||
class << self
|
||||
def schedule
|
||||
|
@ -12,6 +12,10 @@ class CronJob < ApplicationJob
|
|||
delayed_job.destroy if scheduled?
|
||||
end
|
||||
|
||||
def display_schedule
|
||||
pp "#{name}: #{schedule_expression} cron(#{cron_expression})"
|
||||
end
|
||||
|
||||
def scheduled?
|
||||
delayed_job.present?
|
||||
end
|
||||
|
@ -25,5 +29,9 @@ class CronJob < ApplicationJob
|
|||
.where('handler LIKE ?', "%job_class: #{name}%")
|
||||
.first
|
||||
end
|
||||
|
||||
def cron_expression
|
||||
Fugit.do_parse(schedule_expression, multi: :fail).to_cron_s
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class DeclarativeProceduresJob < CronJob
|
||||
self.cron_expression = "* * * * *"
|
||||
self.schedule_expression = "every 1 minute"
|
||||
|
||||
def perform(*args)
|
||||
Procedure.declarative.find_each(&:process_dossiers!)
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class DiscardedDossiersDeletionJob < CronJob
|
||||
self.cron_expression = "0 7 * * *"
|
||||
self.schedule_expression = "every day at 2 am"
|
||||
|
||||
def perform(*args)
|
||||
Dossier.discarded_brouillon_expired.destroy_all
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class DiscardedProceduresDeletionJob < CronJob
|
||||
self.cron_expression = "0 7 * * *"
|
||||
self.schedule_expression = "every day at 1 am"
|
||||
|
||||
def perform(*args)
|
||||
Procedure.discarded_expired.find_each do |procedure|
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class ExpiredDossiersDeletionJob < CronJob
|
||||
self.cron_expression = "0 7 * * *"
|
||||
self.schedule_expression = "every day at 7 am"
|
||||
|
||||
def perform(*args)
|
||||
ExpiredDossiersDeletionService.process_expired_dossiers_brouillon
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class FindDubiousProceduresJob < CronJob
|
||||
self.cron_expression = "0 0 * * *"
|
||||
self.schedule_expression = "every day at midnight"
|
||||
|
||||
FORBIDDEN_KEYWORDS = [
|
||||
'NIR', 'NIRPP', 'race', 'religion',
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class InstructeurEmailNotificationJob < CronJob
|
||||
self.cron_expression = "0 10 * * MON-FRI"
|
||||
self.schedule_expression = "from monday through friday at 10 am"
|
||||
|
||||
def perform(*args)
|
||||
NotificationService.send_instructeur_email_notification
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class NotifyDraftNotSubmittedJob < CronJob
|
||||
self.cron_expression = "0 7 * * *"
|
||||
self.schedule_expression = "from monday through friday at 7 am"
|
||||
|
||||
def perform(*args)
|
||||
Dossier.notify_draft_not_submitted
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class OperationsSignatureJob < CronJob
|
||||
self.cron_expression = "0 6 * * *"
|
||||
self.schedule_expression = "every day at 6 am"
|
||||
|
||||
def perform(*args)
|
||||
last_midnight = Time.zone.today.beginning_of_day
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class PurgeStaleExportsJob < CronJob
|
||||
self.cron_expression = "*/5 * * * *"
|
||||
self.schedule_expression = "every 5 minutes"
|
||||
|
||||
def perform
|
||||
Export.stale.destroy_all
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class PurgeUnattachedBlobsJob < CronJob
|
||||
self.cron_expression = "0 0 * * *"
|
||||
self.schedule_expression = "every day at midnight"
|
||||
|
||||
def perform(*args)
|
||||
ActiveStorage::Blob.unattached
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class UpdateAdministrateurUsageStatisticsJob < CronJob
|
||||
self.cron_expression = "0 10 * * *"
|
||||
self.schedule_expression = "every day at 10 am"
|
||||
|
||||
def perform
|
||||
AdministrateurUsageStatisticsService.new.update_administrateurs
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class WarnExpiringDossiersJob < CronJob
|
||||
self.cron_expression = "0 0 1 * *"
|
||||
self.schedule_expression = "every 1 month at midnight"
|
||||
|
||||
def perform(*args)
|
||||
expiring, expired = Dossier
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
class WeeklyOverviewJob < CronJob
|
||||
self.cron_expression = "0 7 * * MON"
|
||||
self.schedule_expression = "every monday at 7 am"
|
||||
|
||||
def perform(*args)
|
||||
# Feature flipped to avoid mails in staging due to unprocessed dossier
|
||||
|
|
|
@ -5,4 +5,11 @@ namespace :jobs do
|
|||
Dir.glob(glob).each { |f| require f }
|
||||
CronJob.subclasses.each(&:schedule)
|
||||
end
|
||||
|
||||
desc 'Display schedule for all cron jobs'
|
||||
task display_schedule: :environment do
|
||||
glob = Rails.root.join('app', 'jobs', '**', '*_job.rb')
|
||||
Dir.glob(glob).each { |f| require f }
|
||||
CronJob.subclasses.each(&:display_schedule)
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue