summaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeFilesLines
* Release 1.1.01.1.0Vsevolod Stakhov2016-01-182-1/+119
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Incompatible change: sqlite3 and per_user behaviour: Now both redis and sqlite3 follows the common principles for per-user statistics: 1) If per-user statistics is enabled check per-user tokens ONLY 2) If per-user statistics is not enabled then check common tokens ONLY If you need old behaviour, then you'd need to use separate classifier for per-user statistics. * Implement redis statistics backend and cache * Implement autolearning for statistics * Reworked statistics architecture from scratch * Add hyperscan (https://github.com/01org/hyperscan) engine for regular expressions: - add lazy loader for hyperscan databases - rework regexp cache to have joint pcre/hyperscan scanning - implement hyperscan pre-filter support - add compilation guards for bad expressions - implement `rspamadm control recompile` command - implement hyperscan cache monitoring - slides: <https://highsecure.ru/rspamd-hyperscan.pdf> * Implement flexible task logging * Rework fuzzy worker: - it is now possible to run multiple fuzzy workers; - implement lazy writing as sqlite3 is bad at concurrent writing; - add retries for simple sql commands in fuzzy backend; - use fine-grained transactions for fuzzy; - implement new multi-pubkeys mode; - allow encrypted only storages; - rework statistics for fuzzy; - add `rspamadm control fuzzystat` command for extended statistics; - implement human readable output for the previous command; - add condition script for learning fuzzy storage; * Various fixes to SPF: - fix `redirect` records; - fix domains when parsing mx/ptr/a records in includes/redirects; - fix issues with multiple addresses in SPF records; - ignore SPF results in case of DNS failure; - adjust TTL of records when resolving subelements of SPF records; - always select `v=spf1` line if it is available - do not cache records with DNS failure in subrequests; - ignore records with temporary fails during subrequests resolving; - fix `RDNS_RC_NOREC` support; * Add clang plugin for static analysis: - implement static checks for `rspamd_printf` format strings; * Add 'allow_raw_input' option for non-mime messages * Recognize types using libmagic * Fix parsing of IPv6 received headers * Add new interface of communication between workers in rspamd * Add support for named socketpairs * Don't write URLs by default as it is too verbose * Set status for HTTP replies * Try load `rspamd.conf.override` * Implement words decaying for text parts to limit many checks * Improve support of SA rules and plugins: - add check_for_shifted_date and check_for_missing_to_header eval rules; - add 'check_relays_unparseable' support; - add `check_for_mime('mime_attachement')` function; - use new re_cache interface for all SA rules; - add support for `Mail::SpamAssassin::Plugin::MIMEHeader`; - add support of 'special' SA headers to `exists` function; - fix issue when SA metas contain other metas; - fix freemail rules; * Many fixes to the URL parser * Match any newline character in regexps * Fix resolving of upstreams and detection of poor IPv6 configurations * Parse upstreams selection algorithm from the configuration line * Add `reresolve` command to the control interface * Generate fuzzy hashes from task metadata (URLs and headers) * Add method to check if IP is local and `local_addrs` option * Implement forced timeout for delayed filters * Disable fast path of pcre-jit as it seems to be broken * Bayes fixes: - new normalizer function; - really use weights of tokens from the OSB algorithm; - restore multiple classifiers support; * Rules changes: - add `R_SUSPICIOUS_URL` rule that detects obfuscated URL's; - improve empty image rule; - rework `FORGED_RECIPIENTS` rule; - reduce weight of `SUSPICIOUS_RECIPS`; - fix `*_NORESOLVE_MX` symbols in hfilter; - add `SUBJ_ALL_CAPS` rule with support of UTF8 - add spamhaus SBL to uribl - fix `SUSPICIOUS_RECIPS` and `SORTED_RECIPS` rules - remove `R_TO_SEEMS_AUTO` as it generates a lot of FP; - add new Message-ID regexp for Thunderbird (by @moisseev); * Plugins changes: - allow ratelimit plugin to set symbol instead of pre-result - support IP DNS black lists for URIBL (e.g spamhaus SBL); - drop deprecated SURBL bits (by @fatalbanana) - rename `JP_SURBL_MULTI` to `ABUSE_SURBL` (by @fatalbanana) - add `SURBL_BLOCKED` (by @fatalbanana) - add `CR_SURBL` - SURBL: allow fallthrough to default symbol (by @fatalbanana) - Settings: fix IP match (by @fatalbanana) - SURBL: add missing symbols to metric (by @fatalbanana) - allow processing images urls for SURBL - unconditionally disable SPF for authenticated users and local networks * Rework ratelimit plugin - switch to `rates` instead of old and stupid strings to setup; - check if a bucket is zero and disable the corresponding limits' - turn off all buckets by default; - check either `rcpt` or `user` buckets, not all together' - document new `rates` and `symbol` options; - inform user about what buckets are used in the configuration; * Add neural network **experimental** plugin * Add a sample script to learn neural network from rspamd logs * Add documentation strings support to rspamd: - add strings for the main configuration options; - document workers options; - add internal plugin options; - create `rspamadm confighelp` routine; - implement human readable output for the previous command; - add subtree search support; - add keyword search support; * Documentation improvements, tutorials section, statistics description * Many other minor and major bugfixes not noted here Signed-off-by: Vsevolod Stakhov <vsevolod@highsecure.ru>
* Fix an awful memory leakVsevolod Stakhov2016-01-181-6/+18
|
* Small improvement of loggingVsevolod Stakhov2016-01-181-1/+1
|
* Rework hyperscan notifies to reduce noise levelVsevolod Stakhov2016-01-186-23/+62
|
* Disable fast path of pcre as it seems to be brokenVsevolod Stakhov2016-01-181-4/+10
|
* Do not treat unknown worker type as fatal errorVsevolod Stakhov2016-01-171-6/+2
|
* Further reduction of spf noiseVsevolod Stakhov2016-01-171-2/+2
|
* Reduce noise level for certain recordsVsevolod Stakhov2016-01-171-2/+2
|
* RDNS_RC_NOREC is equal for NXDOMAIN in case of SPF checksVsevolod Stakhov2016-01-171-1/+1
|
* '>' and '<' are not domain safe symbolsVsevolod Stakhov2016-01-171-2/+2
|
* Don't treat all but include/redirect errors as tempfailVsevolod Stakhov2016-01-171-1/+2
|
* MisprintVsevolod Stakhov2016-01-161-1/+1
|
* Check if we have some reply before retransmitVsevolod Stakhov2016-01-161-24/+24
|
* Set status for HTTP repliesVsevolod Stakhov2016-01-161-0/+2
|
* Don't write URLs by default as it is too verboseVsevolod Stakhov2016-01-161-7/+10
|
* Fix stupid misprintVsevolod Stakhov2016-01-162-6/+6
|
* Fix memory leakVsevolod Stakhov2016-01-161-8/+11
|
* Some fixes to the default configurationVsevolod Stakhov2016-01-164-5/+10
|
* Fix redis cache config as wellVsevolod Stakhov2016-01-161-17/+28
|
* Also try rspamd.conf.overrideVsevolod Stakhov2016-01-161-0/+1
|
* Simplify redis backend configurationVsevolod Stakhov2016-01-161-15/+26
|
* Fix crashVsevolod Stakhov2016-01-161-3/+1
|
* Fix default paths for the source buildVsevolod Stakhov2016-01-161-3/+3
|
* Unify processing of includes/redirects in SPFVsevolod Stakhov2016-01-151-34/+38
| | | | | Issue: #483 Reported by: @dnl555
* Ignore SPF results in case of DNS failureVsevolod Stakhov2016-01-153-6/+28
|
* Fix bad memory access.Vsevolod Stakhov2016-01-151-2/+2
|
* Fix memory leakVsevolod Stakhov2016-01-151-0/+7
|
* Fix orderVsevolod Stakhov2016-01-151-3/+3
|
* Add workaround for bug in valgrind and rdrandVsevolod Stakhov2016-01-152-1/+6
|
* Fix warnings.Vsevolod Stakhov2016-01-1516-49/+32
|
* Fix weight processingVsevolod Stakhov2016-01-151-1/+1
|
* Fix suffix/bits less URL BLsVsevolod Stakhov2016-01-151-1/+2
|
* Fix prototype.Vsevolod Stakhov2016-01-151-1/+1
|
* Do not free HS database after deserializationVsevolod Stakhov2016-01-151-12/+14
|
* Fix a huge memory leak in hyperscanVsevolod Stakhov2016-01-151-0/+15
|
* Fix a stupid error in symbols groups parsingVsevolod Stakhov2016-01-151-1/+1
| | | | | Issue: #482 Reported by: @rafaelabdo
* Improve unknown results report for surblVsevolod Stakhov2016-01-151-10/+21
|
* Fix format argument for inserting shinglesVsevolod Stakhov2016-01-141-1/+3
| | | | Issue: #478
* Remove events when 0 or error are returnedVsevolod Stakhov2016-01-141-1/+10
|
* Enable redis conditional missed somehowVsevolod Stakhov2016-01-141-0/+1
|
* Fix potential misuse of unionsVsevolod Stakhov2016-01-141-11/+32
| | | | | Issue: #478 Reported by: @moisseev
* Add periodic checks for hyperscan filesVsevolod Stakhov2016-01-141-1/+41
|
* Another fix to always-malloc modeVsevolod Stakhov2016-01-141-1/+1
|
* Fix issues with freeing of bad rdns requestsVsevolod Stakhov2016-01-142-5/+10
|
* Fix format stringVsevolod Stakhov2016-01-141-1/+1
|
* Fix issues with debug mode of mempoolVsevolod Stakhov2016-01-142-4/+20
|
* Allow processing images urls for SURBLVsevolod Stakhov2016-01-145-39/+150
|
* Allow configurations with no classifiersVsevolod Stakhov2016-01-141-2/+10
|
* Fix percentages for bayes confidenceVsevolod Stakhov2016-01-141-1/+5
|
* Do not treat bad backend as an assertVsevolod Stakhov2016-01-131-1/+7
|