upub/src/main.rs

118 lines
2.7 KiB
Rust
Raw Normal View History

pub mod server; // TODO there are some methods that i dont use yet, make it public so that ra shuts up
2024-05-03 04:12:15 +02:00
mod model;
mod routes;
2024-04-06 18:03:13 +02:00
2024-05-03 04:12:15 +02:00
mod errors;
2024-04-06 18:03:13 +02:00
mod config;
#[cfg(feature = "cli")]
mod cli;
2024-04-06 18:03:13 +02:00
#[cfg(feature = "migrations")]
mod migrations;
#[cfg(feature = "migrations")]
use sea_orm_migration::MigratorTrait;
use clap::{Parser, Subcommand};
use sea_orm::{ConnectOptions, Database};
pub use errors::UpubResult as Result;
2024-04-13 22:31:46 +02:00
use tower_http::{cors::CorsLayer, trace::TraceLayer};
2024-03-25 05:02:20 +01:00
pub const VERSION: &str = env!("CARGO_PKG_VERSION");
#[derive(Parser)]
/// all names were taken
struct Args {
#[clap(subcommand)]
/// command to run
command: Mode,
2024-03-20 09:04:08 +01:00
#[arg(short = 'd', long = "db", default_value = "sqlite://./upub.db")]
/// database connection uri
database: String,
2024-03-20 09:04:08 +01:00
#[arg(short = 'D', long, default_value = "http://localhost:3000")]
2024-03-20 08:56:35 +01:00
/// instance base domain, for AP ids
domain: String,
#[arg(long, default_value_t=false)]
/// run with debug level tracing
debug: bool,
}
#[derive(Clone, Subcommand)]
enum Mode {
/// run fediverse server
Serve ,
2024-04-06 18:03:13 +02:00
#[cfg(feature = "migrations")]
/// apply database migrations
Migrate,
2024-03-16 05:46:14 +01:00
#[cfg(feature = "cli")]
/// run maintenance CLI tasks
Cli {
#[clap(subcommand)]
/// task to run
command: cli::CliCommand,
},
}
2024-02-09 17:07:55 +01:00
#[tokio::main]
async fn main() {
let args = Args::parse();
tracing_subscriber::fmt()
.compact()
.with_max_level(if args.debug { tracing::Level::DEBUG } else { tracing::Level::INFO })
.init();
// TODO can i do connectoptions.into() or .connect() and skip these ugly bindings?
let mut opts = ConnectOptions::new(&args.database);
opts
.sqlx_logging_level(tracing::log::LevelFilter::Debug);
let db = Database::connect(opts)
.await.expect("error connecting to db");
match args.command {
2024-04-06 18:03:13 +02:00
#[cfg(feature = "migrations")]
Mode::Migrate =>
migrations::Migrator::up(&db, None)
.await.expect("error applying migrations"),
2024-03-16 05:46:14 +01:00
#[cfg(feature = "cli")]
Mode::Cli { command } =>
cli::run(command, db, args.domain)
.await.expect("failed running cli task"),
Mode::Serve => {
2024-04-09 04:35:57 +02:00
let ctx = server::Context::new(db, args.domain)
.await.expect("failed creating server context");
use routes::activitypub::ActivityPubRouter;
use routes::mastodon::MastodonRouter;
let router = axum::Router::new()
.ap_routes()
.mastodon_routes() // no-op if mastodon feature is disabled
2024-04-13 22:31:46 +02:00
.layer(CorsLayer::permissive())
.layer(TraceLayer::new_for_http())
.with_state(ctx);
2024-04-09 04:35:57 +02:00
// run our app with hyper, listening locally on port 3000
let listener = tokio::net::TcpListener::bind("127.0.0.1:3000")
.await.expect("could not bind tcp socket");
axum::serve(listener, router)
.await
.expect("failed serving application")
},
}
}