diff --git a/server/src/infra/auth_service.rs b/server/src/infra/auth_service.rs index 558af2b..4f7581b 100644 --- a/server/src/infra/auth_service.rs +++ b/server/src/infra/auth_service.rs @@ -18,7 +18,7 @@ use hmac::Hmac; use jwt::{SignWithKey, VerifyWithKey}; use sha2::Sha512; use time::ext::NumericalDuration; -use tracing::{debug, instrument, warn}; +use tracing::{debug, info, instrument, warn}; use lldap_auth::{login, password_reset, registration, JWTClaims}; @@ -183,6 +183,7 @@ where .await { warn!("Error sending email: {:#?}", e); + info!("Reset token: {}", token); return Err(TcpError::InternalServerError(format!( "Could not send email: {}", e diff --git a/server/src/infra/cli.rs b/server/src/infra/cli.rs index 1ee6a99..4356fdd 100644 --- a/server/src/infra/cli.rs +++ b/server/src/infra/cli.rs @@ -132,6 +132,10 @@ pub enum SmtpEncryption { #[derive(Debug, Parser, Clone)] #[clap(next_help_heading = Some("SMTP"))] pub struct SmtpOpts { + /// Enable password reset + #[clap(long, env = "LLDAP_SMTP_OPTIONS__ENABLE_PASSWORD_RESET")] + pub smtp_enable_password_reset: Option, + /// Sender email address. #[clap(long, env = "LLDAP_SMTP_OPTIONS__FROM")] pub smtp_from: Option, diff --git a/server/src/infra/configuration.rs b/server/src/infra/configuration.rs index 6426a1c..bf806d3 100644 --- a/server/src/infra/configuration.rs +++ b/server/src/infra/configuration.rs @@ -276,6 +276,9 @@ impl ConfigOverrider for SmtpOpts { if let Some(tls_required) = self.smtp_tls_required { config.smtp_options.tls_required = Some(tls_required); } + if let Some(enable_password_reset) = self.smtp_enable_password_reset { + config.smtp_options.enable_password_reset = enable_password_reset; + } } }