LinuxQuestions.org

LinuxQuestions.org (/questions/)
-   Linux - Server (https://www.linuxquestions.org/questions/linux-server-73/)
-   -   SpamAssassin (not) catching spams (https://www.linuxquestions.org/questions/linux-server-73/spamassassin-not-catching-spams-4175488647/)

proNick 12-20-2013 03:06 AM

SpamAssassin (not) catching spams
 
Hello,

SpamAssassin on my server have to catch spam emails, that contains several "bad" words. But it does not, and all emails are received regularly in inbox (and that's I need to avoid).

My /etc/mail/spamassassin/local.cf looks like this:

Code:

ok_locales all
skip_rbl_checks 0

required_score 3.5
report_safe 0
rewrite_header Subject ***SPAM***

use_pyzor 1

use_auto_whitelist 0


use_bayes 1
use_bayes_rules 1
bayes_auto_learn 1
blacklist_from *@kupiizaradi.cjb.net
blacklist_from *@hallmark.com
whitelist_from *@*hrgworldwide.com
whitelist_from *@bluehost.com
#blacklist_from *@greekajob.com


header CONTAINS_VIG Subject =~ /viagra, Cialix Pills, sex, xxx, penis, pussy, greekajob, greekajobs, perazdera/
body CONTAINS_PEN /viagra, sex, xxx, penis, puss, greekajob, greekajobs, perazdera/
score CONTAINS_VIG 5.0
score CONTAINS_PEN 5.0
describe CONTAINS_VIG Bad Word
describe CONTAINS_PEN Bad Word


As I said, all of emails are not filtered, and I can receive them in inbox.

Can you help me what I'm doing wrong with this, and what to do to catch spam emails - ie. to delete them or to move them in Spam folder?

proNick 12-20-2013 03:15 PM

Ok, bit of update here.

My SpamAssassin does change subject, if email is classified as a Spam, and it works fine now. File /etc/mail/spamassassin/local.cf looks like this:

Code:

ok_locales all
skip_rbl_checks 0

required_score 5
report_safe 1
rewrite_header Subject ***SPAM***

use_pyzor 1
use_razor2 1

use_auto_whitelist 0


use_bayes 1
use_bayes_rules 1
bayes_auto_learn 1
blacklist_from *@kupiizaradi.cjb.net
blacklist_from *@hallmark.com
whitelist_from *@*hrgworldwide.com
whitelist_from *@bluehost.com
#blacklist_from *@greekajob.com

header CONTAINS_VIG Subject =~ /viagra, Cialix Pills, sex, xxx, penis, pussy, greekajob, greekajobs, pera
zdera/
body CONTAINS_PEN /viagra, sex, xxx, penis, puss, greekajob, greekajobs, perazdera/
score CONTAINS_VIG 1.5
score CONTAINS_PEN 1.5
describe CONTAINS_VIG Bad Word
describe CONTAINS_PEN Bad Word


I need help how to:
1. move those emails into Spam folder
2. automatically create Spam folder for every new mail account added on server

/etc/mail/mailfilter looks like this:

Code:

SHELL="/bin/sh"
import EXT
import HOST
VHOME=`pwd`
TIMESTAMP=`date "+%b %d %H:%M:%S"`
#VERBOSE=9

logfile "/var/log/maildrop/maildrop.log"
log "$TIMESTAMP - BEGIN maildrop processing for $EXT@$HOST ==="

`test -r $VHOME/.mailfilter`
if($RETURNCODE == 0)
{
        log "including $VHOME/.mailfilter"
        exception {
                include $VHOME/.mailfilter
        }
}


# does maildirsize exist?
`test -e $VHOME/Maildir/maildirsize`

# if maildirsize doesn't exist
if($RETURNCODE == 1)
{

        # does vuserinfo exist?
        `test -x /home/vpopmail/bin/vuserinfo`

        # if vuserinfo exists
        if($RETURNCODE == 0)
        {
                # does the user exist?
                `/home/vpopmail/bin/vuserinfo $EXT@$HOST`
                if($RETURNCODE == 0)
                {

                        # find out what the user's quota is
                        $QUOTA=`/home/vpopmail/bin/vuserinfo -Q $EXT@$HOST`
                        log "QUOTA = $QUOTA"

                        # does maildirmake exists?
                        `test -x /usr/bin/maildirmake`

                        # if maildirmake exists
                        if($RETURNCODE == 0)
                        {

                                # does Maildir exist?
                                `test -d $VHOME/Maildir`

                                # if Maildir exists
                                if($RETURNCODE == 0)
                                {

                                        # make the maildirsize file
                                        `/usr/bin/maildirmake -q $QUOTA $VHOME/Maildir`
                                        `test -s "$VHOME/Maildir/maildirsize"`

                                        # if maildirsize exists
                                          if($RETURNCODE == 0)
                                        {
                                            `/bin/chown vpopmail:vchkpw $VHOME/Maildir/maildirsize`
                                                `/bin/chmod 640 $VHOME/Maildir/maildirsize`

                                        # else
                                          }
                                        else
                                        {
                                                log "Problem making 'maildirsize' for $VHOME"
                                        }

                                        # end if maildirsize exists
                                }
                                else
                                {
                                        log "Maildir does not exist for $VHOME"
                                }

                                # end if Maildir exists
                        }
                        else
                        {
                                log "maildirmake does not exist"

                        # end if maildirmake exists
                        }
                }
                else
                {
                        log "user $EXT@HOST does not exist"

                # end if user exists
                }
        }
        else
        {
                log "vuserinfo does not exist"

        # end if vuserinfo exists
        }
}
# does maildirsize exist?
`test -e $VHOME/Maildir/maildirsize`
if($RETURNCODE == 0)
{
        MAILDIRQUOTA=`/usr/bin/head -n1 $VHOME/Maildir/maildirsize`
        log "MAILDIRQUOTA = $MAILDIRQUOTA"
}


#--------------------------------------------------------
# Filter spam - scores >= SPAMLIMIT is not delivered
#
# If you DO NOT want to send mail that is over the spam limit
# to spamassassin autolearn, comment: 'cc "|sa-learn -spam"'
#--------------------------------------------------------

##########################################################################
# Below is where I found some of the main problem, i.e apparently the
# regex logic changed, do a diff against this one and the old one,
# the old one was delimited with the '!' (bang) and grouped as a whole.
# it failed the match always.  By using standard regex grouping, I was able
# to get the filter working. By grouping the score accordingly, it
# breaks it into a number and precision, e.g. MATCH1 and MATCH2
##########################################################################

if(/^X-Spam-Status: Yes, score=([0-9]+)\.([0-9]+)/:h)
{
        if($MATCH1 >= 5)
        {
                cc "|sa-learn --spam"
        }

        # if the user doesnt' have a Spam folder
        `test -d $VHOME/Maildir/.Spam`
        if($RETURNCODE == 1)
        {
                `test -x /usr/bin/maildirmake`
                if($RETURNCODE == 0)
                {
                        `/usr/bin/maildirmake -f Spam $VHOME/Maildir`
                        `test -x /usr/bin/subscribeIMAP.sh`
                        if($RETURNCODE == 0)
                        {
                                `/usr/bin/subscribeIMAP.sh Spam $VHOME`
                        }
                }
        }

        # make sure the deliverquota binary exists and is executable
        `test -x /usr/bin/deliverquota`
        if($RETURNCODE == 1)
        {
                exception {
                        to "$VHOME/Maildir/.Spam"
                }
        }
        else
        {
                cc "|/usr/bin/deliverquota -w 90 $VHOME/Maildir/.Spam"
                if($RETURNCODE == 0)
                {
                        log "=== END ===  $EXT@$HOST  success (quota)"
                        EXITCODE=0
                        exit
                }
                else
                {
                        if($RETURNCODE == 77)
                        {
                                log "$TIMESTAMP - $EXT@$HOST  bounced (quota)"
                                to "|/var/qmail/bin/bouncesaying '$EXT@$HOST is over quota'"
                        }
                        else
                        {
                                log \
                                "$TIMESTAMP - $EXT@$HOST failure (unknown deliverquota error)"
                                to "$VHOME/Maildir/.Spam"
                        }
                }
        }
}

##########################################################################
# Same as above
##########################################################################
if(/^X-Spam-Status: No, score=([\-]*[0-9]+)\.([0-9]+) /:h)
{
        log "  message is clean ($MATCH1.$MATCH2)"
}


#--------------------------------------------------------
# Include any user rules
#--------------------------------------------------------

`test -r $VHOME/Maildir/.mailfilter`
if($RETURNCODE == 0)
{
        log "  including $VHOME/Maildir/.mailfilter"
        exception {
                include $VHOME/Maildir/.mailfilter
        }
}

`test -x /usr/bin/deliverquota`
if ($RETURNCODE == 1)
{
        log "$TIMESTAMP - $EXT@$HOST WARNING: no deliverquota!"
        log "=== END ===  $EXT@$HOST success"
        exception {
                to "$VHOME/Maildir"
        }
}
else
{
        exception {
                log "RETCODE = $RETURNCODE  delivering to $VHOME/Maildir"
                xfilter "/usr/bin/deliverquota -w 90 $VHOME/Maildir"
        }
        #--------------------------------------------------------
        # check to make sure the message was delivered
        # returncode 77 means that out maildir was overquota - bounce mail
        #--------------------------------------------------------
        if($RETURNCODE == 77)
        {
                log "$TIMESTAMP - BOUNCED: bouncesaying '$EXT@$HOST is over quota'"
                log "$TIMESTAMP - $EXT@$HOST  bounced"
                to "|/var/qmail/bin/bouncesaying '$EXT@$HOST is over quota'"
        }
        else
        {
                log "=== END ===  $EXT@$HOST  success (quota)"
                EXITCODE=0
                exit
        }
}

log "$TIMESTAMP - $EXT@$HOST - WARNING: This message should never be printed!"
[root@um-1027 /etc/mail]#


And .qmail-default looks like this:

Code:

|/var/qmail/bin/preline /usr/bin/maildrop /etc/mail/mailfilter

Can somebody help me please how to fix this and to move spam messages into spam folder?


All times are GMT -5. The time now is 08:51 PM.