2024-02-15 21:52:00 +01:00
use std ::{ error ::Error , fs } ;
2024-01-01 15:50:06 +01:00
use lettre ::{
2024-02-15 22:21:40 +01:00
message ::{ header ::ContentType , Attachment , MultiPart , SinglePart } ,
2024-02-15 21:52:00 +01:00
transport ::smtp ::authentication ::Credentials ,
Message , SmtpTransport , Transport ,
2024-01-01 15:50:06 +01:00
} ;
use sqlx ::SqlitePool ;
use crate ::tera ::admin ::mail ::MailToSend ;
2024-02-04 10:34:58 +01:00
use super ::{ family ::Family , log ::Log , role ::Role , user ::User } ;
2024-01-01 15:50:06 +01:00
pub struct Mail { }
impl Mail {
2024-02-15 21:52:00 +01:00
pub async fn send ( db : & SqlitePool , data : MailToSend < '_ > , smtp_pw : String ) -> bool {
2024-01-01 15:50:06 +01:00
let mut email = Message ::builder ( )
. from (
" ASKÖ Ruderverein Donau Linz <no-reply@rudernlinz.at> "
. parse ( )
. unwrap ( ) ,
)
. reply_to (
" ASKÖ Ruderverein Donau Linz <info@rudernlinz.at> "
. parse ( )
. unwrap ( ) ,
)
. to ( " ASKÖ Ruderverein Donau Linz <no-reply@rudernlinz.at> "
. 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 {
2024-02-04 10:34:58 +01:00
match single_rec . parse ( ) {
Ok ( new_bcc_mail ) = > email = email . bcc ( new_bcc_mail ) ,
Err ( _ ) = > {
Log ::create (
db ,
format! ( " Mail not sent to {rec} , because it could not be parsed " ) ,
)
. await ;
}
}
2024-01-01 15:50:06 +01:00
}
}
2024-02-15 22:21:40 +01:00
let mut multipart = MultiPart ::mixed ( ) . singlepart ( SinglePart ::plain ( data . body ) ) ;
2024-02-15 21:52:00 +01:00
for temp_file in & data . files {
let content = fs ::read ( temp_file . path ( ) . unwrap ( ) ) . unwrap ( ) ;
let media_type = format! ( " {} " , temp_file . content_type ( ) . unwrap ( ) . media_type ( ) ) ;
let content_type = ContentType ::parse ( & media_type ) . unwrap ( ) ;
let attachment = Attachment ::new ( format! (
" {}.{} " ,
temp_file . name ( ) . unwrap ( ) ,
temp_file . content_type ( ) . unwrap ( ) . extension ( ) . unwrap ( )
) )
. body ( content , content_type ) ;
multipart = multipart . singlepart ( attachment ) ;
}
2024-01-01 15:50:06 +01:00
2024-02-15 22:21:40 +01:00
let email = email . subject ( data . subject ) . multipart ( multipart ) . unwrap ( ) ;
2024-01-01 15:50:06 +01:00
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
}
2024-01-19 11:19:24 +01:00
pub async fn fees ( db : & SqlitePool , smtp_pw : String ) {
let users = User ::all_payer_groups ( db ) . await ;
for user in users {
2024-01-19 11:47:28 +01:00
if ! user . has_role ( db , " paid " ) . await {
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} , " ) )
2024-01-19 11:19:24 +01:00
}
}
2024-01-19 11:47:28 +01:00
}
None = > {
if let Some ( mail ) = & user . mail {
2024-02-21 14:46:17 +01:00
send_to . push_str ( mail )
2024-01-19 11:19:24 +01:00
}
}
2024-01-19 11:47:28 +01:00
}
2024-01-19 11:19:24 +01:00
2024-01-19 11:47:28 +01:00
let fees = user . fee ( db ) . await ;
if let Some ( fees ) = fees {
let mut content = format! (
2024-01-21 16:09:43 +01:00
" Liebes Vereinsmitglied, \n \n \
2024-01-19 11:19:24 +01:00
dein Vereinsbeitrag für das aktuelle Jahr beträgt { } € " ,
2024-01-19 11:47:28 +01:00
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 ) )
2024-01-19 11:19:24 +01:00
}
2024-01-19 11:47:28 +01:00
}
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 bei it@rudernlinz.at. @Studenten: Bitte die aktuelle Studienbestätigung an it@rudernlinz.at schicken.\n\n\
2024-01-19 11:56:49 +01:00
Wenn du die Vereinsgebühren schon bezahlt hast , kannst du diese Mail einfach ignorieren . \ n \ n
2024-01-19 11:19:24 +01:00
Beste Grüße \ n \
Der Vorstand
" );
2024-01-19 11:47:28 +01:00
let mut email = Message ::builder ( )
. from (
" ASKÖ Ruderverein Donau Linz <no-reply@rudernlinz.at> "
2024-01-19 11:19:24 +01:00
. parse ( )
2024-01-19 11:47:28 +01:00
. unwrap ( ) ,
)
. reply_to (
" ASKÖ Ruderverein Donau Linz <it@rudernlinz.at> "
. parse ( )
. unwrap ( ) ,
)
. to ( " ASKÖ Ruderverein Donau Linz <no-reply@rudernlinz.at> "
. parse ( )
. unwrap ( ) ) ;
let splitted = send_to . split ( ',' ) ;
2024-01-21 16:07:11 +01:00
let mut send_mail = false ;
2024-01-19 11:47:28 +01:00
for single_rec in splitted {
2024-01-21 16:07:11 +01:00
let single_rec = single_rec . trim ( ) ;
2024-01-21 16:00:41 +01:00
match single_rec . parse ( ) {
Ok ( val ) = > {
email = email . bcc ( val ) ;
send_mail = true ;
}
Err ( _ ) = > {
println! ( " Error in mail: {single_rec} " ) ;
}
}
2024-01-19 11:47:28 +01:00
}
2024-01-19 11:19:24 +01:00
2024-01-21 16:00:41 +01:00
if send_mail {
let email = email
. subject ( " ASKÖ Ruderverein Donau Linz | Vereinsgebühren " )
. header ( ContentType ::TEXT_PLAIN )
. body ( content )
. unwrap ( ) ;
2024-01-19 11:19:24 +01:00
2024-01-21 16:00:41 +01:00
let creds =
Credentials ::new ( " no-reply@rudernlinz.at " . to_owned ( ) , smtp_pw . clone ( ) ) ;
2024-01-19 11:19:24 +01:00
2024-01-21 16:00:41 +01:00
let mailer = SmtpTransport ::relay ( " mail.your-server.de " )
. unwrap ( )
. credentials ( creds )
. build ( ) ;
2024-01-19 11:19:24 +01:00
2024-01-21 16:00:41 +01:00
// Send the email
mailer . send ( & email ) . unwrap ( ) ;
}
2024-01-19 11:19:24 +01:00
}
}
}
}
2024-01-01 15:50:06 +01:00
}