Server IP : 85.214.239.14 / Your IP : 3.147.27.154 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /usr/share/perl5/Mail/SpamAssassin/Plugin/ |
Upload File : |
# <@LICENSE> # Licensed to the Apache Software Foundation (ASF) under one or more # contributor license agreements. See the NOTICE file distributed with # this work for additional information regarding copyright ownership. # The ASF licenses this file to you under the Apache License, Version 2.0 # (the "License"); you may not use this file except in compliance with # the License. You may obtain a copy of the License at: # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # </@LICENSE> =head1 NAME Mail::SpamAssassin::Plugin::VBounce - aid in rescuing genuine bounces =head1 SYNOPSIS loadplugin Mail::SpamAssassin::Plugin::VBounce [/path/to/VBounce.pm] =cut package Mail::SpamAssassin::Plugin::VBounce; use Mail::SpamAssassin::Plugin; use Mail::SpamAssassin::Logger; use strict; use warnings; use re 'taint'; our @ISA = qw(Mail::SpamAssassin::Plugin); sub new { my $class = shift; my $mailsaobject = shift; $class = ref($class) || $class; my $self = $class->SUPER::new($mailsaobject); bless ($self, $class); $self->register_eval_rule("have_any_bounce_relays"); # type does not matter $self->register_eval_rule("check_welcomelist_bounce_relays"); # type does not matter $self->register_eval_rule("check_whitelist_bounce_relays"); # type does not matter - #Stub - Remove in SA 4.1 $self->set_config($mailsaobject->{conf}); return $self; } sub set_config { my($self, $conf) = @_; my @cmds; =head1 USER PREFERENCES The following options can be used in both site-wide (C<local.cf>) and user-specific (C<user_prefs>) configuration files to customize how SpamAssassin handles incoming email messages. =over 4 =item welcomelist_bounce_relays hostname [hostname2 ...] Previously whitelist_bounce_relays which will work interchangeably until 4.1. This is used to 'rescue' legitimate bounce messages that were generated in response to mail you really *did* send. List the MTA relay hostnames that your outbound mail is delivered through. If a bounce message is found, and it contains one of these hostnames in a 'Received' header found the in the message body, it will not be marked as a blowback virus-bounce. The hostnames can be file-glob-style patterns, so C<relay*.isp.com> will work. Specifically, C<*> and C<?> are allowed, but all other metacharacters are not. Regular expressions are not used for security reasons. Multiple addresses per line, separated by spaces, is OK. Multiple C<welcomelist_bounce_relays> lines are also OK. =back =cut push (@cmds, { setting => 'welcomelist_bounce_relays', aliases => ['whitelist_bounce_relays'], # backward compatible - to be removed for 4.1 type => $Mail::SpamAssassin::Conf::CONF_TYPE_ADDRLIST }); $conf->{parser}->register_commands(\@cmds); } sub have_any_bounce_relays { my ($self, $pms) = @_; return $pms->{conf}->{welcomelist_bounce_relays} && %{$pms->{conf}->{welcomelist_bounce_relays}} ? 1 : 0; } sub check_welcomelist_bounce_relays { my ($self, $pms) = @_; return 0 if !$self->have_any_bounce_relays($pms); my $body = $pms->get_decoded_stripped_body_text_array(); my $res; # catch lines like: # Received: by dogma.boxhost.net (Postfix, from userid 1007) # check the plain-text body, first foreach my $line (@{$body}) { next unless ($line =~ /^[> ]*Received:/i); while ($line =~ / (\S+\.\S+) /g) { return 1 if $self->_relay_is_in_welcomelist_bounce_relays($pms, $1); } } # now check any "message/anything" attachment MIME parts, too. # don't use the more efficient find_parts() method until bug 5331 is # fixed, otherwise we'll miss some messages due to their MIME structure my $pristine = $pms->{msg}->get_pristine_body(); # triage, avoids expensive loop through large mail with attachments return 0 if $pristine !~ /Received:/i; my $found_received = 0; my $fullhdr = ''; foreach my $line ($pristine =~ /^(.*)$/gm) { if (!defined $line) { return 0; } # don't bother until we see a line with "Received:" in it if (!$found_received) { next unless ($line =~ /^[> ]*Received:/i); $found_received = 1; } if ($line =~ /^\s/) { # bug 5912, deal with multiline $fullhdr .= $line; } else { $fullhdr = $line; } next unless ($fullhdr =~ /^[> ]*Received:/i); while ($fullhdr =~ /\s(\S+\.\S+)\s/gs) { return 1 if $self->_relay_is_in_welcomelist_bounce_relays($pms, $1); } } return 0; } *check_whitelist_bounce_relays = \&check_welcomelist_bounce_relays; # removed in 4.1 sub _relay_is_in_welcomelist_bounce_relays { my ($self, $pms, $relay) = @_; return 1 if $self->_relay_is_in_list( $pms->{conf}->{welcomelist_bounce_relays}, $pms, $relay); dbg("rules: relay $relay doesn't match any welcomelist"); return 0; } sub _relay_is_in_list { my ($self, $list, $pms, $relay) = @_; $relay = lc $relay; utf8::encode($relay) if utf8::is_utf8($relay); # encode chars to UTF-8 if (defined $list->{$relay}) { return 1; } foreach my $regexp (values %{$list}) { if ($relay =~ $regexp) { dbg("rules: relay $relay matches regexp: $regexp"); return 1; } } return 0; } 1;