Commit graph

70 commits

Author SHA1 Message Date
fox.cpp
3f8fdd38ea
check/spf: Change default action for softfail to 'ignore'
See #351.

https://serverfault.com/questions/933705/spf-fail-vs-soft-fail-pros-and-cons
2021-04-30 23:56:06 +03:00
Sergey Kislyakov
580a171886 Fix a typo in maddy-smtp man doc 2021-03-23 00:15:41 +03:00
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
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
c27c8aefe8
docs: Update a number of snippets using outdated module names
Closes #312.
2020-12-06 02:49:02 +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
f58da8a5a5
Remake Prometheus endpoint into a proper endpoint module 2020-08-23 15:41:52 +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
d6105aed26
table: Allow using regexp table without replacement specified 2020-07-18 11:30:42 +03:00
fox.cpp
18bc68a7ac
Implement "IMAP filters"
Closes #202.
2020-07-17 23:33:59 +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
cee8bbdce7
Migrate TLS certificate loading to use modules for sources 2020-07-15 17:58:47 +03:00
fox.cpp
7d497f88f0
docs: Split maddy(1) and maddy(5)
maddy(1) is supported to contain only command line syntax.
2020-07-15 01:31:05 +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
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
30c50b6a91
Implement SMTP REQUIRETLS support
Closes #123.
2020-06-10 19:51:08 +03:00
fox.cpp
2a19d455f3
docs: Fix wrong name of 'targets' directive for smtp_downstream 2020-06-03 14:02:58 +03:00
fox.cpp
e9a4180931
docs: Mention per-source domain limiting option 2020-06-01 01:05:23 +03:00
fox.cpp
c83a2f09dc
docs: Fix a number of links in documentation
Remove link to CONTRIBUTING.md from README.md since it is included
in documentation build and results in broken link since CONTRIBUTING.md
is not included. It does not seem to be possible to include files from
parent directories and symlinks do not work.

Fix man page link in seclevels.md.

Add missing maddy-tables(5) link in maddy(1) "See Also".

Closes #223.
2020-05-31 19:07:40 +03:00
wjywbs
c897d26463
modify/dkim: Allow to sign emails from subdomains using a top domain key
Ref. #228.
Co-authored-by: Max Mazurov <fox.cpp@disroot.org>
2020-05-28 20:42:28 +00:00
Jingyi Wei
c7bdb3d446 add docs 2020-05-28 20:30:03 +00:00
fox.cpp
bf612cb865
storage/imapsql: Implement module.Table interface 2020-05-23 02:55:45 +03:00
fox.cpp
980da86939
target/smtp_downstream: Implement lmtp_downstream module
Closes #205.
2020-05-09 01:00:41 +03:00
fox.cpp
e3da7f3a89
Update refernecs to file table module
It is named just 'file' now.
2020-05-04 23:00:20 +03:00
fox.cpp
e06f2e201c
Implement Dovecot authentication client support 2020-05-04 22:06:38 +03:00
fox.cpp
503b558643
msgpipeline: Implement source_in, destination_in
Closes #138.
2020-05-04 15:25:47 +03:00
fox.cpp
43e980c80f
Implement module.Table for most authentication modules
This allows modules to be used as a table to check account existence.

auth/pass_table: Implement module.Table interface
auth/shadow: Implement module.Table interface
auth/plain_separate: Implement module.Table interface
2020-05-04 12:41:25 +03:00
fox.cpp
d0e7df023c
Preliminary milter client implementation
Based on github.com/foxcpp/go-milter fork
2020-05-03 20:20:35 +03:00
fox.cpp
e19d21dfcb
Fully separate authentication from IMAP access
Now imapsql module does not handle authentication. (it was not doing it so well
anyway)

sql_table module was introduced and used in the default configuration as
a replacement for functionality that was implemented by imapsql before.

Parts of maddyctl code were rewritten to make it work transparently with
any IMAP backend or credentials store.

Closes #212.
2020-04-14 00:06:47 +03:00
bn4t
2f618e5c33 Fix small typo 2020-04-12 13:25:15 +00:00
fox.cpp
47f3d2951e
Include build metadata in -v output 2020-03-13 03:28:49 +03:00
fox.cpp
9915c8a881
modify/dkim: Support mulitple ADMDs per module instance
Allows to use macro expansion like $(local_domains) to configure DKIM
for all domains.

Closes #199.
2020-03-13 03:28:49 +03:00
fox.cpp
aa1804c66d
table: Merge 'replace_sender', 'replace_rcpt' into 'alias'
With 'regexp' and 'static' tables, separate implementations in replace_*
are not necessary.
2020-03-06 04:21:55 +03:00
fox.cpp
a5288aa27a
table: Add identity, static and regexp table modules 2020-03-06 02:28:31 +03:00
fox.cpp
e7d5418b88
storage/imapsql: Rename and clarify docs
See #212.
2020-03-05 22:04:17 +03:00
fox.cpp
9b279735e8
Address several TODO comments
Several comments were removed since they are not worth the trouble.
A few minor issues were addressed.
Most of remaining comments got corresponding GitHub issues assigned.
2020-03-05 02:26:30 +03:00
fox.cpp
2e8216067a
Fix references to alias_table in docs and default config 2020-03-01 02:43:35 +03:00
fox.cpp
cdd01c8e37
Implement table-based authentication provider 2020-03-01 02:36:54 +03:00
fox.cpp
42fc92cf67
docs: Fix-up indent in maddy-auth(5) 2020-02-29 22:42:57 +03:00
fox.cpp
ae36536d93
table: Implement SQL query-based table
Closes #82.
2020-02-29 19:23:28 +03:00
fox.cpp
bdd243668b
modify: Refactor alias_file to use generic Table for lookups
*Breaking change for configuration syntax*
2020-02-28 02:11:16 +03:00
fox.cpp
55a91a37b7
Revert authorization/authentication split
Authentication provider module is responsible only for authentication.
Nothing more. Access control (authorization) should be kept separate.
2020-02-28 01:38:40 +03:00
fox.cpp
3092ca0ca5
Lift restrictions on authentication credentials in shadow/pam modules
With new authorization/authentication identities split, it is possible
to have non-email authentication identity while using email authorization
identity.
2020-02-28 00:31:34 +03:00
fox.cpp
744dd3e10d
Implement separate lookups for username and password in authentication
Closes #56.
2020-02-28 00:29:41 +03:00
fox.cpp
fdb6d0493d
Remove "in early development" disclaimers 2020-02-23 04:29:45 +03:00
fox.cpp
44ba1f13c3
docs: Fix-up f55914372: Add missing escape for * 2020-02-17 17:42:32 +03:00
fox.cpp
f559143728
target/queue: Increase the amount of tries, decrease delay scale factor
This makes server more aggressive in retrying delivery. The total
attempts time is approximately the same (around 5 days).

Notably, the increased amount of attempts is needed to handle large
recipient lists where the remote server sometimes rejects subset of them
with "Too Many Recipients" code.

See #149.
2020-02-16 19:56:57 +03:00
fox.cpp
5bf8cb9f03
endpoint/smtp: Limit amount of Received header fields
Closes #79.
2020-02-16 01:31:47 +03:00