From 86e49c1f6a1f4b978fd700590747c1a03ff7d156 Mon Sep 17 00:00:00 2001 From: George Hazan Date: Mon, 9 Jan 2017 17:53:21 +0300 Subject: fix for duplicated messages when reading history --- protocols/Discord/src/dispatch.cpp | 33 ++++++++++++++++++++------------- 1 file changed, 20 insertions(+), 13 deletions(-) (limited to 'protocols') diff --git a/protocols/Discord/src/dispatch.cpp b/protocols/Discord/src/dispatch.cpp index 307394c8ca..0cb74c06a3 100644 --- a/protocols/Discord/src/dispatch.cpp +++ b/protocols/Discord/src/dispatch.cpp @@ -82,6 +82,10 @@ void CDiscordProto::OnCommandMessage(const JSONNode &pRoot) recv.szMessage = buf; recv.lParam = (LPARAM)msgId.c_str(); ProtoChainRecvMsg(pUser->hContact, &recv); + + SnowFlake lastId = getId(pUser->hContact, DB_KEY_LASTMSGID); // as stored in a database + if (lastId < _wtoi64(msgId)) + setId(pUser->hContact, DB_KEY_LASTMSGID, _wtoi64(msgId)); } ////////////////////////////////////////////////////////////////////////////////////// @@ -148,20 +152,23 @@ void CDiscordProto::OnCommandReady(const JSONNode &pRoot) for (auto it = channels.begin(); it != channels.end(); ++it) { const JSONNode &p = *it; + CDiscordUser *pUser = NULL; const JSONNode &recipients = p["recipients"]; - for (auto it2 = recipients.begin(); it2 != recipients.end(); ++it2) { - const JSONNode &r = *it2; - CDiscordUser *pUser = PrepareUser(r); - pUser->lastMessageId = _wtoi64(r["last_message_id"].as_mstring()); - pUser->channelId = _wtoi64(p["id"].as_mstring()); - pUser->bIsPrivate = true; - - setId(pUser->hContact, DB_KEY_CHANNELID, pUser->channelId); - - SnowFlake oldMsgId = getId(pUser->hContact, DB_KEY_LASTMSGID); - if (pUser->lastMessageId > oldMsgId) - RetrieveHistory(pUser->hContact, MSG_AFTER, oldMsgId); - } + for (auto it2 = recipients.begin(); it2 != recipients.end(); ++it2) + pUser = PrepareUser(*it2); + + if (pUser == NULL) + continue; + + pUser->channelId = _wtoi64(p["id"].as_mstring()); + pUser->lastMessageId = _wtoi64(p["last_message_id"].as_mstring()); + pUser->bIsPrivate = true; + + setId(pUser->hContact, DB_KEY_CHANNELID, pUser->channelId); + + SnowFlake oldMsgId = getId(pUser->hContact, DB_KEY_LASTMSGID); + if (pUser->lastMessageId > oldMsgId) + RetrieveHistory(pUser->hContact, MSG_AFTER, oldMsgId); } } -- cgit v1.2.3