diff options
author | ouwou <26526779+ouwou@users.noreply.github.com> | 2022-10-10 00:27:47 -0400 |
---|---|---|
committer | ouwou <26526779+ouwou@users.noreply.github.com> | 2022-10-10 00:27:47 -0400 |
commit | 78a5b9599c900c5da56da0a15835f425e455b510 (patch) | |
tree | 304c37e30b885c5d00eba73a109f417253eb2001 /src/discord/discord.cpp | |
parent | 5588c46d14cab51596921bc456aadc315dab012f (diff) | |
download | abaddon-portaudio-78a5b9599c900c5da56da0a15835f425e455b510.tar.gz abaddon-portaudio-78a5b9599c900c5da56da0a15835f425e455b510.zip |
remove user from list on disconnect
Diffstat (limited to 'src/discord/discord.cpp')
-rw-r--r-- | src/discord/discord.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/src/discord/discord.cpp b/src/discord/discord.cpp index c62cd2a..91ba1e3 100644 --- a/src/discord/discord.cpp +++ b/src/discord/discord.cpp @@ -1208,6 +1208,13 @@ std::optional<uint32_t> DiscordClient::GetSSRCOfUser(Snowflake id) const { return m_voice.GetSSRCOfUser(id); } +std::optional<Snowflake> DiscordClient::GetVoiceState(Snowflake user_id) const { + if (const auto it = m_voice_state_user_channel.find(user_id); it != m_voice_state_user_channel.end()) { + return it->second; + } + return std::nullopt; +} + void DiscordClient::SetVoiceMuted(bool is_mute) { m_mute_requested = is_mute; SendVoiceStateUpdate(); @@ -2164,9 +2171,17 @@ void DiscordClient::HandleGatewayVoiceStateUpdate(const GatewayMessage &msg) { m_voice.SetSessionID(data.SessionID); } if (data.ChannelID.has_value()) { + const auto old_state = GetVoiceState(data.UserID); SetVoiceState(data.UserID, *data.ChannelID); + if (old_state.has_value() && *old_state != *data.ChannelID) { + m_signal_voice_user_disconnect.emit(data.UserID, *old_state); + } } else { + const auto old_state = GetVoiceState(data.UserID); ClearVoiceState(data.UserID); + if (old_state.has_value()) { + m_signal_voice_user_disconnect.emit(data.UserID, *old_state); + } } } @@ -2952,4 +2967,8 @@ DiscordClient::type_signal_voice_disconnected DiscordClient::signal_voice_discon DiscordClient::type_signal_voice_speaking DiscordClient::signal_voice_speaking() { return m_signal_voice_speaking; } + +DiscordClient::type_signal_voice_user_disconnect DiscordClient::signal_voice_user_disconnect() { + return m_signal_voice_user_disconnect; +} #endif |