Skip to content

Commit

Permalink
Merge pull request #169 from bmerchant22/main
Browse files Browse the repository at this point in the history
Change to patra server
  • Loading branch information
bmerchant22 authored Aug 23, 2024
2 parents efb9c08 + 7323574 commit 6004a04
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 55 deletions.
4 changes: 2 additions & 2 deletions config.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
MAIL:
HOST: "mmtp.iitk.ac.in"
PORT: "25"
HOST: "patra.iitk.ac.in"
PORT: "587"
BATCH: 200
JWT:
EXPIRATION:
Expand Down
58 changes: 5 additions & 53 deletions mail/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@ import (
"fmt"
"net/smtp"
"strings"
"text/template"
"time"
"text/template"

"github.com/sirupsen/logrus"
"crypto/tls"
)

type Mail struct {
Expand Down Expand Up @@ -73,64 +73,16 @@ func Service(mailQueue chan Mail) {
addr := fmt.Sprintf("%s:%s", host, port)
auth := smtp.PlainAuth("", user, pass, host)

tlsConfig := &tls.Config{
InsecureSkipVerify: true, // Change this to verify server certificate in production
}
conn, err := tls.Dial("tcp", addr, tlsConfig)
if err != nil {
logrus.Errorf("Error dialing SMTPS server: %v", err)
}

client, err := smtp.NewClient(conn, host)
if err != nil {
logrus.Errorf("Error creating SMTP client: %v", err)
}


if err := client.Auth(auth); err != nil {
logrus.Errorf("Error authenticating: %v", err)
}

for mail := range mailQueue {
message := mail.BuildMessage()
to := append(mail.To, webteam)
batches := batchEmails(to, batch)
for _, emailBatch := range batches {

// if err := client.StartTLS(tlsConfig); err != nil {
// logrus.Errorf("Error starting TLS: %v", err)
// continue
// }
if err := client.Mail(sender); err != nil {
logrus.Errorf("Error setting sender: %v", err)
}

for _, recipient := range emailBatch {
if err := client.Rcpt(recipient); err != nil {
logrus.Errorf("Error setting recipient %s: %v", recipient, err)
continue
}
}

// Send the email body
w, err := client.Data()
if err != nil {
logrus.Errorf("Error creating data writer: %v", err)
continue
}
_, err = w.Write(message)
if err != nil {
logrus.Errorf("Error writing email body: %v", err)
}
err = w.Close()
if err != nil {
logrus.Errorf("Error closing data writer: %v", err)
if err := smtp.SendMail(addr, auth, sender, emailBatch, message); err != nil {
logrus.Errorf("Error sending mail: %v", emailBatch)
logrus.Errorf("Error: %v", err)
}
time.Sleep(1 * time.Second)
}
}

if err := client.Quit(); err != nil {
logrus.Errorf("Error closing connection: %v", err)
}
}

0 comments on commit 6004a04

Please sign in to comment.