ratchetio 0.1.2 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
data/README.md
CHANGED
@@ -28,11 +28,21 @@ To confirm that it worked, run:
|
|
28
28
|
|
29
29
|
This will raise an exception within a test request; if it works, you'll see a stacktrace in the console, and the exception will appear in the Ratchet.io dashboard.
|
30
30
|
|
31
|
+
## Person tracking
|
32
|
+
|
33
|
+
Ratchet will send information about the current user (called a "person" in Ratchet parlance) along with each error report, when available. This works by trying the `current_user` and `current_member` controller methods. The return value should be an object with an `id` property and, optionally, `username` and `email` properties.
|
34
|
+
|
35
|
+
If you use different naming, add the following in your controller:
|
36
|
+
|
37
|
+
```ruby
|
38
|
+
alias_method :my_user_method, :current_user
|
39
|
+
helper_method :my_user_method
|
40
|
+
```
|
41
|
+
|
31
42
|
## Help / Support
|
32
43
|
|
33
44
|
If you run into any issues, please email me at brian@ratchet.io
|
34
45
|
|
35
|
-
|
36
46
|
## Contributing
|
37
47
|
|
38
48
|
1. Fork it
|
@@ -14,6 +14,22 @@ module Ratchetio
|
|
14
14
|
}
|
15
15
|
end
|
16
16
|
|
17
|
+
def ratchetio_person_data
|
18
|
+
user = begin current_user rescue current_member end
|
19
|
+
# include id, username, email if non-empty
|
20
|
+
user.attributes.select do |k, v|
|
21
|
+
if v.blank?
|
22
|
+
false
|
23
|
+
elsif ['id', 'username', 'email'].include? k
|
24
|
+
true
|
25
|
+
else
|
26
|
+
false
|
27
|
+
end
|
28
|
+
end.symbolize_keys
|
29
|
+
rescue NoMethodError, NameError
|
30
|
+
{}
|
31
|
+
end
|
32
|
+
|
17
33
|
private
|
18
34
|
|
19
35
|
def ratchetio_request_url
|
@@ -11,7 +11,8 @@ module Ratchetio
|
|
11
11
|
begin
|
12
12
|
controller = env['action_controller.instance']
|
13
13
|
request_data = controller.try(:ratchetio_request_data)
|
14
|
-
|
14
|
+
person_data = controller.try(:ratchetio_person_data)
|
15
|
+
Ratchetio.report_request_exception(env, exception, request_data, person_data)
|
15
16
|
rescue Exception => exc
|
16
17
|
# TODO use logger here?
|
17
18
|
puts "[Ratchet.io] Exception while reporting exception to Ratchet.io: "
|
data/lib/ratchetio/version.rb
CHANGED
data/lib/ratchetio.rb
CHANGED
@@ -19,7 +19,7 @@ module Ratchetio
|
|
19
19
|
@configuration ||= Configuration.new
|
20
20
|
end
|
21
21
|
|
22
|
-
def report_request_exception(env, exception, request_data)
|
22
|
+
def report_request_exception(env, exception, request_data, person_data)
|
23
23
|
data = base_data
|
24
24
|
|
25
25
|
# parse backtrace
|
@@ -44,7 +44,8 @@ module Ratchetio
|
|
44
44
|
|
45
45
|
data[:server] = server_data
|
46
46
|
data[:request] = request_data
|
47
|
-
|
47
|
+
data[:person] = person_data
|
48
|
+
|
48
49
|
payload = build_payload(data)
|
49
50
|
send_payload(payload)
|
50
51
|
end
|
@@ -116,10 +117,7 @@ module Ratchetio
|
|
116
117
|
end
|
117
118
|
data
|
118
119
|
end
|
119
|
-
|
120
|
-
def request_data
|
121
|
-
{}
|
122
|
-
end
|
120
|
+
|
123
121
|
end
|
124
122
|
end
|
125
123
|
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: ratchetio
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.2.0
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2012-09-
|
12
|
+
date: 2012-09-28 00:00:00.000000000 Z
|
13
13
|
dependencies: []
|
14
14
|
description: Rails plugin to catch and send exceptions to Ratchet.io
|
15
15
|
email:
|