diff options
Diffstat (limited to 'protocols/FacebookRM/src/communication.cpp')
-rw-r--r-- | protocols/FacebookRM/src/communication.cpp | 119 |
1 files changed, 57 insertions, 62 deletions
diff --git a/protocols/FacebookRM/src/communication.cpp b/protocols/FacebookRM/src/communication.cpp index 6662735d26..f4fd7cf13d 100644 --- a/protocols/FacebookRM/src/communication.cpp +++ b/protocols/FacebookRM/src/communication.cpp @@ -283,6 +283,8 @@ std::string facebook_client::choose_server(RequestType request_type) std::string facebook_client::choose_action(RequestType request_type, std::string *get_data) { + // NOTE: Parameter "client" used in some requests's POST data could be "jewel" (top bar?), "mercury" (chat window, source=source:chat:web) or "web_messenger" (whole chat messages page, source=source:titan:web) + switch (request_type) { case REQUEST_LOGIN: @@ -306,11 +308,11 @@ std::string facebook_client::choose_action(RequestType request_type, std::string case REQUEST_DTSG: return "/editprofile.php?edit=current_city&type=basic"; - case REQUEST_USER_INFO: - return "/ajax/chat/user_info.php?__a=1"; + case REQUEST_USER_INFO: // ok, 17.8.2016 + return "/chat/user_info/?dpr=1"; - case REQUEST_USER_INFO_ALL: - return "/ajax/chat/user_info_all.php?__a=1&viewer=" + self_.user_id; + case REQUEST_USER_INFO_ALL: // ok, 17.8.2016 + return "/chat/user_info_all/?dpr=1&viewer=" + self_.user_id; case REQUEST_USER_INFO_MOBILE: { @@ -335,9 +337,9 @@ std::string facebook_client::choose_action(RequestType request_type, std::string return action; } - case REQUEST_UNREAD_THREADS: + case REQUEST_UNREAD_THREADS: // ok, 17.8.2016 { - return "/ajax/mercury/unread_threads.php?__a=1"; + return "/ajax/mercury/unread_threads.php?dpr=1"; } case REQUEST_DELETE_FRIEND: @@ -380,12 +382,12 @@ std::string facebook_client::choose_action(RequestType request_type, std::string return "/bookmarks/pages?"; } - case REQUEST_NOTIFICATIONS: + case REQUEST_NOTIFICATIONS: // ok, 17.8.2016 { - return "/ajax/notifications/client/get.php?__a=1"; + return "/ajax/notifications/client/get.php?dpr=1"; } - case REQUEST_RECONNECT: + case REQUEST_RECONNECT: // ok, 17.8.2016 { std::string action = "/ajax/presence/reconnect.php?__a=1&reason=%s&fb_dtsg=%s&__user=%s"; @@ -399,6 +401,7 @@ std::string facebook_client::choose_action(RequestType request_type, std::string action += "&__dyn=" + __dyn(); action += "&__req=" + __req(); action += "&__rev=" + __rev(); + action += "&__pc=PHASED:DEFAULT&__be=-1&__a=1"; return action; } @@ -428,12 +431,12 @@ std::string facebook_client::choose_action(RequestType request_type, std::string } case REQUEST_MESSAGES_SEND: - return "/ajax/mercury/send_messages.php?__a=1"; + return "/messaging/send/?dpr=1"; - case REQUEST_THREAD_INFO: - return "/ajax/mercury/thread_info.php?__a=1"; + case REQUEST_THREAD_INFO: // ok, 17.8.2016 + return "/ajax/mercury/thread_info.php?dpr=1"; - case REQUEST_THREAD_SYNC: + case REQUEST_THREAD_SYNC: // TODO: This doesn't work anymore return "/ajax/mercury/thread_sync.php?__a=1"; case REQUEST_MESSAGES_RECEIVE: @@ -491,7 +494,7 @@ std::string facebook_client::choose_action(RequestType request_type, std::string } case REQUEST_VISIBILITY: - return "/ajax/chat/privacy/visibility.php?__a=1"; + return "/ajax/chat/privacy/visibility.php?dpr=1"; // ok, 17.8.2016 case REQUEST_POKE: return "/pokes/dialog/?__a=1"; @@ -509,7 +512,7 @@ std::string facebook_client::choose_action(RequestType request_type, std::string } case REQUEST_TYPING_SEND: - return "/ajax/messaging/typ.php?__a=1"; + return "/ajax/messaging/typ.php?dpr=1"; // ok, 17.8.2016 case REQUEST_ON_THIS_DAY: { @@ -1214,7 +1217,8 @@ bool facebook_client::chat_state(bool online) data += "&__req=" + __req(); data += "&ttstamp=" + ttstamp_; data += "&__rev=" + __rev(); - http::response resp = flap(REQUEST_VISIBILITY, &data); // NOTE: Request revised 11.2.2016 + data += "&__a=1&__pc=PHASED:DEFAULT&__be=-1"; + http::response resp = flap(REQUEST_VISIBILITY, &data); // NOTE: Request revised 17.8.2016 if (!resp.error_title.empty()) return handle_error("chat_state"); @@ -1422,7 +1426,28 @@ int facebook_client::send_message(int seqid, MCONTACT hContact, const std::strin return SEND_MESSAGE_ERROR; } - data += "&message_batch[0][action_type]=ma-type:user-generated-message"; + data += "&client=mercury"; // or "web_messenger" (whole messages page) + data += "&action_type=ma-type:user-generated-message"; + + // Experimental sticker sending support + if (message_text.substr(0, 10) == "[[sticker:" && message_text.substr(message_text.length() - 2) == "]]") { + data += "&body="; + data += "&sticker_id=" + utils::url::encode(message_text.substr(10, message_text.length() - 10 - 2)); + data += "&has_attachment=true"; + // TODO: For sending GIF images instead of "sticker_id=" there is "image_ids[0]=", otherwise it's same + } + else { + data += "&body=" + utils::url::encode(message_text); + data += "&has_attachment=false"; + } + + data += "&ephemeral_ttl_mode=0"; + // data += "&force_sms=true" // TODO: This is present always when sending via "web_messenger" + + // Probably we can generate any random messageID, it just have to be numeric and don't start with "0". We will receive it in response as "client_message_id". + std::string messageId = utils::text::rand_string(10, "123456789", &this->random_); + data += "&message_id=" + messageId; + data += "&offline_threading_id=" + messageId; // Same as message ID if (isChatRoom) { // NOTE: Remove "id." prefix as here we need to give threadFbId and not threadId @@ -1430,60 +1455,30 @@ int facebook_client::send_message(int seqid, MCONTACT hContact, const std::strin if (thread_fbid.substr(0, 3) == "id.") thread_fbid = thread_fbid.substr(3); - data += "&message_batch[0][thread_fbid]=" + thread_fbid; + data += "&thread_fbid=" + thread_fbid; } else { - data += "&message_batch[0][specific_to_list][0]=fbid:" + std::string(userId); - data += "&message_batch[0][specific_to_list][1]=fbid:" + this->self_.user_id; - data += "&message_batch[0][other_user_fbid]=" + std::string(userId); - } - - data += "&message_batch[0][thread_id]="; - data += "&message_batch[0][author]=fbid:" + this->self_.user_id; - data += "&message_batch[0][author_email]"; - data += "&message_batch[0][timestamp]=" + utils::time::mili_timestamp(); - data += "&message_batch[0][timestamp_absolute]"; - data += "&message_batch[0][timestamp_relative]"; - data += "&message_batch[0][timestamp_time_passed]"; - data += "&message_batch[0][is_unread]=false"; - data += "&message_batch[0][is_forward]=false"; - data += "&message_batch[0][is_filtered_content]=false"; - data += "&message_batch[0][is_filtered_content_bh]=false"; - data += "&message_batch[0][is_filtered_content_account]=false"; - data += "&message_batch[0][is_filtered_content_quasar]=false"; - data += "&message_batch[0][is_filtered_content_invalid_app]=false"; - data += "&message_batch[0][is_spoof_warning]=false"; - data += "&message_batch[0][source]=source:chat:web"; - data += "&message_batch[0][source_tags][0]=source:chat"; - - // Experimental sticker sending support - if (message_text.substr(0, 10) == "[[sticker:" && message_text.substr(message_text.length() - 2) == "]]") { - data += "&message_batch[0][body]="; - data += "&message_batch[0][sticker_id]=" + utils::url::encode(message_text.substr(10, message_text.length()-10-2)); + data += "&other_user_fbid=" + std::string(userId); + data += "&specific_to_list[0]=fbid:" + std::string(userId); + data += "&specific_to_list[1]=fbid:" + this->self_.user_id; } - else { - data += "&message_batch[0][body]=" + utils::url::encode(message_text); - } - - data += "&message_batch[0][has_attachment]=false"; - data += "&message_batch[0][html_body]=false"; - data += "&message_batch[0][signatureID]"; - data += "&message_batch[0][ui_push_phase]"; - data += "&message_batch[0][status]=0"; - data += "&message_batch[0][offline_threading_id]"; - data += "&message_batch[0][message_id]"; - data += "&message_batch[0][ephemeral_ttl_mode]=0"; - data += "&message_batch[0][manual_retry_cnt]=0"; - data += "&client=mercury&__a=1&__be=0&__pc=EXP1:DEFAULT"; - data += "&fb_dtsg=" + this->dtsg_; + + data += "&signature_id="; // TODO: How to generate signature ID? It is present only when sending via "mercury" + data += "&source=source:chat:web"; // or "source:titan:web" for web_messenger + data += "×tamp=" + utils::time::mili_timestamp(); + data += "&ui_push_phase=V3"; data += "&__user=" + this->self_.user_id; - data += "&ttstamp=" + ttstamp_; + data += "&__a=1"; data += "&__dyn=" + __dyn(); data += "&__req=" + __req(); + data += "&__be=-1"; + data += "&__pc=PHASED:DEFAULT"; + data += "&fb_dtsg=" + this->dtsg_; + data += "&ttstamp=" + ttstamp_; data += "&__rev=" + __rev(); { ScopedLock s(send_message_lock_); - resp = flap(REQUEST_MESSAGES_SEND, &data); // NOTE: Request revised 11.2.2016 + resp = flap(REQUEST_MESSAGES_SEND, &data); // NOTE: Request revised 17.8.2016 *error_text = resp.error_text; |