On 13/12/2020 05:59, Mar Alegre wrote:> Hello,
>
> I have encountered what I believe to be a bug, or at least inaccurate
> documentation. I am running version 2.3.4.1 of Dovecot (installed via
> the default repo for Debian 10), so my apologies if this has been
> fixed in a more recent version. I tried to look for changelogs but was
> not able to find any.
>
> The `doveadm mailbox delete` command accepts flags `-e` and `-s`
> (among others). The flags are described by both the man pages and the
> wiki as follows:
>
> - `-e`: Require mailboxes to be empty before deleting.
> - `-s`: Unsubscribe deleted mailboxes.
>
> Based on these descriptions, I would expect that when both of these
> flags are combined, a directory that is not empty would be neither
> deleted nor unsubscribed. However, I have discovered that when I run
> the command `doveadm mailbox delete -u $myusername -e -s
> $non_empty_dir`, the result is that the directory is not deleted, but
> it *is* unsubscribed.
>
> I assume this is a bug, but if it is intended, the documentation
> should probably be updated to more clearly communicate that the `-s`
> flag will cause a directory to be unsubscribed even if it is not deleted.
>
> Best,
> Mar Alegre
Hopefully this will fix the issue, allowing the unsubscribe to go ahead
only if the delete did not return an error (<0). There are some cases,
namely? mailbox not open, in which 0 is returned without deleting the
mailbox (autocreated mailboxes) or the delete is done without checking
for an empty mailbox, but I guess those are not relevant when calling
the delete from doveadm, though I may be wrong on that.
--- doveadm/doveadm-mail-mailbox.c.orig??? 2020-12-13 16:58:59.589077259
+0100
+++ doveadm/doveadm-mail-mailbox.c??? 2020-12-13 17:00:28.326194491 +0100
@@ -383,7 +383,7 @@
???? ??? ??? doveadm_mail_failed_mailbox(_ctx, box);
???? ??? ??? ret = -1;
???? ??? }
-??? ??? if (ctx->ctx.subscriptions) {
+??? ??? if (ret2>=0 && ctx->ctx.subscriptions) {
???? ??? ??? if (mailbox_set_subscribed(box, FALSE) < 0) {
???? ??? ??? ??? i_error("Can't unsubscribe mailbox %s: %s", name,
???? ??? ??? ??? ??? mail_storage_get_last_internal_error(storage, NULL));