From: Felix Ableitner Date: Thu, 5 Nov 2020 12:43:46 +0000 (+0100) Subject: Dont send email notifications to banned users (fixes #1251) X-Git-Url: http://these/git/readmes/%24%7B%60data:application/README.md?a=commitdiff_plain;h=d2bea09a60526287a323d4e4c5404a21f3383951;p=lemmy.git Dont send email notifications to banned users (fixes #1251) --- diff --git a/lemmy_structs/src/lib.rs b/lemmy_structs/src/lib.rs index 9b67866a..070cebfb 100644 --- a/lemmy_structs/src/lib.rs +++ b/lemmy_structs/src/lib.rs @@ -77,7 +77,6 @@ fn do_send_local_notifs( do_send_email: bool, ) -> Vec { let mut recipient_ids = Vec::new(); - let hostname = &Settings::get().get_protocol_and_hostname(); // Send the local mentions for mention in mentions @@ -106,17 +105,12 @@ fn do_send_local_notifs( // Send an email to those users that have notifications on if do_send_email && mention_user.send_notifications_to_email { - if let Some(mention_email) = mention_user.email { - let subject = &format!("{} - Mentioned by {}", Settings::get().hostname, user.name,); - let html = &format!( - "

User Mention


{} - {}

inbox", - user.name, comment.content, hostname - ); - match send_email(subject, &mention_email, &mention_user.name, html) { - Ok(_o) => _o, - Err(e) => error!("{}", e), - }; - } + send_email_to_user( + mention_user, + "Mentioned by", + "User Mention", + &comment.content, + ) } } } @@ -130,17 +124,7 @@ fn do_send_local_notifs( recipient_ids.push(parent_user.id); if do_send_email && parent_user.send_notifications_to_email { - if let Some(comment_reply_email) = parent_user.email { - let subject = &format!("{} - Reply from {}", Settings::get().hostname, user.name,); - let html = &format!( - "

Comment Reply


{} - {}

inbox", - user.name, comment.content, hostname - ); - match send_email(subject, &comment_reply_email, &parent_user.name, html) { - Ok(_o) => _o, - Err(e) => error!("{}", e), - }; - } + send_email_to_user(parent_user, "Reply from", "Comment Reply", &comment.content) } } } @@ -153,17 +137,7 @@ fn do_send_local_notifs( recipient_ids.push(parent_user.id); if do_send_email && parent_user.send_notifications_to_email { - if let Some(post_reply_email) = parent_user.email { - let subject = &format!("{} - Reply from {}", Settings::get().hostname, user.name,); - let html = &format!( - "

Post Reply


{} - {}

inbox", - user.name, comment.content, hostname - ); - match send_email(subject, &post_reply_email, &parent_user.name, html) { - Ok(_o) => _o, - Err(e) => error!("{}", e), - }; - } + send_email_to_user(parent_user, "Reply from", "Post Reply", &comment.content) } } } @@ -171,3 +145,29 @@ fn do_send_local_notifs( }; recipient_ids } + +fn send_email_to_user(user: User_, subject_text: &str, body_text: &str, comment_content: &str) { + if user.banned { + return; + } + + if let Some(user_email) = user.email { + let subject = &format!( + "{} - {} {}", + subject_text, + Settings::get().hostname, + user.name, + ); + let html = &format!( + "

{}


{} - {}

inbox", + body_text, + user.name, + comment_content, + Settings::get().get_protocol_and_hostname() + ); + match send_email(subject, &user_email, &user.name, html) { + Ok(_o) => _o, + Err(e) => error!("{}", e), + }; + } +}