Rocket Chat is a Great Self-Hosted Open Source Communication Platform for Teams and Communities.
You can almost categorize it as a Open Source Self Hosted Slack-like Platform.
Rocket Chat offers features such as:
- Chat Platform
- Live Support Chat
- Video Conference
- Mobile Application
- All the other features listed on their Docs
What we will be doing today:
Today, we will setup Rocket Chat on Docker Swarm.
Once you have the pre-requirements setup, we can move onto the next step.
Using Traefik as the Reverse Proxy:
We will setup Traefik as our Reverse Proxy with Letsencrypt for SSL Termination, do in order to do that, we will need to build our image and push it to your registry of choice:
FROM traefik ADD traefik.toml . EXPOSE 80 EXPOSE 8080 EXPOSE 443
defaultEntryPoints = ["http", "https"] [web] address = ":8080" [entryPoints] [entryPoints.http] address = ":80" [entryPoints.https] address = ":443" [entryPoints.https.tls] [acme] email = "firstname.lastname@example.org" storage = "acme.json" entryPoint = "https" onDemand = false OnHostRule = true [docker] endpoint = "unix:///var/run/docker.sock" domain = "apps.domain.com" watch = true exposedbydefault = false
I personally use gitlab's private registry for my docker images, so I will build and push it to gitlab:
$ docker login registry.gitlab.com $ docker build -t registry.gitlab.com/<user>/<repo>/traefik:latest . $ docker push registry.gitlab.com/<user>/<repo>/traefik:latest
Creating the Traefik Service:
Create the Overlay Network:
$ docker network create appnet --driver overlay
Create the Traefik Service:
$ docker service create \ --name traefik \ --constraint 'node.role==manager' \ --publish 80:80 \ --publish 443:443 \ --publish 8080:8080 \ --mount type=bind,source=/var/run/docker.sock,target=/var/run/docker.sock \ --network appnet \ --with-registry-auth registry.gitlab.com/<user>/<repo>/traefik:latest \ --docker \ --docker.swarmmode \ --docker.domain=apps.domain.com \ --docker.watch \ --logLevel=DEBUG \ --web
Create the Rocket Chat Service:
For the current scenarion we have the following envionment:
- MongoDB URi: "mongodb://mongoadmin:email@example.com:27017/rocketchat?authSource=admin"
- Rocket Chat URL: "https://apps.domain.com"
- Rocket Chat Admin User, Pass, Email
Create the Rocket Chat Service:
$ docker service create \ --name rocketchat \ --replicas 1 \ --network appnet \ --label 'traefik.port=3000' \ --label traefik.frontend.rule="Host:apps.domain.com" \ --env DEPLOY_METHOD=docker \ --env NODE_ENV=production \ --env PORT=3000 \ --env MONGO_URL="mongodb://mongoadmin:firstname.lastname@example.org:27017/rocketchat?authSource=admin" \ --env ROOT_URL=https://aps.domain.com \ --env ADMIN_USERNAME=myadmin \ --env ADMIN_PASS=secret \ --env ADMIN_EMAILemail@example.com \ --env Accounts_AvatarStorePath=/app/uploads \ --secret rocketchat_secret \ rocketchat/rocket.chat
Once your services has reached its desired state, you should be able to access Rocket Chat on the chosen URL.
In order to invite users, make sure to configure your mail settings, which can be found from
Setup a Giphy Bot in Rocket Chat:
A cool integration is to setup a bot that uses the Giphy API to send gifs with your conversations. A setup guide shows you how to get that setup.
Setup a Telegram Bot for Rocket Chat:
Use the Incoming and Outgoing Webhooks to setup a Simple Telegram Bot, a full setup guide shows you how to get that done, which is really cool.
Let's face it, we all love emoji's. Head over to slackemojis and download your favorite emoji's, then head over to Rocket Chat:
Custom Emoji to import them.
Using the API via Python:
In a later post, I will give some example code on how to use Python to use Rocket Chat's API to send messages to Channels and Users, but for now, you can find the documentation for rocket-python here
Feel free to join my RocketChat Server, it's quite fresh, so nothing much is going on in there, but the idea is to share awesome posts, new findings, playing around with its API and knowledge sharing.
I hope this is useful, please leave a comment below if you theres any questions.