use log::info;
pub async fn global_shutdown_signal() {
let ctrl_c = async {
tokio::signal::ctrl_c().await.expect("failed to install Ctrl+C handler");
};
#[cfg(unix)]
let terminate = async {
tokio::signal::unix::signal(tokio::signal::unix::SignalKind::terminate())
.expect("failed to install signal handler")
.recv()
.await;
};
#[cfg(not(unix))]
let terminate = std::future::pending::<()>();
tokio::select! {
_ = ctrl_c => {},
_ = terminate => {}
}
}
pub async fn shutdown_signal(stop_receiver: tokio::sync::oneshot::Receiver<u8>) {
let stop = async { stop_receiver.await.expect("Failed to install stop signal.") };
tokio::select! {
_ = stop => {},
_ = global_shutdown_signal() => {}
}
}
pub async fn shutdown_signal_with_message(stop_receiver: tokio::sync::oneshot::Receiver<u8>, message: String) {
shutdown_signal(stop_receiver).await;
info!("{message}");
}