# HG changeset patch # User Elliott Sales de Andrade # Date 1234739478 0 # Node ID 93463c6114aa3f733caffc8fc700c144f45b76b8 # Parent 15fc25014ce261aa8086e0d13b1308597e332089# Parent 2cece7df80c3fd2597af1194dfc86df82039c083 merge of '4021ee6bbfa81bd2fda8e2760cb4ae05d5c30083' and 'efefbfc4bbf45f2744736df7f5e2ee83c21629f6' diff -r 2cece7df80c3 -r 93463c6114aa libpurple/protocols/msn/contact.c --- a/libpurple/protocols/msn/contact.c Sun Feb 15 21:56:50 2009 +0000 +++ b/libpurple/protocols/msn/contact.c Sun Feb 15 23:11:18 2009 +0000 @@ -198,6 +198,8 @@ MsnCallbackState *state = data; xmlnode *fault; char *faultcode_str; + xmlnode *cachekey; + char *changed; if (resp == NULL) { purple_debug_error("msn", @@ -206,12 +208,27 @@ return; } + /* Update CacheKey if necessary */ + cachekey = xmlnode_get_child(resp->xml, "Header/ServiceHeader/CacheKeyChanged"); + if (cachekey != NULL) { + changed = xmlnode_get_data(cachekey); + if (changed && !strcmp(changed, "true")) { + cachekey = xmlnode_get_child(resp->xml, "Header/ServiceHeader/CacheKey"); + g_free(state->session->abch_cachekey); + state->session->abch_cachekey = xmlnode_get_data(cachekey); + purple_debug_info("msn", "Updated CacheKey for %s to '%s'.\n", + purple_account_get_username(state->session->account), + state->session->abch_cachekey); + } + g_free(changed); + } + fault = xmlnode_get_child(resp->xml, "Body/Fault"); if (fault == NULL) { /* No errors */ if (state->cb) - ((MsnSoapCallback)state->cb)(req, resp, data); + state->cb(req, resp, data); msn_callback_state_free(state); return; } @@ -230,7 +247,7 @@ else { if (state->cb) { - ((MsnSoapCallback)state->cb)(req, resp, data); + state->cb(req, resp, data); } else { /* We don't know how to respond to this faultcode, so log it */ char *str = xmlnode_to_str(fault, NULL); @@ -247,6 +264,14 @@ static gboolean msn_contact_request(MsnCallbackState *state) { + xmlnode *cachekey = xmlnode_get_child(state->body, + "Header/ABApplicationHeader/CacheKey"); + if (cachekey != NULL) + xmlnode_free(cachekey); + if (state->session->abch_cachekey != NULL) { + cachekey = xmlnode_new_child(xmlnode_get_child(state->body, "Header/ABApplicationHeader"), "CacheKey"); + xmlnode_insert_data(cachekey, state->session->abch_cachekey, -1); + } if (state->token == NULL) state->token = xmlnode_get_child(state->body, "Header/ABAuthHeader/TicketToken"); diff -r 2cece7df80c3 -r 93463c6114aa libpurple/protocols/msn/msg.c --- a/libpurple/protocols/msn/msg.c Sun Feb 15 21:56:50 2009 +0000 +++ b/libpurple/protocols/msn/msg.c Sun Feb 15 23:11:18 2009 +0000 @@ -352,6 +352,14 @@ memcpy(msg->body, tmp, msg->body_len); msg->body[msg->body_len] = '\0'; } + + if (msg->charset == NULL) { + char *body = g_convert(msg->body, msg->body_len, "UTF-8", + "ISO-8859-1", NULL, &msg->body_len, NULL); + g_free(msg->body); + msg->body = body; + msg->charset = g_strdup("UTF-8"); + } } g_free(tmp_base); diff -r 2cece7df80c3 -r 93463c6114aa libpurple/protocols/msn/msnutils.c --- a/libpurple/protocols/msn/msnutils.c Sun Feb 15 21:56:50 2009 +0000 +++ b/libpurple/protocols/msn/msnutils.c Sun Feb 15 23:11:18 2009 +0000 @@ -446,7 +446,7 @@ } if (fontface == NULL) - fontface = g_strdup("MS Sans Serif"); + fontface = g_strdup("Segoe UI"); *attributes = g_strdup_printf("FN=%s; EF=%s; CO=%s; PF=0; RL=%c", encode_spaces(fontface), diff -r 2cece7df80c3 -r 93463c6114aa libpurple/protocols/msn/nexus.c --- a/libpurple/protocols/msn/nexus.c Sun Feb 15 21:56:50 2009 +0000 +++ b/libpurple/protocols/msn/nexus.c Sun Feb 15 23:11:18 2009 +0000 @@ -74,6 +74,7 @@ for (i = 0; i < nexus->token_len; i++) { g_hash_table_destroy(nexus->tokens[i].token); g_free(nexus->tokens[i].secret); + g_slist_free(nexus->tokens[i].updates); } g_free(nexus->tokens); diff -r 2cece7df80c3 -r 93463c6114aa libpurple/protocols/msn/notification.c --- a/libpurple/protocols/msn/notification.c Sun Feb 15 21:56:50 2009 +0000 +++ b/libpurple/protocols/msn/notification.c Sun Feb 15 23:11:18 2009 +0000 @@ -1619,19 +1619,25 @@ return; } - psm_str = msn_get_psm(cmd->payload,len); - msn_user_set_statusline(user, psm_str); - g_free(psm_str); + if (len != 0) { + psm_str = msn_get_psm(cmd->payload,len); + msn_user_set_statusline(user, psm_str); + g_free(psm_str); - str = msn_get_currentmedia(cmd->payload, len); - if (msn_parse_currentmedia(str, &media)) - msn_user_set_currentmedia(user, &media); - else + str = msn_get_currentmedia(cmd->payload, len); + if (msn_parse_currentmedia(str, &media)) + msn_user_set_currentmedia(user, &media); + else + msn_user_set_currentmedia(user, NULL); + g_free(media.title); + g_free(media.album); + g_free(media.artist); + g_free(str); + + } else { + msn_user_set_statusline(user, NULL); msn_user_set_currentmedia(user, NULL); - g_free(media.title); - g_free(media.album); - g_free(media.artist); - g_free(str); + } msn_user_update(user); } diff -r 2cece7df80c3 -r 93463c6114aa libpurple/protocols/msn/session.c --- a/libpurple/protocols/msn/session.c Sun Feb 15 21:56:50 2009 +0000 +++ b/libpurple/protocols/msn/session.c Sun Feb 15 23:11:18 2009 +0000 @@ -90,8 +90,10 @@ msn_userlist_destroy(session->userlist); g_free(session->psm); - + g_free(session->abch_cachekey); +#if 0 g_free(session->blocked_text); +#endif g_free(session->passport_info.kv); g_free(session->passport_info.sid); diff -r 2cece7df80c3 -r 93463c6114aa libpurple/protocols/msn/session.h --- a/libpurple/protocols/msn/session.h Sun Feb 15 21:56:50 2009 +0000 +++ b/libpurple/protocols/msn/session.h Sun Feb 15 23:11:18 2009 +0000 @@ -94,11 +94,11 @@ gboolean http_method; MsnNotification *notification; - MsnNexus *nexus; - MsnOim *oim; - MsnSync *sync; - - MsnUserList *userlist; + MsnNexus *nexus; + MsnOim *oim; + MsnSync *sync; + MsnUserList *userlist; + char *abch_cachekey; int servconns_count; /**< The count of server connections. */ GList *switches; /**< The list of all the switchboards. */ @@ -107,7 +107,9 @@ /*psm info*/ char *psm; +#if 0 char *blocked_text; +#endif struct {