# HG changeset patch # User Marcus Lundblad # Date 1242587055 0 # Node ID d2424873c66698b6a9378aa99ab282df6e60bb86 # Parent 2dfb639b4f2612f8fa2fd7dfd8b3d8238adc0401# Parent 12d1711e1667e40ff332dcd217fb621598600b4a propagate from branch 'im.pidgin.pidgin' (head 36e85b01808a3c6e32116cb8b71b10e31b0da072) to branch 'im.pidgin.cpw.malu.client_type' (head 23d0d225ef28e21781c194b5c243757309028a55) diff -r 12d1711e1667 -r d2424873c666 Doxyfile.in diff -r 12d1711e1667 -r d2424873c666 finch/finch.c --- a/finch/finch.c Sun May 17 13:07:34 2009 +0000 +++ b/finch/finch.c Sun May 17 19:04:15 2009 +0000 @@ -65,6 +65,7 @@ g_hash_table_insert(ui_info, "version", VERSION); g_hash_table_insert(ui_info, "website", "http://pidgin.im"); g_hash_table_insert(ui_info, "dev_website", "http://developer.pidgin.im"); + g_hash_table_insert(ui_info, "client_type", "console"); } return ui_info; diff -r 12d1711e1667 -r d2424873c666 finch/gntdebug.c diff -r 12d1711e1667 -r d2424873c666 finch/gntft.c diff -r 12d1711e1667 -r d2424873c666 finch/gntpounce.c diff -r 12d1711e1667 -r d2424873c666 finch/gntstatus.c diff -r 12d1711e1667 -r d2424873c666 finch/libgnt/wms/Makefile.am diff -r 12d1711e1667 -r d2424873c666 finch/libgnt/wms/s.c diff -r 12d1711e1667 -r d2424873c666 libpurple/core.h --- a/libpurple/core.h Sun May 17 13:07:34 2009 +0000 +++ b/libpurple/core.h Sun May 17 19:04:15 2009 +0000 @@ -186,6 +186,10 @@ * *
dev_website
*
the UI's development/support website, such as http://developer.pidgin.im.
+ * + *
client_type
+ *
the type of UI (pc, console, phone, handheld, web, bot)
+ * * * * @return A GHashTable with strings for keys and values. This diff -r 12d1711e1667 -r d2424873c666 libpurple/example/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/plugins/perl/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/plugins/ssl/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/plugins/tcl/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/bonjour/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/gg/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/irc/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/jabber/buddy.c --- a/libpurple/protocols/jabber/buddy.c Sun May 17 13:07:34 2009 +0000 +++ b/libpurple/protocols/jabber/buddy.c Sun May 17 19:04:15 2009 +0000 @@ -2519,3 +2519,22 @@ return jabber_resource_has_capability(jbr, cap); } +const gchar * +jabber_resource_get_identity_category_type(const JabberBuddyResource *jbr, + const gchar *category) +{ + const GList *iter = NULL; + + if (jbr->caps.info) { + for (iter = jbr->caps.info->identities ; iter ; iter = g_list_next(iter)) { + const JabberIdentity *identity = + (JabberIdentity *) iter->data; + + if (strcmp(identity->category, category) == 0) { + return identity->type; + } + } + } + + return NULL; +} diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/jabber/buddy.h --- a/libpurple/protocols/jabber/buddy.h Sun May 17 13:07:34 2009 +0000 +++ b/libpurple/protocols/jabber/buddy.h Sun May 17 19:04:15 2009 +0000 @@ -123,4 +123,8 @@ const gchar *cap); gboolean jabber_buddy_has_capability(const JabberBuddy *jb, const gchar *cap); +const gchar * +jabber_resource_get_identity_category_type(const JabberBuddyResource *jbr, + const gchar *category); + #endif /* PURPLE_JABBER_BUDDY_H_ */ diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/jabber/disco.c --- a/libpurple/protocols/jabber/disco.c Sun May 17 13:07:34 2009 +0000 +++ b/libpurple/protocols/jabber/disco.c Sun May 17 19:04:15 2009 +0000 @@ -116,7 +116,7 @@ if(node) xmlnode_set_attrib(query, "node", node); - if(!node || g_str_equal(node, node_uri)) { + if(!node || !strcmp(node, node_uri)) { GList *features, *identities; for(identities = jabber_identities; identities; identities = identities->next) { JabberIdentity *ident = (JabberIdentity*)identities->data; diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/jabber/jabber.c --- a/libpurple/protocols/jabber/jabber.c Sun May 17 13:07:34 2009 +0000 +++ b/libpurple/protocols/jabber/jabber.c Sun May 17 19:04:15 2009 +0000 @@ -23,6 +23,7 @@ #include "account.h" #include "accountopt.h" #include "blist.h" +#include "core.h" #include "cmds.h" #include "connection.h" #include "conversation.h" @@ -1845,7 +1846,7 @@ JabberStream *js; JabberBuddy *jb = NULL; PurpleConnection *gc = purple_account_get_connection(purple_buddy_get_account(b)); - + if(!gc) return NULL; @@ -1858,6 +1859,28 @@ !(jb->subscription & JABBER_SUB_TO))) return "not-authorized"; } + + if (jb) { + JabberBuddyResource *jbr = jabber_buddy_find_resource(jb, NULL); + if (jbr) { + const gchar *client_type = + jabber_resource_get_identity_category_type(jbr, "client"); + + if (client_type) { + if (strcmp(client_type, "phone") == 0) { + return "mobile"; + } else if (strcmp(client_type, "web") == 0) { + return "external"; + } else if (strcmp(client_type, "handheld") == 0) { + return "hiptop"; + } else if (strcmp(client_type, "bot") == 0) { + return "bot"; + } + /* the default value "pc" falls through and has no emblem */ + } + } + } + return NULL; } @@ -3331,9 +3354,24 @@ void jabber_init_plugin(PurplePlugin *plugin) { + GHashTable *ui_info = purple_core_get_ui_info(); + const gchar *ui_type = g_hash_table_lookup(ui_info, "client_type"); + const gchar *type = "pc"; /* default client type, if unknown or + unspecified */ + + if (ui_type) { + if (strcmp(ui_type, "pc") == 0 || + strcmp(ui_type, "console") == 0 || + strcmp(ui_type, "phone") == 0 || + strcmp(ui_type, "handheld") == 0 || + strcmp(ui_type, "web") == 0 || + strcmp(ui_type, "bot") == 0) { + type = ui_type; + } + } my_protocol = plugin; - jabber_add_identity("client", "pc", NULL, PACKAGE); + jabber_add_identity("client", type, NULL, PACKAGE); /* initialize jabber_features list */ jabber_add_feature("jabber:iq:last", 0); diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/msn/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/msn/state.c --- a/libpurple/protocols/msn/state.c Sun May 17 13:07:34 2009 +0000 +++ b/libpurple/protocols/msn/state.c Sun May 17 19:04:15 2009 +0000 @@ -21,6 +21,10 @@ * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA */ + +#include "internal.h" +#include "core.h" + #include "msn.h" #include "state.h" @@ -288,10 +292,29 @@ MsnUser *user; MsnObject *msnobj; const char *state_text; - + GHashTable *ui_info = purple_core_get_ui_info(); + MsnClientCaps caps = MSN_CLIENT_ID; + g_return_if_fail(session != NULL); g_return_if_fail(session->notification != NULL); + /* set client caps based on what the UI tells us it is... */ + if (ui_info) { + const gchar *client_type = g_hash_table_lookup(ui_info, "client_type"); + if (client_type) { + if (strcmp(client_type, "phone") == 0 || + strcmp(client_type, "handheld") == 0) { + caps |= MSN_CLIENT_CAP_WIN_MOBILE; + } else if (strcmp(client_type, "web")) { + caps |= MSN_CLIENT_CAP_WEBMSGR; + } else if (strcmp(client_type, "bot")) { + caps |= MSN_CLIENT_CAP_BOT; + } + /* MSN doesn't a "console" type... + What, they have no ncurses UI? :-) */ + } + } + account = session->account; cmdproc = session->notification->cmdproc; user = session->user; @@ -307,8 +330,7 @@ if (msnobj == NULL) { - msn_cmdproc_send(cmdproc, "CHG", "%s %d", state_text, - MSN_CLIENT_ID); + msn_cmdproc_send(cmdproc, "CHG", "%s %d", state_text, caps); } else { @@ -317,7 +339,7 @@ msnobj_str = msn_object_to_string(msnobj); msn_cmdproc_send(cmdproc, "CHG", "%s %d %s", state_text, - MSN_CLIENT_ID, purple_url_encode(msnobj_str)); + caps, purple_url_encode(msnobj_str)); g_free(msnobj_str); } diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/msnp9/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/myspace/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/novell/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/oscar/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/qq/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/sametime/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/silc/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/simple/Makefile.am diff -r 12d1711e1667 -r d2424873c666 libpurple/protocols/zephyr/Makefile.am diff -r 12d1711e1667 -r d2424873c666 pidgin/gtkconn.c diff -r 12d1711e1667 -r d2424873c666 pidgin/gtkmain.c --- a/pidgin/gtkmain.c Sun May 17 13:07:34 2009 +0000 +++ b/pidgin/gtkmain.c Sun May 17 19:04:15 2009 +0000 @@ -353,6 +353,7 @@ g_hash_table_insert(ui_info, "version", VERSION); g_hash_table_insert(ui_info, "website", "http://pidgin.im"); g_hash_table_insert(ui_info, "dev_website", "http://developer.pidgin.im"); + g_hash_table_insert(ui_info, "client_type", "pc"); } return ui_info; diff -r 12d1711e1667 -r d2424873c666 pidgin/plugins/cap/Makefile.am diff -r 12d1711e1667 -r d2424873c666 pidgin/plugins/gestures/Makefile.am diff -r 12d1711e1667 -r d2424873c666 pidgin/plugins/gevolution/Makefile.am diff -r 12d1711e1667 -r d2424873c666 pidgin/plugins/musicmessaging/Makefile.am diff -r 12d1711e1667 -r d2424873c666 pidgin/plugins/ticker/Makefile.am