diff options
-rw-r--r-- | protocols/FacebookRM/src/communication.cpp | 57 | ||||
-rw-r--r-- | protocols/FacebookRM/src/version.h | 2 |
2 files changed, 41 insertions, 18 deletions
diff --git a/protocols/FacebookRM/src/communication.cpp b/protocols/FacebookRM/src/communication.cpp index c847279530..0196d58c57 100644 --- a/protocols/FacebookRM/src/communication.cpp +++ b/protocols/FacebookRM/src/communication.cpp @@ -910,25 +910,46 @@ bool facebook_client::login(const char *username, const char *password) } // Check if we need to approve also last unapproved device - if (resp.data.find("name=\"name_action_selected\"") == std::string::npos) { - // 1) Continue + + // 1) Continue (it might have been sent with approval code above already) + if (resp.data.find("name=\"submit[Continue]\"") != std::string::npos) { 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=\"", "\"")); resp = flap(REQUEST_SETUP_MACHINE, &inner_data); + } + + // In this step might be needed identity confirmation + if (resp.data.find("name=\"birthday_captcha_") != std::string::npos) { + // Account is locked and needs identity confirmation + client_notify(TranslateT("Login error: Your account is temporarily locked. You need to confirm this device from web browser.")); + parent->debugLogA("!!! Login error: Birthday confirmation."); + return handle_error("login", FORCE_QUIT); + } - // In this step might be needed identity confirmation - if (resp.data.find("name=\"birthday_captcha_") != std::string::npos) { - // Account is locked and needs identity confirmation - client_notify(TranslateT("Login error: Your account is temporarily locked. You need to confirm this device from web browser.")); - parent->debugLogA("!!! Login error: Birthday confirmation."); - return handle_error("login", FORCE_QUIT); + // 2) Approve last unknown login + if (resp.data.find("name=\"submit[This was me]\"") != std::string::npos) { + CMString tszTitle; + tszTitle.AppendFormat(_T("%s - %s"), parent->m_tszUserName, TranslateT("Check last login")); + CMString tszMessage(TranslateT("Do you recognize this activity?")); + + std::string activity = utils::text::slashu_to_utf8(utils::text::source_get_value(&resp.data, 3, "<body", "</strong></div>", "</div>")); + activity = utils::text::trim(utils::text::html_entities_decode(utils::text::remove_html(activity))); + if (!activity.empty()) { + tszMessage.AppendFormat(_T("\n\n%s"), ptrT(mir_utf8decodeT(activity.c_str()))); } - // 2) Approve last unknown login - // inner_data = "submit[I%20don't%20recognize]=I%20don't%20recognize"; // Don't recognize - this will force to change account password - inner_data = "submit[This%20is%20Okay]=This%20is%20Okay"; // Recognize - inner_data += "&submit[This is Okay]=This is Okay"; // I don't know whether it's with classic spaces now or not + if (MessageBox(0, tszMessage, tszTitle, MB_ICONWARNING | MB_YESNO | MB_DEFBUTTON1) == IDYES) { + // Recognized activity, will continue with login + inner_data = "submit[This was me]=This was me"; + } else { + // Don't recognize - this will force to change account password + inner_data = "submit[This wasn't me]=This wasn't me"; + + // We won't continue with this and rather cancel connecting right away, because we don't want to handle password changing via Miranda + client_notify(TranslateT("Login error: You need to confirm last unknown login or revoke it from web browser.")); + return handle_error("login", FORCE_QUIT); + } 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); @@ -942,11 +963,13 @@ bool facebook_client::login(const char *username, const char *password) } // Save this actual device - 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=\"", "\"")); - inner_data += "&name_action_selected=save_device"; // Save device - or "dont_save" - resp = flap(REQUEST_SETUP_MACHINE, &inner_data); + if (resp.data.find("name=\"submit[Continue]\"") != std::string::npos) { + 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=\"", "\"")); + inner_data += "&name_action_selected=save_device"; // Save device - or "dont_save" + resp = flap(REQUEST_SETUP_MACHINE, &inner_data); + } } else if (resp.data.find("name=\"submit[Get Started]\"") != std::string::npos) { if (!parent->getBool(FACEBOOK_KEY_TRIED_DELETING_DEVICE_ID)) { diff --git a/protocols/FacebookRM/src/version.h b/protocols/FacebookRM/src/version.h index 71ef6c5de1..f39c060b13 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 14 -#define __BUILD_NUM 0 +#define __BUILD_NUM 1 #include <stdver.h> |