1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
package email
import (
"fmt"
"net/mail"
"strings"
"time"
)
type ComposeRequest struct {
MessageID string
FromAddress string
FromName string
ToAddresses string
CcAddresses string
Subject string
HTMLBody string
}
func Compose(request ComposeRequest) []byte {
var message strings.Builder
fromHeader := formatMailAddress(request.FromName, request.FromAddress)
message.WriteString(fmt.Sprintf("From: %s\r\n", fromHeader))
message.WriteString(fmt.Sprintf("To: %s\r\n", request.ToAddresses))
if request.CcAddresses != "" {
message.WriteString(fmt.Sprintf("Cc: %s\r\n", request.CcAddresses))
}
message.WriteString(fmt.Sprintf("Subject: %s\r\n", request.Subject))
message.WriteString(fmt.Sprintf("Date: %s\r\n", time.Now().Format(time.RFC1123Z)))
message.WriteString(fmt.Sprintf("Message-ID: %s\r\n", request.MessageID))
message.WriteString("MIME-Version: 1.0\r\n")
message.WriteString("Content-Type: text/html; charset=UTF-8\r\n")
message.WriteString("\r\n")
message.WriteString(request.HTMLBody)
return []byte(message.String())
}
func EnvelopeRecipients(toAddresses string, ccAddresses string, bccAddresses string) []string {
var recipients []string
for _, addressGroup := range []string{toAddresses, ccAddresses, bccAddresses} {
if addressGroup == "" {
continue
}
parsed, parseError := mail.ParseAddressList(addressGroup)
if parseError != nil {
for _, raw := range strings.Split(addressGroup, AddressJoiner) {
trimmed := strings.TrimSpace(raw)
if trimmed != "" {
recipients = append(recipients, trimmed)
}
}
continue
}
for _, address := range parsed {
recipients = append(recipients, address.Address)
}
}
return recipients
}
func formatMailAddress(displayName string, emailAddress string) string {
if displayName == "" {
return emailAddress
}
return fmt.Sprintf("\"%s\" <%s>", displayName, emailAddress)
}
|