diff mcabber/mcabber/carbons.c @ 2104:c7e9950fa741

Added option to enable carbons (set carbons = 1 in mcabberrc) If the server supports carbons and the user has carbons enabled we enable them. Now we need to handle XEP-0297 (Stanza Forwarding) stanzas to make sure the messages end up at the correct place.
author Roeland Jago Douma <roeland@famdouma.nl>
date Sat, 02 Mar 2013 18:22:10 +0100
parents
children 1cc84780eb5f
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mcabber/mcabber/carbons.c	Sat Mar 02 18:22:10 2013 +0100
@@ -0,0 +1,67 @@
+#include "carbons.h"
+#include "settings.h"
+#include "xmpp_helper.h"
+#include "xmpp_defines.h"
+#include "logprint.h"
+#include "xmpp.h"
+
+static int _carbons_available = 0;
+
+static LmHandlerResult cb_carbons_enable(LmMessageHandler *h, LmConnection *c,
+                                         LmMessage *m, gpointer user_data);
+
+
+void carbons_init()
+{
+
+}
+
+void carbons_available()
+{
+  int enable = 0;
+  _carbons_available = 1;
+
+  enable = settings_opt_get_int("carbons");
+
+  if (enable) {
+    carbons_enable();
+  }
+}
+
+void carbons_enable()
+{
+  LmMessage *iq;
+  LmMessageNode *enable;
+  LmMessageHandler *handler;
+  GError *error = NULL;
+
+  iq = lm_message_new_with_sub_type(NULL, LM_MESSAGE_TYPE_IQ,
+                                    LM_MESSAGE_SUB_TYPE_SET);
+
+  enable = lm_message_node_add_child(iq->node, "enable", NULL);
+
+  lm_message_node_set_attribute(enable, "xmlns", NS_CARBONS_2);
+
+  handler = lm_message_handler_new(cb_carbons_enable, NULL, NULL);
+
+  lm_connection_send_with_reply(lconnection, iq, handler, &error);
+  lm_message_handler_unref(handler);
+  lm_message_unref(iq);
+
+  if (error) {
+    scr_LogPrint(LPRINT_LOGNORM, "Error sending IQ request: %s.", error->message);
+    g_error_free(error);
+  }
+}
+
+void carbons_disable()
+{
+
+}
+
+static LmHandlerResult cb_carbons_enable(LmMessageHandler *h, LmConnection *c,
+                                         LmMessage *m, gpointer user_data)
+{
+  scr_LogPrint(LPRINT_NORMAL|LPRINT_DEBUG, "We have a response! O Yeah!");
+  return LM_HANDLER_RESULT_REMOVE_MESSAGE;
+}