use crate::error::KumoError;
pub async fn init(
service_name: impl Into<String>,
otlp_endpoint: impl Into<String>,
) -> Result<(), KumoError> {
use opentelemetry::KeyValue;
use opentelemetry::trace::TracerProvider as _;
use opentelemetry_otlp::WithExportConfig;
use opentelemetry_sdk::{Resource, runtime, trace::TracerProvider as SdkTracerProvider};
use tracing_subscriber::prelude::*;
let service_name = service_name.into();
let endpoint = otlp_endpoint.into();
let exporter = opentelemetry_otlp::SpanExporter::builder()
.with_tonic()
.with_endpoint(&endpoint)
.build()
.map_err(|e| KumoError::store_msg(format!("otel exporter: {e}")))?;
let provider = SdkTracerProvider::builder()
.with_batch_exporter(exporter, runtime::Tokio)
.with_resource(Resource::new(vec![KeyValue::new(
"service.name",
service_name.clone(),
)]))
.build();
opentelemetry::global::set_tracer_provider(provider.clone());
let otel_layer = tracing_opentelemetry::layer().with_tracer(provider.tracer("kumo"));
tracing_subscriber::registry()
.with(tracing_subscriber::EnvFilter::from_default_env())
.with(tracing_subscriber::fmt::layer())
.with(otel_layer)
.try_init()
.map_err(|e| KumoError::store_msg(format!("tracing subscriber: {e}")))?;
tracing::info!(
service = %service_name,
endpoint = %endpoint,
"otel initialized"
);
Ok(())
}
pub fn shutdown() {
opentelemetry::global::shutdown_tracer_provider();
}