mabel/src/main.rs
Hamcha 58bf506240
Some checks failed
continuous-integration/drone/push Build is failing
kept you waiting huh? (I'm sorry i forgor)
2023-07-06 20:08:55 +02:00

52 lines
1.3 KiB
Rust

mod auth;
mod content;
mod database;
mod http;
mod roles;
mod routes;
mod state;
use crate::{http::session::refresh_sessions, state::Config};
use anyhow::Result;
use axum::{middleware, Server};
use figment::{
providers::{Env, Format, Serialized, Toml},
Figment,
};
use sqlx::postgres::PgPoolOptions;
use state::AppState;
use std::{net::SocketAddr, sync::Arc};
#[tokio::main]
async fn main() -> Result<()> {
tracing_subscriber::fmt::init();
let config: Config = Figment::from(Serialized::defaults(Config::default()))
.merge(Toml::file("mabel.toml"))
.merge(Env::prefixed("MABEL_"))
.extract()?;
let addr: SocketAddr = config.bind.parse()?;
let database = PgPoolOptions::new()
.max_connections(5)
.connect(config.database_url.as_str())
.await?;
sqlx::migrate!().run(&database).await?;
// Sanity check config
config.sanity_check();
let shared_state = Arc::new(AppState { database, config });
let app = routes::create_router()
.route_layer(middleware::from_fn_with_state(
shared_state.clone(),
refresh_sessions,
))
.with_state(shared_state);
tracing::debug!("listening on {}", addr);
Server::bind(&addr).serve(app.into_make_service()).await?;
Ok(())
}