diff options
| author | Wilmer van der Gaast <wilmer@gaast.net> | 2006-10-18 19:47:08 +0200 | 
|---|---|---|
| committer | Wilmer van der Gaast <wilmer@gaast.net> | 2006-10-18 19:47:08 +0200 | 
| commit | 1991be623c6c53d2f61f0b15405d41d144c21c8f (patch) | |
| tree | 0b20fcf91e54b7aa41d445c0b0f0331b75611221 | |
| parent | e7276082fede405633f63d38fe18e010e897a972 (diff) | |
get_info() now displays vCard information too.
| -rw-r--r-- | protocols/jabber/iq.c | 142 | ||||
| -rw-r--r-- | protocols/jabber/jabber.c | 2 | ||||
| -rw-r--r-- | protocols/jabber/jabber.h | 1 | 
3 files changed, 145 insertions, 0 deletions
| diff --git a/protocols/jabber/iq.c b/protocols/jabber/iq.c index ccf9d30c..8864e3fd 100644 --- a/protocols/jabber/iq.c +++ b/protocols/jabber/iq.c @@ -320,6 +320,148 @@ static xt_status jabber_parse_roster( struct gaim_connection *gc, struct xt_node  	return XT_HANDLED;  } +static xt_status jabber_iq_display_vcard( struct gaim_connection *gc, struct xt_node *node, struct xt_node *orig ); + +int jabber_get_vcard( struct gaim_connection *gc, char *bare_jid ) +{ +	struct xt_node *node; +	 +	if( strchr( bare_jid, '/' ) ) +		return 1;	/* This was an error, but return 0 should only be done if the connection died... */ +	 +	node = xt_new_node( "vCard", NULL, NULL ); +	xt_add_attr( node, "xmlns", "vcard-temp" ); +	node = jabber_make_packet( "iq", "get", bare_jid, node ); +	 +	jabber_cache_add( gc, node, jabber_iq_display_vcard ); +	return jabber_write_packet( gc, node ); +} + +static xt_status jabber_iq_display_vcard( struct gaim_connection *gc, struct xt_node *node, struct xt_node *orig ) +{ +	struct xt_node *vc, *c, *sc; /* subchild, gc is already in use ;-) */ +	GString *reply; +	char *s; +	 +	if( ( s = xt_find_attr( node, "type" ) ) == NULL || +	    strcmp( s, "result" ) != 0 || +	    ( vc = xt_find_node( node->children, "vCard" ) ) == NULL ) +	{ +		s = xt_find_attr( orig, "to" ); /* If this returns NULL something's wrong.. */ +		serv_got_crap( gc, "Could not retrieve vCard of %s", s ? s : "(NULL)" ); +		return XT_HANDLED; +	} +	 +	s = xt_find_attr( orig, "to" ); +	reply = g_string_new( "vCard information for " ); +	reply = g_string_append( reply, s ? s : "(NULL)" ); +	reply = g_string_append( reply, ":\n" ); +	 +	/* I hate this format, I really do... */ +	 +	if( ( c = xt_find_node( vc->children, "FN" ) ) && c->text_len ) +		g_string_append_printf( reply, "Name: %s\n", c->text ); +	 +	if( ( c = xt_find_node( vc->children, "N" ) ) && c->children ) +	{ +		reply = g_string_append( reply, "Full name:" ); +		 +		if( ( sc = xt_find_node( c->children, "PREFIX" ) ) && sc->text_len ) +			g_string_append_printf( reply, " %s", sc->text ); +		if( ( sc = xt_find_node( c->children, "GIVEN" ) ) && sc->text_len ) +			g_string_append_printf( reply, " %s", sc->text ); +		if( ( sc = xt_find_node( c->children, "MIDDLE" ) ) && sc->text_len ) +			g_string_append_printf( reply, " %s", sc->text ); +		if( ( sc = xt_find_node( c->children, "FAMILY" ) ) && sc->text_len ) +			g_string_append_printf( reply, " %s", sc->text ); +		if( ( sc = xt_find_node( c->children, "SUFFIX" ) ) && sc->text_len ) +			g_string_append_printf( reply, " %s", sc->text ); +		 +		reply = g_string_append_c( reply, '\n' ); +	} +	 +	if( ( c = xt_find_node( vc->children, "NICKNAME" ) ) && c->text_len ) +		g_string_append_printf( reply, "Nickname: %s\n", c->text ); +	 +	if( ( c = xt_find_node( vc->children, "BDAY" ) ) && c->text_len ) +		g_string_append_printf( reply, "Date of birth: %s\n", c->text ); +	 +	/* Slightly alternative use of for... ;-) */ +	for( c = vc->children; ( c = xt_find_node( c, "EMAIL" ) ); c = c->next ) +	{ +		if( ( sc = xt_find_node( c->children, "USERID" ) ) == NULL || sc->text_len == 0 ) +			continue; +		 +		if( xt_find_node( c->children, "HOME" ) ) +			s = "Home"; +		else if( xt_find_node( c->children, "WORK" ) ) +			s = "Work"; +		else +			s = "Misc."; +		 +		g_string_append_printf( reply, "%s e-mail address: %s\n", s, sc->text ); +	} +	 +	if( ( c = xt_find_node( vc->children, "URL" ) ) && c->text_len ) +		g_string_append_printf( reply, "Homepage: %s\n", c->text ); +	 +	/* Slightly alternative use of for... ;-) */ +	for( c = vc->children; ( c = xt_find_node( c, "ADR" ) ); c = c->next ) +	{ +		if( xt_find_node( c->children, "HOME" ) ) +			s = "Home"; +		else if( xt_find_node( c->children, "WORK" ) ) +			s = "Work"; +		else +			s = "Misc."; +		 +		g_string_append_printf( reply, "%s address: ", s ); +		 +		if( ( sc = xt_find_node( c->children, "STREET" ) ) && sc->text_len ) +			g_string_append_printf( reply, "%s ", sc->text ); +		if( ( sc = xt_find_node( c->children, "EXTADR" ) ) && sc->text_len ) +			g_string_append_printf( reply, "%s, ", sc->text ); +		if( ( sc = xt_find_node( c->children, "PCODE" ) ) && sc->text_len ) +			g_string_append_printf( reply, "%s, ", sc->text ); +		if( ( sc = xt_find_node( c->children, "LOCALITY" ) ) && sc->text_len ) +			g_string_append_printf( reply, "%s, ", sc->text ); +		if( ( sc = xt_find_node( c->children, "REGION" ) ) && sc->text_len ) +			g_string_append_printf( reply, "%s, ", sc->text ); +		if( ( sc = xt_find_node( c->children, "CTRY" ) ) && sc->text_len ) +			g_string_append_printf( reply, "%s", sc->text ); +		 +		if( reply->str[reply->len-2] == ',' ) +			reply = g_string_truncate( reply, reply->len-2 ); +		 +		reply = g_string_append_c( reply, '\n' ); +	} +	 +	for( c = vc->children; ( c = xt_find_node( c, "TEL" ) ); c = c->next ) +	{ +		if( ( sc = xt_find_node( c->children, "NUMBER" ) ) == NULL || sc->text_len == 0 ) +			continue; +		 +		if( xt_find_node( c->children, "HOME" ) ) +			s = "Home"; +		else if( xt_find_node( c->children, "WORK" ) ) +			s = "Work"; +		else +			s = "Misc."; +		 +		g_string_append_printf( reply, "%s phone number: %s\n", s, sc->text ); +	} +	 +	if( ( c = xt_find_node( vc->children, "DESC" ) ) && c->text_len ) +		g_string_append_printf( reply, "Other information:\n%s", c->text ); +	 +	/* *sigh* */ +	 +	serv_got_crap( gc, reply->str ); +	g_string_free( reply, TRUE ); +	 +	return XT_HANDLED; +} +  int jabber_add_to_roster( struct gaim_connection *gc, char *handle, char *name )  {  	struct xt_node *node; diff --git a/protocols/jabber/jabber.c b/protocols/jabber/jabber.c index abc3837b..f460aff2 100644 --- a/protocols/jabber/jabber.c +++ b/protocols/jabber/jabber.c @@ -201,6 +201,8 @@ static void jabber_get_info( struct gaim_connection *gc, char *who )  		                   bud->away_message ? : "(none)" );  		bud = bud->next;  	} +	 +	jabber_get_vcard( gc, bud ? bud->handle : who );  }  static void jabber_set_away( struct gaim_connection *gc, char *state_txt, char *message ) diff --git a/protocols/jabber/jabber.h b/protocols/jabber/jabber.h index d1d452b4..cd65d374 100644 --- a/protocols/jabber/jabber.h +++ b/protocols/jabber/jabber.h @@ -111,6 +111,7 @@ xt_status jabber_pkt_iq( struct xt_node *node, gpointer data );  int jabber_init_iq_auth( struct gaim_connection *gc );  xt_status jabber_pkt_bind_sess( struct gaim_connection *gc, struct xt_node *node, struct xt_node *orig );  int jabber_get_roster( struct gaim_connection *gc ); +int jabber_get_vcard( struct gaim_connection *gc, char *bare_jid );  int jabber_add_to_roster( struct gaim_connection *gc, char *handle, char *name );  int jabber_remove_from_roster( struct gaim_connection *gc, char *handle ); | 
