From fe5d7b33ed32ec8114e38ab4f98274b34275c79e Mon Sep 17 00:00:00 2001 From: mdecimus Date: Wed, 22 Jan 2025 19:52:09 +0100 Subject: [PATCH] Do not include IP addresses in greylist keys --- crates/smtp/src/inbound/rcpt.rs | 25 +++++++++++-------------- 1 file changed, 11 insertions(+), 14 deletions(-) diff --git a/crates/smtp/src/inbound/rcpt.rs b/crates/smtp/src/inbound/rcpt.rs index 760d620e..17978d13 100644 --- a/crates/smtp/src/inbound/rcpt.rs +++ b/crates/smtp/src/inbound/rcpt.rs @@ -310,21 +310,18 @@ impl Session { .grey_list .filter(|_| self.data.authenticated_as.is_none()) { - let mut key = Vec::with_capacity(64); + let from_addr = self + .data + .mail_from + .as_ref() + .unwrap() + .address_lcase + .as_bytes(); + let to_addr = self.data.rcpt_to.last().unwrap().address_lcase.as_bytes(); + let mut key = Vec::with_capacity(from_addr.len() + to_addr.len() + 1); key.push(KV_GREYLIST); - match self.data.remote_ip { - std::net::IpAddr::V4(ipv4_addr) => key.extend_from_slice(&ipv4_addr.octets()), - std::net::IpAddr::V6(ipv6_addr) => key.extend_from_slice(&ipv6_addr.octets()), - }; - key.extend_from_slice( - self.data - .mail_from - .as_ref() - .unwrap() - .address_lcase - .as_bytes(), - ); - key.extend_from_slice(self.data.rcpt_to.last().unwrap().address_lcase.as_bytes()); + key.extend_from_slice(from_addr); + key.extend_from_slice(to_addr); match self.server.in_memory_store().key_exists(key.clone()).await { Ok(true) => (),