1 use crate::settings::structs::Settings;
3 message::{header, Mailbox, MultiPart, SinglePart},
5 authentication::Credentials,
6 client::{Tls, TlsParameters},
14 use std::str::FromStr;
23 ) -> Result<(), String> {
24 let email_config = settings.email.to_owned().ok_or("no_email_setup")?;
25 let domain = settings.hostname.to_owned();
27 let (smtp_server, smtp_port) = {
28 let email_and_port = email_config.smtp_server.split(':').collect::<Vec<&str>>();
33 .expect("email needs a port"),
37 let email = Message::builder()
42 .expect("email from address isn't valid"),
45 Some(to_username.to_string()),
46 Address::from_str(to_email).expect("email to address isn't valid"),
48 .message_id(Some(format!("{}@{}", Uuid::new_v4(), settings.hostname)))
51 MultiPart::mixed().multipart(
52 MultiPart::alternative()
55 .header(header::ContentType::TEXT_PLAIN)
56 .body(html.to_string()),
59 MultiPart::related().singlepart(
61 .header(header::ContentType::TEXT_HTML)
62 .body(html.to_string()),
67 .expect("email built incorrectly");
69 // don't worry about 'dangeous'. it's just that leaving it at the default configuration
71 let mut builder = SmtpTransport::builder_dangerous(smtp_server).port(smtp_port);
74 if email_config.use_tls {
75 let tls_config = TlsParameters::new(smtp_server.to_string()).expect("the TLS backend is happy");
76 builder = builder.tls(Tls::Wrapper(tls_config));
79 // Set the creds if they exist
80 if let (Some(username), Some(password)) = (email_config.smtp_login, email_config.smtp_password) {
81 builder = builder.credentials(Credentials::new(username, password));
84 let mailer = builder.hello_name(ClientId::Domain(domain)).build();
86 let result = mailer.send(&email);
90 Err(e) => Err(e.to_string()),