2022-04-23 18:44:02 +00:00
|
|
|
use homedisk_database::Database;
|
2022-06-08 19:16:12 +00:00
|
|
|
use homedisk_server::serve_http;
|
|
|
|
use homedisk_types::config::Config;
|
2022-04-16 18:19:38 +00:00
|
|
|
|
|
|
|
#[tokio::main]
|
2022-06-18 11:55:56 +00:00
|
|
|
async fn main() {
|
2022-06-08 19:16:12 +00:00
|
|
|
// init better_panic
|
|
|
|
better_panic::install();
|
|
|
|
// init logger
|
2022-06-18 11:55:56 +00:00
|
|
|
init_logger().expect("init logger");
|
2022-04-16 18:19:38 +00:00
|
|
|
|
2022-06-07 20:36:26 +00:00
|
|
|
// parse config
|
2022-06-18 11:55:56 +00:00
|
|
|
let config = Config::parse().expect("parse config");
|
2022-04-16 19:22:01 +00:00
|
|
|
|
2022-06-07 20:36:26 +00:00
|
|
|
// open database connection
|
2022-06-18 13:22:43 +00:00
|
|
|
let db = Database::open("homedisk.db")
|
|
|
|
.await
|
|
|
|
.expect("open database file");
|
2022-04-17 22:07:37 +00:00
|
|
|
|
2022-04-18 12:13:15 +00:00
|
|
|
// 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()
|
2022-06-07 20:36:26 +00:00
|
|
|
.map(|e| e.parse().expect("parse CORS hosts"))
|
2022-04-18 12:13:15 +00:00
|
|
|
.collect();
|
2022-04-17 22:07:37 +00:00
|
|
|
|
2022-06-08 19:16:12 +00:00
|
|
|
// format host ip and port
|
2022-04-19 13:25:56 +00:00
|
|
|
let host = format!(
|
|
|
|
"{host}:{port}",
|
|
|
|
host = config.http.host,
|
|
|
|
port = config.http.port
|
|
|
|
);
|
|
|
|
|
2022-06-07 20:36:26 +00:00
|
|
|
// start http server
|
2022-06-18 13:22:43 +00:00
|
|
|
serve_http(host, origins, db, config)
|
|
|
|
.await
|
|
|
|
.expect("start http server");
|
2022-06-08 19:16:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/// 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"),
|
|
|
|
),
|
|
|
|
])?;
|
2022-06-07 20:36:26 +00:00
|
|
|
|
|
|
|
Ok(())
|
2022-04-16 18:19:38 +00:00
|
|
|
}
|