Using Matterbridge

The following is based on a tutorial to use Matterbridge with the plugin: Matterbridge + Peertube

Requirements

The easiest is if the PeerTube instance and Matterbridge run on the same server.

Internal connections only (basic)

You will need to enable Activar les connexions client-servidor in the livechat plugin settings.

This will allow localhost XMPP clients to connect to the Prosody XMPP server.

You may need to add some line to your /etc/hosts:

127.0.0.1       anon.example.org room.example.org

Replace example.org by your actual instance domain name. Afterwards you can continue with the Matterbridge configuration below.

Allow external connections (advanced)

By default, the internal Prosody XMPP server only listens on localhost (127.0.0.1).

On livechat versions >= 10.1.0 a new option call Client to server network interfaces was added to allow changing this.

It allows to add a list of IPs to listen on, coma separated (spaces will be stripped).

You can also use * to listen on all IPv4 interfaces, and :: for all IPv6. Doing so allows external access to the client to server interface.

Then you need to open the C2S port (by default 52822, but check the plugin settings to get the current value) in your firewall so that it can be reached from the internet. If you don’t want to use C2S connections for anything else than your Matterbridge service, you should restrict access to this port to your Matterbridge server IP.

You also need to add DNS records (A and AAAA) for anon.example.org and room.example.org (replace example.org by your actual domain name).

In case you are using a port other than 5222 (XMPP standard port) you also need to set the xmpp-client SRV record to the correct port.

Configurating Matterbridge

In the version 1.22.4, Matterbridge added support for XMPP anonymous connections needed to connect to the built-in prosody.

So in the TOML config file put:

[xmpp.mypeertube]
Anonymous=true
Server="anon.example.org:52822"
Muc="room.example.org"
Nick="Matterbridge"
RemoteNickFormat="[{PROTOCOL}] <{NICK}> "
NoTLS=true
  • Replace example.org by your actual instance domain name.
  • Replace 52822 by the actual port if you changed it.
  • mypeertube can be replaced by another name.
  • Using peertube as the Nick will provide put PeerTube icon for overlay messages, can be also done with overlay config modification.
  • The setting NoTLS=true allows connecting to a server with self-signed certificates.

Now you can add this account to gateways and bridge specific live-chat channels.

Info

This documentation use an anonymous account to connect the bridge to the chat. But since the livechat v10.1.0, there is a new way to generate long term authentication token, that allows to connect using your account. This is used for OBS docks. Using this feature for other purposes is not documented and not officially supported yet. If you want to use it anyway, you can request a token by calling then /plugins/livechat/router/api/auth/tokens endpoint. To get needed headers and request body, just check what happens when you generate a new token for OBS docks.