diff options
author | Milan Crha <mcrha@redhat.com> | 2015-10-08 09:04:26 +0200 |
---|---|---|
committer | Milan Crha <mcrha@redhat.com> | 2015-10-08 09:09:42 +0200 |
commit | 132467c604a4d2ab710d9f8e4d573e2cb8c6db86 (patch) | |
tree | 437c46251bba1cf66b1f54da5f2a7ca7df34813a | |
parent | 2030e471a26b3b51dc0e911028713028f82de532 (diff) | |
download | evolution-data-server-132467c604a4d2ab710d9f8e4d573e2cb8c6db86.tar.gz |
Bug 748636 - [IMAPx] Disable LIST-EXTENDED extension for Cyrus servers
-rw-r--r-- | camel/providers/imapx/camel-imapx-server.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/camel/providers/imapx/camel-imapx-server.c b/camel/providers/imapx/camel-imapx-server.c index e70fd95b7..89bd8d32c 100644 --- a/camel/providers/imapx/camel-imapx-server.c +++ b/camel/providers/imapx/camel-imapx-server.c @@ -610,7 +610,7 @@ imapx_server_stash_command_arguments (CamelIMAPXServer *is) is->priv->status_data_items = g_string_free (buffer, FALSE); g_free (is->priv->list_return_opts); - if (CAMEL_IMAPX_HAVE_CAPABILITY (is->priv->cinfo, LIST_EXTENDED)) { + if (!is->priv->is_cyrus && CAMEL_IMAPX_HAVE_CAPABILITY (is->priv->cinfo, LIST_EXTENDED)) { buffer = g_string_new ("CHILDREN SUBSCRIBED"); if (CAMEL_IMAPX_HAVE_CAPABILITY (is->priv->cinfo, LIST_STATUS)) g_string_append_printf ( @@ -1792,6 +1792,17 @@ imapx_untagged_ok_no_bad (CamelIMAPXServer *is, if (cinfo) imapx_free_capability (cinfo); c (is->priv->tagprefix, "got capability flags %08x\n", is->priv->cinfo ? is->priv->cinfo->capa : 0xFFFFFFFF); + + if (is->priv->context->sinfo->text) { + guint32 list_extended = imapx_lookup_capability ("LIST-EXTENDED"); + + is->priv->is_cyrus = is->priv->is_cyrus || camel_strstrcase (is->priv->context->sinfo->text, "cyrus"); + if (is->priv->is_cyrus && is->priv->cinfo && (is->priv->cinfo->capa & list_extended) != 0) { + /* Disable LIST-EXTENDED for cyrus servers */ + c (is->priv->tagprefix, "Disabling LIST-EXTENDED extension for a Cyrus server\n"); + is->priv->cinfo->capa &= ~list_extended; + } + } imapx_server_stash_command_arguments (is); } break; |