ae83373fa6
Since panics still regularly "destroy" the terminal, it is hard to get a stack trace for panics you do not anticipate. This commit adds a panic handler that automatically creates a logfile inside the current working directory. It has to be added to every goroutine that is started and will repair the terminal on a panic. Signed-off-by: Moritz Poldrack <git@moritz.sh> Acked-by: Robin Jarry <robin@jarry.cc>
83 lines
1.7 KiB
Go
83 lines
1.7 KiB
Go
package imap
|
|
|
|
import (
|
|
"github.com/emersion/go-imap"
|
|
|
|
"git.sr.ht/~rjarry/aerc/logging"
|
|
"git.sr.ht/~rjarry/aerc/models"
|
|
"git.sr.ht/~rjarry/aerc/worker/types"
|
|
)
|
|
|
|
func (imapw *IMAPWorker) handleListDirectories(msg *types.ListDirectories) {
|
|
mailboxes := make(chan *imap.MailboxInfo)
|
|
imapw.worker.Logger.Println("Listing mailboxes")
|
|
done := make(chan interface{})
|
|
|
|
go func() {
|
|
defer logging.PanicHandler()
|
|
|
|
for mbox := range mailboxes {
|
|
if !canOpen(mbox) {
|
|
// no need to pass this to handlers if it can't be opened
|
|
continue
|
|
}
|
|
imapw.worker.PostMessage(&types.Directory{
|
|
Message: types.RespondTo(msg),
|
|
Dir: &models.Directory{
|
|
Name: mbox.Name,
|
|
Attributes: mbox.Attributes,
|
|
},
|
|
}, nil)
|
|
}
|
|
done <- nil
|
|
}()
|
|
|
|
if err := imapw.client.List("", "*", mailboxes); err != nil {
|
|
<-done
|
|
imapw.worker.PostMessage(&types.Error{
|
|
Message: types.RespondTo(msg),
|
|
Error: err,
|
|
}, nil)
|
|
} else {
|
|
<-done
|
|
imapw.worker.PostMessage(
|
|
&types.Done{Message: types.RespondTo(msg)}, nil)
|
|
}
|
|
}
|
|
|
|
func canOpen(mbox *imap.MailboxInfo) bool {
|
|
for _, attr := range mbox.Attributes {
|
|
if attr == imap.NoSelectAttr {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
|
|
func (imapw *IMAPWorker) handleSearchDirectory(msg *types.SearchDirectory) {
|
|
emitError := func(err error) {
|
|
imapw.worker.PostMessage(&types.Error{
|
|
Message: types.RespondTo(msg),
|
|
Error: err,
|
|
}, nil)
|
|
}
|
|
|
|
imapw.worker.Logger.Println("Executing search")
|
|
criteria, err := parseSearch(msg.Argv)
|
|
if err != nil {
|
|
emitError(err)
|
|
return
|
|
}
|
|
|
|
uids, err := imapw.client.UidSearch(criteria)
|
|
if err != nil {
|
|
emitError(err)
|
|
return
|
|
}
|
|
|
|
imapw.worker.PostMessage(&types.SearchResults{
|
|
Message: types.RespondTo(msg),
|
|
Uids: uids,
|
|
}, nil)
|
|
|
|
}
|