Commit graph

99 commits

Author SHA1 Message Date
fox.cpp
ef7fa210dc
Slightly improve debug logging for complex authentication pipelines 2025-02-01 19:25:16 +03:00
fox.cpp
69b434f341
tests: Allow to run maddyctl commands in integration tests 2025-01-28 23:33:37 +03:00
fox.cpp
dbc030c267
Clean-up lint warnings 2025-01-24 23:34:09 +03:00
fox.cpp
dd06ffe435
Add missing tls_client directive to ReadGlobals
See #674.
2024-01-27 16:32:45 +03:00
fox.cpp
a7001ab730
Implement auth_map and storage_map at endpoint level
This makes auth_map do what its name implies. Old auth_map in storage
module is deprecated and will be removed in the next release.
2023-03-12 13:52:04 +03:00
Michael Aldridge
86d3d89f95 internal/auth: Add native NetAuth authentication integration.
NetAuth is an easy to deploy and manage organizational source of truth
for identity and group management.  This commit adds support for maddy
to ask NetAuth about authentication using the native protocol.
2022-09-12 21:56:32 -05:00
fox.cpp
37bfe3bbd6
Merge branch 'dev' 2022-06-18 18:29:55 +03:00
ptrcnull
c9c856ffb6 Move closing the default logger after printing configuration errors 2022-04-24 21:46:30 +03:00
fox.cpp
c0eacfa0f3
Merge maddyctl and maddy executabes
Closes #432.
2022-01-07 00:37:49 +03:00
Gusted
b8d8ca6301 refactor(gofumpt): run gofumpt over the code 2021-08-10 19:33:54 +03:00
Gusted
32b75262ad refactor(ifelse): shorten logic where possible 2021-08-10 19:33:54 +03:00
fox.cpp
ef63383248
storage/blob: Implement S3-compatible storage support
Closes #304.
2021-07-15 20:34:15 +03:00
fox.cpp
e0792c2dbb
auth: Implement LDAP BindDN lookups
Currently connection management code is rather native, there is definitely a room for improvements (e.g. pooling?)

Closes #273
2021-07-14 22:08:42 +03:00
fox.cpp
93cf4f231a Integrate CertMagic ACME client with dns-01 challenge
Support for a subset of libdns providers is added.
Some are enabled by default (assuming they are popular ones). AWS and Google Cloud SDKs take up extra 10 MiB of executable size.

Only filesystem storage is supported as of now.

Closes #3.
2021-07-13 12:38:42 +03:00
fox.cpp
09393aed8f
Refactor imapsql ExternalStore to use modules
Closes #303
2021-07-11 21:42:38 +03:00
fox.cpp
5c143530ff
Merge branch 'master' into dev
# Conflicts:
#	framework/address/norm.go
#	go.mod
#	go.sum
#	internal/target/remote/security.go
2021-07-10 00:23:28 +03:00
fox.cpp
7c2afde847
check/authorize_sender: Implement MAIL FROM, From header authorization for local senders
Closes #268.
2021-07-09 22:49:21 +03:00
fox.cpp
c2099391db
Use a different set of default directories for Docker images 2021-03-07 16:54:36 +03:00
fox.cpp
f58da8a5a5
Remake Prometheus endpoint into a proper endpoint module 2020-08-23 15:41:52 +03:00
fox.cpp
2d18ff5a30
MIT => GPLv3; Add license/copyright notices everywhere 2020-07-22 16:12:26 +03:00
fox.cpp
18bc68a7ac
Implement "IMAP filters"
Closes #202.
2020-07-17 23:33:59 +03:00
fox.cpp
cee8bbdce7
Migrate TLS certificate loading to use modules for sources 2020-07-15 17:58:47 +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
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
c95da483e5
Do not use default server mux for prometheus endpoint
This might collide with future extensions to the used HTTP handlers.
2020-06-10 19:59:24 +03:00
fox.cpp
e258555592
Implement Prometheus metrics for SMTP pipeline
Closes #236.
2020-06-10 00:23:12 +03:00
fox.cpp
3f576c2bbd
Fix and improve -v flag description 2020-05-21 21:18:07 +03:00
fox.cpp
3f1a4e5868
Initial implementation of Dovecot SASL endpoint 2020-05-04 22:58:56 +03:00
fox.cpp
e06f2e201c
Implement Dovecot authentication client support 2020-05-04 22:06:38 +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
fox.cpp
47f3d2951e
Include build metadata in -v output 2020-03-13 03:28:49 +03:00
fox.cpp
e7d5418b88
storage/imapsql: Rename and clarify docs
See #212.
2020-03-05 22:04:17 +03:00
fox.cpp
1579ea10b2
Use config.Node instead of *config.Node everywhere
Closes #197.
2020-03-05 02:26:29 +03:00
fox.cpp
cdd01c8e37
Implement table-based authentication provider 2020-03-01 02:36:54 +03:00
fox.cpp
ea40a8fbc5
Implement global callbacks for "shutdown" and "reload"
This allows modules (and any other code) to implement arbitrary actions
on server shutdown and "reload". Later will be used to address issues
like #160. There are no plans to implement complete configuration
reloading, however, since it adds a lot of problems to the modules
framework and it is believed to be "not worth it" at the moment.

Closes #130.
2020-01-02 12:26:32 +03:00
fox.cpp
850ef87247
Rename 'state' and 'runtime' directives to 'state_dir' and 'runtime_dir'
maddy(1) was incorrect calling them 'statedir' and 'runtimedir'.
Name with 'dir' is preferred since it is more explicit. Use of
underscores is consistent with other directives.
2019-12-28 18:41:55 +03:00
fox.cpp
48e21f566e
Extend .debug.* flags and hide them by default
Allow to override DNS resolver address via the -debug.dnsoverride flag
and SMTP port via -debug.smtpport.

All flags are not available unless maddy is built using the 'debugflags'
tag.
2019-12-13 17:31:35 +03:00
Nick Thomas
c5c8470845 Add a requiretls check for incoming SMTP 2019-12-08 09:58:01 +00:00
fox.cpp
bf188e454f
Move most code from the repo root into subdirectories
The intention is to keep to repo root clean while the list of packages
is slowly growing.

Additionally, a bunch of small (~30 LoC) files in the repo root is
merged into a single maddy.go file, for the same reason.

Most of the internal code is moved into the internal/ directory. Go
toolchain will make it impossible to import these packages from external
applications.

Some packages are renamed and moved into the pkg/ directory in the root.
According to https://github.com/golang-standards/project-layout this is
the de-facto standard to place "library code that's ok to use by
external applications" in.

To clearly define the purpose of top-level directories, README.md files
are added to each.
2019-12-06 01:35:12 +03:00
fox.cpp
b3a09835de
Move all code from cmd/maddy into root package
Build info helpers can be reused by maddyctl.
Same goes for directory configuration.
2019-11-15 19:34:20 +03:00
fox.cpp
a78ae9f305
Fix missing storage_perdomain global directive definition 2019-11-11 22:13:48 +03:00
fox.cpp
7b08f624f0
config: Add tests for Map.AllowUnknown, rename named return values 2019-11-07 20:14:16 +03:00
fox.cpp
206a5d61db
Implement support for DNSBL lookups
Currently lacks whitelisting support and return codes filtering.
Both should be implemented in the future.
2019-11-03 12:22:24 +03:00
fox.cpp
6620282912
Implement SPF policy enforcement
apply_spf module implements recommendation from DMARC RFC to not
reject messages based on only SPF policy if DMARC policy is present.

Closes #91.
2019-10-29 23:15:59 +03:00
fox.cpp
beef9e2455
Implement DKIM signing support
This support is based on github.com/foxcpp/go-msgauth fork until
emerison/go-msgauth#13 gets merged.

Further extensions are required to make sure only messages we can
actually "take responsibility for" are signed.

RSA-2048 is used as a default algorithm when generating new keys.
RSA-4096 can cause trouble with UDP-only DNS due to responses being
bigger than 512 octets. RSA-1024 is too weak and explicitly
disallowed in maddy for new keys. It could be possible to use Ed25519
but support is not widely deployed yet (according to warning in rspamd
docs dated 2019-09). Users concerned about security of RSA-2048 can
switch to RSA-4096 or Ed25519, keeping relevant problems in mind.

Ed25519 key format uses PKCS#8, this seems to be different from other
implementations that just dump key material into a file without any
wrapping. Interoperability is not considered to encourage key
rotation when migration, which is a good thing to do anyway.

There is no option to use "body limit", since it is dangerous
and go-msgauth/dkim does not support it for signing.

The default set of signed header fields is the list used by rspamd.
Most "core" fields are oversigned to provide strict integrity.
"Conditional oversigning" similar to rspamd is not implemented, though
it may be useful, further research is required.

Multi-tentant configuration with DKIM and DMARC is much more verbose,
configuration example is added to config.d/multitentant-dkim.conf to
explain how to make it work.
2019-10-27 20:40:38 +03:00
fox.cpp
ad13d026ec
Make endpoint modules special
To support unusual configuration syntax, endpoint modules (imap, smtp,
etc) relied on rather awkward code using modName+instName+aliases as
arguments. This commit replaces old handling with use of special
signature similar to inlineArgs introduced in 1edd031.

Endpoint modules are placed in a separate 'registry' and use
different initialization callback signature for simplicity. This makes
them inaccessible for other modules, though they are not supposed to be
anyway.

Endpoint modules are initialized before other modules. This allows
detecting unused configuration blocks by checking for modules
that were not lazily initalized after endpoint initialization.
This relies on endpoint modules being essentially "roots" of
instances dependency tree.

Idea of "semantical module names" is completely dropped now and so
HACKING.md is updated to not mention it.
2019-10-26 21:28:07 +03:00
fox.cpp
97b370191d
Make maddy buildable with GOOS=windows
Some people want to do so (#83) and it is not a big trouble
for us to support it.
2019-10-26 19:58:47 +03:00
fox.cpp
0590d5ac3c
smtp_upstream -> smtp_downstream
Terminology is confusing.
2019-10-24 03:42:35 +03:00