2016-07-11 21:23:33 +02:00
|
|
|
package bridge
|
|
|
|
|
|
|
|
import (
|
2020-02-01 15:23:50 +01:00
|
|
|
"log"
|
2016-07-11 21:23:33 +02:00
|
|
|
"strings"
|
2019-02-23 22:51:27 +01:00
|
|
|
"sync"
|
2020-04-19 00:46:35 +02:00
|
|
|
"time"
|
2018-12-26 15:16:09 +01:00
|
|
|
|
|
|
|
"github.com/42wim/matterbridge/bridge/config"
|
|
|
|
"github.com/sirupsen/logrus"
|
2016-07-11 21:23:33 +02:00
|
|
|
)
|
|
|
|
|
2016-11-13 23:06:37 +01:00
|
|
|
type Bridger interface {
|
2017-08-27 22:59:37 +02:00
|
|
|
Send(msg config.Message) (string, error)
|
2016-08-15 23:15:22 +02:00
|
|
|
Connect() error
|
2017-08-12 14:51:41 +02:00
|
|
|
JoinChannel(channel config.ChannelInfo) error
|
2017-02-14 21:12:02 +01:00
|
|
|
Disconnect() error
|
2016-07-11 21:23:33 +02:00
|
|
|
}
|
|
|
|
|
2016-11-13 23:06:37 +01:00
|
|
|
type Bridge struct {
|
|
|
|
Bridger
|
2019-02-23 22:51:27 +01:00
|
|
|
*sync.RWMutex
|
|
|
|
|
2019-01-18 18:35:31 +01:00
|
|
|
Name string
|
|
|
|
Account string
|
|
|
|
Protocol string
|
|
|
|
Channels map[string]config.ChannelInfo
|
|
|
|
Joined map[string]bool
|
|
|
|
ChannelMembers *config.ChannelMembers
|
|
|
|
Log *logrus.Entry
|
|
|
|
Config config.Config
|
|
|
|
General *config.Protocol
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
type Config struct {
|
|
|
|
*Bridge
|
2019-02-23 22:51:27 +01:00
|
|
|
|
|
|
|
Remote chan config.Message
|
2016-11-13 23:06:37 +01:00
|
|
|
}
|
|
|
|
|
2018-02-27 00:33:21 +01:00
|
|
|
// Factory is the factory function to create a bridge
|
2018-03-04 23:52:14 +01:00
|
|
|
type Factory func(*Config) Bridger
|
2018-02-21 00:20:25 +01:00
|
|
|
|
2018-02-27 00:33:21 +01:00
|
|
|
func New(bridge *config.Bridge) *Bridge {
|
2016-09-18 19:21:15 +02:00
|
|
|
accInfo := strings.Split(bridge.Account, ".")
|
2020-02-01 15:23:50 +01:00
|
|
|
if len(accInfo) != 2 {
|
|
|
|
log.Fatalf("config failure, account incorrect: %s", bridge.Account)
|
|
|
|
}
|
|
|
|
|
2016-09-18 19:21:15 +02:00
|
|
|
protocol := accInfo[0]
|
|
|
|
name := accInfo[1]
|
2019-02-23 22:51:27 +01:00
|
|
|
|
|
|
|
return &Bridge{
|
|
|
|
RWMutex: new(sync.RWMutex),
|
|
|
|
Channels: make(map[string]config.ChannelInfo),
|
|
|
|
Name: name,
|
|
|
|
Protocol: protocol,
|
|
|
|
Account: bridge.Account,
|
|
|
|
Joined: make(map[string]bool),
|
|
|
|
}
|
2016-08-16 00:08:38 +02:00
|
|
|
}
|
2017-02-14 21:12:02 +01:00
|
|
|
|
|
|
|
func (b *Bridge) JoinChannels() error {
|
2019-02-23 22:51:27 +01:00
|
|
|
return b.joinChannels(b.Channels, b.Joined)
|
2017-02-14 23:52:45 +01:00
|
|
|
}
|
|
|
|
|
2019-01-18 18:35:31 +01:00
|
|
|
// SetChannelMembers sets the newMembers to the bridge ChannelMembers
|
|
|
|
func (b *Bridge) SetChannelMembers(newMembers *config.ChannelMembers) {
|
|
|
|
b.Lock()
|
|
|
|
b.ChannelMembers = newMembers
|
|
|
|
b.Unlock()
|
|
|
|
}
|
|
|
|
|
2017-03-28 23:56:58 +02: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-27 00:33:21 +01:00
|
|
|
b.Log.Infof("%s: joining %s (ID: %s)", b.Account, channel.Name, ID)
|
2020-04-19 00:46:35 +02:00
|
|
|
time.Sleep(time.Duration(b.GetInt("JoinDelay")) * time.Millisecond)
|
2017-08-12 14:51:41 +02:00
|
|
|
err := b.JoinChannel(channel)
|
2017-03-16 23:05:11 +01:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2017-03-28 23:56:58 +02:00
|
|
|
exists[ID] = true
|
2017-02-14 21:12:02 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2018-03-04 23:52:14 +01:00
|
|
|
|
2020-06-24 23:25:10 +01:00
|
|
|
func (b *Bridge) GetConfigKey(key string) string {
|
|
|
|
return b.Account + "." + key
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *Bridge) IsKeySet(key string) bool {
|
|
|
|
return b.Config.IsKeySet(b.GetConfigKey(key)) || b.Config.IsKeySet("general."+key)
|
|
|
|
}
|
|
|
|
|
2018-03-04 23:52:14 +01:00
|
|
|
func (b *Bridge) GetBool(key string) bool {
|
2020-06-24 23:25:10 +01:00
|
|
|
val, ok := b.Config.GetBool(b.GetConfigKey(key))
|
2018-11-13 22:30:56 +00:00
|
|
|
if !ok {
|
|
|
|
val, _ = b.Config.GetBool("general." + key)
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|
2018-11-13 22:30:56 +00:00
|
|
|
return val
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (b *Bridge) GetInt(key string) int {
|
2020-06-24 23:25:10 +01:00
|
|
|
val, ok := b.Config.GetInt(b.GetConfigKey(key))
|
2018-11-13 22:30:56 +00:00
|
|
|
if !ok {
|
|
|
|
val, _ = b.Config.GetInt("general." + key)
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|
2018-11-13 22:30:56 +00:00
|
|
|
return val
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (b *Bridge) GetString(key string) string {
|
2020-06-24 23:25:10 +01:00
|
|
|
val, ok := b.Config.GetString(b.GetConfigKey(key))
|
2018-11-13 22:30:56 +00:00
|
|
|
if !ok {
|
|
|
|
val, _ = b.Config.GetString("general." + key)
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|
2018-11-13 22:30:56 +00:00
|
|
|
return val
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (b *Bridge) GetStringSlice(key string) []string {
|
2020-06-24 23:25:10 +01:00
|
|
|
val, ok := b.Config.GetStringSlice(b.GetConfigKey(key))
|
2018-11-13 22:30:56 +00:00
|
|
|
if !ok {
|
|
|
|
val, _ = b.Config.GetStringSlice("general." + key)
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|
2018-11-13 22:30:56 +00:00
|
|
|
return val
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (b *Bridge) GetStringSlice2D(key string) [][]string {
|
2020-06-24 23:25:10 +01:00
|
|
|
val, ok := b.Config.GetStringSlice2D(b.GetConfigKey(key))
|
2018-11-13 22:30:56 +00:00
|
|
|
if !ok {
|
|
|
|
val, _ = b.Config.GetStringSlice2D("general." + key)
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|
2018-11-13 22:30:56 +00:00
|
|
|
return val
|
2018-03-04 23:52:14 +01:00
|
|
|
}
|