]> git.ipfire.org Git - thirdparty/dovecot/core.git/log
thirdparty/dovecot/core.git
9 years agoconfigure: Detect pandoc for building documentation
Aki Tuomi [Wed, 12 Oct 2016 06:36:46 +0000 (09:36 +0300)] 
configure: Detect pandoc for building documentation

9 years agolib-program-client: Do not use /tmp in testing
Aki Tuomi [Wed, 12 Oct 2016 07:30:16 +0000 (10:30 +0300)] 
lib-program-client: Do not use /tmp in testing

9 years agoauth: Pass userdb fields to worker
Aki Tuomi [Wed, 12 Oct 2016 09:04:10 +0000 (12:04 +0300)] 
auth: Pass userdb fields to worker

If this is not done, then those userdb handlers
that need access to userdb variables for e.g.
interpolation, cannot access them.

9 years agoauth: Don't re-insert userdb results from auth cache data back to cache.
Timo Sirainen [Tue, 11 Oct 2016 10:18:53 +0000 (13:18 +0300)] 
auth: Don't re-insert userdb results from auth cache data back to cache.

This was also breaking TTLs for the cached userdb results, because each
re-insert reset the TTL.

9 years agolib-program-client: Fixed potential panic in test-program-client-local
Timo Sirainen [Mon, 10 Oct 2016 18:22:15 +0000 (21:22 +0300)] 
lib-program-client: Fixed potential panic in test-program-client-local

If the run finished before io_loop_run(), it would panic with:
Panic: BUG: No IOs or timeouts set. Not waiting for infinity.

9 years agolib-program-client: Fixed program_client_run() that succeeds rapidly.
Timo Sirainen [Mon, 10 Oct 2016 18:19:34 +0000 (21:19 +0300)] 
lib-program-client: Fixed program_client_run() that succeeds rapidly.

program_client_run_async() could have called the callback with result=0
before io_loop_run(). This happened with local client.

Fixes in test-program-client-local:
Panic: BUG: No IOs or timeouts set. Not waiting for infinity.

9 years agofs-metawrap: Don't assert-crash when trying to write an empty file.
Timo Sirainen [Mon, 10 Oct 2016 20:53:55 +0000 (23:53 +0300)] 
fs-metawrap: Don't assert-crash when trying to write an empty file.

Fixes:
Panic: file fs-metawrap.c: line 401 (fs_metawrap_write_stream_finish): assertion failed: (file->super_output->offset > 0 || file->super_output->stream_errno != 0)

9 years agolib-fs: Renamed internal i_stream_mail_read() to i_stream_fs_stats_read()
Timo Sirainen [Mon, 10 Oct 2016 21:31:17 +0000 (00:31 +0300)] 
lib-fs: Renamed internal i_stream_mail_read() to i_stream_fs_stats_read()

Just to make backtraces look clearer. Originally forgot to change this
after copy&pasting code from istream-mail.c

9 years agolib-program-client: Fixed running test-program-client-local as root.
Timo Sirainen [Mon, 10 Oct 2016 17:58:53 +0000 (20:58 +0300)] 
lib-program-client: Fixed running test-program-client-local as root.

uid/gid == -1 isn't treated as "don't change" in here.

9 years agoauth: Compiler warning fix
Timo Sirainen [Mon, 10 Oct 2016 17:35:17 +0000 (20:35 +0300)] 
auth: Compiler warning fix

9 years agoauth: Fix default SASL bind for LDAP
Matwey V. Kornilov [Wed, 21 Sep 2016 07:55:47 +0000 (10:55 +0300)] 
auth: Fix default SASL bind for LDAP

User may configure Dovecot to use SASL bind as default bind method.  This can
be the case when ldapi:/// (or ldaps:///) with SASL EXTERNAL is used.
Currently, Dovecot returns LDAP connection to wrong bind state after first
successful auth bind, LDAP simple bind always used to rebind.  This may broke
setup when ACL in LDAP configured not to allow search/bind for such simple
bind.

9 years agoauth: Introduce db_ldap_bind_sasl() function
Matwey V. Kornilov [Wed, 21 Sep 2016 07:50:02 +0000 (10:50 +0300)] 
auth: Introduce db_ldap_bind_sasl() function

Do refactoring in db_ldap_connect() before fixing the SASL bind issue in the next commit.

9 years agodoveadm director kick: Added -f <passdb field> parameter.
Timo Sirainen [Thu, 6 Oct 2016 12:22:13 +0000 (15:22 +0300)] 
doveadm director kick: Added -f <passdb field> parameter.

This works for all the user_* passdb fields.

9 years agodoveadm director kick: Escape username properly.
Timo Sirainen [Thu, 6 Oct 2016 12:19:51 +0000 (15:19 +0300)] 
doveadm director kick: Escape username properly.

This only mattered if the username contained \001, TAB or LF characters,
which isn't normal.

9 years agodirector: Escape username when handling USER-KICK.
Timo Sirainen [Thu, 6 Oct 2016 12:13:30 +0000 (15:13 +0300)] 
director: Escape username when handling USER-KICK.

This could have caused problems if username parameter contained TABs or LFs,
which of course shouldn't normally happen.

9 years agodoveadm proxy kick: Support multiple user parameters.
Timo Sirainen [Thu, 6 Oct 2016 11:54:51 +0000 (14:54 +0300)] 
doveadm proxy kick: Support multiple user parameters.

9 years agodoveadm proxy kick: Added -f <passdb field> parameter.
Timo Sirainen [Thu, 6 Oct 2016 11:53:11 +0000 (14:53 +0300)] 
doveadm proxy kick: Added -f <passdb field> parameter.

This works for all the user_* passdb fields.

9 years agodoveadm proxy list: Show all user_* fields in output.
Timo Sirainen [Thu, 6 Oct 2016 11:38:04 +0000 (14:38 +0300)] 
doveadm proxy list: Show all user_* fields in output.

9 years ago*-login: Store user_* passdb fields to client->alt_usernames.
Timo Sirainen [Wed, 5 Oct 2016 20:22:56 +0000 (23:22 +0300)] 
*-login: Store user_* passdb fields to client->alt_usernames.

9 years agolast-login: Don't execute last_login on IMAP unhibernation.
Timo Sirainen [Mon, 10 Oct 2016 14:37:27 +0000 (17:37 +0300)] 
last-login: Don't execute last_login on IMAP unhibernation.

9 years agoquota: Don't execute quota_over_script if userdb lookup was over 10 secs ago
Timo Sirainen [Mon, 10 Oct 2016 14:19:32 +0000 (17:19 +0300)] 
quota: Don't execute quota_over_script if userdb lookup was over 10 secs ago

9 years agoimap-hibernate: Preserve mail_user.session_create_time through hibernation
Timo Sirainen [Mon, 10 Oct 2016 14:19:16 +0000 (17:19 +0300)] 
imap-hibernate: Preserve mail_user.session_create_time through hibernation

9 years agolib-storage: Added mail_user.session_create_time and .session_restored
Timo Sirainen [Mon, 10 Oct 2016 14:19:06 +0000 (17:19 +0300)] 
lib-storage: Added mail_user.session_create_time and .session_restored

9 years agoimap-hibernate: Properly fix hibernation
Aki Tuomi [Thu, 6 Oct 2016 11:54:24 +0000 (14:54 +0300)] 
imap-hibernate: Properly fix hibernation

The previous fix did not properly fix hibernation
as the clients still dropped out of hibernate.
Also the tag used was no longer following. This
change will track tag changes and keeps the
hibernation process going on until the user enters
something else than DONE\r\ntag IDLE\r\n in same
packet.

9 years agolib-program-client: Compiler warning fixes
Timo Sirainen [Mon, 10 Oct 2016 11:42:24 +0000 (14:42 +0300)] 
lib-program-client: Compiler warning fixes

9 years agocassandra: Added latency_aware_routing connect-parameter.
Timo Sirainen [Mon, 10 Oct 2016 10:40:41 +0000 (13:40 +0300)] 
cassandra: Added latency_aware_routing connect-parameter.

There's currently no way to change the default settings for it.

9 years agolmtp: Handle lmtp_user_concurrency_limit before lmtp_rcpt_check_quota
Timo Sirainen [Mon, 10 Oct 2016 10:59:57 +0000 (13:59 +0300)] 
lmtp: Handle lmtp_user_concurrency_limit before lmtp_rcpt_check_quota

The quota lookup is more expensive, so it shouldn't be done unnecessarily.

9 years agolib-program-client: Add test suite for program client
Aki Tuomi [Fri, 7 Oct 2016 16:49:24 +0000 (19:49 +0300)] 
lib-program-client: Add test suite for program client

9 years agolib-program-client: Rename remote to unix
Aki Tuomi [Sun, 9 Oct 2016 17:19:22 +0000 (20:19 +0300)] 
lib-program-client: Rename remote to unix

This is to make more clear that the call requires
unix path and does not support TCP. There will be
TCP based API too later.

9 years agolib-program-client: Expose asynchronous API
Aki Tuomi [Fri, 7 Oct 2016 16:48:59 +0000 (19:48 +0300)] 
lib-program-client: Expose asynchronous API

9 years agolib-program-client: Whitespace fix
Aki Tuomi [Thu, 6 Oct 2016 08:57:27 +0000 (11:57 +0300)] 
lib-program-client: Whitespace fix

9 years agodoveadm-sync: Document end-date flag
Aki Tuomi [Mon, 10 Oct 2016 07:37:24 +0000 (10:37 +0300)] 
doveadm-sync: Document end-date flag

9 years agodoveadm-sync: Add end-date support
Aki Tuomi [Mon, 10 Oct 2016 07:36:52 +0000 (10:36 +0300)] 
doveadm-sync: Add end-date support

9 years agodoveadm-sync: Document start date
Aki Tuomi [Mon, 10 Oct 2016 07:13:12 +0000 (10:13 +0300)] 
doveadm-sync: Document start date

9 years agolib-compression: Fixed compler warnings and wrongly triggering asserts.
Timo Sirainen [Sun, 9 Oct 2016 20:34:18 +0000 (23:34 +0300)] 
lib-compression: Fixed compler warnings and wrongly triggering asserts.

Broken by 7f74811b7.

9 years agoglobal: Make sure i_stream_read() calls handle 0 and -2 return values correctly.
Timo Sirainen [Thu, 6 Oct 2016 10:50:59 +0000 (13:50 +0300)] 
global: Make sure i_stream_read() calls handle 0 and -2 return values correctly.

9 years agolog: Minor error logging and comment improvement.
Timo Sirainen [Thu, 6 Oct 2016 10:39:21 +0000 (13:39 +0300)] 
log: Minor error logging and comment improvement.

9 years agoimapc: Added imapc_max_line_length to limit maximum memory usage.
Timo Sirainen [Thu, 6 Oct 2016 10:09:46 +0000 (13:09 +0300)] 
imapc: Added imapc_max_line_length to limit maximum memory usage.

The default is still unlimited, but this should be set to something smaller
for untrusted servers.

9 years agolib-index: Added test-mail-index-modseq unit test
Timo Sirainen [Thu, 6 Oct 2016 09:10:28 +0000 (12:10 +0300)] 
lib-index: Added test-mail-index-modseq unit test

9 years agolib-test: Fixed assert-crash in test_exit() with --enable-static-checker
Timo Sirainen [Wed, 5 Oct 2016 20:59:56 +0000 (23:59 +0300)] 
lib-test: Fixed assert-crash in test_exit() with --enable-static-checker

Fixes:
Panic: Missing t_pop() call

9 years agolib: Simplify static checker's job for i_free() macro.
Timo Sirainen [Wed, 5 Oct 2016 11:22:03 +0000 (14:22 +0300)] 
lib: Simplify static checker's job for i_free() macro.

9 years agolib: [ip]_free(mem) is now also guaranteed to set mem=NULL
Timo Sirainen [Wed, 5 Oct 2016 11:18:07 +0000 (14:18 +0300)] 
lib: [ip]_free(mem) is now also guaranteed to set mem=NULL

It was already doing it, but updated the macros and comments to make it
clear that this won't change in future. Changing this would only make it
more likely that bugs occur and the performance improvements would be
close to nonexistent.

9 years agolib-storage: Fixed assert-crash in mailbox_save_cancel()
Timo Sirainen [Wed, 5 Oct 2016 13:34:16 +0000 (16:34 +0300)] 
lib-storage: Fixed assert-crash in mailbox_save_cancel()

Broken by 05150df8f. Fixes:
Panic: file mail-storage.c: line 2137 (mailbox_save_context_reset): assertion failed: (ctx->saving)

9 years agolib-program-client: Add program-client from pigeonhole
Aki Tuomi [Mon, 12 Sep 2016 10:02:23 +0000 (13:02 +0300)] 
lib-program-client: Add program-client from pigeonhole

9 years agolib: If connect() fails with EADDRNOTAVAIL, retry it 4 more times.
Timo Sirainen [Tue, 27 Sep 2016 13:15:42 +0000 (16:15 +0300)] 
lib: If connect() fails with EADDRNOTAVAIL, retry it 4 more times.

This is needed on busy systems. Nicely explained in:
https://idea.popcount.org/2014-04-03-bind-before-connect/

9 years agoplugins/fts - make storage errors more informative
Phil Carmody [Wed, 5 Oct 2016 12:03:05 +0000 (15:03 +0300)] 
plugins/fts - make storage errors more informative

There are 3 different ways to fail ending a transaction (one
of which is itself just a record that something now unknown
previously failed). Identify which one in the logs.

Signed-off-by: Phil Carmody <phil@dovecot.fi>
9 years agolib-storage: autoexpunge mailboxes with wildcards didn't work with namespace prefix.
Timo Sirainen [Tue, 4 Oct 2016 14:31:26 +0000 (17:31 +0300)] 
lib-storage: autoexpunge mailboxes with wildcards didn't work with namespace prefix.

9 years agolib-index: If view syncing sees index is reset, always mark the view as inconsistent.
Timo Sirainen [Tue, 27 Sep 2016 16:48:14 +0000 (19:48 +0300)] 
lib-index: If view syncing sees index is reset, always mark the view as inconsistent.

Not only when the mailbox has messages, because that could still mess up
assumptions about UIDs. A somewhat better check could have been to do this
only when next_uid>1 (= there have been messages at some point in this
mailbox), but it's safer to just always mark the view as inconsistent.

9 years agolib-index: When finding a view is reset, don't attempt any further syncing.
Timo Sirainen [Tue, 27 Sep 2016 16:45:57 +0000 (19:45 +0300)] 
lib-index: When finding a view is reset, don't attempt any further syncing.

This could cause various errors to be logged, such as:
Error: Append with UID 7103, but next_uid = 7242

9 years agolib-index: Fixed potential assert-crash when view syncing sees a reset marker.
Timo Sirainen [Tue, 27 Sep 2016 16:41:25 +0000 (19:41 +0300)] 
lib-index: Fixed potential assert-crash when view syncing sees a reset marker.

It should never try to use main index map at that point, because
view_sync_have_expunges() looks changes only before the reset marker.
Fixes:

Error: Index .../dovecot.index lost messages without expunging (36 -> 27)

9 years agolib-storage: Make sure mailbox_sync*() fails if view is inconsistent afterwards.
Timo Sirainen [Tue, 27 Sep 2016 16:39:59 +0000 (19:39 +0300)] 
lib-storage: Make sure mailbox_sync*() fails if view is inconsistent afterwards.

9 years agoimap: If mailbox is inconsistent after syncing, don't try to sync message counts.
Timo Sirainen [Tue, 27 Sep 2016 16:38:26 +0000 (19:38 +0300)] 
imap: If mailbox is inconsistent after syncing, don't try to sync message counts.

This fixes (e.g. after doveadm force-resync):
Panic: Message count decreased

9 years agolib: uri-util: Implemented API to check generic URI syntax.
Stephan Bosch [Mon, 26 Sep 2016 19:04:44 +0000 (21:04 +0200)] 
lib: uri-util: Implemented API to check generic URI syntax.

This allows checking whether something is a valid URI of any type.
This change adds a test suite for the generic URI syntax, which is currently the main purpose of the API addition.
Apart from a few simple vality checks, the test suite also tests various URI examples from RFCs.

9 years agolib-http: uri: Removed unnecessary checking of percent encoding of query and fragment...
Stephan Bosch [Sun, 2 Oct 2016 12:18:35 +0000 (14:18 +0200)] 
lib-http: uri: Removed unnecessary checking of percent encoding of query and fragment parts.

This is now always performed in lib/uri-util.

9 years agolib: uri-util: Always fully check the syntax of percent encoding while parsing URI...
Stephan Bosch [Sun, 2 Oct 2016 12:14:48 +0000 (14:14 +0200)] 
lib: uri-util: Always fully check the syntax of percent encoding while parsing URI components.

9 years agolib-test: Fix memory leak in test-ostream
Aki Tuomi [Mon, 3 Oct 2016 07:08:45 +0000 (10:08 +0300)] 
lib-test: Fix memory leak in test-ostream

9 years agolib-test: Fix illegal memory access in test-ostream
Aki Tuomi [Mon, 3 Oct 2016 07:08:31 +0000 (10:08 +0300)] 
lib-test: Fix illegal memory access in test-ostream

9 years agoio: Add source filename
Aki Tuomi [Mon, 3 Oct 2016 06:11:23 +0000 (09:11 +0300)] 
io: Add source filename

This will make debugging alot easier
when you can see what the filename is as well.

9 years agolib-test: Added test_ostream for testing nonblocking ostreams.
Timo Sirainen [Fri, 30 Sep 2016 10:42:45 +0000 (13:42 +0300)] 
lib-test: Added test_ostream for testing nonblocking ostreams.

9 years agolib-test: Moved test_istream code to its own test-istream.c file.
Timo Sirainen [Fri, 30 Sep 2016 10:10:13 +0000 (13:10 +0300)] 
lib-test: Moved test_istream code to its own test-istream.c file.

9 years agolib-test: Allow test_istream_set_*() for test-istream's children.
Timo Sirainen [Fri, 30 Sep 2016 10:04:48 +0000 (13:04 +0300)] 
lib-test: Allow test_istream_set_*() for test-istream's children.

It will internally find the test_istream from parents. This simplifies the
testing code so that it doesn't have to keep track of both the test_istream
and the final istream.

9 years agodirector: Ignore duplicates in director_servers setting.
Timo Sirainen [Tue, 27 Sep 2016 17:21:55 +0000 (20:21 +0300)] 
director: Ignore duplicates in director_servers setting.

9 years agolib-storage: mail_user_dup() should duplicate also userdb_fields.
Timo Sirainen [Fri, 30 Sep 2016 09:36:33 +0000 (12:36 +0300)] 
lib-storage: mail_user_dup() should duplicate also userdb_fields.

9 years agolib-storage: Don't reset mail_save_context.saving too early.
Timo Sirainen [Thu, 29 Sep 2016 11:15:32 +0000 (14:15 +0300)] 
lib-storage: Don't reset mail_save_context.saving too early.

If mailbox_save_using_mail() ended up in mail_storage_copy(), saving was set
to FALSE before the copy() method was finished running. This caused e.g.
notify plugin to think that this was a copy event instead of a save event.

Added comments and asserts to clarify how the logic should work between
all the different copying/moving/saving flags.

9 years agolib-storage: If mailbox_move() fails, reset mail_save_context.moving==FALSE
Timo Sirainen [Thu, 29 Sep 2016 11:00:49 +0000 (14:00 +0300)] 
lib-storage: If mailbox_move() fails, reset mail_save_context.moving==FALSE

9 years agodoveadm-import: Update manpage
Aki Tuomi [Thu, 29 Sep 2016 06:51:40 +0000 (09:51 +0300)] 
doveadm-import: Update manpage

9 years agodoveadm-import: Add -U parameter to specify source user
Aki Tuomi [Thu, 29 Sep 2016 07:17:05 +0000 (10:17 +0300)] 
doveadm-import: Add -U parameter to specify source user

When doing import, you can specify which user to use
as source user.

9 years agodoveadm-import: Use target user as source user
Aki Tuomi [Thu, 29 Sep 2016 07:15:24 +0000 (10:15 +0300)] 
doveadm-import: Use target user as source user

This is done to avoid spurious error messages
caused by being ran as root.

9 years agoimap-hibernate: Accept RFC DONE\IDLE
Aki Tuomi [Wed, 28 Sep 2016 10:34:46 +0000 (13:34 +0300)] 
imap-hibernate: Accept RFC DONE\IDLE

Change imap-hibernate to accept
DONE\r\n<tag> IDLE\r\n
as well, which is specified by RFC

9 years agomaster: Removed hardcoded listen() backlog limit.
Timo Sirainen [Tue, 27 Sep 2016 12:50:11 +0000 (15:50 +0300)] 
master: Removed hardcoded listen() backlog limit.

If it's already too large, the kernel will truncate it automatically. So
there shouldn't be any reason for us to explicitly limit it.

9 years agolib-storage: Update mailbox.recent_flags_count correctly.
Timo Sirainen [Tue, 27 Sep 2016 10:28:15 +0000 (13:28 +0300)] 
lib-storage: Update mailbox.recent_flags_count correctly.

The counter was increased even if the UID was already in recent_flags.
This is the only place where I found that recent_flags and
recent_flags_count could become desynced (which they definitely were in
a core dump), so hopefully this fixes assert-crashes like:

Panic: file index-status.c: line 130 (index_storage_get_open_status): assertion failed: (status_r->recent <= status_r->messages)

9 years agodsync: Virtual sizes weren't exported properly with -I parameter.
Timo Sirainen [Tue, 27 Sep 2016 10:50:51 +0000 (13:50 +0300)] 
dsync: Virtual sizes weren't exported properly with -I parameter.

Although they were incorrectly being exported with -T parameter. This makes
-I work without assert-crashing.

9 years agodsync: Renamed "max sync size" parameter from -S to -I.
Timo Sirainen [Tue, 27 Sep 2016 10:50:10 +0000 (13:50 +0300)] 
dsync: Renamed "max sync size" parameter from -S to -I.

-S can't be used because it was already used for the generic socket path,
so it didn't actually work.

9 years agodict-client: Fixed lock and ioloop wait timings in log messages.
Timo Sirainen [Mon, 26 Sep 2016 12:38:27 +0000 (15:38 +0300)] 
dict-client: Fixed lock and ioloop wait timings in log messages.

Previously it was logging the total amount of time spent on lock waits or on
ioloop during the existence of the entire process, rather than how much time
the command itself was spending on those. This wasn't very useful.
Now it also tries to separate the time spent on the main ioloop and in
dict_wait().

9 years agodict-client: Don't return "Dict server timeout" too early.
Timo Sirainen [Mon, 26 Sep 2016 13:44:21 +0000 (16:44 +0300)] 
dict-client: Don't return "Dict server timeout" too early.

This could have happened when many dict commands were being run without
the timeout being reset in the middle.

9 years agodict-client: Remove timeout when there are only background commands.
Timo Sirainen [Mon, 26 Sep 2016 13:34:23 +0000 (16:34 +0300)] 
dict-client: Remove timeout when there are only background commands.

Normally the timeout wasn't added in the first place, but it was if a
non-background command was added first and it was followed by a background
command.

9 years agologin proxy: Don't leak connections if reconnect fails with "Host is down"
Timo Sirainen [Fri, 23 Sep 2016 11:59:33 +0000 (14:59 +0300)] 
login proxy: Don't leak connections if reconnect fails with "Host is down"

Double-disconnection was also attempting to close the same fd twice, but I
think that couldn't have happened before this leak was fixed.

9 years agolib: Add test for pending io without timeouts
Aki Tuomi [Thu, 22 Sep 2016 11:14:23 +0000 (14:14 +0300)] 
lib: Add test for pending io without timeouts

9 years agolib: Update ioloop attributes
Aki Tuomi [Thu, 22 Sep 2016 11:13:43 +0000 (14:13 +0300)] 
lib: Update ioloop attributes

With pending IO, the ioloop attributes still need
updating, instead of just returning.

9 years agolib-mail: message_header_hash_more() now allows input in any slices.
Timo Sirainen [Thu, 22 Sep 2016 11:23:00 +0000 (14:23 +0300)] 
lib-mail: message_header_hash_more() now allows input in any slices.

There wasn't necessarily any guarantees that the input would be sliced in
such a way that the repeating '?' would be dropped the same way every time.

9 years agolib-mail: Removed obsolete comment about message_header_hash_more()
Timo Sirainen [Thu, 22 Sep 2016 11:16:12 +0000 (14:16 +0300)] 
lib-mail: Removed obsolete comment about message_header_hash_more()

pop3-migration plugin uses this function now, so it doesn't need to be kept
in sync.

9 years agopop3-migration: "first POP3 msg" warning didn't actually show the first one.
Timo Sirainen [Thu, 22 Sep 2016 10:47:42 +0000 (13:47 +0300)] 
pop3-migration: "first POP3 msg" warning didn't actually show the first one.

It was showing the first index in an array, which had nothing to do with
being the first POP3 message number.

9 years agodbox: mailbox_update() shouldn't reset pop3-uidl header.
Timo Sirainen [Thu, 22 Sep 2016 10:38:33 +0000 (13:38 +0300)] 
dbox: mailbox_update() shouldn't reset pop3-uidl header.

This broke reading migrated POP3 UIDLs.

9 years agologin-proxy: Fixed "Host is down" never reseting itself.
Timo Sirainen [Wed, 21 Sep 2016 17:50:24 +0000 (20:50 +0300)] 
login-proxy: Fixed "Host is down" never reseting itself.

Broken by c8eb8314a, which moved adding num_waiting_connections earlier.
After that it was never 0 at the check time.

9 years agolib: test-istream-chain fixes
Timo Sirainen [Wed, 21 Sep 2016 13:17:26 +0000 (16:17 +0300)] 
lib: test-istream-chain fixes

9 years agolib-dcrypt: Don't finalize encryption on o_stream_flush()
Timo Sirainen [Tue, 20 Sep 2016 15:08:10 +0000 (18:08 +0300)] 
lib-dcrypt: Don't finalize encryption on o_stream_flush()

For example the default o_stream_uncork() implementation enforces flushing
and it's probably better not to change that. In general there's really no
reason to perform the finalization at flush when the stream can't be written
to anymore (whereas lib-compression ostreams allow writes after flushes).

9 years agolib: Fixed istream-chain when it has multiple "previous streams".
Timo Sirainen [Wed, 21 Sep 2016 10:26:30 +0000 (13:26 +0300)] 
lib: Fixed istream-chain when it has multiple "previous streams".

Fixes assert:
Panic: file istream-chain.c: line 223 (i_stream_chain_read): assertion failed: (cur_data_pos == data_size)

Unit test for it by Stephan Bosch.

9 years agolib: Fixed ostream-failure-at with blocking parent stream.
Timo Sirainen [Wed, 21 Sep 2016 10:47:05 +0000 (13:47 +0300)] 
lib: Fixed ostream-failure-at with blocking parent stream.

Blocking ostream returns either a full success or a full failure. It can't
return that only n/m bytes were written.

Fixes assert:
Panic: file ostream.c: line 255 (o_stream_sendv_int): assertion failed: (!stream->blocking)

9 years agodoveadm fs get: Fixed logging error messages.
Timo Sirainen [Wed, 21 Sep 2016 09:19:18 +0000 (12:19 +0300)] 
doveadm fs get: Fixed logging error messages.

The error is in istream, not in fs.

9 years agoimap-login: Add missing brace
Aki Tuomi [Tue, 20 Sep 2016 18:06:22 +0000 (21:06 +0300)] 
imap-login: Add missing brace

9 years agoimap-proxy: Fix typo in comment
Aki Tuomi [Tue, 20 Sep 2016 15:51:18 +0000 (18:51 +0300)] 
imap-proxy: Fix typo in comment

9 years agoimap-login: Honor nopipelining during preauth
Aki Tuomi [Tue, 20 Sep 2016 12:02:42 +0000 (15:02 +0300)] 
imap-login: Honor nopipelining during preauth

9 years agolib-storage: remove unused internal_attribute argument from attribute_{get,set}
Josef 'Jeff' Sipek [Tue, 20 Sep 2016 12:51:29 +0000 (08:51 -0400)] 
lib-storage: remove unused internal_attribute argument from attribute_{get,set}

This removes an argument added in 9f37ef2a9192e7d47e3d7ac959080fd01120f2e9
but obsoleted (but not removed) in d1147c225f64596fc5eeb1cb2aab31b3c57d5215.

Not only does this change simplify the codebase, it actually brings the API
closer to what it was back in 2.2.

9 years agolib-dcrypt: Set NOPLUGIN_LDFLAGS to empty
Aki Tuomi [Tue, 20 Sep 2016 09:47:32 +0000 (12:47 +0300)] 
lib-dcrypt: Set NOPLUGIN_LDFLAGS to empty

Avoids -Wl,--as-needed here

9 years agolib-dcrypt: Makefile.am fix
Aki Tuomi [Tue, 20 Sep 2016 07:52:08 +0000 (10:52 +0300)] 
lib-dcrypt: Makefile.am fix

Remove dcrypt.c from openssl library and add missing slash

9 years agolib: Ensure handler_context is not NULL
Aki Tuomi [Fri, 16 Sep 2016 12:50:22 +0000 (15:50 +0300)] 
lib: Ensure handler_context is not NULL

handler context must not be NULL here.

9 years agolib: Prevent crash in ioloop
Aki Tuomi [Fri, 16 Sep 2016 12:49:36 +0000 (15:49 +0300)] 
lib: Prevent crash in ioloop

If only non-fd sources and no timeouts are
in ioloop, prevent crash and unnecessary
waiting when there are pending IOs.

9 years agolib: Assert if i_stream_create_seekable_path(temp_path_prefix==NULL)
Timo Sirainen [Mon, 19 Sep 2016 13:20:14 +0000 (16:20 +0300)] 
lib: Assert if i_stream_create_seekable_path(temp_path_prefix==NULL)

If the stream becomes large enough it would crash then in a callback
function, which makes debugging more difficult.

9 years agofts-plugin: Remove NULL assert
Aki Tuomi [Mon, 19 Sep 2016 09:27:16 +0000 (12:27 +0300)] 
fts-plugin: Remove NULL assert

fts_backend_update_deinit will set box to NULL and call
update_set_mailbox then. NULL check needs to be done
in backends.

9 years agofts-backend-solr: Check that box is not NULL
Aki Tuomi [Mon, 19 Sep 2016 09:26:46 +0000 (12:26 +0300)] 
fts-backend-solr: Check that box is not NULL

fts_backend_update_deinit will set box to NULL and call
update_set_mailbox then.