griffin-interceptors 0.1.6 → 0.1.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/lib/griffin/interceptors/server/filtered_payload_interceptor.rb +9 -3
- data/lib/griffin/interceptors/server/newrelic_interceptor.rb +22 -21
- data/lib/griffin/interceptors/server/raven_interceptor.rb +8 -1
- data/lib/griffin/interceptors/server/scout_apm_interceptor.rb +54 -0
- data/lib/griffin/interceptors/version.rb +1 -1
- metadata +7 -7
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: b785b3cafb37b0e0591d0711e53b26234f42e5fa030e97b1abcd0aeea1cdb7ea
|
4
|
+
data.tar.gz: 1088309028a6cc0b5ef0c9eda8d90959877104f7363bec69bc1edc74c99edee4
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 185036907e1423ecbfb463ada4759865c59012e3c3fb927821f148a7cec6f5610a0398c8807e8bb44f2777ff9663a7ecdfe6bb87eef5e116c9986df9dca9e4f7
|
7
|
+
data.tar.gz: a5924cd5e8b47d68fb2ca35c0ec9274b983a7e872699921092d0e6f5546048fc583ca149f61c79bbdbfe4a8f080947baac5dbf4f5ddd9e6af8d37432fb2ed5ba
|
@@ -2,8 +2,8 @@
|
|
2
2
|
|
3
3
|
require 'griffin/interceptors/server/payload_interceptor'
|
4
4
|
|
5
|
-
# Check actionpack exists to use ActionDispatch::Http::ParameterFilter
|
6
|
-
gem 'actionpack'
|
5
|
+
# Check actionpack exists to use ActionDispatch::Http::ParameterFilter if needed
|
6
|
+
gem 'actionpack' unless defined?(ActiveSupport::ParameterFilter)
|
7
7
|
|
8
8
|
module Griffin
|
9
9
|
module Interceptors
|
@@ -19,7 +19,13 @@ module Griffin
|
|
19
19
|
end
|
20
20
|
end
|
21
21
|
|
22
|
-
|
22
|
+
# ActionDispatch::Http::ParameterFilter is deprecated and will be removed from Rails 6.1.
|
23
|
+
parameter_filter_klass = if defined?(ActiveSupport::ParameterFilter)
|
24
|
+
ActiveSupport::ParameterFilter
|
25
|
+
else
|
26
|
+
ActionDispatch::Http::ParameterFilter
|
27
|
+
end
|
28
|
+
@parameter_filter = parameter_filter_klass.new(@filters)
|
23
29
|
end
|
24
30
|
|
25
31
|
def server_streamer(call: nil, **)
|
@@ -19,26 +19,14 @@ module Griffin
|
|
19
19
|
|
20
20
|
return yield if @ignored_services.include?(service_name)
|
21
21
|
|
22
|
-
transaction_name = build_transaction_name(service_name, method.name)
|
23
|
-
state = NewRelic::Agent::TransactionState.tl_get
|
24
|
-
|
25
22
|
# gRPC's HTTP method is fixed. https://github.com/grpc/grpc/blob/af89e8c00e796f3398b09b7daed693df2b14da56/doc/PROTOCOL-HTTP2.md
|
26
|
-
|
27
|
-
|
28
|
-
#
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
# gRPC alway returns HTTP status code 200
|
34
|
-
state.current_transaction.http_response_code = '200'
|
35
|
-
|
36
|
-
resp
|
37
|
-
rescue => e
|
38
|
-
NewRelic::Agent::Transaction.notice_error(e)
|
39
|
-
raise e
|
40
|
-
ensure
|
41
|
-
NewRelic::Agent::Transaction.stop(state)
|
23
|
+
request = Request.new("/#{service_name}/#{method.name}", call.metadata['user-agent'], 'POST')
|
24
|
+
|
25
|
+
in_transaction("#{service_name}/#{method.name}", request) do |txn|
|
26
|
+
yield.tap do
|
27
|
+
# gRPC always returns HTTP status code 200.
|
28
|
+
txn.http_response_code = '200'
|
29
|
+
end
|
42
30
|
end
|
43
31
|
end
|
44
32
|
|
@@ -46,8 +34,21 @@ module Griffin
|
|
46
34
|
|
47
35
|
private
|
48
36
|
|
49
|
-
|
50
|
-
|
37
|
+
if Gem::Version.new(NewRelic::VERSION::STRING) >= Gem::Version.new('6.0.0')
|
38
|
+
def in_transaction(partial_name, request)
|
39
|
+
NewRelic::Agent::Tracer.in_transaction(partial_name: partial_name, category: :web, options: { request: request }) do
|
40
|
+
yield NewRelic::Agent::Tracer.current_transaction
|
41
|
+
end
|
42
|
+
end
|
43
|
+
else
|
44
|
+
def in_transaction(partial_name, request)
|
45
|
+
state = NewRelic::Agent::TransactionState.tl_get
|
46
|
+
# Specify the controller category so that the transaction gets categorized as a web transaction.
|
47
|
+
# See https://github.com/newrelic/newrelic-ruby-agent/blob/5.7.0.350/lib/new_relic/agent/transaction.rb#L39.
|
48
|
+
NewRelic::Agent::Transaction.wrap(state, "Controller/#{partial_name}", :controller, request: request) do
|
49
|
+
yield state.current_transaction
|
50
|
+
end
|
51
|
+
end
|
51
52
|
end
|
52
53
|
end
|
53
54
|
end
|
@@ -6,7 +6,11 @@ module Griffin
|
|
6
6
|
module Interceptors
|
7
7
|
module Server
|
8
8
|
class RavenInterceptor < GRPC::ServerInterceptor
|
9
|
-
def request_response(
|
9
|
+
def request_response(call: nil, **)
|
10
|
+
if call.metadata['x-request-id']
|
11
|
+
Raven.tags_context(request_id: call.metadata['x-request-id'])
|
12
|
+
end
|
13
|
+
|
10
14
|
begin
|
11
15
|
yield
|
12
16
|
rescue => e
|
@@ -17,6 +21,9 @@ module Griffin
|
|
17
21
|
|
18
22
|
raise GRPC::Unknown.new('Internal server error')
|
19
23
|
end
|
24
|
+
ensure
|
25
|
+
Raven::Context.clear!
|
26
|
+
Raven::BreadcrumbBuffer.clear!
|
20
27
|
end
|
21
28
|
|
22
29
|
alias_method :server_streamer, :request_response
|
@@ -0,0 +1,54 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
gem 'scout_apm'
|
4
|
+
|
5
|
+
require 'scout_apm/layer'
|
6
|
+
require 'scout_apm/request_manager'
|
7
|
+
|
8
|
+
module Griffin
|
9
|
+
module Interceptors
|
10
|
+
module Server
|
11
|
+
class ScoutApmInterceptor < GRPC::ServerInterceptor
|
12
|
+
# Specify the controller layer so that the transaction gets categorized as a web transaction.
|
13
|
+
LAYER_TYPE = 'Controller'
|
14
|
+
|
15
|
+
def initialize(ignored_services: [], sampling_rate: 1.0)
|
16
|
+
@ignored_services = ignored_services.map(&:service_name)
|
17
|
+
@sampling_rate = sampling_rate.to_f
|
18
|
+
end
|
19
|
+
|
20
|
+
def request_response(request: nil, call: nil, method: nil)
|
21
|
+
service_name = call.service_name
|
22
|
+
method_name = method.name
|
23
|
+
|
24
|
+
return yield if rand > @sampling_rate || @ignored_services.include?(service_name)
|
25
|
+
|
26
|
+
layer = ScoutApm::Layer.new(LAYER_TYPE, "#{service_name}/#{method_name}")
|
27
|
+
|
28
|
+
req = ScoutApm::RequestManager.lookup
|
29
|
+
req.start_layer(layer)
|
30
|
+
req.annotate_request(uri: "/#{service_name}/#{method_name}")
|
31
|
+
|
32
|
+
ScoutApm::Context.add(
|
33
|
+
request_id: call.metadata['x-request-id'],
|
34
|
+
user_agent: call.metadata['user-agent'],
|
35
|
+
)
|
36
|
+
|
37
|
+
begin
|
38
|
+
yield
|
39
|
+
rescue => e
|
40
|
+
req.error!
|
41
|
+
raise e
|
42
|
+
ensure
|
43
|
+
req.stop_layer
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
# For now, we don't support server_streamer, client_streamer and bidi_streamer
|
48
|
+
# alias_method :server_streamer, :request_response
|
49
|
+
# alias_method :client_streamer, :request_response
|
50
|
+
# alias_method :bidi_streamer, :request_response
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: griffin-interceptors
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.11
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Yuta Iwama
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2021-01-08 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: get_process_mem
|
@@ -125,6 +125,7 @@ files:
|
|
125
125
|
- lib/griffin/interceptors/server/payload_streamer.rb
|
126
126
|
- lib/griffin/interceptors/server/rails_exception_interceptor.rb
|
127
127
|
- lib/griffin/interceptors/server/raven_interceptor.rb
|
128
|
+
- lib/griffin/interceptors/server/scout_apm_interceptor.rb
|
128
129
|
- lib/griffin/interceptors/server/timeout_interceptor.rb
|
129
130
|
- lib/griffin/interceptors/server/worker_killer_interceptor.rb
|
130
131
|
- lib/griffin/interceptors/server/x_request_id_interceptor.rb
|
@@ -133,7 +134,7 @@ homepage: https://github.com/cookpad/griffin-interceptors
|
|
133
134
|
licenses:
|
134
135
|
- MIT
|
135
136
|
metadata: {}
|
136
|
-
post_install_message:
|
137
|
+
post_install_message:
|
137
138
|
rdoc_options: []
|
138
139
|
require_paths:
|
139
140
|
- lib
|
@@ -148,9 +149,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
148
149
|
- !ruby/object:Gem::Version
|
149
150
|
version: '0'
|
150
151
|
requirements: []
|
151
|
-
|
152
|
-
|
153
|
-
signing_key:
|
152
|
+
rubygems_version: 3.0.3
|
153
|
+
signing_key:
|
154
154
|
specification_version: 4
|
155
155
|
summary: A collection of interceptors for griffin
|
156
156
|
test_files: []
|