Module: Resque::Plugins::CustomLogger

Defined in:
lib/resque/plugins/custom_logger.rb

Instance Method Summary collapse

Instance Method Details

#before_perform(*args) ⇒ Object



9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# File 'lib/resque/plugins/custom_logger.rb', line 9

def before_perform(*args)
  Rails.logger.with_fields = { trace_id: SecureRandom.uuid, name: "RailsWorker"} if Rails.logger.class.to_s == 'Ougai::Logger' && ZuoraConnect.configuration.json_logging
  case args.class.to_s
  when "Array"
    if args.first.class == Hash
      data = args.first.merge({:worker_class => self.to_s})
    else
      data = {:worker_class => self.to_s, :args => args}
    end
  when "Hash"
    data = args.merge({:worker_class => self.to_s})
  end
  data = {:msg => 'Starting job', :job => data}

  app_instance_id = data.dig(:job, 'app_instance_id')
  if app_instance_id.present?
    Rails.logger.before_log = lambda do |data|
      data[:app_instance_id] = app_instance_id
    end
  end

  Rails.logger.info(data) if data.present?
end