2016-07-11 19:23:33 +00:00
|
|
|
package bridge
|
|
|
|
|
|
|
|
import (
|
2017-02-18 22:10:22 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/api"
|
2016-08-14 19:48:51 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/config"
|
2016-09-19 18:53:26 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/discord"
|
2016-09-04 18:03:07 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/gitter"
|
2016-08-14 19:48:51 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/irc"
|
2017-02-19 23:49:27 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/matrix"
|
2016-08-14 19:48:51 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/mattermost"
|
2016-12-02 23:10:29 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/rocketchat"
|
2016-09-05 14:34:37 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/slack"
|
2017-12-03 00:29:25 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/sshchat"
|
2017-06-21 23:02:05 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/steam"
|
2016-11-15 22:15:57 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/telegram"
|
2016-08-14 19:48:51 +00:00
|
|
|
"github.com/42wim/matterbridge/bridge/xmpp"
|
2018-02-20 22:41:09 +00:00
|
|
|
log "github.com/sirupsen/logrus"
|
2017-02-14 20:12:02 +00:00
|
|
|
|
2016-07-11 19:23:33 +00:00
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
2016-11-13 22:06:37 +00:00
|
|
|
type Bridger interface {
|
2017-08-27 20:59:37 +00:00
|
|
|
Send(msg config.Message) (string, error)
|
2016-08-15 21:15:22 +00:00
|
|
|
Connect() error
|
2017-08-12 12:51:41 +00:00
|
|
|
JoinChannel(channel config.ChannelInfo) error
|
2017-02-14 20:12:02 +00:00
|
|
|
Disconnect() error
|
2016-07-11 19:23:33 +00:00
|
|
|
}
|
|
|
|
|
2016-11-13 22:06:37 +00:00
|
|
|
type Bridge struct {
|
|
|
|
Config config.Protocol
|
|
|
|
Bridger
|
2017-03-28 21:56:58 +00:00
|
|
|
Name string
|
|
|
|
Account string
|
|
|
|
Protocol string
|
|
|
|
Channels map[string]config.ChannelInfo
|
2017-04-01 15:24:19 +00:00
|
|
|
Joined map[string]bool
|
2016-11-13 22:06:37 +00:00
|
|
|
}
|
|
|
|
|
2018-02-20 23:20:25 +00:00
|
|
|
var flog *log.Entry
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
flog = log.WithFields(log.Fields{"prefix": "bridge"})
|
|
|
|
}
|
|
|
|
|
2016-11-13 22:06:37 +00:00
|
|
|
func New(cfg *config.Config, bridge *config.Bridge, c chan config.Message) *Bridge {
|
|
|
|
b := new(Bridge)
|
2017-03-28 21:56:58 +00:00
|
|
|
b.Channels = make(map[string]config.ChannelInfo)
|
2016-09-18 17:21:15 +00:00
|
|
|
accInfo := strings.Split(bridge.Account, ".")
|
|
|
|
protocol := accInfo[0]
|
|
|
|
name := accInfo[1]
|
2016-11-13 22:06:37 +00:00
|
|
|
b.Name = name
|
|
|
|
b.Protocol = protocol
|
|
|
|
b.Account = bridge.Account
|
2017-04-01 15:24:19 +00:00
|
|
|
b.Joined = make(map[string]bool)
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig := &config.BridgeConfig{General: &cfg.General, Account: bridge.Account, Remote: c}
|
2016-11-13 22:06:37 +00:00
|
|
|
|
2016-10-30 21:32:29 +00:00
|
|
|
// override config from environment
|
|
|
|
config.OverrideCfgFromEnv(cfg, protocol, name)
|
2016-09-18 17:21:15 +00:00
|
|
|
switch protocol {
|
|
|
|
case "mattermost":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Mattermost[name]
|
|
|
|
b.Bridger = bmattermost.New(bridgeConfig)
|
2016-08-15 22:08:38 +00:00
|
|
|
case "irc":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.IRC[name]
|
|
|
|
b.Bridger = birc.New(bridgeConfig)
|
2016-09-04 18:03:07 +00:00
|
|
|
case "gitter":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Gitter[name]
|
|
|
|
b.Bridger = bgitter.New(bridgeConfig)
|
2016-09-05 14:34:37 +00:00
|
|
|
case "slack":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Slack[name]
|
|
|
|
b.Bridger = bslack.New(bridgeConfig)
|
2016-09-18 17:21:15 +00:00
|
|
|
case "xmpp":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Xmpp[name]
|
|
|
|
b.Bridger = bxmpp.New(bridgeConfig)
|
2016-09-19 18:53:26 +00:00
|
|
|
case "discord":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Discord[name]
|
|
|
|
b.Bridger = bdiscord.New(bridgeConfig)
|
2016-11-15 22:15:57 +00:00
|
|
|
case "telegram":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Telegram[name]
|
|
|
|
b.Bridger = btelegram.New(bridgeConfig)
|
2016-12-02 23:10:29 +00:00
|
|
|
case "rocketchat":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Rocketchat[name]
|
|
|
|
b.Bridger = brocketchat.New(bridgeConfig)
|
2017-02-19 23:49:27 +00:00
|
|
|
case "matrix":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Matrix[name]
|
|
|
|
b.Bridger = bmatrix.New(bridgeConfig)
|
2017-06-21 23:02:05 +00:00
|
|
|
case "steam":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Steam[name]
|
|
|
|
b.Bridger = bsteam.New(bridgeConfig)
|
2017-12-03 00:29:25 +00:00
|
|
|
case "sshchat":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Sshchat[name]
|
|
|
|
b.Bridger = bsshchat.New(bridgeConfig)
|
2017-02-18 22:10:22 +00:00
|
|
|
case "api":
|
2017-12-19 22:15:03 +00:00
|
|
|
bridgeConfig.Config = cfg.Api[name]
|
|
|
|
b.Bridger = api.New(bridgeConfig)
|
2016-08-15 22:08:38 +00:00
|
|
|
}
|
2017-12-26 18:13:27 +00:00
|
|
|
b.Config = bridgeConfig.Config
|
2016-11-13 22:06:37 +00:00
|
|
|
return b
|
2016-08-15 22:08:38 +00:00
|
|
|
}
|
2017-02-14 20:12:02 +00:00
|
|
|
|
|
|
|
func (b *Bridge) JoinChannels() error {
|
2017-04-01 15:24:19 +00:00
|
|
|
err := b.joinChannels(b.Channels, b.Joined)
|
2017-07-13 22:35:01 +00:00
|
|
|
return err
|
2017-02-14 22:52:45 +00:00
|
|
|
}
|
|
|
|
|
2017-03-28 21:56:58 +00:00
|
|
|
func (b *Bridge) joinChannels(channels map[string]config.ChannelInfo, exists map[string]bool) error {
|
|
|
|
for ID, channel := range channels {
|
|
|
|
if !exists[ID] {
|
2018-02-20 23:20:25 +00:00
|
|
|
flog.Infof("%s: joining %s (ID: %s)", b.Account, channel.Name, ID)
|
2017-08-12 12:51:41 +00:00
|
|
|
err := b.JoinChannel(channel)
|
2017-03-16 22:05:11 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2017-03-28 21:56:58 +00:00
|
|
|
exists[ID] = true
|
2017-02-14 20:12:02 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|