Sha256: 0b579f1438172ab47a8fecf0ce882486d0df2f758318101cd67f1c524dbe18e7

Contents?: true

Size: 1.36 KB

Versions: 2

Compression:

Stored size: 1.36 KB

Contents

module Honeybadger
  # Middleware for Rack applications. Any errors raised by the upstream
  # application will be delivered to Honeybadger and re-raised.
  #
  # Synopsis:
  #
  #   require 'rack'
  #   require 'honeybadger'
  #
  #   Honeybadger.configure do |config|
  #     config.api_key = 'my_api_key'
  #   end
  #
  #   app = Rack::Builder.app do
  #     run lambda { |env| raise "Rack down" }
  #   end
  #
  #   use Honeybadger::Rack
  #   run app
  #
  # Use a standard Honeybadger.configure call to configure your api key.
  class Rack
    def initialize(app)
      @app = app
      Honeybadger.configuration.logger ||= Logger.new STDOUT
    end

    def ignored_user_agent?(env)
      true if Honeybadger.
        configuration.
        ignore_user_agent.
        flatten.
        any? { |ua| ua === env['HTTP_USER_AGENT'] }
    end

    def notify_honeybadger(exception,env)
      Honeybadger.notify_or_ignore(exception,:rack_env => env) unless ignored_user_agent?(env)
    end

    def call(env)
      begin
        response = @app.call(env)
      rescue Exception => raised
        env['honeybadger.error_id'] = notify_honeybadger(raised,env)
        raise
      ensure
        Honeybadger.context.clear!
      end

      if env['rack.exception']
        env['honeybadger.error_id'] = notify_honeybadger(env['rack.exception'],env)
      end

      response
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
honeybadger-1.3.1 lib/honeybadger/rack.rb
honeybadger-1.3.0 lib/honeybadger/rack.rb