2024-08-06 11:08:15 -04:00
|
|
|
mod user;
|
|
|
|
|
|
|
|
use axum::Router;
|
|
|
|
use tokio::net::TcpListener;
|
2024-09-30 00:15:19 -04:00
|
|
|
use tracing::info;
|
2024-08-06 11:08:15 -04:00
|
|
|
|
2024-08-24 13:22:51 -04:00
|
|
|
use crate::{
|
|
|
|
db::DbPool,
|
|
|
|
models::{AppError, Environment},
|
|
|
|
};
|
2024-08-06 11:08:15 -04:00
|
|
|
|
|
|
|
#[derive(Clone)]
|
|
|
|
pub struct AppState {
|
|
|
|
pool: DbPool,
|
|
|
|
env: Environment,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AppState {
|
|
|
|
pub fn new(pool: DbPool, env: Environment) -> Self {
|
2024-09-29 09:57:02 -04:00
|
|
|
Self { pool, env }
|
2024-08-06 11:08:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn pool(&self) -> &DbPool {
|
|
|
|
&self.pool
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn env(&self) -> &Environment {
|
|
|
|
&self.env
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn start_app(pool: DbPool, env: Environment) -> Result<(), AppError> {
|
2024-08-22 17:29:24 -04:00
|
|
|
let address = env.hostname();
|
|
|
|
let port = env.port();
|
2024-09-30 00:15:19 -04:00
|
|
|
|
|
|
|
info!("Listening on {address}:{port}...");
|
2024-08-06 11:08:15 -04:00
|
|
|
let listener = TcpListener::bind(format!("{address}:{port}"))
|
|
|
|
.await
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
let app_state = AppState::new(pool, env);
|
|
|
|
let app = Router::new().merge(user::requests(app_state.clone()));
|
|
|
|
|
2024-09-30 00:15:19 -04:00
|
|
|
info!("API started successfully.");
|
2024-08-06 11:08:15 -04:00
|
|
|
axum::serve(listener, app)
|
|
|
|
.await
|
|
|
|
.map_err(AppError::app_startup)?;
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|