Class: Ridc::ExceptionReporter
- Inherits:
-
Object
- Object
- Ridc::ExceptionReporter
- Defined in:
- lib/exception_reporter.rb
Instance Method Summary collapse
- #call(env) ⇒ Object
- #form_data(rack_env) ⇒ Object
- #headers(rack_env) ⇒ Object
-
#initialize(app) ⇒ ExceptionReporter
constructor
A new instance of ExceptionReporter.
- #report(exception, environment) ⇒ Object
-
#useful_environment_parts(env) ⇒ Object
thanks raygun4ruby guys!.
Constructor Details
#initialize(app) ⇒ ExceptionReporter
Returns a new instance of ExceptionReporter.
4 5 6 |
# File 'lib/exception_reporter.rb', line 4 def initialize(app) @app = app end |
Instance Method Details
#call(env) ⇒ Object
8 9 10 11 12 13 14 |
# File 'lib/exception_reporter.rb', line 8 def call(env) response = @app.call(env) rescue Exception => exception #Rails.logger.original.info("yeah!") report(exception, env) raise exception end |
#form_data(rack_env) ⇒ Object
50 51 52 53 54 55 56 |
# File 'lib/exception_reporter.rb', line 50 def form_data(rack_env) request = Rack::Request.new(rack_env) if request.form_data? request.body end end |
#headers(rack_env) ⇒ Object
44 45 46 47 48 |
# File 'lib/exception_reporter.rb', line 44 def headers(rack_env) rack_env.select do |k, v| k.to_s.start_with?("HTTP_") end end |
#report(exception, environment) ⇒ Object
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
# File 'lib/exception_reporter.rb', line 16 def report(exception, environment) event_session_id = Thread.current["session_id"] event_session_content = Thread.current["session_content"] event = { :event_type => "exception", :exception_class => exception.class.to_s, :description => exception.to_s, :backtrace => Array(exception.backtrace).join("\n").to_s, :environment => useful_environment_parts(environment), :event_session_id => event_session_id, :event_session_content => event_session_content } Ridc.sender.add_to_queue(event) end |
#useful_environment_parts(env) ⇒ Object
thanks raygun4ruby guys!
32 33 34 35 36 37 38 39 40 41 42 43 |
# File 'lib/exception_reporter.rb', line 32 def useful_environment_parts(env) { :hostName => env["SERVER_NAME"], :url => env["PATH_INFO"], :httpMethod => env["REQUEST_METHOD"], :ipAddress => env["REMOTE_ADDR"], :queryString => Rack::Utils.parse_nested_query(env["QUERY_STRING"]), :form => form_data(env), :headers => headers(env), :rawData => [] } end |