check_loop plugin by Keith Ivey
git-svn-id: https://svn.perl.org/qpsmtpd/trunk@438 958fd67b-6ff1-0310-b445-bb7760255be9
This commit is contained in:
parent
014efa87c4
commit
9ba9d68f72
53
plugins/check_loop
Normal file
53
plugins/check_loop
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
#!/usr/bin/perl
|
||||||
|
|
||||||
|
=head1 NAME
|
||||||
|
|
||||||
|
check_loop - Detect mail loops
|
||||||
|
|
||||||
|
=head1 DESCRIPTION
|
||||||
|
|
||||||
|
This plugin detects loops by counting "Received" and "Delivered-To"
|
||||||
|
header lines. It's a kluge but it duplicates what qmail-smtpd does,
|
||||||
|
and it does at least prevent messages from looping forever.
|
||||||
|
|
||||||
|
=head1 CONFIGURATION
|
||||||
|
|
||||||
|
Takes one optional parameter, the maximum number of "hops" ("Received"
|
||||||
|
and lines plus "Delivered-To" lines) allowed. The default is 100, the
|
||||||
|
same as in qmail-smtpd.
|
||||||
|
|
||||||
|
=head1 AUTHOR
|
||||||
|
|
||||||
|
Written by Keith C. Ivey
|
||||||
|
|
||||||
|
=head1 LICENSE
|
||||||
|
|
||||||
|
Released to the public domain, 17 June 2005.
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
|
sub register {
|
||||||
|
my ($self, $qp, @args) = @_;
|
||||||
|
$self->register_hook("data_post", "check_loop");
|
||||||
|
|
||||||
|
$self->{_max_hops} = $args[0] || 100;
|
||||||
|
|
||||||
|
if ( $self->{_max_hops} !~ /^\d+$/ ) {
|
||||||
|
$self->log(LOGWARN, "Invalid max_hops value -- using default");
|
||||||
|
}
|
||||||
|
$self->log(LOGWARN, "Ignoring additional arguments") if @args > 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub check_loop {
|
||||||
|
my ($self, $transaction) = @_;
|
||||||
|
|
||||||
|
my $hops = 0;
|
||||||
|
$hops++ for $transaction->header->get('Received'),
|
||||||
|
$transaction->header->get('Delivered-To');
|
||||||
|
|
||||||
|
if ( $hops >= $self->{_max_hops} ) {
|
||||||
|
return DENY, "Too many hops. This message is looping.";
|
||||||
|
}
|
||||||
|
|
||||||
|
return DECLINED;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user