Tell automake to include the configuration file in distribution
[cascardo/rnetproxy.git] / jabber.c
index 6daac0d..61ed23c 100644 (file)
--- a/jabber.c
+++ b/jabber.c
 #include <gnet.h>
 #include <glib.h>
 #include <iksemel.h>
+#include <gsasl.h>
 #include "iksemel_extra.h"
 #include "jabber.h"
 
+jabber_data_t* jabber_data_new (gpointer hook, gpointer parser)
+{
+  jabber_data_t *data;
+  data = g_slice_new0 (jabber_data_t);
+  data->parser = iks_extra_stream_new (hook, parser);
+  gsasl_init (&(data->ctx));
+  return data;
+}
+
+void jabber_data_destroy (gpointer data)
+{
+  jabber_data_t *jdata = (jabber_data_t*) data;
+  if (jdata->parser)
+    iks_parser_delete (jdata->parser);
+  if (jdata->client)
+    gsasl_finish (jdata->client);
+  if (jdata->server)
+    gsasl_finish (jdata->server);
+  if (jdata->ctx)
+    gsasl_done (jdata->ctx);
+  g_slice_free (jabber_data_t, jdata);
+}
+
 static void jabber_connect (net_hook_t* hook)
 {
 }
@@ -35,7 +59,7 @@ static void jabber_close (net_hook_t* hook)
       gnet_conn_disconnect (hook->peer->conn);
     }
   gnet_conn_delete (hook->conn);
-  iks_parser_delete (hook->data);
+  jabber_data_destroy (hook->data);
   g_slice_free (net_hook_t, hook);
 }
 
@@ -45,7 +69,8 @@ static void jabber_write (net_hook_t* hook)
 
 static void jabber_read (net_hook_t* hook, gchar* buffer, size_t len)
 {
-  iks_parse (hook->data, buffer, len, FALSE);
+  jabber_data_t *jdata = (jabber_data_t*) hook->data;
+  iks_parse (jdata->parser, buffer, len, FALSE);
 }
 
 void jabber_error (net_hook_t* hook)
@@ -56,7 +81,6 @@ void jabber_error (net_hook_t* hook)
 GString* jabber_new_start (iks* node)
 {
   GString* buffer;
-  iks* attrib;
   buffer = g_string_sized_new (256);
   g_string_append (buffer, iks_string (iks_stack (node), node));
   g_string_erase (buffer, buffer->len - 2, 1);
@@ -81,9 +105,27 @@ void jabber_connect_server (net_hook_t* hook, char* server, iks* node)
   g_string_free (buffer, TRUE);
 }
 
+void
+jabber_sasl_plain_filter (iks *node)
+{
+  if (g_str_equal (iks_name (node), "auth") &&
+      g_str_equal (iks_find_attrib (node, "xmlns"),
+                                   "urn:ietf:params:xml:ns:xmpp-sasl"))
+    {
+      char *b64;
+      char *uname;
+      gsize uname_len;
+      b64 = iks_cdata (iks_child (node));
+      uname = g_base64_decode (b64, &uname_len);
+      g_message ("User trying authentication as %s", uname);
+      g_free (uname);
+    }
+}
+
 void jabber_send (net_hook_t* hook, iks* node)
 {
   GString* buffer;
+  jabber_sasl_plain_filter (node);
   buffer = g_string_new (iks_string (iks_stack (node), node));
   gnet_conn_write (hook->peer->conn, buffer->str, buffer->len);
   g_string_free (buffer, TRUE);
@@ -129,7 +171,7 @@ net_hook_t* jabber_hook_new (GConn* conn)
   hook->close = jabber_close;
   hook->write = jabber_write;
   hook->read = jabber_read;
-  hook->data = iks_extra_stream_new (hook, jabber_parser);
+  hook->data = jabber_data_new (hook, jabber_parser);
   gnet_conn_set_callback (hook->conn, nethook_event, hook);
   return hook;
 }