adium.1-3: 09a69483: pidgin-facebookchat at r685.

zacw at adiumx.com zacw at adiumx.com
Wed Nov 4 20:35:44 EST 2009


-----------------------------------------------------------------
Revision: 09a6948342ee7d1beaf292349edefb7d35ce8975
Ancestor: a00ecf891b108bb09796d7770835216b7ce73e4f
Author: zacw at adiumx.com
Date: 2009-11-05T01:34:23
Branch: im.pidgin.adium.1-3
URL: http://d.pidgin.im/viewmtn/revision/info/09a6948342ee7d1beaf292349edefb7d35ce8975

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

ChangeLog: 

pidgin-facebookchat at r685.

-------------- next part --------------
============================================================
--- libpurple/protocols/facebook/facebook.nsi	27b05643b15daeeac1bff1585817edcc4e63db91
+++ libpurple/protocols/facebook/facebook.nsi	0a2bccf4de2f00e5527eac5cbc0facb8be28bf11
@@ -6,7 +6,7 @@ SetCompress off
 ; todo: SetBrandingImage
 ; HM NIS Edit Wizard helper defines
 !define PRODUCT_NAME "pidgin-facebookchat"
-!define PRODUCT_VERSION "1.61"
+!define PRODUCT_VERSION "1.62"
 !define PRODUCT_PUBLISHER "Eion Robb"
 !define PRODUCT_WEB_SITE "http://pidgin-facebookchat.googlecode.com/"
 !define PRODUCT_UNINST_KEY "Software\Microsoft\Windows\CurrentVersion\Uninstall\${PRODUCT_NAME}"
============================================================
--- libpurple/protocols/facebook/fb_blist.c	55a589254403723cac7bc7e62531ef9a5241e2a4
+++ libpurple/protocols/facebook/fb_blist.c	a26776243a31152e02bde9a0405a45db552c5121
@@ -498,8 +498,8 @@ gboolean fb_get_buddy_list(gpointer data
 	fba = data;
 
 	postdata = g_strdup_printf(
-			"user=%" G_GINT64_FORMAT "&popped_out=true&force_render=true&buddy_list=1&notifications=1",
-			fba->uid);
+			"user=%" G_GINT64_FORMAT "&popped_out=true&force_render=true&buddy_list=1&__a=1&post_form_id_source=AsyncRequest&post_form_id=%s&fb_dtsg=%s",
+			fba->uid, fba->post_form_id?fba->post_form_id:"(null)", fba->dtsg?fba->dtsg:"(null)");
 	fb_post_or_get(fba, FB_METHOD_POST, NULL, "/ajax/chat/buddy_list.php",
 			postdata, got_buddy_list_cb, NULL, FALSE);
 	g_free(postdata);
============================================================
--- libpurple/protocols/facebook/fb_messages.c	1b4165576e00b956a05890547ccc44abf85528a7
+++ libpurple/protocols/facebook/fb_messages.c	db485285cc61b901a8cfb8f38564c8d805dd7004
@@ -291,7 +291,7 @@ static gboolean fb_get_new_messages(Face
 
 	purple_debug_info("facebook", "getting new messages\n");
 
-	fetch_server = g_strdup_printf("%d.channel%s.facebook.com", 0, channel_number);
+	fetch_server = g_strdup_printf("%d.%s.facebook.com", 0, channel_number);
 	/* use the current time in the url to get past any transparent proxy caches */
 	fetch_url = g_strdup_printf("/x/%lu/%s/p_%" G_GINT64_FORMAT "=%d", (gulong)time(NULL), (fba->is_idle?"false":"true"), fba->uid, fba->message_fetch_sequence);
 
@@ -407,8 +407,6 @@ void got_reconnect_json(FacebookAccount 
 
 void got_reconnect_json(FacebookAccount *fba, gchar *data, gsize data_len, gpointer userdata)
 {
-	gchar *new_channel_number;
-	
 	JsonParser *parser;
 	JsonObject *objnode;
 
@@ -441,9 +439,8 @@ void got_reconnect_json(FacebookAccount 
 		return;
 	}
 	
-	new_channel_number = g_strdup(&new_channel_host[7]);
 	g_free(fba->channel_number);
-	fba->channel_number = new_channel_number;
+	fba->channel_number = g_strdup(new_channel_host);
 	
 	gint new_seq = json_node_get_int(json_object_get_member(payload, "seq"));
 	fba->message_fetch_sequence = new_seq;
@@ -458,7 +455,7 @@ gboolean fb_reconnect(FacebookAccount *f
 
 gboolean fb_reconnect(FacebookAccount *fba)
 {
-	gchar *url = g_strdup_printf("/ajax/presence/reconnect.php?reason=3&post_form_id=%s", fba->post_form_id);
+	gchar *url = g_strdup_printf("/ajax/presence/reconnect.php?reason=7&post_form_id=%s", fba->post_form_id);
 	fb_post_or_get(fba, FB_METHOD_GET, NULL, url, NULL, got_reconnect_json, NULL, FALSE);
 	g_free(url);
 	
@@ -468,7 +465,11 @@ static void got_form_id_page(FacebookAcc
 static void got_form_id_page(FacebookAccount *fba, gchar *data, gsize data_len, gpointer userdata)
 {
 	const gchar *start_text = "id=\"post_form_id\" name=\"post_form_id\" value=\"";
+	const gchar *dtsg_start = "fb_dtsg:\"";
+	const gchar *channel_start = "js\", \"channel";
+	const gchar *channel_start2 = "js\",\"channel";
 	gchar *post_form_id;
+	gchar *channel = NULL;
 	gchar *tmp = NULL;
 	
 	/* NULL data crashes on Windows */
@@ -488,17 +489,45 @@ static void got_form_id_page(FacebookAcc
 	}
 	tmp += strlen(start_text);
 	post_form_id = g_strndup(tmp, strchr(tmp, '"') - tmp);
-
+	
 	g_free(fba->post_form_id);
 	fba->post_form_id = post_form_id;
+	
+	tmp = g_strstr_len(data, data_len, dtsg_start);
+	if (tmp != NULL)
+	{
+		tmp += strlen(dtsg_start);
+		g_free(fba->dtsg);
+		fba->dtsg = g_strndup(tmp, strchr(tmp, '"') - tmp);
+	}
 
+	tmp = g_strstr_len(data, data_len, channel_start);
+	if (tmp != NULL)
+	{
+		tmp += 6;
+	} else {
+		tmp = g_strstr_len(data, data_len, channel_start2);
+		if (tmp != NULL)
+			tmp += 5;
+	}
+	if (tmp != NULL)
+	{
+		channel = g_strndup(tmp, strchr(tmp, '"') - tmp);
+		g_free(fba->channel_number);
+		fba->channel_number = channel;
+	}
 
 	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);
 	g_free(tmp);
 	
-	/* Grab new channel number */
-	fb_reconnect(fba);
+	if (channel == NULL)
+	{
+		/* Grab new channel number */
+		fb_reconnect(fba);
+	} else {
+		fb_get_new_messages(fba);
+	}
 }
 
 gboolean fb_get_post_form_id(FacebookAccount *fba)
============================================================
--- libpurple/protocols/facebook/libfacebook.c	c79f5931a33700bcd827cbf76b222bef530e0a31
+++ libpurple/protocols/facebook/libfacebook.c	2d32ec731cd3af31e053880370477b39222df7fa
@@ -227,6 +227,8 @@ static void fb_login_cb(FacebookAccount 
 	
 	if (len && g_strstr_len(response, len, "captcha"))
 	{
+		purple_debug_info("facebook", "captcha page: %s\n", response);
+
 		purple_connection_update_progress(fba->pc, _("Handling Captcha"), 2, 4);
 		
 		const gchar *persist_data_start = "<input type=\"hidden\" id=\"captcha_persist_data\" name=\"captcha_persist_data\" value=\"";
@@ -259,6 +261,7 @@ static void fb_login_cb(FacebookAccount 
 		
 		if (!fba->extra_challenge || !fba->persist_data || !fba->captcha_session)
 		{
+			purple_debug_info("facebook", "captcha response: %s\n", response);
 			g_free(fba->extra_challenge);
 			g_free(fba->persist_data);
 			g_free(fba->captcha_session);
@@ -382,8 +385,10 @@ static void fb_login(PurpleAccount *acco
 	if (locale == NULL || g_str_equal(locale, "C"))
 		locale = "en_US";
 
+	g_hash_table_replace(fba->cookie_table, g_strdup("lsd"), g_strdup("abcde"));
+
 	postdata = g_strdup_printf(
-			"charset_test=%s&locale=%s&email=%s&pass=%s&pass_placeHolder=Password&persistent=1&login=Login&charset_test=%s",
+			"charset_test=%s&locale=%s&email=%s&pass=%s&pass_placeHolder=Password&persistent=1&login=Login&charset_test=%s&lsd=abcde",
 			encoded_charset_test, locale, encoded_username, encoded_password, encoded_charset_test);
 	g_free(encoded_username);
 	g_free(encoded_password);
@@ -488,6 +493,7 @@ static void fb_close(PurpleConnection *p
 	g_hash_table_destroy(fba->hostname_ip_cache);
 	g_hash_table_destroy(fba->auth_buddies);
 	g_free(fba->post_form_id);
+	g_free(fba->dtsg);
 	g_free(fba->channel_number);
 	g_free(fba->last_status_message);
 	g_free(fba->extra_challenge);
============================================================
--- libpurple/protocols/facebook/libfacebook.h	320fb4a16727ec862f67f3087ace1a23f7ea1ef2
+++ libpurple/protocols/facebook/libfacebook.h	b56c2baea512f6680c01f5ea2c85cbbab5f1f51d
@@ -21,7 +21,7 @@
 #ifndef LIBFACEBOOK_H
 #define LIBFACEBOOK_H
 
-#define FACEBOOK_PLUGIN_VERSION "1.61"
+#define FACEBOOK_PLUGIN_VERSION "1.62"
 #define FACEBOOK_PLUGIN_ID "prpl-bigbrownchunx-facebookim"
 #define FACEBOOK_CAPTCHA_SITE "6LezHAAAAAAAADqVjseQ3ctG3ocfQs2Elo1FTa_a"
 
@@ -110,6 +110,7 @@ struct _FacebookAccount {
 	gchar *captcha_session;
 	gint last_status_timestamp;
 	guint bad_buddy_list_count;
+	gchar *dtsg;
 };
 
 struct _FacebookBuddy {
============================================================
--- libpurple/protocols/facebook/pidgin-facebookchat.rc	df1d296b5f3e4af608710ac1adbc8bbe5d0bae04
+++ libpurple/protocols/facebook/pidgin-facebookchat.rc	9d0c53b057522ae3de5007d9121259ce641eb8f6
@@ -1,7 +1,7 @@ 1 VERSIONINFO
 
 1 VERSIONINFO
-FILEVERSION 1,61,0,0
-PRODUCTVERSION 1,61,0,0
+FILEVERSION 1,62,0,0
+PRODUCTVERSION 1,62,0,0
 FILEOS 0x40004 // VOS_NT_WINDOWS32
 FILETYPE 0x2 // VFT_DLL
 {
@@ -12,8 +12,8 @@ BLOCK "StringFileInfo"
 		VALUE "CompanyName", "Eion Robb\0"
 		VALUE "FileDescription",  "Facebook Chat plugin for Pidgin\0"
 		VALUE "ProductName", "pidgin-facebookchat\0"
-		VALUE "FileVersion", "1.61\0"
-		VALUE "ProductVersion", "1.61\0"
+		VALUE "FileVersion", "1.62\0"
+		VALUE "ProductVersion", "1.62\0"
 		VALUE "InternalName", "pidgin-facebookchat\0"
 		VALUE "OriginalFilename", "libfacebook.dll\0"
 		VALUE "Comments", "http://pidgin-facebookchat.googlecode.com/\0"
============================================================
--- libpurple/protocols/facebook/rss.xml	5307d58e8af5e6e4481d89e241d46b35b5baefde
+++ libpurple/protocols/facebook/rss.xml	baa5c5a1ad452cb3c2f2b341993062adf99d7f29
@@ -13,6 +13,18 @@
 			<width>48</width><height>48</height>
 		</image>
 		<item>
+			<title>Version 1.62</title>
+			<link>http://code.google.com/p/pidgin-facebookchat/issues/detail?id=24#c50</link>
+			<description><![CDATA[Some of you fancy people might have noticed that the plugin hasn't been doing too well over the last few hours.<br/>
+			Fortunately, I've been hard at work to quickly push out a new version.<br/>
+			<br/>
+			Grab it from<br/>
+			<a href="http://code.google.com/p/pidgin-facebookchat/wiki/Downloads">http://code.google.com/p/pidgin-facebookchat/wiki/Downloads</a><br/>
+			while it's still hot]]></description>
+			<pubDate>Wed, 4 November 2009 18:49:10 +1300</pubDate>
+			<guid isPermaLink="true">http://code.google.com/p/pidgin-facebookchat/issues/detail?id=24#c50</guid>
+		</item>
+		<item>
 			<title>Version 1.61</title>
 			<link>http://code.google.com/p/pidgin-facebookchat/issues/detail?id=24#c49</link>
 			<description><![CDATA[Against all odds, I've just put out a new version 1.61 of the plugin.  It should fix up the problems with messages arriving from weird numbers, but it also now requires version 0.7.6 of json-glib to work.  It might or might not also have the option to disable friends lists, depending on who you ask :)<br/><br/>


More information about the Commits mailing list