#![allow(unused_imports, unused_variables)]
use actix_web::{get, middleware, web::Data, App, HttpRequest, HttpResponse, HttpServer, Responder};
pub use controller::{self, Result, State};
use prometheus::{Encoder, TextEncoder};
use tracing::{debug, error, info, trace, warn};
use tracing_subscriber::{prelude::*, EnvFilter, Registry};
#[get("/metrics")]
async fn metrics(c: Data<State>, _req: HttpRequest) -> impl Responder {
let metrics = c.metrics();
let encoder = TextEncoder::new();
let mut buffer = vec![];
encoder.encode(&metrics, &mut buffer).unwrap();
HttpResponse::Ok().body(buffer)
}
#[get("/health")]
async fn health(_: HttpRequest) -> impl Responder {
HttpResponse::Ok().json("healthy")
}
#[get("/")]
async fn index(c: Data<State>, _req: HttpRequest) -> impl Responder {
let d = c.diagnostics().await;
HttpResponse::Ok().json(&d)
}
#[tokio::main]
async fn main() -> Result<()> {
#[cfg(feature = "telemetry")]
let telemetry = tracing_opentelemetry::layer().with_tracer(controller::telemetry::init_tracer().await);
let logger = tracing_subscriber::fmt::layer();
let env_filter = EnvFilter::try_from_default_env()
.or_else(|_| EnvFilter::try_new("info"))
.unwrap();
#[cfg(feature = "telemetry")]
let collector = Registry::default().with(telemetry).with(logger).with(env_filter);
#[cfg(not(feature = "telemetry"))]
let collector = Registry::default().with(logger).with(env_filter);
tracing::subscriber::set_global_default(collector).unwrap();
let client_future = kube::Client::try_default();
let client = match client_future.await {
Ok(wrapped_client) => wrapped_client,
Err(error) => panic!("Please configure your Kubernetes Context"),
};
let (controller, state) = controller::init(client).await;
let server = HttpServer::new(move || {
App::new()
.app_data(Data::new(state.clone()))
.wrap(middleware::Logger::default().exclude("/health"))
.service(index)
.service(health)
.service(metrics)
})
.bind("0.0.0.0:8080")
.expect("Can not bind to 0.0.0.0:8080")
.shutdown_timeout(5);
tokio::select! {
_ = controller => warn!("controller exited"),
_ = server.run() => info!("actix exited"),
}
Ok(())
}