Merge pull request #1164 from bishtawi/bishtawi/smtp-auth
Support SMTP Auth Plain for event publishing
This commit is contained in:
commit
eb700b4b6c
@ -70,15 +70,20 @@ func (b *smtpBackend) Counts() (total int64, success int64, failure int64) {
|
|||||||
|
|
||||||
// smtpSession is returned after EHLO.
|
// smtpSession is returned after EHLO.
|
||||||
type smtpSession struct {
|
type smtpSession struct {
|
||||||
backend *smtpBackend
|
backend *smtpBackend
|
||||||
conn *smtp.Conn
|
conn *smtp.Conn
|
||||||
topic string
|
topic string
|
||||||
token string
|
token string
|
||||||
mu sync.Mutex
|
mu sync.Mutex
|
||||||
|
basic_auth string
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *smtpSession) AuthPlain(username, _ string) error {
|
func (s *smtpSession) AuthPlain(username, password string) error {
|
||||||
logem(s.conn).Field("smtp_username", username).Debug("AUTH PLAIN (with username %s)", username)
|
logem(s.conn).Field("smtp_username", username).Debug("AUTH PLAIN (with username %s)", username)
|
||||||
|
basic_auth := base64.StdEncoding.EncodeToString([]byte(fmt.Sprintf("%s:%s", username, password)))
|
||||||
|
s.mu.Lock()
|
||||||
|
s.basic_auth = basic_auth
|
||||||
|
s.mu.Unlock()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -198,6 +203,8 @@ func (s *smtpSession) publishMessage(m *message) error {
|
|||||||
}
|
}
|
||||||
if s.token != "" {
|
if s.token != "" {
|
||||||
req.Header.Add("Authorization", "Bearer "+s.token)
|
req.Header.Add("Authorization", "Bearer "+s.token)
|
||||||
|
} else if s.basic_auth != "" {
|
||||||
|
req.Header.Add("Authorization", "Basic "+s.basic_auth)
|
||||||
}
|
}
|
||||||
rr := httptest.NewRecorder()
|
rr := httptest.NewRecorder()
|
||||||
s.backend.handler(rr, req)
|
s.backend.handler(rr, req)
|
||||||
@ -214,6 +221,9 @@ func (s *smtpSession) Reset() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (s *smtpSession) Logout() error {
|
func (s *smtpSession) Logout() error {
|
||||||
|
s.mu.Lock()
|
||||||
|
s.basic_auth = ""
|
||||||
|
s.mu.Unlock()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1386,6 +1386,28 @@ what's up
|
|||||||
writeAndReadUntilLine(t, email, c, scanner, "250 2.0.0 OK: queued")
|
writeAndReadUntilLine(t, email, c, scanner, "250 2.0.0 OK: queued")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestSmtpBackend_PlaintextWithPlainAuth(t *testing.T) {
|
||||||
|
email := `EHLO example.com
|
||||||
|
AUTH PLAIN dGVzdAB0ZXN0ADEyMzQ=
|
||||||
|
MAIL FROM: phil@example.com
|
||||||
|
RCPT TO: ntfy-mytopic@ntfy.sh
|
||||||
|
DATA
|
||||||
|
Subject: Very short mail
|
||||||
|
|
||||||
|
what's up
|
||||||
|
.
|
||||||
|
`
|
||||||
|
s, c, _, scanner := newTestSMTPServer(t, func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
require.Equal(t, "/mytopic", r.URL.Path)
|
||||||
|
require.Equal(t, "Very short mail", r.Header.Get("Title"))
|
||||||
|
require.Equal(t, "Basic dGVzdDoxMjM0", r.Header.Get("Authorization"))
|
||||||
|
require.Equal(t, "what's up", readAll(t, r.Body))
|
||||||
|
})
|
||||||
|
defer s.Close()
|
||||||
|
defer c.Close()
|
||||||
|
writeAndReadUntilLine(t, email, c, scanner, "250 2.0.0 OK: queued")
|
||||||
|
}
|
||||||
|
|
||||||
type smtpHandlerFunc func(http.ResponseWriter, *http.Request)
|
type smtpHandlerFunc func(http.ResponseWriter, *http.Request)
|
||||||
|
|
||||||
func newTestSMTPServer(t *testing.T, handler smtpHandlerFunc) (s *smtp.Server, c net.Conn, conf *Config, scanner *bufio.Scanner) {
|
func newTestSMTPServer(t *testing.T, handler smtpHandlerFunc) (s *smtp.Server, c net.Conn, conf *Config, scanner *bufio.Scanner) {
|
||||||
|
Loading…
Reference in New Issue
Block a user