NAME
Mailmunge::Test::Greylist - implementation of greylist
ABSTRACT
This class implements greylisting: Temporarily-failing a combination of machine, sender, and recipient (and possibly other data) that has never seen before.
Mailmunge::Test::Greylist
is a subclass of Mailmunge::Test
SYNOPSIS
# A database must have been created beforehand with
# the following schema:
#
# CREATE TABLE greylist(hash TEXT PRIMARY KEY NOT NULL, last_seen INTEGER);
# CREATE TABLE ips_known_to_retry(ip TEXT PRIMARY KEY NOT NULL, last_seen INTEGER);
my $dbh;
sub initialize {
# Always connect to the database in the "initialize" callback
$dbh = DBI->connect($dsn, $username, $auth, {attr => val});
}
sub cleanup {
# Tidy up when our filter is about to exit
$dbh->disconnect;
}
# The actual use of Mailmunge::Test::Greylist
sub filter_recipient {
my ($ctx) = @_;
my $gl = Mailmunge::Test::Greylist->new($self);
my $min_delay = 5;
my $max_delay = 86400;
my $result = $gl->evaluate($dbh, $min_delay, $max_delay,
$ctx->hostip, $ctx->sender,
$ctx->recipients->[0]);
return $result unless $result->is_success;
# ...
}
CONSTRUCTOR
Mailmunge::Test::Greylist->new($filter)
Constructs and returns a new Mailmunge::Test::Greylist object
METHODS
evaluate($dbh, $min_delay, $max_delay, $ip, @remaining_args)
Evaluates greylisting and returns a Mailmunge::Response
object that will either be CONTINUE or TEMPFAIL.
$dbh is a DBI handle connected to the greylisting database.
$min_delay and $max_delay are the imposed minimum and maximum retry delays respectively. If an SMTP client tries faster than the minimum delay, it continues to get greylisted. If it waits longer than the maximum delay, it begins the greylisting test from scratch.
$ip is the IP address of the connecting SMTP client.
@remaining_args are any other arguments that should be considered to make the greylist tuple specific. Typically, you would call evaluate
from filter_recipient
and would pass the sender and recipient as @remaining_args
AUTHOR
Dianne Skoll <dianne@skollsoft.com>
LICENSE
This code is licenced under the terms of the GNU General Public License, version 2.
Copyright © 2025 Skoll Software Consulting