|  | @ -1,12 +1,13 @@ | 
			
		
	
		
		
			
				
					|  |  | use std::str::FromStr; |  |  | use std::str::FromStr; | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | use chrono::NaiveDateTime; |  |  | use chrono::NaiveDateTime; | 
			
		
	
		
		
			
				
					|  |  |  |  |  | use once_cell::sync::Lazy; | 
			
		
	
		
		
			
				
					|  |  | use percent_encoding::{percent_encode, NON_ALPHANUMERIC}; |  |  | use percent_encoding::{percent_encode, NON_ALPHANUMERIC}; | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | use lettre::{ |  |  | use lettre::{ | 
			
		
	
		
		
			
				
					|  |  |     message::{Attachment, Body, Mailbox, Message, MultiPart, SinglePart}, |  |  |     message::{Attachment, Body, Mailbox, Message, MultiPart, SinglePart}, | 
			
		
	
		
		
			
				
					|  |  |     transport::smtp::authentication::{Credentials, Mechanism as SmtpAuthMechanism}, |  |  |     transport::smtp::authentication::{Credentials, Mechanism as SmtpAuthMechanism}, | 
			
		
	
		
		
			
				
					
					|  |  |     transport::smtp::client::{Tls, TlsParameters}, |  |  |     transport::smtp::client::{Certificate, Tls, TlsParameters}, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |     transport::smtp::extension::ClientId, |  |  |     transport::smtp::extension::ClientId, | 
			
		
	
		
		
			
				
					|  |  |     Address, AsyncSendmailTransport, AsyncSmtpTransport, AsyncTransport, Tokio1Executor, |  |  |     Address, AsyncSendmailTransport, AsyncSmtpTransport, AsyncTransport, Tokio1Executor, | 
			
		
	
		
		
			
				
					|  |  | }; |  |  | }; | 
			
		
	
	
		
		
			
				
					|  | @ -29,6 +30,21 @@ fn sendmail_transport() -> AsyncSendmailTransport<Tokio1Executor> { | 
			
		
	
		
		
			
				
					|  |  |     } |  |  |     } | 
			
		
	
		
		
			
				
					|  |  | } |  |  | } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  | static SMTP_ADDITIONAL_ROOT_CERTS: Lazy<Option<Vec<Certificate>>> = Lazy::new(|| { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     Some( | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         CONFIG | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             .smtp_additional_root_certs()? | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             .split(';') | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             .filter(|path| !path.is_empty()) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             .map(|path| { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 let cert = std::fs::read(path) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                     .unwrap_or_else(|e| panic!("Error loading additional SMTP root certificate file {path}.\n{e}")); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 Certificate::from_pem(&cert).unwrap_or_else(|e| panic!("Error decoding certificate file {path}.\n{e}")) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             }) | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             .collect(), | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     ) | 
			
		
	
		
		
			
				
					|  |  |  |  |  | }); | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | fn smtp_transport() -> AsyncSmtpTransport<Tokio1Executor> { |  |  | fn smtp_transport() -> AsyncSmtpTransport<Tokio1Executor> { | 
			
		
	
		
		
			
				
					|  |  |     use std::time::Duration; |  |  |     use std::time::Duration; | 
			
		
	
		
		
			
				
					|  |  |     let host = CONFIG.smtp_host().unwrap(); |  |  |     let host = CONFIG.smtp_host().unwrap(); | 
			
		
	
	
		
		
			
				
					|  | @ -46,6 +62,11 @@ fn smtp_transport() -> AsyncSmtpTransport<Tokio1Executor> { | 
			
		
	
		
		
			
				
					|  |  |         if CONFIG.smtp_accept_invalid_certs() { |  |  |         if CONFIG.smtp_accept_invalid_certs() { | 
			
		
	
		
		
			
				
					|  |  |             tls_parameters = tls_parameters.dangerous_accept_invalid_certs(true); |  |  |             tls_parameters = tls_parameters.dangerous_accept_invalid_certs(true); | 
			
		
	
		
		
			
				
					|  |  |         } |  |  |         } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         if let Some(ref certs) = *SMTP_ADDITIONAL_ROOT_CERTS { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             for cert in certs { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |                 tls_parameters = tls_parameters.add_root_certificate(cert.clone()); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         } | 
			
		
	
		
		
			
				
					|  |  |         let tls_parameters = tls_parameters.build().unwrap(); |  |  |         let tls_parameters = tls_parameters.build().unwrap(); | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |         if CONFIG.smtp_security() == *"force_tls" { |  |  |         if CONFIG.smtp_security() == *"force_tls" { | 
			
		
	
	
		
		
			
				
					|  | 
 |