imapserver bugfix: fix expunging for messages marked junk/nonjunk

such messages would be marked expunged in the database, then the junkfilter
would be retrained for the removal of the message. but during retraining, the
expunged flag would be cleared again. the on-disk message file would still be
removed. so when opening the mailbox, the message would appear to still exist,
but cannot be retrieved from disk.

if you run "mox fixmsgsize", and you get warnings about missing message files,
you could create empty files (with "touch"), run "mox fixsmsgsize" again,
followed by "mox recalculatemailboxcounts <affectedaccount>" and run "mox
bumpuidvalidity <affectaccount>".

"mox backup" would probably also complain, as would "mox verifydata".

this may have caused the "wrong mailbox counts" error i got from "mox
verifydata" on a backup.
This commit is contained in:
Mechiel Lukkien 2023-08-23 16:13:39 +02:00
parent da9f1d9d0d
commit f029db3f47
No known key found for this signature in database

View file

@ -2915,6 +2915,9 @@ func (c *conn) xexpunge(uidSet *numSet, missingMailboxOK bool) (remove []store.M
removeIDs[i] = m.ID removeIDs[i] = m.ID
anyIDs[i] = m.ID anyIDs[i] = m.ID
mb.Sub(m.MailboxCounts()) mb.Sub(m.MailboxCounts())
// Update "remove", because RetrainMessage below will save the message.
remove[i].Expunged = true
remove[i].ModSeq = modseq
} }
qmr := bstore.QueryTx[store.Recipient](tx) qmr := bstore.QueryTx[store.Recipient](tx)
qmr.FilterEqual("MessageID", anyIDs...) qmr.FilterEqual("MessageID", anyIDs...)
@ -2923,7 +2926,10 @@ func (c *conn) xexpunge(uidSet *numSet, missingMailboxOK bool) (remove []store.M
qm = bstore.QueryTx[store.Message](tx) qm = bstore.QueryTx[store.Message](tx)
qm.FilterIDs(removeIDs) qm.FilterIDs(removeIDs)
_, err = qm.UpdateNonzero(store.Message{Expunged: true, ModSeq: modseq}) n, err := qm.UpdateNonzero(store.Message{Expunged: true, ModSeq: modseq})
if err == nil && n != len(removeIDs) {
err = fmt.Errorf("only %d messages set to expunged, expected %d", n, len(removeIDs))
}
xcheckf(err, "marking messages marked for deleted as expunged") xcheckf(err, "marking messages marked for deleted as expunged")
err = tx.Update(&mb) err = tx.Update(&mb)