summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--bridge/bridge.go2
-rw-r--r--bridge/config/config.go1
-rw-r--r--matterbridge.toml.sample6
3 files changed, 9 insertions, 0 deletions
diff --git a/bridge/bridge.go b/bridge/bridge.go
index 5612e35d..eec2bfaf 100644
--- a/bridge/bridge.go
+++ b/bridge/bridge.go
@@ -4,6 +4,7 @@ import (
"log"
"strings"
"sync"
+ "time"
"github.com/42wim/matterbridge/bridge/config"
"github.com/sirupsen/logrus"
@@ -74,6 +75,7 @@ func (b *Bridge) joinChannels(channels map[string]config.ChannelInfo, exists map
for ID, channel := range channels {
if !exists[ID] {
b.Log.Infof("%s: joining %s (ID: %s)", b.Account, channel.Name, ID)
+ time.Sleep(time.Duration(b.GetInt("JoinDelay")) * time.Millisecond)
err := b.JoinChannel(channel)
if err != nil {
return err
diff --git a/bridge/config/config.go b/bridge/config/config.go
index ea62d7cc..dfb71eec 100644
--- a/bridge/config/config.go
+++ b/bridge/config/config.go
@@ -89,6 +89,7 @@ type Protocol struct {
IgnoreNicks string // all protocols
IgnoreMessages string // all protocols
Jid string // xmpp
+ JoinDelay string // all protocols
Label string // all protocols
Login string // mattermost, matrix
MediaDownloadBlackList []string
diff --git a/matterbridge.toml.sample b/matterbridge.toml.sample
index 0aca45f2..4082b6dc 100644
--- a/matterbridge.toml.sample
+++ b/matterbridge.toml.sample
@@ -177,6 +177,12 @@ StripNick=false
#OPTIONAL (default false)
ShowTopicChange=false
+#Delay in milliseconds between channel joins
+#Only useful when you have a LOT of channels to join
+#See https://github.com/42wim/matterbridge/issues/1084
+#OPTIONAL (default 0)
+JoinDelay=0
+
###################################################################
#XMPP section
###################################################################