opentelemetry/logs/
mod.rs1use crate::ExportError;
6
7use std::{sync::PoisonError, time::Duration};
8use thiserror::Error;
9
10mod logger;
11mod noop;
12mod record;
13
14pub use logger::{Logger, LoggerProvider};
15pub use noop::NoopLoggerProvider;
16pub use record::{AnyValue, LogRecord, Severity};
17
18pub type LogResult<T> = Result<T, LogError>;
20
21#[derive(Error, Debug)]
22#[non_exhaustive]
23pub enum LogError {
25 #[error("Exporter {} encountered the following errors: {0}", .0.exporter_name())]
27 ExportFailed(Box<dyn ExportError>),
28
29 #[error("Exporter timed out after {} seconds", .0.as_secs())]
31 ExportTimedOut(Duration),
32
33 #[error(transparent)]
35 Other(#[from] Box<dyn std::error::Error + Send + Sync + 'static>),
36}
37
38impl<T> From<T> for LogError
39where
40 T: ExportError,
41{
42 fn from(err: T) -> Self {
43 LogError::ExportFailed(Box::new(err))
44 }
45}
46
47impl From<String> for LogError {
48 fn from(err_msg: String) -> Self {
49 LogError::Other(Box::new(Custom(err_msg)))
50 }
51}
52
53impl From<&'static str> for LogError {
54 fn from(err_msg: &'static str) -> Self {
55 LogError::Other(Box::new(Custom(err_msg.into())))
56 }
57}
58
59impl<T> From<PoisonError<T>> for LogError {
60 fn from(err: PoisonError<T>) -> Self {
61 LogError::Other(err.to_string().into())
62 }
63}
64#[derive(Error, Debug)]
66#[error("{0}")]
67struct Custom(String);