2018-12-07 22:36:01 +00:00
|
|
|
package bdiscord
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/42wim/matterbridge/bridge/config"
|
2022-03-12 17:06:39 +01:00
|
|
|
"github.com/bwmarrin/discordgo"
|
2022-02-06 16:58:35 +01:00
|
|
|
"github.com/davecgh/go-spew/spew"
|
2018-12-07 22:36:01 +00:00
|
|
|
)
|
|
|
|
|
2018-12-07 23:48:00 +01:00
|
|
|
func (b *Bdiscord) messageDelete(s *discordgo.Session, m *discordgo.MessageDelete) { //nolint:unparam
|
2018-12-07 22:36:01 +00:00
|
|
|
rmsg := config.Message{Account: b.Account, ID: m.ID, Event: config.EventMsgDelete, Text: config.EventMsgDelete}
|
|
|
|
rmsg.Channel = b.getChannelName(m.ChannelID)
|
2020-01-09 23:54:04 +01:00
|
|
|
|
2018-12-07 22:36:01 +00:00
|
|
|
b.Log.Debugf("<= Sending message from %s to gateway", b.Account)
|
|
|
|
b.Log.Debugf("<= Message is %#v", rmsg)
|
|
|
|
b.Remote <- rmsg
|
|
|
|
}
|
|
|
|
|
2019-06-16 00:15:18 +01:00
|
|
|
// TODO(qaisjp): if other bridges support bulk deletions, it could be fanned out centrally
|
|
|
|
func (b *Bdiscord) messageDeleteBulk(s *discordgo.Session, m *discordgo.MessageDeleteBulk) { //nolint:unparam
|
|
|
|
for _, msgID := range m.Messages {
|
|
|
|
rmsg := config.Message{
|
|
|
|
Account: b.Account,
|
|
|
|
ID: msgID,
|
|
|
|
Event: config.EventMsgDelete,
|
|
|
|
Text: config.EventMsgDelete,
|
2020-01-09 23:54:04 +01:00
|
|
|
Channel: b.getChannelName(m.ChannelID),
|
2019-06-16 00:15:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
b.Log.Debugf("<= Sending message from %s to gateway", b.Account)
|
|
|
|
b.Log.Debugf("<= Message is %#v", rmsg)
|
|
|
|
b.Remote <- rmsg
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-06 16:58:35 +01:00
|
|
|
func (b *Bdiscord) messageEvent(s *discordgo.Session, m *discordgo.Event) {
|
|
|
|
b.Log.Debug(spew.Sdump(m.Struct))
|
|
|
|
}
|
|
|
|
|
2019-10-03 23:18:56 +01:00
|
|
|
func (b *Bdiscord) messageTyping(s *discordgo.Session, m *discordgo.TypingStart) {
|
|
|
|
if !b.GetBool("ShowUserTyping") {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2020-03-22 17:39:11 +00:00
|
|
|
// Ignore our own typing messages
|
|
|
|
if m.UserID == b.userID {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2019-10-03 23:18:56 +01:00
|
|
|
rmsg := config.Message{Account: b.Account, Event: config.EventUserTyping}
|
|
|
|
rmsg.Channel = b.getChannelName(m.ChannelID)
|
|
|
|
b.Remote <- rmsg
|
|
|
|
}
|
|
|
|
|
2018-12-07 23:48:00 +01:00
|
|
|
func (b *Bdiscord) messageUpdate(s *discordgo.Session, m *discordgo.MessageUpdate) { //nolint:unparam
|
2018-12-07 22:36:01 +00:00
|
|
|
if b.GetBool("EditDisable") {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
// only when message is actually edited
|
2022-03-12 17:06:39 +01:00
|
|
|
if m.Message.EditedTimestamp != nil {
|
2018-12-07 22:36:01 +00:00
|
|
|
b.Log.Debugf("Sending edit message")
|
|
|
|
m.Content += b.GetString("EditSuffix")
|
2019-10-27 01:45:57 +02:00
|
|
|
msg := &discordgo.MessageCreate{
|
|
|
|
Message: m.Message,
|
|
|
|
}
|
|
|
|
b.messageCreate(s, msg)
|
2018-12-07 22:36:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-07 23:48:00 +01:00
|
|
|
func (b *Bdiscord) messageCreate(s *discordgo.Session, m *discordgo.MessageCreate) { //nolint:unparam
|
2018-12-07 22:36:01 +00:00
|
|
|
var err error
|
|
|
|
|
|
|
|
// not relay our own messages
|
|
|
|
if m.Author.Username == b.nick {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
// if using webhooks, do not relay if it's ours
|
2020-11-30 05:47:02 +00:00
|
|
|
if m.Author.Bot && b.transmitter.HasWebhook(m.Author.ID) {
|
2018-12-07 22:36:01 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// add the url of the attachments to content
|
|
|
|
if len(m.Attachments) > 0 {
|
|
|
|
for _, attach := range m.Attachments {
|
|
|
|
m.Content = m.Content + "\n" + attach.URL
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
rmsg := config.Message{Account: b.Account, Avatar: "https://cdn.discordapp.com/avatars/" + m.Author.ID + "/" + m.Author.Avatar + ".jpg", UserID: m.Author.ID, ID: m.ID}
|
|
|
|
|
2022-02-06 16:58:35 +01:00
|
|
|
b.Log.Debugf("== Receiving event %#v", m.Message)
|
|
|
|
|
2018-12-07 22:36:01 +00:00
|
|
|
if m.Content != "" {
|
|
|
|
m.Message.Content = b.replaceChannelMentions(m.Message.Content)
|
|
|
|
rmsg.Text, err = m.ContentWithMoreMentionsReplaced(b.c)
|
|
|
|
if err != nil {
|
|
|
|
b.Log.Errorf("ContentWithMoreMentionsReplaced failed: %s", err)
|
|
|
|
rmsg.Text = m.ContentWithMentionsReplaced()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// set channel name
|
|
|
|
rmsg.Channel = b.getChannelName(m.ChannelID)
|
|
|
|
|
2020-03-18 22:12:48 +00:00
|
|
|
fromWebhook := m.WebhookID != ""
|
|
|
|
if !fromWebhook && !b.GetBool("UseUserName") {
|
2019-09-15 20:25:42 +02:00
|
|
|
rmsg.Username = b.getNick(m.Author, m.GuildID)
|
2018-12-07 22:36:01 +00:00
|
|
|
} else {
|
|
|
|
rmsg.Username = m.Author.Username
|
2020-03-18 22:12:48 +00:00
|
|
|
if !fromWebhook && b.GetBool("UseDiscriminator") {
|
2019-02-23 00:28:27 +11:00
|
|
|
rmsg.Username += "#" + m.Author.Discriminator
|
|
|
|
}
|
2018-12-07 22:36:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// if we have embedded content add it to text
|
|
|
|
if b.GetBool("ShowEmbeds") && m.Message.Embeds != nil {
|
|
|
|
for _, embed := range m.Message.Embeds {
|
2020-03-21 21:27:17 +01:00
|
|
|
rmsg.Text += handleEmbed(embed)
|
2018-12-07 22:36:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// no empty messages
|
|
|
|
if rmsg.Text == "" {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// do we have a /me action
|
|
|
|
var ok bool
|
|
|
|
rmsg.Text, ok = b.replaceAction(rmsg.Text)
|
|
|
|
if ok {
|
|
|
|
rmsg.Event = config.EventUserAction
|
|
|
|
}
|
|
|
|
|
2020-03-22 13:16:31 +00:00
|
|
|
// Replace emotes
|
|
|
|
rmsg.Text = replaceEmotes(rmsg.Text)
|
|
|
|
|
2020-12-31 16:21:37 +00:00
|
|
|
// Add our parent id if it exists, and if it's not referring to a message in another channel
|
|
|
|
if ref := m.MessageReference; ref != nil && ref.ChannelID == m.ChannelID {
|
|
|
|
rmsg.ParentID = ref.MessageID
|
2020-12-31 16:59:47 +01:00
|
|
|
}
|
|
|
|
|
2018-12-07 22:36:01 +00:00
|
|
|
b.Log.Debugf("<= Sending message from %s on %s to gateway", m.Author.Username, b.Account)
|
|
|
|
b.Log.Debugf("<= Message is %#v", rmsg)
|
|
|
|
b.Remote <- rmsg
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *Bdiscord) memberUpdate(s *discordgo.Session, m *discordgo.GuildMemberUpdate) {
|
|
|
|
if m.Member == nil {
|
|
|
|
b.Log.Warnf("Received member update with no member information: %#v", m)
|
|
|
|
}
|
|
|
|
|
|
|
|
b.membersMutex.Lock()
|
|
|
|
defer b.membersMutex.Unlock()
|
|
|
|
|
|
|
|
if currMember, ok := b.userMemberMap[m.Member.User.ID]; ok {
|
|
|
|
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,
|
|
|
|
)
|
|
|
|
delete(b.nickMemberMap, currMember.User.Username)
|
|
|
|
delete(b.nickMemberMap, currMember.Nick)
|
|
|
|
delete(b.userMemberMap, m.Member.User.ID)
|
|
|
|
}
|
|
|
|
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
|
|
|
|
}
|
|
|
|
}
|
2019-02-17 21:49:45 +01:00
|
|
|
|
|
|
|
func (b *Bdiscord) memberAdd(s *discordgo.Session, m *discordgo.GuildMemberAdd) {
|
|
|
|
if m.Member == nil {
|
|
|
|
b.Log.Warnf("Received member update with no member information: %#v", m)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
username := m.Member.User.Username
|
|
|
|
if m.Member.Nick != "" {
|
|
|
|
username = m.Member.Nick
|
|
|
|
}
|
|
|
|
|
|
|
|
rmsg := config.Message{
|
|
|
|
Account: b.Account,
|
|
|
|
Event: config.EventJoinLeave,
|
|
|
|
Username: "system",
|
|
|
|
Text: username + " joins",
|
|
|
|
}
|
|
|
|
b.Log.Debugf("<= Sending message from %s to gateway", b.Account)
|
|
|
|
b.Log.Debugf("<= Message is %#v", rmsg)
|
|
|
|
b.Remote <- rmsg
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *Bdiscord) memberRemove(s *discordgo.Session, m *discordgo.GuildMemberRemove) {
|
|
|
|
if m.Member == nil {
|
|
|
|
b.Log.Warnf("Received member update with no member information: %#v", m)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
username := m.Member.User.Username
|
|
|
|
if m.Member.Nick != "" {
|
|
|
|
username = m.Member.Nick
|
|
|
|
}
|
|
|
|
|
|
|
|
rmsg := config.Message{
|
|
|
|
Account: b.Account,
|
|
|
|
Event: config.EventJoinLeave,
|
|
|
|
Username: "system",
|
|
|
|
Text: username + " leaves",
|
|
|
|
}
|
|
|
|
b.Log.Debugf("<= Sending message from %s to gateway", b.Account)
|
|
|
|
b.Log.Debugf("<= Message is %#v", rmsg)
|
|
|
|
b.Remote <- rmsg
|
|
|
|
}
|
2020-03-21 21:27:17 +01:00
|
|
|
|
|
|
|
func handleEmbed(embed *discordgo.MessageEmbed) string {
|
|
|
|
var t []string
|
|
|
|
var result string
|
|
|
|
|
|
|
|
t = append(t, embed.Title)
|
|
|
|
t = append(t, embed.Description)
|
|
|
|
t = append(t, embed.URL)
|
|
|
|
|
|
|
|
i := 0
|
|
|
|
for _, e := range t {
|
|
|
|
if e == "" {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
i++
|
|
|
|
if i == 1 {
|
2020-05-06 23:19:48 +01:00
|
|
|
result += " embed: " + e
|
2020-03-21 21:27:17 +01:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
result += " - " + e
|
|
|
|
}
|
|
|
|
|
|
|
|
if result != "" {
|
|
|
|
result += "\n"
|
|
|
|
}
|
|
|
|
|
|
|
|
return result
|
|
|
|
}
|