From ca903d4228265272a0f6a780f5ed2280772eceec Mon Sep 17 00:00:00 2001 From: Tim Culverhouse Date: Mon, 7 Nov 2022 10:15:48 -0600 Subject: envelope: add InReplyTo field A standard IMAP envelope response includes the In-Reply-To header field. Add this field to the aerc model of Envelope. Update envelope parser to set this value. Update imap worker to set this value. Signed-off-by: Tim Culverhouse Tested-by: Inwit Acked-by: Robin Jarry --- worker/imap/imap.go | 10 +++++----- worker/lib/parse.go | 9 +++++++++ 2 files changed, 14 insertions(+), 5 deletions(-) (limited to 'worker') diff --git a/worker/imap/imap.go b/worker/imap/imap.go index 93b8a945..6e1341b2 100644 --- a/worker/imap/imap.go +++ b/worker/imap/imap.go @@ -1,6 +1,8 @@ package imap import ( + "strings" + "github.com/emersion/go-imap" "git.sr.ht/~rjarry/aerc/models" @@ -50,11 +52,8 @@ func translateEnvelope(e *imap.Envelope) *models.Envelope { // we strip the msgid of "<>" in order to be more compatible with go-message // which wants to handle msgids without the markers - // note this is a very naive way of doing it but probably good enough - msgID := e.MessageId - if len(msgID) > 1 && msgID[0] == '<' && msgID[len(msgID)-1] == '>' { - msgID = msgID[1 : len(msgID)-1] - } + msgID := strings.TrimSuffix(strings.TrimPrefix(e.MessageId, "<"), ">") + inReplyTo := strings.TrimSuffix(strings.TrimPrefix(e.InReplyTo, "<"), ">") return &models.Envelope{ Date: e.Date, @@ -65,6 +64,7 @@ func translateEnvelope(e *imap.Envelope) *models.Envelope { Cc: translateAddresses(e.Cc), Bcc: translateAddresses(e.Bcc), MessageId: msgID, + InReplyTo: inReplyTo, } } diff --git a/worker/lib/parse.go b/worker/lib/parse.go index f57a56ac..6b33d246 100644 --- a/worker/lib/parse.go +++ b/worker/lib/parse.go @@ -164,6 +164,14 @@ func parseEnvelope(h *mail.Header) (*models.Envelope, error) { return nil, err } } + irtList, err := h.MsgIDList("in-reply-to") + if err != nil { + return nil, err + } + irt := "" + if len(irtList) > 0 { + irt = irtList[0] + } date, err := parseDate(h) if err != nil { // still return a valid struct plus a sentinel date parsing error @@ -179,6 +187,7 @@ func parseEnvelope(h *mail.Header) (*models.Envelope, error) { To: to, Cc: cc, Bcc: bcc, + InReplyTo: irt, }, err } -- cgit