[pmg-devel] [PATCH pmg-api v2 4/5] greylist: make netmasks configurable

Stoiko Ivanov s.ivanov at proxmox.com
Mon Apr 20 13:22:42 CEST 2020


Instead of hardcoding the netmask used for comparing greylistentries to
the current ip (24 for ipv4 and 64 for ipv6) - make them configurable in
pmg.conf

This should help with some cloud providers who send the same mail with
different ips from a large network - which all get greylisted separately.
In the worst case the sending cloud drops the mail, after it got defered
too often.

Signed-off-by: Stoiko Ivanov <s.ivanov at proxmox.com>
---
 src/PMG/Config.pm | 16 ++++++++++++++++
 src/bin/pmgpolicy |  6 ++++--
 2 files changed, 20 insertions(+), 2 deletions(-)

diff --git a/src/PMG/Config.pm b/src/PMG/Config.pm
index 7b9ca48..093401a 100755
--- a/src/PMG/Config.pm
+++ b/src/PMG/Config.pm
@@ -609,11 +609,25 @@ sub properties {
 	    type => 'boolean',
 	    default => 1,
 	},
+	greylistmask4 => {
+	    description => "Netmask to apply for greylisting IPv4 hosts",
+	    type => 'integer',
+	    minimum => 0,
+	    maximum => 32,
+	    default => 24,
+	},
 	greylist6 => {
 	    description => "Use Greylisting for IPv6.",
 	    type => 'boolean',
 	    default => 0,
 	},
+	greylistmask6 => {
+	    description => "Netmask to apply for greylisting IPv6 hosts",
+	    type => 'integer',
+	    minimum => 0,
+	    maximum => 128,
+	    default => 64,
+	},
 	helotests => {
 	    description => "Use SMTP HELO tests.",
 	    type => 'boolean',
@@ -671,7 +685,9 @@ sub options {
 	max_smtpd_in => { optional => 1 },
 	max_smtpd_out => { optional => 1 },
 	greylist => { optional => 1 },
+	greylistmask4 => { optional => 1 },
 	greylist6 => { optional => 1 },
+	greylistmask6 => { optional => 1 },
 	helotests => { optional => 1 },
 	tls => { optional => 1 },
 	tlslog => { optional => 1 },
diff --git a/src/bin/pmgpolicy b/src/bin/pmgpolicy
index 810f81f..fd78ced 100755
--- a/src/bin/pmgpolicy
+++ b/src/bin/pmgpolicy
@@ -319,6 +319,8 @@ sub load_config {
     $self->{use_spf} = $pmg_cfg->get('mail', 'spf');
     $self->{use_greylist} = $pmg_cfg->get('mail', 'greylist');
     $self->{use_greylist6} = $pmg_cfg->get('mail', 'greylist6');
+    $self->{greylistmask4} = $pmg_cfg->get('mail', 'greylistmask4');
+    $self->{greylistmask6} = $pmg_cfg->get('mail', 'greylistmask6');
 
     if ($opt_testmode) {
 	$self->{use_spf} = 1;
@@ -556,10 +558,10 @@ sub greylist_value {
     my $masklen;
     my $do_greylist = 0;
     if ($ip =~ m/$IPV4RE/) {
-	$masklen = 24;
+	$masklen = $self->{greylistmask4};
 	$do_greylist = $self->{use_greylist};
     } elsif ($ip =~ m/$IPV6RE/) {
-	$masklen = 64;
+	$masklen = $self->{greylistmask6};
 	$do_greylist = $self->{use_greylist6};
     } else {
 	return 'dunno';
-- 
2.20.1




More information about the pmg-devel mailing list