Sha256: fbb5bb0974e617993c1af42ad2783c35c14fb7563a7736424d232389edf035b0

Contents?: true

Size: 1.99 KB

Versions: 5

Compression:

Stored size: 1.99 KB

Contents

require 'action_dispatch/http/request'
require 'action_dispatch/middleware/exception_wrapper'

# Since we are taking over exception handling, make sure we log exceptions
# https://github.com/rails/rails/blob/4-2-stable/actionpack/lib/action_dispatch/middleware/debug_exceptions.rb
module HalApi::Controller::Exceptions
  extend ActiveSupport::Concern

  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

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

  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

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

  module ClassMethods
    def hal_rescue_standard_errors
      rescue_from StandardError do |error|
        respond_with_error(error)
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
hal_api-rails-1.1.4 lib/hal_api/controller/exceptions.rb
hal_api-rails-1.1.3 lib/hal_api/controller/exceptions.rb
hal_api-rails-1.1.2 lib/hal_api/controller/exceptions.rb
hal_api-rails-1.1.1 lib/hal_api/controller/exceptions.rb
hal_api-rails-1.1.0 lib/hal_api/controller/exceptions.rb