input_pipeline/metrics/
mod.rsuse anyhow::{Context as _, Error};
use cobalt_client::traits::AsEventCode;
use log::warn;
use metrics_registry::*;
use {fidl_fuchsia_metrics as metrics, fuchsia_async as fasync};
fn create_metrics_logger() -> Result<metrics::MetricEventLoggerProxy, Error> {
let factory_proxy =
fuchsia_component::client::connect_to_protocol::<metrics::MetricEventLoggerFactoryMarker>()
.context("connecting to metrics")?;
let (cobalt_proxy, cobalt_server) =
fidl::endpoints::create_proxy::<metrics::MetricEventLoggerMarker>();
let project_spec = metrics::ProjectSpec {
customer_id: None, project_id: Some(PROJECT_ID),
..Default::default()
};
fasync::Task::spawn(async move {
match factory_proxy.create_metric_event_logger(&project_spec, cobalt_server).await {
Err(e) => warn!("FIDL failure setting up event logger: {e:?}"),
Ok(Err(e)) => warn!("CreateMetricEventLogger failure: {e:?}"),
Ok(Ok(())) => {}
}
})
.detach();
Ok(cobalt_proxy)
}
fn log_on_failure(result: Result<Result<(), metrics::Error>, fidl::Error>) {
match result {
Ok(Ok(())) => (),
e => warn!("failed to log metrics: {:?}", e),
};
}
#[derive(Clone, Default)]
pub struct MetricsLogger(Option<metrics::MetricEventLoggerProxy>);
impl MetricsLogger {
pub fn new() -> Self {
let logger =
create_metrics_logger().map_err(|e| warn!("Failed to create metrics logger: {e}")).ok();
Self(logger)
}
pub fn log_warn<E: AsEventCode, S: Into<String>>(&self, event_code: E, message: S) {
log::warn!("{}", message.into());
self.send_metric(event_code);
}
pub fn log_error<E: AsEventCode, S: Into<String>>(&self, event_code: E, message: S) {
log::error!("{}", message.into());
self.send_metric(event_code);
}
fn send_metric<E: AsEventCode>(&self, event_code: E) {
let Some(c) = self.0.clone() else { return };
let code = event_code.as_event_code();
fuchsia_async::Task::spawn(async move {
log_on_failure(c.log_occurrence(INPUT_PIPELINE_ERROR_METRIC_ID, 1, &[code]).await);
})
.detach();
}
}