summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobert Pösel <robyer@seznam.cz>2016-03-25 00:38:54 +0000
committerRobert Pösel <robyer@seznam.cz>2016-03-25 00:38:54 +0000
commit68e1a7d81c92574eaf7b95f37879507c2a8b6532 (patch)
tree18b37bb40a3ee8fab170f6fe5a8b3867486c03d1
parent79412831126e49d990a44506af1ae69f78797d6c (diff)
Facebook: Fix receiving messages (part I, chats and attachments doesn't work yet)
git-svn-id: http://svn.miranda-ng.org/main/trunk@16540 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
-rw-r--r--protocols/FacebookRM/src/json.cpp68
-rw-r--r--protocols/FacebookRM/src/process.cpp2
2 files changed, 68 insertions, 2 deletions
diff --git a/protocols/FacebookRM/src/json.cpp b/protocols/FacebookRM/src/json.cpp
index 51acc6a6c9..1235b081ac 100644
--- a/protocols/FacebookRM/src/json.cpp
+++ b/protocols/FacebookRM/src/json.cpp
@@ -411,7 +411,73 @@ int facebook_json_parser::parse_messages(std::string *pData, std::vector< facebo
continue;
std::string t = type.as_string();
- if (t == "messaging") {
+ if (t == "delta") {
+ // new messaging stuff
+
+ const JSONNode &delta_ = (*it)["delta"];
+ if (!delta_)
+ continue;
+
+ const JSONNode &cls_ = delta_["class"];
+ std::string cls = cls_.as_string();
+ if (cls == "NewMessage") {
+ // TODO: Support for "folders" was probably removed, we should remove the "inboxOnly" option too - but first check how does that "allow messages request" works
+
+ const JSONNode &meta_ = delta_["messageMetadata"];
+ if (!meta_) {
+ proto->debugLogA("json::parse_messages - No messageMetadata element");
+ continue;
+ }
+
+ const JSONNode &sender_fbid = meta_["actorFbId"];
+ const JSONNode &body = delta_["body"];
+
+ const JSONNode &mid = meta_["messageId"];
+ const JSONNode &timestamp = meta_["timestamp"];
+ if (!sender_fbid || !body || !mid || !timestamp)
+ continue;
+
+ std::string id = sender_fbid.as_string();
+ std::string message_id = mid.as_string();
+ std::string message_text = body.as_string();
+
+ std::string other_user_id = meta_["threadKey"]["otherUserFbId"].as_string();
+
+ // Process attachements and stickers
+ parseAttachments(proto, &message_text, delta_, "", other_user_id); // FIXME: Rework and fix parsing attachments
+
+ // Ignore duplicits or messages sent from miranda
+ if (!body || ignore_duplicits(proto, message_id, message_text))
+ continue;
+
+ message_text = utils::text::trim(utils::text::slashu_to_utf8(message_text), true);
+ if (message_text.empty()) {
+ proto->debugLogA("json::parse_messages - Received empty message. Received only some attachment?");
+ // continue;
+ }
+
+ facebook_message* message = new facebook_message();
+ message->isUnread = true;
+ message->isIncoming = (id != proto->facy.self_.user_id);
+ message->message_text = message_text;
+ message->time = utils::time::from_string(timestamp.as_string());
+ message->user_id = id;
+ message->message_id = message_id;
+ // message->thread_id = tid.as_string(); // TODO: or if not incomming use my own id from facy.self_ ?
+ message->isChat = false; // FIXME: Determine whether this is chat or not
+
+ /* if (!message->isChat && !message->isIncoming) {
+ message->sender_name.clear();
+ message->user_id = !other_user_id.empty() ? other_user_id : proto->ThreadIDToContactID(message->thread_id); // TODO: Check if we have contact with this user_id in friendlist and otherwise do something different?
+ } */
+
+ messages->push_back(message);
+ }
+ else {
+ proto->debugLogA("json::parse_messages - Unknown class '%s'", cls.c_str());
+ }
+ }
+ else if (t == "messaging") {
// various messaging stuff (received and sent messages, getting seen info)
const JSONNode &ev_ = (*it)["event"];
diff --git a/protocols/FacebookRM/src/process.cpp b/protocols/FacebookRM/src/process.cpp
index eb64a99f8f..a1f5938fee 100644
--- a/protocols/FacebookRM/src/process.cpp
+++ b/protocols/FacebookRM/src/process.cpp
@@ -979,7 +979,7 @@ void FacebookProto::ReceiveMessages(std::vector<facebook_message*> messages, boo
// Save TID if not exists already
ptrA tid(getStringA(hContact, FACEBOOK_KEY_TID));
- if (!tid || mir_strcmp(tid, messages[i]->thread_id.c_str()))
+ if ((!tid || mir_strcmp(tid, messages[i]->thread_id.c_str())) && !messages[i]->thread_id.empty())
setString(hContact, FACEBOOK_KEY_TID, messages[i]->thread_id.c_str());
if (messages[i]->isIncoming && messages[i]->isUnread && messages[i]->type == MESSAGE) {