pub mod certificate;
pub mod connection_stats;
pub mod server_config;
use crate::collectors::Collector;
use anyhow::Result;
use certificate::CertificateCollector;
use connection_stats::ConnectionTlsCollector;
use futures::{future::BoxFuture, stream::FuturesUnordered, StreamExt};
use prometheus::Registry;
use server_config::ServerTlsConfigCollector;
use sqlx::PgPool;
use std::sync::Arc;
use tracing::{info_span, warn};
use tracing_futures::Instrument;
#[derive(Clone, Default)]
pub struct TlsCollector {
subs: Vec<Arc<dyn Collector + Send + Sync>>,
}
impl TlsCollector {
#[must_use]
pub fn new() -> Self {
Self {
subs: vec![
Arc::new(ServerTlsConfigCollector::new()),
Arc::new(CertificateCollector::new()),
Arc::new(ConnectionTlsCollector::new()),
],
}
}
}
impl Collector for TlsCollector {
fn name(&self) -> &'static str {
"tls"
}
fn register_metrics(&self, registry: &Registry) -> Result<()> {
for sub in &self.subs {
let span = info_span!("collector.register_metrics", sub_collector = %sub.name());
let _guard = span.enter();
if let Err(e) = sub.register_metrics(registry) {
warn!(
"Failed to register metrics for sub-collector '{}': {}",
sub.name(),
e
);
return Err(e);
}
}
Ok(())
}
fn collect<'a>(&'a self, pool: &'a PgPool) -> BoxFuture<'a, Result<()>> {
Box::pin(async move {
let mut tasks = FuturesUnordered::new();
for sub in &self.subs {
let span = info_span!(
"collector.collect",
sub_collector = %sub.name(),
otel.kind = "internal"
);
tasks.push(sub.collect(pool).instrument(span));
}
while let Some(res) = tasks.next().await {
if let Err(e) = res {
warn!("Sub-collector failed: {}", e);
return Err(e);
}
}
Ok(())
})
}
fn enabled_by_default(&self) -> bool {
false
}
}