Skip to main content
Version: 3.0

Development Guide

Welcome to the BigBlueButton Developer's Guide for BigBlueButton 3.0.

This document gives you an overview of how to set up a development environment for BigBlueButton 3.0.

Before you begin

You first need to set up a BigBlueButton 3.0 server. See the instructions at Install BigBlueButton 3.0.

Overview

Note: BigBlueButton 3.0 is still under development

A BigBlueButton server is built from a number of components that correspond to Ubuntu packages. Some of these components are

  • bbb-web -- Implements the BigBlueButton API and conversion of documents for presentation
  • bbb-akka-apps -- Server side application that handles the state of meetings on the server
  • bbb-akka-fsesl -- server component handling the communication with FreeSWITCH
  • bbb-learning-dashboard -- a live dashboard available to moderators, which displays user activity information that can be useful for instructors
  • bbb-fsesl-akka -- Component to send commands to FreeSWITCH
  • bbb-playback-presentation -- Record and playback script to create presentation layout
  • bbb-playback-video -- Record and playback script to create video layout
  • bbb-export-annotations -- Handles capture of breakout content and annotated presentation download
  • bbb-webrtc-sfu -- Signaling server that bridges clients to FreeSWITCH and mediasoup
  • mediasoup -- WebRTC media server for sending/receiving/recording video (webcam and screenshare)
  • bbb-freeswitch-core -- WebRTC media server for sending/receiving/recording audio
  • bbb-graphql-server -- Handles GraphQL queries and subscriptions from clients, checks user permissions
  • bbb-graphql-middleware -- forwards messages between the clients and bbb-graphql-server, json-patch minimizes the info needed to be sent
  • bbb-graphql-actions -- handles requests from the clients on their way to the core
  • bbb-webrtc-sfu -- manages media connections
  • bbb-webrtc-recorder -- handles recording of the media
  • bbb-pads -- manages the control to Etherpad
  • bbb-transcription-controller -- an optional component managing captions for third party services like VOSK or Gladia
  • bbb-etherpad -- used for shared notes and captions, live edit of text by multiple parties
  • bbb-webhooks -- an optional componen, listens for all events on BigBlueButton and sends POST requests with details about these events to hooks registered via an API

This document describes how to set up a development environment using an existing BigBlueButton 3.0 server. Once the environment is set up, you will be able to make custom changes to BigBlueButton source code, compile it, and replace the corresponding components on the server (such as updating the BigBlueButton client).

The instructions in this guide are step-by-step so you can understand each step needed to modify a component. If you encounter problems or errors at any section, don't ignore the errors. Stop and double-check that you have done the step correctly. If you are unable to determine the cause of the error, do the following

  • First, use Google to search for the error. There is a wealth of information in bigbluebutton-dev that has been indexed by Google.
  • Try doing the same steps on a different BigBlueButton server.
  • Post a question to bigbluebutton-dev with a description of the problem and the steps to reproduce. Post logs and error messages to Pastebin link them in your post.

You Have a Working BigBlueButton Server

Before you can start developing on BigBlueButton, you must install BigBlueButton (see installation steps) and ensure it's working correctly. Make sure there were no errors during the installation and that you can join a session successfully.

We emphasize that your BigBlueButton server must be working before you start setting up the development environment. Be sure that you can log in, start sessions, join the audio bridge, share your webcam, and record and play back sessions -- you can verify this if you install Greenlight or navigate to API MATE using your server's secret and url (just run the command bbb-conf --salt to obtain a link for API MATE).

By starting with a working BigBlueButton server, you have the ability to switch back-and-forth between the default-packaged components and any modifications you make.

For example, suppose you modify the BigBlueButton client and something isn't working (such as the client is not fully loading), you can easily switch back to the default-packaged client and check that it's working correctly (thus ruling out any environment issues that may also be preventing your modified client from loading).

Another Note: These instructions assume you have Greenlight installed so you can create and join meetings to test your setup. Alternatively you can use API MATE (just run the command bbb-conf --salt to obtain a link for API MATE).

Developing on Windows

To develop BigBlueButton from within Windows, you have two options:

  • use Windows Subsystem for Linux
  • use VMWare Player or VirtualBox to create a virtual machine (VM).

Choose the OS to be Ubuntu 22.04 64-bit. The associated documentation for VMWare Player and VirtualBox or WSL will guide you on setting up a new 22.04 64-bit VM.

Note: When setting up the VM, it does not matter to BigBlueButton if you set up Ubuntu 22.04 server or desktop. If you install desktop, you'll have the option of using a graphical interface to edit files. When running the VM, you will need a host operating system capable of running a 64-bit virtual machine.

Developing on Linux host via container

Consider using a Docker setup for a development environment - https://github.com/bigbluebutton/docker-dev. This is the way most of the core developers follow.

Root Privileges

Important: The setup is much easier if you develop as user 'bigbluebutton' and just add a home directory via

usermod -a -G sudo bigbluebutton
mkhomedir_helper bigbluebutton # to add homedir to existing user
chown -R bigbluebutton:bigbluebutton /home/bigbluebutton/
sudo su - bigbluebutton
# if you cannot switch to user bigbluebutton, you may need to switch /bin/false to /bin/bash for user bigbluebutton in /etc/passwd
# and then retry "sudo su - bigbluebutton"
# Note that you may want to disable terminal sessions for user bigbluebutton if you will later use the server in production
sudo ls

wget

You'll need to download some files throughout these instructions using wget. If it's not installed on your server, you can install the package using the following command

sudo apt-get install wget

Have a GitHub Account

The BigBlueButton source is hosted on GitHub. You need a GitHub account. In addition, you need to be very familiar with how git works. Specifically, you need to know how to

  • clone a repository
  • create a branch
  • push changes back to a repository

If you have not used git before, or if the terms clone, branch, and commit are unfamiliar to you, stop now. These are fundamental concepts to git that you need to become competent with before trying to develop on BigBlueButton. To become competent, a good place to start is this free book and GitHub Help pages.

Using GitHub makes it easy for you to work on your own copy of the BigBlueButton source, store your updates to the source to your GitHub account, and make it easy for you to contribute to BigBlueButton.

Subscribe to bigbluebutton-dev

We recommend you subscribe to the bigbluebutton-dev mailing list to follow updates to the development of BigBlueButton and to collaborate with other developers. Make sure to include a brief note when you request access so we can distinguish you from spam bots.

Set up a Development Environment

Consider using a Docker setup for a development environment - https://github.com/bigbluebutton/docker-dev It includes all you need to be able to run a local BigBlueButton development environment

Alternative - add a development environment to a [locally running] working BigBlueButton server

First, you need to install the core development tools.

sudo apt-get install git-core openjdk-17-jdk-headless

With the JDK installed, you need to set the JAVA_HOME variable. Edit ~/.profile (here we are using vim to edit the file)

vi ~/.profile

Add the following line at the end of the file

export JAVA_HOME=/usr/lib/jvm/java-17-openjdk-amd64

Reload your profile (this will happen automatically when you next login, but we'll do it explicitly here to load the new environment variable).

source ~/.profile

Do a quick test to ensure JAVA_HOME is set.

$ echo $JAVA_HOME
/usr/lib/jvm/java-17-openjdk-amd64

In the next step, you need to install a number of tools using sdkman.

curl -s "https://get.sdkman.io" | bash
source "$HOME/.sdkman/bin/sdkman-init.sh"

sdk install gradle 7.3.1
sdk install grails 5.3.2
sdk install sbt 1.6.2
sdk install maven 3.5.0

Checking out the Source

With the development tools installed, we'll next clone the source in the following directory:

/home/bigbluebutton/dev

Using your GitHub account, do the following

  1. Fork the BigBlueButton repository into your GitHub account
  2. Clone your repository into your ~/dev folder

After cloning, you'll have the following directory (make sure the bigbluebutton directory is within your dev directory).

/home/bigbluebutton/dev/bigbluebutton

Confirm that you are working on the v3.0.x-release branch.

cd /home/bigbluebutton/dev/bigbluebutton
git status

BigBlueButton 3.0 source code lives on branch v3.0.x-release. This is where any patches to 3.0 will be merged. If you are looking to customize your BigBlueButton 3.0 clone to fit your needs, this is the branch to use.

For the purpose of these instructions we'll assume you are only tweaking your clone of BigBlueButton. Thus we recommend you checkout branch v3.0.x-release.

On branch v3.0.x-release
Your branch is up-to-date with 'origin/v3.0.x-release'.
nothing to commit, working directory clean

The first thing we need to do is to add the remote repository to our local clone.

git remote add upstream https://github.com/bigbluebutton/bigbluebutton.git

You can now check your local list of tracked repositories to verify that the addition worked. You should see at least two results (origin and upstream). The one named "origin" should link to your personal fork and is the repository that you cloned. The second result "upstream" should link to the main BigBlueButton repository.

git remote -v

After, we need to fetch the most up to date version of the remote repository.

git fetch upstream

You are now ready to create a new branch to start your work and base the v3.0.x-release release branch

git checkout -b my-changes-branch upstream/v3.0.x-release

"checkout" switches branches

"-b" is an option to create a new branch before switching

"my-changes-branch" will be the name of the new branch

"upstream/v3.0.x-release" is where you want to start your new branch

You should now confirm that you are in the correct branch.

git status

# On branch my-changes-branch
nothing to commit (working directory clean)

(Optional) Install Greenlight

Note that at this point we recommend installing and using Greenlight or using API-MATE (link can be found when you run $ bbb-conf --salt).

You can access https://BBB_DOMAIN , and you will be able to join meetings.

Developing the HTML5 client

Before starting development on the HTML5 client, make sure you have cloned the BigBlueButton repository and switched to the bigbluebutton-html5 directory:

$ git clone git@github.com:bigbluebutton/bigbluebutton.git
$ cd bigbluebutton/bigbluebutton-html5/

Background

The HTML5 client has seen several major refactors. As of BigBlueButton 3.0 the client code is served directly by NginX, removing several component dependencies we used to have. Make sure to check the HTML5 portion of the Architecture page.

There is one change required to settings.yml to get webcam and screenshare working in the client (assuming you're using HTTPS already). The first step is to find the value for kurento.wsUrl packaged settings.yml.

grep "wsUrl" /var/bigbluebutton/html5-client/private/config/settings.yml

Next, override the wsURL so that it remains the same even if you switch branches:

HOST=$(grep -v '#' /etc/bigbluebutton/bbb-web.properties | sed -n '/^bigbluebutton.web.serverURL/{s/.*\///;p}')
sudo yq e -i ".public.kurento.wsUrl = \"wss://$HOST/bbb-webrtc-sfu\"" /etc/bigbluebutton/bbb-html5.yml
sudo bbb-conf --restart

Install the npm dependencies.

$ npm install

Finally, run the HTML5 code and have it served.

$ npm start

The last couple of steps could alternatively be done with the run-dev.sh script (running in developer mode) or deploy.sh to run in production mode and have the client files served by NginX.

Audio configuration for development environment

You may see the error "Call timeout (Error 1006)" during the microphone echo test after starting the developing HTML5 client by "npm start". A misconfiguration of Freeswitch may account for it, especially when BigBlueButton is set up with bbb-install.sh script. Try changing "sipjsHackViaWs" true in bigbluebutton-html5/private/config/settings.yml.

/private/config

All configurations are located in /private/config/settings.yml. Starting with BigBlueButton 3.0 this file is actually picked by bbb-apps-akka and the settings are passed to the clients. Note that individual configuration settings are overridden with their values (if defined) from file /etc/bigbluebutton/bbb-html5.yml (if the file exists).

Build bbb-common-message

The bbb-common-message is required by a few components of BigBlueButton. So it is required to build this first. Otherwise, you will run into compile errors.

cd ~/dev/bigbluebutton/bbb-common-message
./deploy.sh

Developing BBB-Web

Give your user account access to upload slides to the presentation directory and also access to write log files.

sudo chmod -R ugo+rwx /var/bigbluebutton
sudo chmod -R ugo+rwx /var/log/bigbluebutton

Open the file ~/.sbt/1.0/global.sbt using your editor

mkdir -p ~/.sbt/1.0
vi ~/.sbt/1.0/global.sbt

Add the following into it

resolvers += "Artima Maven Repository" at "https://repo.artima.com/releases"
updateOptions := updateOptions.value.withCachedResolution(true)

Build bbb-common-web

cd ~/dev/bigbluebutton/bbb-common-web
./deploy.sh

Now let's start building bbb-web

cd ~/dev/bigbluebutton/bigbluebutton-web/

We need to stop the bbb-web service

sudo service bbb-web stop

Download the necessary libraries.

./build.sh

Start grails and tell to listen on port 8090

./run.sh

or

grails -reloading -Dserver.port=8090 run-app

If you get an error Could not resolve placeholder 'apiVersion', just run grails -Dserver.port=8090 run-app again. The error is grails not picking up the "bigbluebutton.properties" the first time.

Now test again if you can create and join a meeting.

The command above will run a development version of bbb-web, but if you want to deploy your custom-built bbb-web you need to package a war file.

Instructions for deploying bbb-web

First we need to compile all the project in a single war file.

grails assemble

The war application is generated under build/libs/bigbluebutton-0.10.0.war.

Create a new directory and open it.

mkdir exploded && cd exploded

Extract the war content in the newly create directory

jar -xvf ../build/libs/bigbluebutton-0.10.0.war

Then copy the run-prod.sh after checking all the jar dependencies are listed in

cp ../run-prod.sh .

In the next step we will make a copy of the current production directory for bbb-web

sudo cp -R /usr/share/bbb-web /usr/share/bbb-web-old

Then we will delete all the files we need to be copied for production

sudo rm -rf /usr/share/bbb-web/assets/ /usr/share/bbb-web/META-INF/ /usr/share/bbb-web/org/ /usr/share/bbb-web/run-prod.sh  /usr/share/bbb-web/WEB-INF/

Next, let's copy the complied files into the production directory

sudo cp -R . /usr/share/bbb-web/

Make sure the copied files have the right user ownership.

$ sudo chown bigbluebutton:bigbluebutton /usr/share/bbb-web
$ sudo chown -R bigbluebutton:bigbluebutton /usr/share/bbb-web/assets/ /usr/share/bbb-web/META-INF/ /usr/share/bbb-web/org/ /usr/share/bbb-web/run-prod.sh /usr/share/bbb-web/WEB-INF/

And finally we run the service.

sudo service bbb-web start

If you need to revert back your original production bbb-web just run the following command. (Don't forget to stop bbb-web service before doing it)

sudo mv /usr/share/bbb-web /usr/share/bbb-web-dev && sudo mv /usr/share/bbb-web-old /usr/share/bbb-web

Your compiled code will be under the /usr/share/bbb-web-dev directory and you can safely run the original production ``bbb-web`.

Developing Akka-Apps

You can manually run the application.

cd ~/dev/bigbluebutton/akka-bbb-apps
./run.sh

Don't forget to modify service-bbbWebAPI, service-sharedSecret in ~/dev/bigbluebutton/akka-bbb-apps/src/universal/conf/application.conf, to get it work properly. For instance, these are necessary for starting the breakout rooms.

You can deploy locally akka-apps by building a simple .deb package using sbt and deploying it right away:

sbt debian:packageBin
dpkg -i ./target/bbb-apps-akka_<tab>.deb

Developing Akka-FSESL

You need to build the FS ESL library

cd ~/dev/bigbluebutton/bbb-fsesl-client
./deploy.sh

Then you can run the application.

cd ~/dev/bigbluebutton/akka-bbb-fsesl
./run.sh

You can deploy locally akka-fsesl by building a simple .deb package using sbt and deploying it right away:

sbt debian:packageBin
dpkg -i ./target/bbb-fsesl-akka_<tab>.deb

Developing bbb-export-annotations

You can manually run the service. When running, it'll process export jobs stored in Redis containing the state of the whiteboard at the time of the request.

First, stop the component so that you're not running two copies in parallel:

sudo systemctl stop bbb-export-annotations

To install the npm dependencies, run:

cd ~/dev/bigbluebutton/bbb-export-annotations
npm install

followed by

npm start

to begin exporting presentations with annotations. If you run into permission issues, change presAnnDropboxDir in config/settings.json to a folder in your home directory and make sure your user account has access to the presentation directory (see "Developing BBB-Web").

Use journalctl -u bbb-export-annotations -e to see recent logs.

Troubleshooting

Welcome to NGINX page

If you get the "Welcome to NGINX" page. Check if bigbluebutton is enabled in nginx. You should see bigbluebutton in /etc/nginx/sites-enabled.

If not, enable it.

sudo ln -s /etc/nginx/sites-available/bigbluebutton /etc/nginx/sites-enabled/bigbluebutton

sudo /etc/init.d/nginx restart

Pausing/Restarting VM gives wrong date in commit

If you are developing using a VM and you've paused the VM and later restart it, the time on the VM will be incorrect. The incorrect time will affect any commits you do in GitHub.

To ensure your VM has the correct time, you can install ntp with

sudo apt-get install ntp
sudo /etc/init.d/ntp restart

and then do the following after starting the VM from a paused state

sudo /etc/init.d/ntp restart

The above will re-sync your clock.

Resolving Conflicts Between Java Versions

In situations where multiple versions of Java are installed, BBB components may encounter build errors. One such error message could state, for example, that '17' is not a valid choice for '-release'. This specific error arises when the bbb-common-message component requires Java 17 for its operation, but the sbt build tool is using Java 11 instead.

To address this, you need to set the appropriate Java version. The following command will set Java 17 as the active version:

update-java-alternatives -s java-1.17.0-openjdk-amd64

By executing this command, the system is instructed to use Java 17, i.e., the version with which BBB is currently compatible.

Set up HTTPS

See the installation instructions on how to configure ssl on your BigBlueButton server.