1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-08 23:46:14 +01:00
fab-manager/config/initializers/sidekiq.rb

54 lines
1.6 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require 'sidekiq'
require 'sidekiq-scheduler'
2022-07-25 15:13:28 +02:00
require 'sidekiq/middleware/i18n'
redis_host = ENV.fetch('REDIS_HOST', 'localhost')
2016-03-23 18:39:41 +01:00
redis_url = "redis://#{redis_host}:6379"
2015-05-05 03:10:25 +02:00
Sidekiq.configure_server do |config|
2020-06-09 16:23:07 +02:00
config.redis = { url: redis_url }
2015-05-05 03:10:25 +02:00
# client_middleware is also configured in configure_server block
# because jobs running in the Sidekiq server can themselves push
# new jobs to Sidekiq, thus acting as clients
# see https://github.com/sidekiq/sidekiq/wiki/Middleware for more details
2022-03-09 11:29:30 +01:00
config.client_middleware do |chain|
chain.add Sidekiq::Middleware::I18n::Client
2022-03-09 11:29:30 +01:00
chain.add SidekiqUniqueJobs::Middleware::Client
end
config.server_middleware do |chain|
chain.add Sidekiq::Middleware::I18n::Server
2022-03-09 11:29:30 +01:00
chain.add SidekiqUniqueJobs::Middleware::Server
end
SidekiqUniqueJobs::Server.configure(config)
config.on(:startup) do
# load sidekiq-scheduler schedule config
schedule_file = 'config/schedule.yml'
if File.exist?(schedule_file)
rendered_schedule_file = ERB.new(File.read(schedule_file)).result
Sidekiq.schedule = YAML.safe_load(rendered_schedule_file)
SidekiqScheduler::Scheduler.instance.reload_schedule!
end
2016-03-23 18:39:41 +01:00
end
end
2015-05-05 03:10:25 +02:00
2016-03-23 18:39:41 +01:00
Sidekiq.configure_client do |config|
2020-06-09 16:23:07 +02:00
config.redis = { url: redis_url }
2022-03-09 11:29:30 +01:00
config.client_middleware do |chain|
chain.add Sidekiq::Middleware::I18n::Client
2022-03-09 11:29:30 +01:00
chain.add SidekiqUniqueJobs::Middleware::Client
end
2015-05-05 03:10:25 +02:00
end
# Quieting logging in the test environment
if Rails.env.test?
require 'sidekiq/testing'
Sidekiq.logger.level = Logger::ERROR
end