Sha256: 40a899460bb8bc1aee669c27dd2385c47c09ebdc8f57576c004719fa242f307f

Contents?: true

Size: 1.69 KB

Versions: 2

Compression:

Stored size: 1.69 KB

Contents

require 'mongo'
require 'keys'

module YogiBerra
  class Data
    def self.store!(exception, environment = nil)
      data = parse_exception(exception)
      if environment
        session = environment.delete(:session)
        data[:session] = parse_session(session) if session
        controller = environment.delete(:controller)
        data[:controller] = parse_controller(controller) if controller
        data.merge!(environment)
      end
      # convert all the keys to strings for bson storage, using activesupport keys.rb file
      data.deep_stringify_keys_and_values!
      YogiBerra.connection["caught_exceptions"].insert(data)
    end

    def self.parse_exception(notice)
      data_hash = {
        :error_class => "#{notice.exception.class}",
        :project => YogiBerra.settings["project"],
        :error_message => notice.respond_to?(:error_message) ? notice.error_message : notice.message
      }
      data_hash[:backtraces] = notice.backtrace
      if notice.backtrace.respond_to?(:lines) && notice.backtrace.lines.any?
        data_hash[:backtraces] = notice.backtrace.lines.collect(&:to_s)
      end
      data_hash[:created_at] = Time.now.utc
      data_hash
    end

    def self.parse_session(session)
      session.inject({}) do |result, element|
        key = element.first
        value = element.last
        if value.respond_to?(:as_json)
          result[key] = value.as_json(:except => ["password"])
        else
          value.delete("password")
          result[key] = value
        end
        result
      end
    end

    def self.parse_controller(controller)
      if controller
        { :action => controller.action_name, :name => controller.controller_name }
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
yogi_berra-0.2.1 lib/yogi_berra/data.rb
yogi_berra-0.2.0 lib/yogi_berra/data.rb