1
0
Fork 0
mirror of https://github.com/mperham/sidekiq.git synced 2022-11-09 13:52:34 -05:00
mperham--sidekiq/lib/sidekiq/util.rb
Nate Berkopec 8c53356fc8 Provide consistent interface to exception handlers (#3161)
This commit ensures that exception handlers are always provided with two objects:

* The Exception
* A hash with the following keys:
  * `:context` (Required) - A String message explaining what happened
  * `:job` (Optional) - If this occurred while a job was being processed, this is the deserialized job Hash
  * `:jobstr` (Optional) - If this occurred during job deserialization, this is the raw JSON string of the job
  * `:event` (Optional) - If this occurred during a lifecycle event, name of the event
2016-09-26 13:51:13 -07:00

62 lines
1.2 KiB
Ruby

# frozen_string_literal: true
require 'socket'
require 'securerandom'
require 'sidekiq/exception_handler'
require 'sidekiq/core_ext'
module Sidekiq
##
# This module is part of Sidekiq core and not intended for extensions.
#
module Util
include ExceptionHandler
EXPIRY = 60 * 60 * 24
def watchdog(last_words)
yield
rescue Exception => ex
handle_exception(ex, { context: last_words })
raise ex
end
def safe_thread(name, &block)
Thread.new do
watchdog(name, &block)
end
end
def logger
Sidekiq.logger
end
def redis(&block)
Sidekiq.redis(&block)
end
def hostname
ENV['DYNO'] || Socket.gethostname
end
def process_nonce
@@process_nonce ||= SecureRandom.hex(6)
end
def identity
@@identity ||= "#{hostname}:#{$$}:#{process_nonce}"
end
def fire_event(event, reverse=false)
arr = Sidekiq.options[:lifecycle_events][event]
arr.reverse! if reverse
arr.each do |block|
begin
block.call
rescue => ex
handle_exception(ex, { context: "Exception during Sidekiq lifecycle event.", event: event })
end
end
arr.clear
end
end
end