]>
git.ipfire.org Git - thirdparty/dovecot/core.git/log
Stephan Bosch [Mon, 9 Jan 2017 15:29:26 +0000 (16:29 +0100)]
lib-imap: test-imap-bodystructure: Added more tests.
Stephan Bosch [Mon, 9 Jan 2017 15:20:29 +0000 (16:20 +0100)]
lib-imap: test-imap-bodystructure: Improved handing of parse errors.
Actually show the parse error.
Stephan Bosch [Mon, 9 Jan 2017 15:16:46 +0000 (16:16 +0100)]
lib-imap: test-imap-bodystructure: Added support for more than one test case.
Stephan Bosch [Sun, 8 Jan 2017 21:50:02 +0000 (22:50 +0100)]
lib-imap: imap-bodystructure: Fixed parse error message about invalid Content-M5 field.
Timo Sirainen [Mon, 30 Jan 2017 13:12:04 +0000 (15:12 +0200)]
lib-storage: Set vsize extension when copying mails.
Timo Sirainen [Mon, 30 Jan 2017 13:11:45 +0000 (15:11 +0200)]
lib-storage: Add index_mail_get_vsize_extension()
Timo Sirainen [Mon, 30 Jan 2017 13:06:46 +0000 (15:06 +0200)]
lib-storage: Move index_mail.vsize_ext_id to mailbox.mail_vsize_ext_id
It's mailbox-specific, so it doesn't have to be looked up every time.
Also this is needed for the following fix.
Timo Sirainen [Wed, 14 Dec 2016 16:13:25 +0000 (18:13 +0200)]
imapc: Allow using LAYOUT=none without crashing.
Timo Sirainen [Sat, 28 Jan 2017 22:24:33 +0000 (00:24 +0200)]
imap: Don't unregister internal commands at deinit.
This allows plugins to unregister commands without errors being logged.
Timo Sirainen [Thu, 26 Jan 2017 20:42:09 +0000 (22:42 +0200)]
lib-storage: Lock autoexpunging so only a single process does it.
This hopefully helps to avoid duplicates with lazy_expunge plugin.
Timo Sirainen [Sat, 28 Jan 2017 23:08:23 +0000 (01:08 +0200)]
imap: Use struct mailbox_status.flags for FLAGS reply
Timo Sirainen [Sat, 28 Jan 2017 23:06:55 +0000 (01:06 +0200)]
lib-storage: Add struct mailbox_status.flags
This is similar to permanent_flags, except it tells which flags can be
changed at all in the session. Mainly it allows plugins to make changes to
IMAP's untagged FLAGS reply.
Timo Sirainen [Fri, 27 Jan 2017 19:36:14 +0000 (21:36 +0200)]
lib: io_loop_set_current() - do nothing if ioloop doesn't change
There's no need to call the switch callbacks if the ioloop doesn't change.
Martti Rannanjärvi [Fri, 27 Jan 2017 11:56:30 +0000 (13:56 +0200)]
doveadm: add doveadm_http_rawlog_dir setting
Timo Sirainen [Tue, 24 Jan 2017 15:18:07 +0000 (17:18 +0200)]
lib-fts: Fix assert-crash in fts_icu_lcase()
Fixes:
Panic: file fts-icu.c: line 152 (fts_icu_lcase): assertion failed: (err != U_BUFFER_OVERFLOW_ERROR)
Aki Tuomi [Fri, 27 Jan 2017 07:41:36 +0000 (09:41 +0200)]
lib-storage: Fix comparison to use virtual size instead of body virtual size
Was forgotten on
7f1ecb14
Timo Sirainen [Thu, 26 Jan 2017 07:55:22 +0000 (09:55 +0200)]
lib-index: Don't log error on dovecot.index.cache delete if it doesn't exist
For example if a cache is marked as corrupted and there is no cache, it's
not really an error that it doesn't exist.
Fixes:
Error: unlink(.../dovecot.index.cache) failed: No such file or directory (in mail-cache.c:29)
Timo Sirainen [Thu, 26 Jan 2017 17:51:34 +0000 (19:51 +0200)]
lib-storage: Filling vsize to index on read used wrong size
Aki Tuomi [Thu, 26 Jan 2017 07:42:26 +0000 (09:42 +0200)]
lib-storage: Clear virtual size from index if size is corrupted
Timo Sirainen [Sat, 14 Jan 2017 16:34:11 +0000 (18:34 +0200)]
fts: Fix search query generation when tokens are filtered out.
For example with English stopwords when searching "foo and bar" it should
be equilevant to "foo bar", since "and" is filtered out.
Aki Tuomi [Mon, 9 Jan 2017 08:43:01 +0000 (10:43 +0200)]
lib: Add t_hash helpers for hashing
Aki Tuomi [Wed, 25 Jan 2017 08:11:05 +0000 (10:11 +0200)]
lib-dict: Fix test-dict-sql in out-of-tree build
Aki Tuomi [Mon, 16 Jan 2017 13:31:10 +0000 (15:31 +0200)]
lib-dict: Add unit tests
Aki Tuomi [Mon, 16 Jan 2017 13:30:14 +0000 (15:30 +0200)]
lib-sql: Add test driver
Mock SQL driver
Aki Tuomi [Tue, 17 Jan 2017 07:59:54 +0000 (09:59 +0200)]
dict-sql: Fix iterator to not fail
When iterating a prefix without exact key flag,
do not fail when no more maps are matched if at least
one map has already matched.
Fixes
Error: dict_iterate_deinit failed: sql dict iterate failed for ...: Invalid/unmapped path
Aki Tuomi [Mon, 16 Jan 2017 13:29:25 +0000 (15:29 +0200)]
dict-sql: Move struct sql_dict to header
This allows dereferencing it on test programs
Aki Tuomi [Mon, 16 Jan 2017 12:01:57 +0000 (14:01 +0200)]
dict-sql: Do not increment on set
When merging sets do not use increment mode in builder.
Timo Sirainen [Mon, 23 Jan 2017 16:02:05 +0000 (18:02 +0200)]
director: "doveadm director move" to same host now refreshes user's timeout
This allows keeping user constantly in the same backend by just periodically
moving the user there.
Aki Tuomi [Tue, 24 Jan 2017 07:56:29 +0000 (09:56 +0200)]
global: Update http_server_request_set_destroy_callback usage
Aki Tuomi [Tue, 24 Jan 2017 07:55:49 +0000 (09:55 +0200)]
lib-http: Improve http_server_request_set_destroy_callback API
It now allows using non-void* context
Aki Tuomi [Sun, 22 Jan 2017 15:58:55 +0000 (17:58 +0200)]
global: Update http_client_request_set_destroy_callback usage
Aki Tuomi [Sun, 22 Jan 2017 15:56:19 +0000 (17:56 +0200)]
lib-http: Improve http_client_request_set_destroy_callback
It now allows using non-void* context
Stephan Bosch [Sun, 22 Jan 2017 22:55:24 +0000 (23:55 +0100)]
lib-http: client: Fixed handling of errors occurring for unsubmitted requests during http_client_request_send_payload().
When http_client_request_send_payload() is executed for the first time, the request is submitted.
Errors occurring during submission don't trigger a callback immediately.
Instead, these are queued in the client and will trigger a callback when an ioloop is run with the client.
However, in http_client_request_send_payload() the ioloop is never executed when the request fails that way, meaning that
the callback was never called. Since for example SOLR assumes the callback is always called for an error in
http_client_request_send_payload(), this causes all kinds of problems.
Fixed by manually handling the delayed request errors in http_client_request_send_payload() explicitly.
Aki Tuomi [Wed, 18 Jan 2017 11:46:12 +0000 (13:46 +0200)]
lib-sasl: Add OAUTHBEARER and XOAUTH2 mechanism
Aki Tuomi [Wed, 18 Jan 2017 11:45:27 +0000 (13:45 +0200)]
lib-sasl: Add API for setting and getting extra values
This allows setting extra parameters for authentication
and recovering extended result information from
mechanism.
Timo Sirainen [Fri, 20 Jan 2017 16:19:05 +0000 (18:19 +0200)]
imapc: Fix assert-crash on some connect failures
imapc_storage_has_modseqs() causes imapc_client_get_capabilities() to be
called, which assert-crashes if there isn't a valid connection:
Panic: file imapc-client.c: line 438 (imapc_client_get_capabilities): assertion failed: (conn != NULL)
Timo Sirainen [Fri, 20 Jan 2017 13:57:10 +0000 (15:57 +0200)]
director: Add more debug logging for moving & killing users
Timo Sirainen [Fri, 20 Jan 2017 14:06:48 +0000 (16:06 +0200)]
director: Fix USER-MOVE getting stuck if a director already uses the correct host
Timo Sirainen [Fri, 20 Jan 2017 14:03:12 +0000 (16:03 +0200)]
director: Ignore doveadm user move if host is already the same.
Timo Sirainen [Fri, 20 Jan 2017 13:54:27 +0000 (15:54 +0200)]
director: Make sure USER-KILLED isn't sent before USER-MOVE
If USER-MOVE was for a user that didn't exist, killing sent USER-KILLED
immediately before the forwarding USER-MOVE. This caused the move to get
stuck, giving errors like:
director: Error: Finishing user
3224731354 move timed out, its state may now be inconsistent (state=waiting-for-everyone)
Timo Sirainen [Fri, 20 Jan 2017 13:52:43 +0000 (15:52 +0200)]
director: Add assert to make sure USER-MOVE doesn't change tag
Aki Tuomi [Tue, 27 Dec 2016 07:45:58 +0000 (09:45 +0200)]
lib-storage: Copy cache decisions from inbox on create
Otherwise the decisions are definitely wrong, since
they are nonexistent. Copying from INBOX would make sense.
Aki Tuomi [Tue, 27 Dec 2016 07:44:52 +0000 (09:44 +0200)]
lib-index: Add mail_cache_decisions_copy
This allows priming cache decisions for a folder.
Aki Tuomi [Tue, 3 Jan 2017 10:50:58 +0000 (12:50 +0200)]
lib-index: Unconstify mail_cache_register_get_list
This way the result is usable as input for
mail_cache_register_fields.
Timo Sirainen [Fri, 20 Jan 2017 12:46:30 +0000 (14:46 +0200)]
lib-storage: Fix mailbox's vsize header check for mailboxes not in dovecot.list.index
If mailbox wasn't yet in the dovecot.list.index, mailbox_list_index_status()
for it returns FALSE and doesn't initialize the status. In some situations this
may have caused a non-empty mailbox's vsize to be returned as 0.
Juha Koho [Mon, 10 Oct 2016 22:13:49 +0000 (00:13 +0200)]
ssl: add ssl_curve_list setting for selecting ECHDE curves
Stephan Bosch [Tue, 10 Jan 2017 01:12:25 +0000 (02:12 +0100)]
lib-http: client: Make sure req->conn is only not NULL when that connection holds a reference to that request.
This consolidates the management of req->conn to one place, thereby preventing mishaps.
It makes sure req->conn is always properly assigned, making it more reliable.
This fixes a problem that emerged in the http-proxy.
Stephan Bosch [Thu, 19 Jan 2017 01:16:06 +0000 (02:16 +0100)]
lib-http: client: Keep connection reference throughout http_client_connection_return_response().
Before, it was held in two intervals.
Next commit requires this change, but it also simplifies this function significantly.
Timo Sirainen [Tue, 17 Jan 2017 17:49:39 +0000 (19:49 +0200)]
master: Remove unnecessary service listener start
The listening was already started later on in the same function. Also
in some cases it would have been started unnecessarily, like when service
was stopped or more processes were created immediately.
Martti Rannanjärvi [Fri, 30 Dec 2016 08:20:32 +0000 (10:20 +0200)]
doc: add ssl_dh to example-config
Josef 'Jeff' Sipek [Wed, 18 Jan 2017 09:46:15 +0000 (04:46 -0500)]
index: don't try to unlink in-memory cache file
Avoid these errors:
Error: unlink((in-memory index).cache) failed: No such file or directory (in mail-cache.c:29)
Timo Sirainen [Tue, 17 Jan 2017 18:34:51 +0000 (20:34 +0200)]
doveadm direcor add: Fix checking number as hostname.
521c0460fe705f32ea6899c8b1f101043fe0898c was completely broken.
Timo Sirainen [Tue, 17 Jan 2017 18:03:40 +0000 (20:03 +0200)]
doveconf: Don't read freed memory.
Giving -c parameter frees the returned orig_config_path.
Timo Sirainen [Tue, 17 Jan 2017 13:22:44 +0000 (15:22 +0200)]
doveadm direcor add: Don't accept number as a valid hostname.
This is usually a mistake. For example "doveadm director add -t host 100"
shouldn't be adding a new IP 100 (0.0.0.100)
Timo Sirainen [Tue, 17 Jan 2017 14:28:10 +0000 (16:28 +0200)]
stats plugin: Fix /proc/self/io fd leak on plugin deinit
This could have been a problem with doveadm-server processes if they had
service_count>1, because doveadm unloads all plugins between commands.
Timo Sirainen [Tue, 17 Jan 2017 14:23:50 +0000 (16:23 +0200)]
doveadm: Outgoing dsync TCP connections leaked socket
If doveadm-server was running with service_count>1, each dsync run leaked a
socket.
Timo Sirainen [Tue, 17 Jan 2017 17:21:08 +0000 (19:21 +0200)]
lib-dict: Compiler warning fix
Timo Sirainen [Mon, 16 Jan 2017 14:58:31 +0000 (16:58 +0200)]
dict-file: Fix potential crash when doing other dict calls during iteration.
If file was refreshed, the hash table was cleared, which broke the existing
iterators.
Timo Sirainen [Mon, 16 Jan 2017 15:12:41 +0000 (17:12 +0200)]
lib-dict: Add assert to make sure all iterators are deinitialized.
Timo Sirainen [Mon, 16 Jan 2017 14:57:21 +0000 (16:57 +0200)]
lib: Add asserts to make sure hash table isn't freed while it's frozen.
Timo Sirainen [Mon, 16 Jan 2017 21:55:17 +0000 (23:55 +0200)]
fts-solr: Escape {} chars when sending queries
Fixes:
java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986
Based on patch by Michael Welsh Duggan
Stephan Bosch [Tue, 17 Jan 2017 00:37:25 +0000 (01:37 +0100)]
lib-http: server: Do not generate a payload for a failure response for a HEAD request.
Stephan Bosch [Tue, 17 Jan 2017 00:36:10 +0000 (01:36 +0100)]
lib-http: server: Prevent sending response payload when it is not allowed by the specification.
For a HEAD request, the payload is omitted, but the associated headers are generated.
For the other cases, an assert failure is now triggered.
Aki Tuomi [Mon, 16 Jan 2017 07:37:05 +0000 (09:37 +0200)]
dict-sql: Fix flushing
Remove flushing from set, and add it to unset. Fixes
signal 11 crash caused by infinite recursion.
Aki Tuomi [Tue, 3 Jan 2017 15:21:33 +0000 (17:21 +0200)]
lib-storage: Add vsize extension to index
Keep virtual size in index, instead of cache
when it's less than 2^32-1. This helps when
cache becomes corrupted, and goes away, we
still have virtual sizes for quota calculations.
Timo Sirainen [Sun, 15 Jan 2017 17:56:32 +0000 (19:56 +0200)]
lib-storage: Fix assert-crash on mailbox_copy/move() failure
If mailbox_save_cancel() was being called outside mail_storage_copy()
it assert-crashed:
Panic: file mail-storage.c: line 2168 (mailbox_save_context_reset): assertion failed: (ctx->copying_via_save)
Timo Sirainen [Sat, 14 Jan 2017 14:11:37 +0000 (16:11 +0200)]
lib-storage: If namespaces weren't successfully created, don't autoexpunge at deinit.
Timo Sirainen [Sat, 14 Jan 2017 14:12:56 +0000 (16:12 +0200)]
lib-storage: Add struct mail_user.namespaces_created
This makes it easier to determine in mail_namespaces_added hook if the
namespaces being added are the initial ones or later ones.
Timo Sirainen [Sat, 14 Jan 2017 14:12:03 +0000 (16:12 +0200)]
lib-storage: Stop namespaces_added|created hooks immediately when user has failed
Timo Sirainen [Sat, 14 Jan 2017 14:10:15 +0000 (16:10 +0200)]
doveadm dict get: Support printing multiple values.
Timo Sirainen [Mon, 9 Jan 2017 18:32:12 +0000 (20:32 +0200)]
dict-sql: Support multiple values for lookups
The value's fields must be comma-separated without spaces, for example:
map {
value_field = field1,field2
value_type = string,uint
...
Only the first field is used for INSERTs and UPDATEs.
Timo Sirainen [Thu, 12 Jan 2017 18:35:12 +0000 (20:35 +0200)]
dict-client: Support multiple values for lookups
Timo Sirainen [Thu, 12 Jan 2017 18:22:38 +0000 (20:22 +0200)]
lib-dict: Add support for lookup to return multiple values
Implements only the initial stubs to the drivers.
Timo Sirainen [Sat, 14 Jan 2017 14:54:34 +0000 (16:54 +0200)]
dict-sql: Remove unnecessary "affected rows" tracking from dict_set()
This was useful for dict_atomic_inc(), but not for dict_set().
Fixes assert-crash with Cassandra:
Panic: file driver-cassandra.c: line 1350 (driver_cassandra_update): assertion failed: (affected_rows == NULL)
Timo Sirainen [Sat, 14 Jan 2017 14:45:06 +0000 (16:45 +0200)]
dict-sql: Fix previous "merge sets" to flush at commit
The last dict_set() within transaction was being ignored.
Timo Sirainen [Sat, 14 Jan 2017 13:10:17 +0000 (15:10 +0200)]
lib-storage: Fix accessing the same "raw" mailbox multiple times in process.
If the same file was opened as the raw mailbox multiple times, the previous
mail_index was cached by mail-index-alloc-cache. Opening it the second time
already contained a mail in the index, so trying to add another one logged
an error:
Error: Log synchronization error at seq=1,offset=256 for (in-memory index): Append with UID 1, but next_uid = 2
Timo Sirainen [Fri, 13 Jan 2017 18:39:42 +0000 (20:39 +0200)]
imapc: Fix re-sending retryable commands after reconnect
Timo Sirainen [Thu, 12 Jan 2017 14:20:40 +0000 (16:20 +0200)]
lib-storage: Allow namespaces_created hook to return failure via user error.
Timo Sirainen [Wed, 11 Jan 2017 22:53:54 +0000 (00:53 +0200)]
lib-storage: Improve namespace error message - include separator char.
It wasn't always obvious what the character should have been when
namespace didn't have an explicitly configured separator.
Aki Tuomi [Wed, 11 Jan 2017 17:43:30 +0000 (19:43 +0200)]
lib-dict-sql: Try merge sets to single update
This attempts to put mergeable keys into same
update instead of using multiple SQL statements.
Timo Sirainen [Fri, 23 Dec 2016 18:17:06 +0000 (13:17 -0500)]
lib-dcrypt: istream-decrypt - set stream_errno=EPIPE on unexpected EOF
Timo Sirainen [Tue, 10 Jan 2017 17:23:30 +0000 (19:23 +0200)]
configure: Link libsmtp before libdns
Fixes linking LIBDOVECOT when using .a libraries
Timo Sirainen [Tue, 10 Jan 2017 12:45:20 +0000 (14:45 +0200)]
lib-storage: Compile & indent fix for previous change.
Aki Tuomi [Thu, 5 Jan 2017 08:50:55 +0000 (10:50 +0200)]
lib-storage: Prevent recursion in header parsing
If header parsing error occurs and error handling tries
to get fields, such as Message-ID, it will cause
crash. This fixes problem by preventing reading from
non-cached headers while they are being parsed.
Fixes lmtp: Panic: file ../../../src/lib/array.h: line 219 (array_idx_i):
assertion failed: (idx * array->element_size < array->buffer->used)
Timo Sirainen [Mon, 9 Jan 2017 15:48:56 +0000 (17:48 +0200)]
cassandra: Support configuring heartbeat_interval and idle_timeout
Timo Sirainen [Tue, 10 Jan 2017 11:29:34 +0000 (13:29 +0200)]
director: Fix assert-crash when flush script takes too long
Fixes:
Panic: file director.c: line 966 (director_user_move_timeout): assertion failed: (user->kill_ctx->kill_state != USER_KILL_STATE_FLUSHING)
Timo Sirainen [Mon, 9 Jan 2017 18:31:35 +0000 (20:31 +0200)]
cassandra: Add support for "bigint" value type.
Timo Sirainen [Mon, 9 Jan 2017 20:39:09 +0000 (22:39 +0200)]
dict-client: When failing to resend commands after reconnect, their success is uncertain.
It's possible that the writes before the disconnection did actually finish
successfully. If any of them were commits, we need to return
DICT_COMMIT_RET_WRITE_UNCERTAIN.
Timo Sirainen [Mon, 9 Jan 2017 15:05:14 +0000 (17:05 +0200)]
dict-sql: Support transaction timestamps with Cassandra driver
Timo Sirainen [Mon, 9 Jan 2017 17:16:04 +0000 (19:16 +0200)]
dict-client: Pass through transaction timestamp to dict-server
Timo Sirainen [Mon, 9 Jan 2017 14:55:45 +0000 (16:55 +0200)]
lib-dict: Add dict_transaction_set_timestamp()
Timo Sirainen [Mon, 9 Jan 2017 17:10:25 +0000 (19:10 +0200)]
dict-ldap|fs: Explicitly specify used dict_vfuncs methods.
This was done for other dict drivers in
ade5567577dadb0b275c840208d3ad21a9f00a36
Timo Sirainen [Thu, 29 Dec 2016 18:17:57 +0000 (13:17 -0500)]
config: Fix checking if <path needs to be expanded
Timo Sirainen [Mon, 9 Jan 2017 13:12:48 +0000 (15:12 +0200)]
lmtp: Don't deliver truncated email when client disconnects before "." line
This didn't happen always, because the EOF was handled in two different
places in different ways.
Aki Tuomi [Mon, 9 Jan 2017 07:57:58 +0000 (09:57 +0200)]
auth-policy: Add missing settings
Aki Tuomi [Sun, 8 Jan 2017 18:09:33 +0000 (20:09 +0200)]
auth-policy: Enable SSL connections
Greg C [Wed, 4 Jan 2017 22:02:28 +0000 (14:02 -0800)]
auth-policy: hashed_password will always be blank, tell buffer it has data so str_len works when converting to hex
Aki Tuomi [Sun, 8 Jan 2017 16:44:32 +0000 (18:44 +0200)]
lib-program-client: Do not call program_client_fail twice
Fixes crash in program-client caused by use of freed memory.
Aki Tuomi [Sun, 25 Dec 2016 08:14:07 +0000 (10:14 +0200)]
istream-mmap: Mark stream eof on error and copy errno
Martti Rannanjärvi [Fri, 16 Dec 2016 18:27:09 +0000 (20:27 +0200)]
lib, lib-http: add HTTP_URL_ALLOW_PCT_NUL flag
This allows a URL to contain %00.