forked from open-telemetry/opentelemetry-rust
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtrace.rs
74 lines (63 loc) · 2.35 KB
/
trace.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
use std::sync::Arc;
use futures_core::future::BoxFuture;
use http::{header::CONTENT_TYPE, Method};
use opentelemetry::trace::TraceError;
use opentelemetry_sdk::export::trace::{ExportResult, SpanData, SpanExporter};
use super::OtlpHttpClient;
impl SpanExporter for OtlpHttpClient {
fn export(&mut self, batch: Vec<SpanData>) -> BoxFuture<'static, ExportResult> {
let client = match self
.client
.lock()
.map_err(|e| TraceError::Other(e.to_string().into()))
.and_then(|g| match &*g {
Some(client) => Ok(Arc::clone(client)),
_ => Err(TraceError::Other("exporter is already shut down".into())),
}) {
Ok(client) => client,
Err(err) => return Box::pin(std::future::ready(Err(err))),
};
let (body, content_type) = match self.build_trace_export_body(batch) {
Ok(body) => body,
Err(e) => return Box::pin(std::future::ready(Err(e))),
};
let mut request = match http::Request::builder()
.method(Method::POST)
.uri(&self.collector_endpoint)
.header(CONTENT_TYPE, content_type)
.body(body)
{
Ok(req) => req,
Err(e) => {
return Box::pin(std::future::ready(Err(crate::Error::RequestFailed(
Box::new(e),
)
.into())))
}
};
for (k, v) in &self.headers {
request.headers_mut().insert(k.clone(), v.clone());
}
Box::pin(async move {
let request_uri = request.uri().to_string();
let response = client.send(request).await?;
if !response.status().is_success() {
let error = format!(
"OpenTelemetry trace export failed. Url: {}, Status Code: {}, Response: {:?}",
response.status().as_u16(),
request_uri,
response.body()
);
return Err(TraceError::Other(error.into()));
}
Ok(())
})
}
fn shutdown(&mut self) {
let _ = self.client.lock().map(|mut c| c.take());
}
fn set_resource(&mut self, resource: &opentelemetry_sdk::Resource) -> ExportResult {
self.resource = resource.into();
Ok(())
}
}