From 2f5d76f08d12f55ef28f7b56592b7e641d2cad26 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20P=C3=B6sel?= Date: Sun, 7 Sep 2014 15:01:49 +0000 Subject: Facebook: Fixed using hidden "Locale" option, now it is used in all requests git-svn-id: http://svn.miranda-ng.org/main/trunk@10394 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c --- protocols/FacebookRM/src/communication.cpp | 15 +++++++-------- protocols/FacebookRM/src/db.h | 4 ++-- protocols/FacebookRM/src/proto.cpp | 1 + protocols/FacebookRM/src/proto.h | 1 + 4 files changed, 11 insertions(+), 10 deletions(-) (limited to 'protocols/FacebookRM/src') diff --git a/protocols/FacebookRM/src/communication.cpp b/protocols/FacebookRM/src/communication.cpp index 70d0bd0c59..0d87cd2576 100644 --- a/protocols/FacebookRM/src/communication.cpp +++ b/protocols/FacebookRM/src/communication.cpp @@ -43,6 +43,9 @@ http::response facebook_client::flap(RequestType request_type, std::string* requ url.append(choose_server(request_type, request_data, request_get_data)); url.append(choose_action(request_type, request_data, request_get_data)); + if (!parent->m_locale.empty()) + url += "&locale=" + parent->m_locale; + nlhr.szUrl = (char*)url.c_str(); nlhr.flags = NLHRF_HTTP11 | choose_security_level(request_type); nlhr.headers = get_request_headers(nlhr.requestType, &nlhr.headersCount); @@ -363,7 +366,7 @@ std::string facebook_client::choose_action(RequestType request_type, std::string return "/checkpoint/?next"; case REQUEST_LOGOUT: - return "/logout.php"; + return "/logout.php?"; case REQUEST_HOME: return "/profile.php?v=info"; @@ -402,7 +405,7 @@ std::string facebook_client::choose_action(RequestType request_type, std::string case REQUEST_LOAD_FRIENDSHIPS: { - return "/friends/"; + return "/friends/?"; } case REQUEST_SEARCH: @@ -456,7 +459,7 @@ std::string facebook_client::choose_action(RequestType request_type, std::string case REQUEST_PAGES: { - return "/bookmarks/pages"; + return "/bookmarks/pages?"; } case REQUEST_NOTIFICATIONS: @@ -500,7 +503,7 @@ std::string facebook_client::choose_action(RequestType request_type, std::string return "/ajax/mercury/send_messages.php?__a=1"; case REQUEST_MESSAGE_SEND_INBOX: - return "/ajax/messaging/send.php"; + return "/ajax/messaging/send.php?"; case REQUEST_THREAD_INFO: return "/ajax/mercury/thread_info.php?__a=1"; @@ -783,10 +786,6 @@ bool facebook_client::login(const char *username, const char *password) data += "&email=" + utils::url::encode(username); data += "&pass=" + utils::url::encode(password); - ptrA locale(parent->getStringA(FACEBOOK_KEY_LOCALE)); - if (locale != NULL) - data += "&locale=" + std::string(locale); - // Send validation http::response resp = flap(REQUEST_LOGIN, &data); diff --git a/protocols/FacebookRM/src/db.h b/protocols/FacebookRM/src/db.h index 341cb06be2..1bc512c4ca 100644 --- a/protocols/FacebookRM/src/db.h +++ b/protocols/FacebookRM/src/db.h @@ -75,9 +75,9 @@ along with this program. If not, see . // Hidden account DB keys (can't be changed through GUI) #define FACEBOOK_KEY_POLL_RATE "PollRate" // [HIDDEN] - (byte) #define FACEBOOK_KEY_TIMEOUTS_LIMIT "TimeoutsLimit" // [HIDDEN] - (byte) -#define FACEBOOK_KEY_LOCALE "Locale" // [HIDDEN] - (string) en_US, cs_CZ, etc. +#define FACEBOOK_KEY_LOCALE "Locale" // [HIDDEN] - (string) en_US, cs_CZ, etc. (requires restart to apply) #define FACEBOOK_KEY_LOCAL_TIMESTAMP_UNREAD "UseLocalTimestampUnread" // [HIDDEN] - (byte) 1 = use local timestamp for offline messages #define FACEBOOK_KEY_NASEEMS_SPAM_MODE "NaseemsSpamMode" // [HIDDEN] - (byte) 1 = don't load messages sent from other instances (e.g., browser) - known as "Naseem's spam mode" #define FACEBOOK_KEY_NAME_AS_NICK "NameAsNick" // [HIDDEN] - (byte) 0 = don't use real name as nickname, use nickname if possible #define FACEBOOK_KEY_OPEN_URL_BROWSER "OpenUrlBrowser" // [HIDDEN] - (unicode) = absolute path to browser to open url links with -#define FACEBOOK_KEY_ENABLE_CHAT "EnableChat" // [HIDDEN] - (byte) 0 = don't use multi user chat at all (default is 1) +#define FACEBOOK_KEY_ENABLE_CHAT "EnableChat" // [HIDDEN] - (byte) 0 = don't use multi user chat at all (default is 1) (requires restart to apply) diff --git a/protocols/FacebookRM/src/proto.cpp b/protocols/FacebookRM/src/proto.cpp index 3b3f82f972..b76e389481 100644 --- a/protocols/FacebookRM/src/proto.cpp +++ b/protocols/FacebookRM/src/proto.cpp @@ -38,6 +38,7 @@ FacebookProto::FacebookProto(const char* proto_name,const TCHAR* username) : m_invisible = false; m_signingOut = false; m_enableChat = getBool(FACEBOOK_KEY_ENABLE_CHAT, true); + m_locale = ptrA( getStringA(FACEBOOK_KEY_LOCALE)); CreateProtoService(PS_CREATEACCMGRUI, &FacebookProto::SvcCreateAccMgrUI); CreateProtoService(PS_GETMYAWAYMSG, &FacebookProto::GetMyAwayMsg); diff --git a/protocols/FacebookRM/src/proto.h b/protocols/FacebookRM/src/proto.h index 4ad3a3642c..a18d8e4275 100644 --- a/protocols/FacebookRM/src/proto.h +++ b/protocols/FacebookRM/src/proto.h @@ -54,6 +54,7 @@ public: bool m_invisible; bool m_enableChat; bool m_signingOut; + std::string m_locale; // DB utils missing in proto_interface -- cgit v1.2.3