blob: f2b81aecf9c5cdca0c38836d4a30c454d2de057e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
use tokio::net::TcpListener;
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt};
use unnamed_server::state::AppState;
use crate::config::Config;
mod config;
#[tokio::main]
#[tracing::instrument]
async fn main() -> Result<(), unnamed_server::Error> {
tracing_subscriber::registry()
.with(
tracing_subscriber::EnvFilter::try_from_default_env()
.unwrap_or_else(|_| "unnamed_server=debug".into()),
)
.with(tracing_subscriber::fmt::layer())
.init();
let _ = dotenvy::dotenv();
let config = Config::init();
let state = AppState::new(config.database_url).await?;
let app = unnamed_server::router(state);
let listener = TcpListener::bind("127.0.0.1:30000").await?;
tracing::info!("Server listening on http://{}", listener.local_addr()?);
axum::serve(listener, app)
.with_graceful_shutdown(shutdown_signal())
.await
.map_err(From::from)
}
async fn 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 => {},
}
}
|