2016-09-18 21:04:28 +02:00
#This is configuration for matterbridge.
2017-06-08 23:42:00 +02:00
#WARNING: as this file contains credentials, be sure to set correct file permissions
2016-09-18 21:04:28 +02:00
###################################################################
#IRC section
###################################################################
#REQUIRED to start IRC section
[irc]
#You can configure multiple servers "[irc.name]" or "[irc.name2]"
#In this example we use [irc.freenode]
#REQUIRED
[irc.freenode]
#irc server to connect to.
#REQUIRED
Server="irc.freenode.net:6667"
2016-12-26 10:12:59 +01:00
#Password for irc server (if necessary)
#OPTIONAL (default "")
Password=""
2016-09-18 21:04:28 +02:00
#Enable to use TLS connection to your irc server.
#OPTIONAL (default false)
UseTLS=false
#Enable SASL (PLAIN) authentication. (freenode requires this from eg AWS hosts)
#It uses NickServNick and NickServPassword as login and password
#OPTIONAL (default false)
UseSASL=false
#Enable to not verify the certificate on your irc server. i
#e.g. when using selfsigned certificates
#OPTIONAL (default false)
SkipTLSVerify=true
2017-08-29 21:30:59 +02:00
#If you know your charset, you can specify it manually.
#Otherwise it tries to detect this automatically. Select one below
# "iso-8859-2:1987", "iso-8859-9:1989", "866", "latin9", "iso-8859-10:1992", "iso-ir-109", "hebrew",
# "cp932", "iso-8859-15", "cp437", "utf-16be", "iso-8859-3:1988", "windows-1251", "utf16", "latin6",
# "latin3", "iso-8859-1:1987", "iso-8859-9", "utf-16le", "big5", "cp819", "asmo-708", "utf-8",
# "ibm437", "iso-ir-157", "iso-ir-144", "latin4", "850", "iso-8859-5", "iso-8859-5:1988", "l3",
# "windows-31j", "utf8", "iso-8859-3", "437", "greek", "iso-8859-8", "l6", "l9-iso-8859-15",
# "iso-8859-2", "latin2", "iso-ir-100", "iso-8859-6", "arabic", "iso-ir-148", "us-ascii", "x-sjis",
# "utf16be", "iso-8859-8:1988", "utf16le", "l4", "utf-16", "iso-ir-138", "iso-8859-7", "iso-8859-7:1987",
# "windows-1252", "l2", "koi8-r", "iso8859-1", "latin1", "ecma-114", "iso-ir-110", "elot-928",
# "iso-ir-126", "iso-8859-1", "iso-ir-127", "cp850", "cyrillic", "greek8", "windows-1250", "iso-latin-1",
# "l5", "ibm866", "cp866", "ms-kanji", "ibm850", "ecma-118", "iso-ir-101", "ibm819", "l1", "iso-8859-6:1987",
# "latin5", "ascii", "sjis", "iso-8859-10", "iso-8859-4", "iso-8859-4:1988", "shift-jis
# The select charset will be converted to utf-8 when sent to other bridges.
#OPTIONAL (default "")
Charset=""
2016-09-18 21:04:28 +02:00
#Your nick on irc.
#REQUIRED
Nick="matterbot"
#If you registered your bot with a service like Nickserv on freenode.
#Also being used when UseSASL=true
2017-09-20 22:47:26 +02:00
#
#Note: if you want do to quakenet auth, set NickServNick="Q@CServe.quakenet.org"
2016-09-18 21:04:28 +02:00
#OPTIONAL
NickServNick="nickserv"
NickServPassword="secret"
2017-09-20 22:47:26 +02:00
#OPTIONAL only used for quakenet auth
NickServUsername="username"
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2016-11-01 23:10:29 +01:00
#Flood control
#Delay in milliseconds between each message send to the IRC server
#OPTIONAL (default 1300)
MessageDelay=1300
#Maximum amount of messages to hold in queue. If queue is full
#messages will be dropped.
2017-05-29 21:54:34 +02:00
#<message clipped> will be add to the message that fills the queue.
2016-11-01 23:10:29 +01:00
#OPTIONAL (default 30)
MessageQueue=30
2017-05-29 21:54:34 +02:00
#Maximum length of message sent to irc server. If it exceeds
#<message clipped> will be add to the message.
#OPTIONAL (default 400)
MessageLength=400
2017-11-24 23:27:13 +01:00
#Split messages on MessageLength instead of showing the <message clipped>
#WARNING: this could lead to flooding
#OPTIONAL (default false)
MessageSplit=false
2017-12-23 00:11:30 +01:00
#Delay in seconds to rejoin a channel when kicked
#OPTIONAL (default 0)
RejoinDelay=0
2018-05-12 00:02:43 +03:00
#ColorNicks will show each nickname in a different color.
#Only works in IRC right now.
ColorNicks=false
2018-11-25 19:32:16 +01:00
#RunCommands allows you to send RAW irc commands after connection
#Array of strings
#OPTIONAL (default empty)
RunCommands=["PRIVMSG user hello","PRIVMSG chanserv something"]
2016-11-14 22:53:06 +01:00
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2016-11-14 22:53:06 +01:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="ircspammer1 ircspammer2"
2017-06-18 01:08:11 +02:00
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2016-11-14 22:53:06 +01:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2017-05-30 00:11:53 +02:00
#The string "{NOPINGNICK}" (case sensitive) will be replaced by the actual nick / username, but with a ZWSP inside the nick, so the irc user with the same nick won't get pinged. See https://github.com/42wim/matterbridge/issues/175 for more information
2016-11-14 22:53:06 +01:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
2017-04-07 22:27:36 +02:00
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2016-11-14 22:53:06 +01:00
#OPTIONAL (default false)
ShowJoinPart=false
2018-03-06 21:34:55 +01:00
#Do not send joins/parts to other bridges
#Currently works for messages from the following bridges: irc, mattermost, slack
#OPTIONAL (default false)
NoSendJoinPart=false
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2018-02-02 21:04:43 +01:00
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2016-09-18 21:04:28 +02:00
###################################################################
#XMPP section
###################################################################
[xmpp]
#You can configure multiple servers "[xmpp.name]" or "[xmpp.name2]"
#In this example we use [xmpp.jabber]
#REQUIRED
[xmpp.jabber]
#xmpp server to connect to.
#REQUIRED
Server="jabber.example.com:5222"
#Jid
#REQUIRED
Jid="user@example.com"
#Password
#REQUIRED
Password="yourpass"
#MUC
#REQUIRED
Muc="conference.jabber.example.com"
#Your nick in the rooms
#REQUIRED
Nick="xmppbot"
2017-01-14 00:35:45 +01:00
#Enable to not verify the certificate on your xmpp server.
#e.g. when using selfsigned certificates
#OPTIONAL (default false)
SkipTLSVerify=true
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2016-11-14 22:53:06 +01:00
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2016-11-14 22:53:06 +01:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="ircspammer1 ircspammer2"
2017-06-18 01:08:11 +02:00
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#Messages you want to replace.
#It replaces outgoing messages from the bridge.
#So you need to place it by the sending bridge definition.
#Regular expressions supported
#Some examples:
#This replaces cat => dog and sleep => awake
#ReplaceMessages=[ ["cat","dog"], ["sleep","awake"] ]
#This Replaces every number with number. 123 => numbernumbernumber
#ReplaceMessages=[ ["[0-9]","number"] ]
#OPTIONAL (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#Nicks you want to replace.
#See ReplaceMessages for syntaxA
#OPTIONAL (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2016-11-14 22:53:06 +01:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2016-11-14 22:53:06 +01:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
2017-04-07 22:27:36 +02:00
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2016-11-14 22:53:06 +01:00
#OPTIONAL (default false)
ShowJoinPart=false
2016-09-18 21:04:28 +02:00
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2016-11-26 00:40:21 +01:00
2018-02-02 21:04:43 +01:00
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2016-11-26 00:40:21 +01:00
###################################################################
#hipchat section
###################################################################
#Go to https://www.hipchat.com/account/xmpp this will show you the necessary data
#to fill in the section below
[xmpp.hipchat]
#xmpp server to connect to.
#REQUIRED
Server="chat.hipchat.com:5222"
#Jabber ID
#REQUIRED
Jid="12345_12345@chat.hipchat.com"
#Password (your hipchat password)
#REQUIRED
Password="yourpass"
#Conference (MUC) domain
#REQUIRED
Muc="conf.hipchat.com"
#Room nickname
#REQUIRED
Nick="yourlogin"
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2016-11-26 00:40:21 +01:00
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2016-11-26 00:40:21 +01:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="spammer1 spammer2"
2017-06-18 01:08:11 +02:00
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2016-11-26 00:40:21 +01:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2016-11-26 00:40:21 +01:00
RemoteNickFormat="[{PROTOCOL}/{BRIDGE}] <{NICK}> "
2017-04-07 22:27:36 +02:00
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2016-11-26 00:40:21 +01:00
#OPTIONAL (default false)
ShowJoinPart=false
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2016-11-26 00:40:21 +01:00
2018-02-02 21:04:43 +01:00
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2016-09-18 21:04:28 +02:00
###################################################################
#mattermost section
###################################################################
[mattermost]
#You can configure multiple servers "[mattermost.name]" or "[mattermost.name2]"
#In this example we use [mattermost.work]
#REQUIRED
[mattermost.work]
2017-04-19 21:57:40 +02:00
#The mattermost hostname. (do not prefix it with http or https)
2017-06-24 19:36:10 +02:00
#REQUIRED (when not using webhooks)
2017-04-19 21:57:40 +02:00
Server="yourmattermostserver.domain"
2016-09-18 21:04:28 +02:00
#Your team on mattermost.
2017-06-24 19:36:10 +02:00
#REQUIRED (when not using webhooks)
2016-09-18 21:04:28 +02:00
Team="yourteam"
#login/pass of your bot.
#Use a dedicated user for this and not your own!
2017-06-24 19:36:10 +02:00
#REQUIRED (when not using webhooks)
2016-09-18 21:04:28 +02:00
Login="yourlogin"
Password="yourpass"
2017-08-23 22:49:42 +02:00
#personal access token of the bot.
#new feature since mattermost 4.1. See https://docs.mattermost.com/developer/personal-access-tokens.html
#OPTIONAL (you can use token instead of login/password)
#Token="abcdefghijklm"
2016-09-18 21:04:28 +02:00
#Enable this to make a http connection (instead of https) to your mattermost.
#OPTIONAL (default false)
NoTLS=false
2017-06-24 19:36:10 +02:00
#### Settings for webhook matterbridge.
#NOT RECOMMENDED TO USE INCOMING/OUTGOING WEBHOOK. USE DEDICATED BOT USER WHEN POSSIBLE!
#You don't need to configure this, if you have configured the settings
#above.
#Url is your incoming webhook url as specified in mattermost.
#See account settings - integrations - incoming webhooks on mattermost.
#If specified, messages will be sent to mattermost using this URL
#OPTIONAL
WebhookURL="https://yourdomain/hooks/yourhookkey"
#Address to listen on for outgoing webhook requests from mattermost.
#See account settings - integrations - outgoing webhooks on mattermost.
#If specified, messages will be received from mattermost on this ip:port
#(this will only work if WebhookURL above is also configured)
#OPTIONAL
WebhookBindAddress="0.0.0.0:9999"
#Icon that will be showed in mattermost.
#This only works when WebhookURL is configured
#OPTIONAL
IconURL="http://youricon.png"
#### End settings for webhook matterbridge.
2016-09-18 21:04:28 +02:00
#Enable to not verify the certificate on your mattermost server.
#e.g. when using selfsigned certificates
#OPTIONAL (default false)
SkipTLSVerify=true
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2016-11-14 22:53:06 +01:00
#how to format the list of IRC nicks when displayed in mattermost.
#Possible options are "table" and "plain"
#OPTIONAL (default plain)
NickFormatter="plain"
#How many nicks to list per row for formatters that support this.
#OPTIONAL (default 4)
NicksPerRow=4
2016-09-18 21:04:28 +02:00
#Whether to prefix messages from other bridges to mattermost with the sender's nick.
#Useful if username overrides for incoming webhooks isn't enabled on the
#mattermost server. If you set PrefixMessagesWithNick to true, each message
#from bridge to Mattermost will by default be prefixed by "bridge-" + nick. You can,
#however, modify how the messages appear, by setting (and modifying) RemoteNickFormat
#OPTIONAL (default false)
PrefixMessagesWithNick=false
2017-04-15 20:21:57 +02:00
#Disable sending of edits to other bridges
#OPTIONAL (default false)
EditDisable=false
#Message to be appended to every edited message
#OPTIONAL (default empty)
EditSuffix=" (edited)"
2016-11-14 22:53:06 +01:00
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2016-11-14 22:53:06 +01:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="ircspammer1 ircspammer2"
2017-06-18 01:08:11 +02:00
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2016-09-18 21:04:28 +02:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2016-09-30 20:35:16 +02:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
2016-09-18 21:04:28 +02:00
2017-04-07 22:27:36 +02:00
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2016-11-14 22:53:06 +01:00
#OPTIONAL (default false)
ShowJoinPart=false
2016-09-18 21:04:28 +02:00
2018-03-06 21:34:55 +01:00
#Do not send joins/parts to other bridges
#Currently works for messages from the following bridges: irc, mattermost, slack
#OPTIONAL (default false)
NoSendJoinPart=false
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2018-02-02 21:04:43 +01:00
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2016-09-18 21:04:28 +02:00
###################################################################
#Gitter section
#Best to make a dedicated gitter account for the bot.
###################################################################
[gitter]
#You can configure multiple servers "[gitter.name]" or "[gitter.name2]"
#In this example we use [gitter.myproject]
#REQUIRED
[gitter.myproject]
#Token to connect with Gitter API
#You can get your token by going to https://developer.gitter.im/docs/welcome and SIGN IN
#REQUIRED
Token="Yourtokenhere"
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2016-11-14 22:53:06 +01:00
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2016-11-14 22:53:06 +01:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="ircspammer1 ircspammer2"
2016-09-18 21:04:28 +02:00
2017-06-18 01:08:11 +02:00
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2016-09-18 21:04:28 +02:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2016-09-30 20:35:16 +02:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
2016-09-18 21:04:28 +02:00
2017-04-07 22:27:36 +02:00
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2016-11-14 22:53:06 +01:00
#OPTIONAL (default false)
ShowJoinPart=false
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2018-02-02 21:04:43 +01:00
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2016-09-18 21:04:28 +02:00
###################################################################
#slack section
###################################################################
[slack]
#You can configure multiple servers "[slack.name]" or "[slack.name2]"
#In this example we use [slack.hobby]
#REQUIRED
[slack.hobby]
2017-06-24 19:36:10 +02:00
#Token to connect with the Slack API
#You'll have to use a test/api-token using a dedicated user and not a bot token.
#See https://github.com/42wim/matterbridge/issues/75 for more info.
#Use https://api.slack.com/custom-integrations/legacy-tokens
#REQUIRED (when not using webhooks)
Token="yourslacktoken"
2016-09-18 21:04:28 +02:00
2017-06-24 19:36:10 +02:00
#### Settings for webhook matterbridge.
2017-02-17 23:21:43 +01:00
#NOT RECOMMENDED TO USE INCOMING/OUTGOING WEBHOOK. USE SLACK API
#AND DEDICATED BOT USER WHEN POSSIBLE!
2016-09-18 21:04:28 +02:00
#Url is your incoming webhook url as specified in slack
#See account settings - integrations - incoming webhooks on slack
2017-06-24 19:36:10 +02:00
#OPTIONAL
WebhookURL="https://hooks.slack.com/services/yourhook"
2016-09-18 21:04:28 +02:00
2017-02-17 23:21:43 +01:00
#NOT RECOMMENDED TO USE INCOMING/OUTGOING WEBHOOK. USE SLACK API
#AND DEDICATED BOT USER WHEN POSSIBLE!
2016-09-18 21:04:28 +02:00
#Address to listen on for outgoing webhook requests from slack
#See account settings - integrations - outgoing webhooks on slack
#webhooks
#OPTIONAL
2017-06-24 19:36:10 +02:00
WebhookBindAddress="0.0.0.0:9999"
2016-09-18 21:04:28 +02:00
2016-11-05 01:11:28 +01:00
#Icon that will be showed in slack
#The string "{NICK}" (case sensitive) will be replaced by the actual nick / username.
#The string "{BRIDGE}" (case sensitive) will be replaced by the sending bridge
2018-02-20 18:57:46 +01:00
#The string "{LABEL}" (case sensitive) will be replaced by label= field of the sending bridge
2016-11-05 01:11:28 +01:00
#The string "{PROTOCOL}" (case sensitive) will be replaced by the protocol used by the bridge
#OPTIONAL
IconURL="https://robohash.org/{NICK}.png?size=48x48"
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2016-11-14 22:53:06 +01:00
#how to format the list of IRC nicks when displayed in slack
#Possible options are "table" and "plain"
#OPTIONAL (default plain)
NickFormatter="plain"
#How many nicks to list per row for formatters that support this.
#OPTIONAL (default 4)
NicksPerRow=4
2017-04-16 00:16:24 +02:00
#Disable sending of edits to other bridges
#OPTIONAL (default false)
EditDisable=true
#Message to be appended to every edited message
#OPTIONAL (default empty)
EditSuffix=" (edited)"
2016-11-05 01:11:28 +01:00
#Whether to prefix messages from other bridges to mattermost with RemoteNickFormat
2016-09-18 21:04:28 +02:00
#Useful if username overrides for incoming webhooks isn't enabled on the
#slack server. If you set PrefixMessagesWithNick to true, each message
#from bridge to Slack will by default be prefixed by "bridge-" + nick. You can,
#however, modify how the messages appear, by setting (and modifying) RemoteNickFormat
#OPTIONAL (default false)
PrefixMessagesWithNick=false
2016-11-14 22:53:06 +01:00
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2016-11-14 22:53:06 +01:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="ircspammer1 ircspammer2"
2017-06-18 01:08:11 +02:00
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2016-09-18 21:04:28 +02:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2016-09-30 20:35:16 +02:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
2016-09-18 21:04:28 +02:00
2017-04-07 22:27:36 +02:00
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2016-11-14 22:53:06 +01:00
#OPTIONAL (default false)
ShowJoinPart=false
2016-09-18 21:04:28 +02:00
2018-03-06 21:34:55 +01:00
#Do not send joins/parts to other bridges
#Currently works for messages from the following bridges: irc, mattermost, slack
#OPTIONAL (default false)
NoSendJoinPart=false
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2018-02-02 21:04:43 +01:00
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2018-11-07 16:14:31 +08:00
#Opportunistically preserve threaded replies between Slack channels.
#This only works if the parent message is still in the cache.
#Cache is flushed between restarts.
2018-12-03 23:50:37 +08:00
#Note: Not currently working on gateways with mixed bridges of
# both slack and slack-legacy type. Context in issue #624.
2018-11-07 16:14:31 +08:00
#OPTIONAL (default false)
PreserveThreading=false
2018-11-09 03:45:40 +08:00
#Enable showing "user_typing" events from across gateway when available.
2018-11-10 04:52:37 +08:00
#Protip: Set your bot/user's "Full Name" to be "Someone (over chat bridge)",
#and so the message will say "Someone (over chat bridge) is typing".
2018-11-09 03:45:40 +08:00
#OPTIONAL (default false)
ShowUserTyping=false
2016-09-19 20:53:26 +02:00
###################################################################
#discord section
###################################################################
[discord]
#You can configure multiple servers "[discord.name]" or "[discord.name2]"
#In this example we use [discord.game]
#REQUIRED
[discord.game]
#Token to connect with Discord API
#You can get your token by following the instructions on
#https://github.com/reactiflux/discord-irc/wiki/Creating-a-discord-bot-&-getting-a-token
2017-03-18 16:50:09 +01:00
#If you want roles/groups mentions to be shown with names instead of ID, you'll need to give your bot the "Manage Roles" permission.
2016-09-19 20:53:26 +02:00
#REQUIRED
2016-11-14 16:30:43 +01:00
Token="Yourtokenhere"
2016-09-19 20:53:26 +02:00
#REQUIRED
2016-10-23 19:51:31 +02:00
Server="yourservername"
2016-09-19 20:53:26 +02:00
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2017-06-24 23:17:57 +02:00
#Shows title, description and URL of embedded messages (sent by other bots)
#OPTIONAL (default false)
ShowEmbeds=false
2017-08-01 09:18:55 -07:00
#Shows the username (minus the discriminator) instead of the server nickname
#OPTIONAL (default false)
UseUserName=false
2017-06-26 20:07:27 +02:00
#Specify WebhookURL. If given, will relay messages using the Webhook, which gives a better look to messages.
2017-08-12 14:51:41 +02:00
#This only works if you have one discord channel, if you have multiple discord channels you'll have to specify it in the gateway config
2017-06-26 20:07:27 +02:00
#OPTIONAL (default empty)
WebhookURL="Yourwebhooktokenhere"
2017-04-15 19:00:15 +02:00
#Disable sending of edits to other bridges
#OPTIONAL (default false)
EditDisable=false
#Message to be appended to every edited message
#OPTIONAL (default empty)
EditSuffix=" (edited)"
2016-11-14 22:53:06 +01:00
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2016-11-14 22:53:06 +01:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="ircspammer1 ircspammer2"
2016-09-19 20:53:26 +02:00
2017-06-18 01:08:11 +02:00
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2016-09-19 20:53:26 +02:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2016-09-30 20:35:16 +02:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
2016-09-19 20:53:26 +02:00
2017-04-07 22:27:36 +02:00
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2016-11-14 22:53:06 +01:00
#OPTIONAL (default false)
ShowJoinPart=false
2016-09-18 21:04:28 +02:00
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2018-11-26 17:47:04 +08:00
#Enable to show topic/purpose changes from other bridges
2018-02-02 21:04:43 +01:00
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2018-11-26 17:47:04 +08:00
#Enable to sync topic/purpose changes from other bridges
#Only works syncing topic changes from slack bridge for now
#OPTIONAL (default false)
SyncTopic=false
2016-11-20 17:01:53 +01:00
###################################################################
#telegram section
###################################################################
[telegram]
#You can configure multiple servers "[telegram.name]" or "[telegram.name2]"
#In this example we use [telegram.secure]
#REQUIRED
[telegram.secure]
#Token to connect with telegram API
2017-01-27 23:36:14 +01:00
#See https://core.telegram.org/bots#6-botfather and https://www.linkedin.com/pulse/telegram-bots-beginners-marco-frau
2016-11-20 17:01:53 +01:00
#REQUIRED
Token="Yourtokenhere"
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2017-02-24 18:49:52 +01:00
#OPTIONAL (default empty)
2018-06-19 00:28:16 +02:00
#Supported formats are "HTML", "Markdown" and "HTMLNick"
2017-02-24 18:49:52 +01:00
#See https://core.telegram.org/bots/api#html-style
2018-06-06 01:00:00 +02:00
#See https://core.telegram.org/bots/api#markdown-style
2018-06-19 00:28:16 +02:00
#HTMLNick only allows HTML for the nick, the message itself will be html-escaped
2017-02-24 18:49:52 +01:00
MessageFormat=""
2017-05-15 23:23:10 +02:00
#If enabled use the "First Name" as username. If this is empty use the Username
#If disabled use the "Username" as username. If this is empty use the First Name
#If all names are empty, username will be "unknown"
#OPTIONAL (default false)
UseFirstName=false
2017-07-04 01:34:02 +02:00
#WARNING! If enabled this will relay GIF/stickers/documents and other attachments as URLs
#Those URLs will contain your bot-token. This may not be what you want.
#For now there is no secure way to relay GIF/stickers/documents without seeing your token.
#OPTIONAL (default false)
UseInsecureURL=false
2018-04-17 23:26:41 +02:00
#Disable quoted/reply messages
#OPTIONAL (default false)
QuoteDisable=false
2018-05-11 20:59:15 +02:00
#Format quoted/reply messages
#OPTIONAL (default "{MESSAGE} (re @{QUOTENICK}: {QUOTEMESSAGE})")
QuoteFormat="{MESSAGE} (re @{QUOTENICK}: {QUOTEMESSAGE})"
2017-04-15 19:07:35 +02:00
#Disable sending of edits to other bridges
#OPTIONAL (default false)
EditDisable=false
#Message to be appended to every edited message
#OPTIONAL (default empty)
EditSuffix=" (edited)"
2016-11-20 17:01:53 +01:00
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2016-11-20 17:01:53 +01:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="spammer1 spammer2"
2017-06-18 01:08:11 +02:00
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2016-11-20 17:01:53 +01:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2018-03-17 18:02:00 +01:00
#
#WARNING: if you have set MessageFormat="HTML" be sure that this format matches the guidelines
#on https://core.telegram.org/bots/api#html-style otherwise the message will not go through to
#telegram! eg <{NICK}> should be <{NICK}>
2016-11-20 17:01:53 +01:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
2017-04-07 22:27:36 +02:00
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2016-11-20 17:01:53 +01:00
#OPTIONAL (default false)
ShowJoinPart=false
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2016-12-03 00:10:29 +01:00
2018-02-02 21:04:43 +01:00
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2016-12-03 00:10:29 +01:00
###################################################################
#rocketchat section
###################################################################
[rocketchat]
#You can configure multiple servers "[rocketchat.name]" or "[rocketchat.name2]"
#In this example we use [rocketchat.work]
#REQUIRED
[rocketchat.rockme]
2019-02-10 17:00:11 +01:00
#The rocketchat hostname. (prefix it with http or https)
#REQUIRED (when not using webhooks)
Server="https://yourrocketchatserver.domain.com:443"
#login/pass of your bot.
#Use a dedicated user for this and not your own!
#REQUIRED (when not using webhooks)
Login="yourlogin"
Password="yourpass"
#### Settings for webhook matterbridge.
#USE DEDICATED BOT USER WHEN POSSIBLE! This allows you to use advanced features like message editing/deleting and uploads
#You don't need to configure this, if you have configured the settings
#above.
2016-12-03 00:10:29 +01:00
#Url is your incoming webhook url as specified in rocketchat
#Read #https://rocket.chat/docs/administrator-guides/integrations/#how-to-create-a-new-incoming-webhook
#See administration - integrations - new integration - incoming webhook
#REQUIRED
2017-06-24 19:36:10 +02:00
WebhookURL="https://yourdomain/hooks/yourhookkey"
2016-12-03 00:10:29 +01:00
#Address to listen on for outgoing webhook requests from rocketchat.
#See administration - integrations - new integration - outgoing webhook
#REQUIRED
2017-06-24 19:36:10 +02:00
WebhookBindAddress="0.0.0.0:9999"
2016-12-03 00:10:29 +01:00
#Your nick/username as specified in your incoming webhook "Post as" setting
#REQUIRED
Nick="matterbot"
#Enable this to make a http connection (instead of https) to your rocketchat
#OPTIONAL (default false)
NoTLS=false
#Enable to not verify the certificate on your rocketchat server.
#e.g. when using selfsigned certificates
#OPTIONAL (default false)
SkipTLSVerify=true
2019-02-10 17:00:11 +01:00
#### End settings for webhook matterbridge.
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2016-12-03 00:10:29 +01:00
#Whether to prefix messages from other bridges to rocketchat with the sender's nick.
#Useful if username overrides for incoming webhooks isn't enabled on the
#rocketchat server. If you set PrefixMessagesWithNick to true, each message
#from bridge to rocketchat will by default be prefixed by the RemoteNickFormat setting. i
#OPTIONAL (default false)
PrefixMessagesWithNick=false
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2016-12-03 00:10:29 +01:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="ircspammer1 ircspammer2"
2017-06-18 01:08:11 +02:00
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2016-12-03 00:10:29 +01:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2016-12-03 00:10:29 +01:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
2017-04-07 22:27:36 +02:00
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2016-12-03 00:10:29 +01:00
#OPTIONAL (default false)
ShowJoinPart=false
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2018-02-02 21:04:43 +01:00
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2017-02-20 00:49:27 +01:00
###################################################################
#matrix section
###################################################################
[matrix]
#You can configure multiple servers "[matrix.name]" or "[matrix.name2]"
#In this example we use [matrix.neo]
#REQUIRED
[matrix.neo]
2017-03-14 00:26:05 +01:00
#Server is your homeserver (eg https://matrix.org)
2017-02-20 00:49:27 +01:00
#REQUIRED
2017-03-14 00:26:05 +01:00
Server="https://matrix.org"
2017-02-20 00:49:27 +01:00
#login/pass of your bot.
#Use a dedicated user for this and not your own!
#Messages sent from this user will not be relayed to avoid loops.
#REQUIRED
Login="yourlogin"
Password="yourpass"
2017-05-15 23:11:27 +02:00
#Whether to send the homeserver suffix. eg ":matrix.org" in @username:matrix.org
#to other bridges, or only send "username".(true only sends username)
#OPTIONAL (default false)
NoHomeServerSuffix=false
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2017-02-20 00:49:27 +01:00
#Whether to prefix messages from other bridges to matrix with the sender's nick.
#Useful if username overrides for incoming webhooks isn't enabled on the
#matrix server. If you set PrefixMessagesWithNick to true, each message
#from bridge to matrix will by default be prefixed by the RemoteNickFormat setting. i
#OPTIONAL (default false)
PrefixMessagesWithNick=false
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2017-02-20 00:49:27 +01:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="spammer1 spammer2"
2017-06-18 01:08:11 +02:00
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2017-02-20 00:49:27 +01:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2017-02-20 00:49:27 +01:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
2017-04-07 22:27:36 +02:00
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2017-02-20 00:49:27 +01:00
#OPTIONAL (default false)
ShowJoinPart=false
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2018-02-02 21:04:43 +01:00
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2017-06-22 01:02:05 +02:00
###################################################################
#steam section
###################################################################
[steam]
#You can configure multiple servers "[steam.name]" or "[steam.name2]"
#In this example we use [steam.gamechat]
#REQUIRED
2017-06-22 01:10:15 +02:00
[steam.gamechat]
2017-06-22 01:02:05 +02:00
#login/pass of your bot.
#Use a dedicated user for this and not your own account!
#REQUIRED
Login="yourlogin"
Password="yourpass"
#steamguard mail authcode (not the 2FA code)
#OPTIONAL
Authcode="ABCE12"
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2017-06-22 01:02:05 +02:00
#Whether to prefix messages from other bridges to matrix with the sender's nick.
#Useful if username overrides for incoming webhooks isn't enabled on the
#matrix server. If you set PrefixMessagesWithNick to true, each message
#from bridge to matrix will by default be prefixed by the RemoteNickFormat setting. i
#OPTIONAL (default false)
PrefixMessagesWithNick=false
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2017-06-22 01:02:05 +02:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="spammer1 spammer2"
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
2017-11-24 23:45:00 +01:00
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2017-06-22 01:02:05 +02:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2017-06-22 01:02:05 +02:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
#Enable to show users joins/parts from other bridges
2018-02-02 21:04:43 +01:00
#Currently works for messages from the following bridges: irc, mattermost, slack
2017-06-22 01:02:05 +02:00
#OPTIONAL (default false)
ShowJoinPart=false
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2017-02-20 00:49:27 +01:00
2018-02-02 21:04:43 +01:00
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2018-05-07 21:35:48 +02:00
###################################################################
#zulip section
###################################################################
[zulip]
#You can configure multiple servers "[zulip.name]" or "[zulip.name2]"
#In this example we use [zulip.streamchat]
#REQUIRED
[zulip.streamchat]
#Token to connect with zulip API (called bot API key in Settings - Your bots)
#REQUIRED
Token="Yourtokenhere"
#Username of the bot, normally called yourbot-bot@yourserver.zulipchat.com
#See username in Settings - Your bots
#REQUIRED
Login="yourbot-bot@yourserver.zulipchat.com"
#Servername of your zulip instance
#REQUIRED
Server="https://yourserver.zulipchat.com"
#Topic of the messages matterbridge will use
#OPTIONAL (default "matterbridge")
Topic="matterbridge"
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
#Nicks you want to ignore.
2019-02-17 21:49:28 +01:00
#Regular expressions supported
2018-05-07 21:35:48 +02:00
#Messages from those users will not be sent to other bridges.
#OPTIONAL
IgnoreNicks="spammer1 spammer2"
#Messages you want to ignore.
#Messages matching these regexp will be ignored and not sent to other bridges
#See https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (example below ignores messages starting with ~~ or messages containing badword
IgnoreMessages="^~~ badword"
#messages you want to replace.
#it replaces outgoing messages from the bridge.
#so you need to place it by the sending bridge definition.
#regular expressions supported
#some examples:
#this replaces cat => dog and sleep => awake
#replacemessages=[ ["cat","dog"], ["sleep","awake"] ]
#this replaces every number with number. 123 => numbernumbernumber
#replacemessages=[ ["[0-9]","number"] ]
#optional (default empty)
ReplaceMessages=[ ["cat","dog"] ]
#nicks you want to replace.
#see replacemessages for syntaxa
#optional (default empty)
ReplaceNicks=[ ["user--","user"] ]
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2018-05-07 21:35:48 +02:00
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
#Enable to show users joins/parts from other bridges
#Currently works for messages from the following bridges: irc, mattermost, slack
#OPTIONAL (default false)
ShowJoinPart=false
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
#Enable to show topic changes from other bridges
#Only works hiding/show topic changes from slack bridge for now
#OPTIONAL (default false)
ShowTopicChange=false
2017-02-18 23:10:22 +01:00
###################################################################
#API
###################################################################
[api]
#You can configure multiple API hooks
#In this example we use [api.local]
#REQUIRED
[api.local]
#Address to listen on for API
#REQUIRED
BindAddress="127.0.0.1:4242"
#Amount of messages to keep in memory
2018-11-06 04:53:51 +08:00
#OPTIONAL (library default 10)
2017-02-18 23:10:22 +01:00
Buffer=1000
2017-06-06 00:05:32 +02:00
#Bearer token used for authentication
#curl -H "Authorization: Bearer token" http://localhost:4242/api/messages
#OPTIONAL (no authorization if token is empty)
Token="mytoken"
2018-02-20 18:57:46 +01:00
#extra label that can be used in the RemoteNickFormat
#optional (default empty)
Label=""
2017-02-18 23:10:22 +01:00
#RemoteNickFormat defines how remote users appear on this bridge
2018-10-24 03:53:11 +08:00
#See [general] config section for default options
2017-02-18 23:10:22 +01:00
RemoteNickFormat="{NICK}"
2016-12-03 00:10:29 +01:00
2017-06-06 00:05:32 +02:00
2016-11-20 23:33:41 +01:00
###################################################################
#General configuration
###################################################################
2017-10-20 14:58:39 -04:00
# Settings here are defaults that each protocol can override
2016-11-20 23:33:41 +01:00
[general]
2018-05-01 22:23:37 +02:00
## RELOADABLE SETTINGS
## Settings below can be reloaded by editing the file
2016-11-20 23:33:41 +01:00
#RemoteNickFormat defines how remote users appear on this bridge
#The string "{NICK}" (case sensitive) will be replaced by the actual nick / username.
#The string "{BRIDGE}" (case sensitive) will be replaced by the sending bridge
2018-02-20 18:57:46 +01:00
#The string "{LABEL}" (case sensitive) will be replaced by label= field of the sending bridge
2016-11-20 23:33:41 +01:00
#The string "{PROTOCOL}" (case sensitive) will be replaced by the protocol used by the bridge
2018-10-24 03:53:11 +08:00
#The string "{GATEWAY}" (case sensitive) will be replaced by the origin gateway name that is replicating the message.
#The string "{CHANNEL}" (case sensitive) will be replaced by the origin channel name used by the bridge
2016-11-20 23:33:41 +01:00
#OPTIONAL (default empty)
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
2017-10-27 00:07:33 +02:00
#StripNick only allows alphanumerical nicks. See https://github.com/42wim/matterbridge/issues/285
#It will strip other characters from the nick
#OPTIONAL (default false)
StripNick=false
2017-11-24 23:35:25 +01:00
2018-06-08 22:30:35 +02:00
#MediaServerUpload (or MediaDownloadPath) and MediaServerDownload are used for uploading
#images/files/video to a remote "mediaserver" (a webserver like caddy for example).
#When configured images/files uploaded on bridges like mattermost, slack, telegram will be
#downloaded and uploaded again to MediaServerUpload URL
#MediaDownloadPath is the filesystem path where the media file will be placed, instead of uploaded,
#for if Matterbridge has write access to the directory your webserver is serving.
#It is an alternative to MediaServerUpload.
2017-11-24 23:35:25 +01:00
#The MediaServerDownload will be used so that bridges without native uploading support:
#gitter, irc and xmpp will be shown links to the files on MediaServerDownload
#
#More information https://github.com/42wim/matterbridge/wiki/Mediaserver-setup-%5Badvanced%5D
#OPTIONAL (default empty)
MediaServerUpload="https://user:pass@yourserver.com/upload"
#OPTIONAL (default empty)
2018-06-08 22:30:35 +02:00
MediaDownloadPath="/srv/http/yourserver.com/public/download"
#OPTIONAL (default empty)
2017-11-24 23:35:25 +01:00
MediaServerDownload="https://youserver.com/download"
2017-12-19 23:44:13 +01:00
#MediaDownloadSize is the maximum size of attachments, videos, images
#matterbridge will download and upload this file to bridges that also support uploading files.
#eg downloading from slack to upload it to mattermost
#
#It will only download from bridges that don't have public links available, which are for the moment
2018-02-02 20:23:55 +01:00
#slack, telegram, matrix and mattermost
2017-12-19 23:44:13 +01:00
#
2018-06-09 14:35:02 +02:00
#OPTIONAL (default 1000000 (1 megabyte))
2017-12-19 23:44:13 +01:00
MediaDownloadSize=1000000
2017-11-24 23:35:25 +01:00
2018-06-09 14:35:02 +02:00
#MediaDownloadBlacklist allows you to blacklist specific files from being downloaded.
#Filenames matching these regexp will not be download/uploaded to the mediaserver
#You can use regex for this, see https://regex-golang.appspot.com/assets/html/index.html for more regex info
#OPTIONAL (default empty)
MediaDownloadBlacklist=[".html$",".htm$"]
2018-11-25 10:35:35 +01:00
#IgnoreFailureOnStart allows you to ignore failing bridges on startup.
#Matterbridge will disable the failed bridge and continue with the other ones.
#Context: https://github.com/42wim/matterbridge/issues/455
#OPTIONAL (default false)
IgnoreFailureOnStart=false
2016-09-18 21:04:28 +02:00
###################################################################
#Gateway configuration
###################################################################
#You can specify multiple gateways using [[gateway]]
#Each gateway has a [[gateway.in]] and a [[gateway.out]]
#[[gateway.in]] specifies the account and channels we will receive messages from.
#[[gateway.out]] specifies the account and channels we will send the messages
#from [[gateway.in]] to.
#
#Most of the time [[gateway.in]] and [[gateway.out]] are the same if you
2016-11-20 23:01:44 +01:00
#want bidirectional bridging. You can then use [[gateway.inout]]
2016-10-29 17:34:27 +02:00
#
2016-09-18 21:04:28 +02:00
[[gateway]]
2017-04-01 17:24:19 +02:00
#REQUIRED and UNIQUE
2016-09-18 21:04:28 +02:00
name="gateway1"
#Enable enables this gateway
##OPTIONAL (default false)
enable=true
#[[gateway.in]] specifies the account and channels we will receive messages from.
#The following example bridges between mattermost and irc
[[gateway.in]]
#account specified above
#REQUIRED
account="irc.freenode"
#channel to connect on that account
2016-10-23 19:51:31 +02:00
#How to specify them for the different bridges:
#
2017-06-01 21:00:49 +02:00
#irc - #channel (# is required) (this needs to be lowercase!)
2016-10-23 19:51:31 +02:00
#mattermost - channel (the channel name as seen in the URL, not the displayname)
#gitter - username/room
#xmpp - channel
2017-10-20 15:01:11 -04:00
#slack - channel (without the #)
2018-07-13 23:23:11 +02:00
# - ID:C123456 (where C123456 is the channel ID) does not work with webhook
2016-10-23 19:51:31 +02:00
#discord - channel (without the #)
2016-10-29 17:34:27 +02:00
# - ID:123456789 (where 123456789 is the channel ID)
# (https://github.com/42wim/matterbridge/issues/57)
2016-11-20 17:01:53 +01:00
#telegram - chatid (a large negative number, eg -123456789)
2017-01-27 23:36:14 +01:00
# see (https://www.linkedin.com/pulse/telegram-bots-beginners-marco-frau)
2016-11-26 00:40:21 +01:00
#hipchat - id_channel (see https://www.hipchat.com/account/xmpp for the correct channel)
2017-06-15 23:05:59 +02:00
#rocketchat - #channel (# is required (also needed for private channels!)
2017-05-20 22:53:08 +02:00
#matrix - #channel:server (eg #yourchannel:matrix.org)
# - encrypted rooms are not supported in matrix
2017-06-22 01:02:05 +02:00
#steam - chatid (a large number).
# The number in the URL when you click "enter chat room" in the browser
2018-05-07 21:35:48 +02:00
#zulip - stream (without the #)
2017-06-22 01:02:05 +02:00
#
2016-09-18 21:04:28 +02:00
#REQUIRED
channel="#testing"
2018-06-18 22:55:45 +02:00
#OPTIONAL - only used for IRC and XMPP protocols at the moment
2017-01-04 14:10:35 +01:00
[gateway.in.options]
2018-06-18 22:55:45 +02:00
#OPTIONAL - your irc / xmpp channel key
2017-01-04 14:10:35 +01:00
key="yourkey"
2016-09-18 21:04:28 +02:00
2016-11-20 23:01:44 +01:00
#[[gateway.out]] specifies the account and channels we will sent messages to.
2016-09-18 21:04:28 +02:00
[[gateway.out]]
account="irc.freenode"
channel="#testing"
2018-06-18 22:55:45 +02:00
#OPTIONAL - only used for IRC and XMPP protocols at the moment
2017-01-04 14:10:35 +01:00
[gateway.out.options]
2018-06-18 22:55:45 +02:00
#OPTIONAL - your irc / xmpp channel key
2017-01-04 14:10:35 +01:00
key="yourkey"
2016-11-20 23:01:44 +01:00
#[[gateway.inout]] can be used when then channel will be used to receive from
#and send messages to
[[gateway.inout]]
2016-09-18 21:04:28 +02:00
account="mattermost.work"
channel="off-topic"
2016-10-29 17:34:27 +02:00
2018-06-18 22:55:45 +02:00
#OPTIONAL - only used for IRC and XMPP protocols at the moment
2017-01-04 14:10:35 +01:00
[gateway.inout.options]
2018-06-18 22:55:45 +02:00
#OPTIONAL - your irc / xmpp channel key
2017-01-04 14:10:35 +01:00
key="yourkey"
2016-10-29 17:34:27 +02:00
2017-08-12 14:51:41 +02:00
[[gateway.inout]]
account="discord.game"
channel="mygreatgame"
#OPTIONAL - webhookurl only works for discord (it needs a different URL for each cahnnel)
[gateway.inout.options]
2018-11-25 20:37:14 +11:00
webhookurl="https://discordapp.com/api/webhooks/123456789123456789/C9WPqExYWONPDZabcdef-def1434FGFjstasJX9pYht73y"
2017-08-12 14:51:41 +02:00
2017-02-18 23:10:22 +01:00
#API example
#[[gateway.inout]]
#account="api.local"
#channel="api"
#To send data to the api:
2017-06-08 00:03:06 +02:00
#curl -XPOST -H 'Content-Type: application/json' -d '{"text":"test","username":"randomuser","gateway":"gateway1"}' http://localhost:4242/api/message
#To read from the api:
#curl http://localhost:4242/api/messages
2017-02-18 23:10:22 +01:00
2016-10-29 17:34:27 +02:00
#If you want to do a 1:1 mapping between protocols where the channelnames are the same
#e.g. slack and mattermost you can use the samechannelgateway configuration
#the example configuration below send messages from channel testing on mattermost to
#channel testing on slack and vice versa. (and for the channel testing2 and testing3)
[[samechannelgateway]]
2017-04-01 17:24:19 +02:00
name="samechannel1"
2016-10-29 17:34:27 +02:00
enable = false
accounts = [ "mattermost.work","slack.hobby" ]
channels = [ "testing","testing2","testing3"]