/SelfStreamLive-Jitsi

Jitsi Server automatic deploy to a droplet with subdomain and certificate in DigitalOcean by using DigitalOcean API and Ansible. This Server will be served to stream the Participants and Host Event.

Primary LanguageJavaScriptGNU General Public License v3.0GPL-3.0

Jitsi Meet Ansible Playbook

This playbook will install the Jitsi Meet stack in one or more servers. It is developed and tested on Debian 10 Buster. It may work on other Debian releases or Ubuntu, but it has not been tested there.

Before using it you may want to read a bit about Jitsi Meet's arquitecture here or here or aquí (in Spanish)

TODO

  • Create a Custom Deb package for SelfStream.live

  • Fix Ansible Variables not working.

  • Check snd_aloop module not found. (https://github.com/emrahcom/emrah-buster-templates/blob/master/doc/jitsi_cluster.md??) or (https://community.jitsi.org/t/best-easy-method-to-scale-jibri-2-4-recorders/64797/4)

  • Receive EventId as Env-Var and create a Jitsi-Server with this password as token.

  • Remove the screen to create meeting and when exit does not go there.

  • Receive Subdomain as Env-Var and change strings and sub-folder name in host_vars/event-name

  • Create an env-var with ip-address and change ansible-playbook command

  • Create a Custom Jitsi Server with a SelfStream Subdomain passing as parameter.

  • Remove Jitsi watermark

  • Test WebStream from Jitsi

  • API to Monitoring Jitsi Meeting Usage set env var to number of hours and auto-destroy when reach.

  • Create APT repository and change ansible to read from there.

  • Limit the Meeting to 4 participants (maybe not here)

  • Change bitrate from 645kb to 1.5mbs when live stream

  • Configure Automatically Droplet Alerts to CPU and Inbound and Outbound Net https://www.digitalocean.com/docs/monitoring/quickstart/

  • Configure DigitalOcean Firewall

  • Evaluate certificates creation limits on LetsEncrypt ( Error creating new order :: too many certificates already issued for exact set of domains: domingo-milagres-host.selfstream.live: see https://letsencrypt.org/docs/rate-limits) - Not very important as the subdomain will change within the time.

    sudo ufw allow 80/tcp
    sudo ufw allow 443/tcp
    sudo ufw allow 10000/udp
    sudo ufw allow 22/tcp
    sudo ufw allow 3478/udp
    sudo ufw allow 5349/tcp
    sudo ufw enable
    

How do I use it?

Simple clone it and rename the host configuration directories in hosts_vars/ to match your hosts. Also edit group_vars/meet and the hosts file to suit your needs. Further instructions in USAGE.md. If you're using a git repository to hold your configuration, don't forget to use ansible-vault to encrypt sensitive information. That's why the passwords are stored on 0secret.yml files.

You may run everything on one host. Or have separate hosts for videobridges and jibris. If you want to run a videobridge and/or a jibri instance on the central server, just include it in the "[videobridges]" and/or "[jibris]" group.

The meet_domain variable in group_vars/meet should have a DNS entry and point to your "central" server since a Let's Encrypt certificate will be generated during the installation.

Once you've gone through the hosts/variables you may run the playbook with:

    ansible-playbook -i hosts site.yml -e "channelLastN=-1 defaultLanguage=en jicofo_user=focus jicofo_pass=selfstreamlive jicofo_secret=selfstreamlive run_exporter_container=false exporter_xmpp_user=prometheus exporter_xmpp_pass=selfstreamlive videobridge_user=meet videobridge_pass=selfstreamlive videobridge_muc_nick=meet jibri_user=jibri jibri_pass=selfstreamlive jibri_muc_nick=jibri myIpAddress=68.183.139.133"

If your hosts are behind NAT or a firewall, remember to check the ports required to run Jitsi Meet (80,443 TCP and 1000 UDP at least).

User authentication support

This playbook supports three kinds of user authentication, all managed in group_vars/meet/main.yml:

  • None, everyone can join or start a room
  • Token based, so your application can issue tokens that control user access and permissions (moderators). For example using Moodle's token module
  • LDAP based. Well... that.

Both token and LDAP authentication can also allow non-authenticated users in (depending on the allow_guests value).

You may switch from one authentication scheme to another by editing the file previously mentioned and running:

ansible-playbook -i hosts site.yml --tags authconf

What are the system requirements for running Jitsi Meet a jibri instance?

Jibri depends on the ALSA loopback module. If your server is running on a cloud platform, or with a kernel other than Debian's default, make sure you have support for the "snd-aloop" module before running the playbook on it.

For example, on Google Cloud instances, you need to run:

apt install linux-image-amd64
apt purge linux-image-*cloud*
reboot

After that, you may run the playbook.

Final notes

The playbook has some hacks, like using Debian's certbot package instead of downloading it from Jitsi's packages postint or installing openjdk-8 from Stretch, to better deal with some packaging behaviour/configuration in ansible. The Jitsi project is very active nowadays and this playbook will be (hopefully) frequently revisited to adapt to its changes. Please report any issues or send your PRs.

Droplets Sizes API

https://slugs.do-api.dev/

Commands to User-Data Droplet

Updating Droplet

$ apt-get update
$ apt-get -y install sudo
$ sudo apt-get -y upgrade
$ sudo apt-get -y install gnupg
$ sudo apt-get -y install git

Cloning Private SelfStream Jitsi Repo

$ cd ..
$ git clone https://eb60ea0493dbc8963018d274eb6ef3856f69e774@github.com/guilhermeneves/SelfStreamLive-Jitsi.git

Installing Ansible

$ sed -i '$d' /etc/apt/sources.list
$ echo "deb http://ppa.launchpad.net/ansible/ansible/ubuntu trusty main" >> /etc/apt/sources.list
$ sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 93C4A3FD7BB9C367
$ sudo apt-get update
$ sudo apt-get -y install ansible

Digital Ocean Post to create a Droplet

curl --request POST \
  --url https://api.digitalocean.com/v2/droplets \
  --header 'Authorization: Bearer 896ba0377c79ab6276fda8ffc423a66ded35480ab94be700fe2f53f05fb92db5' \
  --header 'Content-Type: application/json' \
  --cookie __cfduid=dd32467e27572b22a4c897e4c2e94906a1611618721 \
  --data '{
  "name": "eventoaovivo.selfstream.live",
  "region": "nyc1",
  "size": "c-4",
  "image": "debian-10-x64",
  "ssh_keys": [
    29297645
  ],
  "backups": false,
  "ipv6": false,
  "user_data": " #cloud-config\nruncmd:\n - apt-get update\n - apt-get -y install sudo\n - sudo apt-get -y upgrade\n - sudo apt-get -y install git\n - sudo apt-get -y install gnupg\n - cd /root\n - git clone https://eb60ea0493dbc8963018d274eb6ef3856f69e774@github.com/guilhermeneves/SelfStreamLive-Jitsi.git\n - sed -i '\''$d'\'' /etc/apt/sources.list\n - echo \"deb http://ppa.launchpad.net/ansible/ansible/ubuntu trusty main\" >> /etc/apt/sources.list\n - sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 93C4A3FD7BB9C367\n - sudo apt-get update\n - sudo apt-get -y install ansible\n - sudo apt-get -y install curl\n - export ipaddress=$(ip a s eth0 | awk '\''/inet / {print$2}'\'' | head -1 | sed -r '\''s/.{3}$//'\'')\n - '\''export response_domain=$(curl --request POST --url https://api.digitalocean.com/v2/domains/selfstream.live/records --header \"Authorization: Bearer 896ba0377c79ab6276fda8ffc423a66ded35480ab94be700fe2f53f05fb92db5\" --cookie __cfduid=dd32467e27572b22a4c897e4c2e94906a1611618721 --data '\'''\''{\"type\": \"A\",\"name\": \"eventoaovivo\",\"data\": \"'\'''\''\"${ipaddress}\"'\'''\''\",\"priority\": null,\"port\": null,\"ttl\": 30, \"weight\": null, \"flags\": null,\"tag\": null}'\'''\'')'\''\n - echo \"contracted_hours=\\\"1\\\"\" >> /etc/environment\n - source /etc/environment\n - export contracted_hours=1\n - sleep 30s\n - cd SelfStreamLive-Jitsi\n - chmod 777 cron-script.sh\n - chmod 777 auto-destroy-scheduler.sh\n - chmod 777 new-cron-job.sh\n - ./new-cron-job.sh\n - sed -i '\''63,63 s/^##*//'\'' /etc/rsyslog.conf\n - apt-get -y install linux-image-amd64\n - echo \"eventId=\\\"ID-EVENTO-123456789\\\"\" >> /etc/environment\n - echo \"responseDomain=\\\"${response_domain}\\\"\" >> /etc/environment\n - source /etc/environment\n - sudo apt-get -y install dpkg-dev\n - mkdir /opt/debs\n - cp /root/SelfStreamLive-Jitsi/jitsi-custom-deb-files/* /opt/debs\n - cd /opt/debs\n - dpkg-scanpackages . /dev/null > Release\n - dpkg-scanpackages . | gzip -c9  > Packages.gz\n - echo \"deb [trusted=yes] file:///opt/debs ./\" >> /etc/apt/sources.list\n - reboot"
}'

Checking Logs for User-Data

cat /var/log/cloud-init-output.log

Validate Cloud-Init Template


cloud-init devel schema --config-file cloud.yaml

YAML Template Example


#cloud-config
runcmd:
- 'curl --request POST --url https://api.digitalocean.com/v2/domains/selfstream.live/records --header "Authorization: Bearer 896ba0377c79ab6276fda8ffc423a66ded35480ab94be700fe2f53f05fb92db5" --cookie __cfduid=dd32467e27572b22a4c897e4c2e94906a1611618721 --data "{\"type\": \"A\","name": "meuevento-hosts","data": "10.0.0.0","priority": null,"port": null,"ttl": 30, "weight": null, "flags": null,"tag": null}"'


Copy Files from Jitsi-Serve

scp -r ~/.ssh/id_rsa root@142.93.242.93:/usr/share/jitsi-meet/images  /c/Development/Personal/LiveStream-Server/Implementation/SelfStreamLive-Jitsi/images

Restarting the Server


systemctl restart prosody
systemctl restart jicofo
systemctl restart jitsi-videobridge2

Building Jitsi from the Source

First Option: https://jitsi.github.io/handbook/docs/dev-guide/dev-guide-web Second Option: https://community.jitsi.org/t/how-to-how-to-build-jitsi-meet-from-source-a-developers-guide/75422/22

sudo apt-get install curl
curl -sL https://deb.nodesource.com/setup_12.x | sudo -E bash -
sudo apt-get install nodejs

Command:

node -v && npm -v
✓ Result Looks Good:

v12.18.3
6.14.6

cd ~
git clone https://github.com/jitsi/jitsi-meet.git
cd ~/jitsi-meet/
npm update && npm install

Do not run these as the root user. Run all commands from a normal user.

cd ~
git clone https://github.com/jitsi/lib-jitsi-meet.git
Edit the package file: vi ~/jitsi-meet/package.json.
Search for and change: "lib-jitsi-meet": "github:jitsi/lib-jitsi-meet" → "lib-jitsi-meet": "file:../lib-jitsi-meet" (Yes, file:../ is correct.)
Next:
cd ~/lib-jitsi-meet
npm update

cd ~/jitsi-meet/
npm install lib-jitsi-meet --force && make

dpkg-buildpackage -A -rfakeroot -us -uc -tc

Building Jitsi using Docker Container

https://alexclaydon.dev/post/2020-10-05-jitsi-meet-deployment