19 KiB
title |
---|
Security | Rspamd |
About
Rspamd is a "fast, free and open-source spam filtering system". DMS integrates Rspamd like any other service. We provide a basic but easy to maintain setup of Rspamd.
If you want to take a look at the default configuration files for Rspamd that DMS packs, navigate to target/rspamd/
inside the repository. Please consult the section "The Default Configuration" section down below for a written overview.
Related Environment Variables
The following environment variables are related to Rspamd:
ENABLE_RSPAMD
ENABLE_RSPAMD_REDIS
RSPAMD_CHECK_AUTHENTICATED
RSPAMD_GREYLISTING
RSPAMD_HFILTER
RSPAMD_HFILTER_HOSTNAME_UNKNOWN_SCORE
RSPAMD_LEARN
SPAM_SUBJECT
MOVE_SPAM_TO_JUNK
MARK_SPAM_AS_READ
With these variables, you can enable Rspamd itself, and you can enable / disable certain features related to Rspamd.
The Default Configuration
Other Anti-Spam-Services
DMS packs other anti-spam services, like SpamAssassin or Amavis, next to Rspamd. There exist services, like ClamAV (ENABLE_CLAMAV
), that Rspamd can utilize to improve the scanning. Except for ClamAV, we recommend disabling all other anti-spam services when using Rspamd. The basic configuration shown below provides a good starting point.
Mode of Operation
!!! tip "Attention"
Read this section carefully if you want to understand how Rspamd is integrated into DMS and how it works (on a surface level).
Rspamd is integrated as a milter into DMS. When enabled, Postfix's main.cf
configuration file includes the parameter rspamd_milter = inet:localhost:11332
, which is added to smtpd_milters
. As a milter, Rspamd can inspect incoming and outgoing e-mails.
Each mail is assigned what Rspamd calls symbols: when an e-mail matches a specific criterion, the e-mail receives a symbol. Afterward, Rspamd applies a spam score (as usual with anti-spam software) to the e-mail.
- The score itself is calculated by adding the values of the individual symbols applied earlier. The higher the spam score is, the more likely the e-mail is spam.
- Symbol values can be negative (i.e., these symbols indicate the mail is legitimate, maybe because SPF and DKIM are verified successfully). On the other hand, symbol scores can be positive (i.e., these symbols indicate the e-mail is spam, perhaps because the e-mail contains numerous links).
Rspamd then adds (a few) headers to the e-mail based on the spam score. Most important is X-Spamd-Result
, which contains an overview of which symbols were applied. It could look like this:
X-Spamd-Result default: False [-2.80 / 11.00]; R_SPF_NA(1.50)[no SPF record]; R_DKIM_ALLOW(-1.00)[example.com:s=dtag1]; DWL_DNSWL_LOW(-1.00)[example.com:dkim]; RWL_AMI_LASTHOP(-1.00)[192.0.2.42:from]; DMARC_POLICY_ALLOW(-1.00)[example.com,none]; RWL_MAILSPIKE_EXCELLENT(-0.40)[192.0.2.42:from]; FORGED_SENDER(0.30)[noreply@example.com,some-reply-address@bounce.example.com]; RCVD_IN_DNSWL_LOW(-0.10)[192.0.2.42:from]; MIME_GOOD(-0.10)[multipart/mixed,multipart/related,multipart/alternative,text/plain]; MIME_TRACE(0.00)[0:+,1:+,2:+,3:+,4:~,5:~,6:~]; RCVD_COUNT_THREE(0.00)[3]; RCPT_COUNT_ONE(0.00)[1]; REPLYTO_DN_EQ_FROM_DN(0.00)[]; ARC_NA(0.00)[]; TO_MATCH_ENVRCPT_ALL(0.00)[]; RCVD_TLS_LAST(0.00)[]; DKIM_TRACE(0.00)[example.com:+]; HAS_ATTACHMENT(0.00)[]; TO_DN_NONE(0.00)[]; FROM_NEQ_ENVFROM(0.00)[noreply@example.com,some-reply-address@bounce.example.com]; FROM_HAS_DN(0.00)[]; REPLYTO_DOM_NEQ_FROM_DOM(0.00)[]; PREVIOUSLY_DELIVERED(0.00)[receiver@anotherexample.com]; ASN(0.00)[asn:3320, ipnet:192.0.2.0/24, country:DE]; MID_RHS_MATCH_FROM(0.00)[]; MISSING_XM_UA(0.00)[]; HAS_REPLYTO(0.00)[some-reply-address@dms-reply.example.com]
And then there is a corresponding X-Rspamd-Action
header, which shows the overall result and the action that is taken. In our example, it would be:
X-Rspamd-Action no action
Since the score is -2.80
, nothing will happen and the e-mail is not classified as spam. Our custom actions.conf
defines what to do at certain scores:
- At a score of 4, the e-mail is to be greylisted;
- At a score of 6, the e-mail is marked with a header (
X-Spam: Yes
); - At a score of 11, the e-mail is outright rejected.
There is more to spam analysis than meets the eye: we have not covered the Bayes training and filters here, nor have we discussed Sieve rules for e-mails that are marked as spam.
Even the calculation of the score with the individual symbols has been presented to you in a simplified manner. But with the knowledge from above, you're equipped to read on and use Rspamd confidently. Keep on reading to understand the integration even better - you will want to know about your anti-spam software, not only to keep the bad e-mail out, but also to make sure the good e-mail arrive properly!
Workers
The proxy worker operates in self-scan mode. This simplifies the setup as we do not require a normal worker. You can easily change this though by overriding the configuration by DMS.
DMS does not set a default password for the controller worker. You may want to do that yourself. In setups where you already have an authentication provider in front of the Rspamd webpage, you may want to set the secure_ip
option to "0.0.0.0/0"
for the controller worker to disable password authentication inside Rspamd completely.
Persistence with Redis
When Rspamd is enabled, we implicitly also start an instance of Redis in the container:
- Redis is configured to persist its data via RDB snapshots to disk in the directory
/var/lib/redis
(or the/var/mail-state/
volume when present). - With the volume mount, the snapshot will restore the Redis data across container restarts, and provide a way to keep backup.
Redis uses /etc/redis/redis.conf
for configuration:
- We adjust this file when enabling the internal Redis service.
- If you have an external instance of Redis to use, the internal Redis service can be opt-out via setting the ENV
ENABLE_RSPAMD_REDIS=0
(link also details required changes to the DMS Rspamd config).
Web Interface
Rspamd provides a web interface, which contains statistics and data Rspamd collects. The interface is enabled by default and reachable on port 11334.
To use the web interface you will need to configure a password, otherwise you won't be able to log in.
??? example "Set a custom password"
Add this line to [your rspamd `custom-commands.conf` config](#with-the-help-of-a-custom-file) which sets the `password` option of the _controller worker_:
```
set-option-for-controller password "your hashed password here"
```
The password hash can be generated via the `rspamadm pw` command:
```bash
docker exec -it <CONTAINER_NAME> rspamadm pw
```
DNS
DMS does not supply custom values for DNS servers (to Rspamd). If you need to use custom DNS servers, which could be required when using DNS-based deny/allowlists, you need to adjust options.inc
yourself. Make sure to also read our FAQ page on DNS servers.
!!! warning
Rspamd heavily relies on a properly working DNS server that it can use to resolve DNS queries. If your DNS server is misconfigured, you will encounter issues when Rspamd queries DNS to assess if mail is spam. Legitimate mail is then unintentionally marked as spam or worse, rejected entirely.
When Rspamd is deciding if mail is spam, it will check DNS records for SPF, DKIM and DMARC. Each of those has an associated symbol for DNS temporary errors with a non-zero weight assigned. That weight contributes towards the spam score assessed by Rspamd which is normally desirable - provided your network DNS is functioning correctly, otherwise when DNS is broken all mail is biased towards spam due to these failed DNS lookups.
!!! danger
While we do not provide values for custom DNS servers by default, we set `soft_reject_on_timeout = true;` by default. This setting will cause a soft reject if a task (presumably a DNS request) timeout takes place.
This setting is enabled to not allow spam to proceed just because DNS requests did not succeed. It could deny legitimate e-mails to pass though too in case your DNS setup is incorrect or not functioning properly.
Logs
You can find the Rspamd logs at /var/log/mail/rspamd.log
, and the corresponding logs for Redis, if it is enabled, at /var/log/supervisor/rspamd-redis.log
. We recommend inspecting these logs (with docker exec -it <CONTAINER NAME> less /var/log/mail/rspamd.log
) in case Rspamd does not work as expected.
Modules
You can find a list of all Rspamd modules on their website.
Disabled By Default
DMS disables certain modules (clickhouse
, elastic
, neural
, reputation
, spamassassin
, url_redirector
, metric_exporter
) by default. We believe these are not required in a standard setup, and they would otherwise needlessly use system resources.
Anti-Virus (ClamAV)
You can choose to enable ClamAV, and Rspamd will then use it to check for viruses. Just set the environment variable ENABLE_CLAMAV=1
.
RBLs (Real-time Blacklists) / DNSBLs (DNS-based Blacklists)
The RBL module is enabled by default. As a consequence, Rspamd will perform DNS lookups to various blacklists. Whether an RBL or a DNSBL is queried depends on where the domain name was obtained: RBL servers are queried with IP addresses extracted from message headers, DNSBL server are queried with domains and IP addresses extracted from the message body [source].
!!! danger "Rspamd and DNS Block Lists"
When the RBL module is enabled, Rspamd will do a variety of DNS requests to (amongst other things) DNSBLs. There are a variety of issues involved when using DNSBLs. Rspamd will try to mitigate some of them by properly evaluating all return codes. This evaluation is a best effort though, so if the DNSBL operators change or add return codes, it may take a while for Rspamd to adjust as well.
If you want to use DNSBLs, **try to use your own DNS resolver** and make sure it is set up correctly, i.e. it should be a non-public & **recursive** resolver. Otherwise, you might not be able ([see this Spamhaus post][spamhaus::faq::dnsbl-usage]) to make use of the block lists.
Providing Custom Settings & Overriding Settings
DMS brings sane default settings for Rspamd. They are located at /etc/rspamd/local.d/
inside the container (or target/rspamd/local.d/
in the repository).
Manually
!!! question "What is docker-data/dms/config/
?"
If you want to overwrite the default settings or provide your settings, you can place files at docker-data/dms/config/rspamd/override.d/
. Files from this directory are copied to /etc/rspamd/override.d/
during startup. These files forcibly override Rspamd and DMS default settings.
!!! question "What is the local.d
directory and how does it compare to override.d
?"
!!! warning "Clashing Overrides"
Note that when also [using the `custom-commands.conf` file](#with-the-help-of-a-custom-file), files in `override.d` may be overwritten in case you adjust them manually and with the help of the file.
With the Help of a Custom File
DMS provides the ability to do simple adjustments to Rspamd modules with the help of a single file. Just place a file called custom-commands.conf
into docker-data/dms/config/rspamd/
. If this file is present, DMS will evaluate it. The structure is simple, as each line in the file looks like this:
COMMAND ARGUMENT1 ARGUMENT2 ARGUMENT3
where COMMAND
can be:
disable-module
: disables the module with nameARGUMENT1
enable-module
: explicitly enables the module with nameARGUMENT1
set-option-for-module
: sets the value for optionARGUMENT2
toARGUMENT3
inside moduleARGUMENT1
set-option-for-controller
: set the value of optionARGUMENT1
toARGUMENT2
for the controller workerset-option-for-proxy
: set the value of optionARGUMENT1
toARGUMENT2
for the proxy workerset-common-option
: set the optionARGUMENT1
that defines basic Rspamd behavior to valueARGUMENT2
add-line
: this will add the complete line afterARGUMENT1
(with all characters) to the file/etc/rspamd/override.d/<ARGUMENT1>
!!! example "An Example Is Shown Down Below"
!!! note "File Names & Extensions"
For command 1 - 3, we append the `.conf` suffix to the module name to get the correct file name automatically. For commands 4 - 6, the file name is fixed (you don't even need to provide it). For command 7, you will need to provide the whole file name (including the suffix) yourself!
You can also have comments (the line starts with #
) and blank lines in custom-commands.conf
- they are properly handled and not evaluated.
!!! tip "Adjusting Modules This Way"
These simple commands are meant to give users the ability to _easily_ alter modules and their options. As a consequence, they are not powerful enough to enable multi-line adjustments. If you need to do something more complex, we advise to do that [manually](#manually)!
Examples & Advanced Configuration
A Very Basic Configuration
Do you want to start using Rspamd? Rspamd is disabled by default, so you need to set the following environment variables:
ENABLE_RSPAMD=1
# ClamAV is compatible with Rspamd. Optionally enable it for anti-virus support:
ENABLE_CLAMAV=1
# Rspamd replaces the functionality of all these anti-spam services, disable them:
ENABLE_OPENDKIM=0
ENABLE_OPENDMARC=0
ENABLE_POLICYD_SPF=0
ENABLE_AMAVIS=0
ENABLE_SPAMASSASSIN=0
# Provided you've set `RSPAMD_GREYLISTING=1`, also disable Postgrey:
ENABLE_POSTGREY=0
This will enable Rspamd and disable services you don't need when using Rspamd.
Adjusting and Extending The Very Basic Configuration
Rspamd is running, but you want or need to adjust it? First, create a file named custom-commands.conf
under docker-data/dms/config/rspamd
(which translates to /tmp/docker-mailserver/rspamd/
inside the container). Then add your changes:
- Say you want to be able to easily look at the frontend Rspamd provides on port 11334 (default) without the need to enter a password (maybe because you already provide authorization and authentication). You will have to adjust the controller worker:
set-option-for-controller secure_ip "0.0.0.0/0"
. - Do you additionally want to enable the auto-spam-learning for the Bayes module? No problem:
set-option-for-module classifier-bayes autolearn true
. - But the chartable module gets on your nerves? Easy:
disable-module chartable
.
??? example "What Does the Result Look Like?" Here is what the file looks like in the end:
```bash
# See 1.
# ATTENTION: this disables authentication on the website - make sure you know what you're doing!
set-option-for-controller secure_ip "0.0.0.0/0"
# See 2.
set-option-for-module classifier-bayes autolearn true
# See 3.
disable-module chartable
```
DKIM Signing
There is a dedicated section for setting up DKIM with Rspamd in our documentation.
Abusix Integration
This subsection provides information about the integration of Abusix, "a set of blocklists that work as an additional email security layer for your existing mail environment". The setup is straight-forward and well documented:
- Create an account
- Retrieve your API key
- Navigate to the "Getting Started" documentation for Rspamd and follow the steps described there
- Make sure to change
<APIKEY>
to your private API key
We recommend mounting the files directly into the container, as they are rather big and not manageable with our custom-command.conf
script. If mounted to the correct location, Rspamd will automatically pick them up.
While Abusix can be integrated into Postfix, Postscreen and a multitude of other software, we recommend integrating Abusix only into a single piece of software running in your mail server - everything else would be excessive and wasting queries. Moreover, we recommend the integration into suitable filtering software and not Postfix itself, as software like Postscreen or Rspamd can properly evaluate the return codes and other configuration.