summaryrefslogtreecommitdiff
path: root/protocols
diff options
context:
space:
mode:
authorRobert Pösel <robyer@seznam.cz>2015-04-18 21:39:44 +0000
committerRobert Pösel <robyer@seznam.cz>2015-04-18 21:39:44 +0000
commitb6c4bc14c137ecf8f4bea73f01ebde7786bf8a0f (patch)
treecd0eaef3e9b91221d313c8dd1a63bed3ff93c2ae /protocols
parent45678ffaea325ab8c6c85bde1d5fa2b72db7e350 (diff)
Facebook: Attempt to handle the "computer is infected" login problem; version bump
git-svn-id: http://svn.miranda-ng.org/main/trunk@12925 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols')
-rw-r--r--protocols/FacebookRM/src/communication.cpp41
-rw-r--r--protocols/FacebookRM/src/version.h2
2 files changed, 32 insertions, 11 deletions
diff --git a/protocols/FacebookRM/src/communication.cpp b/protocols/FacebookRM/src/communication.cpp
index ad9928c9e4..66e931bf14 100644
--- a/protocols/FacebookRM/src/communication.cpp
+++ b/protocols/FacebookRM/src/communication.cpp
@@ -744,6 +744,8 @@ bool facebook_client::login(const char *username, const char *password)
if (!cookies["datr"].empty())
parent->setString(FACEBOOK_KEY_DEVICE_ID, cookies["datr"].c_str());
+ bool scanComputerRequest = false;
+
if (resp.code == HTTP_CODE_FOUND && resp.headers.find("Location") != resp.headers.end())
{
std::string location = resp.headers["Location"];
@@ -817,23 +819,37 @@ bool facebook_client::login(const char *username, const char *password)
}
else if (resp.data.find("name=\"submit[OK]\"") != std::string::npos) {
-
+ // TODO: not sure this branch could happen anymore
inner_data = "submit[OK]=OK";
inner_data += "&nh=" + utils::text::source_get_value(&resp.data, 3, "name=\"nh\"", "value=\"", "\"");
inner_data += "&fb_dtsg=" + utils::url::encode(utils::text::source_get_value(&resp.data, 3, "name=\"fb_dtsg\"", "value=\"", "\""));
resp = flap(REQUEST_SETUP_MACHINE, &inner_data);
+ }
+ else if (resp.data.find("name=\"submit[Get%20Started]\"") != std::string::npos) {
+ // Facebook things that computer was infected by malware and needs cleaning
+ parent->debugLogA("!!! Facebook requires computer scan.");
+ scanComputerRequest = true;
- if (resp.data.find("security-essentials") != std::string::npos) {
- // Computer was probably infected by malware and needs cleaning (actually this may happen because Miranda doesn't support FB's captcha)
- inner_data = "submit[Continue]=Continue";
- inner_data += "&nh=" + utils::text::source_get_value(&resp.data, 3, "name=\"nh\"", "value=\"", "\"");
- inner_data += "&fb_dtsg=" + utils::url::encode(utils::text::source_get_value(&resp.data, 3, "name=\"fb_dtsg\"", "value=\"", "\""));
+ // Step 1: Get started
+ inner_data = "submit[Get%20Started]=Get%20Started";
+ inner_data += "&nh=" + utils::text::source_get_value(&resp.data, 3, "name=\"nh\"", "value=\"", "\"");
+ inner_data += "&fb_dtsg=" + utils::url::encode(utils::text::source_get_value(&resp.data, 3, "name=\"fb_dtsg\"", "value=\"", "\""));
- // Mark that used cleaned his computer already, because he must confirm it anyway to be able to continue
- inner_data += "&confirm=1";
+ resp = flap(REQUEST_SETUP_MACHINE, &inner_data);
- resp = flap(REQUEST_SETUP_MACHINE, &inner_data);
- }
+ // Step 2: Download F-Secure Online Scanner (we're not really downloading anything)
+ inner_data = "submit[Download]=Download";
+ inner_data += "&nh=" + utils::text::source_get_value(&resp.data, 3, "name=\"nh\"", "value=\"", "\"");
+ inner_data += "&fb_dtsg=" + utils::url::encode(utils::text::source_get_value(&resp.data, 3, "name=\"fb_dtsg\"", "value=\"", "\""));
+
+ resp = flap(REQUEST_SETUP_MACHINE, &inner_data);
+
+ // Step 3: Skip scanning and try to do Complete login
+ inner_data = "submit[Complete%20Login]=Complete%20Login";
+ inner_data += "&nh=" + utils::text::source_get_value(&resp.data, 3, "name=\"nh\"", "value=\"", "\"");
+ inner_data += "&fb_dtsg=" + utils::url::encode(utils::text::source_get_value(&resp.data, 3, "name=\"fb_dtsg\"", "value=\"", "\""));
+
+ resp = flap(REQUEST_SETUP_MACHINE, &inner_data);
}
}
}
@@ -858,6 +874,11 @@ bool facebook_client::login(const char *username, const char *password)
return handle_error("login", FORCE_QUIT);
}
+ if (scanComputerRequest) {
+ // FIXME: remove this message when someone confirm that it works...
+ client_notify(TranslateT("Facebook required computer cleaning and plugin correctly skipped it. Please report this to the plugin developer!"));
+ }
+
// Get and notify error message
std::string error = utils::text::source_get_value(&resp.data, 4, "login_error_box", "<div", ">", "</div>");
if (error.empty())
diff --git a/protocols/FacebookRM/src/version.h b/protocols/FacebookRM/src/version.h
index 103b6a9a5b..bcf56532d2 100644
--- a/protocols/FacebookRM/src/version.h
+++ b/protocols/FacebookRM/src/version.h
@@ -1,7 +1,7 @@
#define __MAJOR_VERSION 0
#define __MINOR_VERSION 2
#define __RELEASE_NUM 10
-#define __BUILD_NUM 5
+#define __BUILD_NUM 6
#include <stdver.h>