
    Ki                    $   S SK Jr  S SKrS SKrS SKJr  S SKJr  S SKJ	r	  S SK
JrJr  S SKJr  S SKJr  \R"                  " \5      rSS	 jr\" 5       rSS
 jrSSS jjr S       SS jjrSS jrSS jrSS jr\" S5      r\" S5      r/ SQrg)    )annotationsN)Token)environ)uuid4)Context_RuntimeContext)OTEL_PYTHON_CONTEXT)entry_pointsc            
     H   Sn [         R                  " [        U 5      n [        [	        [        SUS95      5      R                  5       " 5       $ ! [         aI    [        R                  SUU 5        [        [	        [        SU S95      5      R                  5       " 5       s $ f = f)zKInitialize the RuntimeContext

Returns:
    An instance of RuntimeContext.
contextvars_contextopentelemetry_context)groupnamez*Failed to load context: %s, fallback to %s)
r   getr	   nextiterr
   load	Exceptionlogger	exception)default_contextconfigured_contexts     `/var/www/html/dynamic-report/venv/lib/python3.13/site-packages/opentelemetry/context/__init__.py_load_runtime_contextr      s     ,O %8/J1+
 $&  	  8	

 1(
 $&  	s   .A AB! B!c                4    U S-   [        [        5       5      -   $ )aI  To allow cross-cutting concern to control access to their local state,
the RuntimeContext API provides a function which takes a keyname as input,
and returns a unique key.
Args:
    keyname: The key name is for debugging purposes and is not required to be unique.
Returns:
    A unique string representing the newly created key.
-)strr   )keynames    r   
create_keyr   I   s     S=3uw<''    c                \    Ub  UR                  U 5      $ [        5       R                  U 5      $ )aV  To access the local state of a concern, the RuntimeContext API
provides a function which takes a context and a key as input,
and returns a value.

Args:
    key: The key of the value to retrieve.
    context: The context from which to retrieve the value, if None, the current context is used.

Returns:
    The value associated with the key.
)r   get_current)keycontexts     r   	get_valuer%   U   s*      '27;;sN8I8I#8NNr    c                Z    Uc
  [        5       nUR                  5       nXU '   [        U5      $ )a  To record the local state of a cross-cutting concern, the
RuntimeContext API provides a function which takes a context, a
key, and a value as input, and returns an updated context
which contains the new value.

Args:
    key: The key of the entry to set.
    value: The value of the entry to set.
    context: The context to copy, if None, the current context is used.

Returns:
    A new `Context` containing the value set.
)r"   copyr   )r#   valuer$   
new_valuess       r   	set_valuer*   d   s-      -JsO:r    c                 *    [         R                  5       $ )zTo access the context associated with program execution,
the Context API provides a function which takes no arguments
and returns a Context.

Returns:
    The current `Context` object.
)_RUNTIME_CONTEXTr"    r    r   r"   r"   {   s     ''))r    c                ,    [         R                  U 5      $ )zAssociates a Context with the caller's current execution unit. Returns
a token that can be used to restore the previous Context.

Args:
    context: The Context to set as current.

Returns:
    A token that can be used with `detach` to reset the context.
)r,   attach)r$   s    r   r/   r/      s     ""7++r    c                z     [         R                  U 5        g! [         a    [        R	                  S5         gf = f)zResets the Context associated with the caller's current execution unit
to the value it had before attaching a specified Context.

Args:
    token: The Token that was returned by a previous call to attach a Context.
zFailed to detach contextN)r,   detachr   r   r   )tokens    r   r1   r1      s3    5& 5345s    ::suppress_instrumentationsuppress_http_instrumentation)r   r/   r   r1   r"   r%   r*   )returnr   )r   r   r5   r   )N)r#   r   r$   typing.Optional[Context]r5   'object')r#   r   r(   r7   r$   r6   r5   r   )r5   r   )r$   r   r5   Token[Context])r2   r8   r5   None)
__future__r   loggingtypingcontextvarsr   osr   uuidr   opentelemetry.context.contextr   r   #opentelemetry.environment_variablesr	   &opentelemetry.util._importlib_metadatar
   	getLogger__name__r   r   r,   r   r%   r*   r"   r/   r1   _SUPPRESS_INSTRUMENTATION_KEY"_SUPPRESS_HTTP_INSTRUMENTATION_KEY__all__r-   r    r   <module>rH      s    #      C C ?			8	$$N )* 	(O  DH	(@.*
,
5  !++E F %/#& "r    