jmserver/src/main.rs
Timo Ley 46773e9d17
All checks were successful
continuous-integration/drone/push Build is passing
feat: postgres migration
2023-07-06 17:35:23 +02:00

73 lines
1.6 KiB
Rust

use axum::{
body::Body,
http::{header, HeaderValue, Request},
Router,
};
use config::Config;
use error::JMError;
use reqwest::{Client, Url};
use sqlx::PgPool;
use std::{path::PathBuf, sync::Arc};
use structopt::StructOpt;
use tower_http::{add_extension::AddExtensionLayer, set_header::SetResponseHeaderLayer};
mod cdn;
mod config;
mod error;
mod ipfs;
mod lib;
mod matrix;
mod models;
mod sql;
mod v1;
mod v2;
#[derive(StructOpt)]
struct Opt {
#[structopt(
short,
long,
help = "config file to use",
default_value = "./config.toml"
)]
config: PathBuf,
}
pub struct JMServiceInner {
client: Client,
db_pool: PgPool,
ipfs_url: Url,
cdn_url: String,
matrix_url: Url,
matrix_token: String,
matrix_domain: String,
}
pub type JMService = Arc<JMServiceInner>;
#[tokio::main]
async fn main() -> Result<(), JMError> {
let opt = Opt::from_args();
let config = std::fs::read(&opt.config)?;
let config = toml::from_slice::<Config>(&config)?;
let db_pool = PgPool::new(&config.database).await?;
let service = config.service(db_pool)?;
let app = Router::new()
.nest("/api/v1", v1::routes())
.nest("/api/v2", v2::routes())
.nest("/cdn", cdn::routes())
.layer(AddExtensionLayer::new(service))
.layer(SetResponseHeaderLayer::<_, Request<Body>>::if_not_present(
header::ACCESS_CONTROL_ALLOW_ORIGIN,
HeaderValue::from_static("*"),
));
axum::Server::bind(&config.addr)
.serve(app.into_make_service())
.await?;
Ok(())
}