Public | Automated Build

Last pushed: 2 years ago
Short Description
"A multi streaming tool for with read only merged chats for platforms like Twitch and Facebook
Full Description


Self hosted simulcasting made easy

<a href=""><img src="" alt="Build Status"></a> <a href=""><img src=""></a> <img src="">

Streamroller is a mutlistream tool that allows you to broadcast your streams (e.g OBS/Xsplit) to multiple platforms such as Twitch, Youtube, and Facebook at once. It also has read only chat to make it easy to vocally respond to your viewers in a single window.

This tool is meant to be hosted remotely to avoid networking issues locally as trying to stream for multiple sources can get quite heavy.




  • [x] Combined chat (read)
  • [ ] Combined chat (write)
  • [x] RTMP cloning
  • [ ] Streamroller stream key protection
  • [ ] RTMPT to RTMP


  • [x] Twitch
  • [x] Facebook Live
  • [x] Youtube
  • [ ] Azubu
  • [ ] Hitbox

Getting Keys/Tokens

Before installing to make the setup simpler, it's best to get all the keys and tokens you'll need from your accounts first. Not every platform is required, only keys and tokens for the platforms you wish to stream to.


OAuth Token:
There's a simple app that safely generates oauth tokens for you found here.

Live/Stream Key:
You can grab your key directly from your twitch dashboard.


Youtube uses a refresh token in order to access chat. As long as streamroller is running (even if you're not streaming), it'll keep the token alive. If it dies, simply repeat the process to generate a new one.

OAuth Token:

  1. Open
  2. Scroll down to "Youtube Data API" and select the first item in the list
  3. Authenticate with the Google account you plan on streaming with.
  4. Click "Generate Token", then copy the "Refresh Token".

Live/Stream Key:

Your key can be found at the bottom of your Youtube Live dashboard here.


Facebook requires you to stream from a Facebook page rather then a personal profile. If you don't already have one, make one first.

You'll also need to create a developer app. Head over too, click "Add a New App", and fill in the blanks. It doesn't matter what you name it, it won't been seen by others.

OAuth Token:

  1. Open
  2. From the Application menu on the top right (the first item is Graph API Explorer), select the app you created previously.
  3. Click "Get Token", and then "Get User Access Token".
  4. Select "manage_pages" from the list and click "Get Access Token".
  5. Click the "i" icon at the beginning of your token and then "Open in Access Token Tool".
  6. Click "Extend Access Token" at the bottom, and copy your newly generated token. Keep note of when it expires.

Live/Stream Key:

A live/stream key for Facebook unfortunately changes every time you create a new Live video. You'll have to update this key each time you stream. You can follow this guide to get your started with streaming to Facebook, it includes generating your Live key.


Docker Cloud

Docker Cloud is users who are atleast somewhat familiar with working on servers. You can follow Docker Cloud's get started guide here, and then afterwards hit the Deploy with Cloud button.


A docker image is available over at Docker Hub. It's suggested to use a tag rather then latest.


Grab the latest release from the releases page, or build from source and install directly from master. Streamroller is currently built and tested against Go 1.7.

Quick install for Linux:

curl -Ls "" | tar xz -C /usr/local/bin/

Build From Source:

A makefile exists to handle all things needed to build and install from source.

git pull
cd streamroller
make install


Configuration can be done either by command line parameters, environment variables, or a JSON file. Please see all available flags with streamroller --help or in the example below.

To set a configuration, you can take the flag name and export it in your environment or save in one of the three locations for config files. If on Heroku or Docker, use the environments examples.

After launch, chat can be found on the index, (e.g http://localhost:8080). And streams can also be submitted to index (e.g rtmp://localhost:8080).


  "twitch-livekey": "", // Twitch live key
  "twitch-username": "", // Twitch Username
  "twitch-oauth": "", // Twitch oauth key

  "facebook-livekey": "", // Facebook live key
  "facebook-token": "", // Facebook auth token

  "youtube-livekey": "", // Youtube live key
  "youtube-token": "", // Youtube oauth refresh token

  "json": false, // Output logs in JSON
  "port": 8080, // Port for server to listen on
  "verbose": false, // Verbose logging



streamroller --twitch-livekey aBc123 facebook-livekey EfG456


All flags/parameters can be used with environment variables by prefixing with SR_, and replacing dashes with underscores.


JSON File:

Configuration files can be stored in one of the three locations

  "twitch-livekey": "aBc123",
  "facebook-livekey": "EfG456"


  • Ethan for the name
  • JDoeDevel for the chat snippet

Related Projects

  • StreamWithFriends - StreamWithFriends allows your friends webcams to appear on your stream all through a web broswer.


Docker Pull Command
Source Repository