]> git.ipfire.org Git - thirdparty/dovecot/core.git/log
thirdparty/dovecot/core.git
8 years agolib: ostream-multiplex - set ostream_private.parent
Timo Sirainen [Mon, 9 Oct 2017 10:19:32 +0000 (13:19 +0300)] 
lib: ostream-multiplex - set ostream_private.parent

Unlike with istream-multiplex, there are no issues with I/Os. Only the
parent stream will have the I/O. Using the default parent adds the
missing methods that otherwise would have needed to be implemented:
 - cork
 - flush_pending
 - switch_ioloop

8 years agolib: istream-multiplex - Forward i_stream_switch_ioloop() to parent
Timo Sirainen [Mon, 9 Oct 2017 10:14:23 +0000 (13:14 +0300)] 
lib: istream-multiplex - Forward i_stream_switch_ioloop() to parent

Most istreams do this because istream_private.parent is set to the parent
stream, but this can't be done with istream-multiplex. The main problem
with attempting to do the same with istream-multiplex is that the different
channels don't share the same I/O. Just because one channel received data
doesn't mean that other channels received any data. (It would be possible
to solve this by implementing a new method that allows overriding
i_stream_set_io(), but I'm not sure if that's a good idea either.)

8 years agoacl: Fix compiler warning with -Wstrict-bool
Timo Sirainen [Sun, 8 Oct 2017 22:22:47 +0000 (01:22 +0300)] 
acl: Fix compiler warning with -Wstrict-bool

8 years agoacl: Fix checking create (k) permission in global acl-file
Timo Sirainen [Fri, 6 Oct 2017 13:55:28 +0000 (16:55 +0300)] 
acl: Fix checking create (k) permission in global acl-file

Just because the global ACL file hasn't changed since it was last refreshed
for another ACL object, it doesn't mean that those ACLs don't need to be
applied to this ACL object.

This didn't usually cause problems, because the initial ACL object refresh
was always done due to local-path refresh returning "needs a refresh".
The only exception was when acl_object_init_from_parent() was called,
because it added an empty non-NULL validity for the local-path, so the
"needs a refresh" wasn't returned. This happened only when trying to
CREATE or RENAME mailbox under a parent where user didn't have create
permissions.

This affected only when using a single global acl-file, not when using
global acl directory containing per-mailbox files.

8 years agoacl: Cleanup - move code to a new acl_vfile_validity_has_changed()
Timo Sirainen [Fri, 6 Oct 2017 13:54:20 +0000 (16:54 +0300)] 
acl: Cleanup - move code to a new acl_vfile_validity_has_changed()

8 years agoacl: Fix checking whether global acl-file has changed
Timo Sirainen [Fri, 6 Oct 2017 13:44:01 +0000 (16:44 +0300)] 
acl: Fix checking whether global acl-file has changed

We always assumed that it was changed and re-read it.

8 years agoauth: Fix %{ldap_dn} change to compile with v2.2 API
Timo Sirainen [Fri, 6 Oct 2017 13:30:11 +0000 (16:30 +0300)] 
auth: Fix %{ldap_dn} change to compile with v2.2 API

8 years agoauth: Expand %{ldap_dn} to ldap_get_dn().
Sergey Kitov [Fri, 15 Sep 2017 12:17:08 +0000 (15:17 +0300)] 
auth: Expand %{ldap_dn} to ldap_get_dn().

8 years agolib: iostream-multiplex tests - Fix hangs by setting the pipe fds non-blocking
Timo Sirainen [Thu, 5 Oct 2017 17:25:29 +0000 (20:25 +0300)] 
lib: iostream-multiplex tests - Fix hangs by setting the pipe fds non-blocking

8 years agolib: istream-multiplex - Minor code cleanup
Timo Sirainen [Thu, 5 Oct 2017 17:24:11 +0000 (20:24 +0300)] 
lib: istream-multiplex - Minor code cleanup

Avoid propagating the error twice, and avoid any confusion about what "got"
actually contains.

8 years agodirector: When ring is synced, purge any pending "removed" directors
Timo Sirainen [Thu, 5 Oct 2017 09:34:10 +0000 (12:34 +0300)] 
director: When ring is synced, purge any pending "removed" directors

This allows adding a director back to the ring without having to wait for 30
seconds.

8 years agodirector: Rename director_delayed_dir_remove_timeout() to director_hosts_purge_removed()
Timo Sirainen [Tue, 3 Oct 2017 13:40:32 +0000 (16:40 +0300)] 
director: Rename director_delayed_dir_remove_timeout() to director_hosts_purge_removed()

This allows using it for other purposes without having a confusing name.

8 years agodirector: Fix potential panic when director is alone
Timo Sirainen [Thu, 5 Oct 2017 13:12:38 +0000 (16:12 +0300)] 
director: Fix potential panic when director is alone

If director is alone and it can't connect to other directors, it might crash
with:

Panic: file director.c: line 318 (director_set_ring_synced): assertion failed: (!dir->ring_synced)

8 years agodirector: Allow doveadm director ring remove for the same director
Timo Sirainen [Thu, 5 Oct 2017 08:51:23 +0000 (11:51 +0300)] 
director: Allow doveadm director ring remove for the same director

Fixes:
Panic: file doveadm-connection.c: line 859 (doveadm_connection_cmd_run): assertion failed: (conn->dir->right == NULL && conn->dir->left == NULL)

8 years agodirector: Don't crash on doveadm director ring remove for unknown director
Timo Sirainen [Thu, 5 Oct 2017 08:49:31 +0000 (11:49 +0300)] 
director: Don't crash on doveadm director ring remove for unknown director

Ring syncing isn't started, so it shouldn't try to wait for ring sync.

Fixes:
Panic: file doveadm-connection.c: line 859 (doveadm_connection_cmd_run): assertion failed: (conn->dir->right == NULL && conn->dir->left == NULL)

8 years agodirector: Don't crash if DIRECTOR-REMOVE is received for itself
Timo Sirainen [Thu, 5 Oct 2017 08:46:55 +0000 (11:46 +0300)] 
director: Don't crash if DIRECTOR-REMOVE is received for itself

This triggers the director removal from the ring, which causes the
connection to be destroyed. But since we're still in the middle of handling
the connection it needs refcounting.

8 years agodirector: Fix ring sync wait after DIRECTOR-REMOVE
Timo Sirainen [Thu, 14 Sep 2017 15:13:05 +0000 (18:13 +0300)] 
director: Fix ring sync wait after DIRECTOR-REMOVE

It was sending OK twice, and the first OK was too early.

8 years agodirector: Ignore CONNECT requests to hosts that have been removed already
Timo Sirainen [Thu, 14 Sep 2017 14:59:05 +0000 (17:59 +0300)] 
director: Ignore CONNECT requests to hosts that have been removed already

8 years agodirector: After CONNECT was received, make sure we disconnect
Timo Sirainen [Thu, 14 Sep 2017 14:57:29 +0000 (17:57 +0300)] 
director: After CONNECT was received, make sure we disconnect

The remote side won't be reading anything after the CONNECT, so we have to
disconnect anyway. If we decide that the CONNECT request is wrong, reconnect
after a short delay and hope that the remote agrees with us the next time.

8 years agodirector: When director is removed, notify it before disconnecting
Timo Sirainen [Thu, 14 Sep 2017 14:48:50 +0000 (17:48 +0300)] 
director: When director is removed, notify it before disconnecting

This way the removed director will know that it's been removed, and it
can also more quickly forward the removal to other directors.

8 years agodirector: Don't reset directors' last_network_failure while handshaking
Timo Sirainen [Thu, 14 Sep 2017 14:38:24 +0000 (17:38 +0300)] 
director: Don't reset directors' last_network_failure while handshaking

The reset is done mainly to make it faster for a director that has been down
to connect back to the ring, without other directors still thinking that
it's down. But DIRECTOR that is sent during handshake says nothing about
whether the director is up at the moment or not.

8 years agodirector: Log info line for every incoming/outgoing connection
Timo Sirainen [Thu, 14 Sep 2017 14:35:02 +0000 (17:35 +0300)] 
director: Log info line for every incoming/outgoing connection

This can help with debugging problems.

8 years agodirector: Cleanup - move code to a new director_log_connect()
Timo Sirainen [Thu, 14 Sep 2017 14:33:19 +0000 (17:33 +0300)] 
director: Cleanup - move code to a new director_log_connect()

Also adds a missing ')' to the log line.

8 years agodirector: Log info line whenever a director is added/removed from ring
Timo Sirainen [Thu, 14 Sep 2017 14:29:48 +0000 (17:29 +0300)] 
director: Log info line whenever a director is added/removed from ring

This can help with debugging problems.

8 years agodirector: Improve debugging: Log ring desync when there is no right connection
Timo Sirainen [Thu, 14 Sep 2017 15:13:33 +0000 (18:13 +0300)] 
director: Improve debugging: Log ring desync when there is no right connection

8 years agodirector: When logging "ring SYNC lost", include sync seq number in message
Timo Sirainen [Thu, 14 Sep 2017 14:26:39 +0000 (17:26 +0300)] 
director: When logging "ring SYNC lost", include sync seq number in message

This can help with debugging.

8 years agodoveadm director ring remove: Wait ring sync before and after removal
Timo Sirainen [Thu, 14 Sep 2017 08:57:27 +0000 (11:57 +0300)] 
doveadm director ring remove: Wait ring sync before and after removal

This helps mainly with automated tests.

8 years agolib-master: master_service_init_log() - Switch log handlers only on the first call
Timo Sirainen [Tue, 3 Oct 2017 11:51:16 +0000 (14:51 +0300)] 
lib-master: master_service_init_log() - Switch log handlers only on the first call

The secondary calls were only done by mail_storage_service_*() calls. They
want to initialize the logging once, but afterwards they only care about
changing the log prefix. Switch to this behavior now explicitly.

This fixes behavior if logging functions are changed between
mail_storage_service_*() calls, so they don't get reset.

8 years agolib: Fix warning with gcc7's -Wint-in-bool-context
Timo Sirainen [Thu, 5 Oct 2017 09:47:17 +0000 (12:47 +0300)] 
lib: Fix warning with gcc7's -Wint-in-bool-context

8 years agodoveadm: Deliver remote logs over doveadm socket
Aki Tuomi [Thu, 24 Aug 2017 11:59:07 +0000 (14:59 +0300)] 
doveadm: Deliver remote logs over doveadm socket

8 years agodoveadm: Refactor server/client code to support versioning properly
Aki Tuomi [Thu, 24 Aug 2017 11:45:22 +0000 (14:45 +0300)] 
doveadm: Refactor server/client code to support versioning properly

This way we can distinguish between old and new server side

8 years agodoveadm-server: Refactor connection handshake and authentication
Aki Tuomi [Tue, 12 Sep 2017 10:43:30 +0000 (13:43 +0300)] 
doveadm-server: Refactor connection handshake and authentication

Simplifies next change

8 years agolib: Add multiplex stream support
Aki Tuomi [Tue, 22 Aug 2017 07:14:22 +0000 (10:14 +0300)] 
lib: Add multiplex stream support

This allows having multiple channels of data in single stream.

8 years agodirector: Fix HOST-RESET-USERS when all hosts are down
Timo Sirainen [Wed, 4 Oct 2017 12:41:03 +0000 (15:41 +0300)] 
director: Fix HOST-RESET-USERS when all hosts are down

If there were a lot of users being kicked, the host was flushed after the
initial round of user kills. This caused the rest of the user connections to
be just discarded instead of actually being killed.

8 years agodirector: Fix tracking user move count when user is freed early
Timo Sirainen [Wed, 4 Oct 2017 12:39:08 +0000 (15:39 +0300)] 
director: Fix tracking user move count when user is freed early

users_moving_count wasn't updated if the user was freed before killing it
finished. This caused "doveadm director flush" to hang while waiting for
the move count to drop to 0, which it never did. Also following flushes
were doing less work in parallel, or possibly even nothing since director
thought there were too many users already being moved.

8 years agoquota-clone: Always update dict
Aki Tuomi [Wed, 4 Oct 2017 07:32:17 +0000 (10:32 +0300)] 
quota-clone: Always update dict

ret_count and ret_bytes become zero if no quota rules
are specified, so we need to update the dict anyways.

Broken in 81d10aff29baede9ae4944d6c89790871123d11d

8 years agodsync: Add hashed_headers setting
Aki Tuomi [Fri, 22 Sep 2017 10:30:43 +0000 (13:30 +0300)] 
dsync: Add hashed_headers setting

This makes it possible to configure them

8 years agodsync: Fix typo, it's ibc not icb
Aki Tuomi [Fri, 22 Sep 2017 11:08:45 +0000 (14:08 +0300)] 
dsync: Fix typo, it's ibc not icb

8 years agodsync: Add missing space to handshake optional keys
Aki Tuomi [Mon, 25 Sep 2017 07:28:03 +0000 (10:28 +0300)] 
dsync: Add missing space to handshake optional keys

8 years agodoveadm proxy: Avoid DNS lookup for "host" if passdb also returns "hostip"
Timo Sirainen [Fri, 8 Sep 2017 08:02:29 +0000 (11:02 +0300)] 
doveadm proxy: Avoid DNS lookup for "host" if passdb also returns "hostip"

8 years agolmtp proxy: Avoid DNS lookup for "host" if passdb also returns "hostip"
Timo Sirainen [Fri, 8 Sep 2017 08:02:07 +0000 (11:02 +0300)] 
lmtp proxy: Avoid DNS lookup for "host" if passdb also returns "hostip"

8 years agoauth: Avoid DNS lookup for "host" if passdb returns also "hostip"
Timo Sirainen [Fri, 8 Sep 2017 08:01:20 +0000 (11:01 +0300)] 
auth: Avoid DNS lookup for "host" if passdb returns also "hostip"

8 years agolib: Fix compiler warning in var-expand-if
Timo Sirainen [Tue, 25 Jul 2017 07:39:43 +0000 (10:39 +0300)] 
lib: Fix compiler warning in var-expand-if

8 years agolib: Fix static analyzer warnings in var-expand-if
Timo Sirainen [Tue, 25 Jul 2017 06:43:56 +0000 (09:43 +0300)] 
lib: Fix static analyzer warnings in var-expand-if

8 years agovar-expand-if: Remove unused variable par_start
Aki Tuomi [Mon, 24 Jul 2017 15:30:01 +0000 (18:30 +0300)] 
var-expand-if: Remove unused variable par_start

8 years agovar-expand: Add tests for var_expand conditionals
Aki Tuomi [Mon, 24 Jul 2017 10:31:49 +0000 (13:31 +0300)] 
var-expand: Add tests for var_expand conditionals

8 years agovar-expand: Add support for conditionals
Aki Tuomi [Mon, 24 Jul 2017 10:31:02 +0000 (13:31 +0300)] 
var-expand: Add support for conditionals

%{if;value-a,op,value-b:true-value:false-value}

8 years agodirector: Remember backends' hostnames and send them in login reply.
Timo Sirainen [Mon, 19 Oct 2015 10:49:54 +0000 (13:49 +0300)] 
director: Remember backends' hostnames and send them in login reply.
This allows login processes to verify the remote server's hostname in SSL
certificate.

8 years agodirector: Run director/host changing doveadm commands only after ring is synced
Timo Sirainen [Fri, 18 Aug 2017 08:51:36 +0000 (11:51 +0300)] 
director: Run director/host changing doveadm commands only after ring is synced

If the ring sync is still pending, the doveadm command may become reverted.
This doesn't fully prevent problems caused by sending doveadm commands
simultaneously to multiple directors, but it should prevent issues when
only a single director is used for doveadm commands.

It would have been nice to enable this also for HOST/DIRECTOR-LIST commands,
but they don't support returning a ring timeout error without changing the
protocol. It's a bit too much effort to change that for now.

8 years agodirector: doveadm HOST-* commands now wait for ring sync before returning OK
Timo Sirainen [Mon, 14 Aug 2017 07:29:47 +0000 (10:29 +0300)] 
director: doveadm HOST-* commands now wait for ring sync before returning OK

This should make it easier for tests and maybe for scripts in general, so
they won't think the command failed when it just takes a while to finish.

8 years agodirector: Cleanup - Doveadm commands now return enum doveadm_director_cmd_ret
Timo Sirainen [Mon, 14 Aug 2017 07:06:34 +0000 (10:06 +0300)] 
director: Cleanup - Doveadm commands now return enum doveadm_director_cmd_ret

8 years agodirector: Cleanup - Move all doveadm commands into an array.
Timo Sirainen [Mon, 14 Aug 2017 07:01:01 +0000 (10:01 +0300)] 
director: Cleanup - Move all doveadm commands into an array.

8 years agocassandra: Timestamp should be in microseconds, not milliseconds
Timo Sirainen [Tue, 19 Sep 2017 11:48:54 +0000 (14:48 +0300)] 
cassandra: Timestamp should be in microseconds, not milliseconds

8 years agocassandra: Fix paged queries to work again
Timo Sirainen [Wed, 13 Sep 2017 12:16:59 +0000 (15:16 +0300)] 
cassandra: Fix paged queries to work again

When continuing the result, consistency was reset to 0 (=ANY), which caused
the queries to fail. There's no need to initialize the statement again when
continuing it. Also set result->consistency to be correct mainly for
debugging purposes.

8 years agocassandra: Disable prepared statements with protocol v3 and older
Timo Sirainen [Tue, 12 Sep 2017 10:23:51 +0000 (13:23 +0300)] 
cassandra: Disable prepared statements with protocol v3 and older

8 years agocassandra: Add support for prepared statements
Timo Sirainen [Tue, 22 Aug 2017 11:35:11 +0000 (14:35 +0300)] 
cassandra: Add support for prepared statements

8 years agocassandra: Cleanup - Create statement earlier
Timo Sirainen [Tue, 22 Aug 2017 10:55:15 +0000 (13:55 +0300)] 
cassandra: Cleanup - Create statement earlier

Simplifies the following changes

8 years agocassandra: sql_transaction_commit*() cleanup - handle multiple query failures earlier
Timo Sirainen [Thu, 24 Aug 2017 08:56:38 +0000 (11:56 +0300)] 
cassandra: sql_transaction_commit*() cleanup - handle multiple query failures earlier

This makes the handling same for the sync and async method. It also
simplifies code for the following commits.

8 years agocassandra: sql_transaction_commit_s() - Set query_type correctly
Timo Sirainen [Thu, 24 Aug 2017 08:13:32 +0000 (11:13 +0300)] 
cassandra: sql_transaction_commit_s() - Set query_type correctly

The queries were all sent with READ type instead of WRITE/DELETE. This
meant they were using potentially wrong consistency values. Although
synchronous commits aren't actually used anywhere, so this practically
this doesn't fix anything right now.

8 years agocassandra: sql_transaction_commit_s() - Don't allow multi-query transactions
Timo Sirainen [Thu, 24 Aug 2017 08:09:05 +0000 (11:09 +0300)] 
cassandra: sql_transaction_commit_s() - Don't allow multi-query transactions

They were already denied for asynchronous commits. Also the synchronous
commits aren't actually used anywhere, so this shouldn't break anything.

8 years agodict-sql: Use prepared statements
Timo Sirainen [Thu, 7 Sep 2017 12:40:16 +0000 (15:40 +0300)] 
dict-sql: Use prepared statements

Create a hash table of query template -> prepared statement and fill it out
as needed. This could have been done some alternative ways that wouldn't
require building the string first, but this should still be fast enough and
much easier to implement.

8 years agodict-sql: Flush pending atomic_inc on set, and pending set on atomic_inc
Timo Sirainen [Sat, 26 Aug 2017 20:27:21 +0000 (23:27 +0300)] 
dict-sql: Flush pending atomic_inc on set, and pending set on atomic_inc

8 years agodict-sql: Cleanup - change query generator functions to return statement
Timo Sirainen [Sat, 26 Aug 2017 20:17:45 +0000 (23:17 +0300)] 
dict-sql: Cleanup - change query generator functions to return statement

Instead of query+params. This is in preparation for the following changes.

8 years agodict-sql: Cleanup - Remove unnecessary code
Timo Sirainen [Tue, 15 Aug 2017 13:50:16 +0000 (16:50 +0300)] 
dict-sql: Cleanup - Remove unnecessary code

The values are explicitly added to params. sql_dict_update_query() doesn't
add them again. Since the "diff" parameter is already a long long type,
this avoids unnecessary conversion to string and back.

8 years agodict-sql: Use sql_statement_bind_*()
Timo Sirainen [Tue, 15 Aug 2017 13:38:33 +0000 (16:38 +0300)] 
dict-sql: Use sql_statement_bind_*()

8 years agodict-sql: Add signed "int" type
Timo Sirainen [Tue, 15 Aug 2017 12:37:01 +0000 (15:37 +0300)] 
dict-sql: Add signed "int" type

8 years agodict-sql: Use sql_statement_set_timestamp() instead of adding it to query
Timo Sirainen [Tue, 15 Aug 2017 11:55:48 +0000 (14:55 +0300)] 
dict-sql: Use sql_statement_set_timestamp() instead of adding it to query

8 years agodict-sql: Initial change to use sql_statement API
Timo Sirainen [Tue, 15 Aug 2017 11:46:10 +0000 (14:46 +0300)] 
dict-sql: Initial change to use sql_statement API

sql_statement_bind_*() will be followed by later changes.

8 years agodict-sql: Remove dict_sql_build_query.inc
Timo Sirainen [Tue, 15 Aug 2017 13:44:27 +0000 (16:44 +0300)] 
dict-sql: Remove dict_sql_build_query.inc

It's no longer useful with the current code.

8 years agolib-dict: Moved/removed explicit stack frames in dict drivers.
Timo Sirainen [Fri, 6 May 2016 09:19:21 +0000 (12:19 +0300)] 
lib-dict: Moved/removed explicit stack frames in dict drivers.

Added them back to dict_set/unset/atomic_inc() in dict.c. Others are
unlikely to be called many times.

8 years agodict-sql: Change "uint" type to mean 64bit instead of 32bit integer.
Timo Sirainen [Tue, 15 Aug 2017 11:27:40 +0000 (14:27 +0300)] 
dict-sql: Change "uint" type to mean 64bit instead of 32bit integer.

This is likely what is usually wanted (especially in e.g. quotas).
If someone actually wants it to be restricted to 32bit, we could add
uint32 later on.

8 years agolib-sql: Add support for prepared SQL statements.
Timo Sirainen [Tue, 22 Aug 2017 08:37:17 +0000 (11:37 +0300)] 
lib-sql: Add support for prepared SQL statements.

This initial implementation doesn't use prepared statements in drivers, but
simply generates the query string internally.

8 years agolib-sql: Explicitly specify used *_vfuncs methods for drivers.
Timo Sirainen [Tue, 22 Aug 2017 08:31:51 +0000 (11:31 +0300)] 
lib-sql: Explicitly specify used *_vfuncs methods for drivers.

This allows adding more methods without modifying all the existing drivers.

8 years agolib: When logging I/O or timeout leak, log also raw backtrace
Timo Sirainen [Tue, 8 Aug 2017 17:07:18 +0000 (20:07 +0300)] 
lib: When logging I/O or timeout leak, log also raw backtrace

This can be useful when trying to figure out where the io_loop_destroy() was
called from.

8 years agolib-storage: index: Made MIME FILENAME search criterion match case-insensitively.
Stephan Bosch [Tue, 23 May 2017 12:05:02 +0000 (14:05 +0200)] 
lib-storage: index: Made MIME FILENAME search criterion match case-insensitively.

8 years agodirector: Fix flush to kick the user also when all backends are down
Timo Sirainen [Tue, 19 Sep 2017 22:47:38 +0000 (01:47 +0300)] 
director: Fix flush to kick the user also when all backends are down

The user's host can't change, because there are no other hosts. So add a
new parameter to force the kick anyway.

8 years agodirector: Avoid "ring sync timeout" errors when all backends are down
Timo Sirainen [Thu, 14 Sep 2017 09:50:29 +0000 (12:50 +0300)] 
director: Avoid "ring sync timeout" errors when all backends are down

doveadm commands were failing with it. Also pending request failures were
logged as failing due to ring sync timeout, instead of because no hosts.

8 years agodirector: Delay calling state_change_callback() after user kick is finished
Timo Sirainen [Thu, 14 Sep 2017 10:02:40 +0000 (13:02 +0300)] 
director: Delay calling state_change_callback() after user kick is finished

Otherwise it can get into recursive loop and cause problems.

8 years agodoveadm director: Improve logging unexpected disconnections from director socket
Timo Sirainen [Thu, 14 Sep 2017 09:42:13 +0000 (12:42 +0300)] 
doveadm director: Improve logging unexpected disconnections from director socket

Previously it just logged "failed", which wasn't very understandable.

8 years agodirector: Fix crash when flush is run and all backends are down.
Timo Sirainen [Tue, 22 Aug 2017 13:32:32 +0000 (16:32 +0300)] 
director: Fix crash when flush is run and all backends are down.

Instead of moving the users elsewhere, just kill them and flush the backend.

8 years agonotify-status plugin: Use priv/status/<mailbox> for keys
Timo Sirainen [Wed, 20 Sep 2017 12:03:55 +0000 (15:03 +0300)] 
notify-status plugin: Use priv/status/<mailbox> for keys

priv/<mailbox>/status can't be used with dict-sql when <mailbox> has '/'.

8 years agonotify-status: Remove first_unseen_seq field
Timo Sirainen [Mon, 18 Sep 2017 20:04:55 +0000 (23:04 +0300)] 
notify-status: Remove first_unseen_seq field

The sequence number keeps changing, so it's very unlikely to be useful.
It's also not always as efficiently available as the other fields, so
better to avoid having it.

8 years agonotify-status: Provide access to all easy fields
Aki Tuomi [Mon, 4 Sep 2017 12:32:24 +0000 (15:32 +0300)] 
notify-status: Provide access to all easy fields

8 years agonotify-status: Add notify-status plugin
Aki Tuomi [Tue, 4 Jul 2017 11:22:19 +0000 (14:22 +0300)] 
notify-status: Add notify-status plugin

This enables updating a dictionary with mailbox
status information when the mailbox changes.

It requires notify_status_dict setting for specifying
the dict where the data is stored.

One can optionally use notify_status_mailbox patterns
for specifying which box(es) the status update is done.
Subsequent patterns are notify_status_mailbox2 and so forth.

One can also specify data format using notify_status_value
plugin setting.

8 years agolib: file_lock_set_unlink_on_free() - Avoid unlink() if another process is waiting...
Timo Sirainen [Tue, 12 Sep 2017 11:54:57 +0000 (14:54 +0300)] 
lib: file_lock_set_unlink_on_free() - Avoid unlink() if another process is waiting on the lock

8 years agolib-compression: Fix assert in i_stream_zlib_seek
Anton Yuzhaninov [Thu, 31 Aug 2017 00:49:17 +0000 (20:49 -0400)] 
lib-compression: Fix assert in i_stream_zlib_seek

Also fix same bug in i_stream_bzlib_seek, i_stream_lz4_seek, i_stream_lzma_seek.

8 years agomaster: Change service "connections are being dropped" warning interval to 1 second
Timo Sirainen [Fri, 14 Jul 2017 14:00:21 +0000 (17:00 +0300)] 
master: Change service "connections are being dropped" warning interval to 1 second

When this is happening, it's often accompanied with all kinds of other errors and
these warnings drown in them. Make them easier to notice by reducing the interval
from 60 seconds to 1 second.

8 years agodsync: Fix panic if syncing fails during attribute iteration
Timo Sirainen [Tue, 13 Jun 2017 18:00:23 +0000 (21:00 +0300)] 
dsync: Fix panic if syncing fails during attribute iteration

Fixes:
Panic: file dict.c: line 104 (dict_deinit): assertion failed: (dict->iter_count == 0)

8 years agolib-storage: mail_storage_set_critical() - don't free old error_string too early
Timo Sirainen [Fri, 25 Aug 2017 15:02:44 +0000 (18:02 +0300)] 
lib-storage: mail_storage_set_critical() - don't free old error_string too early

It may be used in one of the parameters.

8 years agolib-smtp: lmtp-client: Fixed handling of unexpected reply while sending RCPT TO commands.
Stephan Bosch [Tue, 12 Sep 2017 22:28:38 +0000 (00:28 +0200)] 
lib-smtp: lmtp-client: Fixed handling of unexpected reply while sending RCPT TO commands.

It caused a segfault.

8 years agodoveadm director kick: Fix -f parameter to work
Timo Sirainen [Fri, 8 Sep 2017 13:00:53 +0000 (16:00 +0300)] 
doveadm director kick: Fix -f parameter to work

It already worked as --passdb-field, but now it matches the usage string.

8 years agodsync: Ignore missing remote mailbox when doing unidirectional sync
Aki Tuomi [Tue, 5 Sep 2017 07:43:46 +0000 (10:43 +0300)] 
dsync: Ignore missing remote mailbox when doing unidirectional sync

If there are some folders on remote system that
are being ignored by remote brain, do not error out.

8 years agodoveadm: Actually use resolved IP address(es) in director flush
Aki Tuomi [Fri, 18 Aug 2017 11:58:37 +0000 (14:58 +0300)] 
doveadm: Actually use resolved IP address(es) in director flush

It left the IP variable unitialized which caused host parameter
to be left empty causing flush all. Flushing with IP address
was not affected.

8 years agodirector: Make sure users gets expired even on an idle director
Timo Sirainen [Thu, 10 Aug 2017 14:50:04 +0000 (17:50 +0300)] 
director: Make sure users gets expired even on an idle director

Normally expiring gets done while looking up users, but if nothing is doing
that on an idle director the users won't get expired. This can cause confusion
in "doveadm director status" output.

8 years agodoveconf: Preserve import_environment when execing binary
Timo Sirainen [Wed, 7 Jun 2017 22:03:13 +0000 (01:03 +0300)] 
doveconf: Preserve import_environment when execing binary

This allows import_environment setting to work with doveadm and other
standalone tools.

8 years agolib-master, config: Move the responsibility of cleaning environment to doveconf
Timo Sirainen [Wed, 7 Jun 2017 21:40:12 +0000 (00:40 +0300)] 
lib-master, config: Move the responsibility of cleaning environment to doveconf

8 years agolib-master: Use master_service_import_environment() for preserving environments
Timo Sirainen [Wed, 7 Jun 2017 21:35:08 +0000 (00:35 +0300)] 
lib-master: Use master_service_import_environment() for preserving environments

8 years agolib-master: master_service_import_environment() - use a data stack frame
Timo Sirainen [Wed, 7 Jun 2017 21:33:32 +0000 (00:33 +0300)] 
lib-master: master_service_import_environment() - use a data stack frame

This way the caller doesn't have to do it.

8 years agomaster: Move master_set_import_environment() to lib-master
Timo Sirainen [Wed, 7 Jun 2017 21:24:19 +0000 (00:24 +0300)] 
master: Move master_set_import_environment() to lib-master

8 years agomaster: Append to existing DOVECOT_PRESERVE_ENVS instead of overwriting it
Timo Sirainen [Wed, 7 Jun 2017 21:20:38 +0000 (00:20 +0300)] 
master: Append to existing DOVECOT_PRESERVE_ENVS instead of overwriting it