Sha256: afb360403e7ff5f5e4fc529e6a13a482113b6225ce4e957b277bf90d1dc16750

Contents?: true

Size: 1.44 KB

Versions: 36

Compression:

Stored size: 1.44 KB

Contents

module Bugsnag::Middleware
  ##
  # Extracts and attaches user information from Warden to an error report
  class WardenUser
    SCOPE_PATTERN = /^warden\.user\.([^.]+)\.key$/
    COMMON_USER_FIELDS = [:email, :name, :first_name, :last_name, :created_at, :id]

    def initialize(bugsnag)
      @bugsnag = bugsnag
    end

    def call(report)
      if report.request_data[:rack_env] && report.request_data[:rack_env]["warden"]
        env = report.request_data[:rack_env]
        session = env["rack.session"] || {}

        # Find all warden user scopes
        warden_scopes = session.keys.select {|k| k.match(SCOPE_PATTERN)}.map {|k| k.gsub(SCOPE_PATTERN, '\1')}
        unless warden_scopes.empty?
          # Pick the best scope for unique id (the default is "user")
          best_scope = warden_scopes.include?("user") ? "user" : warden_scopes.first

          # Extract useful user information
          user = {}
          user_object = env["warden"].user({:scope => best_scope, :run_callbacks => false}) rescue nil
          if user_object
            # Build the user info for this scope
            COMMON_USER_FIELDS.each do |field|
              user[field] = user_object.send(field) if user_object.respond_to?(field)
            end
          end

          # We merge the first warden scope down, so that it is the main "user" for the request
          report.user = user unless user.empty?
        end
      end

      @bugsnag.call(report)
    end
  end
end

Version data entries

36 entries across 36 versions & 1 rubygems

Version Path
bugsnag-6.26.4 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.26.3 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.26.2 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.26.1 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.26.0 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.25.2 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.25.1 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.25.0 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.24.2 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.24.1 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.24.0 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.23.0 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.22.1 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.21.0 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.20.0 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.19.0 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.18.0 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.17.0 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.16.0 lib/bugsnag/middleware/warden_user.rb
bugsnag-6.15.0 lib/bugsnag/middleware/warden_user.rb