Commit graph

185 commits

Author SHA1 Message Date
fox.cpp
178579d78a
Remove remaining references to 0.3 module names in code and docs 2020-12-13 19:47:27 +03:00
fox.cpp
d6a0324ae0
Force domains to be interpreted as FQDN where this is required by standards
This includes email addresses and EHLO in SMTP.

See #311 for details.
2020-12-12 01:31:41 +03:00
fox.cpp
cf72b11c76
Fix/silence a couple of linter warnings 2020-12-06 14:51:03 +03:00
fox.cpp
889ba39aa0
target/smtp: Do not attempt STARTTLS by default for LMTP connections
Security for LMTP should be configured using Implicit TLS that is
already supported using tls:// scheme for addresses. TLS
is also unnecessary for most LMTP use-cases (Unix sockets, etc) and
attempting STARTTLS caused issues in the past (see #309).
2020-12-06 14:15:32 +03:00
fox.cpp
e4ad3bdd5a
target/remote: Reimplement TLSA records discovery algorithm, add tests
Now it covers all edge cases described by RFC 7672.

There is an unrelated change in tests/ due to interface change in
go-mockdns.
2020-11-30 18:40:59 +03:00
fox.cpp
5995528f1c
target/remote: Reimplement DANE verification algorithm, add tests 2020-11-30 18:40:58 +03:00
fox.cpp
54132f3258
target/remote: Use AuthLookupIPAddr instead of AuthLookupHost
AuthLookupHost is just a wrapper for AuthLookupIPAddr that does
unnecessary (in this case) records conversion.
2020-11-30 18:40:58 +03:00
fox.cpp
719217a73f
target/remote: Try A/AAAA lookup before TLSA 2020-11-30 18:40:58 +03:00
fox.cpp
1351c05ea8
target/remote: Reimplement DANE-TA verification 2020-11-30 18:40:57 +03:00
fox.cpp
7fd43b7702
target/remote: Restrict TLSA selector to 0 and 1 (supported values) 2020-11-30 18:40:57 +03:00
fox.cpp
c068271c71
target/remote: Remove PKIX-TA and PKIX-EE TLSA records support
They are not required to be supported, offer marginal security and add
handling complexity.
2020-11-30 18:40:56 +03:00
fox.cpp
3c9e637bb9
config/module: Always pass the fully qualified module name to constructor
Ensures that modules using modName to change behavior (e.g.
target.smtp/target.lmtp) behave consistently irregardless of whatever
they are referenced inline ("deliver_to lmtp ...") or via named
configuration block ("deliver_to &local_mailboxes).

Closes #308.
2020-11-30 14:57:49 +03:00
fox.cpp
925b758e09
endpoint/smtp: Actually fix autobuffer function
Regressed in 1c42a70533.
It truncates messages to I/O buffer size (4096 bytes).
If first 4096 bytes cover head then it causes "unexpected EOF" (see
 #300), otherwise it silently breaks the message.
2020-11-27 21:04:17 +03:00
fox.cpp
c9060025c4
Bump go-msgauth version
See https://github.com/emersion/go-msgauth/issues/36

allow_body_subset directive for check.dkim is removed since
signatures with BodyLength are no longer supported by upstream.
2020-11-27 20:37:28 +03:00
fox.cpp
bf982ebbea
msgpipeline: Fix wrong effective_rcpt in log messages when sub-pipelines do rewriting 2020-11-21 23:03:02 +03:00
fox.cpp
cbdea9c28e
check/milter: Add missing handler for milter.ActTempFail ('t')
Closes #288.
2020-10-31 12:34:38 +03:00
fox.cpp
51ccd84011
msgpipeline: Fix log messages missing for separate (not endpoint) pipelines 2020-10-31 12:29:05 +03:00
fox.cpp
1c42a70533
endpoint/smtp: Fix handling of empty messages in auto-buffer code
Add the missing os.MkdirAll for "fs" buffer mode along the way.
And add integration tests for all that.
2020-10-24 21:23:12 +03:00
fox.cpp
83a4af4021
auth/plain_separate: Make configuration directives actually work
Woops....
2020-10-23 22:16:13 +03:00
fox.cpp
50598ea189
check/rspamd: Fix sending of message header
Closes #282.
2020-10-12 21:16:39 +03:00
fox.cpp
fe890faa09
check/milter: Make it actually usable
It was not implementing module.Check interface, making it inaccessible.
2020-10-11 16:09:45 +03:00
fox.cpp
f58da8a5a5
Remake Prometheus endpoint into a proper endpoint module 2020-08-23 15:41:52 +03:00
fox.cpp
1da80d9ac5
storage/imapsql: Fix nil pointer reference when no IMAP filters are set 2020-08-21 23:07:04 +03:00
fox.cpp
1ffceae810
Clean minor linter warnings 2020-08-03 16:43:18 +03:00
fox.cpp
665c443de6
Enable THREAD=ORDEREDSUBJECT and SORT extensions for go-imap-sql
Closes #252.
2020-07-27 16:46:50 +03:00
fox.cpp
f8caf1d188
storage/imapsql: Fix incorrect module name in log messages related to delivery errors 2020-07-24 18:21:52 +03:00
fox.cpp
7b8e13782c
check/spf: Make sure error value from library is always reported in logs 2020-07-24 18:18:18 +03:00
fox.cpp
e407ec9f94
Bump go-smtp version, update tests to expect LF in messages
Upstream change fixes \r\n\r\n being mangled into \r\n\n.
2020-07-24 15:12:04 +03:00
fox.cpp
2d18ff5a30
MIT => GPLv3; Add license/copyright notices everywhere 2020-07-22 16:12:26 +03:00
fox.cpp
04d39f2163
endpoint/imap: Add NAMESPACE extension 2020-07-22 16:06:49 +03:00
fox.cpp
6243b3067c
msgpipeline: Permit duplicate destination/source rules
This allows "the most specific match wins" semantics for
$(local_domains) rule and per-domain matching.
2020-07-18 17:42:17 +03:00
fox.cpp
e60f6fc41f
target/smtp: Fix target.lmtp using SMTP 2020-07-18 14:43:58 +03:00
fox.cpp
d6105aed26
table: Allow using regexp table without replacement specified 2020-07-18 11:30:42 +03:00
fox.cpp
e27574a9e5
storage/imapsql: Register module in delivery target namespace
Allows it to be used as "deliver_to imapsql".
2020-07-17 23:36:11 +03:00
fox.cpp
18bc68a7ac
Implement "IMAP filters"
Closes #202.
2020-07-17 23:33:59 +03:00
fox.cpp
aaf04c7511
target/remote: Remove sts_preload tests 2020-07-17 00:33:37 +03:00
fox.cpp
c02b96fdfe
target/remote: Replace STARTTLS Everywhere support with a stub
On the way to keeping a reasonable degree of compatibility, we are now
issuing at least one minor version with functionality being marked as
deprecated instead of directly removing it.

Since STARTTLS Everywhere support is broken anyway due to list being
expired - we stub out all related code and make it no-op.

In 0.5 it will be gone completely.

Closes #244.
2020-07-17 00:30:51 +03:00
fox.cpp
b8452b3575
dsn: Mangle CRLF in Diagnostic-Code input
Closes #245.
2020-07-16 12:58:16 +03:00
fox.cpp
cee8bbdce7
Migrate TLS certificate loading to use modules for sources 2020-07-15 17:58:47 +03:00
fox.cpp
6c0b947464
target/remote: Use modules system for MX authentication policies
Allow extensibility via external plugins
2020-07-15 01:31:06 +03:00
fox.cpp
1ee501ba99
Fix two typos 2020-07-15 01:31:06 +03:00
fox.cpp
bcceec4fe4
Extract several packages to form a public API 2020-07-15 01:31:06 +03:00
fox.cpp
03d9e52627
Rename modules and introduce namespace-aware module name lookups
See #248.
2020-07-15 01:31:05 +03:00
fox.cpp
4ea9f1eef7
endpoint/smtp: Hide "operation was canceled" errors for async rDNS lookup 2020-07-07 21:02:54 +03:00
fox.cpp
5f76f6c335
endpoint/smtp: Add missing msg_id for 'RCPT error' message 2020-06-24 23:52:56 +03:00
fox.cpp
cd928e9efb
Implement check module for easier integration with rspamd
This replaces old rspamc-based integration script that is inefficient
and had many disadvantages.
2020-06-24 23:52:36 +03:00
fox.cpp
071d06dbff
table: Fix use of numbered argument placeholders
go-sqlite3 does not implement them properly (in fact, the proper support
was just removed, wtf, mattn). Additionally, go-sqlite3 does not handle
$name or @name properly despite these being supported by SQLite, only
:name works.

Closes #241.
2020-06-19 14:09:48 +03:00
fox.cpp
7f7393e480
targets/remote: Implement experimental connection caching
Closes #235.
2020-06-13 21:18:20 +03:00
fox.cpp
bdce3e4c14
endpoint/smtp: Fix typo in Prometheus metric extension 2020-06-10 19:54:01 +03:00
fox.cpp
30c50b6a91
Implement SMTP REQUIRETLS support
Closes #123.
2020-06-10 19:51:08 +03:00