
    i                        d Z ddlmZ ddlmZ ddlmZ ddlmZ ddl	m
Z
 ddlmZmZ ddlmZ  ee          Zd	ej        fd
ej        dee         dej        ej                 defdZd	ej        fd
ej        dee         dej        ej                 dd	fdZg Z ej        e
d          Ze                    d          D ]Ze                                Z	 e                      e  e! ede                              "                                                       d# e#$ r e$                    de            w xY w ej%        e          a&dej'        fdZ(dej'        dd	fdZ)d	S )ax  
API for propagation of context.

The propagators for the
``mysql.opentelemetry.propagators.composite.CompositePropagator`` can be defined
via configuration in the ``OTEL_PROPAGATORS`` environment variable. This
variable should be set to a comma-separated string of names of values for the
``opentelemetry_propagator`` entry point. For example, setting
``OTEL_PROPAGATORS`` to ``tracecontext,baggage`` (which is the default value)
would instantiate
``mysql.opentelemetry.propagators.composite.CompositePropagator`` with 2
propagators, one of type
``mysql.opentelemetry.trace.propagation.tracecontext.TraceContextTextMapPropagator``
and other of type ``mysql.opentelemetry.baggage.propagation.W3CBaggagePropagator``.
Notice that these propagator classes are defined as
``opentelemetry_propagator`` entry points in the ``pyproject.toml`` file of
``opentelemetry``.

Example::

    import flask
    import requests
    from opentelemetry import propagate


    PROPAGATOR = propagate.get_global_textmap()


    def get_header_from_flask_request(request, key):
        return request.headers.get_all(key)

    def set_header_into_requests_request(request: requests.Request,
                                            key: str, value: str):
        request.headers[key] = value

    def example_route():
        context = PROPAGATOR.extract(
            get_header_from_flask_request,
            flask.request
        )
        request_to_downstream = requests.Request(
            "GET", "http://httpbin.org/get"
        )
        PROPAGATOR.inject(
            set_header_into_requests_request,
            request_to_downstream,
            context=context
        )
        session = requests.Session()
        session.send(request_to_downstream.prepare())


.. _Propagation API Specification:
    https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/context/api-propagators.md
    )	getLogger)environ)Optional)Context)OTEL_PROPAGATORS)	compositetextmap)entry_pointsNcarriercontextgetterreturnc                 J    t                                          | ||          S )aZ  Uses the configured propagator to extract a Context from the carrier.

    Args:
        getter: an object which contains a get function that can retrieve zero
            or more values from the carrier and a keys function that can get all the keys
            from carrier.
        carrier: 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: an optional Context to use. Defaults to root
            context if not set.
    )r   )get_global_textmapextract)r   r   r   s      `/var/www/cyber-strat/venv/lib/python3.11/site-packages/mysql/opentelemetry/propagate/__init__.pyr   r   S   s%    $ '''HHH    setterc                 N    t                                          | ||           dS )a  Uses the configured propagator to inject a Context into the carrier.

    Args:
        carrier: An object that contains a representation of HTTP
            headers. Should be paired with setter, which
            should know how to set header values on the carrier.
        context: An optional Context to use. Defaults to current
            context if not set.
        setter: An optional `Setter` object that can set values
            on the carrier.
    )r   r   N)r   inject)r   r   r   s      r   r   r   h   s+      HHHHHr   ztracecontext,baggage,opentelemetry_propagator)groupnamez(Failed to load configured propagator: %sc                      t           S N_HTTP_TEXT_FORMAT r   r   r   r      s    r   http_text_formatc                 
    | a d S r   r   )r    s    r   set_global_textmapr"      s     )r   )*__doc__loggingr   osr   typingr   #mysql.opentelemetry.context.contextr   )mysql.opentelemetry.environment_variablesr   mysql.opentelemetry.propagatorsr   r	   ,mysql.opentelemetry.util._importlib_metadatar
   __name__loggerdefault_getterCarrierTGetterr   default_setterSetterr   propagatorsgetenviron_propagatorssplit
propagatorstripappendnextiterload	Exception	exceptionCompositePropagatorr   TextMapPropagatorr   r"   r   r   r   <module>r@      s  6 6p                   7 7 7 7 7 7 F F F F F F > > > > > > > > E E E E E E	8		
 "&/6/EI IIgI N7+,I 	I I I I. "&/6/EI IIgI N7+,I 
	I I I I&  "gk   &++C00  J!!##JDD L8'     dff 		
 		
 		
 		
    CZPPP
 2I1+>> G5    )/)	) ) ) ) ) )s   AD$$E