Skip to content

Commit

Permalink
fix: use the smtp creds from the shoutrrr URL
Browse files Browse the repository at this point in the history
  • Loading branch information
adityathebe committed Sep 15, 2023
1 parent 75e2136 commit cf47ca1
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 17 deletions.
31 changes: 20 additions & 11 deletions mail/mailer.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,7 @@ var FromAddress string

type Mail struct {
message *gomail.Message
}

func (t *Mail) SetFrom(from string) *Mail {
t.message.SetHeader("From", from)
return t
dialer *gomail.Dialer
}

func New(to, subject, body, contentType string) *Mail {
Expand All @@ -27,11 +23,24 @@ func New(to, subject, body, contentType string) *Mail {
return &Mail{message: m}
}

func (t *Mail) SetFrom(from string) *Mail {
t.message.SetHeader("From", from)
return t
}

func (t *Mail) SetCredentials(host string, port int, user, password string) *Mail {
t.dialer = gomail.NewDialer(host, port, user, password)
return t
}

func (m Mail) Send() error {
host := os.Getenv("SMTP_HOST")
user := os.Getenv("SMTP_USER")
password := os.Getenv("SMTP_PASSWORD")
port, _ := strconv.Atoi(os.Getenv("SMTP_PORT"))
d := gomail.NewDialer(host, port, user, password)
return d.DialAndSend(m.message)
if m.dialer == nil {
host := os.Getenv("SMTP_HOST")
user := os.Getenv("SMTP_USER")
password := os.Getenv("SMTP_PASSWORD")
port, _ := strconv.Atoi(os.Getenv("SMTP_PORT"))
m.SetCredentials(host, port, user, password)
}

return m.dialer.DialAndSend(m.message)
}
15 changes: 9 additions & 6 deletions notification/shoutrrr.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"fmt"
"net/url"
"os"
"strconv"
"strings"

stripmd "github.com/adityathebe/go-strip-markdown/v2"
Expand Down Expand Up @@ -88,11 +89,9 @@ func Send(ctx *api.Context, connectionName, shoutrrrURL, title, message string,

injectTitleIntoProperties(service, title, allProps)

var params *types.Params
params := &types.Params{}
if properties != nil {
params = (*types.Params)(&allProps)
} else {
params = &types.Params{}
}

// NOTE: Until shoutrrr fixes the "UseHTML" props, we'll use the mailer package
Expand All @@ -104,11 +103,15 @@ func Send(ctx *api.Context, connectionName, shoutrrrURL, title, message string,

query := parsedURL.Query()
var (
to = utils.Coalesce(query.Get("ToAddresses"), (*params)["ToAddresses"])
from = utils.Coalesce(query.Get("FromAddress"), (*params)["FromAddress"])
to = utils.Coalesce(query.Get("ToAddresses"), (*params)["ToAddresses"])
from = utils.Coalesce(query.Get("FromAddress"), (*params)["FromAddress"])
password, _ = parsedURL.User.Password()
port, _ = strconv.Atoi(parsedURL.Port())
)

m := mail.New(to, title, message, `text/html; charset="UTF-8"`).SetFrom(from)
m := mail.New(to, title, message, `text/html; charset="UTF-8"`).
SetFrom(from).
SetCredentials(parsedURL.Hostname(), port, parsedURL.User.Username(), password)
return m.Send()
}

Expand Down

0 comments on commit cf47ca1

Please sign in to comment.