From ab7236480aa71a278e4882eabbfed20f386333d3 Mon Sep 17 00:00:00 2001 From: George Hazan Date: Mon, 13 Nov 2023 14:50:51 +0300 Subject: Telegram: added error processing in message sending --- protocols/Telegram/src/proto.cpp | 11 ++++++++++- protocols/Telegram/src/server.cpp | 27 +++++++++++++++++++++------ 2 files changed, 31 insertions(+), 7 deletions(-) diff --git a/protocols/Telegram/src/proto.cpp b/protocols/Telegram/src/proto.cpp index 9a79af6d94..fff388caa5 100644 --- a/protocols/Telegram/src/proto.cpp +++ b/protocols/Telegram/src/proto.cpp @@ -491,7 +491,16 @@ int CTelegramProto::SendMsg(MCONTACT hContact, const char *pszMessage) if (szId == nullptr) return 0; - return SendTextMessage(_atoi64(szId), pszMessage); + __int64 id = _atoi64(szId); + auto *pUser = FindUser(id); + if (pUser == nullptr) + return 0; + + int msgid = SendTextMessage(pUser->chatId, pszMessage); + if (msgid != -1) + m_arOwnMsg.insert(new TG_OWN_MESSAGE(hContact, (HANDLE)msgid, -1)); + + return msgid; } int CTelegramProto::SetStatus(int iNewStatus) diff --git a/protocols/Telegram/src/server.cpp b/protocols/Telegram/src/server.cpp index f9c2d17fc0..0bd26786be 100644 --- a/protocols/Telegram/src/server.cpp +++ b/protocols/Telegram/src/server.cpp @@ -253,15 +253,30 @@ void CTelegramProto::OnSendMessage(td::ClientManager::Response &response) if (!response.object) return; - if (response.object->get_id() != TD::message::ID) { + switch(response.object->get_id()) { + case TD::error::ID: + for (auto &it : m_arOwnMsg) + if (it->hAck == (HANDLE)response.request_id) { + auto *pError= ((TD::error *)response.object.get()); + CMStringW wszMsg(FORMAT, TranslateT("Error %d: %s"), pError->code_, TranslateW(Utf2T(pError->message_.c_str()))); + ProtoBroadcastAck(it->hContact, ACKTYPE_MESSAGE, ACKRESULT_FAILED, it->hAck, (LPARAM)wszMsg.c_str()); + break; + } + break; + + case TD::message::ID: + for (auto &it : m_arOwnMsg) + if (it->hAck == (HANDLE)response.request_id) { + auto *pMessage = ((TD::message *)response.object.get()); + it->tmpMsgId = pMessage->id_; + break; + } + break; + + default: debugLogA("Gotten class ID %d instead of %d, exiting", response.object->get_id(), TD::message::ID); return; } - - auto *pMessage = ((TD::message *)response.object.get()); - auto *pUser = FindChat(pMessage->chat_id_); - if (pUser) - m_arOwnMsg.insert(new TG_OWN_MESSAGE(pUser->hContact, (HANDLE)response.request_id, pMessage->id_)); } int CTelegramProto::SendTextMessage(int64_t chatId, const char *pszMessage) -- cgit v1.2.3