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



35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# File 'lib/hal_api/controller/exceptions.rb', line 35

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



52
53
54
55
56
# File 'lib/hal_api/controller/exceptions.rb', line 52

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
29
30
31
32
33
# File 'lib/hal_api/controller/exceptions.rb', line 9

def respond_with_error(exception)
  wrapper = case HalApi.rails_major_version
            when 5
              ::ActionDispatch::ExceptionWrapper.new(ActiveSupport::BacktraceCleaner.new, exception)
            else
              ::ActionDispatch::ExceptionWrapper.new(request.env, exception)
            end

  log_error(request.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

  json = {status: error.status, message: error.message}
  if Rails.configuration.try(:consider_all_requests_local)
    json[:backtrace] = error.backtrace
  end
  render status: error.status, json: json
end