diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-04-28 18:32:09 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-04-28 18:32:09 +0100 |
commit | 6aa19ec1d89b5fd93c74347c74186aedde101d4c (patch) | |
tree | 90141538363f5cb533eff03f078ec681e5043671 /doc | |
parent | 7f8ab548d375051edb54fed9bafd8996f2f3fb33 (diff) | |
download | rspamd-6aa19ec1d89b5fd93c74347c74186aedde101d4c.tar.gz rspamd-6aa19ec1d89b5fd93c74347c74186aedde101d4c.zip |
Add documentation for SURBL module.
Diffstat (limited to 'doc')
-rw-r--r-- | doc/markdown/modules/fuzzy_check.md | 1 | ||||
-rw-r--r-- | doc/markdown/modules/surbl.md | 134 |
2 files changed, 135 insertions, 0 deletions
diff --git a/doc/markdown/modules/fuzzy_check.md b/doc/markdown/modules/fuzzy_check.md index b85496a5a..4f41a5c04 100644 --- a/doc/markdown/modules/fuzzy_check.md +++ b/doc/markdown/modules/fuzzy_check.md @@ -49,6 +49,7 @@ fuzzy_check { # List of additional mime types to be checked in this fuzzy mime_types = "application/pdf"; + mime_types = ["application/*", "*/octet-stream", "*"]; # Maximum global score for all maps max_score = 20.0; diff --git a/doc/markdown/modules/surbl.md b/doc/markdown/modules/surbl.md index e69de29bb..6ce883e8a 100644 --- a/doc/markdown/modules/surbl.md +++ b/doc/markdown/modules/surbl.md @@ -0,0 +1,134 @@ +# SURBL module + +This module performs scanning of URL's found in messages against a list of known +DNS lists. It can add different symbols depending on the DNS replies from a +specific DNS URL list. + +## Module configuration + +The default configuration defines several public URL lists. However, their terms +of usage normally disallows commercial or very extensive usage without purchasing +a specific sort of license. + +Nonetheless, they can be used by personal services or low volume requests free +of charge. + +~~~nginx +surbl { + # List of domains that are not checked by surbl + whitelist = "file://$CONFDIR/surbl-whitelist.inc"; + # Additional exceptions for TLD rules + exceptions = "file://$CONFDIR/2tld.inc"; + + rule { + # DNS suffix for this rule + suffix = "multi.surbl.org"; + symbol = "SURBL_MULTI"; + bits { + # List of bits ORed when reply is given + JP_SURBL_MULTI = 64; + AB_SURBL_MULTI = 32; + MW_SURBL_MULTI = 16; + PH_SURBL_MULTI = 8; + WS_SURBL_MULTI = 4; + SC_SURBL_MULTI = 2; + } + } + rule { + suffix = "multi.uribl.com"; + symbol = "URIBL_MULTI"; + bits { + URIBL_BLACK = 2; + URIBL_GREY = 4; + URIBL_RED = 8; + } + } + rule { + suffix = "uribl.rambler.ru"; + symbol = "RAMBLER_URIBL"; + } + rule { + suffix = "dbl.spamhaus.org"; + symbol = "DBL"; + # Do not check numeric URL's + options = "noip"; + } + rule { + suffix = "uribl.spameatingmonkey.net"; + symbol = "SEM_URIBL_UNKNOWN"; + bits { + SEM_URIBL = 2; + } + options = "noip"; + } + rule { + suffix = "fresh15.spameatingmonkey.net"; + symbol = "SEM_URIBL_FRESH15_UNKNOWN"; + bits { + SEM_URIBL_FRESH15 = 2; + } + options = "noip"; + } +} +~~~ + +In general, the configuration of `surbl` module is definition of DNS lists. Each +list must have suffix that defines the list itself and optionally for some lists +it is possible to specify either `bit` or `ips` sections. + +## Principles of operation + +In this section, we define how `surbl` module performs its checks. + +### TLD composition + +By default, we want to check some top level domain, however, many domains contain +two components while others can have 3 or even more components to check against the +list. By default, rspamd takes top level domain as defined in the [public suffixes](https://publicsuffix.org). +Then one more component is prepended, for example: + + sub.example.com -> [.com] -> example.com + sub.co.uk -> [.co.uk] -> sub.co.uk + +However, sometimes even more levels of domain components are required. In this case, +the `exceptions` map can be used. For example, if we want to check all subdomains of +`example.com` and `example.co.uk`, then we can define the following list: + + example.com + example.co.uk + +Here are new composition rules: + + sub.example.com -> [.example.com] -> sub.example.com + sub1.sub2.example.co.uk -> [.example.co.uk] -> sub2.example.co.uk + +### DNS composition + +SURBL module composes the DNS request of two parts: + +- TLD component as defined in the previous section; +- DNS list suffix + +For example, to form a request to multi.surbl.org, the following applied: + + example.com -> example.com.multi.surbl.com + +### Results parsing + +Normally, DNS blacklists encode reply in A record from some private network +(namely, `127.0.0.0/8`). Encoding varies from one service to another. Some lists +use bits encoding, where a single DNS list or error message is encoded as a bit +in the least significant octet of the IP address. For example, if bit 1 encodes `LISTA` +and bit 2 encodes `LISTB`, then we need to perform bitwise `OR` for each specific bit +to decode reply: + + 127.0.0.3 -> LISTA | LISTB -> both bit symbols are added + 127.0.0.2 -> LISTB only + 127.0.0.1 -> LISTA only + +This encoding can save DNS requests to query multiple lists one at a time. + +Some other lists use direct encoding of lists by some specific addresses. In this +case you should define results decoding principle in `ips` section not `bits` since +bitwise rules are not applicable to these lists. In `ips` section you explicitly +match the ip returned by a list and its meaning.
\ No newline at end of file |