adium: 6f2ee12a: facebookchat svn at r463.

zacw at adiumx.com zacw at adiumx.com
Sat May 2 15:20:27 EDT 2009


-----------------------------------------------------------------
Revision: 6f2ee12a3da60beab8a2df575653fce061b7e8b1
Ancestor: d426726115c911c7b6006becc903308f988dd7cb
Author: zacw at adiumx.com
Date: 2009-05-02T19:03:54
Branch: im.pidgin.adium
URL: http://d.pidgin.im/viewmtn/revision/info/6f2ee12a3da60beab8a2df575653fce061b7e8b1

Modified files:
        libpurple/protocols/facebook/fb_blist.c
        libpurple/protocols/facebook/fb_connection.c
        libpurple/protocols/facebook/fb_managefriends.c
        libpurple/protocols/facebook/fb_messages.c
        libpurple/protocols/facebook/libfacebook.c
        libpurple/protocols/facebook/pidgin-facebookchat.rc
        libpurple/protocols/facebook/rss.xml

ChangeLog: 

facebookchat svn at r463.

-------------- next part --------------
============================================================
--- libpurple/protocols/facebook/fb_blist.c	c8ae76955f130eb0d93fbea79efe34bf98007be3
+++ libpurple/protocols/facebook/fb_blist.c	4a02f018ba3dac7cc7bc76cac9921751dacf09f3
@@ -318,22 +318,26 @@ static void got_buddy_list_cb(FacebookAc
 			/* Turn the \/ into / */
 			tmp = g_strcompress(buddy_icon_url);
 
-			/* small icon at http://profile.ak.facebook.com/profile6/1845/74/q800753867_2878.jpg */
-			/* bigger icon at http://profile.ak.facebook.com/profile6/1845/74/n800753867_2878.jpg */
-			search_tmp = strstr(tmp, "/q");
-			if (search_tmp)
-				*(search_tmp + 1) = 'n';
-
 			if (g_str_equal(tmp, "http://static.ak.fbcdn.net/pics/q_silhouette.gif"))
+			{
 				/* User has no icon */
 				purple_buddy_icons_set_for_user(fba->account,
 						purple_buddy_get_name(buddy), NULL, 0, NULL);
+			}
 			else
+			{
+				/* small icon at http://profile.ak.facebook.com/profile6/1845/74/q800753867_2878.jpg */
+				/* bigger icon at http://profile.ak.facebook.com/profile6/1845/74/n800753867_2878.jpg */
+				search_tmp = strstr(tmp, "/q");
+				if (search_tmp)
+					*(search_tmp + 1) = 'n';
+				
 				/* Fetch their icon */
 				fb_post_or_get(fba, FB_METHOD_GET, "profile.ak.facebook.com",
 						tmp + strlen("http://profile.ak.facebook.com"), NULL,
 						buddy_icon_cb, g_strdup(purple_buddy_get_name(buddy)),
 					FALSE);
+			}
 			g_free(tmp);
 		}
 		g_free(buddy_icon_url);
============================================================
--- libpurple/protocols/facebook/fb_connection.c	404289452b1ede585959c8ae9561b9e730af6af9
+++ libpurple/protocols/facebook/fb_connection.c	9a80b89fd6fe38724437f7ac53723b107442e459
@@ -103,7 +103,7 @@ static void fb_update_cookies(FacebookAc
 	/* grab the data up until ';' */
 	cookie_start = headers;
 	while ((cookie_start = strstr(cookie_start, "\r\nSet-Cookie: ")) &&
-			(headers-cookie_start) < header_len)
+			(cookie_start - headers) < header_len)
 	{
 		cookie_start += 14;
 		cookie_end = strchr(cookie_start, '=');
============================================================
--- libpurple/protocols/facebook/fb_managefriends.c	bdd64e0ef56c78433fafd7899367bbf0b9e32cdb
+++ libpurple/protocols/facebook/fb_managefriends.c	13711a39b329088119005f6dd7c6ec6617de8f26
@@ -130,9 +130,10 @@ static void fb_check_friend_request_cb(F
 				name, msg_plain, TRUE,
 				fb_auth_accept_cb, fb_auth_reject_cb, buddy);
 
+		g_free(name);
 		g_free(uid);
-		/* TODO: msg_plain might be leaking here? */
-
+		g_free(msg_plain);
+		
 		/* Don't display an auth request for this buddy again */
 		fba->auth_buddies = g_slist_prepend(
 				fba->auth_buddies, GINT_TO_POINTER(uid_int));
============================================================
--- libpurple/protocols/facebook/fb_messages.c	6831ce6a6068eedeba1fe863b4610515b3394807
+++ libpurple/protocols/facebook/fb_messages.c	09af6820f46c993c5874e2765e3d40831096b7ee
@@ -341,13 +341,7 @@ static gboolean fb_get_new_messages(Face
 
 	if (fba->channel_number == NULL)
 	{
-		channel_number = purple_account_get_string(fba->account, "last_channel_number", NULL);
-		if (channel_number == NULL)
-		{
-			/* channel number is probably updating */
-			fba->new_messages_check_timer = purple_timeout_add_seconds(3 - (now - fba->last_messages_download_time), (GSourceFunc)fb_get_new_messages, fba);
-			return FALSE;
-		}
+		return FALSE;
 	} else {
 		channel_number = fba->channel_number;
 	}
@@ -499,44 +493,31 @@ static void got_form_id_page(FacebookAcc
 	g_free(fba->post_form_id);
 	fba->post_form_id = post_form_id;
 
-	/* dodgy as search for channel server number */
-	if (!fba->channel_number)
+	/* search for channel server number. we might want to use
+         * /ajax/presence/reconnect.php in the future */
+	start_text = "\", \"channel";
+	tmp = g_strstr_len(data, data_len, start_text);
+	if (tmp == NULL)
 	{
-		start_text = "\", \"channel";
+		/* Some proxies strip whitepsace */
+		start_text = "\",\"channel";
 		tmp = g_strstr_len(data, data_len, start_text);
 		if (tmp == NULL)
 		{
-			/* Some proxies strip whitepsace */
-			start_text = "\",\"channel";
-			tmp = g_strstr_len(data, data_len, start_text);
-			if (tmp == NULL)
-			{
-				/* TODO: Is it better to pick a random channel number or to disconnect? */
-				/* MARKCONFLICT (r283,r286) */
-				channel_number = g_strdup(purple_account_get_string(fba->account, "last_channel_number", ""));
-				if (channel_number[0] == '\0')
-				{
-					purple_debug_error("facebook", "couldn't find channel\n");
-					purple_debug_misc("facebook", "page content: %s\n", data);
-					purple_connection_error_reason(fba->pc,
-							PURPLE_CONNECTION_ERROR_NETWORK_ERROR,
-							_("Chat service currently unavailable."));
-					return;
-				}
-			}
+			purple_debug_error("facebook", "couldn't find channel\n");
+			purple_debug_misc("facebook", "page content: %s\n", data);
+			purple_connection_error_reason(fba->pc,
+				PURPLE_CONNECTION_ERROR_NETWORK_ERROR,
+				_("Chat service currently unavailable."));
+			return;
 		}
-
-		if (tmp != NULL)
-		{
-			tmp += strlen(start_text);
-			channel_number = g_strndup(tmp, strchr(tmp, '"') - tmp);
-		}
-
-		purple_account_set_string(fba->account, "last_channel_number", channel_number);
-
-		g_free(fba->channel_number);
-		fba->channel_number = channel_number;
 	}
+	
+	tmp += strlen(start_text);
+	channel_number = g_strndup(tmp, strchr(tmp, '"') - tmp);
+	
+	g_free(fba->channel_number);
+	fba->channel_number = channel_number;
 
 	tmp = g_strdup_printf("visibility=true&post_form_id=%s", post_form_id);
 	fb_post_or_get(fba, FB_METHOD_POST, "apps.facebook.com", "/ajax/chat/settings.php", tmp, NULL, NULL, FALSE);
============================================================
--- libpurple/protocols/facebook/libfacebook.c	845e5f8dd761ecab24105b9ccd26ea8b052cdc58
+++ libpurple/protocols/facebook/libfacebook.c	171834be239f664301869ffb3a517a1cc548fa56
@@ -261,7 +261,7 @@ static void fb_login(PurpleAccount *acco
 {
 	FacebookAccount *fba;
 	guint16 i;
-	gchar *postdata, *encoded_username, *encoded_password;
+	gchar *postdata, *encoded_username, *encoded_password, *encoded_charset_test;
 
 	/* Create account and initialize state */
 	fba = g_new0(FacebookAccount, 1);
@@ -297,12 +297,14 @@ static void fb_login(PurpleAccount *acco
 			purple_account_get_username(fba->account)));
 	encoded_password = g_strdup(purple_url_encode(
 			purple_account_get_password(fba->account)));
+	encoded_charset_test = g_strdup(purple_url_encode("EUR,?,EUR,?,?,?,?"));
 
 	postdata = g_strdup_printf(
-			"email=%s&pass=%s&persistent=1&login=Login&charset_test=%%E2%%AC%%C2%%B4%%E2%%82%%AC%%C2%%B4%%E6%%B0%%B4%%D0%%94%%D0%%84",
-			encoded_username, encoded_password);
+			"email=%s&pass=%s&persistent=1&login=Login&charset_test=%s",
+			encoded_username, encoded_password, encoded_charset_test);
 	g_free(encoded_username);
 	g_free(encoded_password);
+	g_free(encoded_charset_test);
 
 	fb_post_or_get(fba, FB_METHOD_POST | FB_METHOD_SSL, "login.facebook.com",
 			"/login.php", postdata, fb_login_cb, NULL, FALSE);
============================================================
--- libpurple/protocols/facebook/pidgin-facebookchat.rc	69d4e8083a8b82a2ecc42c286cc3b47243d38a75
+++ libpurple/protocols/facebook/pidgin-facebookchat.rc	18e43509de2ce09ee5a4fde52ac334a133eb2d02
@@ -1,7 +1,7 @@ 1 VERSIONINFO
 
 1 VERSIONINFO
-FILEVERSION 1,47,0,0
-PRODUCTVERSION 1,47,0,0
+FILEVERSION 1,50,0,0
+PRODUCTVERSION 1,50,0,0
 FILEOS 0x40004 // VOS_NT_WINDOWS32
 FILETYPE 0x2 // VFT_DLL
 {
@@ -9,14 +9,14 @@ BLOCK "StringFileInfo"
 {
 	BLOCK "040904B0" // U.S. English, Unicode
 	{
-		VALUE "CompanyName", "Pidgin-facebookchat Developers\0"
+		VALUE "CompanyName", "Eion Robb\0"
 		VALUE "FileDescription",  "Facebook Chat plugin for Pidgin\0"
 		VALUE "ProductName", "pidgin-facebookchat\0"
-		VALUE "FileVersion", "1.47\0"
-		VALUE "ProductVersion", "1.47\0"
+		VALUE "FileVersion", "1.50\0"
+		VALUE "ProductVersion", "1.50\0"
 		VALUE "InternalName", "pidgin-facebookchat\0"
 		VALUE "OriginalFilename", "pidgin-facebookchat.dll\0"
-		VALUE "Comments", "http://code.google.com/p/pidgin-facebookchat\0"
+		VALUE "Comments", "http://pidgin-facebookchat.googlecode.com/\0"
 	}
 }
 
============================================================
--- libpurple/protocols/facebook/rss.xml	2d2064433f85019ffe97cd0d86665437ecdcaa50
+++ libpurple/protocols/facebook/rss.xml	d62ddd39ac317b8409bc64d84a3c848dafeb23b7
@@ -13,6 +13,20 @@
 			<width>48</width><height>48</height>
 		</image>
 		<item>
+			<title>Version 1.50</title>
+			<link>http://code.google.com/p/pidgin-facebookchat/issues/detail?id=24#c42</link>
+			<description><![CDATA[So its been a while since the last version so I've bumped it up to v1.50.
+			<br/><br/>
+			This version should (hopefully) fix the bandwidth issues that people are having, as well as a crash-on-quit issue.			
+			<br/><br/>
+			Oh, and some people may be interested to try setting their status to 'idle' when they set their status to 'away'.  Maybe.  Haven't tried it :)
+			<br/><br/>
+			Download v1.50 of the plugin from:<br/>
+<a href="http://code.google.com/p/pidgin-facebookchat/downloads/list">http://code.google.com/p/pidgin-facebookchat/downloads/list</a>]]></description>
+			<pubDate>Mon, 13 Apr 2009 00:03:29 +1200</pubDate>
+			<guid isPermaLink="true">http://code.google.com/p/pidgin-facebookchat/issues/detail?id=24#c42</guid>
+		</item>	
+		<item>
 			<title>Version 1.47</title>
 			<link>http://code.google.com/p/pidgin-facebookchat/issues/detail?id=24#c41</link>
 			<description><![CDATA[v1.47 Gets rid of the "(via Pidgin)" but when setting status message and fixes some rare crashes


More information about the Commits mailing list