Ansible role to install BigBlueButton web conferencing platform with SSL support out of the box using LetsEncrypt.
The role follows BigBlueButton official installation instructions.
Forked from softwaremill/ansible-bigbluebutton, as it seems abandoned. Itr has the following additional features:
- Installs latest stable version (currently 2.2).
- Installation behind a firewall (NAT setup support)
- Automatic SSL configuration using LetsEncrypt certificates using thefinn93/ansible-letsencrypt role.
- Optionally installs the demo and check packages.
As this role follows the official installation instructions, the supported OS version is the one specified there: Ubuntu (16.04 for the current bbb version).
Requires Ansible >= 2.4.0
To get up BigBlueButton up and running the following variables can be configured:
bbb_server_names
: Set the list of FQDN hostnames that point to the server where BigBlueButton is going to be installed. If only a single FQDN is required,bbb_server_name
can be used instead. Setting either one of these is the only mandatory value, the playbook will fail if neither variable is defined.bbb_configure_firewall
: Configure local UFW firewall on server (Default:True
).bbb_configure_nat
: Configure NAT support for servers behind an external firewall (Default:False
).bbb_configure_ssl
: Configure SSL support using LetsEncrypt certificates (Default:False
).bbb_ssl_email
: Set LetsEncrypt authorization email address.bbb_install_html5
: Install the HTML5 client (Default:True
).bbb_install_demo
: Install the bbb-demo package, useful to easily test the new installation is working (Default:False
).bbb_install_check
: Install the bbb-check package, useful to debug the new installation if having issues (Default:False
).bbb_install_playback_notes
: Install the bbb-playback-notes package to play back shared notes from a recorded session (Default:True
).bbb_install_playback_podcast
: Install the bbb-playback-podcast package to play back audio from a recorded session (Default:True
).bbb_install_playback_screenshare
: Install the bbb-playback-screenshare package to play back shared screens from a recorded session (Default:True
).bbb_install_webhooks
: Install the bbb-webhooks package, useful to integrate bbb into other web applications (Default:True
).bbb_install_greenlight
: Install the Greenlight frontend (Default:False
)
To configure optional SIP dial-in, define a dict bbb_sip_providers
(Default: unset) to supply information about each SIP provider. Each key in the dict
corresponds to a provider config. Its value is another dict where each key maps to a parameter of the same name in the BBB SIP configuration. At least
username
, password
(for the SIP credentials), proxy
(FQDN of the SIP gateway), and extension (dial-in number) have to be set. The default dial-in
number for display in human-readable format should be supplied in bbb_sip_default_dialin
. A verbose dial-in message can be supplied in
bbb_sip_welcome_footer
(defaults to the message example given in the BBB SIP documentation).
In order to deploy a basic setup of the Greenlight frontend alongside BigBlueButton, the following variables can be set:
bbb_greenlight_image
: Docker image to run for Greenlight (Default:bigbluebutton/greenlight:v2
)bbb_greenlight_etcdir
: Path to configuration directory (Default:/etc/bigbluebutton/greenlight
)bbb_greenlight_libdir
: Path to working directory (Default:/var/lib/greenlight
)bbb_greenlight_dbdir
: Path to database directory (Default: Subdirectoryproduction
belowbbb_greenlight_libdir
)bbb_greenlight_logdir
: Path to log directory (Default:/var/log/greenlight
)bbb_greenlight_redirect_root
: Whether to add a redirection from the domain root URL to Greenlight (Default:false
)bbb_greenlight_db_adapter
: Database type to use (sqlite3
orpostgresql
, default:postgresql
)bbb_greenlight_db_host
: Name of database host. Forpostgresql
adapter, special namedb
will spawn database in a separate container (Default:db
)bbb_greenlight_db_username
: User name for database connection (Default:postgres
)bbb_greenlight_db_name
: Name of Greenlight database (Default:greenlight_production
)bbb_greenlight_db_port
: Host port for database connection (Default:5432
)bbb_greenlight_environment
: Dictionary of additional Greenlight environment variables (Default: empty)
---
- hosts: bbb
remote_user: ansible
become: True
become_user: root
become_method: sudo
gather_facts: True
roles:
- role: ansible-bigbluebutton
bbb_server_name: bbb.example.com
bbb_configure_nat: True
bbb_install_demo: True
bbb_install_check: True
bbb_configure_ssl: True
bbb_ssl_email: foo@bar.com
bbb_sip_default_dialin: "+613-555-1234"
bbb_sip_welcome_footer: "<br/><br/>dial %%DIALNUM%%, then enter %%CONFNUM%% as conference PIN."
bbb_sip_providers:
sipprovider1:
username: "123456789"
password: "topsecret"
extension: "6135551234"
proxy: sip.example.com
register: "true"
context: "public"
sipprovider2:
username: "11114444"
password: "changeme"
extension: "8005554321"
proxy: sip.example.org
register: "true"
context: "public"