cd19995557
Do not pass logger objects around anymore. Shuffle some messages to make them consistent with the new logging API. Avoid using %v when a more specific verb exists for the argument types. The loggers are completely disabled (i.e. Sprintf is not even called) by default. They are only enabled when redirecting stdout to a file. Signed-off-by: Robin Jarry <robin@jarry.cc> Acked-by: Moritz Poldrack <moritz@poldrack.dev>
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)
|
|
logging.Infof("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)
|
|
}
|
|
|
|
logging.Infof("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)
|
|
|
|
}
|