summaryrefslogtreecommitdiff
path: root/protocols/FacebookRM/src/communication.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/FacebookRM/src/communication.cpp')
-rw-r--r--protocols/FacebookRM/src/communication.cpp57
1 files changed, 42 insertions, 15 deletions
diff --git a/protocols/FacebookRM/src/communication.cpp b/protocols/FacebookRM/src/communication.cpp
index 0efc1657e8..0996625777 100644
--- a/protocols/FacebookRM/src/communication.cpp
+++ b/protocols/FacebookRM/src/communication.cpp
@@ -392,6 +392,11 @@ std::string facebook_client::choose_action(RequestType request_type, std::string
utils::text::replace_first(&action, "%s", this->chat_reconnect_reason_);
utils::text::replace_first(&action, "%s", this->dtsg_);
utils::text::replace_first(&action, "%s", this->self_.user_id);
+
+ action += "&__dyn=" + __dyn();
+ action += "&__req=" + __req();
+ action += "&__rev=" + __rev();
+
return action;
}
@@ -454,11 +459,16 @@ std::string facebook_client::choose_action(RequestType request_type, std::string
int idleSeconds = parent->IdleSeconds();
if (idleSeconds > 0 && !parent->isInvisible())
action += "&idle=" + utils::conversion::to_string(&idleSeconds, UTILS_CONV_UNSIGNED_NUMBER);
- action += "&cap=0"; // TODO: what's this item? Sometimes it's 0, sometimes 8
- // action += "&wtc=0,0,0.000,0,0"; // TODO: what's this item? It's numbers grows with every new request...
- action += "&msgs_recv=" + utils::conversion::to_string(&this->chat_msgs_recv_, UTILS_CONV_UNSIGNED_NUMBER);
+ if (!isPing) {
+ action += "&qp=y"; // TODO: what's this item?
+ action += "&pws=fresh"; // TODO: what's this item?
+ action += "&isq=449655"; // TODO: what's this item?
+ action += "&msgs_recv=" + utils::conversion::to_string(&this->chat_msgs_recv_, UTILS_CONV_UNSIGNED_NUMBER);
+ // TODO: sometimes there is &tur=1697 and &qpmade=<some actual timestamp>
+ }
+ action += "&cap=8"; // TODO: what's this item? Sometimes it's 0, sometimes 8
action += "&uid=" + self_.user_id;
action += "&viewer_uid=" + self_.user_id;
@@ -488,13 +498,7 @@ std::string facebook_client::choose_action(RequestType request_type, std::string
return "/ajax/mercury/change_read_status.php?__a=1";
case REQUEST_NOTIFICATIONS_READ:
- {
- std::string action = "/ajax/notifications/mark_read.php?__a=1";
- if (get_data != NULL) {
- action += "&" + (*get_data);
- }
- return action;
- }
+ return "/ajax/notifications/mark_read.php?__a=1";
case REQUEST_TYPING_SEND:
return "/ajax/messaging/typ.php?__a=1";
@@ -1075,7 +1079,11 @@ bool facebook_client::chat_state(bool online)
data += "&window_id=0";
data += "&fb_dtsg=" + dtsg_;
data += "&__user=" + self_.user_id;
- http::response resp = flap(REQUEST_VISIBILITY, &data);
+ data += "&__dyn=" + __dyn();
+ data += "&__req=" + __req();
+ data += "&ttstamp=" + ttstamp_;
+ data += "&__rev=" + __rev();
+ http::response resp = flap(REQUEST_VISIBILITY, &data); // NOTE: Request revised 11.2.2016
if (!resp.error_title.empty())
return handle_error("chat_state");
@@ -1287,6 +1295,7 @@ int facebook_client::send_message(int seqid, MCONTACT hContact, const std::strin
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][client_thread_id]=user:" + std::string(userId);
+ data += "&message_batch[0][other_user_fbid]=" + std::string(userId);
}
data += "&message_batch[0][thread_fbid]";
@@ -1303,22 +1312,37 @@ int facebook_client::send_message(int seqid, MCONTACT hContact, const std::strin
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";
- data += "&message_batch[0][body]=" + utils::url::encode(message_text);
+
+ // 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));
+ }
+ 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][manual_retry_cnt]";
- data += "&client=mercury&__a=1&__dyn&__req&__rev";
+ data += "&message_batch[0][ephemeral_ttl_mode]=0";
+ data += "&message_batch[0][manual_retry_cnt]=0";
+ data += "&client=mercury&__a=1";
data += "&fb_dtsg=" + this->dtsg_;
data += "&__user=" + this->self_.user_id;
data += "&ttstamp=" + ttstamp_;
+ data += "&__dyn=" + __dyn();
+ data += "&__req=" + __req();
+ data += "&__rev=" + __rev();
{
ScopedLock s(send_message_lock_);
- resp = flap(REQUEST_MESSAGE_SEND_CHAT, &data);
+ resp = flap(REQUEST_MESSAGE_SEND_CHAT, &data); // NOTE: Request revised 11.2.2016
*error_text = resp.error_text;
@@ -1373,7 +1397,10 @@ int facebook_client::send_message(int seqid, MCONTACT hContact, const std::strin
parent->debugLogA(" Got captchaPersistData (first): %s", captchaPersistData.c_str());
std::string capStr = "new_captcha_type=TFBCaptcha&skipped_captcha_data=" + captchaPersistData;
- capStr += "&__dyn=&__req=&__rev=&__user=" + this->self_.user_id;
+ capStr += "&__dyn=" + __dyn();
+ capStr += "&__req=" + __req();
+ capStr += "&__rev=" + __rev();
+ capStr += "&__user=" + this->self_.user_id;
http::response capResp = flap(REQUEST_CAPTCHA_REFRESH, NULL, &capStr);
if (capResp.code == HTTP_CODE_OK) {