botui/src/main.rs

68 lines
1.6 KiB
Rust
Raw Normal View History

2025-12-21 23:40:44 -03:00
2025-12-03 18:42:22 -03:00
use log::info;
use std::net::SocketAddr;
2025-12-03 18:42:22 -03:00
mod shared;
2025-12-03 18:42:22 -03:00
mod ui_server;
fn init_logging() {
botlib::logging::init_compact_logger("info");
}
fn get_port() -> u16 {
std::env::var("BOTUI_PORT")
.ok()
.and_then(|p| p.parse().ok())
.unwrap_or(3000)
}
2025-12-03 18:42:22 -03:00
#[tokio::main]
async fn main() -> anyhow::Result<()> {
init_logging();
2025-12-21 23:40:44 -03:00
let version = env!("CARGO_PKG_VERSION");
info!("BotUI {version} starting...");
2025-12-03 18:42:22 -03:00
let app = ui_server::configure_router();
let port = get_port();
let addr = SocketAddr::from(([0, 0, 0, 0], port));
2025-12-03 18:42:22 -03:00
let listener = tokio::net::TcpListener::bind(addr).await?;
2025-12-21 23:40:44 -03:00
info!("UI server listening on http://{addr}");
axum::serve(listener, app)
.with_graceful_shutdown(shutdown_signal())
.await?;
info!("BotUI shutdown complete");
Ok(())
}
async fn shutdown_signal() {
let ctrl_c = async {
2025-12-21 23:40:44 -03:00
if let Err(e) = tokio::signal::ctrl_c().await {
log::error!("Failed to install Ctrl+C handler: {e}");
}
};
#[cfg(unix)]
let terminate = async {
2025-12-21 23:40:44 -03:00
match tokio::signal::unix::signal(tokio::signal::unix::SignalKind::terminate()) {
Ok(mut signal) => {
signal.recv().await;
}
Err(e) => {
log::error!("Failed to install SIGTERM handler: {e}");
}
}
};
#[cfg(not(unix))]
let terminate = std::future::pending::<()>();
2025-12-03 18:42:22 -03:00
tokio::select! {
2025-12-21 23:40:44 -03:00
() = ctrl_c => info!("Received Ctrl+C, shutting down..."),
() = terminate => info!("Received SIGTERM, shutting down..."),
}
2025-12-03 18:42:22 -03:00
}