aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/base/smtp.go
diff options
context:
space:
mode:
authorLibravatarLibravatar Silvan Jegen <[email protected]> 2024-02-03 10:52:45 +0100
committerLibravatarLibravatar Simon Ser <[email protected]> 2024-02-03 21:52:58 +0100
commit0a2ff6a630eb42b7c2491d639ff2e495524577f0 (patch)
tree6e4c4c096fbd61b3de41edefb059adced643638b /plugins/base/smtp.go
parentadcb58e49563a9b0ab791ca4249d8201b215a8db (diff)
downloadalps-0a2ff6a630eb42b7c2491d639ff2e495524577f0.tar.gz
alps-0a2ff6a630eb42b7c2491d639ff2e495524577f0.tar.bz2
alps-0a2ff6a630eb42b7c2491d639ff2e495524577f0.zip
Add optional Cc and Bcc fields when composing a message
This should address https://todo.sr.ht/~migadu/alps/145.
Diffstat (limited to 'plugins/base/smtp.go')
-rw-r--r--plugins/base/smtp.go35
1 files changed, 26 insertions, 9 deletions
diff --git a/plugins/base/smtp.go b/plugins/base/smtp.go
index bf91c24..be9aedc 100644
--- a/plugins/base/smtp.go
+++ b/plugins/base/smtp.go
@@ -81,6 +81,8 @@ func (att *imapAttachment) Filename() string {
type OutgoingMessage struct {
From string
To []string
+ Cc []string
+ Bcc []string
Subject string
MessageID string
InReplyTo string
@@ -123,6 +125,19 @@ func writeAttachment(mw *mail.Writer, att Attachment) error {
return nil
}
+func prepareAddressList(addresses []string) ([]*mail.Address, error) {
+ l := make([]*mail.Address, len(addresses))
+ for i, rcpt := range addresses {
+ addr, err := mail.ParseAddress(rcpt)
+ if err != nil {
+ return nil, err
+ }
+ l[i] = addr
+ }
+
+ return l, nil
+}
+
func (msg *OutgoingMessage) WriteTo(w io.Writer) error {
fromAddr, err := mail.ParseAddress(msg.From)
if err != nil {
@@ -130,19 +145,21 @@ func (msg *OutgoingMessage) WriteTo(w io.Writer) error {
}
from := []*mail.Address{fromAddr}
- to := make([]*mail.Address, len(msg.To))
- for i, rcpt := range msg.To {
- addr, err := mail.ParseAddress(rcpt)
- if err != nil {
- return err
- }
- to[i] = addr
+ to, err := prepareAddressList(msg.To)
+ if err != nil {
+ return err
+ }
+
+ cc, err := prepareAddressList(msg.Cc)
+ if err != nil {
+ return err
}
var h mail.Header
h.SetDate(time.Now())
h.SetAddressList("From", from)
h.SetAddressList("To", to)
+ h.SetAddressList("Cc", cc)
if msg.Subject != "" {
h.SetText("Subject", msg.Subject)
}
@@ -200,10 +217,10 @@ func sendMessage(c *smtp.Client, msg *OutgoingMessage) error {
return fmt.Errorf("MAIL FROM failed: %v", err)
}
- for _, to := range msg.To {
+ for _, to := range append(msg.To, append(msg.Bcc, msg.Cc...)...) {
addr, err := mail.ParseAddress(to)
if err != nil {
- return fmt.Errorf("parsing 'To' address failed: %v", err)
+ return fmt.Errorf("parsing address %q failed: %v", to, err)
}
if err := c.Rcpt(addr.Address, nil); err != nil {