X-Git-Url: http://git.cascardo.eti.br/?a=blobdiff_plain;f=status.c;h=afb71bd42d471cda55e8855dabc89908d427b80c;hb=9695548b52dc59be0bbf54a3beb6ce6a194fd5a0;hp=83c57d4b1f86e6b7fb10884b694ecd37bbb25e92;hpb=d1a29bfd0dbb9d00b3712d02561b6ed9109e6cb7;p=cascardo%2Fpubsub-bot.git diff --git a/status.c b/status.c index 83c57d4..afb71bd 100644 --- a/status.c +++ b/status.c @@ -17,11 +17,14 @@ */ +#include #include #include #include #include #include +#include +#include static char * server = "vespa.holoscopio.com"; static char * username = "pubsub"; @@ -134,6 +137,35 @@ pushmood (iksparser *parser, char *node, char *line) iks_delete (iq); } +iks * +createtune (char *line) +{ + iks *tune; + tune = iks_new ("tune"); + iks_insert_attrib (tune, "xmlns", "http://jabber.org/protocol/tune"); + iks_insert_cdata (iks_insert (tune, "artist"), line, 0); + return tune; +} + +void +pushtune (iksparser *parser, char *node, iks *tune) +{ + iks *iq; + iks *query; + iks *publish; + iks *item; + iq = createiq ("set", pbservice, "pubsub", + "http://jabber.org/protocol/pubsub", &query); + publish = iks_insert (query, "publish"); + iks_insert_attrib (publish, "node", node); + item = iks_insert (publish, "item"); + iks_insert_node (item, tune); + printf ("debug: %s\n", iks_string (iks_stack (iq), iq)); + iks_send (parser, iq); + iks_delete (iq); +} + + void process_mood (iksparser *parser, char *cmdline) { @@ -151,12 +183,20 @@ process_mood (iksparser *parser, char *cmdline) createnode (parser, cmdline); else if (!strcmp (cmd, "get")) getnode (parser, cmdline); - else if (!strcmp (cmd, "push")) + else if (!strcmp (cmd, "mood")) { char *node; - node = strsep (&cmdline, " "); + node = "http://jabber.org/protocol/mood"; pushmood (parser, node, cmdline); } + else if (!strcmp (cmd, "tune")) + { + char *node; + iks *tune; + node = "http://jabber.org/protocol/tune"; + tune = createtune (cmdline); + pushtune (parser, node, tune); + } free (orig_cmdline); } @@ -369,6 +409,102 @@ hook (void *data, int type, iks *node) return IKS_OK; } +gboolean +handler (GIOChannel *channel, GIOCondition cond, gpointer data) +{ + iksparser *parser = data; + iks_recv (parser, 0); + return TRUE; +} + +void +tune_add_dbus_arg (iks *tune, DBusMessageIter *args) +{ + DBusMessageIter entry; + DBusMessageIter var; + char *strkey = NULL; + char *strval = NULL; + dbus_message_iter_recurse (args, &entry); + if (dbus_message_iter_get_arg_type (&entry) == DBUS_TYPE_STRING) + { + dbus_message_iter_get_basic (&entry, &strkey); + dbus_message_iter_next (&entry); + if (dbus_message_iter_get_arg_type (&entry) == DBUS_TYPE_VARIANT) + { + dbus_message_iter_recurse (&entry, &var); + if (dbus_message_iter_get_arg_type (&var) == DBUS_TYPE_STRING) + { + dbus_message_iter_get_basic (&var, &strval); + } + } + } + else + printf ("%c\n", dbus_message_iter_get_arg_type (&entry)); + if (strkey && strval) + { + iks_insert_cdata (iks_insert (tune, strkey), strval, 0); + } +} + +iks * +tune_from_dbus (DBusMessage *msg) +{ + DBusMessageIter args; + iks *tune; + tune = iks_new ("tune"); + iks_insert_attrib (tune, "xmlns", "http://jabber.org/protocol/tune"); + dbus_message_iter_init (msg, &args); + if (dbus_message_iter_get_arg_type (&args) == DBUS_TYPE_ARRAY) + { + DBusMessageIter dict; + dbus_message_iter_recurse (&args, &dict); + while (dbus_message_iter_get_arg_type (&dict) == + DBUS_TYPE_DICT_ENTRY) + { + tune_add_dbus_arg (tune, &dict); + dbus_message_iter_next (&dict); + } + } + return tune; +} + +DBusHandlerResult +gettune (DBusConnection *conn, DBusMessage *msg, void *data) +{ + iks *tune; + if (dbus_message_is_signal (msg, "org.MetaPlayer.tag", "playing")) + { + tune = tune_from_dbus (msg); + pushtune (data, "http://jabber.org/protocol/tune", tune); + return DBUS_HANDLER_RESULT_HANDLED; + } + else + return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; +} + +static void +prepare_dbus (gpointer parser) +{ + DBusConnection *conn; + conn = dbus_bus_get (DBUS_BUS_SESSION, NULL); + dbus_bus_register (conn, NULL); + dbus_bus_add_match (conn, + "type='signal'", NULL); + dbus_connection_flush (conn); + dbus_connection_setup_with_g_main (conn, g_main_context_default ()); + dbus_connection_add_filter (conn, gettune, parser, NULL); +} + +void +loop (iksparser *parser) +{ + GIOChannel *channel; + channel = g_io_channel_unix_new (iks_fd (parser)); + g_io_add_watch (channel, G_IO_IN, handler, parser); + prepare_dbus (parser); + g_main_loop_run (g_main_loop_new (g_main_context_default (), TRUE)); +} + int main (int argc, char **argv) { @@ -397,7 +533,6 @@ main (int argc, char **argv) } parser = iks_stream_new ("jabber:client", &parser, hook); iks_connect_tcp (parser, server, 5222); - while (1) - iks_recv (parser, -1); + loop (parser); return 0; }