summaryrefslogtreecommitdiff
path: root/protocols/Telegram/src
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/Telegram/src')
-rw-r--r--protocols/Telegram/src/groupchat.cpp26
-rw-r--r--protocols/Telegram/src/proto.cpp3
-rw-r--r--protocols/Telegram/src/proto.h2
-rw-r--r--protocols/Telegram/src/server.cpp2
4 files changed, 32 insertions, 1 deletions
diff --git a/protocols/Telegram/src/groupchat.cpp b/protocols/Telegram/src/groupchat.cpp
index b32db4c13f..c0ea6165e8 100644
--- a/protocols/Telegram/src/groupchat.cpp
+++ b/protocols/Telegram/src/groupchat.cpp
@@ -130,6 +130,32 @@ void CTelegramProto::StartGroupChat(td::ClientManager::Response &response, void
/////////////////////////////////////////////////////////////////////////////////////////
+int CTelegramProto::GcMuteHook(WPARAM hContact, LPARAM mode)
+{
+ if (Proto_IsProtoOnContact(hContact, m_szModuleName)) {
+ if (auto *pUser = FindUser(_atoi64(getMStringA(hContact, DBKEY_ID)))) {
+ auto settings = TD::make_object<TD::chatNotificationSettings>();
+ memcpy(settings.get(), &pUser->notificationSettings, sizeof(pUser->notificationSettings));
+
+ switch (mode) {
+ case CHATMODE_MUTE:
+ settings->use_default_mute_for_ = false;
+ settings->mute_for_ = 45000000;
+ break;
+
+ default:
+ settings->use_default_mute_for_ = true;
+ settings->mute_for_ = 0;
+ break;
+ }
+ SendQuery(new TD::setChatNotificationSettings(pUser->chatId, std::move(settings)));
+ }
+ }
+ return 0;
+}
+
+/////////////////////////////////////////////////////////////////////////////////////////
+
enum
{
IDM_LEAVE = 1,
diff --git a/protocols/Telegram/src/proto.cpp b/protocols/Telegram/src/proto.cpp
index d7cac65780..090619cc5d 100644
--- a/protocols/Telegram/src/proto.cpp
+++ b/protocols/Telegram/src/proto.cpp
@@ -61,7 +61,7 @@ CTelegramProto::CTelegramProto(const char* protoName, const wchar_t* userName) :
HookProtoEvent(ME_HISTORY_EMPTY, &CTelegramProto::OnEmptyHistory);
HookProtoEvent(ME_OPT_INITIALISE, &CTelegramProto::OnOptionsInit);
-
+
// avatar
CreateDirectoryTreeW(GetAvatarPath());
@@ -82,6 +82,7 @@ CTelegramProto::CTelegramProto(const char* protoName, const wchar_t* userName) :
gcr.pszModule = m_szModuleName;
Chat_Register(&gcr);
+ HookProtoEvent(ME_GC_MUTE, &CTelegramProto::GcMuteHook);
HookProtoEvent(ME_GC_EVENT, &CTelegramProto::GcEventHook);
HookProtoEvent(ME_GC_BUILDMENU, &CTelegramProto::GcMenuHook);
}
diff --git a/protocols/Telegram/src/proto.h b/protocols/Telegram/src/proto.h
index 657dce496a..af6c3d9851 100644
--- a/protocols/Telegram/src/proto.h
+++ b/protocols/Telegram/src/proto.h
@@ -93,6 +93,7 @@ struct TG_USER
CMStringW wszNick, wszFirstName, wszLastName;
time_t m_timer1 = 0, m_timer2 = 0;
SESSION_INFO *m_si = nullptr;
+ TD::chatNotificationSettings notificationSettings;
CMStringW getDisplayName() const;
};
@@ -300,6 +301,7 @@ public:
int __cdecl OnOptionsInit(WPARAM, LPARAM);
int __cdecl GcMenuHook(WPARAM, LPARAM);
+ int __cdecl GcMuteHook(WPARAM, LPARAM);
int __cdecl GcEventHook(WPARAM, LPARAM);
// Services //////////////////////////////////////////////////////////////////////////
diff --git a/protocols/Telegram/src/server.cpp b/protocols/Telegram/src/server.cpp
index 8641e202e9..2204be7de6 100644
--- a/protocols/Telegram/src/server.cpp
+++ b/protocols/Telegram/src/server.cpp
@@ -374,6 +374,8 @@ void CTelegramProto::ProcessChatNotification(TD::updateChatNotificationSettings
Chat_Mute(pUser->hContact, CHATMODE_MUTE);
else
Chat_Mute(pUser->hContact, CHATMODE_NORMAL);
+
+ memcpy(&pUser->notificationSettings, pSettings.get(), sizeof(pUser->notificationSettings));
}
void CTelegramProto::ProcessChatPosition(TD::updateChatPosition *pObj)