opentelemetry-instrumentation-rack 0.13.0 → 0.18.0

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: 0dfb36f720e7c29d75aa43e7704bcdcbc48f7d372c26ac8375369cab8488fdf1
4
- data.tar.gz: 866c30087a8a130be2e77ffdbc93c788afa6f1710d9e1c777721b8ecf2ffc0e9
3
+ metadata.gz: 045d523393ba587000900fa6fe04d53639bbc893745795ae71b95a8e295fa33f
4
+ data.tar.gz: c56bdb588db187f92fc59038b6a7f612d9e38fe17a2d9544f3c04e9cc2a78551
5
5
  SHA512:
6
- metadata.gz: 9aa4b46b9fad82880a7bf4dba1d537cab64d9bd4743fb6bf6d6c71aed9c6a4d960bf3cd036e170d6bc0ea826b73a0342dcf4204931f406e03d45406b10dc0294
7
- data.tar.gz: a03e4a30b5e2c82047cbbd8b490e06dbe92e792b7f8d8c0481c4ed45397768e7e924520ec660205cb28a4064748e40e4e61ddd584d48de21bcf2e276a170ba97
6
+ metadata.gz: 235196039e3f220a14563489952c810d2acface20997498213a8bb57573307c9a4cf1cbce1cb38da22e3073f56ec53838f9c1bf2eae053428779f6e2274345e3
7
+ data.tar.gz: 66431cf36f90e5ed006d2a12cd396be2d30249562372cbc5bfdf5b97748f61afba051e765f99505474d7d074abcf117df84b9d7ec5cd9aa6fad143fbdd1ac46a
data/CHANGELOG.md CHANGED
@@ -1,8 +1,37 @@
1
1
  # Release History: opentelemetry-instrumentation-rack
2
2
 
3
+ ### v0.18.0 / 2021-05-21
4
+
5
+ * ADDED: Updated API depedency for 1.0.0.rc1
6
+ * FIXED: Removed http.status_text attribute #750
7
+
8
+ ### v0.17.0 / 2021-04-22
9
+
10
+ * (No significant changes)
11
+
12
+ ### v0.16.0 / 2021-03-17
13
+
14
+ * BREAKING CHANGE: Pass env to url quantization rack config to allow more flexibility
15
+
16
+ * ADDED: Pass env to url quantization rack config to allow more flexibility
17
+ * ADDED: Add rack instrumentation config option to accept callable to filter requests to trace
18
+ * FIXED: Example scripts now reference local common lib
19
+ * DOCS: Replace Gitter with GitHub Discussions
20
+
21
+ ### v0.15.0 / 2021-02-18
22
+
23
+ * ADDED: Add instrumentation config validation
24
+
25
+ ### v0.14.0 / 2021-02-03
26
+
27
+ * BREAKING CHANGE: Replace getter and setter callables and remove rack specific propagators
28
+
29
+ * ADDED: Replace getter and setter callables and remove rack specific propagators
30
+ * ADDED: Add untraced endpoints config to rack middleware
31
+
3
32
  ### v0.13.0 / 2021-01-29
4
33
 
5
- * FIXED: Only include user agent when present
34
+ * FIXED: Only include user agent when present
6
35
 
7
36
  ### v0.12.0 / 2020-12-24
8
37
 
@@ -10,11 +39,11 @@
10
39
 
11
40
  ### v0.11.0 / 2020-12-11
12
41
 
13
- * FIXED: Copyright comments to not reference year
42
+ * FIXED: Copyright comments to not reference year
14
43
 
15
44
  ### v0.10.1 / 2020-12-09
16
45
 
17
- * FIXED: Rack current_span
46
+ * FIXED: Rack current_span
18
47
 
19
48
  ### v0.10.0 / 2020-12-03
20
49
 
@@ -22,24 +51,24 @@
22
51
 
23
52
  ### v0.9.0 / 2020-11-27
24
53
 
25
- * BREAKING CHANGE: Add timeout for force_flush and shutdown
54
+ * BREAKING CHANGE: Add timeout for force_flush and shutdown
26
55
 
27
- * ADDED: Instrument rails
28
- * ADDED: Add timeout for force_flush and shutdown
56
+ * ADDED: Instrument rails
57
+ * ADDED: Add timeout for force_flush and shutdown
29
58
 
30
59
  ### v0.8.0 / 2020-10-27
31
60
 
32
- * BREAKING CHANGE: Move context/span methods to Trace module
33
- * BREAKING CHANGE: Remove 'canonical' from status codes
61
+ * BREAKING CHANGE: Move context/span methods to Trace module
62
+ * BREAKING CHANGE: Remove 'canonical' from status codes
34
63
 
35
- * FIXED: Move context/span methods to Trace module
36
- * FIXED: Remove 'canonical' from status codes
64
+ * FIXED: Move context/span methods to Trace module
65
+ * FIXED: Remove 'canonical' from status codes
37
66
 
38
67
  ### v0.7.0 / 2020-10-07
39
68
 
40
- * FIXED: Remove superfluous file from Rack gem
41
- * DOCS: Added README for Rack Instrumentation
42
- * DOCS: Standardize toplevel docs structure and readme
69
+ * FIXED: Remove superfluous file from Rack gem
70
+ * DOCS: Added README for Rack Instrumentation
71
+ * DOCS: Standardize toplevel docs structure and readme
43
72
 
44
73
  ### v0.6.0 / 2020-09-10
45
74
 
data/README.md CHANGED
@@ -38,7 +38,7 @@ Example usage can be seen in the `./example/trace_demonstration.rb` file [here](
38
38
 
39
39
  The `opentelemetry-instrumentation-rack` gem source is [on github][repo-github], along with related gems including `opentelemetry-api` and `opentelemetry-sdk`.
40
40
 
41
- The OpenTelemetry Ruby gems are maintained by the OpenTelemetry-Ruby special interest group (SIG). You can get involved by joining us on our [gitter channel][ruby-gitter] or attending our weekly meeting. See the [meeting calendar][community-meetings] for dates and times. For more information on this and other language SIGs, see the OpenTelemetry [community page][ruby-sig].
41
+ The OpenTelemetry Ruby gems are maintained by the OpenTelemetry-Ruby special interest group (SIG). You can get involved by joining us in [GitHub Discussions][discussions-url] or attending our weekly meeting. See the [meeting calendar][community-meetings] for dates and times. For more information on this and other language SIGs, see the OpenTelemetry [community page][ruby-sig].
42
42
 
43
43
  ## License
44
44
 
@@ -50,4 +50,4 @@ The `opentelemetry-instrumentation-rack` gem is distributed under the Apache 2.0
50
50
  [license-github]: https://github.com/open-telemetry/opentelemetry-ruby/blob/main/LICENSE
51
51
  [ruby-sig]: https://github.com/open-telemetry/community#ruby-sig
52
52
  [community-meetings]: https://github.com/open-telemetry/community#community-meetings
53
- [ruby-gitter]: https://gitter.im/open-telemetry/opentelemetry-ruby
53
+ [discussions-url]: https://github.com/open-telemetry/opentelemetry-ruby/discussions
@@ -5,6 +5,7 @@
5
5
  # SPDX-License-Identifier: Apache-2.0
6
6
 
7
7
  require 'opentelemetry'
8
+ require 'opentelemetry-instrumentation-base'
8
9
 
9
10
  module OpenTelemetry
10
11
  module Instrumentation
@@ -22,6 +22,15 @@ module OpenTelemetry
22
22
  defined?(::Rack)
23
23
  end
24
24
 
25
+ option :allowed_request_headers, default: [], validate: :array
26
+ option :allowed_response_headers, default: [], validate: :array
27
+ option :application, default: nil, validate: :callable
28
+ option :record_frontend_span, default: false, validate: :boolean
29
+ option :retain_middleware_names, default: false, validate: :boolean
30
+ option :untraced_endpoints, default: [], validate: :array
31
+ option :url_quantization, default: nil, validate: :callable
32
+ option :untraced_requests, default: nil, validate: :callable
33
+
25
34
  private
26
35
 
27
36
  def require_dependencies
@@ -49,16 +49,25 @@ module OpenTelemetry
49
49
 
50
50
  def initialize(app)
51
51
  @app = app
52
+ @untraced_endpoints = config[:untraced_endpoints]
52
53
  end
53
54
 
54
- def call(env) # rubocop:disable Metrics/AbcSize
55
+ def call(env) # rubocop:disable Metrics/AbcSize, Metrics/MethodLength
56
+ if untraced_request?(env)
57
+ OpenTelemetry::Common::Utilities.untraced do
58
+ return @app.call(env)
59
+ end
60
+ end
55
61
  original_env = env.dup
56
- extracted_context = OpenTelemetry.propagation.http.extract(env)
62
+ extracted_context = OpenTelemetry.propagation.extract(
63
+ env,
64
+ getter: OpenTelemetry::Context::Propagation.rack_env_getter
65
+ )
57
66
  frontend_context = create_frontend_span(env, extracted_context)
58
67
 
59
68
  # restore extracted context in this process:
60
69
  OpenTelemetry::Context.with_current(frontend_context || extracted_context) do
61
- request_span_name = create_request_span_name(env['REQUEST_URI'] || original_env['PATH_INFO'])
70
+ request_span_name = create_request_span_name(env['REQUEST_URI'] || original_env['PATH_INFO'], env)
62
71
  request_span_kind = frontend_context.nil? ? :server : :internal
63
72
  tracer.in_span(request_span_name,
64
73
  attributes: request_span_attributes(env: env),
@@ -76,6 +85,13 @@ module OpenTelemetry
76
85
 
77
86
  private
78
87
 
88
+ def untraced_request?(env)
89
+ return true if @untraced_endpoints.include?(env['PATH_INFO'])
90
+ return true if config[:untraced_requests]&.call(env)
91
+
92
+ false
93
+ end
94
+
79
95
  # return Context with the frontend span as the current span
80
96
  def create_frontend_span(env, extracted_context)
81
97
  request_start_time = OpenTelemetry::Instrumentation::Rack::Util::QueueTime.get_request_start(env)
@@ -125,12 +141,12 @@ module OpenTelemetry
125
141
  # strip off query param value, keep param name)
126
142
  #
127
143
  # see http://github.com/open-telemetry/opentelemetry-specification/pull/416/files
128
- def create_request_span_name(request_uri_or_path_info)
144
+ def create_request_span_name(request_uri_or_path_info, env)
129
145
  # NOTE: dd-trace-rb has implemented 'quantization' (which lowers url cardinality)
130
146
  # see Datadog::Quantization::HTTP.url
131
147
 
132
148
  if (implementation = config[:url_quantization])
133
- implementation.call(request_uri_or_path_info)
149
+ implementation.call(request_uri_or_path_info, env)
134
150
  else
135
151
  request_uri_or_path_info
136
152
  end
@@ -143,7 +159,6 @@ module OpenTelemetry
143
159
  # NOTE: if data is available, it would be good to do this:
144
160
  # set_attribute('http.route', ...
145
161
  # e.g., "/users/:userID?
146
- span.set_attribute('http.status_text', ::Rack::Utils::HTTP_STATUS_CODES[status])
147
162
 
148
163
  allowed_response_headers(headers).each { |k, v| span.set_attribute(k, v) }
149
164
  end
@@ -7,7 +7,7 @@
7
7
  module OpenTelemetry
8
8
  module Instrumentation
9
9
  module Rack
10
- VERSION = '0.13.0'
10
+ VERSION = '0.18.0'
11
11
  end
12
12
  end
13
13
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: opentelemetry-instrumentation-rack
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.13.0
4
+ version: 0.18.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - OpenTelemetry Authors
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-01-30 00:00:00.000000000 Z
11
+ date: 2021-05-21 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: opentelemetry-api
@@ -16,14 +16,28 @@ dependencies:
16
16
  requirements:
17
17
  - - "~>"
18
18
  - !ruby/object:Gem::Version
19
- version: 0.13.0
19
+ version: 1.0.0.rc1
20
20
  type: :runtime
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
24
  - - "~>"
25
25
  - !ruby/object:Gem::Version
26
- version: 0.13.0
26
+ version: 1.0.0.rc1
27
+ - !ruby/object:Gem::Dependency
28
+ name: opentelemetry-instrumentation-base
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: 0.18.0
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: 0.18.0
27
41
  - !ruby/object:Gem::Dependency
28
42
  name: appraisal
29
43
  requirement: !ruby/object:Gem::Requirement
@@ -72,14 +86,14 @@ dependencies:
72
86
  requirements:
73
87
  - - "~>"
74
88
  - !ruby/object:Gem::Version
75
- version: '0.0'
89
+ version: 1.0.0.rc1
76
90
  type: :development
77
91
  prerelease: false
78
92
  version_requirements: !ruby/object:Gem::Requirement
79
93
  requirements:
80
94
  - - "~>"
81
95
  - !ruby/object:Gem::Version
82
- version: '0.0'
96
+ version: 1.0.0.rc1
83
97
  - !ruby/object:Gem::Dependency
84
98
  name: rack
85
99
  requirement: !ruby/object:Gem::Requirement
@@ -214,10 +228,10 @@ homepage: https://github.com/open-telemetry/opentelemetry-ruby
214
228
  licenses:
215
229
  - Apache-2.0
216
230
  metadata:
217
- changelog_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-instrumentation-rack/v0.13.0/file.CHANGELOG.html
231
+ changelog_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-instrumentation-rack/v0.18.0/file.CHANGELOG.html
218
232
  source_code_uri: https://github.com/open-telemetry/opentelemetry-ruby/tree/main/instrumentation/rack
219
233
  bug_tracker_uri: https://github.com/open-telemetry/opentelemetry-ruby/issues
220
- documentation_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-instrumentation-rack/v0.13.0
234
+ documentation_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-instrumentation-rack/v0.18.0
221
235
  post_install_message:
222
236
  rdoc_options: []
223
237
  require_paths:
@@ -233,7 +247,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
233
247
  - !ruby/object:Gem::Version
234
248
  version: '0'
235
249
  requirements: []
236
- rubygems_version: 3.1.4
250
+ rubygems_version: 3.1.6
237
251
  signing_key:
238
252
  specification_version: 4
239
253
  summary: Rack instrumentation for the OpenTelemetry framework