
     jh)                         d dl Z ddlmZmZ ddlmZ ddlmZmZ ddl	m
Z
 ddlmZ  e j        e j        d	          Z G d
 d          Z G d d          ZdS )    N   )AsyncClientWrapperSyncClientWrapper)RequestOptions   )AsyncRawOpentelemetryClientRawOpentelemetryClient)OtelResourceSpan)OtelTraceResponse.c                   |    e Zd ZdefdZedefd            Zdddej	        e
         dej        e         defd	ZdS )
OpentelemetryClientclient_wrapperc                0    t          |          | _        d S N)r   )r	   _raw_clientselfr   s     k/lsinfo/ai/hellotax_ai/base_platform/venv/lib/python3.11/site-packages/langfuse/api/opentelemetry/client.py__init__zOpentelemetryClient.__init__   s    1PPP    returnc                     | j         S )z
        Retrieves a raw implementation of this client that returns raw responses.

        Returns
        -------
        RawOpentelemetryClient
        r   r   s    r   with_raw_responsez%OpentelemetryClient.with_raw_response        r   Nrequest_optionsresource_spansr   c                H    | j                             ||          }|j        S )a  
        **OpenTelemetry Traces Ingestion Endpoint**

        This endpoint implements the OTLP/HTTP specification for trace ingestion, providing native OpenTelemetry integration for Langfuse Observability.

        **Supported Formats:**
        - Binary Protobuf: `Content-Type: application/x-protobuf`
        - JSON Protobuf: `Content-Type: application/json`
        - Supports gzip compression via `Content-Encoding: gzip` header

        **Specification Compliance:**
        - Conforms to [OTLP/HTTP Trace Export](https://opentelemetry.io/docs/specs/otlp/#otlphttp)
        - Implements `ExportTraceServiceRequest` message format

        **Documentation:**
        - Integration guide: https://langfuse.com/integrations/native/opentelemetry
        - Data model: https://langfuse.com/docs/observability/data-model

        Parameters
        ----------
        resource_spans : typing.Sequence[OtelResourceSpan]
            Array of resource spans containing trace data as defined in the OTLP specification

        request_options : typing.Optional[RequestOptions]
            Request-specific configuration.

        Returns
        -------
        OtelTraceResponse

        Examples
        --------
        from langfuse import LangfuseAPI
        from langfuse.opentelemetry import (
            OtelAttribute,
            OtelAttributeValue,
            OtelResource,
            OtelResourceSpan,
            OtelScope,
            OtelScopeSpan,
            OtelSpan,
        )

        client = LangfuseAPI(
            x_langfuse_sdk_name="YOUR_X_LANGFUSE_SDK_NAME",
            x_langfuse_sdk_version="YOUR_X_LANGFUSE_SDK_VERSION",
            x_langfuse_public_key="YOUR_X_LANGFUSE_PUBLIC_KEY",
            username="YOUR_USERNAME",
            password="YOUR_PASSWORD",
            base_url="https://yourhost.com/path/to/api",
        )
        client.opentelemetry.export_traces(
            resource_spans=[
                OtelResourceSpan(
                    resource=OtelResource(
                        attributes=[
                            OtelAttribute(
                                key="service.name",
                                value=OtelAttributeValue(
                                    string_value="my-service",
                                ),
                            ),
                            OtelAttribute(
                                key="service.version",
                                value=OtelAttributeValue(
                                    string_value="1.0.0",
                                ),
                            ),
                        ],
                    ),
                    scope_spans=[
                        OtelScopeSpan(
                            scope=OtelScope(
                                name="langfuse-sdk",
                                version="2.60.3",
                            ),
                            spans=[
                                OtelSpan(
                                    trace_id="0123456789abcdef0123456789abcdef",
                                    span_id="0123456789abcdef",
                                    name="my-operation",
                                    kind=1,
                                    start_time_unix_nano="1747872000000000000",
                                    end_time_unix_nano="1747872001000000000",
                                    attributes=[
                                        OtelAttribute(
                                            key="langfuse.observation.type",
                                            value=OtelAttributeValue(
                                                string_value="generation",
                                            ),
                                        )
                                    ],
                                    status={},
                                )
                            ],
                        )
                    ],
                )
            ],
        )
        r   r   r   export_tracesdatar   r   r   	_responses       r   r#   z!OpentelemetryClient.export_traces   s1    V $22)? 3 
 
	 ~r   )__name__
__module____qualname__r   r   propertyr	   r   typingSequencer
   Optionalr   r   r#    r   r   r   r      s        Q*; Q Q Q Q  #9       X  <@	n n n (89n  8	n
 
n n n n n nr   r   c                   |    e Zd ZdefdZedefd            Zdddej	        e
         dej        e         defd	ZdS )
AsyncOpentelemetryClientr   c                0    t          |          | _        d S r   )r   r   r   s     r   r   z!AsyncOpentelemetryClient.__init__   s    6nUUUr   r   c                     | j         S )z
        Retrieves a raw implementation of this client that returns raw responses.

        Returns
        -------
        AsyncRawOpentelemetryClient
        r   r   s    r   r   z*AsyncOpentelemetryClient.with_raw_response   r   r   Nr   r   r   c                X   K   | j                             ||           d{V }|j        S )a  
        **OpenTelemetry Traces Ingestion Endpoint**

        This endpoint implements the OTLP/HTTP specification for trace ingestion, providing native OpenTelemetry integration for Langfuse Observability.

        **Supported Formats:**
        - Binary Protobuf: `Content-Type: application/x-protobuf`
        - JSON Protobuf: `Content-Type: application/json`
        - Supports gzip compression via `Content-Encoding: gzip` header

        **Specification Compliance:**
        - Conforms to [OTLP/HTTP Trace Export](https://opentelemetry.io/docs/specs/otlp/#otlphttp)
        - Implements `ExportTraceServiceRequest` message format

        **Documentation:**
        - Integration guide: https://langfuse.com/integrations/native/opentelemetry
        - Data model: https://langfuse.com/docs/observability/data-model

        Parameters
        ----------
        resource_spans : typing.Sequence[OtelResourceSpan]
            Array of resource spans containing trace data as defined in the OTLP specification

        request_options : typing.Optional[RequestOptions]
            Request-specific configuration.

        Returns
        -------
        OtelTraceResponse

        Examples
        --------
        import asyncio

        from langfuse import AsyncLangfuseAPI
        from langfuse.opentelemetry import (
            OtelAttribute,
            OtelAttributeValue,
            OtelResource,
            OtelResourceSpan,
            OtelScope,
            OtelScopeSpan,
            OtelSpan,
        )

        client = AsyncLangfuseAPI(
            x_langfuse_sdk_name="YOUR_X_LANGFUSE_SDK_NAME",
            x_langfuse_sdk_version="YOUR_X_LANGFUSE_SDK_VERSION",
            x_langfuse_public_key="YOUR_X_LANGFUSE_PUBLIC_KEY",
            username="YOUR_USERNAME",
            password="YOUR_PASSWORD",
            base_url="https://yourhost.com/path/to/api",
        )


        async def main() -> None:
            await client.opentelemetry.export_traces(
                resource_spans=[
                    OtelResourceSpan(
                        resource=OtelResource(
                            attributes=[
                                OtelAttribute(
                                    key="service.name",
                                    value=OtelAttributeValue(
                                        string_value="my-service",
                                    ),
                                ),
                                OtelAttribute(
                                    key="service.version",
                                    value=OtelAttributeValue(
                                        string_value="1.0.0",
                                    ),
                                ),
                            ],
                        ),
                        scope_spans=[
                            OtelScopeSpan(
                                scope=OtelScope(
                                    name="langfuse-sdk",
                                    version="2.60.3",
                                ),
                                spans=[
                                    OtelSpan(
                                        trace_id="0123456789abcdef0123456789abcdef",
                                        span_id="0123456789abcdef",
                                        name="my-operation",
                                        kind=1,
                                        start_time_unix_nano="1747872000000000000",
                                        end_time_unix_nano="1747872001000000000",
                                        attributes=[
                                            OtelAttribute(
                                                key="langfuse.observation.type",
                                                value=OtelAttributeValue(
                                                    string_value="generation",
                                                ),
                                            )
                                        ],
                                        status={},
                                    )
                                ],
                            )
                        ],
                    )
                ],
            )


        asyncio.run(main())
        r!   Nr"   r%   s       r   r#   z&AsyncOpentelemetryClient.export_traces   sS      f *88)? 9 
 
 
 
 
 
 
 
	 ~r   )r'   r(   r)   r   r   r*   r   r   r+   r,   r
   r-   r   r   r#   r.   r   r   r0   r0      s        V*< V V V V  #>       X  <@	v v v (89v  8	v
 
v v v v v vr   r0   )r+   core.client_wrapperr   r   core.request_optionsr   
raw_clientr   r	   types.otel_resource_spanr
   types.otel_trace_responser   castAnyOMITr   r0   r.   r   r   <module>r<      s     G G G G G G G G 1 1 1 1 1 1 K K K K K K K K 6 6 6 6 6 6 8 8 8 8 8 8 v{6:s##} } } } } } } }@E E E E E E E E E Er   