v2.rb
2.2 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
module Hoptoad
module V2
def self.process_notice(parsed)
for_errbit_api(
normalize(
rekey(parsed)))
end
private
def self.rekey(node)
case node
when Hash
if node.has_key?('var') && node.has_key?('key')
{normalize_key(node['key']) => rekey(node['var'])}
elsif node.has_key?('var')
rekey(node['var'])
elsif node.has_key?('__content__') && node.has_key?('key')
{normalize_key(node['key']) => rekey(node['__content__'])}
elsif node.has_key?('__content__')
rekey(node['__content__'])
elsif node.has_key?('key')
{normalize_key(node['key']) => nil}
else
node.inject({}) {|rekeyed, (key, val)| rekeyed.merge(normalize_key(key) => rekey(val))}
end
when Array
if node.first.has_key?('key')
node.inject({}) {|rekeyed, keypair| rekeyed.merge(rekey(keypair))}
else
node.map {|n| rekey(n)}
end
else
node
end
end
def self.normalize_key(key)
key.gsub('.', '_')
end
def self.normalize(notice)
error = notice['error']
backtrace = error['backtrace']
backtrace['line'] = [backtrace['line']] unless backtrace['line'].is_a?(Array)
notice['request'] ||= {}
notice['request']['component'] = 'unknown' if notice['request']['component'].blank?
notice['request']['action'] = nil if notice['request']['action'].blank?
notice
end
def self.for_errbit_api(notice)
{
:error_class => notice['error']['class'] || notice['error']['key'],
:message => notice['error']['message'],
:backtrace => notice['error']['backtrace']['line'],
:request => notice['request'],
:server_environment => notice['server-environment'],
:api_key => notice['api-key'],
:notifier => notice['notifier'],
# 'current-user' from airbrake, 'user-attributes' from airbrake_user_attributes gem
:user_attributes => notice['current-user'] || notice['user-attributes'] || {},
:framework => notice['framework']
}
end
end
end