error_report.rb
1.73 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
require 'digest/sha1'
require 'hoptoad_notifier'
class ErrorReport
attr_reader :error_class, :message, :backtrace, :request, :server_environment, :api_key, :notifier, :user_attributes, :current_user
def initialize(xml_or_attributes)
@attributes = (xml_or_attributes.is_a?(String) ? Hoptoad.parse_xml!(xml_or_attributes) : xml_or_attributes).with_indifferent_access
@attributes.each{|k, v| instance_variable_set(:"@#{k}", v) }
end
def fingerprint
@fingerprint ||= Digest::SHA1.hexdigest(fingerprint_source.to_s)
end
def rails_env
server_environment['environment-name'] || 'development'
end
def component
request['component'] || 'unknown'
end
def action
request['action']
end
def app
@app ||= App.find_by_api_key!(api_key)
end
def generate_notice!
notice = Notice.new(
:message => message,
:error_class => error_class,
:backtrace => backtrace,
:request => request,
:server_environment => server_environment,
:notifier => notifier,
:user_attributes => user_attributes,
:current_user => current_user
)
err = app.find_or_create_err!(
:error_class => error_class,
:component => component,
:action => action,
:environment => rails_env,
:fingerprint => fingerprint)
err.notices << notice
notice
end
private
def fingerprint_source
{
:backtrace => normalized_backtrace.to_s,
:error_class => error_class,
:component => component,
:action => action,
:environment => rails_env,
:api_key => api_key
}
end
def normalized_backtrace
backtrace[0...3].map do |trace|
trace.merge 'method' => trace['method'].gsub(/[0-9_]{10,}+/, "__FRAGMENT__")
end
end
end