opentelemetry-instrumentation 0.44b0__tar.gz → 0.46b0__tar.gz
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.
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/LICENSE +1 -1
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/PKG-INFO +2 -3
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/pyproject.toml +0 -3
- opentelemetry_instrumentation-0.46b0/src/opentelemetry/instrumentation/_semconv.py +386 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/bootstrap.py +25 -16
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/bootstrap_gen.py +54 -49
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/distro.py +4 -3
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/version.py +1 -1
- opentelemetry_instrumentation-0.44b0/src/opentelemetry/instrumentation/_semconv.py +0 -217
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/.gitignore +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/README.rst +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/auto_instrumentation/__init__.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/auto_instrumentation/_load.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/auto_instrumentation/sitecustomize.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/dependencies.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/environment_variables.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/instrumentor.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/propagators.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/py.typed +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/sqlcommenter_utils.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/src/opentelemetry/instrumentation/utils.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/__init__.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/auto_instrumentation/test_load.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/auto_instrumentation/test_run.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/test_bootstrap.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/test_dependencies.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/test_distro.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/test_instrumentor.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/test_propagators.py +0 -0
- {opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/test_utils.py +0 -0
@@ -186,7 +186,7 @@
|
|
186
186
|
same "printed page" as the copyright notice for easier
|
187
187
|
identification within third-party archives.
|
188
188
|
|
189
|
-
Copyright
|
189
|
+
Copyright [yyyy] [name of copyright owner]
|
190
190
|
|
191
191
|
Licensed under the Apache License, Version 2.0 (the "License");
|
192
192
|
you may not use this file except in compliance with the License.
|
@@ -1,6 +1,6 @@
|
|
1
|
-
Metadata-Version: 2.
|
1
|
+
Metadata-Version: 2.3
|
2
2
|
Name: opentelemetry-instrumentation
|
3
|
-
Version: 0.
|
3
|
+
Version: 0.46b0
|
4
4
|
Summary: Instrumentation Tools & Auto Instrumentation for OpenTelemetry Python
|
5
5
|
Project-URL: Homepage, https://github.com/open-telemetry/opentelemetry-python-contrib/tree/main/opentelemetry-instrumentation
|
6
6
|
Author-email: OpenTelemetry Authors <cncf-opentelemetry-contributors@lists.cncf.io>
|
@@ -19,7 +19,6 @@ Requires-Python: >=3.8
|
|
19
19
|
Requires-Dist: opentelemetry-api~=1.4
|
20
20
|
Requires-Dist: setuptools>=16.0
|
21
21
|
Requires-Dist: wrapt<2.0.0,>=1.0.0
|
22
|
-
Provides-Extra: test
|
23
22
|
Description-Content-Type: text/x-rst
|
24
23
|
|
25
24
|
OpenTelemetry Instrumentation
|
{opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/pyproject.toml
RENAMED
@@ -29,9 +29,6 @@ dependencies = [
|
|
29
29
|
"wrapt >= 1.0.0, < 2.0.0",
|
30
30
|
]
|
31
31
|
|
32
|
-
[project.optional-dependencies]
|
33
|
-
test = []
|
34
|
-
|
35
32
|
[project.scripts]
|
36
33
|
opentelemetry-bootstrap = "opentelemetry.instrumentation.bootstrap:run"
|
37
34
|
opentelemetry-instrument = "opentelemetry.instrumentation.auto_instrumentation:run"
|
@@ -0,0 +1,386 @@
|
|
1
|
+
# Copyright The OpenTelemetry Authors
|
2
|
+
#
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
4
|
+
# you may not use this file except in compliance with the License.
|
5
|
+
# You may obtain a copy of the License at
|
6
|
+
#
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
+
#
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
+
# See the License for the specific language governing permissions and
|
13
|
+
# limitations under the License.
|
14
|
+
|
15
|
+
import os
|
16
|
+
import threading
|
17
|
+
from enum import Enum
|
18
|
+
|
19
|
+
from opentelemetry.instrumentation.utils import http_status_to_status_code
|
20
|
+
from opentelemetry.semconv.trace import SpanAttributes
|
21
|
+
from opentelemetry.trace.status import Status, StatusCode
|
22
|
+
|
23
|
+
# TODO: will come through semconv package once updated
|
24
|
+
_SPAN_ATTRIBUTES_ERROR_TYPE = "error.type"
|
25
|
+
_SPAN_ATTRIBUTES_NETWORK_PEER_ADDRESS = "network.peer.address"
|
26
|
+
_SPAN_ATTRIBUTES_NETWORK_PEER_PORT = "network.peer.port"
|
27
|
+
_METRIC_ATTRIBUTES_CLIENT_DURATION_NAME = "http.client.request.duration"
|
28
|
+
_METRIC_ATTRIBUTES_SERVER_DURATION_NAME = "http.server.request.duration"
|
29
|
+
|
30
|
+
_client_duration_attrs_old = [
|
31
|
+
SpanAttributes.HTTP_STATUS_CODE,
|
32
|
+
SpanAttributes.HTTP_HOST,
|
33
|
+
SpanAttributes.NET_PEER_PORT,
|
34
|
+
SpanAttributes.NET_PEER_NAME,
|
35
|
+
SpanAttributes.HTTP_METHOD,
|
36
|
+
SpanAttributes.HTTP_FLAVOR,
|
37
|
+
SpanAttributes.HTTP_SCHEME,
|
38
|
+
]
|
39
|
+
|
40
|
+
_client_duration_attrs_new = [
|
41
|
+
_SPAN_ATTRIBUTES_ERROR_TYPE,
|
42
|
+
SpanAttributes.HTTP_REQUEST_METHOD,
|
43
|
+
SpanAttributes.HTTP_RESPONSE_STATUS_CODE,
|
44
|
+
SpanAttributes.NETWORK_PROTOCOL_VERSION,
|
45
|
+
SpanAttributes.SERVER_ADDRESS,
|
46
|
+
SpanAttributes.SERVER_PORT,
|
47
|
+
# TODO: Support opt-in for scheme in new semconv
|
48
|
+
# SpanAttributes.URL_SCHEME,
|
49
|
+
]
|
50
|
+
|
51
|
+
_server_duration_attrs_old = [
|
52
|
+
SpanAttributes.HTTP_METHOD,
|
53
|
+
SpanAttributes.HTTP_HOST,
|
54
|
+
SpanAttributes.HTTP_SCHEME,
|
55
|
+
SpanAttributes.HTTP_STATUS_CODE,
|
56
|
+
SpanAttributes.HTTP_FLAVOR,
|
57
|
+
SpanAttributes.HTTP_SERVER_NAME,
|
58
|
+
SpanAttributes.NET_HOST_NAME,
|
59
|
+
SpanAttributes.NET_HOST_PORT,
|
60
|
+
]
|
61
|
+
|
62
|
+
_server_duration_attrs_new = [
|
63
|
+
_SPAN_ATTRIBUTES_ERROR_TYPE,
|
64
|
+
SpanAttributes.HTTP_REQUEST_METHOD,
|
65
|
+
SpanAttributes.HTTP_RESPONSE_STATUS_CODE,
|
66
|
+
SpanAttributes.HTTP_ROUTE,
|
67
|
+
SpanAttributes.NETWORK_PROTOCOL_VERSION,
|
68
|
+
SpanAttributes.URL_SCHEME,
|
69
|
+
]
|
70
|
+
|
71
|
+
_server_active_requests_count_attrs_old = [
|
72
|
+
SpanAttributes.HTTP_METHOD,
|
73
|
+
SpanAttributes.HTTP_HOST,
|
74
|
+
SpanAttributes.HTTP_SCHEME,
|
75
|
+
SpanAttributes.HTTP_FLAVOR,
|
76
|
+
SpanAttributes.HTTP_SERVER_NAME,
|
77
|
+
SpanAttributes.NET_HOST_NAME,
|
78
|
+
SpanAttributes.NET_HOST_PORT,
|
79
|
+
]
|
80
|
+
|
81
|
+
_server_active_requests_count_attrs_new = [
|
82
|
+
SpanAttributes.HTTP_REQUEST_METHOD,
|
83
|
+
SpanAttributes.URL_SCHEME,
|
84
|
+
]
|
85
|
+
|
86
|
+
OTEL_SEMCONV_STABILITY_OPT_IN = "OTEL_SEMCONV_STABILITY_OPT_IN"
|
87
|
+
|
88
|
+
|
89
|
+
class _OpenTelemetryStabilitySignalType:
|
90
|
+
HTTP = "http"
|
91
|
+
|
92
|
+
|
93
|
+
class _HTTPStabilityMode(Enum):
|
94
|
+
# http - emit the new, stable HTTP and networking conventions ONLY
|
95
|
+
HTTP = "http"
|
96
|
+
# http/dup - emit both the old and the stable HTTP and networking conventions
|
97
|
+
HTTP_DUP = "http/dup"
|
98
|
+
# default - continue emitting old experimental HTTP and networking conventions
|
99
|
+
DEFAULT = "default"
|
100
|
+
|
101
|
+
|
102
|
+
def _report_new(mode):
|
103
|
+
return mode.name != _HTTPStabilityMode.DEFAULT.name
|
104
|
+
|
105
|
+
|
106
|
+
def _report_old(mode):
|
107
|
+
return mode.name != _HTTPStabilityMode.HTTP.name
|
108
|
+
|
109
|
+
|
110
|
+
class _OpenTelemetrySemanticConventionStability:
|
111
|
+
_initialized = False
|
112
|
+
_lock = threading.Lock()
|
113
|
+
_OTEL_SEMCONV_STABILITY_SIGNAL_MAPPING = {}
|
114
|
+
|
115
|
+
@classmethod
|
116
|
+
def _initialize(cls):
|
117
|
+
with _OpenTelemetrySemanticConventionStability._lock:
|
118
|
+
if not _OpenTelemetrySemanticConventionStability._initialized:
|
119
|
+
# Users can pass in comma delimited string for opt-in options
|
120
|
+
# Only values for http stability are supported for now
|
121
|
+
opt_in = os.environ.get(OTEL_SEMCONV_STABILITY_OPT_IN, "")
|
122
|
+
opt_in_list = []
|
123
|
+
if opt_in:
|
124
|
+
opt_in_list = [s.strip() for s in opt_in.split(",")]
|
125
|
+
http_opt_in = _HTTPStabilityMode.DEFAULT
|
126
|
+
if opt_in_list:
|
127
|
+
# Process http opt-in
|
128
|
+
# http/dup takes priority over http
|
129
|
+
if _HTTPStabilityMode.HTTP_DUP.value in opt_in_list:
|
130
|
+
http_opt_in = _HTTPStabilityMode.HTTP_DUP
|
131
|
+
elif _HTTPStabilityMode.HTTP.value in opt_in_list:
|
132
|
+
http_opt_in = _HTTPStabilityMode.HTTP
|
133
|
+
_OpenTelemetrySemanticConventionStability._OTEL_SEMCONV_STABILITY_SIGNAL_MAPPING[
|
134
|
+
_OpenTelemetryStabilitySignalType.HTTP
|
135
|
+
] = http_opt_in
|
136
|
+
_OpenTelemetrySemanticConventionStability._initialized = True
|
137
|
+
|
138
|
+
@classmethod
|
139
|
+
# Get OpenTelemetry opt-in mode based off of signal type (http, messaging, etc.)
|
140
|
+
def _get_opentelemetry_stability_opt_in_mode(
|
141
|
+
cls,
|
142
|
+
signal_type: _OpenTelemetryStabilitySignalType,
|
143
|
+
) -> _HTTPStabilityMode:
|
144
|
+
return _OpenTelemetrySemanticConventionStability._OTEL_SEMCONV_STABILITY_SIGNAL_MAPPING.get(
|
145
|
+
signal_type, _HTTPStabilityMode.DEFAULT
|
146
|
+
)
|
147
|
+
|
148
|
+
|
149
|
+
def _filter_semconv_duration_attrs(
|
150
|
+
attrs,
|
151
|
+
old_attrs,
|
152
|
+
new_attrs,
|
153
|
+
sem_conv_opt_in_mode=_HTTPStabilityMode.DEFAULT,
|
154
|
+
):
|
155
|
+
filtered_attrs = {}
|
156
|
+
# duration is two different metrics depending on sem_conv_opt_in_mode, so no DUP attributes
|
157
|
+
allowed_attributes = (
|
158
|
+
new_attrs
|
159
|
+
if sem_conv_opt_in_mode == _HTTPStabilityMode.HTTP
|
160
|
+
else old_attrs
|
161
|
+
)
|
162
|
+
for key, val in attrs.items():
|
163
|
+
if key in allowed_attributes:
|
164
|
+
filtered_attrs[key] = val
|
165
|
+
return filtered_attrs
|
166
|
+
|
167
|
+
|
168
|
+
def _filter_semconv_active_request_count_attr(
|
169
|
+
attrs,
|
170
|
+
old_attrs,
|
171
|
+
new_attrs,
|
172
|
+
sem_conv_opt_in_mode=_HTTPStabilityMode.DEFAULT,
|
173
|
+
):
|
174
|
+
filtered_attrs = {}
|
175
|
+
if _report_old(sem_conv_opt_in_mode):
|
176
|
+
for key, val in attrs.items():
|
177
|
+
if key in old_attrs:
|
178
|
+
filtered_attrs[key] = val
|
179
|
+
if _report_new(sem_conv_opt_in_mode):
|
180
|
+
for key, val in attrs.items():
|
181
|
+
if key in new_attrs:
|
182
|
+
filtered_attrs[key] = val
|
183
|
+
return filtered_attrs
|
184
|
+
|
185
|
+
|
186
|
+
def set_string_attribute(result, key, value):
|
187
|
+
if value:
|
188
|
+
result[key] = value
|
189
|
+
|
190
|
+
|
191
|
+
def set_int_attribute(result, key, value):
|
192
|
+
if value:
|
193
|
+
try:
|
194
|
+
result[key] = int(value)
|
195
|
+
except ValueError:
|
196
|
+
return
|
197
|
+
|
198
|
+
|
199
|
+
def _set_http_method(result, original, normalized, sem_conv_opt_in_mode):
|
200
|
+
original = original.strip()
|
201
|
+
normalized = normalized.strip()
|
202
|
+
# See https://github.com/open-telemetry/semantic-conventions/blob/main/docs/http/http-spans.md#common-attributes
|
203
|
+
# Method is case sensitive. "http.request.method_original" should not be sanitized or automatically capitalized.
|
204
|
+
if original != normalized and _report_new(sem_conv_opt_in_mode):
|
205
|
+
set_string_attribute(
|
206
|
+
result, SpanAttributes.HTTP_REQUEST_METHOD_ORIGINAL, original
|
207
|
+
)
|
208
|
+
|
209
|
+
if _report_old(sem_conv_opt_in_mode):
|
210
|
+
set_string_attribute(result, SpanAttributes.HTTP_METHOD, normalized)
|
211
|
+
if _report_new(sem_conv_opt_in_mode):
|
212
|
+
set_string_attribute(
|
213
|
+
result, SpanAttributes.HTTP_REQUEST_METHOD, normalized
|
214
|
+
)
|
215
|
+
|
216
|
+
|
217
|
+
def _set_http_status_code(result, code, sem_conv_opt_in_mode):
|
218
|
+
if _report_old(sem_conv_opt_in_mode):
|
219
|
+
set_int_attribute(result, SpanAttributes.HTTP_STATUS_CODE, code)
|
220
|
+
if _report_new(sem_conv_opt_in_mode):
|
221
|
+
set_int_attribute(
|
222
|
+
result, SpanAttributes.HTTP_RESPONSE_STATUS_CODE, code
|
223
|
+
)
|
224
|
+
|
225
|
+
|
226
|
+
def _set_http_url(result, url, sem_conv_opt_in_mode):
|
227
|
+
if _report_old(sem_conv_opt_in_mode):
|
228
|
+
set_string_attribute(result, SpanAttributes.HTTP_URL, url)
|
229
|
+
if _report_new(sem_conv_opt_in_mode):
|
230
|
+
set_string_attribute(result, SpanAttributes.URL_FULL, url)
|
231
|
+
|
232
|
+
|
233
|
+
def _set_http_scheme(result, scheme, sem_conv_opt_in_mode):
|
234
|
+
if _report_old(sem_conv_opt_in_mode):
|
235
|
+
set_string_attribute(result, SpanAttributes.HTTP_SCHEME, scheme)
|
236
|
+
if _report_new(sem_conv_opt_in_mode):
|
237
|
+
set_string_attribute(result, SpanAttributes.URL_SCHEME, scheme)
|
238
|
+
|
239
|
+
|
240
|
+
def _set_http_host(result, host, sem_conv_opt_in_mode):
|
241
|
+
if _report_old(sem_conv_opt_in_mode):
|
242
|
+
set_string_attribute(result, SpanAttributes.HTTP_HOST, host)
|
243
|
+
if _report_new(sem_conv_opt_in_mode):
|
244
|
+
set_string_attribute(result, SpanAttributes.SERVER_ADDRESS, host)
|
245
|
+
|
246
|
+
|
247
|
+
# Client
|
248
|
+
|
249
|
+
|
250
|
+
def _set_http_net_peer_name_client(result, peer_name, sem_conv_opt_in_mode):
|
251
|
+
if _report_old(sem_conv_opt_in_mode):
|
252
|
+
set_string_attribute(result, SpanAttributes.NET_PEER_NAME, peer_name)
|
253
|
+
if _report_new(sem_conv_opt_in_mode):
|
254
|
+
set_string_attribute(result, SpanAttributes.SERVER_ADDRESS, peer_name)
|
255
|
+
|
256
|
+
|
257
|
+
def _set_http_peer_port_client(result, port, sem_conv_opt_in_mode):
|
258
|
+
if _report_old(sem_conv_opt_in_mode):
|
259
|
+
set_int_attribute(result, SpanAttributes.NET_PEER_PORT, port)
|
260
|
+
if _report_new(sem_conv_opt_in_mode):
|
261
|
+
set_int_attribute(result, SpanAttributes.SERVER_PORT, port)
|
262
|
+
|
263
|
+
|
264
|
+
def _set_http_network_protocol_version(result, version, sem_conv_opt_in_mode):
|
265
|
+
if _report_old(sem_conv_opt_in_mode):
|
266
|
+
set_string_attribute(result, SpanAttributes.HTTP_FLAVOR, version)
|
267
|
+
if _report_new(sem_conv_opt_in_mode):
|
268
|
+
set_string_attribute(
|
269
|
+
result, SpanAttributes.NETWORK_PROTOCOL_VERSION, version
|
270
|
+
)
|
271
|
+
|
272
|
+
|
273
|
+
# Server
|
274
|
+
|
275
|
+
|
276
|
+
def _set_http_net_host(result, host, sem_conv_opt_in_mode):
|
277
|
+
if _report_old(sem_conv_opt_in_mode):
|
278
|
+
set_string_attribute(result, SpanAttributes.NET_HOST_NAME, host)
|
279
|
+
if _report_new(sem_conv_opt_in_mode):
|
280
|
+
set_string_attribute(result, SpanAttributes.SERVER_ADDRESS, host)
|
281
|
+
|
282
|
+
|
283
|
+
def _set_http_net_host_port(result, port, sem_conv_opt_in_mode):
|
284
|
+
if _report_old(sem_conv_opt_in_mode):
|
285
|
+
set_int_attribute(result, SpanAttributes.NET_HOST_PORT, port)
|
286
|
+
if _report_new(sem_conv_opt_in_mode):
|
287
|
+
set_int_attribute(result, SpanAttributes.SERVER_PORT, port)
|
288
|
+
|
289
|
+
|
290
|
+
def _set_http_target(result, target, path, query, sem_conv_opt_in_mode):
|
291
|
+
if _report_old(sem_conv_opt_in_mode):
|
292
|
+
set_string_attribute(result, SpanAttributes.HTTP_TARGET, target)
|
293
|
+
if _report_new(sem_conv_opt_in_mode):
|
294
|
+
if path:
|
295
|
+
set_string_attribute(result, SpanAttributes.URL_PATH, path)
|
296
|
+
if query:
|
297
|
+
set_string_attribute(result, SpanAttributes.URL_QUERY, query)
|
298
|
+
|
299
|
+
|
300
|
+
def _set_http_peer_ip(result, ip, sem_conv_opt_in_mode):
|
301
|
+
if _report_old(sem_conv_opt_in_mode):
|
302
|
+
set_string_attribute(result, SpanAttributes.NET_PEER_IP, ip)
|
303
|
+
if _report_new(sem_conv_opt_in_mode):
|
304
|
+
set_string_attribute(result, SpanAttributes.CLIENT_ADDRESS, ip)
|
305
|
+
|
306
|
+
|
307
|
+
def _set_http_peer_port_server(result, port, sem_conv_opt_in_mode):
|
308
|
+
if _report_old(sem_conv_opt_in_mode):
|
309
|
+
set_int_attribute(result, SpanAttributes.NET_PEER_PORT, port)
|
310
|
+
if _report_new(sem_conv_opt_in_mode):
|
311
|
+
set_int_attribute(result, SpanAttributes.CLIENT_PORT, port)
|
312
|
+
|
313
|
+
|
314
|
+
def _set_http_user_agent(result, user_agent, sem_conv_opt_in_mode):
|
315
|
+
if _report_old(sem_conv_opt_in_mode):
|
316
|
+
set_string_attribute(
|
317
|
+
result, SpanAttributes.HTTP_USER_AGENT, user_agent
|
318
|
+
)
|
319
|
+
if _report_new(sem_conv_opt_in_mode):
|
320
|
+
set_string_attribute(
|
321
|
+
result, SpanAttributes.USER_AGENT_ORIGINAL, user_agent
|
322
|
+
)
|
323
|
+
|
324
|
+
|
325
|
+
def _set_http_net_peer_name_server(result, name, sem_conv_opt_in_mode):
|
326
|
+
if _report_old(sem_conv_opt_in_mode):
|
327
|
+
set_string_attribute(result, SpanAttributes.NET_PEER_NAME, name)
|
328
|
+
if _report_new(sem_conv_opt_in_mode):
|
329
|
+
set_string_attribute(result, SpanAttributes.CLIENT_ADDRESS, name)
|
330
|
+
|
331
|
+
|
332
|
+
def _set_http_flavor_version(result, version, sem_conv_opt_in_mode):
|
333
|
+
if _report_old(sem_conv_opt_in_mode):
|
334
|
+
set_string_attribute(result, SpanAttributes.HTTP_FLAVOR, version)
|
335
|
+
if _report_new(sem_conv_opt_in_mode):
|
336
|
+
set_string_attribute(
|
337
|
+
result, SpanAttributes.NETWORK_PROTOCOL_VERSION, version
|
338
|
+
)
|
339
|
+
|
340
|
+
|
341
|
+
def _set_status(
|
342
|
+
span,
|
343
|
+
metrics_attributes,
|
344
|
+
status_code_str,
|
345
|
+
status_code,
|
346
|
+
sem_conv_opt_in_mode,
|
347
|
+
):
|
348
|
+
if status_code < 0:
|
349
|
+
if _report_new(sem_conv_opt_in_mode):
|
350
|
+
span.set_attribute(_SPAN_ATTRIBUTES_ERROR_TYPE, status_code_str)
|
351
|
+
metrics_attributes[_SPAN_ATTRIBUTES_ERROR_TYPE] = status_code_str
|
352
|
+
|
353
|
+
span.set_status(
|
354
|
+
Status(
|
355
|
+
StatusCode.ERROR,
|
356
|
+
"Non-integer HTTP status: " + status_code_str,
|
357
|
+
)
|
358
|
+
)
|
359
|
+
else:
|
360
|
+
status = http_status_to_status_code(status_code, server_span=True)
|
361
|
+
|
362
|
+
if _report_old(sem_conv_opt_in_mode):
|
363
|
+
span.set_attribute(SpanAttributes.HTTP_STATUS_CODE, status_code)
|
364
|
+
metrics_attributes[SpanAttributes.HTTP_STATUS_CODE] = status_code
|
365
|
+
if _report_new(sem_conv_opt_in_mode):
|
366
|
+
span.set_attribute(
|
367
|
+
SpanAttributes.HTTP_RESPONSE_STATUS_CODE, status_code
|
368
|
+
)
|
369
|
+
metrics_attributes[SpanAttributes.HTTP_RESPONSE_STATUS_CODE] = (
|
370
|
+
status_code
|
371
|
+
)
|
372
|
+
if status == StatusCode.ERROR:
|
373
|
+
span.set_attribute(
|
374
|
+
_SPAN_ATTRIBUTES_ERROR_TYPE, status_code_str
|
375
|
+
)
|
376
|
+
metrics_attributes[_SPAN_ATTRIBUTES_ERROR_TYPE] = (
|
377
|
+
status_code_str
|
378
|
+
)
|
379
|
+
span.set_status(Status(status))
|
380
|
+
|
381
|
+
|
382
|
+
# Get schema version based off of opt-in mode
|
383
|
+
def _get_schema_url(mode: _HTTPStabilityMode) -> str:
|
384
|
+
if mode is _HTTPStabilityMode.DEFAULT:
|
385
|
+
return "https://opentelemetry.io/schemas/1.11.0"
|
386
|
+
return SpanAttributes.SCHEMA_URL
|
@@ -14,8 +14,14 @@
|
|
14
14
|
|
15
15
|
import argparse
|
16
16
|
import logging
|
17
|
-
import subprocess
|
18
17
|
import sys
|
18
|
+
from subprocess import (
|
19
|
+
PIPE,
|
20
|
+
CalledProcessError,
|
21
|
+
Popen,
|
22
|
+
SubprocessError,
|
23
|
+
check_call,
|
24
|
+
)
|
19
25
|
|
20
26
|
import pkg_resources
|
21
27
|
|
@@ -34,7 +40,7 @@ def _syscall(func):
|
|
34
40
|
if package:
|
35
41
|
return func(package)
|
36
42
|
return func()
|
37
|
-
except
|
43
|
+
except SubprocessError as exp:
|
38
44
|
cmd = getattr(exp, "cmd", None)
|
39
45
|
if cmd:
|
40
46
|
msg = f'Error calling system command "{" ".join(cmd)}"'
|
@@ -48,18 +54,21 @@ def _syscall(func):
|
|
48
54
|
@_syscall
|
49
55
|
def _sys_pip_install(package):
|
50
56
|
# explicit upgrade strategy to override potential pip config
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
57
|
+
try:
|
58
|
+
check_call(
|
59
|
+
[
|
60
|
+
sys.executable,
|
61
|
+
"-m",
|
62
|
+
"pip",
|
63
|
+
"install",
|
64
|
+
"-U",
|
65
|
+
"--upgrade-strategy",
|
66
|
+
"only-if-needed",
|
67
|
+
package,
|
68
|
+
]
|
69
|
+
)
|
70
|
+
except CalledProcessError as error:
|
71
|
+
print(error)
|
63
72
|
|
64
73
|
|
65
74
|
def _pip_check():
|
@@ -70,8 +79,8 @@ def _pip_check():
|
|
70
79
|
'opentelemetry-instrumentation-flask 1.0.1 has requirement opentelemetry-sdk<2.0,>=1.0, but you have opentelemetry-sdk 0.5.'
|
71
80
|
To not be too restrictive, we'll only check for relevant packages.
|
72
81
|
"""
|
73
|
-
with
|
74
|
-
[sys.executable, "-m", "pip", "check"], stdout=
|
82
|
+
with Popen(
|
83
|
+
[sys.executable, "-m", "pip", "check"], stdout=PIPE
|
75
84
|
) as check_pipe:
|
76
85
|
pip_check = check_pipe.communicate()[0].decode()
|
77
86
|
pip_check_lower = pip_check.lower()
|
@@ -18,175 +18,180 @@
|
|
18
18
|
libraries = [
|
19
19
|
{
|
20
20
|
"library": "aio_pika >= 7.2.0, < 10.0.0",
|
21
|
-
"instrumentation": "opentelemetry-instrumentation-aio-pika==0.
|
21
|
+
"instrumentation": "opentelemetry-instrumentation-aio-pika==0.46b0",
|
22
22
|
},
|
23
23
|
{
|
24
24
|
"library": "aiohttp ~= 3.0",
|
25
|
-
"instrumentation": "opentelemetry-instrumentation-aiohttp-client==0.
|
25
|
+
"instrumentation": "opentelemetry-instrumentation-aiohttp-client==0.46b0",
|
26
26
|
},
|
27
27
|
{
|
28
28
|
"library": "aiohttp ~= 3.0",
|
29
|
-
"instrumentation": "opentelemetry-instrumentation-aiohttp-server==0.
|
29
|
+
"instrumentation": "opentelemetry-instrumentation-aiohttp-server==0.46b0",
|
30
30
|
},
|
31
31
|
{
|
32
32
|
"library": "aiopg >= 0.13.0, < 2.0.0",
|
33
|
-
"instrumentation": "opentelemetry-instrumentation-aiopg==0.
|
33
|
+
"instrumentation": "opentelemetry-instrumentation-aiopg==0.46b0",
|
34
34
|
},
|
35
35
|
{
|
36
36
|
"library": "asgiref ~= 3.0",
|
37
|
-
"instrumentation": "opentelemetry-instrumentation-asgi==0.
|
37
|
+
"instrumentation": "opentelemetry-instrumentation-asgi==0.46b0",
|
38
38
|
},
|
39
39
|
{
|
40
40
|
"library": "asyncpg >= 0.12.0",
|
41
|
-
"instrumentation": "opentelemetry-instrumentation-asyncpg==0.
|
41
|
+
"instrumentation": "opentelemetry-instrumentation-asyncpg==0.46b0",
|
42
42
|
},
|
43
43
|
{
|
44
44
|
"library": "boto~=2.0",
|
45
|
-
"instrumentation": "opentelemetry-instrumentation-boto==0.
|
45
|
+
"instrumentation": "opentelemetry-instrumentation-boto==0.46b0",
|
46
46
|
},
|
47
47
|
{
|
48
48
|
"library": "boto3 ~= 1.0",
|
49
|
-
"instrumentation": "opentelemetry-instrumentation-boto3sqs==0.
|
49
|
+
"instrumentation": "opentelemetry-instrumentation-boto3sqs==0.46b0",
|
50
50
|
},
|
51
51
|
{
|
52
52
|
"library": "botocore ~= 1.0",
|
53
|
-
"instrumentation": "opentelemetry-instrumentation-botocore==0.
|
53
|
+
"instrumentation": "opentelemetry-instrumentation-botocore==0.46b0",
|
54
54
|
},
|
55
55
|
{
|
56
56
|
"library": "cassandra-driver ~= 3.25",
|
57
|
-
"instrumentation": "opentelemetry-instrumentation-cassandra==0.
|
57
|
+
"instrumentation": "opentelemetry-instrumentation-cassandra==0.46b0",
|
58
58
|
},
|
59
59
|
{
|
60
60
|
"library": "scylla-driver ~= 3.25",
|
61
|
-
"instrumentation": "opentelemetry-instrumentation-cassandra==0.
|
61
|
+
"instrumentation": "opentelemetry-instrumentation-cassandra==0.46b0",
|
62
62
|
},
|
63
63
|
{
|
64
64
|
"library": "celery >= 4.0, < 6.0",
|
65
|
-
"instrumentation": "opentelemetry-instrumentation-celery==0.
|
65
|
+
"instrumentation": "opentelemetry-instrumentation-celery==0.46b0",
|
66
66
|
},
|
67
67
|
{
|
68
68
|
"library": "confluent-kafka >= 1.8.2, <= 2.3.0",
|
69
|
-
"instrumentation": "opentelemetry-instrumentation-confluent-kafka==0.
|
69
|
+
"instrumentation": "opentelemetry-instrumentation-confluent-kafka==0.46b0",
|
70
70
|
},
|
71
71
|
{
|
72
72
|
"library": "django >= 1.10",
|
73
|
-
"instrumentation": "opentelemetry-instrumentation-django==0.
|
73
|
+
"instrumentation": "opentelemetry-instrumentation-django==0.46b0",
|
74
74
|
},
|
75
75
|
{
|
76
|
-
"library": "elasticsearch >=
|
77
|
-
"instrumentation": "opentelemetry-instrumentation-elasticsearch==0.
|
76
|
+
"library": "elasticsearch >= 6.0",
|
77
|
+
"instrumentation": "opentelemetry-instrumentation-elasticsearch==0.46b0",
|
78
78
|
},
|
79
79
|
{
|
80
80
|
"library": "falcon >= 1.4.1, < 3.1.2",
|
81
|
-
"instrumentation": "opentelemetry-instrumentation-falcon==0.
|
81
|
+
"instrumentation": "opentelemetry-instrumentation-falcon==0.46b0",
|
82
82
|
},
|
83
83
|
{
|
84
84
|
"library": "fastapi ~= 0.58",
|
85
|
-
"instrumentation": "opentelemetry-instrumentation-fastapi==0.
|
85
|
+
"instrumentation": "opentelemetry-instrumentation-fastapi==0.46b0",
|
86
86
|
},
|
87
87
|
{
|
88
88
|
"library": "flask >= 1.0",
|
89
|
-
"instrumentation": "opentelemetry-instrumentation-flask==0.
|
89
|
+
"instrumentation": "opentelemetry-instrumentation-flask==0.46b0",
|
90
90
|
},
|
91
91
|
{
|
92
92
|
"library": "grpcio ~= 1.27",
|
93
|
-
"instrumentation": "opentelemetry-instrumentation-grpc==0.
|
93
|
+
"instrumentation": "opentelemetry-instrumentation-grpc==0.46b0",
|
94
94
|
},
|
95
95
|
{
|
96
96
|
"library": "httpx >= 0.18.0",
|
97
|
-
"instrumentation": "opentelemetry-instrumentation-httpx==0.
|
97
|
+
"instrumentation": "opentelemetry-instrumentation-httpx==0.46b0",
|
98
98
|
},
|
99
99
|
{
|
100
100
|
"library": "jinja2 >= 2.7, < 4.0",
|
101
|
-
"instrumentation": "opentelemetry-instrumentation-jinja2==0.
|
101
|
+
"instrumentation": "opentelemetry-instrumentation-jinja2==0.46b0",
|
102
102
|
},
|
103
103
|
{
|
104
104
|
"library": "kafka-python >= 2.0",
|
105
|
-
"instrumentation": "opentelemetry-instrumentation-kafka-python==0.
|
105
|
+
"instrumentation": "opentelemetry-instrumentation-kafka-python==0.46b0",
|
106
106
|
},
|
107
107
|
{
|
108
108
|
"library": "mysql-connector-python ~= 8.0",
|
109
|
-
"instrumentation": "opentelemetry-instrumentation-mysql==0.
|
109
|
+
"instrumentation": "opentelemetry-instrumentation-mysql==0.46b0",
|
110
110
|
},
|
111
111
|
{
|
112
112
|
"library": "mysqlclient < 3",
|
113
|
-
"instrumentation": "opentelemetry-instrumentation-mysqlclient==0.
|
113
|
+
"instrumentation": "opentelemetry-instrumentation-mysqlclient==0.46b0",
|
114
114
|
},
|
115
115
|
{
|
116
116
|
"library": "pika >= 0.12.0",
|
117
|
-
"instrumentation": "opentelemetry-instrumentation-pika==0.
|
117
|
+
"instrumentation": "opentelemetry-instrumentation-pika==0.46b0",
|
118
|
+
},
|
119
|
+
{
|
120
|
+
"library": "psycopg >= 3.1.0",
|
121
|
+
"instrumentation": "opentelemetry-instrumentation-psycopg==0.46b0",
|
118
122
|
},
|
119
123
|
{
|
120
124
|
"library": "psycopg2 >= 2.7.3.1",
|
121
|
-
"instrumentation": "opentelemetry-instrumentation-psycopg2==0.
|
125
|
+
"instrumentation": "opentelemetry-instrumentation-psycopg2==0.46b0",
|
122
126
|
},
|
123
127
|
{
|
124
128
|
"library": "pymemcache >= 1.3.5, < 5",
|
125
|
-
"instrumentation": "opentelemetry-instrumentation-pymemcache==0.
|
129
|
+
"instrumentation": "opentelemetry-instrumentation-pymemcache==0.46b0",
|
126
130
|
},
|
127
131
|
{
|
128
132
|
"library": "pymongo >= 3.1, < 5.0",
|
129
|
-
"instrumentation": "opentelemetry-instrumentation-pymongo==0.
|
133
|
+
"instrumentation": "opentelemetry-instrumentation-pymongo==0.46b0",
|
130
134
|
},
|
131
135
|
{
|
132
136
|
"library": "PyMySQL < 2",
|
133
|
-
"instrumentation": "opentelemetry-instrumentation-pymysql==0.
|
137
|
+
"instrumentation": "opentelemetry-instrumentation-pymysql==0.46b0",
|
134
138
|
},
|
135
139
|
{
|
136
140
|
"library": "pyramid >= 1.7",
|
137
|
-
"instrumentation": "opentelemetry-instrumentation-pyramid==0.
|
141
|
+
"instrumentation": "opentelemetry-instrumentation-pyramid==0.46b0",
|
138
142
|
},
|
139
143
|
{
|
140
144
|
"library": "redis >= 2.6",
|
141
|
-
"instrumentation": "opentelemetry-instrumentation-redis==0.
|
145
|
+
"instrumentation": "opentelemetry-instrumentation-redis==0.46b0",
|
142
146
|
},
|
143
147
|
{
|
144
148
|
"library": "remoulade >= 0.50",
|
145
|
-
"instrumentation": "opentelemetry-instrumentation-remoulade==0.
|
149
|
+
"instrumentation": "opentelemetry-instrumentation-remoulade==0.46b0",
|
146
150
|
},
|
147
151
|
{
|
148
152
|
"library": "requests ~= 2.0",
|
149
|
-
"instrumentation": "opentelemetry-instrumentation-requests==0.
|
153
|
+
"instrumentation": "opentelemetry-instrumentation-requests==0.46b0",
|
150
154
|
},
|
151
155
|
{
|
152
156
|
"library": "scikit-learn ~= 0.24.0",
|
153
|
-
"instrumentation": "opentelemetry-instrumentation-sklearn==0.
|
157
|
+
"instrumentation": "opentelemetry-instrumentation-sklearn==0.46b0",
|
154
158
|
},
|
155
159
|
{
|
156
160
|
"library": "sqlalchemy",
|
157
|
-
"instrumentation": "opentelemetry-instrumentation-sqlalchemy==0.
|
161
|
+
"instrumentation": "opentelemetry-instrumentation-sqlalchemy==0.46b0",
|
158
162
|
},
|
159
163
|
{
|
160
164
|
"library": "starlette ~= 0.13.0",
|
161
|
-
"instrumentation": "opentelemetry-instrumentation-starlette==0.
|
165
|
+
"instrumentation": "opentelemetry-instrumentation-starlette==0.46b0",
|
162
166
|
},
|
163
167
|
{
|
164
168
|
"library": "psutil >= 5",
|
165
|
-
"instrumentation": "opentelemetry-instrumentation-system-metrics==0.
|
169
|
+
"instrumentation": "opentelemetry-instrumentation-system-metrics==0.46b0",
|
166
170
|
},
|
167
171
|
{
|
168
172
|
"library": "tornado >= 5.1.1",
|
169
|
-
"instrumentation": "opentelemetry-instrumentation-tornado==0.
|
173
|
+
"instrumentation": "opentelemetry-instrumentation-tornado==0.46b0",
|
170
174
|
},
|
171
175
|
{
|
172
176
|
"library": "tortoise-orm >= 0.17.0",
|
173
|
-
"instrumentation": "opentelemetry-instrumentation-tortoiseorm==0.
|
177
|
+
"instrumentation": "opentelemetry-instrumentation-tortoiseorm==0.46b0",
|
174
178
|
},
|
175
179
|
{
|
176
180
|
"library": "pydantic >= 1.10.2",
|
177
|
-
"instrumentation": "opentelemetry-instrumentation-tortoiseorm==0.
|
181
|
+
"instrumentation": "opentelemetry-instrumentation-tortoiseorm==0.46b0",
|
178
182
|
},
|
179
183
|
{
|
180
184
|
"library": "urllib3 >= 1.0.0, < 3.0.0",
|
181
|
-
"instrumentation": "opentelemetry-instrumentation-urllib3==0.
|
185
|
+
"instrumentation": "opentelemetry-instrumentation-urllib3==0.46b0",
|
182
186
|
},
|
183
187
|
]
|
184
188
|
default_instrumentations = [
|
185
|
-
"opentelemetry-instrumentation-asyncio==0.
|
186
|
-
"opentelemetry-instrumentation-aws-lambda==0.
|
187
|
-
"opentelemetry-instrumentation-dbapi==0.
|
188
|
-
"opentelemetry-instrumentation-logging==0.
|
189
|
-
"opentelemetry-instrumentation-sqlite3==0.
|
190
|
-
"opentelemetry-instrumentation-
|
191
|
-
"opentelemetry-instrumentation-
|
189
|
+
"opentelemetry-instrumentation-asyncio==0.46b0",
|
190
|
+
"opentelemetry-instrumentation-aws-lambda==0.46b0",
|
191
|
+
"opentelemetry-instrumentation-dbapi==0.46b0",
|
192
|
+
"opentelemetry-instrumentation-logging==0.46b0",
|
193
|
+
"opentelemetry-instrumentation-sqlite3==0.46b0",
|
194
|
+
"opentelemetry-instrumentation-threading==0.46b0",
|
195
|
+
"opentelemetry-instrumentation-urllib==0.46b0",
|
196
|
+
"opentelemetry-instrumentation-wsgi==0.46b0",
|
192
197
|
]
|
@@ -50,9 +50,10 @@ class BaseDistro(ABC):
|
|
50
50
|
def load_instrumentor( # pylint: disable=no-self-use
|
51
51
|
self, entry_point: EntryPoint, **kwargs
|
52
52
|
):
|
53
|
-
"""Takes
|
54
|
-
and
|
55
|
-
|
53
|
+
"""Takes an instrumentation entry point and activates it by instantiating
|
54
|
+
and calling instrument() on it.
|
55
|
+
This is called for each opentelemetry_instrumentor entry point by auto
|
56
|
+
instrumentation.
|
56
57
|
|
57
58
|
Distros can override this method to customize the behavior by
|
58
59
|
inspecting each entry point and configuring them in special ways,
|
@@ -1,217 +0,0 @@
|
|
1
|
-
# Copyright The OpenTelemetry Authors
|
2
|
-
#
|
3
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
4
|
-
# you may not use this file except in compliance with the License.
|
5
|
-
# You may obtain a copy of the License at
|
6
|
-
#
|
7
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
-
#
|
9
|
-
# Unless required by applicable law or agreed to in writing, software
|
10
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
-
# See the License for the specific language governing permissions and
|
13
|
-
# limitations under the License.
|
14
|
-
|
15
|
-
import os
|
16
|
-
import threading
|
17
|
-
from enum import Enum
|
18
|
-
|
19
|
-
from opentelemetry.semconv.trace import SpanAttributes
|
20
|
-
|
21
|
-
# TODO: will come through semconv package once updated
|
22
|
-
_SPAN_ATTRIBUTES_ERROR_TYPE = "error.type"
|
23
|
-
_SPAN_ATTRIBUTES_NETWORK_PEER_ADDRESS = "network.peer.address"
|
24
|
-
_SPAN_ATTRIBUTES_NETWORK_PEER_PORT = "network.peer.port"
|
25
|
-
_METRIC_ATTRIBUTES_CLIENT_DURATION_NAME = "http.client.request.duration"
|
26
|
-
|
27
|
-
_client_duration_attrs_old = [
|
28
|
-
SpanAttributes.HTTP_STATUS_CODE,
|
29
|
-
SpanAttributes.HTTP_HOST,
|
30
|
-
SpanAttributes.NET_PEER_PORT,
|
31
|
-
SpanAttributes.NET_PEER_NAME,
|
32
|
-
SpanAttributes.HTTP_METHOD,
|
33
|
-
SpanAttributes.HTTP_FLAVOR,
|
34
|
-
SpanAttributes.HTTP_SCHEME,
|
35
|
-
]
|
36
|
-
|
37
|
-
_client_duration_attrs_new = [
|
38
|
-
_SPAN_ATTRIBUTES_ERROR_TYPE,
|
39
|
-
SpanAttributes.HTTP_REQUEST_METHOD,
|
40
|
-
SpanAttributes.HTTP_RESPONSE_STATUS_CODE,
|
41
|
-
SpanAttributes.NETWORK_PROTOCOL_VERSION,
|
42
|
-
SpanAttributes.SERVER_ADDRESS,
|
43
|
-
SpanAttributes.SERVER_PORT,
|
44
|
-
# TODO: Support opt-in for scheme in new semconv
|
45
|
-
# SpanAttributes.URL_SCHEME,
|
46
|
-
]
|
47
|
-
|
48
|
-
|
49
|
-
def _filter_duration_attrs(attrs, sem_conv_opt_in_mode):
|
50
|
-
filtered_attrs = {}
|
51
|
-
allowed_attributes = (
|
52
|
-
_client_duration_attrs_new
|
53
|
-
if sem_conv_opt_in_mode == _OpenTelemetryStabilityMode.HTTP
|
54
|
-
else _client_duration_attrs_old
|
55
|
-
)
|
56
|
-
for key, val in attrs.items():
|
57
|
-
if key in allowed_attributes:
|
58
|
-
filtered_attrs[key] = val
|
59
|
-
return filtered_attrs
|
60
|
-
|
61
|
-
|
62
|
-
def set_string_attribute(result, key, value):
|
63
|
-
if value:
|
64
|
-
result[key] = value
|
65
|
-
|
66
|
-
|
67
|
-
def set_int_attribute(result, key, value):
|
68
|
-
if value:
|
69
|
-
try:
|
70
|
-
result[key] = int(value)
|
71
|
-
except ValueError:
|
72
|
-
return
|
73
|
-
|
74
|
-
|
75
|
-
def _set_http_method(result, original, normalized, sem_conv_opt_in_mode):
|
76
|
-
original = original.strip()
|
77
|
-
normalized = normalized.strip()
|
78
|
-
# See https://github.com/open-telemetry/semantic-conventions/blob/main/docs/http/http-spans.md#common-attributes
|
79
|
-
# Method is case sensitive. "http.request.method_original" should not be sanitized or automatically capitalized.
|
80
|
-
if original != normalized and _report_new(sem_conv_opt_in_mode):
|
81
|
-
set_string_attribute(
|
82
|
-
result, SpanAttributes.HTTP_REQUEST_METHOD_ORIGINAL, original
|
83
|
-
)
|
84
|
-
|
85
|
-
if _report_old(sem_conv_opt_in_mode):
|
86
|
-
set_string_attribute(result, SpanAttributes.HTTP_METHOD, normalized)
|
87
|
-
if _report_new(sem_conv_opt_in_mode):
|
88
|
-
set_string_attribute(
|
89
|
-
result, SpanAttributes.HTTP_REQUEST_METHOD, normalized
|
90
|
-
)
|
91
|
-
|
92
|
-
|
93
|
-
def _set_http_url(result, url, sem_conv_opt_in_mode):
|
94
|
-
if _report_old(sem_conv_opt_in_mode):
|
95
|
-
set_string_attribute(result, SpanAttributes.HTTP_URL, url)
|
96
|
-
if _report_new(sem_conv_opt_in_mode):
|
97
|
-
set_string_attribute(result, SpanAttributes.URL_FULL, url)
|
98
|
-
|
99
|
-
|
100
|
-
def _set_http_scheme(result, scheme, sem_conv_opt_in_mode):
|
101
|
-
if _report_old(sem_conv_opt_in_mode):
|
102
|
-
set_string_attribute(result, SpanAttributes.HTTP_SCHEME, scheme)
|
103
|
-
# TODO: Support opt-in for scheme in new semconv
|
104
|
-
# if _report_new(sem_conv_opt_in_mode):
|
105
|
-
# set_string_attribute(result, SpanAttributes.URL_SCHEME, scheme)
|
106
|
-
|
107
|
-
|
108
|
-
def _set_http_hostname(result, hostname, sem_conv_opt_in_mode):
|
109
|
-
if _report_old(sem_conv_opt_in_mode):
|
110
|
-
set_string_attribute(result, SpanAttributes.HTTP_HOST, hostname)
|
111
|
-
if _report_new(sem_conv_opt_in_mode):
|
112
|
-
set_string_attribute(result, SpanAttributes.SERVER_ADDRESS, hostname)
|
113
|
-
|
114
|
-
|
115
|
-
def _set_http_net_peer_name(result, peer_name, sem_conv_opt_in_mode):
|
116
|
-
if _report_old(sem_conv_opt_in_mode):
|
117
|
-
set_string_attribute(result, SpanAttributes.NET_PEER_NAME, peer_name)
|
118
|
-
if _report_new(sem_conv_opt_in_mode):
|
119
|
-
set_string_attribute(result, SpanAttributes.SERVER_ADDRESS, peer_name)
|
120
|
-
|
121
|
-
|
122
|
-
def _set_http_port(result, port, sem_conv_opt_in_mode):
|
123
|
-
if _report_old(sem_conv_opt_in_mode):
|
124
|
-
set_int_attribute(result, SpanAttributes.NET_PEER_PORT, port)
|
125
|
-
if _report_new(sem_conv_opt_in_mode):
|
126
|
-
set_int_attribute(result, SpanAttributes.SERVER_PORT, port)
|
127
|
-
|
128
|
-
|
129
|
-
def _set_http_status_code(result, code, sem_conv_opt_in_mode):
|
130
|
-
if _report_old(sem_conv_opt_in_mode):
|
131
|
-
set_int_attribute(result, SpanAttributes.HTTP_STATUS_CODE, code)
|
132
|
-
if _report_new(sem_conv_opt_in_mode):
|
133
|
-
set_int_attribute(
|
134
|
-
result, SpanAttributes.HTTP_RESPONSE_STATUS_CODE, code
|
135
|
-
)
|
136
|
-
|
137
|
-
|
138
|
-
def _set_http_network_protocol_version(result, version, sem_conv_opt_in_mode):
|
139
|
-
if _report_old(sem_conv_opt_in_mode):
|
140
|
-
set_string_attribute(result, SpanAttributes.HTTP_FLAVOR, version)
|
141
|
-
if _report_new(sem_conv_opt_in_mode):
|
142
|
-
set_string_attribute(
|
143
|
-
result, SpanAttributes.NETWORK_PROTOCOL_VERSION, version
|
144
|
-
)
|
145
|
-
|
146
|
-
|
147
|
-
_OTEL_SEMCONV_STABILITY_OPT_IN_KEY = "OTEL_SEMCONV_STABILITY_OPT_IN"
|
148
|
-
|
149
|
-
|
150
|
-
class _OpenTelemetryStabilitySignalType:
|
151
|
-
HTTP = "http"
|
152
|
-
|
153
|
-
|
154
|
-
class _OpenTelemetryStabilityMode(Enum):
|
155
|
-
# http - emit the new, stable HTTP and networking conventions ONLY
|
156
|
-
HTTP = "http"
|
157
|
-
# http/dup - emit both the old and the stable HTTP and networking conventions
|
158
|
-
HTTP_DUP = "http/dup"
|
159
|
-
# default - continue emitting old experimental HTTP and networking conventions
|
160
|
-
DEFAULT = "default"
|
161
|
-
|
162
|
-
|
163
|
-
def _report_new(mode):
|
164
|
-
return mode.name != _OpenTelemetryStabilityMode.DEFAULT.name
|
165
|
-
|
166
|
-
|
167
|
-
def _report_old(mode):
|
168
|
-
return mode.name != _OpenTelemetryStabilityMode.HTTP.name
|
169
|
-
|
170
|
-
|
171
|
-
class _OpenTelemetrySemanticConventionStability:
|
172
|
-
_initialized = False
|
173
|
-
_lock = threading.Lock()
|
174
|
-
_OTEL_SEMCONV_STABILITY_SIGNAL_MAPPING = {}
|
175
|
-
|
176
|
-
@classmethod
|
177
|
-
def _initialize(cls):
|
178
|
-
with _OpenTelemetrySemanticConventionStability._lock:
|
179
|
-
if not _OpenTelemetrySemanticConventionStability._initialized:
|
180
|
-
# Users can pass in comma delimited string for opt-in options
|
181
|
-
# Only values for http stability are supported for now
|
182
|
-
opt_in = os.environ.get(_OTEL_SEMCONV_STABILITY_OPT_IN_KEY, "")
|
183
|
-
opt_in_list = []
|
184
|
-
if opt_in:
|
185
|
-
opt_in_list = [s.strip() for s in opt_in.split(",")]
|
186
|
-
http_opt_in = _OpenTelemetryStabilityMode.DEFAULT
|
187
|
-
if opt_in_list:
|
188
|
-
# Process http opt-in
|
189
|
-
# http/dup takes priority over http
|
190
|
-
if (
|
191
|
-
_OpenTelemetryStabilityMode.HTTP_DUP.value
|
192
|
-
in opt_in_list
|
193
|
-
):
|
194
|
-
http_opt_in = _OpenTelemetryStabilityMode.HTTP_DUP
|
195
|
-
elif _OpenTelemetryStabilityMode.HTTP.value in opt_in_list:
|
196
|
-
http_opt_in = _OpenTelemetryStabilityMode.HTTP
|
197
|
-
_OpenTelemetrySemanticConventionStability._OTEL_SEMCONV_STABILITY_SIGNAL_MAPPING[
|
198
|
-
_OpenTelemetryStabilitySignalType.HTTP
|
199
|
-
] = http_opt_in
|
200
|
-
_OpenTelemetrySemanticConventionStability._initialized = True
|
201
|
-
|
202
|
-
@classmethod
|
203
|
-
# Get OpenTelemetry opt-in mode based off of signal type (http, messaging, etc.)
|
204
|
-
def _get_opentelemetry_stability_opt_in_mode(
|
205
|
-
cls,
|
206
|
-
signal_type: _OpenTelemetryStabilitySignalType,
|
207
|
-
) -> _OpenTelemetryStabilityMode:
|
208
|
-
return _OpenTelemetrySemanticConventionStability._OTEL_SEMCONV_STABILITY_SIGNAL_MAPPING.get(
|
209
|
-
signal_type, _OpenTelemetryStabilityMode.DEFAULT
|
210
|
-
)
|
211
|
-
|
212
|
-
|
213
|
-
# Get schema version based off of opt-in mode
|
214
|
-
def _get_schema_url(mode: _OpenTelemetryStabilityMode) -> str:
|
215
|
-
if mode is _OpenTelemetryStabilityMode.DEFAULT:
|
216
|
-
return "https://opentelemetry.io/schemas/1.11.0"
|
217
|
-
return SpanAttributes.SCHEMA_URL
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/__init__.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/test_distro.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
{opentelemetry_instrumentation-0.44b0 → opentelemetry_instrumentation-0.46b0}/tests/test_utils.py
RENAMED
File without changes
|