From bc2b9ef55b0449b2e97e7fb0eeecc686732ca9a2 Mon Sep 17 00:00:00 2001 From: George Hazan Date: Wed, 1 Mar 2017 22:07:32 +0300 Subject: fix #726 (Logging out and in duplicates last sent message if it was the last message of the conversation) --- protocols/Discord/src/dispatch.cpp | 80 +++++++++++++++++++------------------- 1 file changed, 40 insertions(+), 40 deletions(-) (limited to 'protocols/Discord/src') diff --git a/protocols/Discord/src/dispatch.cpp b/protocols/Discord/src/dispatch.cpp index aad6c1f478..3f04af06a3 100644 --- a/protocols/Discord/src/dispatch.cpp +++ b/protocols/Discord/src/dispatch.cpp @@ -373,13 +373,6 @@ void CDiscordProto::OnCommandMessage(const JSONNode &pRoot) CMStringW wszUserId = pRoot["author"]["id"].as_mstring(); CDiscordMessage msg(_wtoi64(wszMessageId), _wtoi64(wszUserId)); - SnowFlake nonce = ::getId(pRoot["nonce"]); - SnowFlake *p = arOwnMessages.find(&nonce); - if (p != nullptr) { // own message? skip it - debugLogA("skipping own message with nonce=%lld, id=%lld", nonce, msg.id); - return; - } - // try to find a sender by his channel SnowFlake channelId = ::getId(pRoot["channel_id"]); CDiscordUser *pUser = FindUserByChannel(channelId); @@ -392,44 +385,51 @@ void CDiscordProto::OnCommandMessage(const JSONNode &pRoot) if (pUser->lastMsg.id == msg.id) msg = pUser->lastMsg; - // if a message has myself as an author, add some flags - PROTORECVEVENT recv = {}; - if (msg.authorId == m_ownId) - recv.flags = PREF_CREATEREAD | PREF_SENT; - - CMStringW wszText = PrepareMessageText(pRoot); - - const JSONNode &edited = pRoot["edited_timestamp"]; - if (!edited.isnull()) - wszText.AppendFormat(L" (%s %s)", TranslateT("edited at"), edited.as_mstring().c_str()); - - if (pUser->bIsPrivate) { - debugLogA("store a message from private user %lld, channel id %lld", pUser->id, pUser->channelId); - ptrA buf(mir_utf8encodeW(wszText)); - recv.timestamp = (DWORD)StringToDate(pRoot["timestamp"].as_mstring()); - recv.szMessage = buf; - recv.lParam = (LPARAM)wszMessageId.c_str(); - ProtoChainRecvMsg(pUser->hContact, &recv); + SnowFlake nonce = ::getId(pRoot["nonce"]); + SnowFlake *p = arOwnMessages.find(&nonce); + if (p != nullptr) { // own message? skip it + debugLogA("skipping own message with nonce=%lld, id=%lld", nonce, msg.id); } else { - debugLogA("store a message into the group channel id %lld", channelId); - - SESSION_INFO *si = pci->SM_FindSession(pUser->wszUsername, m_szModuleName); - if (si == nullptr) { - debugLogA("nessage to unknown channal %lld ignored", channelId); - return; + CMStringW wszText = PrepareMessageText(pRoot); + + const JSONNode &edited = pRoot["edited_timestamp"]; + if (!edited.isnull()) + wszText.AppendFormat(L" (%s %s)", TranslateT("edited at"), edited.as_mstring().c_str()); + + if (pUser->bIsPrivate) { + // if a message has myself as an author, add some flags + PROTORECVEVENT recv = {}; + if (msg.authorId == m_ownId) + recv.flags = PREF_CREATEREAD | PREF_SENT; + + debugLogA("store a message from private user %lld, channel id %lld", pUser->id, pUser->channelId); + ptrA buf(mir_utf8encodeW(wszText)); + recv.timestamp = (DWORD)StringToDate(pRoot["timestamp"].as_mstring()); + recv.szMessage = buf; + recv.lParam = (LPARAM)wszMessageId.c_str(); + ProtoChainRecvMsg(pUser->hContact, &recv); } + else { + debugLogA("store a message into the group channel id %lld", channelId); - ParseSpecialChars(si, wszText); + SESSION_INFO *si = pci->SM_FindSession(pUser->wszUsername, m_szModuleName); + if (si == nullptr) { + debugLogA("nessage to unknown channal %lld ignored", channelId); + return; + } - GCDEST gcd = { m_szModuleName, pUser->wszUsername, GC_EVENT_MESSAGE }; - GCEVENT gce = { &gcd }; - gce.dwFlags = GCEF_ADDTOLOG; - gce.ptszUID = wszUserId; - gce.ptszText = wszText; - gce.time = (DWORD)StringToDate(pRoot["timestamp"].as_mstring()); - gce.bIsMe = msg.authorId == m_ownId; - Chat_Event(&gce); + ParseSpecialChars(si, wszText); + + GCDEST gcd = { m_szModuleName, pUser->wszUsername, GC_EVENT_MESSAGE }; + GCEVENT gce = { &gcd }; + gce.dwFlags = GCEF_ADDTOLOG; + gce.ptszUID = wszUserId; + gce.ptszText = wszText; + gce.time = (DWORD)StringToDate(pRoot["timestamp"].as_mstring()); + gce.bIsMe = msg.authorId == m_ownId; + Chat_Event(&gce); + } } pUser->lastMsg = msg; -- cgit v1.2.3