From 441730e1f7a27541d52d1aaccc59a8204a96d079 Mon Sep 17 00:00:00 2001 From: Alex Auvolat Date: Thu, 21 Jul 2022 12:50:44 +0200 Subject: Fix open_mailbox --- src/mail/incoming.rs | 2 +- src/mail/user.rs | 24 +++++++++++------------- 2 files changed, 12 insertions(+), 14 deletions(-) (limited to 'src/mail') diff --git a/src/mail/incoming.rs b/src/mail/incoming.rs index bc579ed..26ca52a 100644 --- a/src/mail/incoming.rs +++ b/src/mail/incoming.rs @@ -109,7 +109,7 @@ async fn incoming_mail_watch_process_internal( if Some(id) != inbox.as_ref().map(|b| b.id) { match user.open_mailbox_by_id(id, uidvalidity).await { Ok(mb) => { - inbox = mb; + inbox = Some(mb); } Err(e) => { inbox = None; diff --git a/src/mail/user.rs b/src/mail/user.rs index fd858d3..d921e6d 100644 --- a/src/mail/user.rs +++ b/src/mail/user.rs @@ -77,17 +77,15 @@ impl User { } if let Some((uidvalidity, Some(mbid))) = list.get_mailbox(name) { - let mb_opt = self.open_mailbox_by_id(mbid, uidvalidity).await?; - if let Some(mb) = &mb_opt { - let mb_uidvalidity = mb.current_uid_index().await.uidvalidity; - if mb_uidvalidity > uidvalidity { - list.update_uidvalidity(name, mb_uidvalidity); - self.save_mailbox_list(&list, ct).await?; - } + let mb = self.open_mailbox_by_id(mbid, uidvalidity).await?; + let mb_uidvalidity = mb.current_uid_index().await.uidvalidity; + if mb_uidvalidity > uidvalidity { + list.update_uidvalidity(name, mb_uidvalidity); + self.save_mailbox_list(&list, ct).await?; } - Ok(mb_opt) + Ok(Some(mb)) } else { - bail!("Mailbox does not exist: {}", name); + Ok(None) } } @@ -203,11 +201,11 @@ impl User { &self, id: UniqueIdent, min_uidvalidity: ImapUidvalidity, - ) -> Result>> { + ) -> Result> { { let cache = self.mailboxes.lock().unwrap(); if let Some(mb) = cache.get(&id).and_then(Weak::upgrade) { - return Ok(Some(mb)); + return Ok(mb); } } @@ -216,10 +214,10 @@ impl User { let mut cache = self.mailboxes.lock().unwrap(); if let Some(concurrent_mb) = cache.get(&id).and_then(Weak::upgrade) { drop(mb); // we worked for nothing but at least we didn't starve someone else - Ok(Some(concurrent_mb)) + Ok(concurrent_mb) } else { cache.insert(id, Arc::downgrade(&mb)); - Ok(Some(mb)) + Ok(mb) } } -- cgit v1.2.3