o
    KDio                     @   s  U d Z ddlZddlmZmZ ddlmZ ddlmZ ddl	m
Z
 ddlmZmZmZmZmZmZmZ ddlmZ dd	lmZmZmZmZmZmZmZmZmZmZm Z m!Z!m"Z"m#Z#m$Z$m%Z%m&Z&m'Z'm(Z(m)Z)m*Z*m+Z+ dd
l,m-Z- ddl.m/Z/ ddl0m1Z1 ee2Z3ee%e'e&e(e)e*e+f Z4G dd deZ5G dd de5Z6G dd de5Z7G dd deZ8G dd de8Z9G dd de8Z:e- Z;da<ee5 e=d< e7 Z>			d)de?de?dee5 dee? ddf
d d!Z@de5d"eAddfd#d$ZBde5ddfd%d&ZCde5fd'd(ZDdS )*a  
The OpenTelemetry metrics API  describes the classes used to generate
metrics.

The :class:`.MeterProvider` provides users access to the :class:`.Meter` which in
turn is used to create :class:`.Instrument` objects. The :class:`.Instrument` objects are
used to record measurements.

This module provides abstract (i.e. unimplemented) classes required for
metrics, and a concrete no-op implementation :class:`.NoOpMeter` that allows applications
to use the API package alone without a supporting implementation.

To get a meter, you need to provide the package name from which you are
calling the meter APIs to OpenTelemetry by calling `MeterProvider.get_meter`
with the calling instrumentation name and the version of your package.

The following code shows how to obtain a meter using the global :class:`.MeterProvider`::

    from opentelemetry.metrics import get_meter

    meter = get_meter("example-meter")
    counter = meter.create_counter("example-counter")

.. versionadded:: 1.10.0
    N)ABCabstractmethod)	getLogger)environ)Lock)ListOptionalSequenceSetTupleUnioncast)OTEL_PYTHON_METER_PROVIDER)	CallbackTCounterGauge	HistogramNoOpCounter	NoOpGaugeNoOpHistogramNoOpObservableCounterNoOpObservableGaugeNoOpObservableUpDownCounterNoOpUpDownCounterObservableCounterObservableGaugeObservableUpDownCounterUpDownCounter_ProxyCounter_ProxyGauge_ProxyHistogram_ProxyObservableCounter_ProxyObservableGauge_ProxyObservableUpDownCounter_ProxyUpDownCounter)Once)_load_provider)
Attributesc                   @   sF   e Zd ZdZe			ddedee dee dee ddf
d	d
ZdS )MeterProviderz_
    MeterProvider is the entry point of the API. It provides access to `Meter` instances.
    Nnameversion
schema_url
attributesreturnMeterc                 C      dS )aD  Returns a `Meter` for use by the given instrumentation library.

        For any two calls it is undefined whether the same or different
        `Meter` instances are returned, even for different library names.

        This function may return different `Meter` types (e.g. a no-op meter
        vs. a functional meter).

        Args:
            name: The name of the instrumenting module.
                ``__name__`` may not be used as this can result in
                different meter names if the meters are in different files.
                It is better to use a fixed string that can be imported where
                needed and used consistently as the name of the meter.

                This should *not* be the name of the module that is
                instrumented but the name of the module doing the instrumentation.
                E.g., instead of ``"requests"``, use
                ``"opentelemetry.instrumentation.requests"``.

            version: Optional. The version string of the
                instrumenting library.  Usually this should be the same as
                ``importlib.metadata.version(instrumenting_library_name)``.

            schema_url: Optional. Specifies the Schema URL of the emitted telemetry.
            attributes: Optional. Attributes that are associated with the emitted telemetry.
        N selfr)   r*   r+   r,   r0   r0   a/var/www/Datamplify/venv/lib/python3.10/site-packages/opentelemetry/metrics/_internal/__init__.py	get_meterd       zMeterProvider.get_meterNNN)	__name__
__module____qualname____doc__r   strr   r'   r4   r0   r0   r0   r3   r(   _   s"    r(   c                   @   sB   e Zd ZdZ			ddedee dee dee ddf
d	d
ZdS )NoOpMeterProviderzQThe default MeterProvider used when no MeterProvider implementation is available.Nr)   r*   r+   r,   r-   r.   c                 C   s   t |||dS )zReturns a NoOpMeter.r*   r+   )	NoOpMeterr1   r0   r0   r3   r4      s   zNoOpMeterProvider.get_meterr6   )r7   r8   r9   r:   r;   r   r'   r4   r0   r0   r0   r3   r<      s     r<   c                   @   sZ   e Zd ZdddZ			ddedee dee dee dd	f
d
dZdeddfddZ	dS )_ProxyMeterProviderr-   Nc                 C   s   t  | _g | _d | _d S N)r   _lock_meters_real_meter_providerr2   r0   r0   r3   __init__   s   
z_ProxyMeterProvider.__init__r)   r*   r+   r,   r.   c                 C   sp   | j + | jd ur| j|||W  d    S t|||d}| j| |W  d    S 1 s1w   Y  d S Nr=   )rA   rC   r4   _ProxyMeterrB   append)r2   r)   r*   r+   r,   meterr0   r0   r3   r4      s   
$z_ProxyMeterProvider.get_metermeter_providerc                 C   sH   | j  || _| jD ]}|| q
W d    d S 1 sw   Y  d S r@   )rA   rC   rB   on_set_meter_provider)r2   rJ   rI   r0   r0   r3   rK      s   
"z)_ProxyMeterProvider.on_set_meter_providerr-   Nr6   )
r7   r8   r9   rE   r;   r   r'   r4   r(   rK   r0   r0   r0   r3   r?      s"    

r?   c                       s  e Zd ZdZ		d$dedee dee ddf fddZedefd	d
Zedee fddZ	edee fddZ
dededededeeef f
ddZe		d%dedededefddZe		d%dedededefddZe			d&dedeee  dededef
ddZe		d%dedededefddZ		d%dedededefddZe			d&dedeee  dededef
d d!Ze			d&dedeee  dededef
d"d#Z  Z S )'r.   zHandles instrument creation.

    This class provides methods for creating instruments which are then
    used to produce measurements.
    Nr)   r*   r+   r-   c                    s0   t    || _|| _|| _t | _t | _d S r@   )	superrE   _name_version_schema_urlset_instrument_idsr   _instrument_ids_lockr2   r)   r*   r+   	__class__r0   r3   rE      s   
zMeter.__init__c                 C      | j S )z7
        The name of the instrumenting module.
        )rN   rD   r0   r0   r3   r)         z
Meter.namec                 C   rW   )zB
        The version string of the instrumenting library.
        )rO   rD   r0   r0   r3   r*      rX   zMeter.versionc                 C   rW   )zC
        Specifies the Schema URL of the emitted telemetry
        )rP   rD   r0   r0   r3   r+      rX   zMeter.schema_urltype_unitdescriptionc                 C   s   d |  |j||g}d}| j# || jv rd}n| j| W d   ||fS W d   ||fS 1 s9w   Y  ||fS )a)  
        Check if an instrument with the same name, type, unit and description
        has been registered already.

        Returns a tuple. The first value is `True` if the instrument has been
        registered already, `False` otherwise. The second value is the
        instrument id.
        ,FTN)joinstriplowerr7   rS   rR   add)r2   r)   rY   rZ   r[   instrument_idresultr0   r0   r3   _is_instrument_registered   s   


zMeter._is_instrument_registered c                 C   r/   )aR  Creates a `Counter` instrument

        Args:
            name: The name of the instrument to be created
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr0   r2   r)   rZ   r[   r0   r0   r3   create_counter   r5   zMeter.create_counterc                 C   r/   )aY  Creates an `UpDownCounter` instrument

        Args:
            name: The name of the instrument to be created
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr0   re   r0   r0   r3   create_up_down_counter  r5   zMeter.create_up_down_counter	callbacksc                 C   r/   )a  Creates an `ObservableCounter` instrument

        An observable counter observes a monotonically increasing count by calling provided
        callbacks which accept a :class:`~opentelemetry.metrics.CallbackOptions` and return
        multiple :class:`~opentelemetry.metrics.Observation`.

        For example, an observable counter could be used to report system CPU
        time periodically. Here is a basic implementation::

            def cpu_time_callback(options: CallbackOptions) -> Iterable[Observation]:
                observations = []
                with open("/proc/stat") as procstat:
                    procstat.readline()  # skip the first line
                    for line in procstat:
                        if not line.startswith("cpu"): break
                        cpu, *states = line.split()
                        observations.append(Observation(int(states[0]) // 100, {"cpu": cpu, "state": "user"}))
                        observations.append(Observation(int(states[1]) // 100, {"cpu": cpu, "state": "nice"}))
                        observations.append(Observation(int(states[2]) // 100, {"cpu": cpu, "state": "system"}))
                        # ... other states
                return observations

            meter.create_observable_counter(
                "system.cpu.time",
                callbacks=[cpu_time_callback],
                unit="s",
                description="CPU time"
            )

        To reduce memory usage, you can use generator callbacks instead of
        building the full list::

            def cpu_time_callback(options: CallbackOptions) -> Iterable[Observation]:
                with open("/proc/stat") as procstat:
                    procstat.readline()  # skip the first line
                    for line in procstat:
                        if not line.startswith("cpu"): break
                        cpu, *states = line.split()
                        yield Observation(int(states[0]) // 100, {"cpu": cpu, "state": "user"})
                        yield Observation(int(states[1]) // 100, {"cpu": cpu, "state": "nice"})
                        # ... other states

        Alternatively, you can pass a sequence of generators directly instead of a sequence of
        callbacks, which each should return iterables of :class:`~opentelemetry.metrics.Observation`::

            def cpu_time_callback(states_to_include: set[str]) -> Iterable[Iterable[Observation]]:
                # accept options sent in from OpenTelemetry
                options = yield
                while True:
                    observations = []
                    with open("/proc/stat") as procstat:
                        procstat.readline()  # skip the first line
                        for line in procstat:
                            if not line.startswith("cpu"): break
                            cpu, *states = line.split()
                            if "user" in states_to_include:
                                observations.append(Observation(int(states[0]) // 100, {"cpu": cpu, "state": "user"}))
                            if "nice" in states_to_include:
                                observations.append(Observation(int(states[1]) // 100, {"cpu": cpu, "state": "nice"}))
                            # ... other states
                    # yield the observations and receive the options for next iteration
                    options = yield observations

            meter.create_observable_counter(
                "system.cpu.time",
                callbacks=[cpu_time_callback({"user", "system"})],
                unit="s",
                description="CPU time"
            )

        The :class:`~opentelemetry.metrics.CallbackOptions` contain a timeout which the
        callback should respect. For example if the callback does asynchronous work, like
        making HTTP requests, it should respect the timeout::

            def scrape_http_callback(options: CallbackOptions) -> Iterable[Observation]:
                r = requests.get('http://scrapethis.com', timeout=options.timeout_millis / 10**3)
                for value in r.json():
                    yield Observation(value)

        Args:
            name: The name of the instrument to be created
            callbacks: A sequence of callbacks that return an iterable of
                :class:`~opentelemetry.metrics.Observation`. Alternatively, can be a sequence of generators that each
                yields iterables of :class:`~opentelemetry.metrics.Observation`.
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr0   r2   r)   rh   rZ   r[   r0   r0   r3   create_observable_counter  r5   zMeter.create_observable_counterc                 C   r/   )ar  Creates a :class:`~opentelemetry.metrics.Histogram` instrument

        Args:
            name: The name of the instrument to be created
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr0   re   r0   r0   r3   create_histogramy  r5   zMeter.create_histogramc                 C   s   t d dS )aR  Creates a ``Gauge`` instrument

        Args:
            name: The name of the instrument to be created
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        z5create_gauge() is not implemented and will be a no-opN)warningswarnre   r0   r0   r3   create_gauge  s   zMeter.create_gaugec                 C   r/   )aZ  Creates an `ObservableGauge` instrument

        Args:
            name: The name of the instrument to be created
            callbacks: A sequence of callbacks that return an iterable of
                :class:`~opentelemetry.metrics.Observation`. Alternatively, can be a generator that yields iterables
                of :class:`~opentelemetry.metrics.Observation`.
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr0   ri   r0   r0   r3   create_observable_gauge  r5   zMeter.create_observable_gaugec                 C   r/   )ab  Creates an `ObservableUpDownCounter` instrument

        Args:
            name: The name of the instrument to be created
            callbacks: A sequence of callbacks that return an iterable of
                :class:`~opentelemetry.metrics.Observation`. Alternatively, can be a generator that yields iterables
                of :class:`~opentelemetry.metrics.Observation`.
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr0   ri   r0   r0   r3   !create_observable_up_down_counter  r5   z'Meter.create_observable_up_down_counterNNrd   rd   Nrd   rd   )!r7   r8   r9   r:   r;   r   rE   propertyr)   r*   r+   typer   boolrc   r   r   rf   r   rg   r	   r   r   rj   r   rk   r   rn   r   ro   r   rp   __classcell__r0   r0   rU   r3   r.      s    	


`


r.   c                       sX  e Zd Z		ddedee dee ddf fddZdeddfd	d
Z		ddedededefddZ			ddededede
fddZ			ddedeee  dededef
ddZ		ddedededefddZ		ddedededefddZ			ddedeee  dededef
ddZ			ddedeee  dededef
ddZ  ZS ) rG   Nr)   r*   r+   r-   c                    s*   t  j|||d t | _g | _d | _d S rF   )rM   rE   r   rA   _instruments_real_meterrT   rU   r0   r3   rE     s   
z_ProxyMeter.__init__rJ   c                 C   s\   | | j| j| j}| j || _| jD ]}|| qW d   dS 1 s'w   Y  dS )zCalled when a real meter provider is set on the creating _ProxyMeterProvider

        Creates a real backing meter for this instance and notifies all created
        instruments so they can create real backing instruments.
        N)r4   rN   rO   rP   rA   ry   rx   on_meter_set)r2   rJ   
real_meter
instrumentr0   r0   r3   rK     s   
"z!_ProxyMeter.on_set_meter_providerrd   rZ   r[   c                 C   j   | j ( | jr| j|||W  d    S t|||}| j| |W  d    S 1 s.w   Y  d S r@   )rA   ry   rf   r   rx   rH   r2   r)   rZ   r[   proxyr0   r0   r3   rf        $z_ProxyMeter.create_counterc                 C   r}   r@   )rA   ry   rg   r$   rx   rH   r~   r0   r0   r3   rg        $z"_ProxyMeter.create_up_down_counterrh   c                 C   p   | j + | jr| j||||W  d    S t||||d}| j| |W  d    S 1 s1w   Y  d S NrZ   r[   )rA   ry   rj   r!   rx   rH   r2   r)   rh   rZ   r[   r   r0   r0   r3   rj        $z%_ProxyMeter.create_observable_counterc                 C   r}   r@   )rA   ry   rk   r    rx   rH   r~   r0   r0   r3   rk     r   z_ProxyMeter.create_histogramc                 C   r}   r@   )rA   ry   rn   r   rx   rH   r~   r0   r0   r3   rn     r   z_ProxyMeter.create_gaugec                 C   r   r   )rA   ry   ro   r"   rx   rH   r   r0   r0   r3   ro   )  r   z#_ProxyMeter.create_observable_gaugec                 C   r   r   )rA   ry   rp   r#   rx   rH   r   r0   r0   r3   rp   ;  s   $z-_ProxyMeter.create_observable_up_down_counterrq   rr   rs   )r7   r8   r9   r;   r   rE   r(   rK   r   rf   r   rg   r	   r   r   rj   r   rk   r   rn   r   ro   r   rp   rw   r0   r0   rU   r3   rG     s    








rG   c                   @   s  e Zd ZdZ		ddedededefddZ		ddedededefd	d
Z		ddededede	fddZ
			ddedeee  dededef
ddZ		ddedededefddZ			ddedeee  dededef
ddZ			ddedeee  dededef
ddZdS )r>   zeThe default Meter used when no Meter implementation is available.

    All operations are no-op.
    rd   r)   rZ   r[   r-   c                 C   6   |  |t||d rtd|tj|| t|||dS )zReturns a no-op Counter.r   YAn instrument with name %s, type %s, unit %s and description %s has been created already.r   )rc   r   _loggerwarningr   r7   re   r0   r0   r3   rf   W     zNoOpMeter.create_counterc                 C   r   )zReturns a no-op Gauge.r   r   r   )rc   r   r   r   r   r7   re   r0   r0   r3   rn   k  s   zNoOpMeter.create_gaugec                 C   r   )zReturns a no-op UpDownCounter.r   r   r   )rc   r   r   r   r   r7   re   r0   r0   r3   rg     r   z NoOpMeter.create_up_down_counterNrh   c                 C   8   |  |t||d rtd|tj|| t||||dS )z"Returns a no-op ObservableCounter.r   r   r   )rc   r   r   r   r   r7   ri   r0   r0   r3   rj     $   z#NoOpMeter.create_observable_counterc                 C   r   )zReturns a no-op Histogram.r   r   r   )rc   r   r   r   r   r7   re   r0   r0   r3   rk     r   zNoOpMeter.create_histogramc                 C   r   )z Returns a no-op ObservableGauge.r   r   r   )rc   r   r   r   r   r7   ri   r0   r0   r3   ro     r   z!NoOpMeter.create_observable_gaugec                 C   r   )z(Returns a no-op ObservableUpDownCounter.r   r   r   )rc   r   r   r   r   r7   ri   r0   r0   r3   rp     r   z+NoOpMeter.create_observable_up_down_counterrr   rs   )r7   r8   r9   r:   r;   r   rf   r   rn   r   rg   r   r	   r   r   rj   r   rk   r   ro   r   rp   r0   r0   r0   r3   r>   Q  s    








r>   _METER_PROVIDERrd   r)   r*   rJ   r+   r-   c                 C   s   |du rt  }|| ||S )zReturns a `Meter` for use by the given instrumentation library.

    This function is a convenience wrapper for
    `opentelemetry.metrics.MeterProvider.get_meter`.

    If meter_provider is omitted the current configured one is used.
    N)get_meter_providerr4   )r)   r*   rJ   r+   r0   r0   r3   r4     s   r4   logc                    s6   d fdd}t |}|r|std d S d S d S )Nr-   c                      s    a t  d S r@   )r   _PROXY_METER_PROVIDERrK   r0   rJ   r0   r3   set_mp  s   z#_set_meter_provider.<locals>.set_mpz2Overriding of current MeterProvider is not allowedrL   )_METER_PROVIDER_SET_ONCEdo_oncer   r   )rJ   r   r   did_setr0   r   r3   _set_meter_provider  s
   
r   c                 C   s   t | dd dS )zSets the current global :class:`~.MeterProvider` object.

    This can only be done once, a warning will be logged if any further attempt
    is made.
    Tr   N)r   r   r0   r0   r3   set_meter_provider  s   r   c                  C   s4   t du rttvr
tS ttd} t| dd tdt S )z8Gets the current global :class:`~.MeterProvider` object.NrJ   Fr   r(   )r   r   r   r   r&   r   r   r   r0   r0   r3   r   $  s   
r   )rd   NN)Er:   rl   abcr   r   loggingr   osr   	threadingr   typingr   r   r	   r
   r   r   r   #opentelemetry.environment_variablesr   *opentelemetry.metrics._internal.instrumentr   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r    r!   r"   r#   r$   opentelemetry.util._oncer%   opentelemetry.util._providersr&   opentelemetry.util.typesr'   r7   r   _ProxyInstrumentTr(   r<   r?   r.   rG   r>   r   r   __annotations__r   r;   r4   rv   r   r   r   r0   r0   r0   r3   <module>   sj   $`*    &
	