diff options
author | George Hazan <george.hazan@gmail.com> | 2025-04-12 18:57:33 +0300 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2025-04-12 18:57:33 +0300 |
commit | 431ef15f6d8e223a8a0abe720194b71cf3bd3a20 (patch) | |
tree | d8d3edf424c254ee5d92ef9eb27615d9ca81ae8b /protocols/Telegram/src/server.cpp | |
parent | f984c62b96484001afd82540df82357f69eeb526 (diff) |
Telegram: fix for marking incoming messages as read
Diffstat (limited to 'protocols/Telegram/src/server.cpp')
-rw-r--r-- | protocols/Telegram/src/server.cpp | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/protocols/Telegram/src/server.cpp b/protocols/Telegram/src/server.cpp index 714347b229..9ecd5ff29a 100644 --- a/protocols/Telegram/src/server.cpp +++ b/protocols/Telegram/src/server.cpp @@ -922,8 +922,10 @@ void CTelegramProto::ProcessMarkRead(TD::updateChatReadInbox *pObj) return;
}
- if (pObj->last_read_inbox_message_id_)
+ if (pObj->last_read_inbox_message_id_) {
pUser->bInited = true;
+ pUser->lastReadId = pObj->last_read_inbox_message_id_;
+ }
CMStringA szMaxId(msg2id(pObj->chat_id_, pObj->last_read_inbox_message_id_));
if (db_event_getById(m_szModuleName, szMaxId) == 0) {
@@ -992,9 +994,11 @@ void CTelegramProto::ProcessMessage(const TD::message *pMessage) dbei.cbBlob = szText.GetLength();
dbei.iTimestamp = pMessage->date_;
if (pMessage->is_outgoing_)
- dbei.flags |= DBEF_SENT | DBEF_READ;
+ dbei.bSent = dbei.bRead = true;
+ else if (pMessage->id_ <= pUser->lastReadId)
+ dbei.bRead = true;
if (!pUser->bInited)
- dbei.flags |= DBEF_READ;
+ dbei.bRead = true;
if (GetGcUserId(pUser, pMessage, szUserId))
dbei.szUserId = szUserId;
if (auto iReplyId = getReplyId(pMessage->reply_to_.get())) {
|