2025-05-02 23:48:54 -07:00
|
|
|
use clap::Parser as _;
|
|
|
|
|
use dotenvy::dotenv;
|
2025-07-08 14:37:03 -07:00
|
|
|
use interim_models::MIGRATOR;
|
2025-05-02 23:48:54 -07:00
|
|
|
use tracing_subscriber::EnvFilter;
|
|
|
|
|
|
|
|
|
|
use crate::{
|
|
|
|
|
app_state::{App, AppState},
|
2025-07-08 14:37:03 -07:00
|
|
|
cli::{Cli, Commands, serve_command, worker_command},
|
2025-05-02 23:48:54 -07:00
|
|
|
settings::Settings,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
mod app_error;
|
|
|
|
|
mod app_state;
|
|
|
|
|
mod auth;
|
2025-05-26 22:08:21 -07:00
|
|
|
mod base_pooler;
|
|
|
|
|
mod base_user_perms;
|
|
|
|
|
mod bases;
|
2025-05-02 23:48:54 -07:00
|
|
|
mod cli;
|
2025-05-26 22:08:21 -07:00
|
|
|
mod db_conns;
|
2025-07-08 14:37:03 -07:00
|
|
|
mod lenses;
|
2025-05-02 23:48:54 -07:00
|
|
|
mod middleware;
|
2025-05-28 16:35:00 -07:00
|
|
|
mod rel_invitations;
|
2025-05-02 23:48:54 -07:00
|
|
|
mod router;
|
2025-05-26 22:08:21 -07:00
|
|
|
mod routes;
|
2025-05-02 23:48:54 -07:00
|
|
|
mod sessions;
|
|
|
|
|
mod settings;
|
|
|
|
|
mod users;
|
|
|
|
|
mod worker;
|
|
|
|
|
|
|
|
|
|
/// Run CLI
|
|
|
|
|
#[tokio::main]
|
|
|
|
|
async fn main() {
|
|
|
|
|
// Attempt to pre-load .env in case it contains a RUST_LOG variable
|
|
|
|
|
dotenv().ok();
|
|
|
|
|
tracing_subscriber::fmt()
|
|
|
|
|
.with_env_filter(EnvFilter::from_default_env())
|
|
|
|
|
.init();
|
|
|
|
|
|
|
|
|
|
let settings = Settings::load().unwrap();
|
|
|
|
|
|
|
|
|
|
let state: AppState = App::from_settings(settings.clone()).await.unwrap().into();
|
|
|
|
|
|
2025-07-08 14:37:03 -07:00
|
|
|
if settings.run_database_migrations != 0 {
|
|
|
|
|
MIGRATOR.run(&state.app_db).await.unwrap();
|
2025-05-02 23:48:54 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let cli = Cli::parse();
|
|
|
|
|
match &cli.command {
|
|
|
|
|
Commands::Serve => serve_command(state).await.unwrap(),
|
|
|
|
|
Commands::Worker(args) => worker_command(args, state).await.unwrap(),
|
|
|
|
|
}
|
|
|
|
|
}
|