5
0
mirror of https://github.com/cwinfo/matterbridge.git synced 2024-11-26 12:21:35 +00:00

Fix Discord mentions by populating the nickMemberMap at connect (#498)

This commit is contained in:
NikkyAI 2018-09-17 21:25:06 +02:00 committed by Wim
parent e0ca876de2
commit 296428d53e

View File

@ -89,6 +89,21 @@ func (b *Bdiscord) Connect() error {
for _, channel := range b.Channels { for _, channel := range b.Channels {
b.Log.Debugf("found channel %#v", channel) b.Log.Debugf("found channel %#v", channel)
} }
// obtaining guild members and initializing nickname mapping
b.Lock()
members, err := b.c.GuildMembers(b.guildID, "", 1000)
if err != nil {
b.Log.Error("Error obtaining guild members", err)
return err
}
for _, member := range members {
b.userMemberMap[member.User.ID] = member
b.nickMemberMap[member.User.Username] = member
if member.Nick != "" {
b.nickMemberMap[member.Nick] = member
}
}
b.Unlock()
return nil return nil
} }
@ -298,7 +313,10 @@ func (b *Bdiscord) memberUpdate(s *discordgo.Session, m *discordgo.GuildMemberUp
b.Log.Debugf("%s: memberupdate: user %s (nick %s) changes nick to %s", b.Account, m.Member.User.Username, b.userMemberMap[m.Member.User.ID].Nick, m.Member.Nick) b.Log.Debugf("%s: memberupdate: user %s (nick %s) changes nick to %s", b.Account, m.Member.User.Username, b.userMemberMap[m.Member.User.ID].Nick, m.Member.Nick)
} }
b.userMemberMap[m.Member.User.ID] = m.Member b.userMemberMap[m.Member.User.ID] = m.Member
b.nickMemberMap[m.Member.User.Username] = m.Member
if m.Member.Nick != "" {
b.nickMemberMap[m.Member.Nick] = m.Member b.nickMemberMap[m.Member.Nick] = m.Member
}
b.Unlock() b.Unlock()
} }