summaryrefslogtreecommitdiff
path: root/protocols/Discord/src/dispatch.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/Discord/src/dispatch.cpp')
-rw-r--r--protocols/Discord/src/dispatch.cpp26
1 files changed, 24 insertions, 2 deletions
diff --git a/protocols/Discord/src/dispatch.cpp b/protocols/Discord/src/dispatch.cpp
index 6a9776c304..5e615367b3 100644
--- a/protocols/Discord/src/dispatch.cpp
+++ b/protocols/Discord/src/dispatch.cpp
@@ -321,7 +321,8 @@ void CDiscordProto::OnCommandMessage(const JSONNode &pRoot)
{
CMStringW wszMessageId = pRoot["id"].as_mstring();
CMStringW wszUserId = pRoot["author"]["id"].as_mstring();
- CDiscordMessage msg(_wtoi64(wszMessageId), _wtoi64(wszUserId));
+ SnowFlake userId = _wtoi64(wszUserId);
+ CDiscordMessage msg(_wtoi64(wszMessageId), userId);
// try to find a sender by his channel
SnowFlake channelId = ::getId(pRoot["channel_id"]);
@@ -365,10 +366,31 @@ void CDiscordProto::OnCommandMessage(const JSONNode &pRoot)
SESSION_INFO *si = pci->SM_FindSession(pUser->wszUsername, m_szModuleName);
if (si == nullptr) {
- debugLogA("nessage to unknown channal %lld ignored", channelId);
+ debugLogA("message to unknown channel %lld ignored", channelId);
return;
}
+ CDiscordGuild *pGuild = FindGuild(pUser->guildId);
+ if (pGuild == nullptr) {
+ debugLogA("message to unknown guild %lld ignored", pUser->guildId);
+ return;
+ }
+
+ CDiscordGuildMember *pm = pGuild->FindUser(userId);
+ if (pm == nullptr) {
+ pm = new CDiscordGuildMember(userId);
+ pm->wszNick = pRoot["nick"].as_mstring();
+ if (pm->wszNick.IsEmpty())
+ pm->wszNick = pRoot["user"]["username"].as_mstring() + L"#" + pRoot["user"]["discriminator"].as_mstring();
+ pGuild->arChatUsers.insert(pm);
+
+ for (int i = 0; i < arUsers.getCount(); i++) {
+ CDiscordUser &pChannel = arUsers[i];
+ if (pChannel.guildId == pGuild->id)
+ AddUserToChannel(pChannel, *pm);
+ }
+ }
+
ParseSpecialChars(si, wszText);
GCEVENT gce = { m_szModuleName, pUser->wszUsername, GC_EVENT_MESSAGE };