diff options
author | xengineering <me@xengineering.eu> | 2023-06-27 16:43:45 +0200 |
---|---|---|
committer | xengineering <me@xengineering.eu> | 2023-06-27 16:45:07 +0200 |
commit | c600e10faf59e96be6b0ad440bd4c5d8cc13d38a (patch) | |
tree | ca584829183369178cf67c27dc7f5c1c1b0e86d2 /xmpp/sasl.go | |
parent | 35a9c27783524a035ab6545061f5ecd5fdee6ea7 (diff) | |
download | limox-c600e10faf59e96be6b0ad440bd4c5d8cc13d38a.tar limox-c600e10faf59e96be6b0ad440bd4c5d8cc13d38a.tar.zst limox-c600e10faf59e96be6b0ad440bd4c5d8cc13d38a.zip |
xmpp: Re-introduce SASL authentication
Diffstat (limited to 'xmpp/sasl.go')
-rw-r--r-- | xmpp/sasl.go | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/xmpp/sasl.go b/xmpp/sasl.go new file mode 100644 index 0000000..1cb3670 --- /dev/null +++ b/xmpp/sasl.go @@ -0,0 +1,36 @@ +package xmpp + +import ( + "encoding/xml" + "encoding/base64" + "log" +) + +func (s *session) sasl() { + tokens := make([]xml.Token, 0, 3) + + start := xml.StartElement{ + xml.Name{"urn:ietf:params:xml:ns:xmpp-sasl", "auth"}, + []xml.Attr{ + xml.Attr{xml.Name{"", "mechanism"}, "PLAIN"}, + }, + } + tokens = append(tokens, start) + + data := []byte("\x00" + username(s.jid) + "\x00" + s.pwd) + dst := make([]byte, base64.StdEncoding.EncodedLen(len(data))) + base64.StdEncoding.Encode(dst, data) + payload := xml.CharData(dst) + tokens = append(tokens, payload) + + end := start.End() + tokens = append(tokens, end) + + for _, t := range tokens { + err := s.ed.encodeToken(t) + if err != nil { + log.Println("Could not encode stream end!") + return + } + } +} |