lldap/src/main.rs

42 lines
1.2 KiB
Rust
Raw Normal View History

use crate::infra::configuration::Configuration;
2021-03-02 19:51:33 +00:00
use anyhow::Result;
use futures_util::TryFutureExt;
2021-03-02 19:51:33 +00:00
use log::*;
2021-03-07 15:13:50 +00:00
use sqlx::sqlite::{SqliteConnectOptions, SqlitePoolOptions};
use std::str::FromStr;
2021-03-02 19:51:33 +00:00
2021-03-02 19:13:58 +00:00
mod infra;
async fn run_server(config: Configuration) -> Result<()> {
2021-03-07 15:13:50 +00:00
let sql_pool = SqlitePoolOptions::new()
.max_connections(5)
.connect_with(SqliteConnectOptions::from_str("sqlite://users.db")?.create_if_missing(true))
.await?;
let server_builder = infra::ldap_server::build_ldap_server(
&config,
sql_pool.clone(),
actix_server::Server::build(),
)?;
let server_builder = infra::tcp_server::build_tcp_server(&config, sql_pool, server_builder)?;
server_builder.workers(1).run().await?;
Ok(())
}
2021-03-02 19:51:33 +00:00
fn main() -> Result<()> {
2021-03-02 19:13:58 +00:00
let cli_opts = infra::cli::init();
2021-03-02 19:51:33 +00:00
let config = infra::configuration::init(cli_opts.clone())?;
infra::logging::init(config.clone())?;
info!("Starting LLDAP....");
debug!("CLI: {:#?}", cli_opts);
debug!("Configuration: {:#?}", config);
2021-03-02 22:07:01 +00:00
actix::run(
run_server(config).unwrap_or_else(|e| error!("Could not bring up the servers: {:?}", e)),
)?;
2021-03-02 22:07:01 +00:00
2021-03-02 19:51:33 +00:00
info!("End.");
Ok(())
2021-03-02 11:45:30 +00:00
}