]> git.ipfire.org Git - thirdparty/dovecot/core.git/log
thirdparty/dovecot/core.git
8 years agolib-index: mail_transaction_log_file_get_highest_modseq_at() - return error string
Timo Sirainen [Wed, 17 May 2017 13:28:58 +0000 (16:28 +0300)] 
lib-index: mail_transaction_log_file_get_highest_modseq_at() - return error string

This can help figuring out why some error happened when more context is
provided in the caller's error messages.

8 years agolib-index: Add missing error logging for mail_index_view_sync_begin()
Timo Sirainen [Wed, 17 May 2017 13:21:54 +0000 (16:21 +0300)] 
lib-index: Add missing error logging for mail_index_view_sync_begin()

8 years agolib-index: mail_transaction_log_file_map() - return reason/error string
Timo Sirainen [Wed, 17 May 2017 10:33:44 +0000 (13:33 +0300)] 
lib-index: mail_transaction_log_file_map() - return reason/error string

This can help figuring out why some error happened when more context is
provided in the caller's error messages.

8 years agolib-index: mail_transaction_log_view_set_all() - don't entirely ignore corrupted...
Timo Sirainen [Wed, 17 May 2017 10:31:09 +0000 (13:31 +0300)] 
lib-index: mail_transaction_log_view_set_all() - don't entirely ignore corrupted logs

Ignore them only if it's followed by an index reset.

8 years agolib-storage: Fix mailbox list index records without guid having invalid flags
Timo Sirainen [Thu, 18 May 2017 20:13:38 +0000 (23:13 +0300)] 
lib-storage: Fix mailbox list index records without guid having invalid flags

With LAYOUT=index the mailbox is found with its GUID. If it doesn't exist,
the mailbox has to be either \NonExistent or \NoSelect. It probably doesn't
make much difference which one, so we'll fix them by adding \NoSelect.

With other layouts the GUID is allowed to be empty, because it can be looked
up from the actual mailbox.

8 years agolib-storage: Fix mailbox list index records with name_id=0
Timo Sirainen [Thu, 18 May 2017 20:06:20 +0000 (23:06 +0300)] 
lib-storage: Fix mailbox list index records with name_id=0

name_id=0 isn't valid, so it needs to be changed and writen to the disk.
The write-to-disk part wasn't working.

8 years agolib: Fix memory leak in test-istream-concat
Timo Sirainen [Fri, 19 May 2017 06:45:28 +0000 (09:45 +0300)] 
lib: Fix memory leak in test-istream-concat

8 years agolib: Fix crash when seeking istream-concat to EOF and trying to read it
Timo Sirainen [Thu, 18 May 2017 19:18:15 +0000 (22:18 +0300)] 
lib: Fix crash when seeking istream-concat to EOF and trying to read it

8 years agoimapc: Make sure a valid UIDVALIDITY is returned by SELECT
Timo Sirainen [Thu, 18 May 2017 18:10:33 +0000 (21:10 +0300)] 
imapc: Make sure a valid UIDVALIDITY is returned by SELECT

Fixes errors such as:
Error: Synchronization corrupted index header (in-memory index): uidvalidity=0, but next_uid=9

8 years agoimapc: Fix assert-crash if server doesn't send EXISTS reply to SELECT
Timo Sirainen [Thu, 18 May 2017 18:08:23 +0000 (21:08 +0300)] 
imapc: Fix assert-crash if server doesn't send EXISTS reply to SELECT

Fixes:
Panic: file imapc-sync.c: line 477 (imapc_sync_index): assertion failed: (mbox->sync_fetch_first_uid == 1)

8 years agolib-imap-client: Change server IP only on connect() failures
Timo Sirainen [Thu, 18 May 2017 17:18:24 +0000 (20:18 +0300)] 
lib-imap-client: Change server IP only on connect() failures

Also log an warning-level message about it. This is mainly useful to see
that a slow connection could be caused by a connect() timeout. Since more
IPs are still available, it's not yet an error.

8 years agoimapc: Fix infinite reconnection when server keeps sending corrupted state
Timo Sirainen [Thu, 18 May 2017 16:42:03 +0000 (19:42 +0300)] 
imapc: Fix infinite reconnection when server keeps sending corrupted state

When corrupted state was found, imapc_client_mailbox_reconnect() is called
to reconnect. This call skipped the normal "is it safe to reconnect?"
checks causing potentially infinite reconnections.

8 years agolib-imap: imap_parser_unref() should always set parser=NULL
Timo Sirainen [Thu, 18 May 2017 16:40:04 +0000 (19:40 +0300)] 
lib-imap: imap_parser_unref() should always set parser=NULL

Not just when the last reference is cleared. This is how *_unref()s should
work everywhere in Dovecot. This fixes a bug in lib-imap-client where a
parser could have been accessed after it was already freed.

8 years agoimapc: Avoid resending duplicate FETCH when reconnecting during the initial sync
Timo Sirainen [Thu, 18 May 2017 15:09:56 +0000 (18:09 +0300)] 
imapc: Avoid resending duplicate FETCH when reconnecting during the initial sync

8 years agoimapc: If initial SELECT fails, don't resend it twice on reconnect.
Timo Sirainen [Thu, 18 May 2017 15:01:27 +0000 (18:01 +0300)] 
imapc: If initial SELECT fails, don't resend it twice on reconnect.

8 years agolib-imap-client: Avoid infinite reconnection loops when retrying command fails
Timo Sirainen [Thu, 18 May 2017 14:36:27 +0000 (17:36 +0300)] 
lib-imap-client: Avoid infinite reconnection loops when retrying command fails

reconnect_command_count wasn't calculated correctly, because the SELECT and
potentially other following sync commands weren't included in it.

8 years agolib: Add dovecot_build_info variable containing Dovecot build information.
Timo Sirainen [Thu, 18 May 2017 09:32:12 +0000 (12:32 +0300)] 
lib: Add dovecot_build_info variable containing Dovecot build information.

By default this includes the version, including the git hash. The idea is
that this version information would be available in all the core dumps.

The DOVECOT_BUILD_INFO can be overridden by compiling with:

DOVECOT_BUILD_INFO='"build info"' make

8 years agoauth: If passdb/userdb ldap has blocking=yes, auth master shouldn't connect to ldap
Timo Sirainen [Tue, 16 May 2017 14:53:23 +0000 (17:53 +0300)] 
auth: If passdb/userdb ldap has blocking=yes, auth master shouldn't connect to ldap

8 years agodirector: Add old host's up/down and vhost count parameters to director_flush_socket
Timo Sirainen [Thu, 18 May 2017 08:57:38 +0000 (11:57 +0300)] 
director: Add old host's up/down and vhost count parameters to director_flush_socket

The "down" status allows the script to determine whether it should try to
perform any work on the old host. The vhost count may be unnecessary, but
might be useful for some purpose.

8 years agodsync: Try to commit transactions every dsync_commit_msgs_interval messages
Timo Sirainen [Sun, 30 Apr 2017 09:31:48 +0000 (12:31 +0300)] 
dsync: Try to commit transactions every dsync_commit_msgs_interval messages

This was first attempted to be implemented by
ec0cc8fa647794e44a1afaa448f495a713048dc4, but it was later partially
reverted by 5973d496b16721af6d2c1fa90b016aacddf13554. This current
commit should fix its problems.

8 years agolib-storage: add a mail user pre-deinit vfunc
Josef 'Jeff' Sipek [Fri, 12 May 2017 09:44:27 +0000 (12:44 +0300)] 
lib-storage: add a mail user pre-deinit vfunc

This allows plugins to perform checks right before the deinit call.

8 years agoimapc: Try to merge STOREs together as much as possible when syncing
Timo Sirainen [Thu, 4 May 2017 16:59:41 +0000 (19:59 +0300)] 
imapc: Try to merge STOREs together as much as possible when syncing

8 years agolib-storage: Avoid unnecessary UIDNEXT lookups after saving a mail
Timo Sirainen [Fri, 5 May 2017 12:20:05 +0000 (15:20 +0300)] 
lib-storage: Avoid unnecessary UIDNEXT lookups after saving a mail

The vsize checking code was expecting that this would always be a cheap
operation, but with imapc code it could trigger a remote STATUS (UIDNEXT)
call. Do this only when we've checked that this mailbox is updating vsize
header at all.

8 years agoimapc-quota: Avoid sending unnecessarily many GETQUOTA[ROOT] commands
Timo Sirainen [Fri, 12 May 2017 12:42:31 +0000 (15:42 +0300)] 
imapc-quota: Avoid sending unnecessarily many GETQUOTA[ROOT] commands

The last_refresh == ioloop_timeval check didn't work, because the refresh
itself updated ioloop_timeval. This caused a single quota lookup to issue
multiple GETQUOTA[ROOT] commands to imapc.

8 years agodoveadm mailbox status: Add "firstsaved" field.
Timo Sirainen [Wed, 10 May 2017 09:44:25 +0000 (12:44 +0300)] 
doveadm mailbox status: Add "firstsaved" field.

8 years agolib-index: Add mail_cache_expunge_count
Aki Tuomi [Tue, 9 May 2017 11:29:04 +0000 (14:29 +0300)] 
lib-index: Add mail_cache_expunge_count

It can be called to correctly handle cache counters
when records are removed.

8 years agolib-imap: imap_append_string_for_humans() - Change CR/LF to space
Timo Sirainen [Tue, 2 May 2017 09:18:40 +0000 (12:18 +0300)] 
lib-imap: imap_append_string_for_humans() - Change CR/LF to space

Practically this shouldn't matter, because in email headers a CR/LF is
always followed by a space/tab. But maybe this can be used for some
other purposes in future, and it makes the unit tests clearer. :)

8 years agolib-storage: Add missing ATTR_FORMAT to mail_set_mail_cache_corrupted()
Timo Sirainen [Fri, 12 May 2017 08:13:09 +0000 (11:13 +0300)] 
lib-storage: Add missing ATTR_FORMAT to mail_set_mail_cache_corrupted()

8 years agolib-storage: Use new mail_cache_set_seq_corrupted_reason
Aki Tuomi [Tue, 9 May 2017 11:01:07 +0000 (14:01 +0300)] 
lib-storage: Use new mail_cache_set_seq_corrupted_reason

8 years agolib-index: Add mail_cache_set_seq_corrupted_reason
Aki Tuomi [Tue, 9 May 2017 11:00:38 +0000 (14:00 +0300)] 
lib-index: Add mail_cache_set_seq_corrupted_reason

Marks a seq in cache corrupted, and removes
that instead of the whole cache.

8 years agolib-storage: Remove index_storage_save_continue
Aki Tuomi [Fri, 12 May 2017 10:35:06 +0000 (13:35 +0300)] 
lib-storage: Remove index_storage_save_continue

It was not intended for v2.2

8 years agolib-storage: Unconstify test functions
Aki Tuomi [Fri, 12 May 2017 04:47:56 +0000 (07:47 +0300)] 
lib-storage: Unconstify test functions

Removes a compiler warning

8 years agolib: Use t_malloc instead of t_malloc_no0
Aki Tuomi [Fri, 12 May 2017 04:41:27 +0000 (07:41 +0300)] 
lib: Use t_malloc instead of t_malloc_no0

Broken in 4792d4bd

8 years agolib: Add dec2str_buf()
Timo Sirainen [Tue, 2 May 2017 12:38:00 +0000 (15:38 +0300)] 
lib: Add dec2str_buf()

Conflicts:
src/lib/strfuncs.c

8 years agomaster: Send SIGQUIT to processes running at deinit to close socket listeners.
Timo Sirainen [Tue, 2 May 2017 15:40:43 +0000 (18:40 +0300)] 
master: Send SIGQUIT to processes running at deinit to close socket listeners.

This allows Dovecot to be restarted even when some lmtp/doveadm process is
running for a long time. Otherwise it would keep the inet_listener socket
open and prevent the new Dovecot from binding to the port.

8 years agolib-master: When running under master, close listeners immediately on SIGQUIT
Timo Sirainen [Tue, 2 May 2017 13:13:08 +0000 (16:13 +0300)] 
lib-master: When running under master, close listeners immediately on SIGQUIT

8 years agolib-master: Remove listener's IO earlier if possible
Timo Sirainen [Tue, 2 May 2017 15:39:06 +0000 (18:39 +0300)] 
lib-master: Remove listener's IO earlier if possible

This is needed for the next change to work properly.

8 years agomaster: Wait more precisely 5 secs at deinit for child processes to die.
Timo Sirainen [Tue, 2 May 2017 12:56:40 +0000 (15:56 +0300)] 
master: Wait more precisely 5 secs at deinit for child processes to die.

Use milliseconds granularity instead of seconds.

8 years agolib: Use lib_signals_syscall_error() for write() failure in signal handler
Timo Sirainen [Tue, 2 May 2017 12:41:41 +0000 (15:41 +0300)] 
lib: Use lib_signals_syscall_error() for write() failure in signal handler

8 years agolib: Add lib_signals_syscall_error()
Timo Sirainen [Tue, 2 May 2017 12:41:04 +0000 (15:41 +0300)] 
lib: Add lib_signals_syscall_error()

8 years agoman: Fix doveadm-flags examples
Timo Sirainen [Tue, 9 May 2017 10:15:42 +0000 (13:15 +0300)] 
man: Fix doveadm-flags examples

Patch by Frank Ebert

8 years agoauth: Do not use AUTH_SUBSYS_MECH in logging when request->mech is NULL
Aki Tuomi [Tue, 9 May 2017 09:25:49 +0000 (12:25 +0300)] 
auth: Do not use AUTH_SUBSYS_MECH in logging when request->mech is NULL

This can happen when a lookup is done instead of authentication.

Fixes auth: Panic: file auth-request.c: line 2560 (get_log_prefix): assertion failed: (auth_request->mech != NULL)

8 years agopassdb-imap: Make sure ssl verification is possible with current settings
Aki Tuomi [Mon, 8 May 2017 09:24:52 +0000 (12:24 +0300)] 
passdb-imap: Make sure ssl verification is possible with current settings

8 years agopassdb-imap: Add ssl_ca_file setting
Aki Tuomi [Mon, 8 May 2017 09:24:21 +0000 (12:24 +0300)] 
passdb-imap: Add ssl_ca_file setting

Allow setting SSL trust roots from a file

8 years agopassdb-imap: Add option to control certificate verification
Aki Tuomi [Fri, 28 Apr 2017 17:28:23 +0000 (20:28 +0300)] 
passdb-imap: Add option to control certificate verification

Turn it on by default

8 years agolib-ssl-iostream: Support IP address SANs
Aki Tuomi [Mon, 8 May 2017 10:35:35 +0000 (13:35 +0300)] 
lib-ssl-iostream: Support IP address SANs

8 years agoimap: Set FETCH transactions hidden only when \Seen flags are implicitly set
Timo Sirainen [Fri, 5 May 2017 09:35:23 +0000 (12:35 +0300)] 
imap: Set FETCH transactions hidden only when \Seen flags are implicitly set

This simplifies implementing some plugins and has no downsides to core
functionality.

8 years agolib-storage: Fix memory leak in mail_search_args_simplify()
Timo Sirainen [Thu, 4 May 2017 14:31:47 +0000 (17:31 +0300)] 
lib-storage: Fix memory leak in mail_search_args_simplify()

The leaks happened when search args were already initialized (which they
usually were at this point) and some of the args were dropped entirely.

Improved the unit test to initialize search args before calling the
simplify, so valgrind would notice if there are any leaks.

Conflicts:
src/lib-storage/test-mail-search-args-simplify.c

8 years agolib-master: Add comments to struct master_service_connection
Timo Sirainen [Tue, 2 May 2017 12:02:25 +0000 (15:02 +0300)] 
lib-master: Add comments to struct master_service_connection

Conflicts:
src/lib-master/master-service.h

8 years agolib-storage: When save is aborted, close dest_mail without crashing
Timo Sirainen [Fri, 28 Apr 2017 11:35:36 +0000 (14:35 +0300)] 
lib-storage: When save is aborted, close dest_mail without crashing

Fixes:
Panic: file mail-index-transaction-update.c: line 1023 (mail_index_update_ext): assertion failed: (seq > 0 && (seq <= mail_index_view_get_messages_count(t->view) || seq <= t->last_new_seq))

Because cache was still attempted to be updated, but the mail was already
expunged from index.

8 years agolib-storage: Move backend code to a common index_storage_save_abort_last()
Timo Sirainen [Fri, 28 Apr 2017 11:06:43 +0000 (14:06 +0300)] 
lib-storage: Move backend code to a common index_storage_save_abort_last()

Conflicts:
src/lib-storage/index/index-storage.c
src/lib-storage/index/index-storage.h

8 years agoauth: Log reason for skipping passdb
Aki Tuomi [Thu, 27 Apr 2017 11:09:08 +0000 (14:09 +0300)] 
auth: Log reason for skipping passdb

8 years agoauth: Add test suite for username filter
Aki Tuomi [Fri, 28 Apr 2017 09:49:37 +0000 (12:49 +0300)] 
auth: Add test suite for username filter

8 years agoauth: Refactor auth to use libauth.la
Aki Tuomi [Fri, 28 Apr 2017 07:25:14 +0000 (10:25 +0300)] 
auth: Refactor auth to use libauth.la

This makes writing new unit tests easier, as you can link
to libauth.la.

8 years agoauth: Add username_filter for passdb block
Aki Tuomi [Fri, 28 Apr 2017 09:51:20 +0000 (12:51 +0300)] 
auth: Add username_filter for passdb block

username_filter lets you specify one or more pattern(s) for
including or excluding users. exclusion patterns are denoted
with ! prefix.

if any exclude matches the username, passdb will be skipped.
if any inclusions is specified, and the username does not match
one of them, passdb will be skipped.

8 years agoauth: Use MECH subsystem when logging error about skipping all password databases
Aki Tuomi [Thu, 27 Apr 2017 08:53:13 +0000 (11:53 +0300)] 
auth: Use MECH subsystem when logging error about skipping all password databases

Otherwise it will assert-crash because all password databases were skipped.

8 years agolib-storage: mail_search_arg_to_imap() - Fix writing invalid keywords
Timo Sirainen [Thu, 27 Apr 2017 09:54:20 +0000 (12:54 +0300)] 
lib-storage: mail_search_arg_to_imap() - Fix writing invalid keywords

Just write the original invalid keyword string as output. It might not be
entirely invalid - just invalid within this mailbox (e.g. a mailbox doesn't
allow new keywords).

8 years agolib-storage: Fix searching when search query has invalid keywords.
Timo Sirainen [Thu, 27 Apr 2017 09:53:18 +0000 (12:53 +0300)] 
lib-storage: Fix searching when search query has invalid keywords.

For example "SEARCH KEYWORD ]" was returning all mails instead of nothing.

8 years agolib-index: mail_index_update_keywords() - don't assert if adding/removing 0 keywords
Timo Sirainen [Thu, 27 Apr 2017 09:50:13 +0000 (12:50 +0300)] 
lib-index: mail_index_update_keywords() - don't assert if adding/removing 0 keywords

Although it would be nice for the caller to check it, it's easier to do
here. It's mainly a problem with mailbox_keywords_create_valid() that may
unexpectedly create empty keywords.

8 years agoquota: imapc backend now never enforces the quota itself
Timo Sirainen [Wed, 26 Apr 2017 20:41:03 +0000 (23:41 +0300)] 
quota: imapc backend now never enforces the quota itself

It just causes a lot of GETQUOTA/GETQUOTAROOT calls to remove. In theory we
could make this optional, but I doubt anyone would want it.

8 years agolib-storage: Fix crash in mail_get_parts() with a special plugin
Timo Sirainen [Wed, 26 Apr 2017 20:43:24 +0000 (23:43 +0300)] 
lib-storage: Fix crash in mail_get_parts() with a special plugin

If plugin hooks into mail_get_stream() which causes data->parts to be set,
this code crashed with:

Panic: file index-mail.c: line 1163 (index_mail_parse_body): assertion failed: (data->parser_ctx != NULL)

8 years agoimapc: Don't send NOOP on sync if MAILBOX_SYNC_FLAG_FAST is set
Timo Sirainen [Wed, 26 Apr 2017 20:13:20 +0000 (23:13 +0300)] 
imapc: Don't send NOOP on sync if MAILBOX_SYNC_FLAG_FAST is set

Fast syncing should do only the minimal amount of work.

8 years agoimap: Allow plugins to hook into syncing.
Timo Sirainen [Wed, 26 Apr 2017 12:04:23 +0000 (15:04 +0300)] 
imap: Allow plugins to hook into syncing.

Ideally all of the existing pieces in the syncing code would start using
this at some point, so their code could be moved to a more logical location.

8 years agoimap: Move struct imap_sync_context to imap-sync-private.h
Timo Sirainen [Wed, 26 Apr 2017 11:57:40 +0000 (14:57 +0300)] 
imap: Move struct imap_sync_context to imap-sync-private.h

8 years agolib-storage: mail_search_arg_to_imap() - minor keywords writing optimization
Timo Sirainen [Tue, 18 Apr 2017 12:55:08 +0000 (15:55 +0300)] 
lib-storage: mail_search_arg_to_imap() - minor keywords writing optimization

Avoid an extra str_delete() by checking whether the parenthesis are needed.

8 years agolib-storage: mail_search_arg_to_imap() - minor FLAGS writing optimization
Timo Sirainen [Tue, 18 Apr 2017 12:51:39 +0000 (15:51 +0300)] 
lib-storage: mail_search_arg_to_imap() - minor FLAGS writing optimization

Avoid an extra str_delete() by immediately calculating whether the
parenthesis are needed.

8 years agolib: Add bits_is_power_of_two()
Timo Sirainen [Tue, 18 Apr 2017 12:38:59 +0000 (15:38 +0300)] 
lib: Add bits_is_power_of_two()

8 years agolib: Fixed bits_required64() with 32bit systems.
Timo Sirainen [Tue, 19 Apr 2016 18:14:37 +0000 (21:14 +0300)] 
lib: Fixed bits_required64() with 32bit systems.

Broken by 84f697c5e30565823619abaaeb57164c789d4b66.

8 years agolib: bits - GCC (and clang) provide bit-twiddle intrinsics, use them
Phil Carmody [Fri, 5 Feb 2016 13:57:30 +0000 (15:57 +0200)] 
lib: bits - GCC (and clang) provide bit-twiddle intrinsics, use them

Signed-off-by: Phil Carmody <phil@dovecot.fi>
8 years agolib: bits - new fractional log-like helper
Phil Carmody [Wed, 3 Feb 2016 16:34:13 +0000 (18:34 +0200)] 
lib: bits - new fractional log-like helper

For stats gathering, where the data can have a wide range of values, you
don't necessarily need the same granularity along the full range of values.
For example, 1ms and 11ms latencies are very different, but 1.001s and
1.011s latencies are not worth distinguishing. Something logarithmic seems
more apt. Simply looking at power-of-2 sized bands (e.g. doing log2(n)),
however, is too granular, so these new helpers let you specify how fine
to (linearly) subdivide each of those bands. 1 fractional bit splits
each power of 2 band into 2 halves. 2 fractional bits splits each power
of 2 band into 4 quarters, and so on. 0 fractional bits is just log2().

Exact identification of percentiles is impossible, but it was anyway, as you
simply cannot store all the data required to calculate them. However, a mere
896 buckets will permit you to have 32 bands per power of 2, 5 fracional bits.
The above example would have buckets such as 2.432s-2.496s, and 55.3s-56.3s.
Assuming smooth distribution lets you calculate percentiles more accurately,
just assume within each bucket is a trapezial distribution. This holds even
if the distribution is multi-modal, which it will be. However, maths required.

Signed-off-by: Phil Carmody <phil@dovecot.fi>
8 years agoauth: Fixed dovecot/auth hanging when child ntlm_auth crashes while processing an...
Andriy Syrovenko [Sun, 16 Apr 2017 22:14:02 +0000 (01:14 +0300)] 
auth: Fixed dovecot/auth hanging when child ntlm_auth crashes while processing an authentication request

8 years agoimapc: Fix memory leak when closing mailbox with delayed changes
Timo Sirainen [Wed, 26 Apr 2017 11:20:49 +0000 (14:20 +0300)] 
imapc: Fix memory leak when closing mailbox with delayed changes

8 years agoimapc: Use UID SEARCH instead of SEARCH
Timo Sirainen [Tue, 25 Apr 2017 09:39:04 +0000 (12:39 +0300)] 
imapc: Use UID SEARCH instead of SEARCH

UIDs work better for some broken IMAP servers, so it's safer to use it.

Keep using sequences for ESEARCH, since servers supporting it aren't at
least yet known to be broken and the search result with sequences is
smaller.

8 years agoquota: Add imapc backend
Timo Sirainen [Mon, 24 Apr 2017 14:59:53 +0000 (17:59 +0300)] 
quota: Add imapc backend

This allows using imapc storage with imapc quota. The quota acts as
read-only, so it's used only when the current quota usage is explicitly
asked.

The quota can be looked up using either a mailbox name or quota root name.
By default INBOX's quota is looked up. If there are multiple quota roots
returned for the mailbox, only the first quota root returned by the
QUOTAROOT reply is used.

8 years agoquota: Fix namespace deduplication when mailboxes don't have paths.
Timo Sirainen [Mon, 24 Apr 2017 14:58:53 +0000 (17:58 +0300)] 
quota: Fix namespace deduplication when mailboxes don't have paths.

Nothing requires a mailbox path for quota backends, especially imapc.
Still do namespace deduplication based on alias_for settings.

8 years agoimapc: include imapc-client.h in imapc-storage.h
Timo Sirainen [Mon, 24 Apr 2017 14:10:10 +0000 (17:10 +0300)] 
imapc: include imapc-client.h in imapc-storage.h

It was already required to be able to successfully include imapc-storage.h.

8 years agoimap-plugins: Use client_add_capability() for adding dynamic capabilities
Timo Sirainen [Mon, 24 Apr 2017 15:13:13 +0000 (18:13 +0300)] 
imap-plugins: Use client_add_capability() for adding dynamic capabilities

8 years agoimap: Use client_add_capability() for adding all dynamic capabilities
Timo Sirainen [Mon, 24 Apr 2017 15:51:53 +0000 (18:51 +0300)] 
imap: Use client_add_capability() for adding all dynamic capabilities

8 years agoimap: Add client_add_capability()
Timo Sirainen [Mon, 24 Apr 2017 15:12:55 +0000 (18:12 +0300)] 
imap: Add client_add_capability()

8 years agoimapc: Add imapc_features=fetch-bodystructure
Timo Sirainen [Mon, 24 Apr 2017 10:29:13 +0000 (13:29 +0300)] 
imapc: Add imapc_features=fetch-bodystructure

This allows using the remote IMAP server's BODY and BODYSTRUCTURE replies.

8 years agolib-storage: Add mail_storage.nonbody_access_fields
Timo Sirainen [Mon, 24 Apr 2017 10:27:43 +0000 (13:27 +0300)] 
lib-storage: Add mail_storage.nonbody_access_fields

This avoids index_mail_update_access_parts_pre() from opening the mail
stream unnecessarily for fields that can be looked up via other methods
by the storage.

8 years agolib-storage: Add index_mail_get_cached_body[structure]()
Timo Sirainen [Mon, 24 Apr 2017 10:05:48 +0000 (13:05 +0300)] 
lib-storage: Add index_mail_get_cached_body[structure]()

This just moves the code to these functions without changing any of the
logic.

8 years agolib-imap: Make imap_bodystructure_parse_args() public
Timo Sirainen [Mon, 24 Apr 2017 11:04:01 +0000 (14:04 +0300)] 
lib-imap: Make imap_bodystructure_parse_args() public

8 years agolib-imap: Add imap_write_arg() to write only a single arg
Timo Sirainen [Mon, 24 Apr 2017 09:50:10 +0000 (12:50 +0300)] 
lib-imap: Add imap_write_arg() to write only a single arg

8 years agolib-imap-client: Fix imapc_client_get_capabilities() when called without connections
Timo Sirainen [Sun, 23 Apr 2017 16:57:11 +0000 (19:57 +0300)] 
lib-imap-client: Fix imapc_client_get_capabilities() when called without connections

8 years agoimapc: Fix crash in mailbox_exists() when LAYOUT isn't imapc.
Timo Sirainen [Sun, 23 Apr 2017 14:19:36 +0000 (17:19 +0300)] 
imapc: Fix crash in mailbox_exists() when LAYOUT isn't imapc.

Especially breaks LAYOUT=none.

8 years agoimapc: Support imapc_features=search without ESEARCH extension
Timo Sirainen [Sun, 23 Apr 2017 10:35:18 +0000 (13:35 +0300)] 
imapc: Support imapc_features=search without ESEARCH extension

8 years agoimapc: Make sure client is logged in when checking capabilities
Timo Sirainen [Sun, 23 Apr 2017 16:14:54 +0000 (19:14 +0300)] 
imapc: Make sure client is logged in when checking capabilities

Especially with imapc_features=delay-login the capability could have been
looked at before the client was even connected.

8 years agoimapc: Add imapc_mailbox.capabilities
Timo Sirainen [Sun, 23 Apr 2017 15:51:02 +0000 (18:51 +0300)] 
imapc: Add imapc_mailbox.capabilities

Use it instead of imapc_client_get_capabilities(). Simplifies the
following patch.

8 years agoimapc: Rename imapc_storage_has_modseqs() to imapc_mailbox_has_modseqs()
Timo Sirainen [Sun, 23 Apr 2017 15:57:15 +0000 (18:57 +0300)] 
imapc: Rename imapc_storage_has_modseqs() to imapc_mailbox_has_modseqs()

Simplifies the following patch.

8 years agocassandra: Use fallback consistency for CASS_ERROR_LIB_NO_HOSTS_AVAILABLE errors
Timo Sirainen [Fri, 21 Apr 2017 09:54:17 +0000 (12:54 +0300)] 
cassandra: Use fallback consistency for CASS_ERROR_LIB_NO_HOSTS_AVAILABLE errors

I'm not entirely sure if this is always appropriate, but at least this error
happens every time when attempting to use write_consistency=two when there
is only a single Cassandra node.

8 years agodsync-server: Fix support for dsync_features=empty-header-workaround
Timo Sirainen [Fri, 21 Apr 2017 17:59:55 +0000 (20:59 +0300)] 
dsync-server: Fix support for dsync_features=empty-header-workaround

Fixes:
Panic: Unknown key: empty_hdr_workaround

8 years ago*-login: Add client_vfuncs.send_raw_data()
Timo Sirainen [Fri, 21 Apr 2017 10:35:33 +0000 (13:35 +0300)] 
*-login: Add client_vfuncs.send_raw_data()

This allows login plugins to hook into seeing all the data that is sent to
the imap/pop3 client.

8 years agoimap: Add imap_client_vfuncs.send_tagline()
Timo Sirainen [Fri, 21 Apr 2017 10:27:18 +0000 (13:27 +0300)] 
imap: Add imap_client_vfuncs.send_tagline()

This allows plugins to catch all the IMAP command replies.

8 years ago*-login: Unload plugins at deinit.
Timo Sirainen [Tue, 18 Apr 2017 07:23:37 +0000 (10:23 +0300)] 
*-login: Unload plugins at deinit.

8 years agolib-storage: Allow mail_add_temp_wanted_fields() to be called before mail_set_seq*()
Timo Sirainen [Wed, 19 Apr 2017 12:01:19 +0000 (15:01 +0300)] 
lib-storage: Allow mail_add_temp_wanted_fields() to be called before mail_set_seq*()

Quota plugin was already doing this, but it didn't actually work. It was
also crashing with imapc:

Panic: file mail-cache-lookup.c: line 341 (mail_cache_field_exists): assertion failed: (seq > 0)

8 years agolib-storage: Add mailbox_attribute_unregister_internal[s]()
Timo Sirainen [Thu, 20 Apr 2017 16:16:46 +0000 (19:16 +0300)] 
lib-storage: Add mailbox_attribute_unregister_internal[s]()

This allows plugins to unregister internal attributes when they're unloaded.

8 years agolib-storage: mail_search_args_simplify() - deduplicate flags
Timo Sirainen [Thu, 13 Apr 2017 12:13:19 +0000 (15:13 +0300)] 
lib-storage: mail_search_args_simplify() - deduplicate flags

This needs to be done in a bit more complicated way because multiple
SEARCH_FLAGS parameters are wanted to be merged together using a single
shared value.flags. Move this merging last after all the deduplication is
done.

8 years agolib-storage: mail_search_args_simplify() - simplify "x AND NOT x"
Timo Sirainen [Thu, 13 Apr 2017 12:09:19 +0000 (15:09 +0300)] 
lib-storage: mail_search_args_simplify() - simplify "x AND NOT x"

Implemented for SEARCH_KEYWORD, SEARCH_TEXT, SEARCH_BODY and SEARCH_HEADER*.
Dates and sizes would need special code, which gets a bit complicated.

8 years agolib-storage: Add more tests to test-mail-search-args-simplify
Timo Sirainen [Thu, 13 Apr 2017 11:05:55 +0000 (14:05 +0300)] 
lib-storage: Add more tests to test-mail-search-args-simplify