raygun-apm 0.0.24-universal-darwin → 0.0.25-universal-darwin

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: ba6d477ea9e5a8e1f7755f207572eb71013d9fd649d0dbe46392bbf0cee21f9c
4
- data.tar.gz: b26062f2d14781244e347cc927aacaf02d24081f1bb1d003634e2aad8cdb099e
3
+ metadata.gz: 8cbd4a4849aec64aaad3b41b0871d38f125fc09515cc98f81d1e7d0aebbef610
4
+ data.tar.gz: 20ea68ad7d939efdf2a5d07252d3a9c304d511c53558826781a369ca56656650
5
5
  SHA512:
6
- metadata.gz: 39ec3f64fd40ff1116cee96c8636234a9262a426d3eb488421a086d14dc02648fd3e30b3aacac621335c0159685f4d8a0f2429d11b77ba771615a54c5772cef7
7
- data.tar.gz: d0cd5be852006ed6989e4719d59b09d88d656ed7830595e72ad47cb3fe935b297a4d59b8c4f95ac326ae8a7a6f5849af49694d0affb80a1dc7ed089dc8c8636b
6
+ metadata.gz: 10a914762f1e0e88f2f72f633731ab600ab3e8111e2b531341dacc5247b3d3a708407f252e20c2e5d7d6bbf1a6a8e8a8aed27dfa4c9b1330a367bb047961ee81
7
+ data.tar.gz: 4ddb191526ebeafa89dadb4c29ecc18243a2269b40b7bf8b3e1ac1dc0c6ff5cbc349c7c332e9c6f20f0c4ec7e681e8f266451f635a5fe75722e9cbdb43c3e4b6
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- raygun-apm (0.0.24)
4
+ raygun-apm (0.0.25)
5
5
 
6
6
  GEM
7
7
  remote: https://rubygems.org/
@@ -30,4 +30,4 @@ DEPENDENCIES
30
30
  raygun-apm!
31
31
 
32
32
  BUNDLED WITH
33
- 2.1.0
33
+ 2.1.2
data/README.rdoc CHANGED
@@ -75,7 +75,7 @@ Extended events can be sent where appropiate
75
75
  event = Raygun::Apm::Event::HttpIn.new
76
76
  event[:pid] = Process.pid
77
77
  event[:tid] = 0
78
- event[:timestamp] = Time.now.to_f*1000000
78
+ event[:timestamp] = tracer.now
79
79
  event[:url] = 'https://google.com/'
80
80
  event[:verb] = 'GET'
81
81
  event[:status] = 200
@@ -87,7 +87,7 @@ Extended events can be sent where appropiate
87
87
  event = Raygun::Apm::Event::Sql.new
88
88
  event[:pid] = Process.pid
89
89
  event[:tid] = 0
90
- event[:timestamp] = Time.now.to_f*1000000
90
+ event[:timestamp] = tracer.now
91
91
  event[:provider] = 'postgres'
92
92
  event[:host] = 'localhost'
93
93
  event[:database] = 'rails'
Binary file
Binary file
@@ -136,6 +136,9 @@ module Raygun
136
136
  Warning
137
137
  ZeroDivisionError
138
138
  IPAddr
139
+ Net::
140
+ OpenSSL
141
+ BasicSocket
139
142
  }
140
143
 
141
144
  def self.extend_with(list)
@@ -0,0 +1,46 @@
1
+ require 'net/http'
2
+
3
+ module Raygun
4
+ module Apm
5
+ module Hooks
6
+ module Net
7
+ module HTTP
8
+ private
9
+
10
+ def transport_request(request)
11
+ if tracer = raygun_apm_tracer
12
+ started = tracer.now
13
+ response = super
14
+ ended = tracer.now
15
+ event = raygun_apm_http_out_event
16
+ event[:url] = request.uri.to_s
17
+ event[:verb] = request.method
18
+ event[:status] = response.code.to_i
19
+ event[:duration] = ended - started
20
+ event[:timestamp] = started
21
+ event[:tid] = tracer.get_thread_id(Thread.current)
22
+ tracer.emit(event)
23
+ response
24
+ else
25
+ super
26
+ end
27
+ end
28
+
29
+ def raygun_apm_http_out_event
30
+ @_raygun_apm_http_out_event ||= begin
31
+ event = Raygun::Apm::Event::HttpOut.new
32
+ event[:pid] = Process.pid
33
+ event
34
+ end
35
+ end
36
+
37
+ def raygun_apm_tracer
38
+ Thread.current.thread_variable_get(:_raygun_apm_tracer)
39
+ end
40
+ end
41
+ end
42
+ end
43
+ end
44
+ end
45
+
46
+ ::Net::HTTP.prepend(Raygun::Apm::Hooks::Net::HTTP)
@@ -1,5 +1,5 @@
1
1
  module Raygun
2
2
  module Apm
3
- VERSION = "0.0.24"
3
+ VERSION = "0.0.25"
4
4
  end
5
5
  end
data/lib/raygun/apm.rb CHANGED
@@ -11,6 +11,5 @@ require "raygun/apm/event"
11
11
 
12
12
  module Raygun
13
13
  module Apm
14
- # Your code goes here...
15
14
  end
16
15
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: raygun-apm
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.24
4
+ version: 0.0.25
5
5
  platform: universal-darwin
6
6
  authors:
7
7
  - Erkki Eilonen
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2019-12-19 00:00:00.000000000 Z
11
+ date: 2019-12-24 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: debase-ruby_core_source
@@ -127,7 +127,7 @@ files:
127
127
  - lib/raygun/apm/blacklist.rb
128
128
  - lib/raygun/apm/config.rb
129
129
  - lib/raygun/apm/event.rb
130
- - lib/raygun/apm/middleware.rb
130
+ - lib/raygun/apm/hooks/net_http.rb
131
131
  - lib/raygun/apm/tracer.rb
132
132
  - lib/raygun/apm/version.rb
133
133
  - raygun-apm.gemspec
@@ -1,104 +0,0 @@
1
- module Raygun
2
- module Apm
3
- class Middleware
4
- def initialize(app)
5
- @app = app
6
- @tracer = Raygun::Apm::Tracer.new
7
- @tracer.udp_sink!
8
- @tracer.process_started
9
- ObjectSpace.define_finalizer(self, self.class.finalize(@tracer))
10
-
11
- @http_in_subscriber = ActiveSupport::Notifications.subscribe('process_action.action_controller') do |*args|
12
- http_in_handler(args)
13
- end
14
- @sql_subscriber = ActiveSupport::Notifications.subscribe('sql.active_record') do |*args|
15
- sql_handler(args)
16
- end
17
-
18
- # If any kamikaze errors on init, shutdown the tracer
19
- rescue Raygun::Apm::FatalError => e
20
- kamikaze_handler(e)
21
- end
22
-
23
- def call(env)
24
- @status, @headers, @response = instrument(env)
25
- [@status, @headers, @response]
26
- end
27
-
28
- def instrument(env)
29
- res = nil
30
- # Can be nil if we had a kamikaze error
31
- @tracer.start_trace if @tracer
32
- res = @app.call(env)
33
- # Can be nil if we had a kamikaze error
34
- @tracer.end_trace if @tracer
35
- res
36
- rescue Raygun::Apm::FatalError => e
37
- kamikaze_handler(e)
38
- end
39
-
40
- def kamikaze_handler(exception)
41
- warn "Raygun APM shutting down due to error - %s", e.message
42
- # Kill extended event subcriptions
43
- ActiveSupport::Notifications.unsubscribe(@http_in_subscriber)
44
- ActiveSupport::Notifications.unsubscribe(@sql_subscriber)
45
- # Shutdown the tracepoint if enabled to reduce any overhead and stall emission
46
- @tracer.tracepoint.stop if @tracer.tracepoint.enabled?
47
- # Let the GC clean up the sink thread through the finalizer below
48
- @tracer = nil
49
- end
50
-
51
- def http_in_handler(args)
52
- notification = ActiveSupport::Notifications::Event.new *args
53
- if notification.payload[:exception]
54
- # XXX notify?
55
- return
56
- end
57
- req = Rack::Request.new notification.payload[:headers].env
58
- event = Raygun::Apm::Event::HttpIn.new
59
- event[:url] = req.url
60
- event[:verb] = req.request_method
61
- event[:status] = notification.payload[:status]
62
- # XXX constant milliseconds to microseconds
63
- event[:duration] = notification.duration * 1000
64
- event[:timestamp] = notification.time.to_f*1000000
65
- event[:pid] = Process.pid
66
- event[:tid] = @tracer.get_thread_id(Thread.current)
67
- @tracer.emit(event)
68
- rescue => e
69
- # XXX report
70
- end
71
-
72
- def sql_handler(args)
73
- notification = ActiveSupport::Notifications::Event.new *args
74
- connection = if notification.payload[:connection]
75
- notification.payload[:connection]
76
- else
77
- ObjectSpace._id2ref(notification.payload[:connection_id])
78
- end
79
- event = Raygun::Apm::Event::Sql.new
80
- event[:query] = notification.payload[:sql]
81
-
82
- # XXX this is hacky
83
- if config = connection.instance_variable_get('@config')
84
- event[:provider] = config[:adapter]
85
- event[:host] = config[:host]
86
- event[:database] = config[:database]
87
- end
88
-
89
- # XXX constant milliseconds to microseconds
90
- event[:duration] = notification.duration * 1000
91
- event[:timestamp] = notification.time.to_f*1000000
92
- event[:pid] = Process.pid
93
- event[:tid] = @tracer.get_thread_id(Thread.current)
94
- @tracer.emit(event)
95
- rescue => e
96
- # XXX report
97
- end
98
-
99
- def self.finalize(tracer)
100
- proc {tracer.process_ended}
101
- end
102
- end
103
- end
104
- end