1
0
mirror of https://github.com/nikoksr/notify.git synced 2025-01-24 03:16:35 +02:00
notify/service/mailgun/mailgun.go

52 lines
1.4 KiB
Go
Raw Normal View History

2021-02-10 19:22:20 +02:00
package mailgun
import (
"context"
"github.com/mailgun/mailgun-go/v4"
"github.com/pkg/errors"
)
// Mailgun struct holds necessary data to communicate with the Mailgun API.
type Mailgun struct {
client mailgun.Mailgun
senderAddress string
receiverAddresses []string
}
// New returns a new instance of a Mailgun notification service.
// You will need a Mailgun API key and domain name.
// See https://documentation.mailgun.com/en/latest/
func New(domain, apiKey, senderAddress string, opts ...Option) *Mailgun {
m := &Mailgun{
2021-02-12 10:31:23 +02:00
client: mailgun.NewMailgun(domain, apiKey),
2021-02-10 19:22:20 +02:00
senderAddress: senderAddress,
receiverAddresses: []string{},
}
for _, opt := range opts {
opt(m)
}
return m
}
// AddReceivers takes email addresses and adds them to the internal address list. The Send method will send
// a given message to all those addresses.
func (m *Mailgun) AddReceivers(addresses ...string) {
m.receiverAddresses = append(m.receiverAddresses, addresses...)
}
// Send takes a message subject and a message body and sends them to all previously set chats. Message body supports
// html as markup language.
func (m Mailgun) Send(ctx context.Context, subject, message string) error {
2021-02-10 19:22:20 +02:00
mailMessage := m.client.NewMessage(m.senderAddress, subject, message, m.receiverAddresses...)
_, _, err := m.client.Send(ctx, mailMessage)
if err != nil {
2021-02-10 19:22:20 +02:00
return errors.Wrap(err, "failed to send mail using Mailgun service")
}
return nil
}