2016-09-19 21:05:13 +02:00
|
|
|
package bdiscord
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/42wim/matterbridge/bridge/config"
|
|
|
|
log "github.com/Sirupsen/logrus"
|
|
|
|
"github.com/bwmarrin/discordgo"
|
2016-10-26 01:01:36 +02:00
|
|
|
"strings"
|
2016-09-19 21:05:13 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
type bdiscord struct {
|
2016-10-26 01:01:36 +02:00
|
|
|
c *discordgo.Session
|
|
|
|
Config *config.Protocol
|
|
|
|
Remote chan config.Message
|
|
|
|
protocol string
|
|
|
|
origin string
|
|
|
|
Channels []*discordgo.Channel
|
|
|
|
Nick string
|
|
|
|
UseChannelID bool
|
2016-09-19 21:05:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
var flog *log.Entry
|
|
|
|
var protocol = "discord"
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
flog = log.WithFields(log.Fields{"module": protocol})
|
|
|
|
}
|
|
|
|
|
2016-11-04 00:05:15 +01:00
|
|
|
func New(cfg config.Protocol, origin string, c chan config.Message) *bdiscord {
|
2016-09-19 21:05:13 +02:00
|
|
|
b := &bdiscord{}
|
2016-11-04 00:05:15 +01:00
|
|
|
b.Config = &cfg
|
2016-09-19 21:05:13 +02:00
|
|
|
b.Remote = c
|
|
|
|
b.protocol = protocol
|
|
|
|
b.origin = origin
|
|
|
|
return b
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *bdiscord) Connect() error {
|
|
|
|
var err error
|
2016-09-20 00:15:30 +02:00
|
|
|
flog.Info("Connecting")
|
2016-09-19 21:05:13 +02:00
|
|
|
b.c, err = discordgo.New(b.Config.Token)
|
|
|
|
if err != nil {
|
|
|
|
flog.Debugf("%#v", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
flog.Info("Connection succeeded")
|
|
|
|
b.c.AddHandler(b.messageCreate)
|
|
|
|
err = b.c.Open()
|
|
|
|
if err != nil {
|
|
|
|
flog.Debugf("%#v", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
guilds, err := b.c.UserGuilds()
|
|
|
|
if err != nil {
|
|
|
|
flog.Debugf("%#v", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
userinfo, err := b.c.User("@me")
|
|
|
|
if err != nil {
|
|
|
|
flog.Debugf("%#v", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
b.Nick = userinfo.Username
|
|
|
|
for _, guild := range guilds {
|
2016-10-23 19:50:12 +02:00
|
|
|
if guild.Name == b.Config.Server {
|
2016-09-19 21:05:13 +02:00
|
|
|
b.Channels, err = b.c.GuildChannels(guild.ID)
|
|
|
|
if err != nil {
|
|
|
|
flog.Debugf("%#v", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *bdiscord) FullOrigin() string {
|
|
|
|
return b.protocol + "." + b.origin
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *bdiscord) JoinChannel(channel string) error {
|
2016-10-26 01:01:36 +02:00
|
|
|
idcheck := strings.Split(channel, "ID:")
|
|
|
|
if len(idcheck) > 1 {
|
|
|
|
b.UseChannelID = true
|
|
|
|
}
|
2016-09-19 21:05:13 +02:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *bdiscord) Name() string {
|
|
|
|
return b.protocol + "." + b.origin
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *bdiscord) Protocol() string {
|
|
|
|
return b.protocol
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *bdiscord) Origin() string {
|
|
|
|
return b.origin
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *bdiscord) Send(msg config.Message) error {
|
2016-09-20 00:15:30 +02:00
|
|
|
flog.Debugf("Receiving %#v", msg)
|
2016-09-19 21:05:13 +02:00
|
|
|
channelID := b.getChannelID(msg.Channel)
|
|
|
|
if channelID == "" {
|
|
|
|
flog.Errorf("Could not find channelID for %v", msg.Channel)
|
|
|
|
return nil
|
|
|
|
}
|
2016-11-05 01:11:28 +01:00
|
|
|
nick := config.GetNick(&msg, b.Config)
|
|
|
|
b.c.ChannelMessageSend(channelID, nick+msg.Text)
|
2016-09-19 21:05:13 +02:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *bdiscord) messageCreate(s *discordgo.Session, m *discordgo.MessageCreate) {
|
|
|
|
// not relay our own messages
|
|
|
|
if m.Author.Username == b.Nick {
|
|
|
|
return
|
|
|
|
}
|
2016-10-26 00:09:22 +02:00
|
|
|
if len(m.Attachments) > 0 {
|
|
|
|
for _, attach := range m.Attachments {
|
|
|
|
m.Content = m.Content + "\n" + attach.URL
|
|
|
|
}
|
|
|
|
}
|
2016-10-26 00:12:31 +02:00
|
|
|
if m.Content == "" {
|
|
|
|
return
|
|
|
|
}
|
2016-09-20 00:15:30 +02:00
|
|
|
flog.Debugf("Sending message from %s on %s to gateway", m.Author.Username, b.FullOrigin())
|
2016-10-26 01:01:36 +02:00
|
|
|
channelName := b.getChannelName(m.ChannelID)
|
|
|
|
if b.UseChannelID {
|
|
|
|
channelName = "ID:" + m.ChannelID
|
|
|
|
}
|
2016-10-30 22:55:34 +01:00
|
|
|
b.Remote <- config.Message{Username: m.Author.Username, Text: m.ContentWithMentionsReplaced(), Channel: channelName,
|
2016-11-06 00:46:32 +01:00
|
|
|
Origin: b.origin, Protocol: b.protocol, FullOrigin: b.FullOrigin(), Avatar: "https://cdn.discordapp.com/avatars/" + m.Author.ID + "/" + m.Author.Avatar + ".jpg"}
|
2016-09-19 21:05:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (b *bdiscord) getChannelID(name string) string {
|
2016-10-26 01:01:36 +02:00
|
|
|
idcheck := strings.Split(name, "ID:")
|
|
|
|
if len(idcheck) > 1 {
|
|
|
|
return idcheck[1]
|
|
|
|
}
|
2016-09-19 21:05:13 +02:00
|
|
|
for _, channel := range b.Channels {
|
|
|
|
if channel.Name == name {
|
|
|
|
return channel.ID
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *bdiscord) getChannelName(id string) string {
|
|
|
|
for _, channel := range b.Channels {
|
|
|
|
if channel.ID == id {
|
|
|
|
return channel.Name
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|