diff libpurple/protocols/jabber/jabber.c @ 26187:00eb738116ae

propagate from branch 'im.pidgin.pidgin' (head 73e463add9a124c86554c2958526e1a6ee5fc22f) to branch 'im.pidgin.cpw.malu.client_type' (head c34e7e9b1b7e8671cdf8e58c09154dbd591beb70)
author Marcus Lundblad <ml@update.uu.se>
date Mon, 16 Mar 2009 21:46:01 +0000
parents 7ace7bf0bfad ae2b4394fbe2
children cec679e45332
line wrap: on
line diff
--- a/libpurple/protocols/jabber/jabber.c	Mon Mar 16 17:07:41 2009 +0000
+++ b/libpurple/protocols/jabber/jabber.c	Mon Mar 16 21:46:01 2009 +0000
@@ -1634,7 +1634,7 @@
 	JabberStream *js;
 	JabberBuddy *jb = NULL;
 	PurpleConnection *gc = purple_account_get_connection(purple_buddy_get_account(b));
-
+	
 	if(!gc)
 		return NULL;
 
@@ -1647,6 +1647,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;
 }