summaryrefslogtreecommitdiff
path: root/protocols/Telegram/src/server.cpp
diff options
context:
space:
mode:
authorGeorge Hazan <george.hazan@gmail.com>2023-11-13 14:50:51 +0300
committerGeorge Hazan <george.hazan@gmail.com>2023-11-13 14:50:51 +0300
commitab7236480aa71a278e4882eabbfed20f386333d3 (patch)
tree4b7e6a7ae4dcd69cc5c3269bd06ade216beaa959 /protocols/Telegram/src/server.cpp
parent4e2a7eebd5e4e1a40450bbe02c48809059248624 (diff)
Telegram: added error processing in message sending
Diffstat (limited to 'protocols/Telegram/src/server.cpp')
-rw-r--r--protocols/Telegram/src/server.cpp27
1 files changed, 21 insertions, 6 deletions
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)