diff options
author | Robert Pösel <robyer@seznam.cz> | 2014-09-19 17:19:57 +0000 |
---|---|---|
committer | Robert Pösel <robyer@seznam.cz> | 2014-09-19 17:19:57 +0000 |
commit | b59603c66c0982effbe8faccd62f5088d0078c23 (patch) | |
tree | bdaf771ce5015086a2026f993ffe6278dd4ece28 | |
parent | e546ee6ef368b6b7d1f21ccc30b0496b42e4f10c (diff) |
Facebook: Fix for Facebook's image captcha; version bump
git-svn-id: http://svn.miranda-ng.org/main/trunk@10524 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
-rw-r--r-- | protocols/FacebookRM/src/communication.cpp | 40 | ||||
-rw-r--r-- | protocols/FacebookRM/src/constants.h | 1 | ||||
-rw-r--r-- | protocols/FacebookRM/src/version.h | 2 |
3 files changed, 35 insertions, 8 deletions
diff --git a/protocols/FacebookRM/src/communication.cpp b/protocols/FacebookRM/src/communication.cpp index 2ad9e3cd96..fe8fdc3cfb 100644 --- a/protocols/FacebookRM/src/communication.cpp +++ b/protocols/FacebookRM/src/communication.cpp @@ -233,6 +233,7 @@ DWORD facebook_client::choose_security_level(RequestType request_type) // case REQUEST_RECONNECT: // case REQUEST_POST_STATUS: // case REQUEST_IDENTITY_SWITCH: +// case REQUEST_CAPTCHA_REFRESH: // case REQUEST_LINK_SCRAPER: // case REQUEST_MESSAGE_SEND_CHAT: // case REQUEST_MESSAGE_SEND_INBOX: @@ -289,6 +290,7 @@ int facebook_client::choose_method(RequestType request_type) // case REQUEST_USER_INFO_MOBILE: // case REQUEST_LOAD_FRIENDSHIPS: // case REQUEST_SEARCH: +// case REQUEST_CAPTCHA_REFRESH: default: return REQUEST_GET; } @@ -334,6 +336,7 @@ std::string facebook_client::choose_server(RequestType request_type, std::string // case REQUEST_RECONNECT: // case REQUEST_POST_STATUS: // case REQUEST_IDENTITY_SWITCH: +// case REQUEST_CAPTCHA_REFRESH: // case REQUEST_LINK_SCRAPER: // case REQUEST_MESSAGE_SEND_CHAT: // case REQUEST_MESSAGE_SEND_INBOX: @@ -490,6 +493,15 @@ std::string facebook_client::choose_action(RequestType request_type, std::string case REQUEST_IDENTITY_SWITCH: return "/identity_switch.php?__a=1"; + case REQUEST_CAPTCHA_REFRESH: + { + std::string action = "/captcha/refresh_ajax.php?__a=1"; + if (get_data != NULL) { + action += "&" + (*get_data); + } + return action; + } + case REQUEST_LINK_SCRAPER: { std::string action = "/ajax/composerx/attachment/link/scraper/?__a=1&composerurihash=2&scrape_url="; @@ -1315,17 +1327,31 @@ int facebook_client::send_message(MCONTACT hContact, std::string message_recipie { std::string imageUrl = utils::text::html_entities_decode(utils::text::slashu_to_utf8(utils::text::source_get_value(&resp.data, 3, "img class=\\\"img\\\"", "src=\\\"", "\\\""))); std::string captchaPersistData = utils::text::source_get_value(&resp.data, 3, "\\\"captcha_persist_data\\\"", "value=\\\"", "\\\""); + + parent->debugLogA("Got imageUrl (first): %s", imageUrl.c_str()); + parent->debugLogA("Got captchaPersistData (first): %s", captchaPersistData.c_str()); + + std::string data = "new_captcha_type=TFBCaptcha&skipped_captcha_data=" + captchaPersistData; + data += "&__dyn=&__req=&__rev=&__user=" + this->self_.user_id; + http::response resp = flap(REQUEST_CAPTCHA_REFRESH, NULL, &data); - parent->debugLogA("Got imageUrl: %s", imageUrl.c_str()); - parent->debugLogA("Got captchaPersistData: %s", captchaPersistData.c_str()); + if (resp.code == HTTP_CODE_OK) { + imageUrl = utils::text::html_entities_decode(utils::text::slashu_to_utf8(utils::text::source_get_value(&resp.data, 3, "img class=\\\"img\\\"", "src=\\\"", "\\\""))); + captchaPersistData = utils::text::source_get_value(&resp.data, 3, "\\\"captcha_persist_data\\\"", "value=\\\"", "\\\""); + + parent->debugLogA("Got imageUrl (second): %s", imageUrl.c_str()); + parent->debugLogA("Got captchaPersistData (second): %s", captchaPersistData.c_str()); + + std::string result; + if (!parent->RunCaptchaForm(imageUrl, result)) { + *error_text = Translate("User cancel captcha challenge."); + return SEND_MESSAGE_CANCEL; + } - std::string result; - if (!parent->RunCaptchaForm(imageUrl, result)) { - *error_text = Translate("User cancel captcha challenge."); - return SEND_MESSAGE_CANCEL; + return send_message(hContact, message_recipient, message_text, error_text, method, captchaPersistData, result); } - return send_message(hContact, message_recipient, message_text, error_text, method, captchaPersistData, result); + return SEND_MESSAGE_CANCEL; // Cancel because we failed to load captcha image so we can't continue only with error } default: // Other error diff --git a/protocols/FacebookRM/src/constants.h b/protocols/FacebookRM/src/constants.h index d2fd847e69..d7211b2f1b 100644 --- a/protocols/FacebookRM/src/constants.h +++ b/protocols/FacebookRM/src/constants.h @@ -113,6 +113,7 @@ enum RequestType { REQUEST_RECONNECT, // getting __sequence_num__ and __channel_id__
REQUEST_VISIBILITY, // setting chat visibility
REQUEST_IDENTITY_SWITCH, // changing identity to post status for pages
+ REQUEST_CAPTCHA_REFRESH, // refreshing captcha dialog (changing captcha type)
REQUEST_FEEDS, // getting feeds
REQUEST_NOTIFICATIONS, // getting notifications
diff --git a/protocols/FacebookRM/src/version.h b/protocols/FacebookRM/src/version.h index 1efaf598d8..234a5218ab 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 9
-#define __BUILD_NUM 2
+#define __BUILD_NUM 3
#include <stdver.h>
|