From 12e6975aa7e64f5fec76a80f0c8a4aa440e87364 Mon Sep 17 00:00:00 2001 From: Mechiel Lukkien Date: Sun, 14 Apr 2024 17:28:00 +0200 Subject: [PATCH] return smtp response/error correctly in more cases --- queue/direct.go | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/queue/direct.go b/queue/direct.go index bfad49c..5b4af46 100644 --- a/queue/direct.go +++ b/queue/direct.go @@ -708,14 +708,18 @@ func deliverHost(log mlog.Log, resolver dns.Resolver, dialer smtpclient.Dialer, } resps, err := sc.DeliverMultiple(ctx, mailFrom, rcpts, size, msg, has8bit, smtputf8, m0.RequireTLS != nil && *m0.RequireTLS) - if err != nil && len(resps) == len(msgResps) { + if err != nil && (len(resps) == 0 && n == len(msgResps) || len(resps) == len(msgResps)) { // If error and it applies to all recipients, return a single error. return deliverResult{err: inspectError(err)} } var ntodo []*msgResp for i, mr := range todo[:n] { if err != nil { - mr.resp = smtpclient.Response{Err: err} + if cerr, ok := err.(smtpclient.Error); ok { + mr.resp = smtpclient.Response(cerr) + } else { + mr.resp = smtpclient.Response{Err: err} + } failed = append(failed, mr) } else if i > 0 && (resps[i].Code == smtp.C452StorageFull || resps[i].Code == smtp.C552MailboxFull) { ntodo = append(ntodo, mr)