summaryrefslogtreecommitdiff
path: root/protocols/FacebookRM/src
diff options
context:
space:
mode:
authorGeorge Hazan <ghazan@miranda.im>2018-08-13 20:27:28 +0300
committerGeorge Hazan <ghazan@miranda.im>2018-08-13 20:27:28 +0300
commita3f483f04556eed243bd03138e5ae336a04cb6c8 (patch)
treeeeb7bb6e0fdb89858606e667620ef298221db63e /protocols/FacebookRM/src
parent7572c2f49fc29f3f5b20128cdb96e6087f89ab9a (diff)
fix for FB suddenly going mad
Diffstat (limited to 'protocols/FacebookRM/src')
-rw-r--r--protocols/FacebookRM/src/communication.cpp25
1 files changed, 2 insertions, 23 deletions
diff --git a/protocols/FacebookRM/src/communication.cpp b/protocols/FacebookRM/src/communication.cpp
index 2dd2c7aac7..e7ca35788c 100644
--- a/protocols/FacebookRM/src/communication.cpp
+++ b/protocols/FacebookRM/src/communication.cpp
@@ -905,30 +905,9 @@ bool facebook_client::channel()
// Update msgs_recv number for every "msg" type we receive (during fullRefresh/reload responses it stays the same)
this->chat_msgs_recv_++;
}
- else if (type == "fullReload") {
- // At fullReload we force our seq number to received value (there may have been some error or something)
- this->chat_sequence_num_ = seq;
- }
- // Check if it's different from our old one (which means we should increment our old one)
- if (seq != this->chat_sequence_num_) {
- // Facebook now often return much bigger number which results in skipping few data requests, so we increment it manually
- // Bigger skips (when there is some problem or something) are handled when fullreload/refresh response type
- int iseq = 0;
- if (utils::conversion::from_string<int>(iseq, this->chat_sequence_num_, std::dec)) {
- // Increment and convert it back to string
- iseq++;
- std::string newSeq = utils::conversion::to_string(&iseq, UTILS_CONV_SIGNED_NUMBER);
-
- // Check if we have different seq than the one from Facebook
- if (newSeq != seq) {
- parent->debugLogA("!!! Use self incremented sequence number: %s (instead of: %s)", newSeq.c_str(), seq.c_str());
- seq = newSeq;
- }
- }
- }
-
- this->chat_sequence_num_ = seq;
+ if (!seq.empty())
+ this->chat_sequence_num_ = seq;
}
else // No type? This shouldn't happen unless there is a big API change.
return handle_error("channel");