Skip to content

spamhaus/spamassassin-dqs

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Using DQS with SpamAssassin

This repository contains the configuration files and a plugin written for SpamAssassin, (https://spamassassin.apache.org/) for use with Spamhaus Technology Data Query Service (DQS) product.


Table of contents


What is DQS?

Data Query Service (DQS) is a set of DNSBLs, updated in real-time, operated by Spamhaus Technology (https://www.spamhaustech.com)


What zones are available with DQS?

All zones, their definitions, and all possible return codes are documented here


What are the advantages of DQS?

With DQS, Spamhaus provides real time updates instead of the one-minute-delayed updates that are used by the public mirrors and the RSYNC feed. Sixty seconds doesn't seem like much, but when dealing with hailstormers they are crucial: the increase in catch rate between the public mirrors and DQS is mostly due to the real time updates.

Along with the above advantage, free DQS users will also get two new zones to query, Zero Reputation Domains (ZRD) and AuthBL. Paid-for DQS users will also get access to the Hash BlockList (HBL).

ZRD automatically adds newly-registered as well as previously-dormant domains to a block list for 24 hours. It also gives return codes that indicate the age of the domain (in hours) since first detection.

AuthBL is primarily designed for use by anyone operating a submission SMTP server. It is a list of IPs that are known to host bots that use stolen credentials to spam. If one of your customers gets their credentials stolen, AuthBL greatly mitigates the ability of botnets to abuse the account, and keeps your MTAs safe from collateral damage.

HBL is a zone dedicated to deal with sextortions/scam cryptowallets, dropbox emails, malicious files and malicious URLs.


How does DQS perform?

You can see it yourself. We are independently tested by Virus Bulletin, a company that tests both DQS and public mirror performances. The difference between them is that DQS catches up to 42% more spam than our public mirrors. NOTE: Results on VBSpam are achieved by using only the DQS dataset, meaning that if you just add an antivirus to your email filtering setup you can potentially reach the same performance as other commercial antispam products.

HBL performance boost

While we know that every scenario is different, our in the field observations made using the Virus Bulletin spam feed shows that including HBL in your antispam setup could roughly boost spam detection from 0,3% up to slightly more than 1%


What is the licensing for DQS?

The usage terms are the same as the terms for our public mirrors, meaning that if you already use our public mirrors you are entitled to a free DQS key.


What is the difference between paid-for and free DQS?

With free DQS you have access to ZRD and AuthBL, and you must abide by the free usage policy limits

With a paid subscription there is no query limit, and access to HBL (the new zone that deals with cryptovalues, emails, malware and malicious URLs) is included.

All the technical information about HBL is available here

If you have a free DQS subscription and would like to trial HBL, please send an email to [email protected] including your customer ID, and you will be contacted by one of our representative to activate a 30 day trial.


How do I register a DQS key?

Just go here and complete the registration procedure. After you register an account, go to this page and you'll find the DQS key under section "1.0 Datafeed Query Service".


Prerequisites

You need a DQS key along with an existing SpamAssassin 3.4.1+ installation on your system. These instructions do not cover the initial SpamAssassin installation. To correctly install SpamAssassin, please refer to instructions applicable to your SpamAssassin distribution.

Since SpamAssassin 4.0.x replaced 3.4.x , we are only supporting installations on the 4.0.x branch. The version for 3.4.x stays here only for legacy, you are strongly encouraged to move to 4.0.x if you are still running the old branch.


Conventions

We are going to use some abbreviations and placeholders:

  • SA: SpamAssassin
  • SH: Spamhaus
  • configuration directory: whenever you find these italic words, we are referring to SA's configuration directory. Depending on your distribution it may be /etc/spamassassin or /etc/mail/spamassassin or something else.
  • Whenever you see the box below, it means that you need to enter the command on your shell:
	$ command
  • Whenever you see the box below, it means that you need to enter the command on a shell with root privileges:
	# command

Installation instructions

Install from Github

Start by downloading the latest package:

	$ git clone https://github.com/spamhaus/spamassassin-dqs
	Cloning into 'spamassassin-dqs'...
	remote: Enumerating objects: 11, done.
	remote: Counting objects: 100% (11/11), done.
	remote: Compressing objects: 100% (9/9), done.
	remote: Total 11 (delta 0), reused 11 (delta 0), pack-reused 0
	Unpacking objects: 100% (11/11), done.

A subdirectory called spamassassin-dqs will be created. Within it you will find the following files:

  • README.md. This is just a pointer to this document.
  • Changelog.md. The changes log file
  • MDaemon.md. Instructions on how to install this plugin on MDaemon servers
  • hbltest.sh. A script that helps you know if your DQS key is HBL enabled
  • LICENSE. The Apache software license
  • NOTICE. A file containing copyright notices
  • 3.4.1+/sh.pre. This file is the loader for the plugin
  • 3.4.1+/SH.pm. This is a dedicated SA plugin written by SH that overcomes some of SA's limitations
  • 3.4.1+/sh.cf. This file contains lookup redefinitions and will need to be edited (see below)
  • 3.4.1+/sh_scores.cf. In this file we override some of SA's default rule scoring
  • 3.4.1+/sh_hbl.cf. Definitions for HBL lookups
  • 3.4.1+/sh_hbl_scores.cf. Definitions for HBL lookups scores
  • 4.0.0+/sh.cf. This file contains lookup redefinitions and will need to be edited (see below)
  • 4.0.0+/sh_scores.cf. In this file we override some of SA's default rule scoring
  • 4.0.0+/sh_hbl.cf. Definitions for HBL lookups
  • 4.0.0+/sh_hbl_scores.cf. Definitions for HBL lookups scores

Check if your key is HBL enabled

We provide a simple script to help you verify whether your DQS key is HBL enabled or not. Use this script to understand what files to copy in your SpamAssassin config directory. You only need to run the script and input your DQS key.

Assuming the example key aip7yig6sahg6ehsohn5shco3z is DQS enabled, run the script and the output will confirm whether your key is HBL enabled:

	$ sh hbltest.sh
	Please input your DQS key: aip7yig6sahg6ehsohn5shco3z
	Looking up test record for HBL... done
	Your DQS key aip7yig6sahg6ehsohn5shco3z is enabled for HBL
	You can copy sh_hbl.cf and sh_hbl_scores.cf if you want HBL enabled

If your key is not HBL enabled (meaning that you registered a FREE DQS key and did not use a paid subscription) the output will be the following:

	$ sh hbltest.sh 
	Please input your DQS key: aip7yig6sahg6ehsohn5shco3z
	Looking up test record for HBL... done
	Your DQS key aip7yig6sahg6ehsohn5shco3z is -=NOT=- enabled for HBL
	Please *do not* copy sh_hbl.cf and sh_hbl_scores.cf

Now follow the instructions based on the version of SpamAssassin you have. If you don't know what version you are running, you can get it by running the following command:

	# spamassassin --version
	SpamAssassin version 3.4.6
	  running on Perl version 5.24.1

Instructions for SpamAssassin 3.4.1 to 3.4.6

First, configure your DQS key. Assuming your key is aip7yig6sahg6ehsohn5shco3z, execute the following commands:

	$ cd spamassassin-dqs/3.4.1+
	$ sed -i -e 's/your_DQS_key/aip7yig6sahg6ehsohn5shco3z/g' sh.cf
	$ sed -i -e 's/your_DQS_key/aip7yig6sahg6ehsohn5shco3z/g' sh_hbl.cf

If you are using FreeBSD, the commands change slightly:

	$ cd spamassassin-dqs/3.4.1+
	$ sed -i "" -e 's/your_DQS_key/aip7yig6sahg6ehsohn5shco3z/g' sh.cf
	$ sed -i "" -e 's/your_DQS_key/aip7yig6sahg6ehsohn5shco3z/g' sh_hbl.cf

There will be no output, but the key will be inserted into sh.cf and sh_hbl.cf in all the needed places.

Edit sh.pre with your editor of choice, and look at the first line:

	loadplugin       Mail::SpamAssassin::Plugin::SH <config_directory>/SH.pm

You will need to replace <config_directory> with your actual configuration directory. So, for example, if your configuration directory is /etc/mail/spamassassin, the line will become:

	loadplugin       Mail::SpamAssassin::Plugin::SH /etc/mail/spamassassin/SH.pm

If you have an HBL enabled key, and assuming the configuration directory is /etc/mail/spamassassin do the following:

	# cp SH.pm /etc/mail/spamassassin
	# cp sh.cf /etc/mail/spamassassin
	# cp sh_scores.cf /etc/mail/spamassassin
	# cp sh_hbl.cf /etc/mail/spamassassin
	# cp sh_hbl_scores.cf /etc/mail/spamassassin
	# cp sh.pre /etc/mail/spamassassin

If your key is not HBL enabled, this is what needs to be done:

	# cp SH.pm /etc/mail/spamassassin
	# cp sh.cf /etc/mail/spamassassin
	# cp sh_scores.cf /etc/mail/spamassassin
	# cp sh.pre /etc/mail/spamassassin

We strongly suggest to not copy the HBL files if your key is not HBL enabled, as the lookups timeout will very likely slow SA email processing.

Next, test the setup by running:

	# spamassassin --lint

This command checks the whole SA installation; if you don't see any output then congratulations! You successfully installed SH's SA setup. You only need to restart SpamAssassin to have the plugin loaded.

In case you tried installing the plugin with a wrong SpamAssassin version (< 3.4.1) you will receive a warning similar to the following :

	# spamassassin --lint

	SHPlugin: ************************** WARNING *************************
	SHPlugin: This plugin will work only with SpamAssassin 3.4.1 and above
	SHPlugin: Your currently installed version is 3.4.0
	SHPlugin: ******************** THIS WILL NOT WORK ********************
	SHPlugin: Remove sh.pre file or update SpamAssassin

Be sure to follow the instructions and remove all the previously copied files. As stated above, the plugin will work only on SpamAssassin 3.4.1 up to 3.4.6.

Instructions for SpamAssassin 4.0.0+

Be sure that you are running the latest 4.0.x version of SpamAssassin.

First, configure your DQS key. Assuming your key is aip7yig6sahg6ehsohn5shco3z, execute the following commands:

	$ cd spamassassin-dqs/4.0.0+
	$ sed -i -e 's/your_DQS_key/aip7yig6sahg6ehsohn5shco3z/g' sh.cf
	$ sed -i -e 's/your_DQS_key/aip7yig6sahg6ehsohn5shco3z/g' sh_hbl.cf

If you are using FreeBSD, the commands change slightly:

	$ cd spamassassin-dqs/4.0.0+
	$ sed -i "" -e 's/your_DQS_key/aip7yig6sahg6ehsohn5shco3z/g' sh.cf
	$ sed -i "" -e 's/your_DQS_key/aip7yig6sahg6ehsohn5shco3z/g' sh_hbl.cf

There will be no output, but the key will be inserted into sh.cf and sh_hbl.cf in all the needed places.

Edit sh.pre with your editor of choice, and look at the first line:

	loadplugin       Mail::SpamAssassin::Plugin::SH <config_directory>/SH.pm

You will need to replace <config_directory> with your actual configuration directory. So, for example, if your configuration directory is /etc/mail/spamassassin, the line will become:

	loadplugin       Mail::SpamAssassin::Plugin::SH /etc/mail/spamassassin/SH.pm

If you have an HBL enabled key, and assuming the configuration directory is /etc/mail/spamassassin do the following:

	# cp SH.pm /etc/mail/spamassassin
	# cp sh.cf /etc/mail/spamassassin
	# cp sh_scores.cf /etc/mail/spamassassin
	# cp sh_hbl.cf /etc/mail/spamassassin
	# cp sh_hbl_scores.cf /etc/mail/spamassassin
	# cp sh.pre /etc/mail/spamassassin

If your key is not HBL enabled, this is what needs to be done:

	# cp sh.cf /etc/mail/spamassassin
	# cp sh_scores.cf /etc/mail/spamassassin

There is no need of copying SH.pm if your key is not HBL enabled, but you'll need to enable the HashBL native SpamAssassin plugin. If your configuration directory is /etc/mail/spamassassin, then edit the file /etc/mail/spamassassin/v342.pre , find the line:

    # loadplugin Mail::SpamAssassin::Plugin::HashBL

and remove the #, making it:

    loadplugin Mail::SpamAssassin::Plugin::HashBL

We strongly suggest to not copy the HBL files if your key is not HBL enabled, as the lookups timeout will very likely slow SA email processing.

Next, test the setup by running:

	# spamassassin --lint

This command checks the whole SA installation; if you don't see any output then congratulations! You successfully installed SH's SA setup. You only need to restart SpamAssassin to have the plugin loaded.


Install from FreeBSD ports

lrosenman maintains a FreeBSD port of our plugin. We don't give support for this port, but if you want to use it, the instructions are as follows:

	# pkg install spamassassin-dqs

and then follow the instructions.

Or, if using ports:

	$ cd /usr/ports/mail/spamassassin-dqs
	$ sudo make install

Install the plugin in a MDaemon server

Please see the file MDaemon.md for instructions

Testing your setup

Once you succesfully installed the plugin, you could head to http://blt.spamhaus.com and test if you have correctly installed everything.

Please read the docs carefully, as a "delivered" response with a red flag doesn't always mean you missed something; it depends on your setup. You should always check all the headers of any email that the BLT sends and look for spam headers, usually, but not always: "X-Spam-Flag: Yes" or "X-Spam: Yes".


Plugin internals

While we acknowledge SpamAssassin's abilities at stopping spam with only minor tweaking of the default config, there are some key uses of our datasets that can only be fully taken advantage of by writing some special SA functions. That is why we decided to develop this special plugin that includes these functions:

  • check_sh_helo. This function checks the domain used in the HELO/EHLO string against DBL and ZRD.

  • check_sh_headers. This function takes the domain out of the From , Reply-to , Envelope From, Return-Path header lines and then checks the domain against DBL and ZRD.

  • check_sh_bodyemail. This function scans the email body looking for email addresses. For all email addresses found, it extracts the domain and check it against DBL and ZRD. This approach has been proven useful, for example, in some dating-scam campaigns.

  • check_sh_bodyemail_ns. This function scans the email body looking for email addresses. For all email addresses found, it extracts the domain and then checks its authoritative nameservers IPs in SBL (beta, not used, but you are encouraged to try it).

  • check_sh_reverse This function checks the reverse DNS (rDNS) of the last untrusted relay in both DBL and ZRD

  • check_sh_bodyuri_a This function scans the email body and looks for URLs; when one is found the hostname is then resolved, and the resulting IP address is checked in SBL and CSS.

  • check_sh_bodyuri_ns This function scans the email body and looks for URLs; when one is found it takes the domain's authoritative nameservers IPs and checks them in SBL (beta, not used, but you are encouraged to try it).

  • check_sh_hostname This function extracts whole hostnames starting from URLs in the email body and is used to check them in the abused-legit component of DBL

  • check_sh_crypto This functions looks for cryptowallets in the email body and checks them in HBL. As of today, we support the following cryptos:

    • BTC
    • BCH
    • XMR
    • LTC
    • XRP
    • ETH
  • check_sh_attachment This functions computes the hash of all the attachments and checks them in HBL, looking for confirmed or suspect malware.

  • check_sh_emails This functions collects all email addresses from headers and body and checks their hashes in HBL.

  • check_urihash This function has been borrowed from SURBL (https://github.com/brt-surbl/URIHash) and slightly modified. It's used to hash URLs and check them in HBL


Final recommendations

The configuration in the VBSpam survey makes exclusive use of our data, since our goal was to certify their quality, and to keep an eye on how we perform in the field.

While the results are reasonably good, the malware/phishing scoring can certainly be improved by employing some additional actions that we recommend.

  • Install an antivirus software on your mailserver;
  • The modern rule of thumb for receiving email should be to "stay defensive", which is why we recommend doing basic attachment filtering by dropping all emails that contains potentially hazardous attachments, at minimum all file extensions that match this regex:
(exe|vbs|pif|scr|bat|cmd|com|cpl|dll|cpgz|chm|js|jar|wsf)
  • You should also drop, by default, all Office documents with macros.

Support and feedback

We would be happy to receive your feedback! If you notice any problems with this installation, please open a Github issue and we'll do our best to help you.

Remember that we are only going to support the latest version, so before opening an issue, please be sure to be running the up-to-date code from this Github repository.

Acknowledgements

We'd like to thank everyone for their suggestions and contributions!