- Info: http://spamassassin.apache.org/
- Docs: http://spamassassin.apache.org/full/4.0.x/doc/
- Latest version: 4.0.2
- Download: http://spamassassin.apache.org/downloads.cgi
- Upgrading notes: https://svn.apache.org/repos/asf/spamassassin/trunk/UPGRADE
- github: https://github.com/apache/spamassassin
SpamAssassin is a mature, widely-deployed open source project that serves as a mail filter to identify Spam. SpamAssassin uses a variety of mechanisms including header and text analysis, Bayesian filtering, DNS blocklists, and collaborative filtering databases. SpamAssassin runs on a server, and filters spam before it reaches your mailbox.
Changelog
- Oct 4, 2025
 - added a section in theRBLpage, which addresses thespamhausban issue for queries from open resolvers.
- Sep 11, 2025
 -txrepis working badly in a server where data were not completely deleted. Read the updates below
- Sep 10, 2025
 - spamassassin upgraded to v 4.0.2
 - added a new page "Preparing the SQL database in SpamAssassin" where the old issue about the MySQL/MariaDB driver is addressed.
- May 31, 2025
 - We are know denying validity, as it is imposing low limits and drastically blocking the queries (tx Shailendra Shukla).
Upgrading SpamAssassin
Update: txrep performed very poorly on a recently upgraded server, where I had only purged data older than a month. The scores attributed by txrep went completely wrong, and I had several false positives (legit mail with high spam score). I therefore deleted all the data from the txrep table. No issue instead in my personal server.
I recommend wait a bit before upgrading to version 4.0.2, or take the precautions outlined above, namely completely purging the txrep table and limiting its score. Please contribute to the tests if you can and report here in the comments.
If you are upgrading SpamAssassin from version 3.x, follow the instructions in the dedicated page and then come back here.
If you are upgrading from v4.0.1 to v4.0.2 do what follows.
Create the database table for the new Redirectors plugin by running the following SQL query
use spamassassin; CREATE TABLE `redir_url_cache` ( `redir_url` VARCHAR(255) NOT NULL, `target_url` VARCHAR(512) NOT NULL, `hits` INT NOT NULL DEFAULT 1, `created` INT(11) NOT NULL, `modified` INT(11) NOT NULL, PRIMARY KEY (`redir_url`) ) ENGINE = InnoDB; -- Maintaining index for cleaning is likely more expensive than occasional full table scan ALTER TABLE `redir_url_cache` ADD INDEX `redir_url_created` (`created`);
Stop the services and do the upgrade:
svc -d /service/qmail-send spamdctl stop cpan -T install Mail::SpamAssassin sa-update
Enable the Redirectors plugin in /etc/mail/spamassassin/v402.pre. Just uncomment the following line:
loadplugin Mail::SpamAssassin::Plugin::Redirectors
Add the following configuration to 90-sql.conf:
# Redirectors plugin # https://spamassassin.apache.org/full/4.0.x/doc/Mail_SpamAssassin_Plugin_Redirectors.html # https://github.com/apache/spamassassin/blob/trunk/sql/redirectors_mysql.sql url_redirector_cache_type dbi url_redirector_cache_dsn DBI:MariaDB:database=spamassassin;host=localhost;port=3306 url_redirector_cache_username spamassassin url_redirector_cache_password xxxxxxxxxxxxxxx
Be aware that you have to use the right MySQL/MariaDB driver as explained in the following page, where I explain how to purge the cache table as well.
Now restart the services:
spamdctl start svc -u /service/qmail-send
Finally we have to take care of the following issue that appeared in the release notes:
TxRep data when using a SQL backend might be wrong because of a bug in SpamAssassin 4.0.1, TxRep score can be limited with new txrep_min_score and txrep_max_score configuration options or you can remove email entries from TxRep database.
So the values saved in the DB could be incorrect or distorted, resulting in incorrect reputation calculations. Therefore a sender could appear more "trustworthy" or more "spammy" than it should.
It is up to you the decision to purge the TxRep table or DROP/TRUNCATE the table. I am deleting all records from my txrep table:
use spamassassin;
DELETE FROM txrep;
I'm also adding the following to my configuration:
txrep_min_score 0 txrep_max_score 2
Install
Create the spamd user and group, prepare config and log dirs:
mkdir -p /etc/mail/spamassassin /home/spamd /var/log/spamassassin groupadd spamd useradd -g spamd -d /home/spamd spamd chown -R spamd:spamd /home/spamd
Then install spamassassin and all the modules we need with their prerequisites. First let's set CPAN to follow the dependencies without without showing us a prompt:
> perl -MCPAN -e shell cpan> o conf prerequisites_policy follow cpan> o conf commit
Cut and paste the following in CPAN (the order is important):
notest install Socket6 IO::Socket IO::Socket::INET6 LWP MD5 CPAN::DistnameInfo Mail::DKIM notest install Test::More MIME::Base64 Digest::MD5 Digest::HMAC_MD5 Net::IP notest install Net::Ping Net::DNS Time::HiRes Digest::SHA1 Getopt::Long Digest::Nilsimsa URI::Escape HTML::Parser HTTP::Date IO::Zlib Archive::Tar Mail::SPF notest install Mail::SPF::Query Net::Ident IO::Socket::SSL Mail::DomainKeys Mail::DKIM LWP::UserAgent HTTP::Date Encode::Detect BSD::Resource notest install Storable DB_File Net::SMTP BerkeleyDB Class::Method::Modifiers notest install Geo::IP IO::Socket::IP Net::Patricia notest install Mail::DMARC::PurePerl MIME::QuotedPrint Compress::Raw::Zlib DBD::SQLite
Install spamassassin:
notest install Mail::SpamAssassin Mail::SpamAssassin::Plugin::Razor2 Mail::SpamAssassin::BayesStore::MySQL
I had to skip the tests because of some error.
We have installed in advance the Razor2 and the Bayesstore:MySQL plugins that we'll need later.
Configuring
You can find the config files into /etc/mail/spamassassin
> cd /etc/mail/spamassassin > ls init.pre local.cf v310.pre v312.pre v320.pre v330.pre v340.pre v341.pre v342.pre v343.pre v400.pre
local.cf
# Add *****SPAM***** to the Subject header of spam e-mails # rewrite_header Subject *****SPAM***** # put here your subnet trusted_networks 10.0.0. # Set the threshold at which a message is considered spam (default: 5.0) required_score 5.0 # denying VALIDITY # https://knowledge.validity.com/s/articles/Accessing-Validity-reputation-data-through-DNS dns_query_restriction deny bl.score.senderscore.com dns_query_restriction deny sa-accredit.habeas.com dns_query_restriction deny sa-trusted.bondedsender.org
We are know denying validity, as it is imposing low limits and drastically blocking the queries (tx Shailendra Shukla).
ExtractText
- Thanks to Gabriel Torres for reviewing and correcting this section
The purpose of the ExtractText plugin is to, when enabled, convert attachments (including images, byt the use of an OCR) into plain text in order to SpamAssassin to apply its rules to this text. So if we receive doc/pdf/images with spammy text in them, SpamAssassin will now be able to safely mark the email as spam.
In order to do that, we need to have installed some external programs in our server. The configuration lines added to local.cf have to load these programs to scan each message attachment.
Install the required external programs. Debian users will do;
apt-get install antiword apt-get install docx2txt apt-get install unrtf apt-get install odt2txt apt-get install tesseract-ocr apt-get install poppler-utils
Slackware users will find all these programs on SlackBuild, while poppler is already availble in the distro.
Add the following lines to 70-extracttext.cf file:
cat > 70-extracttext.cf << EOF
ifplugin Mail::SpamAssassin::Plugin::ExtractText
extracttext_external pdftotext /usr/bin/pdftotext -nopgbrk -layout -enc UTF-8 {} -
extracttext_use pdftotext .pdf application/pdf
# http://docx2txt.sourceforge.net
extracttext_external docx2txt /usr/bin/docx2txt {} -
extracttext_use docx2txt .docx application/docx
extracttext_external antiword /usr/bin/antiword -t -w 0 -m UTF-8.txt {}
extracttext_use antiword .doc application/(?:vnd\.?)?ms-?word.*
extracttext_external unrtf /usr/bin/unrtf --nopict {}
extracttext_use unrtf .doc .rtf application/rtf text/rtf
extracttext_external odt2txt /usr/bin/odt2txt --encoding=UTF-8 {}
extracttext_use odt2txt .odt .ott application/.*?opendocument.*text
extracttext_use odt2txt .sdw .stw application/(?:x-)?soffice application/(?:x-)?starwriter
extracttext_external tesseract {OMP_THREAD_LIMIT=1} /usr/bin/tesseract -c page_separator= {} -
extracttext_use tesseract .jpg .png .bmp .tif .tiff image/(?:jpeg|png|x-ms-bmp|tiff)
add_header all ExtractText-Flags _EXTRACTTEXTFLAGS_
#header PDF_NO_TEXT X-ExtractText-Flags =~ /\bNoText\b/
#describe PDF_NO_TEXT PDF without text
#score PDF_NO_TEXT 0.2
#header DOC_NO_TEXT X-ExtractText-Flags =~ /\bNoText\b/
#describe DOC_NO_TEXT Document without text
#score DOC_NO_TEXT 0.2
#header EXTRACTTEXT exists:X-ExtractText-Flags
#describe EXTRACTTEXT Email processed by extracttext plugin
#score EXTRACTTEXT 0.001
endif
EOF
You can see three rules commented out. You can safely leave them commented out or enable them for debug purposes. The EXTRACTTEXT rule is just to have proof that the plugin is active. PDF_NO_TEXT and DOC_NO_TEXT will be hit in case of an empty document in attach. You will have an header like this when these two rules have been hit:
X-Spam-ExtractText-Flags: NoText
init.pre
# RelayCountry - add metadata for Bayes learning, marking the countries # a message was relayed through # # Note: This requires the IP::Country::Fast Perl module # loadplugin Mail::SpamAssassin::Plugin::RelayCountry # URIDNSBL - look up URLs found in the message against several DNS # blocklists. # loadplugin Mail::SpamAssassin::Plugin::URIDNSBL # SPF - perform SPF verification. # loadplugin Mail::SpamAssassin::Plugin::SPF
v400.pre
Load all new plugin which come with SA v.4
loadplugin Mail::SpamAssassin::Plugin::ExtractText loadplugin Mail::SpamAssassin::Plugin::DecodeShortURLs loadplugin Mail::SpamAssassin::Plugin::DMARC
sa-update
sa-update updates the rules (it requires gpg 1.4). Before running spamassassin for the first time download the rules:
sa-update
Add to your crontab this line to update the rules once a day
cat >> /etc/cron.d/qmail << EOF # spamassassin update 30 3 * * * /usr/local/bin/sa-update --nogpg -v & EOF
The -v option will produce an email notification to postmaster.
Testing
Run this debug command. If you get no error you are ready to run the daemon.
sudo -u spamd -H spamassassin -D --lint
Do not quit spamd with ctrl+C, because the next test with spamc will have to connect to it.
Open another terminal and check if the headers are inserted:
echo -e "From: myself@mymailserver.net\nTo:myfriend@domain.net\nSubject: test\n\n" | spamc
Received: from localhost by qmail.mymailserver.net
 with SpamAssassin (version 3.3.1);
 Tue, 30 Nov 2010 23:18:37 +0100
From: myself@mymailserver.net
To: myfriend@domain.net
Subject: test
X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-04-18) on qmail.mymailserver.net
X-Spam-Flag: YES
X-Spam-Level: *****
X-Spam-Status: Yes, score=5.4 required=5.0 tests=BAYES_99,FREEMAIL_FROM,
 MISSING_DATE,MISSING_MID,NO_RECEIVED,NO_RELAYS,TVD_SPACE_RATIO,
 T_TO_NO_BRKTS_FREEMAIL autolearn=no version=3.3.1
Running spamassassin
Download the startup script
cd /usr/local/bin wget https://notes.sagredo.eu/files/qmail/spamdctl chmod +x spamdctl
Set the IP variable with the IPs that are allowed to send queries to spamd:
#!/bin/bash
#
# Spamd init script
#
# August, 2th 2003
# Martin Ostlund, nomicon
# Modified slightly by Troy Belding for Qmailrocks - February 23, 2004
#
# Modified by Roberto Puzzanghera - September 02, 2014
# November 17, 2020: moved log file to /var/log/spamassassin/spamd.log
# Comma separated IPs that are allowed to query the spamd server
IP=127.0.0.1,::1,1.2.3.4,10.0.0.0/24
DAEMON=/usr/local/bin/spamd
NAME=spamd
SNAME=spamdctl
DESC="SpamAssassin Mail Filter Daemon"
LOGFILE=/var/log/spamassassin/spamd.log
PIDFILE="/var/run/$NAME.pid"
PNAME="spamd"
LISTEN_IP=0.0.0.0
# DEBUG="-D" # comment out to disable debug
# USER_PREFS="-q" # Use with -x. Comment out to disable sql user prefs
DOPTIONS="${DEBUG} ${USER_PREFS} -x -u spamd -A ${IP} -i ${$LISTEN_IP} -s $LOGFILE -H /home/spamd -d --pidfile=$PIDFILE"
KILL="/bin/kill"
KILLALL="/bin/killall"
# Defaults - don't touch, edit /etc/mail/spamassassin/local.cf
ENABLED=0
OPTIONS=""
set -e
case "$1" in
start)
echo -n "Starting $DESC: "
$DAEMON $OPTIONS $DOPTIONS
echo "$NAME."
;;
stop)
echo -n "Stopping $DESC: "
$KILL -9 `cat $PIDFILE`
/bin/rm $PIDFILE
echo "$NAME."
;;
restart|force-reload)
echo -n "Restarting $DESC: "
$0 stop
$0 start
echo "$NAME."
;;
*)
ME=/usr/local/bin/$SNAME
echo "Usage: $ME {start|stop|restart|force-reload}" >&2
exit 1
;;
esac
exit 0
Now check that spamd is running:
> spamdctl start > ps axfu root 1859 0.1 3.4 139360 61044 ? Ss 19:00 0:01 /usr/bin/spamd -x -u spamd -A 127.0.0.1,<external-IP> -H /home/spamd -d --pidfile=/var/run/spamd.pid spamd 1860 0.0 3.2 139360 58984 ? S 19:00 0:00 \_ spamd child spamd 1861 0.0 3.2 139360 58984 ? S 19:00 0:00 \_ spamd child
Type spamd -c to learn how to use spamd. See also http://spamassassin.apache.org/full/3.4.x/doc/spamd.html
Blocklists
If using an open DNS, e.g. google's 8.8.8.8, the queries towards spamhaus will be blocked. In this case have a look to the dedicated section in the RBL page.
Starting spamassassin at boot time
To start spamassassin at boot time put your startup script in your rc.local:
/usr/local/bin/spamdctl start &
logrotate
Create a file /etc/logrotate.d/spamd like this (slackware) to rotate daily your spamd logs:
cat > /etc/logrotate.d/spamd << __EOF__
/var/log/spamassassin/spamd.log /var/log/spamassassin/razor-agent.log {
su root apache
rotate 5
daily
missingok
notifempty
delaycompress
postrotate
   [ -f '/var/run/spamd.pid' ] && (kill -HUP \`cat /var/run/spamd.pid\`) || exit 0
endscript
}
__EOF__
Be aware that we have already setup the logrotate for the log file or Razor, which we'll see in the next page.


 
  
 
Comments
SpamAssassin 4.0.2 available!
Gabriel Torres September 6, 2025 20:30 CET
Hi Roberto,
SpamAssassin 4.0.2 has just been released! Please try updating this page, so we know if the issues you reported are still present. I'll wait for your update before upgrading our server.
Cheers!
Reply | Permalink
SpamAssassin 4.0.2 available!
Roberto Puzzanghera Gabriel Torres September 7, 2025 16:12 CET
Hi Gabriel,
I would wait a bit before the upgrade as there's a post in their m/l about a performance degradation that I would like to see solved and, more importantly, a strange warning in the upgrade notes about a possible trouble with txRep
Reply | Permalink
SpamAssassin 4.0.2 available!
Roberto Puzzanghera Roberto Puzzanghera September 7, 2025 17:05 CET
Gabriel,
concerning the compilation issue with DBD-mysql module, it's not dependent on spamassassin version. It has been solved in latest v4.x version, while latest v5.x continues to break with mariadb.
Edit: See the next page
Reply | Permalink
SA-Update Rules 01-May-2025
Shailendra Shukla May 2, 2025 16:43 CET
Hi Roberto,
There seems to be a few features added / changed in SA after the rules update on 01-May-2025. The below fields are seen the the Spam Mails received ,
Well after following the link provided in the message , it seems like one has to create a free account on https://my.validity.com/ and register your mail server ip / ip range CIDR to access queries made to their sender reputation data . Below is the transcript from their website
Although I have created a account and added my IP's , just wanted to check with you if you are aware of the same / updates to SA.
Can you check / investigate if my above findings are true and the optimum configuration if any has to be applied to SA configuration for the same
Cheers
Reply | Permalink
SA-Update Rules 01-May-2025
Roberto Puzzanghera Shailendra Shukla May 2, 2025 18:38 CET
Hi Shailendra, yes I have it in my logs as well
did you solve by registering your IP in their database?
Reply | Permalink
SA-Update Rules 01-May-2025
Shailendra Shukla Roberto Puzzanghera May 14, 2025 15:01 CET
Hi Roberto,
Just a quick update , well registering the ip with Validity RPBL did not resolve the issue for the timebeing. I had a follow up with thier support system and they did mention that my ip did around 18,936 queries in the last 30 days ( which I guess was mainly because we were using a open dns server ) So according to their support I have to wait for some time before they roll off the request counter until it goes below 10,000. The roll off is on a day to day basis if I made 1000 queries on say 15th of April then those 1000 queries will roll off the counter on 15th May. So one has to wait till the roll off takes the counter below 10,000 where your ip is again whitelisted to make queries.
You can check the block list by quering their list using dig command on your server. If the output is 127.255.255.255 then your server is blocked from query to the RPBL
And if its not blocked you should get something like below
I did solve the issue by making SA query the Validity RPBL using a different DNS server by adding the below to local.cf in /etc/mail/spamassassin/
After this I dont get any warnings or errors in my log.
Cheers
Reply | Permalink
SA-Update Rules 01-May-2025
Roberto Puzzanghera Shailendra Shukla May 14, 2025 17:01 CET
I suppose that this one will work until you reach again the limit, isn't it?
does it modify the dns of all other services, not only validity, right?
Reply | Permalink
SA-Update Rules 01-May-2025
Shailendra Shukla Roberto Puzzanghera May 31, 2025 10:55 CET
Hi Roberto ,
A quick update , the fix that I applied worked for some time only . And again the queries to Validity are blocked. I have checked / analyzed the mail traffic on my server
Total for April 2025 was 3148 mails
Total for May 2025 was 2598 mails
Not sure how Validty is calculating the Limit. But for now I have disabled the validty queries modifying the /etc/mail/spamassassin/local.cf and adding the below to it
Well I am not pursuing the matter further with Validty as they are keen on pitching their Paid Subscription which we are not interested in buying as the amount of spam we receive is negligible so we can live with that.
Cheers
Reply | Permalink
SA-Update Rules 01-May-2025
Roberto Puzzanghera Shailendra Shukla May 31, 2025 11:05 CET
Thanks for the update. I'll add it to the guide
Reply | Permalink
SA-Update Rules 01-May-2025
Shailendra Shukla Roberto Puzzanghera May 14, 2025 18:34 CET
dns_server aa.bb.cc.dd
Yes this would work until it hits the limit again. But that should not be a problem now as earlier when I was using the open dns server others querying the validity RPBL was also adding upto the limit. I am not sure if they are counting by the SA IP doing the query or the dns server ip used to resolve the Validity URL, I did test it with a few open dns servers and they end up being blocked .
While what I have currently done is redirect the query only for "spamassassin" via a Authorative DNS server that does not have recurssion which I have in my setup.
the dns_server directive in the SA local.cf basically redirects all the queries that SA does for all the BL's etc via the dns server specified. While all other applications / services like the /var/qmail/control/dnsbllist use the dns( this can be a open dns also) of the actual server . It only modifies the spamassassin dns query server.
Reply | Permalink
SPAMC Error Log
Shailendra Shukla April 16, 2025 15:07 CET
Hi Roberto ,
Not sure if anybody else is expereincing it or not but there are error logs in the /var/log/maillog in regards to spamc on SA4.0.1 noticed the below entries
The installation is as per the guide . After playing around a bit with the settings , I had to fix it with the below workaround.
create /etc/mail/spamassassin/spamc.conf with the following line
And restart spamassassin and the above error lines go away. I have checked these errors on two systems Rocky 8.10 and Rocky 9.5 .
Can you check if this is the actual case with SA 4.0.1 . For those who want the error entires to vanish can use the temp fix provided above .
Cheers
Reply | Permalink
SPAMC Error Log
Roberto Puzzanghera Shailendra Shukla April 16, 2025 15:53 CET
What did you set in the LISTEN_IP variable in your spamdctl script? It appears that you are calling sa in ipv6 but it's only listening on ipv4
Reply | Permalink
SPAMC Error Log
Shailendra Shukla Roberto Puzzanghera April 16, 2025 16:20 CET
This is what I have is spamdctl
Regards
Reply | Permalink
SPAMC Error Log
Shailendra Shukla Shailendra Shukla April 16, 2025 17:26 CET
Well got it to work without the spamc.conf containing -d 127.0.0.1 as I suggested earlier.
As per the spamd daemon help The --listen option (or -i) may be specified multiple times. I did try with -i ${LISTEN_IP},${LISTEN_IP6} but that does not work. Also LISTEN_IP=0.0.0.0,:: ( comma seperated ip list) also does not work
So I modified the spamdctl script like below
Now SA listens on all interfaces i.e 127.0.0.1 and ipv4 public ip , with ::1 and ipv6 public ip.
Cheers
Reply | Permalink
SPAMC Error Log
Roberto Puzzanghera Shailendra Shukla April 16, 2025 17:24 CET
So, if you want to allow connections only on ipv4, as per your spamc.conf, you should change IP to IP=127.0.0.1
Reply | Permalink
Installing spamassassin
Arkadiusz Bronowicki November 30, 2024 10:29 CET
I'm assuming it's me doing something wrong and not knowing how to do something, but I follow the command by command, step by step and I'm not able to install spamassassin.
I have this message :(
What now?
My system is Debian 12.
all the best
Arek
Reply | Permalink
Installing spamassassin
Roberto Puzzanghera Arkadiusz Bronowicki November 30, 2024 11:32 CET
it works here as explained above. Some optional perl packages required the libidn2-dev package from debian
By the way, the last time that I installed spamassassin in a production server was a debian 11 server, and I installed it from debian packages in this way
if you can check if this still works for debian 12 I'll add a note to this page for debian users.
Reply | Permalink
Installing spamassassin
Arkadiusz Bronowicki Roberto Puzzanghera November 30, 2024 11:44 CET
Hi,
I install all additional packages....
still the same after command:
Reply | Permalink
Installing spamassassin
Roberto Puzzanghera Arkadiusz Bronowicki November 30, 2024 12:09 CET
You have to force the install and skip all tests, so
Reply | Permalink
Installing spamassassin
Arkadiusz Bronowicki Roberto Puzzanghera November 30, 2024 12:29 CET
Just won't disabling package testing make the whole installation wrong anyway? Since this spamd_pid doesn't work, it won't work anyway. :O
Reply | Permalink
Installing spamassassin
Roberto Puzzanghera Arkadiusz Bronowicki November 30, 2024 12:34 CET
Some test always fail. If you have time to stay there and click yes in order to proceed, just do it. But this is how I install it since 2008 and it works, as I don't get errors in my logs
Reply | Permalink
Installing spamassassin
Roberto Puzzanghera Roberto Puzzanghera November 30, 2024 12:41 CET
PS: all tests that I do in the post installation that I suggest above succed. This is the reason why I think you can skip the tests during the installation
Reply | Permalink
Installing spamassassin
Arkadiusz Bronowicki Roberto Puzzanghera November 30, 2024 12:36 CET
ok :)
Thanks for Your time and support
all the best
Arek
Reply | Permalink
Reset Spamassassin Score
Kenny Lee September 9, 2024 05:14 CET
Hi Roberto, any way to reset the score of spamassassin and it's AWL score?
Reply | Permalink
Reset Spamassassin Score
Roberto Puzzanghera Kenny Lee September 9, 2024 17:35 CET
Hi Kenny,
are you sure that you mean AWL and not txrep/bayesan? AWL has been replaced by txrep a couple of years ago.
Do you want to purge or completely empty the table? In the first case, just run a query like this (better as a cronjob)
change the number of days. Also purge the userprefs table.
In the second case you can truncate all the tables in the spamassassin database.
Reply | Permalink
Spamassasin at MX level ?
Pablo Murillo December 14, 2023 21:57 CET
Hi
I have SA running on virtual host and I enabled or disabled the SA for any domain from vpopmail.limits table, this works perfect
Now, I'm looking for a way to run SA at MX level, whitout users-prefs, without learning, but I can't find the way to make it work :D
I don't have vpopmail on my mxs, only qmail and spamdyke
How can I make SA works without vpopmail DB (mysql) ?
Can I enable SA from tcp.smtp ?
Thanks
Reply | Permalink
Spamassasin at MX level ?
Roberto Puzzanghera Pablo Murillo December 14, 2023 22:07 CET
Do you mean running SA before qmail-queue? I don't know...
Reply | Permalink
Spamassasin at MX level ?
Pablo Murillo Roberto Puzzanghera December 14, 2023 22:34 CET
Hi Roberto
Sorry !, after I post the question I remember that I'm using SIMSCAN !!!
I recompile simscan with SA support and now it's working :D
Reply | Permalink
Mail::SpamAssassin::Plugin::Hashcash
Mike November 22, 2023 10:32 CET
Hello Roberto,
from ver 4.0 hashcash was REMOVED from SpamAssassin.
pls update.
Txh
Reply | Permalink
Mail::SpamAssassin::Plugin::Hashcash
Roberto Puzzanghera Mike November 22, 2023 14:51 CET
Thank you. Corrected
Reply | Permalink
Details on how to correctly configure the ExtractText plugin
Gabriel Torres June 22, 2023 23:13 CET
Hi Roberto,
The purpose of the ExtractText plugin is to, when enabled, convert attachments (including imagens, byt the use of an OCR) into plain text in order to SpamAssassin to apply its rules to this text. So if we receive doc/pdf/images with spammy text in them, SpamAssassin will now be able to safely mark the email as spam.
In order to do that, we need to have installed some external programs in our server. The configuration lines added to local.cf have to load these programs to scan each message attachment. Also, the rules provided in the example at the SpamAssassin Apache page are just examples. Here are the correct instructions to make the ExtractText plugin to work. I hope you can test them yourself and update this page (and also the "migrating to SpamAssassin 4.0.0" page.
1. Install the required external programs
Here we run Debian, so we need:
2. Add the following lines to the local.cf file. NOTE: your tutorial is missing the required extracttext_external lines:
3. Instructions on how to configure the plugin
The official website suggests the configuration lines above. But this is just an example and there is a small adjustment to be made.
a. Here with me, the string added to X-ExtractText-Flags was only 'NoText' when the attached word/pdf file didn't have any text. So the first two rules wouldn't be triggered. For this reason, I replaced the PDF_NO_TEXT and DOC_NO_TEXT with:
b. Note how I adjusted the score from 0.001 to 0.2. With a score of 0.001, the original rule won't do anything. But, it is up to you to assign a score for emails containing doc/pdf files with no text. I ajusted the rule to a score of 0.2.
Personal note: honestly, both rules PDF_NO_TEXT and DOC_NO_TEXT could be safely removed. They are present in the documentation only so you know they are available.
The final rule, EXTRACTTEXT should be left alone. This rule only exists so we have EXTRACTTEXT in the email header in the list of all rules that the message triggered, so we know that attachments were present in the email and they were converted/scanned by the plugin. It is a great debugging tool.
Cheers,
Gabriel.
Reply | Permalink
Details on how to correctly configure the ExtractText plugin
Roberto Puzzanghera Gabriel Torres June 23, 2023 07:44 CET
Thanks a lot Gabriel. I'll read and test carefully and I'll use it to improve this page
Reply | Permalink
X-Spam-ExtractText-Flags: _EXTRACTTEXTFLAGS_
Gabriel Torres June 20, 2023 23:24 CET
Hi Roberto,
After finally making the move to SA 4.0.0, I noticed that a new header was included, but its value is weird, IMHO:
Isn't this _EXTRACTTEXTFLAGS_ a variable that should be replaced with something else?
Also:
Shouldn't this be:
Please advise!
Cheers!
Reply | Permalink
X-Spam-ExtractText-Flags: _EXTRACTTEXTFLAGS_
Roberto Puzzanghera Gabriel Torres June 21, 2023 09:28 CET
I did a test changing like this with no luck
Reply | Permalink
X-Spam-ExtractText-Flags: _EXTRACTTEXTFLAGS_
Roberto Puzzanghera Gabriel Torres June 21, 2023 08:59 CET
Hi Gabriel,
Actually I would expect it to fill that _EXTRACTTEXTFLAGS_ tag with the notes of the plugin, something like
but I have it as is.
Concerning the other question, I copied the example from the man page here
I hope that someone else can be more specific than me...
Reply | Permalink
X-Spam-ExtractText-Flags: _EXTRACTTEXTFLAGS_
Gabriel Torres Roberto Puzzanghera June 21, 2023 11:54 CET
I'll investigate this further and let you know. Thanks.
Reply | Permalink
Update to spamdctl script
Gabriel Torres August 24, 2021 23:04 CET
Hi Roberto,
After upgrading our OS here to the latest version, spamd stopped working. Upon further inspection, I found this in the log file:
This meant that spamd was listening on 127.0.0.1 but not at ::1 (IPv6 version of 127.0.0.1). Therefore, I replaced IP= with:
and the problem was gone.
Just a small note for you to upgrade the script to support both 127.0.0.1 and ::1.
Cheers.
Reply | Permalink
Update to spamdctl script
Roberto Puzzanghera Gabriel Torres August 25, 2021 09:57 CET
Thank you.
Probably you have to adjust for ipv6 dovecot as well...
Reply | Permalink
GEOIP Perl Module
kittonian June 16, 2020 19:47 CET
For anyone still having issues with GEOIP or GEOIP2, I had to manually patch the file with the help of some freenode people.
Here's the link to the patch: https://github.com/neilgierman/awstats/compare/GeoIP2...Grinnz:patch-1
Reply | Permalink
Create .spamassassin/ dir
Gabriel Torres July 13, 2019 15:03 CET
Here I had to manually create /etc/mail/spamassassin/.spamassassin/ and chown spamd:spamd otherwise I would see error messages in the log files saying that the tx-reputation file couldn't be created.
Reply | Permalink
SA scans only from external emails how to scan local emails?
munku January 12, 2018 01:49 CET
Hi,
Spamassassin is installed correctly and is working fine for years and still is. While spamassassin scans incoming email from external sources, it does not scan emails that is being send locally, (from local to local or local to external domains). Is there a way to make it scan local emails as well? I tried modifying tcp rules to include simscan for local IP addresses but it still does not work.
thanks
Reply | Permalink
How to get SA scan local emails?
Roberto Puzzanghera munku January 12, 2018 18:04 CET
Try to recompile simscan adding
to your configure. This should "turn on spam scanning for authenticated users (default no)."
Reply | Permalink
got error
kwa January 7, 2018 14:40 CET
installed everithing, but got this error (slackware current)
anybody knows where to grab..
Reply | Permalink
got error
Roberto Puzzanghera kwa January 7, 2018 19:03 CET
Let me understand... you upgraded perl and then your installed modules stopped to work?
Reply | Permalink
SSL and AUTH
Nicolas November 3, 2016 09:03 CET
Hello,
Being a long time qmail user I recently wanted to switch to full SSL. Unfortunately I cannot succeed having both SSL and AUTH working at same time.
When using stunnel, it just creates an openrelay : any login/pass is considered as OK (all vars are the same as for normal smtp)
and stunnel_smtpd.conf
When using sslserver, I've no openrelay, but I don't get AUTH on prompt (I've well exported the SMTPAUTH var)
Has anybody succeeded having SSL and AUTH at same time ?
Reply | Permalink
I think I did manage to have
mizzio Nicolas November 11, 2016 11:59 CET
I think I did manage to have SSL on 465 with AUTH. I had to play with the run file of the specific service (on my system, /var/qmail/service/smtpd-465/run). Can you post yours ?
Reply | Permalink
I don't use SSL 465
roberto puzzanghera mizzio November 11, 2016 14:23 CET
I don't use SSL 465
Reply | Permalink
spamdctl DOPTIONS for IPv6
John D Trolinger July 14, 2016 00:12 CET
Spamassassin 3.4.1 was not working. I was getting spamd.log hits
and spamd was not working at all.
I added ::1 in the spamdctl file like so:
Reply | Permalink
I think you have to check
roberto puzzanghera John D Trolinger July 14, 2016 09:26 CET
I think you have to check that spamd is listening on IPv6 as well and eventually add a "-i [::1]:783" option to your spamdctl. Look here for details http://spamassassin.apache.org/full/3.4.x/doc/spamd.html
Reply | Permalink
IPv6
John roberto puzzanghera July 14, 2016 23:06 CET
Roberto,
We have a new email server for 300 people thanks to your guide. Being able to use Roundcube with PGP was the key piece. I had to keep the old qmail / sqmail with the PGP plugin up until today.
IPv6 is working great and spamassassin is doing the job.
I sent you a couple of coffee's and we thank you for keeping the awesome qmail alive.
John D. Trolinger
Reply | Permalink
spamassassin error
rudi durieux February 23, 2016 10:41 CET
Hi,
I have this error on load :
Thanks
Reply | Permalink
spamassassin error
Ivelin Topalov rudi durieux February 8, 2018 15:25 CET
the problem is missing geoip-perl-api - solve like this:
Reply | Permalink
spamassassin error
Roberto Puzzanghera Ivelin Topalov February 8, 2018 16:19 CET
GEO:IP is already mentioned above among the packages that must be installed via CPAN...
Reply | Permalink
I would try to see which
roberto puzzanghera rudi durieux February 23, 2016 13:51 CET
I would try to see which module is missing looking inside that file/line
Reply | Permalink
did you installed GEO:IP?
roberto puzzanghera rudi durieux February 23, 2016 12:01 CET
did you installed GEO:IP?
Reply | Permalink
I have this in cpan
rudi durieux roberto puzzanghera February 23, 2016 12:14 CET
I have this in cpan
install Geo::IP
Geo::IP is up to date (1.45).
Reply | Permalink
Geo::IP
John D Trolinger rudi durieux July 14, 2016 00:27 CET
I had to disable loadplugin Mail::SpamAssassin::Plugin::URILocalBL in v341.pre to get rid of this error in the spamd.log
error: Can't locate loadable object for module Geo::IP in @INC
Reply | Permalink
Geo::IP
J John D Trolinger February 2, 2023 00:48 CET
I had the same issue. It was resolved by installing GeoIP2 and uninstall IP::GeoIP. Spamd may complain about missing Class::XSAccessor, after installing it there was no more error.
Reply | Permalink
Geo::IP
Roberto Puzzanghera J January 8, 2025 18:26 CET
GeoIP2 is not found and unfortunately the Perl GeoIP2 module has been declared deprecated and not suitable for use by its maintainer (more info here), so I think it's better for us to stick with Geo::IP
Reply | Permalink
Change DB Spamassassin
Arturo May 10, 2015 13:10 CET
For update Spamassassin 3.4.1 is necesary update the db (in my case):
Regards
Reply | Permalink
Disable Spamassassin
Fabiano Heringer April 29, 2014 14:55 CET
How can I disable the use of spamassassin? Just uninstalling it?
Thanks!
Reply | Permalink
no, just edit
roberto puzzanghera Fabiano Heringer April 29, 2014 14:59 CET
no, just edit /var/qmail/control/simcontrol and put spam=no. update the simcontrol after that:
Reply | Permalink
Many thanks
3rensho June 27, 2011 09:07 CET
Wow, just found this post yesterday when I wanted to install Spamassassin on my Slackware64-current box. I can't thank you enough for this superb post. Grazie mille!
Reply | Permalink
Geo::IP plug not working
catalin 3rensho March 30, 2014 23:20 CET
Thank you for a great tutorial.
I was wondering did you manage to make the new Geo::IP plug in working. I have installed from cpan and updated (geoiplookup works) but spamassassin doesn't seems to take that in consideration when I block a country. I have enable it from init.pre. Any ideea what can be?
Thanks
Reply | Permalink
I don't use that plugin
roberto puzzanghera catalin March 31, 2014 13:44 CET
Sorry, I don't use that plugin
Reply | Permalink