use std::error::Error; use lettre::{ message::{ header::{self, ContentType}, MultiPart, SinglePart, }, transport::smtp::authentication::Credentials, Message, SmtpTransport, Transport, }; use sqlx::SqlitePool; use crate::tera::admin::mail::MailToSend; use super::{family::Family, role::Role, user::User}; pub struct Mail {} impl Mail { pub async fn send(db: &SqlitePool, data: MailToSend<'_>, smtp_pw: String) -> bool { let mut email = Message::builder() .from( "ASKÖ Ruderverein Donau Linz " .parse() .unwrap(), ) .reply_to( "ASKÖ Ruderverein Donau Linz " .parse() .unwrap(), ) .to("ASKÖ Ruderverein Donau Linz " .parse() .unwrap()); let role = Role::find_by_id(db, data.role_id).await.unwrap(); for rec in role.mails_from_role(db).await { let splitted = rec.split(','); for single_rec in splitted { email = email.bcc(single_rec.parse().unwrap()); } } // TODO: handle attachments let email = email .subject(data.subject) .header(ContentType::TEXT_PLAIN) .body(String::from(data.body)) .unwrap(); let creds = Credentials::new("no-reply@rudernlinz.at".to_owned(), smtp_pw); let mailer = SmtpTransport::relay("mail.your-server.de") .unwrap() .credentials(creds) .build(); // Send the email match mailer.send(&email) { Ok(_) => return true, Err(e) => println!("{:?}", e.source()), }; false } pub async fn fees(db: &SqlitePool, smtp_pw: String) { let users = User::all_payer_groups(db).await; for user in users { if user.has_role(db, "paid").await { if user.name == "Philipp Hofer" { let mut is_family = false; let mut send_to = String::new(); match Family::find_by_opt_id(db, user.family_id).await { Some(family) => { is_family = true; for member in family.members(db).await { if let Some(mail) = member.mail { send_to.push_str(&format!("{mail},")) } } } None => { if let Some(mail) = &user.mail { send_to.push_str(&mail) } } } let fees = user.fee(db).await; if let Some(fees) = fees { let mut content = format!( "Liebes Vereinsmitglied, \n\ \n dein Vereinsbeitrag für das aktuelle Jahr beträgt {}€", fees.sum_in_cents / 100, ); if fees.parts.len() == 1 { content.push_str(&format!(" ({}).\n", fees.parts[0].0)) } else { content .push_str(". Dieser setzt sich aus folgenden Teilen zusammen: \n"); for (desc, fee_in_cents) in fees.parts { content.push_str(&format!("- {}: {}€\n", desc, fee_in_cents / 100)) } } if is_family { content.push_str(&format!( "Dieser gilt für die gesamte Familie ({}).\n", fees.name )) } content.push_str("\n Bitte überweise diesen auf folgendes Konto: IBAN: AT13 1200 0804 1300 1200. Auf https://app.rudernlinz.at/planned findest du einen QR Code, den du mit deiner Bankapp scannen kannst um alle Eingaben bereits ausgefüllt zu haben.\n\n\ Falls die Berechnung nicht stimmt (korrekte Preise findest du unter https://rudernlinz.at/unser-verein/gebuhren/) melde dich bitte an it@rudernlinz.at. @Studenten: Bitte Bestätigung an it@rudernlinz.at schicken.\n\n\ Beste Grüße\n\ Der Vorstand "); let mut email = Message::builder() .from( "ASKÖ Ruderverein Donau Linz " .parse() .unwrap(), ) .reply_to( "ASKÖ Ruderverein Donau Linz " .parse() .unwrap(), ) .to("ASKÖ Ruderverein Donau Linz " .parse() .unwrap()); let splitted = send_to.split(','); for single_rec in splitted { email = email.bcc(single_rec.parse().unwrap()); } let email = email .subject("ASKÖ Ruderverein Donau Linz | Vereinsgebühren") .header(ContentType::TEXT_PLAIN) .body(content) .unwrap(); let creds = Credentials::new("no-reply@rudernlinz.at".to_owned(), smtp_pw.clone()); let mailer = SmtpTransport::relay("mail.your-server.de") .unwrap() .credentials(creds) .build(); // Send the email mailer.send(&email).unwrap(); } } } } } }