summaryrefslogtreecommitdiffstats
path: root/src/main.rs
blob: 71e68f997b487d7f9c4ced2f0c17a6a9271a368a (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
use tokio::net::TcpListener;
use tracing::level_filters::LevelFilter;
use tracing_subscriber::{layer::SubscriberExt, registry, util::SubscriberInitExt, EnvFilter};
use unnamed_server::state::AppState;

use crate::config::Config;

mod config;

#[tokio::main]
async fn main() -> Result<(), main_error::MainError> {
    registry()
        .with(
            EnvFilter::builder()
                .with_default_directive(LevelFilter::INFO.into())
                .from_env_lossy(),
        )
        .with(tracing_subscriber::fmt::layer())
        .init();

    let config = Config::builder().file()?.env().build()?;

    let listener = TcpListener::bind(config.listen_addr).await?;
    let state = AppState::new(config.database_url).await?;
    let router = unnamed_server::router().with_state(state);

    tracing::info!("Listening on http://{}", listener.local_addr()?);

    axum::serve(listener, router).await.map_err(From::from)
}