Sha256: 6e0f0c3f2009aa24779685be4d0ff53e50e3a14c585e3372d838c39129ffe315

Contents?: true

Size: 1.44 KB

Versions: 4

Compression:

Stored size: 1.44 KB

Contents

module Bugsnag::Middleware
  class RackRequest
    def initialize(bugsnag)
      @bugsnag = bugsnag
    end
      
    def call(notification)
      if notification.request_data[:rack_env]
        env = notification.request_data[:rack_env]

        request = ::Rack::Request.new(env)
        params = request.params
        session = env["rack.session"]

        # Set the context
        notification.context = "#{request.request_method} #{request.path}"

        # Set a sensible default for user_id
        notification.user_id = request.ip

        # Build the clean url (hide the port if it is obvious)
        url = "#{request.scheme}://#{request.host}"
        url << ":#{request.port}" unless [80, 443].include?(request.port)
        url << Bugsnag::Helpers.cleanup_url(request.fullpath, notification.configuration.params_filters)

        # Add a request tab
        notification.add_tab(:request, {
          :url => url,
          :httpMethod => request.request_method,
          :params => params.to_hash,
          :userAgent => request.user_agent,
          :clientIp => request.ip
        })
          
        # Add an environment tab
        notification.add_tab(:environment, env)

        # Add a session tab
        notification.add_tab(:session, session) if session

        # Add a cookies tab
        cookies = request.cookies
        notification.add_tab(:cookies, cookies) if cookies
      end

      @bugsnag.call(notification)
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
bugsnag-1.4.1 lib/bugsnag/middleware/rack_request.rb
bugsnag-1.4.0 lib/bugsnag/middleware/rack_request.rb
bugsnag-1.3.8 lib/bugsnag/middleware/rack_request.rb
bugsnag-1.3.7 lib/bugsnag/middleware/rack_request.rb