opentelemetry.propagators.textmap
Module contents
- class opentelemetry.propagators.textmap.Getter(*args, **kwds)[source]
-
This class implements a Getter that enables extracting propagated fields from a carrier.
- class opentelemetry.propagators.textmap.Setter(*args, **kwds)[source]
-
This class implements a Setter that enables injecting propagated fields into a carrier.
- class opentelemetry.propagators.textmap.DefaultGetter(*args, **kwds)[source]
- class opentelemetry.propagators.textmap.TextMapPropagator[source]
Bases:
ABC
This class provides an interface that enables extracting and injecting context into headers of HTTP requests. HTTP frameworks and clients can integrate with TextMapPropagator by providing the object containing the headers, and a getter and setter function for the extraction and injection of values, respectively.
- abstract extract(carrier, context=None, getter=<opentelemetry.propagators.textmap.DefaultGetter object>)[source]
Create a Context from values in the carrier.
The extract function should retrieve values from the carrier object using getter, and use values to populate a Context value and return it.
- Parameters:
getter (
Getter
[TypeVar
(CarrierT
)]) – a function that can retrieve zero or more values from the carrier. In the case that the value does not exist, return an empty list.carrier (
TypeVar
(CarrierT
)) – and object which contains values that are used to construct a Context. This object must be paired with an appropriate getter which understands how to extract a value from it.context (
Optional
[Context
]) – an optional Context to use. Defaults to root context if not set.
- Return type:
- Returns:
A Context with configuration found in the carrier.
- abstract inject(carrier, context=None, setter=<opentelemetry.propagators.textmap.DefaultSetter object>)[source]
Inject values from a Context into a carrier.
inject enables the propagation of values into HTTP clients or other objects which perform an HTTP request. Implementations should use the Setter ‘s set method to set values on the carrier.
- Parameters:
carrier (
TypeVar
(CarrierT
)) – An object that a place to define HTTP headers. Should be paired with setter, which should know how to set header values on the carrier.context (
Optional
[Context
]) – an optional Context to use. Defaults to current context if not set.setter (
Setter
[TypeVar
(CarrierT
)]) – An optional Setter object that can set values on the carrier.
- Return type: