2023-07-27 17:36:30 +02:00
|
|
|
use std::time::Duration;
|
|
|
|
|
|
|
|
use actix_web::web::Data;
|
2023-08-01 16:29:03 +02:00
|
|
|
use actix_web::{middleware, App, HttpServer};
|
2023-07-27 17:36:30 +02:00
|
|
|
use sea_orm::ConnectOptions;
|
2023-07-26 11:16:29 +02:00
|
|
|
|
|
|
|
#[actix_web::main]
|
|
|
|
async fn main() -> std::io::Result<()> {
|
2023-07-27 17:36:30 +02:00
|
|
|
{
|
|
|
|
use tracing_subscriber::prelude::*;
|
|
|
|
use tracing_subscriber::{fmt, EnvFilter};
|
|
|
|
|
|
|
|
let fmt_layer = fmt::layer().with_target(false);
|
|
|
|
let filter_layer = EnvFilter::try_from_default_env()
|
|
|
|
.or_else(|_| EnvFilter::try_new("info"))
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
tracing_subscriber::registry()
|
|
|
|
.with(filter_layer)
|
|
|
|
.with(fmt_layer)
|
|
|
|
.init();
|
|
|
|
}
|
|
|
|
|
|
|
|
let mut db_opts = ConnectOptions::new("postgres://postgres@localhost/oswilno".to_string());
|
|
|
|
db_opts
|
|
|
|
.max_connections(100)
|
|
|
|
.min_connections(5)
|
|
|
|
.connect_timeout(Duration::from_secs(8))
|
|
|
|
.idle_timeout(Duration::from_secs(8))
|
|
|
|
.sqlx_logging(true);
|
|
|
|
let conn: sea_orm::DatabaseConnection = sea_orm::Database::connect(db_opts).await.unwrap();
|
|
|
|
HttpServer::new(move || {
|
2023-07-26 11:16:29 +02:00
|
|
|
App::new()
|
2023-07-27 17:36:30 +02:00
|
|
|
.wrap(middleware::Logger::default())
|
|
|
|
.app_data(Data::new(conn.clone()))
|
2023-07-26 11:16:29 +02:00
|
|
|
.configure(oswilno_parking_space::mount)
|
|
|
|
.configure(oswilno_admin::mount)
|
2023-08-01 16:29:03 +02:00
|
|
|
.configure(web_assets::configure)
|
2023-07-26 11:16:29 +02:00
|
|
|
})
|
|
|
|
.bind(("0.0.0.0", 8080))?
|
|
|
|
.run()
|
|
|
|
.await
|
|
|
|
}
|