summaryrefslogtreecommitdiff
path: root/xmpp/routing.go
diff options
context:
space:
mode:
Diffstat (limited to 'xmpp/routing.go')
-rw-r--r--xmpp/routing.go39
1 files changed, 28 insertions, 11 deletions
diff --git a/xmpp/routing.go b/xmpp/routing.go
index 55ec135..23f92bb 100644
--- a/xmpp/routing.go
+++ b/xmpp/routing.go
@@ -2,6 +2,7 @@ package xmpp
import (
"encoding/xml"
+ "encoding/base64"
"errors"
"log"
)
@@ -14,15 +15,14 @@ type tokenRouter struct {
enc *encoder
}
-func newTokenRouter(e *encoder) tokenRouter {
+func newTokenRouter() tokenRouter {
return tokenRouter{
buffer: make([]xml.Token, 0),
level: 0,
- enc: e,
}
}
-func (r *tokenRouter) route(t xml.Token) error {
+func (r *tokenRouter) route(t xml.Token, c *Conn) error {
r.buffer = append(r.buffer, t)
switch unwrapped := t.(type) {
@@ -43,8 +43,7 @@ func (r *tokenRouter) route(t xml.Token) error {
case 0:
return errors.New("Stream was closed by server")
case 1:
- // call elementRouter
- err := routeElement(r.buffer)
+ err := routeElement(r.buffer, c)
if err != nil {
return err
}
@@ -64,7 +63,7 @@ func (r *tokenRouter) route(t xml.Token) error {
return nil
}
-func routeElement(b []xml.Token) error {
+func routeElement(b []xml.Token, c *Conn) error {
tab := elementRoutingTable{
{xml.Name{"http://etherx.jabber.org/streams", "features"}, streamFeatures},
}
@@ -73,7 +72,7 @@ func routeElement(b []xml.Token) error {
case xml.StartElement:
for _, v := range(tab) {
if unwrapped.Name == v.name {
- err := v.handler(b)
+ err := v.handler(b, c)
if err != nil {
return err
}
@@ -91,11 +90,11 @@ func routeElement(b []xml.Token) error {
type elementRoutingTable []struct {
name xml.Name
- handler func(b []xml.Token) error
+ handler func(b []xml.Token, c *Conn) error
}
-func streamFeatures(b []xml.Token) error {
- err := sendSaslAuth(b)
+func streamFeatures(b []xml.Token, c *Conn) error {
+ err := sendSaslAuth(b, c)
if err != nil {
return err
}
@@ -103,7 +102,7 @@ func streamFeatures(b []xml.Token) error {
return nil
}
-func sendSaslAuth(b []xml.Token) error {
+func sendSaslAuth(b []xml.Token, c *Conn) error {
mechanisms := make([]string, 0)
for i, v := range(b) {
switch token := v.(type) {
@@ -121,6 +120,24 @@ func sendSaslAuth(b []xml.Token) error {
for _, v := range(mechanisms) {
if v == "PLAIN" {
+ start := xml.StartElement{
+ xml.Name{"urn:ietf:params:xml:ns:xmpp-sasl", "auth"},
+ []xml.Attr{
+ xml.Attr{xml.Name{"", "mechanism"}, "PLAIN"},
+ },
+ }
+
+ data := []byte("\x00" + username(c.jid) + "\x00" + c.pwd)
+ dst := make([]byte, base64.StdEncoding.EncodedLen(len(data)))
+ base64.StdEncoding.Encode(dst, data)
+ payload := xml.CharData(dst)
+
+ end := start.End()
+
+ c.enc.encodeNow(start)
+ c.enc.encode(payload)
+ c.enc.encodeNow(end)
+
return nil
}
}