HomeDisk/core/src/main.rs

60 lines
1.5 KiB
Rust

use homedisk_database::Database;
use homedisk_server::serve_http;
use homedisk_types::config::Config;
#[tokio::main]
async fn main() {
// init better_panic
better_panic::install();
// init logger
init_logger().expect("init logger");
// parse config
let config = Config::parse().expect("parse config");
// open database connection
let db = Database::open("homedisk.db").await.expect("open database file");
// change the type from Vec<String> to Vec<HeaderValue> so that the http server can correctly detect CORS hosts
let origins = config
.http
.cors
.iter()
.map(|e| e.parse().expect("parse CORS hosts"))
.collect();
// format host ip and port
let host = format!(
"{host}:{port}",
host = config.http.host,
port = config.http.port
);
// start http server
serve_http(host, origins, db, config).await.expect("start http server");
}
/// Init logger
fn init_logger() -> anyhow::Result<()> {
use std::fs::File;
use log::LevelFilter;
use simplelog::{ColorChoice, CombinedLogger, Config, TermLogger, TerminalMode, WriteLogger};
CombinedLogger::init(vec![
TermLogger::new(
LevelFilter::Debug,
Config::default(),
TerminalMode::Mixed,
ColorChoice::Auto,
),
WriteLogger::new(
LevelFilter::Info,
Config::default(),
File::create("logs.log").expect("create logs file"),
),
])?;
Ok(())
}