diff options
author | George Hazan <ghazan@miranda.im> | 2018-01-03 13:41:49 +0300 |
---|---|---|
committer | George Hazan <ghazan@miranda.im> | 2018-01-03 13:41:49 +0300 |
commit | f524101c14374c2efd1318f9d9085b1216b69620 (patch) | |
tree | 1a556fda936976e854ce14a42cb801e21829dd67 /protocols/FacebookRM/src/requests/channel.h | |
parent | d5d5b3f352e0cc2601013950cd48d5aad5c73baa (diff) |
Facebook:
- switch to the kernel parameter types;
- strong parameters typization (also produces more compact code)
- fixed timeline notifications
- version bump
Diffstat (limited to 'protocols/FacebookRM/src/requests/channel.h')
-rw-r--r-- | protocols/FacebookRM/src/requests/channel.h | 49 |
1 files changed, 16 insertions, 33 deletions
diff --git a/protocols/FacebookRM/src/requests/channel.h b/protocols/FacebookRM/src/requests/channel.h index e4d3ec84d5..a1c1b649de 100644 --- a/protocols/FacebookRM/src/requests/channel.h +++ b/protocols/FacebookRM/src/requests/channel.h @@ -42,59 +42,42 @@ public: bool isPing = (type == PING); - Url << CHAR_VALUE("channel", fc->chat_channel_.empty() ? ("p_" + fc->self_.user_id).c_str() : fc->chat_channel_.c_str()); + Url << CHAR_PARAM("channel", fc->chat_channel_.empty() ? ("p_" + fc->self_.user_id).c_str() : fc->chat_channel_.c_str()); if (!isPing) - Url << CHAR_VALUE("seq", fc->chat_sequence_num_.empty() ? "0" : fc->chat_sequence_num_.c_str()); + Url << CHAR_PARAM("seq", fc->chat_sequence_num_.empty() ? "0" : fc->chat_sequence_num_.c_str()); Url - << CHAR_VALUE("partition", fc->chat_channel_partition_.empty() ? "0" : fc->chat_channel_partition_.c_str()) - << CHAR_VALUE("clientid", fc->chat_clientid_.c_str()) - << CHAR_VALUE("cb", utils::text::rand_string(4, "0123456789abcdefghijklmnopqrstuvwxyz", &fc->random_).c_str()); - - /* - original cb = return (1048576 * Math.random() | 0).toString(36); - char buffer[10]; - itoa(((int)(1048576 * (((double)rand()) / (RAND_MAX + 1))) | 0), buffer, 36); - Url << CHAR_VALUE("cb", buffer); - */ + << CHAR_PARAM("partition", fc->chat_channel_partition_.empty() ? "0" : fc->chat_channel_partition_.c_str()) + << CHAR_PARAM("clientid", fc->chat_clientid_.c_str()) + << CHAR_PARAM("cb", utils::text::rand_string(4, "0123456789abcdefghijklmnopqrstuvwxyz", &fc->random_).c_str()); int idleSeconds = fc->parent->IdleSeconds(); - Url << INT_VALUE("idle", idleSeconds); // Browser is sending "idle" always, even if it's "0" + Url << INT_PARAM("idle", idleSeconds); // Browser is sending "idle" always, even if it's "0" if (!isPing) { - Url << "qp=y"; // TODO: what's this item? - Url << "pws=fresh"; // TODO: what's this item? - Url << "isq=487632"; // TODO: what's this item? - Url << INT_VALUE("msgs_recv", fc->chat_msgs_recv_); + Url << CHAR_PARAM("qp", "y") << CHAR_PARAM("pws", "fresh") << INT_PARAM("isq", 487632); + Url << INT_PARAM("msgs_recv", fc->chat_msgs_recv_); // TODO: sometimes there is &tur=1711 and &qpmade=<some actual timestamp> and &isq=487632 // Url << "request_batch=1"; // it somehow batches up more responses to one - then response has special "t=batched" type and "batches" array with the data // Url << "msgr_region=LLA"; // it was here only for first pull, same as request_batch } - Url << "cap=8" // TODO: what's this item? Sometimes it's 0, sometimes 8 - << CHAR_VALUE("uid", fc->self_.user_id.c_str()) - << CHAR_VALUE("viewer_uid", fc->self_.user_id.c_str()); + Url << INT_PARAM("cap", 8) // TODO: what's this item? Sometimes it's 0, sometimes 8 + << CHAR_PARAM("uid", fc->self_.user_id.c_str()) + << CHAR_PARAM("viewer_uid", fc->self_.user_id.c_str()); if (!fc->chat_sticky_num_.empty() && !fc->chat_sticky_pool_.empty()) { - Url << CHAR_VALUE("sticky_token", fc->chat_sticky_num_.c_str()); - Url << CHAR_VALUE("sticky_pool", fc->chat_sticky_pool_.c_str()); + Url << CHAR_PARAM("sticky_token", fc->chat_sticky_num_.c_str()); + Url << CHAR_PARAM("sticky_pool", fc->chat_sticky_pool_.c_str()); } if (!isPing && !fc->chat_traceid_.empty()) - Url << CHAR_VALUE("traceid", fc->chat_traceid_.c_str()); + Url << CHAR_PARAM("traceid", fc->chat_traceid_.c_str()); if (fc->parent->isInvisible()) - Url << "state=offline"; + Url << CHAR_PARAM("state", "offline"); else if (isPing || idleSeconds < 60) - Url << "state=active"; - - /* - Body - << "persistent=1" - << CHAR_VALUE("email", ptrA(mir_urlEncode(username))) - << CHAR_VALUE("pass", ptrA(mir_urlEncode(password))) - << CHAR_VALUE("lgndim", "eyJ3IjoxOTIwLCJoIjoxMDgwLCJhdyI6MTgzNCwiYWgiOjEwODAsImMiOjMyfQ==") // means base64 encoded: {"w":1920,"h":1080,"aw":1834,"ah":1080,"c":32} - << bodyData; // additional data parsed from form*/ + Url << CHAR_PARAM("state", "active"); } }; |