feat(main): Configure & start OIDC actor when Converse launches

This commit is contained in:
Vincent Ambo 2018-04-08 22:37:52 +02:00
parent a63bc782b0
commit 1c4d436eae

View file

@ -42,6 +42,14 @@ use diesel::r2d2::{ConnectionManager, Pool};
use std::env; use std::env;
use handlers::*; use handlers::*;
fn config(name: &str) -> String {
env::var(name).expect(&format!("{} must be set", name))
}
fn config_default(name: &str, default: &str) -> String {
env::var(name).unwrap_or(default.into())
}
fn main() { fn main() {
env_logger::init(); env_logger::init();
@ -49,27 +57,47 @@ fn main() {
let sys = actix::System::new("converse"); let sys = actix::System::new("converse");
info!("Initialising database connection pool ..."); info!("Initialising database connection pool ...");
let db_url = env::var("DATABASE_URL") let db_url = config("DATABASE_URL");
.expect("DATABASE_URL must be set");
let manager = ConnectionManager::<PgConnection>::new(db_url); let manager = ConnectionManager::<PgConnection>::new(db_url);
let pool = Pool::builder().build(manager).expect("Failed to initialise DB pool"); let pool = Pool::builder().build(manager).expect("Failed to initialise DB pool");
let db_addr = SyncArbiter::start(2, move || DbExecutor(pool.clone())); let db_addr = SyncArbiter::start(2, move || DbExecutor(pool.clone()));
info!("Initialising OIDC integration ...");
let oidc_url = config("OIDC_DISCOVERY_URL");
let oidc_config = oidc::load_oidc(&oidc_url)
.expect("Failed to retrieve OIDC discovery document");
let oidc = oidc::OidcExecutor {
oidc_config,
client_id: config("OIDC_CLIENT_ID"),
client_secret: config("OIDC_CLIENT_SECRET"),
redirect_uri: format!("{}/oidc/callback", config("BASE_URL")),
};
let oidc_addr: Addr<Syn, oidc::OidcExecutor> = oidc.start();
info!("Initialising HTTP server ..."); info!("Initialising HTTP server ...");
let bind_host = env::var("CONVERSE_BIND_HOST").unwrap_or("127.0.0.1:4567".into()); let bind_host = config_default("CONVERSE_BIND_HOST", "127.0.0.1:4567");
server::new(move || { server::new(move || {
let template_path = concat!(env!("CARGO_MANIFEST_DIR"), "/templates/**/*"); let template_path = concat!(env!("CARGO_MANIFEST_DIR"), "/templates/**/*");
let tera = compile_templates!(template_path); let tera = compile_templates!(template_path);
let state = AppState {
db: db_addr.clone(),
oidc: oidc_addr.clone(),
tera,
};
App::with_state(AppState { db: db_addr.clone(), tera }) App::with_state(state)
.middleware(middleware::Logger::default()) .middleware(middleware::Logger::default())
.resource("/", |r| r.method(Method::GET).with(forum_index)) .resource("/", |r| r.method(Method::GET).with(forum_index))
.resource("/thread/submit", |r| r.method(Method::POST).with2(submit_thread)) .resource("/thread/submit", |r| r.method(Method::POST).with2(submit_thread))
.resource("/thread/reply", |r| r.method(Method::POST).with2(reply_thread)) .resource("/thread/reply", |r| r.method(Method::POST).with2(reply_thread))
.resource("/thread/{id}", |r| r.method(Method::GET).with2(forum_thread))}) .resource("/thread/{id}", |r| r.method(Method::GET).with2(forum_thread))
.resource("/oidc/login", |r| r.method(Method::GET).with(login))
.resource("/oidc/callback", |r| r.method(Method::POST).with2(callback))})
.bind(&bind_host).expect(&format!("Could not bind on '{}'", bind_host)) .bind(&bind_host).expect(&format!("Could not bind on '{}'", bind_host))
.start(); .start();