mirror of
https://github.com/openziti/zrok.git
synced 2025-01-12 08:58:28 +01:00
93 lines
2.2 KiB
Go
93 lines
2.2 KiB
Go
package limits
|
|
|
|
import (
|
|
"fmt"
|
|
"github.com/openziti/zrok/build"
|
|
"github.com/openziti/zrok/controller/emailUi"
|
|
"github.com/pkg/errors"
|
|
"github.com/sirupsen/logrus"
|
|
"github.com/wneessen/go-mail"
|
|
)
|
|
|
|
type detailMessage struct {
|
|
lines []string
|
|
}
|
|
|
|
func newDetailMessage() *detailMessage {
|
|
return &detailMessage{}
|
|
}
|
|
|
|
func (m *detailMessage) append(msg string, args ...interface{}) *detailMessage {
|
|
m.lines = append(m.lines, fmt.Sprintf(msg, args...))
|
|
return m
|
|
}
|
|
|
|
func (m *detailMessage) html() string {
|
|
out := ""
|
|
for i := range m.lines {
|
|
out += fmt.Sprintf("<p style=\"text-align: left;\">%s</p>\n", m.lines[i])
|
|
}
|
|
return out
|
|
}
|
|
|
|
func (m *detailMessage) plain() string {
|
|
out := ""
|
|
for i := range m.lines {
|
|
out += fmt.Sprintf("%s\n\n", m.lines[i])
|
|
}
|
|
return out
|
|
}
|
|
|
|
func sendLimitWarningEmail(cfg *emailUi.Config, emailTo string, d *detailMessage) error {
|
|
emailData := &emailUi.WarningEmail{
|
|
EmailAddress: emailTo,
|
|
Version: build.String(),
|
|
}
|
|
|
|
emailData.Detail = d.plain()
|
|
plainBody, err := emailData.MergeTemplate("limitWarning.gotext")
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
emailData.Detail = d.html()
|
|
htmlBody, err := emailData.MergeTemplate("limitWarning.gohtml")
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
msg := mail.NewMsg()
|
|
if err := msg.From(cfg.From); err != nil {
|
|
return errors.Wrap(err, "failed to set from address in limit warning email")
|
|
}
|
|
if err := msg.To(emailTo); err != nil {
|
|
return errors.Wrap(err, "failed to set to address in limit warning email")
|
|
}
|
|
|
|
msg.Subject("zrok Limit Warning Notification")
|
|
msg.SetDate()
|
|
msg.SetMessageID()
|
|
msg.SetBulk()
|
|
msg.SetImportance(mail.ImportanceHigh)
|
|
msg.SetBodyString(mail.TypeTextPlain, plainBody)
|
|
msg.SetBodyString(mail.TypeTextHTML, htmlBody)
|
|
|
|
client, err := mail.NewClient(cfg.Host,
|
|
mail.WithPort(cfg.Port),
|
|
mail.WithSMTPAuth(mail.SMTPAuthPlain),
|
|
mail.WithUsername(cfg.Username),
|
|
mail.WithPassword(cfg.Password),
|
|
mail.WithTLSPolicy(mail.TLSMandatory),
|
|
)
|
|
|
|
if err != nil {
|
|
return errors.Wrap(err, "error creating limit warning email client")
|
|
}
|
|
if err := client.DialAndSend(msg); err != nil {
|
|
return errors.Wrap(err, "error sending limit warning email")
|
|
}
|
|
|
|
logrus.Infof("limit warning email sent to '%v'", emailTo)
|
|
return nil
|
|
}
|