5
0
mirror of https://github.com/cwinfo/matterbridge.git synced 2024-12-24 18:25:40 +00:00
bridge between mattermost, IRC, gitter, xmpp, slack, discord, telegram, rocket.chat,hipchat (via xmpp), steam, twitch, ssh-chat, zulip, whatsapp and matrix with REST API (mattermost not required!)
Go to file
Wim 7baf386ede Refactor for more flexibility
* Move from gcfg to toml configuration because gcfg was too restrictive
* Implemented gateway which has support multiple in and out bridges.
* Allow for bridging the same bridges, which means eg you can now bridge between multiple mattermosts.
* Support multiple gateways
2016-09-18 19:21:15 +02:00
bridge Refactor for more flexibility 2016-09-18 19:21:15 +02:00
gateway Refactor for more flexibility 2016-09-18 19:21:15 +02:00
matterclient Fix mattermost API change for UpdateLastViewedAt 2016-09-17 15:33:02 +02:00
matterhook Add Slack support 2016-09-05 16:34:37 +02:00
vendor Refactor for more flexibility 2016-09-18 19:21:15 +02:00
changelog.md Release v0.6.1 2016-09-17 15:34:59 +02:00
Dockerfile Release v0.6.0-beta1 2016-08-20 18:09:00 +02:00
LICENSE Initial commit 2015-10-23 17:07:05 +02:00
matterbridge.conf.sample Update documentation 2016-09-05 16:42:46 +02:00
matterbridge.go Refactor for more flexibility 2016-09-18 19:21:15 +02:00
migration.md Add migration info 2016-07-12 01:23:36 +02:00
README.md Release v0.6.1 2016-09-17 15:34:59 +02:00

matterbridge

Simple bridge between mattermost, IRC, XMPP and Gitter

  • Relays public channel messages between mattermost, IRC, XMPP and Gitter. Pick and mix.
  • Supports multiple channels.
  • Matterbridge -plus also works with private groups on your mattermost.

Look at [matterbridge.conf.sample] (https://github.com/42wim/matterbridge/blob/master/matterbridge.conf.sample) for documentation and an example.

Changelog

Since v0.6.1 support for XMPP, Gitter and Slack is added. More details in [changelog.md] (https://github.com/42wim/matterbridge/blob/master/changelog.md)

Requirements:

Accounts to one of the supported bridges

binaries

Binaries can be found [here] (https://github.com/42wim/matterbridge/releases/)

  • For use with mattermost 3.3.0+ v0.6.1
  • For use with mattermost 3.0.0-3.2.0 v0.5.0

Compatibility

Mattermost

  • Matterbridge v0.6.1 works with mattermost 3.3.0 and higher 3.3.0 release
  • Matterbridge v0.5.0 works with mattermost 3.0.0 - 3.2.0 3.2.0 release

Webhooks version

  • Configured incoming/outgoing webhooks on your mattermost instance.

Plus (API) version

  • A dedicated user(bot) on your mattermost instance.

building

Go 1.6+ is required. Make sure you have Go properly installed, including setting up your [GOPATH] (https://golang.org/doc/code.html#GOPATH)

cd $GOPATH
go get github.com/42wim/matterbridge

You should now have matterbridge binary in the bin directory:

$ ls bin/
matterbridge

running

  1. Copy the matterbridge.conf.sample to matterbridge.conf in the same directory as the matterbridge binary.
  2. Edit matterbridge.conf with the settings for your environment. See below for more config information.
  3. Now you can run matterbridge.
Usage of ./matterbridge:
  -conf string
        config file (default "matterbridge.conf")
  -debug
        enable debug
  -plus
        running using API instead of webhooks (deprecated, set Plus flag in [general] config)
  -version
        show version

config

matterbridge

matterbridge looks for matterbridge.conf in current directory. (use -conf to specify another file)

Look at [matterbridge.conf.sample] (https://github.com/42wim/matterbridge/blob/master/matterbridge.conf.sample) for an example.

mattermost

webhooks version

You'll have to configure the incoming and outgoing webhooks.

  • incoming webhooks Go to "account settings" - integrations - "incoming webhooks".
    Choose a channel at "Add a new incoming webhook", this will create a webhook URL right below.
    This URL should be set in the matterbridge.conf in the [mattermost] section (see above)

  • outgoing webhooks Go to "account settings" - integrations - "outgoing webhooks".
    Choose a channel (the same as the one from incoming webhooks) and fill in the address and port of the server matterbridge will run on.

e.g. http://192.168.1.1:9999 (192.168.1.1:9999 is the BindAddress specified in [mattermost] section of matterbridge.conf)

plus version

You'll have to create a new dedicated user on your mattermost instance. Specify the login and password in [mattermost] section of matterbridge.conf

FAQ

Please look at [matterbridge.conf.sample] (https://github.com/42wim/matterbridge/blob/master/matterbridge.conf.sample) for more information first.

Mattermost doesn't show the IRC nicks

If you're running the webhooks version, this can be fixed by either:

  • enabling "override usernames". See mattermost documentation
  • setting PrefixMessagesWithNick to true in mattermost section of your matterbridge.conf.

If you're running the plus version you'll need to:

  • setting PrefixMessagesWithNick to true in mattermost section of your matterbridge.conf.

Also look at the RemoteNickFormat setting.