view mcabber/mcabber/carbons.c @ 2106:72876dcf9094

Bit more checks for enabling carbons -Make sure we do not enable carbons if they are already enabled -Return status of carbons
author Roeland Jago Douma <roeland@famdouma.nl>
date Tue, 15 Oct 2013 18:51:39 +0200
parents 1cc84780eb5f
children adfd962e1343
line wrap: on
line source

#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 int _carbons_enabled = 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()
{
  if (_carbons_available == 0) {
    return;
  }

  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);

  if (!lm_connection_send_with_reply(lconnection, iq, handler, &error)) {
    scr_LogPrint(LPRINT_DEBUG, "Error sending IQ request: %s.", error->message);
    g_error_free(error);
  }

  lm_message_handler_unref(handler);
  lm_message_unref(iq);
}

void carbons_disable()
{
  if (_carbons_available == 0) {
    return;
  }
}

void carbons_info()
{
  if (_carbons_enabled) {
    scr_LogPrint(LPRINT_NORMAL, "Carbons enabled.");
  } else {
    if (_carbons_available) {
      scr_LogPrint(LPRINT_NORMAL, "Carbons available, but not enabled.");
    } else {
      scr_LogPrint(LPRINT_NORMAL, "Carbons not available.");     
    }
  }
}

static LmHandlerResult cb_carbons_enable(LmMessageHandler *h, LmConnection *c,
                                         LmMessage *m, gpointer user_data)
{
  if (lm_message_get_sub_type(m) == LM_MESSAGE_SUB_TYPE_RESULT) {
    _carbons_enabled = _carbons_enabled == 0 ? 1 : 0;
  } else {
    //Handle error cases
  }

  return LM_HANDLER_RESULT_REMOVE_MESSAGE;
}