2019-01-13 16:18:10 -05:00
|
|
|
package imap
|
|
|
|
|
|
|
|
import (
|
2019-03-10 23:45:00 -04:00
|
|
|
"github.com/emersion/go-imap"
|
2020-09-12 15:05:02 +02:00
|
|
|
sortthread "github.com/emersion/go-imap-sortthread"
|
2019-03-10 23:45:00 -04:00
|
|
|
|
2019-05-17 20:57:10 -04:00
|
|
|
"git.sr.ht/~sircmpwn/aerc/worker/types"
|
2019-01-13 16:18:10 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
func (imapw *IMAPWorker) handleOpenDirectory(msg *types.OpenDirectory) {
|
|
|
|
imapw.worker.Logger.Printf("Opening %s", msg.Directory)
|
2019-04-28 13:01:56 +00:00
|
|
|
|
|
|
|
_, err := imapw.client.Select(msg.Directory, false)
|
|
|
|
if err != nil {
|
|
|
|
imapw.worker.PostMessage(&types.Error{
|
|
|
|
Message: types.RespondTo(msg),
|
|
|
|
Error: err,
|
|
|
|
}, nil)
|
|
|
|
} else {
|
|
|
|
imapw.worker.PostMessage(&types.Done{types.RespondTo(msg)}, nil)
|
2019-05-13 20:16:55 -04:00
|
|
|
if imapw.idleStop == nil {
|
|
|
|
imapw.idleStop = make(chan struct{})
|
|
|
|
}
|
2019-04-28 13:01:56 +00:00
|
|
|
}
|
2019-01-13 16:18:10 -05:00
|
|
|
}
|
2019-03-10 23:45:00 -04:00
|
|
|
|
|
|
|
func (imapw *IMAPWorker) handleFetchDirectoryContents(
|
|
|
|
msg *types.FetchDirectoryContents) {
|
|
|
|
|
|
|
|
imapw.worker.Logger.Printf("Fetching UID list")
|
|
|
|
|
2019-04-28 13:01:56 +00:00
|
|
|
seqSet := &imap.SeqSet{}
|
|
|
|
seqSet.AddRange(1, imapw.selected.Messages)
|
2020-09-12 15:05:02 +02:00
|
|
|
|
|
|
|
searchCriteria := &imap.SearchCriteria{
|
2019-04-28 13:01:56 +00:00
|
|
|
SeqNum: seqSet,
|
2020-09-12 15:05:02 +02:00
|
|
|
}
|
|
|
|
sortCriteria := translateSortCriterions(msg.SortCriteria)
|
|
|
|
|
|
|
|
var uids []uint32
|
|
|
|
|
|
|
|
// If the server supports the SORT extension, do the sorting server side
|
|
|
|
ok, err := imapw.client.sort.SupportSort()
|
|
|
|
if err == nil && ok && len(sortCriteria) > 0 {
|
|
|
|
uids, err = imapw.client.sort.UidSort(sortCriteria, searchCriteria)
|
|
|
|
// copy in reverse as msgList displays backwards
|
|
|
|
for i, j := 0, len(uids)-1; i < j; i, j = i+1, j-1 {
|
|
|
|
uids[i], uids[j] = uids[j], uids[i]
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if err != nil {
|
|
|
|
// Non fatal, but we do want to print to get some debug info
|
|
|
|
imapw.worker.Logger.Printf("can't check for SORT support: %v", err)
|
|
|
|
}
|
|
|
|
uids, err = imapw.client.UidSearch(searchCriteria)
|
|
|
|
}
|
2019-04-28 13:01:56 +00:00
|
|
|
if err != nil {
|
|
|
|
imapw.worker.PostMessage(&types.Error{
|
|
|
|
Message: types.RespondTo(msg),
|
|
|
|
Error: err,
|
|
|
|
}, nil)
|
|
|
|
} else {
|
|
|
|
imapw.worker.Logger.Printf("Found %d UIDs", len(uids))
|
2019-11-10 14:17:55 -08:00
|
|
|
if len(imapw.seqMap) < len(uids) {
|
|
|
|
imapw.seqMap = make([]uint32, len(uids))
|
|
|
|
}
|
2019-04-28 13:01:56 +00:00
|
|
|
imapw.worker.PostMessage(&types.DirectoryContents{
|
|
|
|
Message: types.RespondTo(msg),
|
|
|
|
Uids: uids,
|
|
|
|
}, nil)
|
|
|
|
imapw.worker.PostMessage(&types.Done{types.RespondTo(msg)}, nil)
|
|
|
|
}
|
2019-03-10 23:45:00 -04:00
|
|
|
}
|
2020-09-12 15:05:02 +02:00
|
|
|
|
|
|
|
type sortFieldMapT map[types.SortField]sortthread.SortField
|
|
|
|
|
|
|
|
// caution, incomplete mapping
|
|
|
|
var sortFieldMap sortFieldMapT = sortFieldMapT{
|
|
|
|
types.SortArrival: sortthread.SortArrival,
|
|
|
|
types.SortCc: sortthread.SortCc,
|
|
|
|
types.SortDate: sortthread.SortDate,
|
|
|
|
types.SortFrom: sortthread.SortFrom,
|
|
|
|
types.SortSize: sortthread.SortSize,
|
|
|
|
types.SortSubject: sortthread.SortSubject,
|
|
|
|
types.SortTo: sortthread.SortTo,
|
|
|
|
}
|
|
|
|
|
|
|
|
func translateSortCriterions(
|
|
|
|
cs []*types.SortCriterion) []sortthread.SortCriterion {
|
|
|
|
result := make([]sortthread.SortCriterion, 0, len(cs))
|
|
|
|
for _, c := range cs {
|
|
|
|
if f, ok := sortFieldMap[c.Field]; ok {
|
|
|
|
result = append(result, sortthread.SortCriterion{f, c.Reverse})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|