X-Git-Url: https://git.madduck.net/etc/mailfilter.git/blobdiff_plain/77db0127feeb3654994cee2c75fa53b530e84eeb..738ccfc6ab6240ad466793412bfa15b7c6d80b25:/procmail/spamfilter diff --git a/procmail/spamfilter b/procmail/spamfilter index 066b9cb..80d59cf 100755 --- a/procmail/spamfilter +++ b/procmail/spamfilter @@ -29,16 +29,29 @@ PMDIR=${PMDIR:-$HOME/.etc/mailfilter/procmail} # |$FORMAIL -I"X-Spam: spamtrapped" #} -# check whether this message is being reinjected -TRAINED_AS +# check whether this message is being resubmitted :0 *$ $MSG_DEJAVU -* ^X-Trained-As: \/(h|sp)am { - LOG="spamfilter: skipping already trained $MATCH$NL" :0 - * MATCH ?? spam - { IS_SPAM=already-trained } + * TRAINED_AS ?? . + { + LOG="spamfilter: skipping already trained $TRAINED_AS$NL" + :0 + * TRAINED_AS ?? spam + { IS_SPAM=already-trained } + } + + :0 E + { LOG="spamfilter: skipping resubmitted message$NL" } +} + +# do not run spamfilters if the message destination is already set +:0 E +* DEST ?? . +{ + LOG="spamfilter: message already routed to '$DEST'$NL" + SPAM_UNKNOWN=already-destined } # let earlier parts of the mailfilter cause bypassing the checks @@ -76,6 +89,8 @@ TRAINED_AS # now run the spamfilters :0 E { + INCLUDERC=$PMDIR/spamtraps + INCLUDERC=$PMDIR/spammers INCLUDERC=$PMDIR/pre-spam-cleanup # crm114 @@ -84,6 +99,7 @@ TRAINED_AS :0 * !SKIP_CRM ?? . { + #TODO: somehow filter out headers we added :0 fw |$CRM114 @@ -261,6 +277,7 @@ TRAINED_AS |$FORMAIL -I"X-Spam: spamtrapped ham" IS_SPAM=spamtrapped-ham RETRAIN=spam + SPAM_UNSURE } #VERBOSE=no