]> git.ipfire.org Git - thirdparty/dovecot/core.git/log
thirdparty/dovecot/core.git
4 years agoNEWS: fix 2.3.14 version
Aki Tuomi [Wed, 21 Apr 2021 07:01:46 +0000 (10:01 +0300)] 
NEWS: fix 2.3.14 version

4 years agoNEWS: Mention XZ/LZMA removal.
Aki Tuomi [Thu, 4 Mar 2021 07:52:40 +0000 (09:52 +0200)] 
NEWS: Mention XZ/LZMA removal.

4 years agoNEWS: Update news for 2.3.14
Aki Tuomi [Tue, 2 Mar 2021 08:55:53 +0000 (10:55 +0200)] 
NEWS: Update news for 2.3.14

4 years agolib-imap: imap_bodystructure_write() - Return error on corruption instead of assert...
Timo Sirainen [Thu, 1 Apr 2021 17:39:27 +0000 (20:39 +0300)] 
lib-imap: imap_bodystructure_write() - Return error on corruption instead of assert-crash

This could happen if broken message_parts came from cache and
message_part->data was newly read from the mail input.

4 years agolib-storage: Split off index_mail_parse_bodystructure_full()
Timo Sirainen [Thu, 8 Apr 2021 12:04:42 +0000 (15:04 +0300)] 
lib-storage: Split off index_mail_parse_bodystructure_full()

4 years agolib-imap: fuzz-imap-bodystructure - Change failures to i_panic() instead of i_fatal()
Timo Sirainen [Fri, 9 Apr 2021 11:09:17 +0000 (14:09 +0300)] 
lib-imap: fuzz-imap-bodystructure - Change failures to i_panic() instead of i_fatal()

4 years agolib-smtp: smtp-params - Make explicit which extra parameters can be written by smtp_p...
Stephan Bosch [Tue, 30 Mar 2021 19:12:41 +0000 (21:12 +0200)] 
lib-smtp: smtp-params - Make explicit which extra parameters can be written by smtp_params_*_write().

This can be used to prevent sending unsupported parameters to the remote server,
even when these are listed in extra_parameters. Before, blindly proxying
parameters would cause MAIL/RCPT error replies from the remote server.

4 years agolib-smtp: smtp-client-connection - Explicitly specify which MAIL/RCPT parameters...
Stephan Bosch [Tue, 30 Mar 2021 19:06:58 +0000 (21:06 +0200)] 
lib-smtp: smtp-client-connection - Explicitly specify which MAIL/RCPT parameters are added by extra capabilities.

This is used in later commit to limit which custom parameters are actually sent
to the server based on the capabilities supported by said server.

4 years agolib-smtp: smtp-client-connection - Prevent recording extra capabilities from server...
Stephan Bosch [Tue, 30 Mar 2021 19:48:24 +0000 (21:48 +0200)] 
lib-smtp: smtp-client-connection - Prevent recording extra capabilities from server more than once.

4 years agolib-smtp: smtp-client-connection - Prevent duplicate registrations for extra capabili...
Stephan Bosch [Tue, 30 Mar 2021 19:45:33 +0000 (21:45 +0200)] 
lib-smtp: smtp-client-connection - Prevent duplicate registrations for extra capabilities.

4 years agolib-smtp: smtp-client-connection - Move smtp_client_connection_find_extra_capability().
Stephan Bosch [Wed, 31 Mar 2021 10:33:38 +0000 (12:33 +0200)] 
lib-smtp: smtp-client-connection - Move smtp_client_connection_find_extra_capability().

4 years agolib-smtp: smtp-client-connection - Change extra capability registration to use a...
Stephan Bosch [Tue, 30 Mar 2021 19:33:17 +0000 (21:33 +0200)] 
lib-smtp: smtp-client-connection - Change extra capability registration to use a struct.

This is needed for adding additional features in later commit.

4 years agolib-smtp: smtp-client-connection - Fix typo in function name.
Stephan Bosch [Tue, 30 Mar 2021 19:41:48 +0000 (21:41 +0200)] 
lib-smtp: smtp-client-connection - Fix typo in function name.

4 years agolmtp: lmtp-commands - Drop XRCPTFORWARD parameter once processed.
Stephan Bosch [Tue, 30 Mar 2021 22:06:29 +0000 (00:06 +0200)] 
lmtp: lmtp-commands - Drop XRCPTFORWARD parameter once processed.

This prevents it from popping up elsewhere. This for example crudely fixes a
problem in the proxy where XRCPTFORWARD was sent even without backend server support.

4 years agoimap: NOTIFY - Fix crash if client disconnects while sending FETCH notification ...
Timo Sirainen [Mon, 19 Apr 2021 09:46:44 +0000 (12:46 +0300)] 
imap: NOTIFY - Fix crash if client disconnects while sending FETCH notification (try #2)

Continues the incomplete fix for c4f4058d16096f23eea0b3182205d6653f5954dd

Fixes:
Panic: Trying to close mailbox INBOX with open transactions

4 years agolib-oauth2: test-oauth2-jwt - Fix linkage for openssl
Aki Tuomi [Wed, 14 Apr 2021 16:17:30 +0000 (19:17 +0300)] 
lib-oauth2: test-oauth2-jwt - Fix linkage for openssl

Without whole archive option ssl_iostream_unref isn't
included in linkage, which will prevent libdcrypt from
loading openssl backend.

4 years agolib-oauth2: Ensure azp is escaped too
Aki Tuomi [Thu, 19 Nov 2020 17:55:42 +0000 (19:55 +0200)] 
lib-oauth2: Ensure azp is escaped too

4 years agolib-oauth2: Add test for token escape
Aki Tuomi [Wed, 14 Apr 2021 10:47:16 +0000 (13:47 +0300)] 
lib-oauth2: Add test for token escape

4 years agolib-oauth2: Improve identifier escaping function
Aki Tuomi [Wed, 14 Apr 2021 11:12:16 +0000 (14:12 +0300)] 
lib-oauth2: Improve identifier escaping function

4 years agolib-oauth2: Move identifier escaping to own function
Aki Tuomi [Sat, 10 Apr 2021 14:54:45 +0000 (17:54 +0300)] 
lib-oauth2: Move identifier escaping to own function

4 years agologin-common: Fix memory leak if anvil query is aborted
Timo Sirainen [Fri, 16 Apr 2021 13:13:39 +0000 (16:13 +0300)] 
login-common: Fix memory leak if anvil query is aborted

4 years agovirtual: virtual-mail - Use index_mail_set_seq to ensure cleanup
Aki Tuomi [Fri, 16 Apr 2021 08:18:15 +0000 (11:18 +0300)] 
virtual: virtual-mail - Use index_mail_set_seq to ensure cleanup

Forgotten in 67ab2070cf513179382b564871f2a0f177987cc9

4 years agovirtual: virtual-mail - Pass wanted_headers and wanted_fields to backend mails only
Aki Tuomi [Fri, 16 Apr 2021 08:16:36 +0000 (11:16 +0300)] 
virtual: virtual-mail - Pass wanted_headers and wanted_fields to backend mails only

Broken in 67ab2070cf513179382b564871f2a0f177987cc9

4 years agovirtual: virtual-mail - Use index_mail_free
Aki Tuomi [Fri, 16 Apr 2021 07:01:45 +0000 (10:01 +0300)] 
virtual: virtual-mail - Use index_mail_free

Since we are using index_mail_init, we need to use index_mail_free
to free up the virtual mail.

4 years agovirtual: virtual-mail - Free wanted headers in close if we are freeing
Aki Tuomi [Fri, 16 Apr 2021 07:24:22 +0000 (10:24 +0300)] 
virtual: virtual-mail - Free wanted headers in close if we are freeing

Simplifies next change

4 years agovirtual: virtual-mail - Free up mails in virtual_mail_close if we are freeing up
Aki Tuomi [Fri, 16 Apr 2021 07:03:33 +0000 (10:03 +0300)] 
virtual: virtual-mail - Free up mails in virtual_mail_close if we are freeing up

Makes next change easier

4 years agolib: Add comment to CALLBACK_TYPECHECK() macro
Timo Sirainen [Wed, 14 Apr 2021 15:08:03 +0000 (18:08 +0300)] 
lib: Add comment to CALLBACK_TYPECHECK() macro

4 years agolib-index: Add "mail_cache_lookup" event
Siavash Tavakoli [Wed, 31 Mar 2021 02:08:26 +0000 (03:08 +0100)] 
lib-index: Add "mail_cache_lookup" event

Adds new event for cache lookups with lookup name as "field" event field.

4 years agolib-index: Small refactor in mail_cache_lookup_field()
Siavash Tavakoli [Wed, 31 Mar 2021 16:28:46 +0000 (17:28 +0100)] 
lib-index: Small refactor in mail_cache_lookup_field()

Makes it easier to emit event in next commit regardless of code path.

4 years agolib-storage: Add "mail_expunged" event
Siavash Tavakoli [Mon, 29 Mar 2021 23:37:59 +0000 (00:37 +0100)] 
lib-storage: Add "mail_expunged" event

Emitted when a message is actually expunged. Has UID as a field.

4 years agolib-storage, plugins/virtual: Use mail_sync_notify()
Siavash Tavakoli [Mon, 29 Mar 2021 12:41:55 +0000 (13:41 +0100)] 
lib-storage, plugins/virtual: Use mail_sync_notify()

Instead of calling sync_notify vfunc directly.

4 years agolib-storage: Add mailbox_sync_notify()
Siavash Tavakoli [Mon, 29 Mar 2021 12:41:32 +0000 (13:41 +0100)] 
lib-storage: Add mailbox_sync_notify()

Instead of calling sync_notify vfunc directly everywhere.

4 years agolib-storage: Emit "mail_expunge_requested" event
Siavash Tavakoli [Mon, 29 Mar 2021 12:01:40 +0000 (13:01 +0100)] 
lib-storage: Emit "mail_expunge_requested" event

Adds a new event, "mail_expunge_requested" which is emitted when a
message is marked to being expunged.

4 years agolib-storage: Emit "mail_opened" event when mails opened
Aki Tuomi [Wed, 10 Feb 2021 11:57:08 +0000 (13:57 +0200)] 
lib-storage: Emit "mail_opened" event when mails opened

Adds a new event, "mail_opened" with "reason" as field. Also drop duplicate
event in index_mail_init_stream().

4 years agolib-storage: Include "age_days" field in mail.event
Siavash Tavakoli [Mon, 5 Apr 2021 23:38:06 +0000 (00:38 +0100)] 
lib-storage: Include "age_days" field in mail.event

Goes back one week, if mail age information is known, an integer field is added
with value of mail age in number of days.

4 years agoplugins/virtual: Use index_mail_init() to initialize the mail
Siavash Tavakoli [Wed, 31 Mar 2021 15:08:06 +0000 (16:08 +0100)] 
plugins/virtual: Use index_mail_init() to initialize the mail

Cleans up duplicated code. Also, index_mail_init initializes mail.event
as well. Something that was missing previously.

4 years agolib-storage: Refactor index_mail_init() to make it more reusable
Siavash Tavakoli [Wed, 31 Mar 2021 15:01:02 +0000 (16:01 +0100)] 
lib-storage: Refactor index_mail_init() to make it more reusable

Adds arguments for two memory pools, to be set for mail.pool and
mail.data_pool. If data_pool is NULL, a pool is allocated but mail_pool
is required.

4 years agolib-storage: Recreate mail.event when active mail is changed
Timo Sirainen [Thu, 11 Mar 2021 12:14:53 +0000 (14:14 +0200)] 
lib-storage: Recreate mail.event when active mail is changed

This makes sure that the two mails' events are treated completely
independently without any accidental spilling. It also prevents wasting
memory if each mail changes the event and grows the memory pool.

4 years agolib-smtp: fuzz-smtp-server - Implement all callbacks required for full transaction.
Stephan Bosch [Mon, 12 Apr 2021 19:18:05 +0000 (21:18 +0200)] 
lib-smtp: fuzz-smtp-server - Implement all callbacks required for full transaction.

Before required RCPT and DATA callbacks were omitted, causing assertion failures
when the fuzzer reached the RCPT stage.

4 years agolib-test: fuzzer - Fix FD-based fuzzing to only shutdown input FD upon end of data.
Stephan Bosch [Mon, 12 Apr 2021 19:14:07 +0000 (21:14 +0200)] 
lib-test: fuzzer - Fix FD-based fuzzing to only shutdown input FD upon end of data.

Before, it closed the whole socket once the data input ended. This for
example caused the SMTP server fuzzer to end before all replies were sent. This
shortened the test and could have hidden bugs that occur later in the SMTP
transaction.

4 years agolib-smtp: smtp-reply - Add debug message for reply send error.
Stephan Bosch [Mon, 12 Apr 2021 19:12:27 +0000 (21:12 +0200)] 
lib-smtp: smtp-reply - Add debug message for reply send error.

This makes it a little clearer at what point the connection loss or error was
noticed and for which command/reply.

4 years agolib-lua: Fix compiler warning with dlua_pcall_yieldable()
Timo Sirainen [Wed, 14 Apr 2021 08:57:39 +0000 (11:57 +0300)] 
lib-lua: Fix compiler warning with dlua_pcall_yieldable()

4 years agolib-storage: Make sure listescape can work correctly with shared namespaces
Markus Valentin [Fri, 9 Apr 2021 09:35:05 +0000 (11:35 +0200)] 
lib-storage: Make sure listescape can work correctly with shared namespaces

This makes sure that if storage_name_escape_char is set, shared mailboxes
do not return the invalid/unescaped mailbox storage_name internally which
could result in failures like "Invalid mailbox name: Name must not have '/'
character" even when using the listescape plugin.

Broken by 5fd5ad3a2be6708e81f8dcfcbb06a3957dddd276

4 years agolib: Fix buffer_t aliasing problems with LTO
Timo Sirainen [Thu, 1 Apr 2021 18:42:02 +0000 (21:42 +0300)] 
lib: Fix buffer_t aliasing problems with LTO

This changes the buffer_t slightly, which requires adding extra braces
when buffer_t contents are directly defined.

This changes Dovecot to require C11 compatible compiler, because it uses
anonymous union and struct. GNU99 extensions are also enough.

4 years agolib: buffer - Change real_buffer.r_buffer type to const void *
Timo Sirainen [Thu, 1 Apr 2021 18:37:27 +0000 (21:37 +0300)] 
lib: buffer - Change real_buffer.r_buffer type to const void *

4 years agoimap: Fix accessing uninitialized variable warning with LTO
Timo Sirainen [Thu, 1 Apr 2021 09:47:15 +0000 (12:47 +0300)] 
imap: Fix accessing uninitialized variable warning with LTO

There doesn't seem to be any other way to quiet this warning, although
it's wrong.

4 years agodoveadm dict: Handle missing parameters without crashing
Timo Sirainen [Thu, 1 Apr 2021 09:45:39 +0000 (12:45 +0300)] 
doveadm dict: Handle missing parameters without crashing

4 years agoglobal: Fix accessing uninitialized variables on unit test failures
Timo Sirainen [Thu, 1 Apr 2021 09:20:46 +0000 (12:20 +0300)] 
global: Fix accessing uninitialized variables on unit test failures

4 years agolib-imap: imap_envelope_parse() - Refactor to avoid LTO warnings
Timo Sirainen [Thu, 1 Apr 2021 09:33:33 +0000 (12:33 +0300)] 
lib-imap: imap_envelope_parse() - Refactor to avoid LTO warnings

The original code was correct, but gcc with LTO still gave warnings about
potentially uninitialized envlp_r and error_r.

4 years agolib: test-array - Fix LTO compiler warnings
Timo Sirainen [Thu, 1 Apr 2021 09:22:37 +0000 (12:22 +0300)] 
lib: test-array - Fix LTO compiler warnings

-flto correctly realizes that the source buffer size is 1, while memcpy() is
trying to copy UINT_MAX. Try to hide this by allocating the source buffer
dynamically. The intention is to assert-crash anyway before the memcpy() is
reached.

4 years agolib-compression: ostream-zstd - Do not return 0 as default
Aki Tuomi [Tue, 13 Apr 2021 09:45:45 +0000 (12:45 +0300)] 
lib-compression: ostream-zstd - Do not return 0 as default

This is accepted by the library but does complicate things with dovecot.

4 years agolib-compression: ostream-zstd - Fix assert on value range
Aki Tuomi [Tue, 13 Apr 2021 09:45:23 +0000 (12:45 +0300)] 
lib-compression: ostream-zstd - Fix assert on value range

4 years agodoc/openssl.cnf: Increase default_bits to 2048
Arjen de Korte [Sat, 10 Apr 2021 11:52:15 +0000 (13:52 +0200)] 
doc/openssl.cnf: Increase default_bits to 2048

NIST guidelines mandate that all SSL certificates must be of at least 2048 key length

4 years agoglobal: Update default TLS protocol to TLSv1.2
Aki Tuomi [Fri, 26 Mar 2021 12:10:37 +0000 (14:10 +0200)] 
global: Update default TLS protocol to TLSv1.2

4 years agolib-ssl-iostream: Accept TLS version case-insensitive
Aki Tuomi [Tue, 6 Apr 2021 12:42:22 +0000 (15:42 +0300)] 
lib-ssl-iostream: Accept TLS version case-insensitive

4 years agolib-ssl-iostream: Add additional supported protocols
Aki Tuomi [Fri, 26 Mar 2021 12:11:48 +0000 (14:11 +0200)] 
lib-ssl-iostream: Add additional supported protocols

ANY - Any protocol version accepted
TLSv1.3 - Self-explanatory
LATEST - The newest protocol only

4 years agolib-master: Add ssl_cipher_suites
Aki Tuomi [Fri, 26 Mar 2021 10:08:40 +0000 (12:08 +0200)] 
lib-master: Add ssl_cipher_suites

4 years agoimap-zlib: Support per-algorithm compression level
Aki Tuomi [Thu, 1 Apr 2021 09:41:40 +0000 (12:41 +0300)] 
imap-zlib: Support per-algorithm compression level

4 years agozlib: Check that compression level is within supported range
Aki Tuomi [Tue, 30 Mar 2021 16:05:42 +0000 (19:05 +0300)] 
zlib: Check that compression level is within supported range

4 years agoimap-zlib: Check that compression level is within supported range
Aki Tuomi [Tue, 30 Mar 2021 16:04:31 +0000 (19:04 +0300)] 
imap-zlib: Check that compression level is within supported range

4 years agofs-compress: Check that compression range is within supported range
Aki Tuomi [Tue, 30 Mar 2021 16:03:30 +0000 (19:03 +0300)] 
fs-compress: Check that compression range is within supported range

4 years agolib-compression: Implement min/default/max getters
Aki Tuomi [Thu, 1 Apr 2021 06:26:10 +0000 (09:26 +0300)] 
lib-compression: Implement min/default/max getters

4 years agolib-compression: Add compression level range to handlers
Aki Tuomi [Tue, 30 Mar 2021 16:01:20 +0000 (19:01 +0300)] 
lib-compression: Add compression level range to handlers

4 years agolib-compression: Use designated initializers for compression handlers
Aki Tuomi [Tue, 30 Mar 2021 15:54:42 +0000 (18:54 +0300)] 
lib-compression: Use designated initializers for compression handlers

4 years agom4: want_zstd.m4 - Detect is ZSTD_minCLevel is present
Aki Tuomi [Thu, 1 Apr 2021 06:51:09 +0000 (09:51 +0300)] 
m4: want_zstd.m4 - Detect is ZSTD_minCLevel is present

4 years agolib-compression: Be explicit about xz magic number including a \0
Josef 'Jeff' Sipek [Fri, 5 Feb 2021 19:48:52 +0000 (14:48 -0500)] 
lib-compression: Be explicit about xz magic number including a \0

4 years agolib-smtp: test-smtp-server-errors - Add actual HELO tests to "bad HELO" test.
Stephan Bosch [Thu, 8 Apr 2021 23:49:21 +0000 (01:49 +0200)] 
lib-smtp: test-smtp-server-errors - Add actual HELO tests to "bad HELO" test.

Before, it only tested the EHLO command.

4 years agolib-smtp: test-smtp-server-errors - Add correct command test to "bad HELO" test.
Stephan Bosch [Thu, 8 Apr 2021 23:43:38 +0000 (01:43 +0200)] 
lib-smtp: test-smtp-server-errors - Add correct command test to "bad HELO" test.

4 years agolib-smtp: test-smtp-server-errors - Properly check server reply in "bad HELO" test.
Stephan Bosch [Thu, 8 Apr 2021 23:25:59 +0000 (01:25 +0200)] 
lib-smtp: test-smtp-server-errors - Properly check server reply in "bad HELO" test.

4 years agolib-smtp: test-smtp-server-errors - Rename "bad EHLO" test to "bad HELO".
Stephan Bosch [Thu, 8 Apr 2021 23:29:06 +0000 (01:29 +0200)] 
lib-smtp: test-smtp-server-errors - Rename "bad EHLO" test to "bad HELO".

4 years agolib-smtp: smtp-server-cmd-helo - Fix panic occurring for default HELO reply.
Stephan Bosch [Fri, 11 Sep 2020 19:08:03 +0000 (21:08 +0200)] 
lib-smtp: smtp-server-cmd-helo - Fix panic occurring for default HELO reply.

This only fails for the HELO command; the EHLO command is unaffected. The
default reply routine is not actually used at the moment, but it is used by the
fuzzer.

Panic was:

Panic: file smtp-server-cmd-helo.c: line 160 (smtp_server_cmd_ehlo_reply_create): assertion failed: (cmd->cmd->reg->func == smtp_server_cmd_ehlo)

4 years agolib-smtp: Reformat smtp-server-cmd-helo.c.
Stephan Bosch [Fri, 11 Sep 2020 20:40:31 +0000 (22:40 +0200)] 
lib-smtp: Reformat smtp-server-cmd-helo.c.

4 years agolib-smtp: smtp-server-cmd-data - Fix crash occurring when BDAT is the last in a too...
Stephan Bosch [Tue, 23 Mar 2021 09:27:23 +0000 (10:27 +0100)] 
lib-smtp: smtp-server-cmd-data - Fix crash occurring when BDAT is the last in a too long sequence of bad commands.

When smtp_server_reply() detects that too many replies were sent regarding
syntax errors, it will terminate the connection. Most commands will just stop
processing and exit when a reply is submitted, so no crash occurs for those.
However, BDAT will try to skip the data block, so that it will not be
interpreted as a large set of input commands, which subsequentely crashes
because the command parser is already gone after terminating the connection.

4 years agopush-notification: Fix logging initialization error
Timo Sirainen [Thu, 25 Mar 2021 08:59:19 +0000 (10:59 +0200)] 
push-notification: Fix logging initialization error

4 years agoimapc: imapc_list_get_fs() - Set index_pvt_dir for mailbox_list_settings
Markus Valentin [Wed, 24 Mar 2021 08:43:17 +0000 (09:43 +0100)] 
imapc: imapc_list_get_fs() - Set index_pvt_dir for mailbox_list_settings

To allow using private indexes with imapc storage the index_pvt_dir must
be set when listing the mailbox. Previously this did not happen because
the index_pvt_dir was simply NULL, now the value is copied from the
imapc_mailbox_list.

4 years agolib-index: Avoid accessing already freed "reason" when purging
Timo Sirainen [Tue, 30 Mar 2021 13:50:13 +0000 (16:50 +0300)] 
lib-index: Avoid accessing already freed "reason" when purging

Broken by 4b60d609c05d334d29a72c6dbbe301a66f518089

4 years agolib-ssl-iostream: Avoid calling X509_check_ip_asc if malformed input was used
Siavash Tavakoli [Tue, 30 Mar 2021 10:00:57 +0000 (11:00 +0100)] 
lib-ssl-iostream: Avoid calling X509_check_ip_asc if malformed input was used

Try to match certificate using "X509_check_ip_asc" only when
"X509_check_host" didn't report an internal error or malformed input.

4 years agolib-lua: Document the DLUA_WRAP_C_DATA macro
Josef 'Jeff' Sipek [Wed, 24 Mar 2021 15:01:34 +0000 (11:01 -0400)] 
lib-lua: Document the DLUA_WRAP_C_DATA macro

4 years agooauth2-jwt: Use int64_t instead time_t for portability
Aki Tuomi [Thu, 13 Aug 2020 17:01:41 +0000 (20:01 +0300)] 
oauth2-jwt: Use int64_t instead time_t for portability

4 years agolib-ssl-iostream: Use OpenSSL's X509_check_host and X509_check_ip_asc if available
Siavash Tavakoli [Sun, 21 Mar 2021 22:15:48 +0000 (22:15 +0000)] 
lib-ssl-iostream: Use OpenSSL's X509_check_host and X509_check_ip_asc if available

Make use of "X509_check_host()" and "X509_check_ip_asc()" if OpenSSL version
used has support for these functions. Revert back to previous custom
implementation in case either is not available.

Hosts are checked with partial wildcards (e.g. foo*.example.com) disabled.
If host name check fails, check against IP addresses in the certificate.

4 years agom4: Add HAVE_X509_CHECK_HOST, HAVE_X509_CHECK_IP, and HAVE_X509_CHECK_IP_ASC
Siavash Tavakoli [Sun, 21 Mar 2021 22:14:55 +0000 (22:14 +0000)] 
m4: Add HAVE_X509_CHECK_HOST, HAVE_X509_CHECK_IP, and HAVE_X509_CHECK_IP_ASC

Defined when compiling against an OpenSSL version supporting "X509_check_host",
"X509_check_ip()", and "X509_check_ip_asc()" respectively.

4 years agolib-ssl-iostream: Ignore case when checking certificate name
Siavash Tavakoli [Thu, 18 Mar 2021 12:20:35 +0000 (12:20 +0000)] 
lib-ssl-iostream: Ignore case when checking certificate name

Host name case must be ignored when cheking with certificate.

4 years agolib: ioloop - Remove unused timer_is_larger() macro
Timo Sirainen [Mon, 22 Mar 2021 11:00:31 +0000 (13:00 +0200)] 
lib: ioloop - Remove unused timer_is_larger() macro

4 years agolib: test-ioloop - Make sure recreating 0-timeout in callback works
Timo Sirainen [Mon, 1 Mar 2021 10:56:21 +0000 (12:56 +0200)] 
lib: test-ioloop - Make sure recreating 0-timeout in callback works

4 years agolib: ioloop - Fix 0 ms timeouts to trigger without waiting 2ms between calls
Timo Sirainen [Mon, 1 Mar 2021 11:03:16 +0000 (13:03 +0200)] 
lib: ioloop - Fix 0 ms timeouts to trigger without waiting 2ms between calls

4 years agolib-test: test_assert_ucmp() - Fix typo to make it compile
Timo Sirainen [Mon, 1 Mar 2021 11:02:40 +0000 (13:02 +0200)] 
lib-test: test_assert_ucmp() - Fix typo to make it compile

4 years agolib-compression: Get error with i_stream_get_error() so it's recursive
Markus Valentin [Mon, 22 Mar 2021 12:04:15 +0000 (13:04 +0100)] 
lib-compression: Get error with i_stream_get_error() so it's recursive

In some cases the iostream.error was NULL so the errno default message
was used. This fixes an regression introduced by 8b6142f9ba9.

4 years agolib-dict: dict-lua - Do not free pool after iteration finishes
Aki Tuomi [Tue, 23 Mar 2021 07:02:06 +0000 (09:02 +0200)] 
lib-dict: dict-lua - Do not free pool after iteration finishes

Otherwise we get double-free from gc.

Broken in 1e67b93cc9f469bb144fc890a6cb9b9b9cd20811

4 years agoman: doveconf - Fix -P/ typo to just -P
Timo Sirainen [Tue, 23 Mar 2021 10:32:13 +0000 (12:32 +0200)] 
man: doveconf - Fix -P/ typo to just -P

4 years agoman: doveconf - Document -s parameter
Timo Sirainen [Tue, 23 Mar 2021 10:31:46 +0000 (12:31 +0200)] 
man: doveconf - Document -s parameter

4 years agodoveadm zlibconnect: Support multiple compression algorithms
Timo Sirainen [Wed, 27 Jan 2021 18:26:26 +0000 (20:26 +0200)] 
doveadm zlibconnect: Support multiple compression algorithms

Unfortunately they don't work very well, because only the deflate ostream
supports flushing ostream before closing it.

4 years agodoveadm zlibconnect: Support automatically starting compression on COMPRESS command
Timo Sirainen [Wed, 27 Jan 2021 17:50:38 +0000 (19:50 +0200)] 
doveadm zlibconnect: Support automatically starting compression on COMPRESS command

The previous method of using ctrl-d wasn't really suitable for scripting.

4 years agolib-compression: Fix potential hangs with non-blocking istreams
Timo Sirainen [Wed, 27 Jan 2021 18:29:11 +0000 (20:29 +0200)] 
lib-compression: Fix potential hangs with non-blocking istreams

4 years agolib: i_stream_read() - Fix assert with DEBUG enabled
Timo Sirainen [Wed, 27 Jan 2021 18:34:29 +0000 (20:34 +0200)] 
lib: i_stream_read() - Fix assert with DEBUG enabled

It doesn't matter if the data buffer changes for <=0 return value if the
buffer was previously empty.

4 years agolib-storage: mailbox_list_init_fs() - Add event_parent
Timo Sirainen [Thu, 4 Feb 2021 00:15:22 +0000 (02:15 +0200)] 
lib-storage: mailbox_list_init_fs() - Add event_parent

4 years agolib-storage: Rename mail_storage_service_input.parent_event to event_parent
Timo Sirainen [Thu, 4 Feb 2021 00:00:28 +0000 (02:00 +0200)] 
lib-storage: Rename mail_storage_service_input.parent_event to event_parent

This makes it more consistent with other settings.

4 years agolib-fs: Rename fs_settings.event to event_parent
Timo Sirainen [Wed, 3 Feb 2021 23:58:25 +0000 (01:58 +0200)] 
lib-fs: Rename fs_settings.event to event_parent

This makes it more consistent with other settings.

4 years agolib-dict: Set connections' event_parent correctly
Timo Sirainen [Wed, 3 Feb 2021 23:36:52 +0000 (01:36 +0200)] 
lib-dict: Set connections' event_parent correctly

dict->dict.event is NULL at this point.

4 years agoauth: db-sql - Fill sql_settings.event_parent
Timo Sirainen [Wed, 3 Feb 2021 23:27:34 +0000 (01:27 +0200)] 
auth: db-sql - Fill sql_settings.event_parent

4 years agoglobal: Set http_client_settings.event_parent when possible
Timo Sirainen [Wed, 3 Feb 2021 23:16:12 +0000 (01:16 +0200)] 
global: Set http_client_settings.event_parent when possible