summaryrefslogtreecommitdiff
path: root/discord/discord.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'discord/discord.cpp')
-rw-r--r--discord/discord.cpp14
1 files changed, 14 insertions, 0 deletions
diff --git a/discord/discord.cpp b/discord/discord.cpp
index 0ef1202..c4276dc 100644
--- a/discord/discord.cpp
+++ b/discord/discord.cpp
@@ -1220,6 +1220,9 @@ void DiscordClient::HandleGatewayMessage(std::string str) {
case GatewayEvent::THREAD_MEMBER_UPDATE: {
HandleGatewayThreadMemberUpdate(m);
} break;
+ case GatewayEvent::THREAD_UPDATE: {
+ HandleGatewayThreadUpdate(m);
+ } break;
}
} break;
default:
@@ -1749,6 +1752,12 @@ void DiscordClient::HandleGatewayThreadMemberUpdate(const GatewayMessage &msg) {
m_signal_added_to_thread.emit(*data.Member.ThreadID);
}
+void DiscordClient::HandleGatewayThreadUpdate(const GatewayMessage &msg) {
+ ThreadUpdateData data = msg.Data;
+ m_store.SetChannel(data.Thread.ID, data.Thread);
+ m_signal_thread_update.emit(data);
+}
+
void DiscordClient::HandleGatewayReadySupplemental(const GatewayMessage &msg) {
ReadySupplementalData data = msg.Data;
for (const auto &p : data.MergedPresences.Friends) {
@@ -2116,6 +2125,7 @@ void DiscordClient::LoadEventMap() {
m_event_map["THREAD_LIST_SYNC"] = GatewayEvent::THREAD_LIST_SYNC;
m_event_map["THREAD_MEMBERS_UPDATE"] = GatewayEvent::THREAD_MEMBERS_UPDATE;
m_event_map["THREAD_MEMBER_UPDATE"] = GatewayEvent::THREAD_MEMBER_UPDATE;
+ m_event_map["THREAD_UPDATE"] = GatewayEvent::THREAD_UPDATE;
}
DiscordClient::type_signal_gateway_ready DiscordClient::signal_gateway_ready() {
@@ -2270,6 +2280,10 @@ DiscordClient::type_signal_thread_members_update DiscordClient::signal_thread_me
return m_signal_thread_members_update;
}
+DiscordClient::type_signal_thread_update DiscordClient::signal_thread_update() {
+ return m_signal_thread_update;
+}
+
DiscordClient::type_signal_added_to_thread DiscordClient::signal_added_to_thread() {
return m_signal_added_to_thread;
}