Skip to content

Latest commit

 

History

History
170 lines (132 loc) · 3.69 KB

README.md

File metadata and controls

170 lines (132 loc) · 3.69 KB

BigBlueBot for Testing Scalelite

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

Requirements

A BigBlueButton's server and API's secret

Instructions

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

Set your environment variables

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 and moderatorPW 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

Make a run script

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);

Runtime options

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);

Run your script

node run.js