Rspamd modules
Rspamd ships with a set of modules. Some modules are written in C to speed up
complex procedures, while others are written in Lua to reduce code size.
We encourage you to write new modules in Lua and add the essential
support to the Lua API itself. Lua modules are very close to
C modules in terms of performance. Lua modules, however, can be written and loaded
dynamically.
C Modules
C modules provide the core functionality of Rspamd and are statically linked to the
main Rspamd code. C modules are defined in options.inc with the filters
attribute.
The default configuration enables all C modules explicitly:
filters = "chartable,dkim,regexp,fuzzy_check";
If no filters
attribute is defined, all C modules are disabled. To understand how to
override defaults, see the FAQ here
and here.
Available C modules:
- chartable: checks character sets of text parts in messages. (Note:
“char” as in character, and “table” as in a table of character sets.)
- dkim: performs DKIM signatures checks.
- fuzzy_check: checks a message’s fuzzy hashes against public blacklists.
- regexp: a core module that deals with regular expressions, internal
functions and Lua code to filter messages.
In prior releases other C modules were enabled by default:
- spf: checks SPF records for messages processed. This C module was removed in
version 2.3 and replaced by an equivalent Lua module.
- surbl: extracts URLs from messages and check them against
public DNS black-lists to filter messages containing malicious URLs. This module was removed
in version 2.0 and replaced by the rbl module. In an upgrade to v2, the existing
configuration is automatically converted.
Lua modules
Lua modules are dynamically loaded on Rspamd startup and are reloaded on Rspamd
reconfiguration. Should you want to write a Lua module, consult the
Lua API documentation. To define a path to Lua modules there is a section
named modules
in common.conf:
modules {
path = "${PLUGINSDIR}";
fallback_path = "${SHAREDIR}/lua"; # Legacy path
try_path = "${LOCAL_CONFDIR}/plugins.d/"; # User plugins
}
If a path is a directory then Rspamd scans it for *.lua
pattern and load all
files matched.
The following Lua modules are enabled in the default configuration (but may require additional configuration to work, see notes below):
- antivirus - integrates virus scanners (requires configuration)
- arc - checks and signs ARC signatures
- asn - looks up ASN-related information
- clickhouse - pushes scan-related information to clickhouse DBMS (requires configuration)
- bayes_expiry - provides expiration of statistical tokens (requires Redis and configuration)
- dcc - performs DCC lookups to determine message bulkiness (requires configuration)
- dkim_signing - adds DKIM signatures to messages (requires configuration)
- dmarc - performs DMARC policy checks (requires Redis & configuration for reporting)
- elastic - pushes scan-related information to Elasticsearch. (requires configuration)
- emails - extract emails from a message and checks it against DNS blacklists. (requires configuration)
- force_actions - forces actions if selected symbols are detected (requires configuration)
- greylisting - allows to delay suspicious messages (requires Redis)
- history redis - stores history in Redis (requires Redis)
- ip_score - dynamically scores sender reputation (requires Redis). This module is removed since Rspamd 2.0 and replaced by reputation module. The existing configuration is automatically converted by Rspamd.
- maillist - determines the common mailing list signatures in a message.
- metadata_exporter - pushes message metadata to external systems (requires configuration)
- metric_exporter - pushes statistics to external monitoring systems (requires configuration)
- mid - selectively suppresses invalid/missing message-id rules
- milter_headers - adds/removes headers from messages (requires configuration)
- mime_types - applies some rules about mime types met in messages
- multimap - a complex module that operates with different types of maps.
- neural networks - allows to post-process messages using neural network classification. (requires Redis).
- once_received - detects messages with a single
Received
headers and performs some additional checks for such messages.
- phishing - detects messages with phished URLs.
- ratelimit - implements leaked bucket algorithm for ratelimiting (requires Redis & configuration)
- replies - checks if an incoming message is a reply for our own message (requires Redis)
- rbl - a plugin that checks messages against DNS runtime blacklists.
- reputation - a plugin that manages reputation evaluation based on various rules.
- rspamd_update - load dynamic rules and other Rspamd updates (requires configuration)
- spamassassin - load spamassassin rules (requires configuration)
- spf - perform SPF checks
- trie - uses suffix trie for extra-fast patterns lookup in messages. (requires configuration)
- whitelist - provides a flexible way to whitelist (or blacklist) messages based on SPF/DKIM/DMARC combinations
- url_redirector - dereferences redirects (requires Redis configuration)
The following modules are explicitly disabled in the default configuration, set enabled = true
in local.d/${MODULE_NAME}.conf
to enable them:
- mx_check - checks if sending domain has a connectable MX (requires Redis)
The following modules are explicitly disabled and are experimental, so you need to set enabled = true
in local.d/${MODULE_NAME}.conf
AND to set the global option enable_experimental = true
in local.d/options.inc
:
- url_reputation - assigns reputation to domains in URLs (requires Redis). Removed in Rspamd 2.0.
- url_tags - persists URL tags in Redis (requires Redis). Removed in Rspamd 2.0.
Experimental modules are not recommended for production usage!
Disabling module
To disable an entire module you can set enabled = false;
in /etc/rspamd/local.d/${MODULE_NAME}.conf