Module: HalApi::Controller::Exceptions

Extended by:
ActiveSupport::Concern
Included in:
HalApi::Controller
Defined in:
lib/hal_api/controller/exceptions.rb

Overview

Since we are taking over exception handling, make sure we log exceptions github.com/rails/rails/blob/4-2-stable/actionpack/lib/action_dispatch/middleware/debug_exceptions.rb

Defined Under Namespace

Modules: ClassMethods

Instance Method Summary collapse

Instance Method Details

#log_error(env, wrapper) ⇒ Object



30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
# File 'lib/hal_api/controller/exceptions.rb', line 30

def log_error(env, wrapper)
  logger = env['action_dispatch.logger'] || self.logger || ActiveSupport::Logger.new($stderr)
  return unless logger

  exception = wrapper.exception

  trace = wrapper.application_trace
  trace = wrapper.framework_trace if trace.empty?

  ActiveSupport::Deprecation.silence do
    message = "\n#{exception.class} (#{exception.message}):\n"
    message << exception.annoted_source_code.to_s if exception.respond_to?(:annoted_source_code)
    message << "  " << trace.join("\n  ")
    logger.fatal("#{message}\n\n")
  end
end

#notice_error(error) ⇒ Object



47
48
49
50
51
# File 'lib/hal_api/controller/exceptions.rb', line 47

def notice_error(error)
  if defined?(::NewRelic::Agent) && ::NewRelic::Agent.respond_to?(:notice_error)
    ::NewRelic::Agent.notice_error(error)
  end
end

#respond_with_error(exception) ⇒ Object



9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# File 'lib/hal_api/controller/exceptions.rb', line 9

def respond_with_error(exception)
  wrapper = ::ActionDispatch::ExceptionWrapper.new(env, exception)
  log_error(env, wrapper)

  error = exception
  if !error.is_a?(HalApi::Errors::ApiError)
    error = HalApi::Errors::ApiError.new(error.message).tap do |e|
      e.set_backtrace(error.backtrace)
    end
  end

  notice_error(exception) if error.status >= 500

  respond_with(
    error,
    status: error.status,
    location: nil, # for POST requests
    represent_with: HalApi::Errors::Representer
  )
end