From 690e3433c5bcfea991a8efce03e0ae2ef389df44 Mon Sep 17 00:00:00 2001 From: George Hazan Date: Sun, 22 Jun 2025 17:42:11 +0300 Subject: =?UTF-8?q?fixes=20#5049=20(Telegram:=20=D0=B4=D0=BE=D0=B1=D0=B0?= =?UTF-8?q?=D0=B2=D0=B8=D1=82=D1=8C=20=D0=B2=20=D1=8E=D0=B7=D0=B5=D1=80?= =?UTF-8?q?=D0=B8=D0=BD=D1=84=D0=BE=20=D0=BA=D0=B0=D0=BD=D0=B0=D0=BB=D0=B0?= =?UTF-8?q?=20=D0=BE=D0=BF=D0=B8=D1=81=D0=B0=D0=BD=D0=B8=D0=B5=20=D0=BA?= =?UTF-8?q?=D0=B0=D0=BD=D0=B0=D0=BB=D0=B0)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- protocols/Telegram/src/server.cpp | 27 ++++++++++++++++++--------- 1 file changed, 18 insertions(+), 9 deletions(-) (limited to 'protocols/Telegram/src/server.cpp') diff --git a/protocols/Telegram/src/server.cpp b/protocols/Telegram/src/server.cpp index 148a68928c..8333e032a0 100644 --- a/protocols/Telegram/src/server.cpp +++ b/protocols/Telegram/src/server.cpp @@ -216,11 +216,15 @@ void CTelegramProto::ProcessResponse(td::ClientManager::Response response) break; case TD::updateBasicGroup::ID: - ProcessBasicGroup((TD::updateBasicGroup*)response.object.get()); + ProcessBasicGroup((TD::updateBasicGroup *)response.object.get()); break; case TD::updateBasicGroupFullInfo::ID: - ProcessBasicGroupInfo((TD::updateBasicGroupFullInfo *)response.object.get()); + { + auto *pObj = (TD::updateBasicGroupFullInfo *)response.object.get(); + if (auto *pChat = FindUser(pObj->basic_group_id_)) + ProcessBasicGroupInfo(pChat, pObj->basic_group_full_info_.get()); + } break; case TD::updateChatAction::ID: @@ -244,7 +248,7 @@ void CTelegramProto::ProcessResponse(td::ClientManager::Response response) break; case TD::updateChatNotificationSettings::ID: - ProcessChatNotification((TD::updateChatNotificationSettings*)response.object.get()); + ProcessChatNotification((TD::updateChatNotificationSettings *)response.object.get()); break; case TD::updateChatPosition::ID: @@ -260,9 +264,9 @@ void CTelegramProto::ProcessResponse(td::ClientManager::Response response) break; case TD::updateDeleteMessages::ID: - ProcessDeleteMessage((TD::updateDeleteMessages*)response.object.get()); + ProcessDeleteMessage((TD::updateDeleteMessages *)response.object.get()); break; - + case TD::updateConnectionState::ID: ProcessConnectionState((TD::updateConnectionState *)response.object.get()); break; @@ -272,7 +276,7 @@ void CTelegramProto::ProcessResponse(td::ClientManager::Response response) break; case TD::updateForumTopicInfo::ID: - ProcessForum((TD::updateForumTopicInfo*)response.object.get()); + ProcessForum((TD::updateForumTopicInfo *)response.object.get()); break; case TD::updateMessageContent::ID: @@ -312,8 +316,7 @@ void CTelegramProto::ProcessResponse(td::ClientManager::Response response) ProcessChat((TD::updateNewChat *)response.object.get()); break; - case TD::updateNewMessage::ID: - { + case TD::updateNewMessage::ID: { auto *pMessage = ((TD::updateNewMessage *)response.object.get())->message_.get(); TG_OWN_MESSAGE tmp(0, 0, msg2id(pMessage)); if (!m_arOwnMsg.find(&tmp)) @@ -338,7 +341,13 @@ void CTelegramProto::ProcessResponse(td::ClientManager::Response response) break; case TD::updateSupergroupFullInfo::ID: - ProcessSuperGroupInfo((TD::updateSupergroupFullInfo *)response.object.get()); + { + auto *pObj = (TD::updateSupergroupFullInfo *)response.object.get(); + if (auto *pUser = FindUser(pObj->supergroup_id_)) + ProcessSuperGroupInfo(pUser, pObj->supergroup_full_info_.get()); + else + debugLogA("Uknown super group id %lld, skipping", pObj->supergroup_id_); + } break; case TD::updateUserStatus::ID: -- cgit v1.2.3