From 2054ca5c9ab721a9a182e2380079aef975578556 Mon Sep 17 00:00:00 2001 From: Praveen raj Mani Date: Thu, 9 Apr 2020 01:15:24 +0530 Subject: [PATCH] fix: honor token based authentication in NATS streaming (#9296) fixes #9148 --- pkg/event/target/nats.go | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/pkg/event/target/nats.go b/pkg/event/target/nats.go index c42d6ae24..7bc1dec82 100644 --- a/pkg/event/target/nats.go +++ b/pkg/event/target/nats.go @@ -121,6 +121,10 @@ func (n NATSArgs) Validate() error { return errors.New("cert and key must be specified as a pair") } + if n.Username != "" && n.Password == "" || n.Username == "" && n.Password != "" { + return errors.New("username and password must be specified as a pair") + } + if n.Streaming.Enable { if n.Streaming.ClusterID == "" { return errors.New("empty cluster id") @@ -168,7 +172,15 @@ func (n NATSArgs) connectStan() (stan.Conn, error) { if n.Secure { scheme = "tls" } - addressURL := scheme + "://" + n.Username + ":" + n.Password + "@" + n.Address.String() + + var addressURL string + if n.Username != "" && n.Password != "" { + addressURL = scheme + "://" + n.Username + ":" + n.Password + "@" + n.Address.String() + } else if n.Token != "" { + addressURL = scheme + "://" + n.Token + "@" + n.Address.String() + } else { + addressURL = scheme + "://" + n.Address.String() + } clientID, err := getNewUUID() if err != nil {