[−][src]Struct opentelemetry::sdk::propagation::TextMapCompositePropagator
Composite propagator
A propagator that chains multiple TextMapPropagator
propagators together,
injecting or extracting by their respective HTTP header names.
Injection and extraction from this propagator will preserve the order of the injectors and extractors passed in during initialization.
Examples
use opentelemetry::{ baggage::BaggageExt, propagation::TextMapPropagator, trace::{TraceContextExt, Tracer, TracerProvider}, Context, KeyValue, }; use opentelemetry::sdk::propagation::{ BaggagePropagator, TextMapCompositePropagator, TraceContextPropagator, }; use opentelemetry::sdk::trace as sdktrace; use std::collections::HashMap; // First create 1 or more propagators let baggage_propagator = BaggagePropagator::new(); let trace_context_propagator = TraceContextPropagator::new(); // Then create a composite propagator let composite_propagator = TextMapCompositePropagator::new(vec![ Box::new(baggage_propagator), Box::new(trace_context_propagator), ]); // Then for a given implementation of `Injector` let mut injector = HashMap::new(); // And a given span let example_span = sdktrace::TracerProvider::default() .get_tracer("example-component", None) .start("span-name"); // with the current context, call inject to add the headers composite_propagator.inject_context( &Context::current_with_span(example_span) .with_baggage(vec![KeyValue::new("test", "example")]), &mut injector, ); // The injector now has both `baggage` and `traceparent` headers assert!(injector.get("baggage").is_some()); assert!(injector.get("traceparent").is_some());
Implementations
impl TextMapCompositePropagator
[src]
pub fn new(propagators: Vec<Box<dyn TextMapPropagator + Send + Sync>>) -> Self
[src]
Constructs a new propagator out of instances of TextMapPropagator
.
Trait Implementations
impl Debug for TextMapCompositePropagator
[src]
impl TextMapPropagator for TextMapCompositePropagator
[src]
fn inject_context(&self, context: &Context, injector: &mut dyn Injector)
[src]
Encodes the values of the Context
and injects them into the Injector
.
fn extract_with_context(
&self,
cx: &Context,
extractor: &dyn Extractor
) -> Context
[src]
&self,
cx: &Context,
extractor: &dyn Extractor
) -> Context
Retrieves encoded Context
information using the Extractor
. If no data was
retrieved OR if the retrieved data is invalid, then the current Context
is
returned.
fn fields(&self) -> FieldIter<'_>ⓘ
[src]
fn inject(&self, injector: &mut dyn Injector)
[src]
fn extract(&self, extractor: &dyn Extractor) -> Context
[src]
Auto Trait Implementations
impl !RefUnwindSafe for TextMapCompositePropagator
impl Send for TextMapCompositePropagator
impl Sync for TextMapCompositePropagator
impl Unpin for TextMapCompositePropagator
impl !UnwindSafe for TextMapCompositePropagator
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
[src]
V: MultiLane<T>,