packages icon



 AntiSpam(8)                                                     AntiSpam(8)
 -                                                                         -

                                  Jan 2000



 NAME
      antispam - allow pop users to use relay to send mail

 SYNOPSIS
      antispam

 DESCRIPTION
      This program is a daemon that keeps an eye on the mail log and watches
      for POP3 logins on the machine.  For each successful POP3 login
      antispam keeps a record of the originating machine's IP and allows it
      to use the local mail relay.

      The deamon keeps two hash files where it stores the IPs of authorised
      machines. The first hashed is for internal use and stores the IPs and
      the time at which the login was made (for timeout purposes). The
      second hash is shared with sendmail (or whatever mailer is in use).
      The mailer must search this additional file for IP's that it should
      allow relaying to.


 CONFIGURATION
      The progam has a config file ( /etc/antispam.cfg ) which it will open
      upon startup. Options on that file are specified on a one-per-line
      basis. Paramenters with more than one word must be double quoted
      (example:  log "my anti spamming log"). Lines beginning with '#' are
      ignored.

      Available config file options:

      log <logfile>
           This is the file where antispam will record all it's activity. If
           not specified defaults to /var/log/antispam

      maillog <logfile>
           This is the file where antispam will look for all successful POP3
           logins (example: /var/log/maillog). This parameter is mandatory.

      runtimedb <hashfile>
           Location of antispam's runtime hash. This is where antispam will
           keep track of the currently authorised IP's and their respective
           expiry times. If not specified defaults to /var/run/antispam.db

      ip_allow <hashfile>
           Hash where antispam will "inform" the mailer of IPs that are
           allowed to use the relay (example: /. The mailer must be
           configured to consult this hash and allow relaying to all the IPs
           in it (see below). This parameter is mandatory.

      timeout <minutes>



                                    - 1 -        Formatted:  January 2, 2025






 AntiSpam(8)                                                     AntiSpam(8)
 -                                                                         -

                                  Jan 2000



           Time after which the authorization will expire. That is... after
           the last successful POP3 login from an IP, the number of minutes
           that the same IP will be allowed to use the relay. If not
           specified defaults to 10 minutes.

      check <minutes>
           Time between checks for expiry. Every x minutes antispam will go
           through the authorised IP's list and wipe those with expired
           autorization.  The check time must be inferior to the timeout
           value, otherwise they'll be swapped. If not specified defaults to
           1 minute.

      resolvenames <value>
           Should antispam check the dns names of the pop3 clients before
           authorizing them? This can take two values: 0 or 1. If it's 0,
           antispam won't resolve the hostname in POP3 and match it's IP
           against the one where the connection came from.  If it's 1,
           antispam WILL resolve the hostname in POP3 and if it's different
           from the one where the connection came from there will be no
           authorization and a warning will be issued in the log.

      ignore_ip <IP>
           This option makes antispam ignore the specified IP (example:
           ignore_ip 192.168.1.1). If there's a successful POP3 login from
           that IP, it will NOT be added to the authorized list.  POP3 login

      ignore_net <network>
           Same as ignore_ip but this one only matches the beginning of the
           remote IP (example: ignore_net 192.168.1. ). Usefull to avoid
           authorizing IPs from your own network that are already authorised
           by default.

      ignore_host <host>
           This option is identical to ignore_ip but matches the hostname
           instead of the IP. If you want to make it clear on the config
           file which hosts you're ignoring use this (example: ignore_host
           relay.outter.net) If the hosts don't have a reverse DNS sentry
           for their IPs then use ignore_ip

      ignore_domain <domain>
           Same as ignore_host but this one only matches the end the remote
           host (example: ignore_domain .outter.friendly.net ). Usefull to
           avoid keeping authorizing our own domains that are already
           authorised by default.

      You can have several ignore_ip, ignore_net, ignore_host and
      ignore_domain directives in your config file. If any of them matches a
      POP3 login, that login will not be taken into account regarding
      authorization.



                                    - 2 -        Formatted:  January 2, 2025






 AntiSpam(8)                                                     AntiSpam(8)
 -                                                                         -

                                  Jan 2000



 INSTALLATION
    Setting up the files
      Create your config file, and put the antispam in /usr/sbin.  You can
      also copy the antispam.init script to your /etc/rc.d/init.d/
      directory.

    Configuring the mailer
      This is the tricky part. I use sendmail (no flames please). I changed
      my sendmail.cf by including the following line: Kantispam hash
      /etc/mail/ip_allow.db

      This will add an hash map called 'antispam'. Now we have to make
      sendmail consult this map before rejecting the relaying of a mail. The
      hash map that antispam generates for sendmail (or any other mailer
      that supports hash maps) has a key/value pair. The key is the IP
      itself and the value is 'OK'.

      I'm not a sendmail gury by any means but I changed my check_rcpt rule
      from:


      Scheck_rcpt
      # first: get client address
      R$+                     $: $(dequote "" $&{client_addr} $) $| $1
      R0 $| $*                $@ ok           client_addr is 0 for sendmail -bs
      R$={LocalIP}$* $| $*    $@ ok           from here
      # next: get client name
      R$* $| $+               $: $(dequote "" $&{client_name} $) $| $2
      R $| $*                 $@ ok           no client name: directly invoked
      #R$- $| $*              $@ ok           for those without full DNS...
      R$*$=w $| $*            $@ ok           from here
      R$*$={LocalNames} $| $* $@ ok           from allowed system
      # now check other side
      R$* $| $*               $: $>3 $2
      # remove local part
      R$*<@$+.>$*             $: $>remove_local $1<@$2.>$3
      # still something left?
      R$*<@$+>$*              $#error $@ 5.7.1 $: 551 we do not relay


      to


      Scheck_rcpt
      # first: get client address
      R$+                     $: $(dequote "" $&{client_addr} $) $| $1
      R0 $| $*                $@ ok           client_addr is 0 for sendmail -bs
      R$={LocalIP}$* $| $*    $@ ok           from here
      R$* $| $+               $: $(antispam $1 $) $| $2 # !! Consult the map



                                    - 3 -        Formatted:  January 2, 2025






 AntiSpam(8)                                                     AntiSpam(8)
 -                                                                         -

                                  Jan 2000



      Rok $| $+               $@ ok           # !! Matches 'ok'? Let it pass
      # next: get client name
      R$* $| $+               $: $(dequote "" $&{client_name} $) $| $2
      R $| $*                 $@ ok           no client name: directly invoked
      #R$- $| $*              $@ ok           for those without full DNS...
      R$*$=w $| $*            $@ ok           from here
      R$*$={LocalNames} $| $* $@ ok           from allowed system
      # now check other side
      R$* $| $*               $: $>3 $2
      # remove local part
      R$*<@$+.>$*             $: $>remove_local $1<@$2.>$3
      # still something left?
      R$*<@$+>$*              $#error $@ 5.7.1 $: 551 we do not relay

    Getting it up and running
      Just call /usr/sbin/antispam. If everything's ok with the config file
      it will become a daemon, fork a 'tail -f' to your maillog file and
      start working.

      Do a 'tail -f /var/log/antispam' (or whatever log file you named in
      the config) and do a POP on the server. If the machine you "popped"
      from isn't on the "ignore list" you should see something like:

      [Thu Nov 11 17:09:29 1999] Authorized an.internet.host [192.168.1.1]
      to use smtp

      When the timeout you defined expires you should see something like:

      [Thu Nov 11 16:55:04 1999] Disallowing 192.168.1.1 to use smtp

      It is usual to see several "authorized" lines for the same host/ip
      before the "disallowing" line itself. If the host does a POP before
      it's expiry time passes there won't be multiple instances of it's IP
      on the database. Instead his expiry time will be updated.

      Also, if you kill antispam with entries on the database, they'll
      remain permanently authorized for the mailer. Altough, when antispam
      is brought up running again it'll erase those that have expired. So,
      if antispam crashes (never happened, really :) ) you won't end up with
      permanently authorized hosts when you "reboot" it.


    Log Rotating
      If you wish to rotate antispam's logs you'll have to terminate it
      (send it a TERM signal: 'killall -TERM antispam'), rotate the logs and
      launch it again.

      I usually create a antispam.conf file on the /etc/logrotate.d/
      directory containing:



                                    - 4 -        Formatted:  January 2, 2025






 AntiSpam(8)                                                     AntiSpam(8)
 -                                                                         -

                                  Jan 2000



      /var/log/antispam {
        daily
        missingok
        postrotate
          /etc/rc.d/init.d/antispam.init restart > /dev/null
        endscript
      }

 BUGS
      Maybe lots of them... you tell me.

 REPORTING BUGS
      Report bugs to <alf@linuxbox.com>.


 FILES
      /etc/antispam.cfg /var/run/antispam.db /var/log/antispam
      /etc/mail/ip_allow.db


 ACKOWLEDGMENTS
      Thanks to Jose Legatheaux Martins for coming up to me with the idea.

      Thanks to Carlos Canau for encouraging me to give it a finishing
      touch, correcting lots of imperfections, the bug tracking and lots of
      ideas.


 AUTHOR
      AntiSpam was made by Pedro Almeida <alf@alf.linuxbox.com>

 COPYRIGHT
      This is free software; see the source for copying conditions.  There
      is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
      PARTICULAR PURPOSE.

















                                    - 5 -        Formatted:  January 2, 2025