summaryrefslogtreecommitdiff
path: root/protocols/FacebookRM/src/json.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/FacebookRM/src/json.cpp')
-rw-r--r--protocols/FacebookRM/src/json.cpp61
1 files changed, 31 insertions, 30 deletions
diff --git a/protocols/FacebookRM/src/json.cpp b/protocols/FacebookRM/src/json.cpp
index 24c7022abe..586189784f 100644
--- a/protocols/FacebookRM/src/json.cpp
+++ b/protocols/FacebookRM/src/json.cpp
@@ -221,7 +221,7 @@ int FacebookProto::ParseNotifications(std::string *data, std::map< std::string,
if (!text_ || !state_ || state_.as_string() == "SEEN_AND_READ" || !time_)
continue;
- facebook_notification* notification = new facebook_notification();
+ facebook_notification *notification = new facebook_notification();
notification->id = id_.as_string();
@@ -681,7 +681,7 @@ int FacebookProto::ParseMessages(std::string *pData, std::vector<facebook_messag
// Only new notifications
facy.last_notification_time_ = timestamp;
- facebook_notification* notification = new facebook_notification();
+ facebook_notification *notification = new facebook_notification();
notification->text = utils::text::slashu_to_utf8(text.as_string());
notification->link = url.as_string();
notification->id = alert_id.as_string();
@@ -709,46 +709,47 @@ int FacebookProto::ParseMessages(std::string *pData, std::vector<facebook_messag
if (!data)
continue;
- const JSONNode &appId_ = data["app_id"];
- const JSONNode &type_ = data["type"];
-
- if (appId_.as_string() == "2356318349" || type_.as_string() == "friend_confirmed") {
- // Friendship notifications
-
- const JSONNode &body_ = data["body"];
- const JSONNode &html_ = body_["__html"];
+ const JSONNode &html_ = data["body"]["__html"];
+ const JSONNode &href_ = data["href"];
+ const JSONNode &unread_ = data["unread"];
+ if (!html_ || !href_ || !unread_ || unread_.as_int() == 0)
+ continue;
- const JSONNode &href_ = data["href"];
- const JSONNode &unread_ = data["unread"];
- const JSONNode &alertId_ = data["alert_id"];
-
- if (!html_ || !href_ || !unread_ || unread_.as_int() == 0)
- continue;
+ std::string alert_id = data["alert_id"].as_string();
+ const JSONNode &type_ = data["type"];
+ if (type_.as_string() == "friend_confirmed") {
std::string text = utils::text::remove_html(utils::text::slashu_to_utf8(html_.as_string()));
std::string url = href_.as_string();
- std::string alert_id = alertId_.as_string();
// Notify it, if user wants to be notified
- if (getByte(FACEBOOK_KEY_EVENT_FRIENDSHIP_ENABLE, DEFAULT_EVENT_FRIENDSHIP_ENABLE)) {
- NotifyEvent(m_tszUserName, ptrW(mir_utf8decodeW(text.c_str())), NULL, EVENT_FRIENDSHIP, &url, alert_id.empty() ? nullptr : &alert_id);
- }
+ if (getByte(FACEBOOK_KEY_EVENT_FRIENDSHIP_ENABLE, DEFAULT_EVENT_FRIENDSHIP_ENABLE))
+ NotifyEvent(m_tszUserName, ptrW(mir_utf8decodeW(text.c_str())), 0, EVENT_FRIENDSHIP, &url, alert_id.empty() ? nullptr : &alert_id);
+ }
+ else { // new comment, like or reaction
+ PrepareNotificationsChatRoom();
+
+ // Fix notification ID
+ std::string::size_type pos = alert_id.find(":");
+ if (pos != std::string::npos)
+ alert_id = alert_id.substr(pos + 1);
+
+ facebook_notification *notification = new facebook_notification();
+ notification->text = utils::text::remove_html(utils::text::html_entities_decode(html_.as_string()));
+ notification->link = href_.as_string();
+ notification->id = alert_id;
+ notification->time = utils::time::from_string(data["time"].as_string());
+
+ // Write notification to chatroom
+ UpdateNotificationsChatRoom(notification);
+
+ notifications->insert(std::make_pair(notification->id, notification));
}
}
else if (t == "jewel_requests_add") {
// New friendship request, load them all with real names (because there is only user_id in "from" field)
ForkThread(&FacebookProto::ProcessFriendRequests, nullptr);
}
- /*else if (t == "jewel_requests_handled") { // revised 5.3.2017
- // When some request is approved (or perhaps even ignored/removed)
- const JSONNode &item_id_ = (*it)["item_id"]; // "<other_userid>_1_req"
- const JSONNode &realtime_viewer_fbid_ = (*it)["realtime_viewer_fbid"]; // our user fbid
- }
- else if (t == "type=jewel_requests_remove_old") { // revised 5.3.2017
- // Probably same as above? Happened in same situation. Could happen few times in a row.
- const JSONNode &from_ = (*it)["from"]; // other_userid
- const JSONNode &realtime_viewer_fbid_ = (*it)["realtime_viewer_fbid"]; // our user fbid
- }*/
else if (t == "typ") { // revised 5.3.2017
// chat typing notification
const JSONNode &from_ = (*it)["from"]; // user fbid