|
|
@ -25,6 +25,7 @@ extern crate oath;
|
|
|
|
extern crate data_encoding;
|
|
|
|
extern crate data_encoding;
|
|
|
|
extern crate jsonwebtoken as jwt;
|
|
|
|
extern crate jsonwebtoken as jwt;
|
|
|
|
extern crate u2f;
|
|
|
|
extern crate u2f;
|
|
|
|
|
|
|
|
extern crate yubico;
|
|
|
|
extern crate dotenv;
|
|
|
|
extern crate dotenv;
|
|
|
|
#[macro_use]
|
|
|
|
#[macro_use]
|
|
|
|
extern crate lazy_static;
|
|
|
|
extern crate lazy_static;
|
|
|
@ -245,6 +246,10 @@ pub struct Config {
|
|
|
|
domain: String,
|
|
|
|
domain: String,
|
|
|
|
domain_set: bool,
|
|
|
|
domain_set: bool,
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
yubico_cred_set: bool,
|
|
|
|
|
|
|
|
yubico_client_id: String,
|
|
|
|
|
|
|
|
yubico_secret_key: String,
|
|
|
|
|
|
|
|
|
|
|
|
mail: Option<MailConfig>,
|
|
|
|
mail: Option<MailConfig>,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -258,6 +263,9 @@ impl Config {
|
|
|
|
|
|
|
|
|
|
|
|
let domain = get_env("DOMAIN");
|
|
|
|
let domain = get_env("DOMAIN");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let yubico_client_id = get_env("YUBICO_CLIENT_ID");
|
|
|
|
|
|
|
|
let yubico_secret_key = get_env("YUBICO_SECRET_KEY");
|
|
|
|
|
|
|
|
|
|
|
|
Config {
|
|
|
|
Config {
|
|
|
|
database_url: get_env_or("DATABASE_URL", format!("{}/{}", &df, "db.sqlite3")),
|
|
|
|
database_url: get_env_or("DATABASE_URL", format!("{}/{}", &df, "db.sqlite3")),
|
|
|
|
icon_cache_folder: get_env_or("ICON_CACHE_FOLDER", format!("{}/{}", &df, "icon_cache")),
|
|
|
|
icon_cache_folder: get_env_or("ICON_CACHE_FOLDER", format!("{}/{}", &df, "icon_cache")),
|
|
|
@ -283,6 +291,10 @@ impl Config {
|
|
|
|
domain_set: domain.is_some(),
|
|
|
|
domain_set: domain.is_some(),
|
|
|
|
domain: domain.unwrap_or("http://localhost".into()),
|
|
|
|
domain: domain.unwrap_or("http://localhost".into()),
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
yubico_cred_set: yubico_client_id.is_some() && yubico_secret_key.is_some(),
|
|
|
|
|
|
|
|
yubico_client_id: yubico_client_id.unwrap_or("00000".into()),
|
|
|
|
|
|
|
|
yubico_secret_key: yubico_secret_key.unwrap_or("AAAAAAA".into()),
|
|
|
|
|
|
|
|
|
|
|
|
mail: MailConfig::load(),
|
|
|
|
mail: MailConfig::load(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|