authorizer/server/email/email.go

95 lines
2.5 KiB
Go
Raw Normal View History

2021-07-12 18:22:16 +00:00
package email
import (
2022-01-17 06:02:13 +00:00
"bytes"
"crypto/tls"
2022-01-17 06:02:13 +00:00
"encoding/json"
"strconv"
2022-01-17 06:02:13 +00:00
"text/template"
2021-07-12 18:22:16 +00:00
2022-05-23 06:22:51 +00:00
log "github.com/sirupsen/logrus"
gomail "gopkg.in/mail.v2"
2021-07-23 16:27:44 +00:00
"github.com/authorizerdev/authorizer/server/constants"
2022-05-29 11:52:46 +00:00
"github.com/authorizerdev/authorizer/server/memorystore"
2021-07-12 18:22:16 +00:00
)
2022-01-17 06:02:13 +00:00
// addEmailTemplate is used to add html template in email body
func addEmailTemplate(a string, b map[string]interface{}, templateName string) string {
tmpl, err := template.New(templateName).Parse(a)
if err != nil {
output, _ := json.Marshal(b)
return string(output)
}
buf := &bytes.Buffer{}
err = tmpl.Execute(buf, b)
if err != nil {
panic(err)
}
s := buf.String()
return s
}
// SendMail function to send mail
2022-01-08 13:14:19 +00:00
func SendMail(to []string, Subject, bodyMessage string) error {
2022-03-02 12:12:31 +00:00
// dont trigger email sending in case of test
2022-05-29 11:52:46 +00:00
envKey, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeyEnv)
if err != nil {
return err
}
if envKey == "test" {
2022-03-02 12:12:31 +00:00
return nil
}
m := gomail.NewMessage()
2022-05-29 11:52:46 +00:00
senderEmail, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeySenderEmail)
if err != nil {
log.Errorf("Error while getting sender email from env variable: %v", err)
return err
}
smtpPort, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeySmtpPort)
if err != nil {
log.Errorf("Error while getting smtp port from env variable: %v", err)
return err
}
smtpHost, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeySmtpHost)
if err != nil {
log.Errorf("Error while getting smtp host from env variable: %v", err)
return err
}
smtpUsername, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeySmtpUsername)
if err != nil {
log.Errorf("Error while getting smtp username from env variable: %v", err)
return err
}
smtpPassword, err := memorystore.Provider.GetStringStoreEnvVariable(constants.EnvKeySmtpPassword)
if err != nil {
log.Errorf("Error while getting smtp password from env variable: %v", err)
return err
}
isProd, err := memorystore.Provider.GetBoolStoreEnvVariable(constants.EnvKeyIsProd)
if err != nil {
log.Errorf("Error while getting env variable: %v", err)
return err
}
m.SetHeader("From", senderEmail)
m.SetHeader("To", to...)
m.SetHeader("Subject", Subject)
m.SetBody("text/html", bodyMessage)
2022-05-29 11:52:46 +00:00
port, _ := strconv.Atoi(smtpPort)
d := gomail.NewDialer(smtpHost, port, smtpUsername, smtpPassword)
if !isProd {
d.TLSConfig = &tls.Config{InsecureSkipVerify: true}
}
if err := d.DialAndSend(m); err != nil {
2022-05-25 07:00:22 +00:00
log.Debug("SMTP Failed: ", err)
2021-07-12 18:22:16 +00:00
return err
}
return nil
}