2012-07-31 11:43:09 -04:00
|
|
|
module Sidekiq
|
|
|
|
module ExceptionHandler
|
|
|
|
|
2012-08-02 20:46:06 -07:00
|
|
|
def handle_exception(ex, msg)
|
|
|
|
Sidekiq.logger.warn msg
|
|
|
|
Sidekiq.logger.warn ex
|
|
|
|
Sidekiq.logger.warn ex.backtrace.join("\n")
|
2012-10-28 13:24:01 -07:00
|
|
|
# This list of services is getting a bit ridiculous.
|
|
|
|
# For future error services, please add your own
|
|
|
|
# middleware like BugSnag does:
|
|
|
|
# https://github.com/bugsnag/bugsnag-ruby/blob/master/lib/bugsnag/sidekiq.rb
|
2012-07-31 11:43:09 -04:00
|
|
|
send_to_airbrake(msg, ex) if defined?(::Airbrake)
|
2012-10-26 20:33:54 -07:00
|
|
|
send_to_honeybadger(msg, ex) if defined?(::Honeybadger)
|
2012-07-31 11:43:09 -04:00
|
|
|
send_to_exceptional(msg, ex) if defined?(::Exceptional)
|
|
|
|
send_to_exception_notifier(msg, ex) if defined?(::ExceptionNotifier)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def send_to_airbrake(msg, ex)
|
2012-09-06 18:49:58 +01:00
|
|
|
::Airbrake.notify_or_ignore(ex, :parameters => msg)
|
2012-07-31 11:43:09 -04:00
|
|
|
end
|
|
|
|
|
2012-10-26 20:33:54 -07:00
|
|
|
def send_to_honeybadger(msg, ex)
|
|
|
|
::Honeybadger.notify_or_ignore(ex, :parameters => msg)
|
|
|
|
end
|
|
|
|
|
2012-07-31 11:43:09 -04:00
|
|
|
def send_to_exceptional(msg, ex)
|
|
|
|
if ::Exceptional::Config.should_send_to_api?
|
|
|
|
::Exceptional.context(msg)
|
|
|
|
::Exceptional::Remote.error(::Exceptional::ExceptionData.new(ex))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def send_to_exception_notifier(msg, ex)
|
2013-05-06 08:15:07 +08:00
|
|
|
::ExceptionNotifier.notify_exception(ex, :data => {:message => msg})
|
2012-07-31 11:43:09 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|