This is a fork from the great https://github.com/mconf/bigbluebot. It is adjusted to support testing not a single BBB server but a scalelite instance.
BigBlueButton bots
A BigBlueButton's server and API's secret
IMPORTANT: do not run this lib with root
privileges
IMPORTANT: only works for english chromes and bbb version 2.3 since the language files were hardcoded
npm i git+https://github.com/jonnyfux/bigbluebot.git
cp node_modules/bigbluebot/.env.template .env
At the .env
file you just copied, set:
- your BigBlueButton server URL
BIGBLUEBOT_HOST=https://your.bigbluebutton.server (e.g. https://scalelite.hostname.com/bigbluebutton/api/join? )
- your BigBlueButton server API secret
BIGBLUEBOT_SECRET=yourbigbluebuttonsecret
- your BigBlueButton server running version (currently 2.2 or 2.3)
BIGBLUEBOT_VERSION=2.2
- [optional] room name or meetingID
BIGBLUEBOT_ROOM=yourbigbluebuttonroomidentifier
If you would like the bots to join an existing room, you may fill
out the password variables and use the meetingID
value as BIGBLUEBOT_ROOM
To find out these data, you may call the getMeetings
route of your BBB
instance as described here.
- [optional] the
attendeePW
andmoderatorPW
as shown in getMeetings
BIGBLUEBOT_ATTENDEE_PW=yourattendeepassword
BIGBLUEBOT_MODERATOR_PW=yourmoderatorpassword
- [optional] number of bots to join the room
BIGBLUEBOT_BOTS=1
- [optional] time (milliseconds) between bots to join
BIGBLUEBOT_WAIT=2000
- [optional] time (milliseconds) of a bot life span
BIGBLUEBOT_LIFE=60000
- [optional] external browser to be used
BIGBLUEBOT_BROWSER=/path/to/your/browser
- [optional] endpoint browser websocket to be used
BIGBLUEBOT_ENDPOINT=wss://your.browser.websocket
- [optional] endpoint authentication token
BIGBLUEBOT_TOKEN=yourauthenticationtoken
- [optional] log level
BIGBLUEBOT_LOG=info
- [optional] Ignore HTTPS errors during navigation
BIGBLUEBOT_IGNORE_HTTPS_ERRORS=false
Create your script, e.g. run.js
:
Join audio with microphone
const bigbluebot = require('bigbluebot');
const actions = async page => {
await bigbluebot.audio.modal.microphone(page);
};
bigbluebot.run(actions);
Join audio as a listener
const bigbluebot = require('bigbluebot');
const actions = async page => {
await bigbluebot.audio.modal.listen(page);
};
bigbluebot.run(actions);
Join video
const bigbluebot = require('bigbluebot');
const actions = async page => {
await bigbluebot.video.join(page);
};
bigbluebot.run(actions);
Write in chat
const bigbluebot = require('bigbluebot');
const actions = async page => {
await bigbluebot.chat.send(page);
};
bigbluebot.run(actions);
You can pass options as a run parameter
const bigbluebot = require('bigbluebot');
const actions = async page => {
await bigbluebot.audio.modal.microphone(page);
await bigbluebot.video.join(page);
await bigbluebot.chat.send(page);
};
const options = {
host: 'https://your.bigbluebutton.server',
secret: 'yourbigbluebuttonsecret',
version: '2.2' OR '2.3',
room: 'yourbigbluebuttonroomidentifier',
password: {
moderator: 'yourmoderatorpassword',
attendee: 'yourattendeepassword',
},
moderator: true OR false,
userdata: {
"userdata-bbb_first_userdata": value,
"userdata-bbb_second_userdata": value,
"userdata-bbb_third_userdata": value,
},
};
bigbluebot.run(actions, options);
node run.js