@ -20,41 +20,36 @@ class bbb
public $url;
public $url;
public $salt;
public $salt;
public $api;
public $api;
public $user_complete_name = null ;
public $user_complete_name = '' ;
public $protocol = 'http://';
public $protocol = 'http://';
public $debug = false;
public $debug = false;
public $logout_url = null;
public $logoutUrl = '';
public $plugin_enabled = false;
public $pluginEnabled = false;
public $enableGlobalConference = false;
public $isGlobalConference = false;
/**
/**
*
* Constructor (generates a connection to the API and the Chamilo settings
* Constructor (generates a connection to the API and the Chamilo settings
* required for the connection to the video conference server)
* required for the connection to the video conference server)
* @param string $host
* @param string $host
* @param string $salt
* @param string $salt
*/
*/
public function __construct($host = null, $salt = null )
public function __construct($host = '', $salt = '', $isGlobalConference = false )
{
{
// Initialize video server settings from global settings
// Initialize video server settings from global settings
$plugin = BBBPlugin::create();
$plugin = BBBPlugin::create();
$bbb_p lugin = $plugin->get('tool_enable');
$bbbP lugin = $plugin->get('tool_enable');
if (empty($host)) {
$bbb_host = !empty($host) ? $host : $plugin->get('host');
$bbb_host = $plugin->get('host');
$bbb_salt = !empty($salt) ? $salt : $plugin->get('salt');
} else {
$bbb_host = $host;
}
if (empty($salt)) {
$bbb_salt = $plugin->get('salt');
} else {
$bbb_salt = $salt;
}
$this->logout_url = api_get_path(WEB_PLUGIN_PATH).'bbb/listing.php?'.api_get_cidreq ();
$this->logoutUrl = $this->getListingUrl();
$this->table = Database::get_main_table('plugin_bbb_meeting');
$this->table = Database::get_main_table('plugin_bbb_meeting');
$this->enableGlobalConference = $plugin->get('enable_global_conference');
$this->isGlobalConference = (bool) $isGlobalConference;
if ($bbb_plugin == true) {
if ($bbbPlugin === true) {
$userInfo = api_get_user_info();
$userInfo = api_get_user_info();
$this->user_complete_name = $userInfo['complete_name'];
$this->user_complete_name = $userInfo['complete_name'];
$this->salt = $bbb_salt;
$this->salt = $bbb_salt;
@ -70,15 +65,36 @@ class bbb
define('CONFIG_SERVER_BASE_URL', $this->url);
define('CONFIG_SERVER_BASE_URL', $this->url);
$this->api = new BigBlueButtonBN();
$this->api = new BigBlueButtonBN();
$this->plugin_enabled = true;
$this->pluginEnabled = true;
}
}
/**
* @return bool
*/
public function isGlobalConferenceEnabled()
{
return (bool) $this->enableGlobalConference;
}
/**
* @return bool
*/
public function isGlobalConference()
{
if ($this->isGlobalConferenceEnabled() === false) {
return false;
}
}
return (bool) $this->isGlobalConference;
}
}
/**
/**
* Checks whether a user is teacher in the current course
* Checks whether a user is teacher in the current course
* @return bool True if the user can be considered a teacher in this course, false otherwise
* @return bool True if the user can be considered a teacher in this course, false otherwise
*/
*/
public function isTeacher()
public function isConferenceManag er()
{
{
return api_is_course_admin() || api_is_coach() || api_is_platform_admin();
return api_is_course_admin() || api_is_coach() || api_is_platform_admin();
}
}
@ -117,11 +133,11 @@ class bbb
*/
*/
public function createMeeting($params)
public function createMeeting($params)
{
{
$params['c_id'] = api_get_course_int_id();
$courseCode = api_get_course_id();
$courseCode = api_get_course_id();
$params['c_id'] = api_get_course_int_id();
$params['session_id'] = api_get_session_id();
$params['session_id'] = api_get_session_id();
$params['attendee_pw'] = isset($params['moderator_pw']) ? $params['moderator_pw'] : api_get_course_id() ;
$params['attendee_pw'] = isset($params['moderator_pw']) ? $params['moderator_pw'] : $courseCode ;
$attendeePassword = $params['attendee_pw'];
$attendeePassword = $params['attendee_pw'];
$params['moderator_pw'] = isset($params['moderator_pw']) ? $params['moderator_pw'] : $this->getModMeetingPassword();
$params['moderator_pw'] = isset($params['moderator_pw']) ? $params['moderator_pw'] : $this->getModMeetingPassword();
$moderatorPassword = $params['moderator_pw'];
$moderatorPassword = $params['moderator_pw'];
@ -129,13 +145,14 @@ class bbb
$params['record'] = api_get_course_setting('big_blue_button_record_and_store', $courseCode) == 1 ? true : false;
$params['record'] = api_get_course_setting('big_blue_button_record_and_store', $courseCode) == 1 ? true : false;
$max = api_get_course_setting('big_blue_button_max_students_allowed', $courseCode);
$max = api_get_course_setting('big_blue_button_max_students_allowed', $courseCode);
$max = isset($max) ? $max : -1;
$max = isset($max) ? $max : -1;
$params['status'] = 1;
$params['status'] = 1;
// Generate a pseudo-global-unique-id to avoid clash of conferences on
// Generate a pseudo-global-unique-id to avoid clash of conferences on
// the same BBB server with several Chamilo portals
// the same BBB server with several Chamilo portals
$params['remote_id'] = uniqid(true, true);
$params['remote_id'] = uniqid(true, true);
// Each simultaneous conference room needs to have a different
// Each simultaneous conference room needs to have a different
// voice_bridge composed of a 5 digits number, so generating a random one
// voice_bridge composed of a 5 digits number, so generating a random one
$params['voice_bridge'] = rand(10000,99999);
$params['voice_bridge'] = rand(10000, 99999);
if ($this->debug) {
if ($this->debug) {
error_log("enter create_meeting ".print_r($params, 1));
error_log("enter create_meeting ".print_r($params, 1));
@ -166,7 +183,7 @@ class bbb
'dialNumber' => '', // The main number to call into. Optional.
'dialNumber' => '', // The main number to call into. Optional.
'voiceBridge' => $params['voice_bridge'], // PIN to join voice. Required.
'voiceBridge' => $params['voice_bridge'], // PIN to join voice. Required.
'webVoice' => '', // Alphanumeric to join voice. Optional.
'webVoice' => '', // Alphanumeric to join voice. Optional.
'logoutUrl' => $this->logout_u rl,
'logoutUrl' => $this->logoutU rl,
'maxParticipants' => $max, // Optional. -1 = unlimitted. Not supported in BBB. [number]
'maxParticipants' => $max, // Optional. -1 = unlimitted. Not supported in BBB. [number]
'record' => $record, // New. 'true' will tell BBB to record the meeting.
'record' => $record, // New. 'true' will tell BBB to record the meeting.
'duration' => $duration, // Default = 0 which means no set duration in minutes. [number]
'duration' => $duration, // Default = 0 which means no set duration in minutes. [number]
@ -180,12 +197,11 @@ class bbb
$status = false;
$status = false;
$meeting = null;
$meeting = null;
while ($status == false) {
while ($status === false) {
$result = $this->api->createMeetingWithXmlResponseArray(
$result = $this->api->createMeetingWithXmlResponseArray(
$bbbParams
$bbbParams
);
);
if (isset($result) & & strval($result['returncode']) == 'SUCCESS'
if (isset($result) & & strval($result['returncode']) == 'SUCCESS') {
) {
if ($this->debug) {
if ($this->debug) {
error_log(
error_log(
"create_meeting result: " . print_r($result, 1)
"create_meeting result: " . print_r($result, 1)
@ -196,7 +212,8 @@ class bbb
return $meeting;
return $meeting;
}
}
}
}
return $this->logout;
return $this->logoutUrl;
}
}
}
}
@ -212,8 +229,10 @@ class bbb
public function meetingExists($meetingName)
public function meetingExists($meetingName)
{
{
if (empty($meetingName)) {
if (empty($meetingName)) {
return false;
return false;
}
}
$courseId = api_get_course_int_id();
$courseId = api_get_course_int_id();
$sessionId = api_get_session_id();
$sessionId = api_get_session_id();
$meetingData = Database::select(
$meetingData = Database::select(
@ -230,7 +249,9 @@ class bbb
if ($this->debug) {
if ($this->debug) {
error_log("meeting_exists ".print_r($meetingData, 1));
error_log("meeting_exists ".print_r($meetingData, 1));
}
}
if (empty($meetingData)) {
if (empty($meetingData)) {
return false;
return false;
} else {
} else {
return true;
return true;
@ -277,7 +298,7 @@ class bbb
$status = false;
$status = false;
$meetingInfoExists = false;
$meetingInfoExists = false;
while ($status == false) {
while ($status === false) {
$meetingIsRunningInfo = $this->getMeetingInfo($params);
$meetingIsRunningInfo = $this->getMeetingInfo($params);
if ($meetingIsRunningInfo === false) {
if ($meetingIsRunningInfo === false) {
@ -333,11 +354,12 @@ class bbb
$url = $this->api->getJoinMeetingURL($joinParams);
$url = $this->api->getJoinMeetingURL($joinParams);
$url = $this->protocol.$url;
$url = $this->protocol.$url;
} else {
} else {
$url = $this->logout_u rl;
$url = $this->logoutU rl;
}
}
if ($this->debug) {
if ($this->debug) {
error_log("return url :" . $url);
error_log("return url :" . $url);
}
}
return $url;
return $url;
}
}
@ -363,6 +385,7 @@ class bbb
error_log('Caught exception: ', $e->getMessage(), "\n");
error_log('Caught exception: ', $e->getMessage(), "\n");
}
}
}
}
return false;
return false;
}
}
@ -370,16 +393,26 @@ class bbb
* Gets all the course meetings saved in the plugin_bbb_meeting table
* Gets all the course meetings saved in the plugin_bbb_meeting table
* @return array Array of current open meeting rooms
* @return array Array of current open meeting rooms
*/
*/
public function getCourse Meetings()
public function getMeetings()
{
{
$pass = $this->getUserMeetingPassword();
$pass = $this->getUserMeetingPassword();
$meetingList = Database::select('*', $this->table, array('where' => array('c_id = ? AND session_id = ? ' => array(api_get_course_int_id(), api_get_session_id()))));
$meetingList = Database::select(
'*',
$this->table,
array(
'where' => array(
'c_id = ? AND session_id = ? ' => array(
api_get_course_int_id(),
api_get_session_id(),
),
),
)
);
$isGlobal = $this->isGlobalConference();
$newMeetingList = array();
$newMeetingList = array();
$item = array();
$item = array();
foreach ($meetingList as $meetingDB) {
foreach ($meetingList as $meetingDB) {
$meetingBBB = $this->getMeetingInfo(array('meetingId' => $meetingDB['remote_id'], 'password' => $pass));
$meetingBBB = $this->getMeetingInfo(['meetingId' => $meetingDB['remote_id'], 'password' => $pass] );
if ($meetingBBB === false) {
if ($meetingBBB === false) {
//checking with the remote_id didn't work, so just in case and
//checking with the remote_id didn't work, so just in case and
// to provide backwards support, check with the id
// to provide backwards support, check with the id
@ -392,17 +425,17 @@ class bbb
$meetingBBB = $this->getMeetingInfo($params);
$meetingBBB = $this->getMeetingInfo($params);
}
}
if ($meetingDB['visibility'] == 0 and $this->isTeacher() == false) {
if ($meetingDB['visibility'] == 0 & & $this->isConferenceManager() = == false) {
continue;
continue;
}
}
$meetingBBB['end_url'] = api_get_self().'?'.api_get_cidreq().'&action=end&id='.$meetingDB['id'];
$meetingBBB['end_url'] = $this->endUrl($meetingDB);
if ((string)$meetingBBB['returncode'] == 'FAILED') {
if ((string)$meetingBBB['returncode'] == 'FAILED') {
if ($meetingDB['status'] == 1 & & $this->isTeach er()) {
if ($meetingDB['status'] == 1 & & $this->isConferenceManag er()) {
$this->endMeeting($meetingDB['id']);
$this->endMeeting($meetingDB['id']);
}
}
} else {
} else {
$meetingBBB['add_to_calendar_url'] = api_get_self().'?'.api_get_cidreq().'&action=add_to_calendar&id='.$meetingDB['id'].'&start='.api_strtotime($meetingDB['created_at']);
$meetingBBB['add_to_calendar_url'] = $this->addToCalendarUrl($meetingDB);
}
}
$recordArray = array();
$recordArray = array();
@ -438,9 +471,7 @@ class bbb
array(),
array(),
ICON_SIZE_MEDIUM
ICON_SIZE_MEDIUM
),
),
api_get_self().'?'.
$this->publishUrl($meetingDB)
api_get_cidreq().
'& action=publish& id='.$meetingDB['id']
);
);
} else {
} else {
$actionLinksArray[] = Display::url(
$actionLinksArray[] = Display::url(
@ -450,13 +481,9 @@ class bbb
array(),
array(),
ICON_SIZE_MEDIUM
ICON_SIZE_MEDIUM
),
),
api_get_self().'?'.
$this->unPublishUrl($meetingDB)
api_get_cidreq().
'& action=unpublish& id='.$meetingDB['id']
);
);
}
}
} else {
//$recordArray[] = $records['message'];
}
}
} else {
} else {
foreach ($records as $record) {
foreach ($records as $record) {
@ -471,36 +498,31 @@ class bbb
array('target' => '_blank')
array('target' => '_blank')
);
);
$actionLinks = '';
$actionLinks = '';
if ($this->isTeacher()) {
if ($this->isConferenceManager()) {
if ($isGlobal === false) {
$actionLinks .= Display::url(
$actionLinks .= Display::url(
Display::return_icon(
Display::return_icon(
'link.gif',
'link.gif',
get_lang('CopyToLinkTool')
get_lang('CopyToLinkTool')
),
),
api_get_self().'?'.
$this->copyToRecordToLinkTool($meetingDB)
api_get_cidreq().
'& action=copy_record_to_link_tool& id='.$meetingDB['id']
);
);
$actionLinks .= Display::url(
$actionLinks .= Display::url(
Display::return_icon(
Display::return_icon(
'agenda.png',
'agenda.png',
get_lang('AddToCalendar')
get_lang('AddToCalendar')
),
),
api_get_self().'?'.
$this->addToCalendarUrl($meetingDB, $record)
api_get_cidreq().
'& action=add_to_calendar& id='.$meetingDB['id'].
'& start='.api_strtotime($meetingDB['created_at']).
'& url='.$record['playbackFormatUrl']
);
);
}
$actionLinks .= Display::url(
$actionLinks .= Display::url(
Display::return_icon(
Display::return_icon(
'delete.png',
'delete.png',
get_lang('Delete')
get_lang('Delete')
),
),
api_get_self().'?'.
$this->deleteRecordUrl($meetingDB)
api_get_cidreq().
'& action=delete_record& id='.$meetingDB['id']
);
);
if ($meetingDB['visibility'] == 0) {
if ($meetingDB['visibility'] == 0) {
$actionLinks .= Display::url(
$actionLinks .= Display::url(
Display::return_icon(
Display::return_icon(
@ -509,9 +531,7 @@ class bbb
array(),
array(),
ICON_SIZE_MEDIUM
ICON_SIZE_MEDIUM
),
),
api_get_self().'?'.
$this->publishUrl($meetingDB)
api_get_cidreq().
'& action=publish& id='.$meetingDB['id']
);
);
} else {
} else {
$actionLinks .= Display::url(
$actionLinks .= Display::url(
@ -521,13 +541,10 @@ class bbb
array(),
array(),
ICON_SIZE_MEDIUM
ICON_SIZE_MEDIUM
),
),
api_get_self().'?'.
$this->unPublishUrl($meetingDB)
api_get_cidreq().
'& action=unpublish& id='.$meetingDB['id']
);
);
}
}
}
}
//$url .= api_get_self().'?action=publish&id='.$record['recordID'];
$count++;
$count++;
$recordArray[] = $url;
$recordArray[] = $url;
$actionLinksArray[] = $actionLinks;
$actionLinksArray[] = $actionLinks;
@ -541,7 +558,7 @@ class bbb
foreach($record['playbacks'] as $item) {
foreach($record['playbacks'] as $item) {
$url = Display::url(get_lang('ViewRecord'), $item['url'], array('target' => '_blank'));
$url = Display::url(get_lang('ViewRecord'), $item['url'], array('target' => '_blank'));
//$url .= Display::url(get_lang('DeleteRecord'), api_get_self().'?action=delete_record&'.$record['recordID']);
//$url .= Display::url(get_lang('DeleteRecord'), api_get_self().'?action=delete_record&'.$record['recordID']);
if ($this->isTeach er()) {
if ($this->isConferenceManag er()) {
$url .= Display::url(Display::return_icon('link.gif',get_lang('CopyToLinkTool')), api_get_self().'?action=copy_record_to_link_tool&id='.$meetingDB['id'].'&record_id='.$record['recordID']);
$url .= Display::url(Display::return_icon('link.gif',get_lang('CopyToLinkTool')), api_get_self().'?action=copy_record_to_link_tool&id='.$meetingDB['id'].'&record_id='.$record['recordID']);
$url .= Display::url(Display::return_icon('agenda.png',get_lang('AddToCalendar')), api_get_self().'?action=add_to_calendar&id='.$meetingDB['id'].'&start='.api_strtotime($meetingDB['created_at']).'&url='.$item['url']);
$url .= Display::url(Display::return_icon('agenda.png',get_lang('AddToCalendar')), api_get_self().'?action=add_to_calendar&id='.$meetingDB['id'].'&start='.api_strtotime($meetingDB['created_at']).'&url='.$item['url']);
$url .= Display::url(Display::return_icon('delete.png',get_lang('Delete')), api_get_self().'?action=delete_record&id='.$record['recordID']);
$url .= Display::url(Display::return_icon('delete.png',get_lang('Delete')), api_get_self().'?action=delete_record&id='.$record['recordID']);
@ -556,7 +573,7 @@ class bbb
}
}
} else {
} else {
$actionLinks = '';
$actionLinks = '';
if ($this->isTeach er()) {
if ($this->isConferenceManag er()) {
if ($meetingDB['visibility'] == 0) {
if ($meetingDB['visibility'] == 0) {
$actionLinks .= Display::url(
$actionLinks .= Display::url(
Display::return_icon(
Display::return_icon(
@ -565,9 +582,7 @@ class bbb
array(),
array(),
ICON_SIZE_MEDIUM
ICON_SIZE_MEDIUM
),
),
api_get_self().'?'.
$this->publishUrl($meetingDB)
api_get_cidreq().
'& action=publish& id='.$meetingDB['id']
);
);
} else {
} else {
$actionLinks .= Display::url(
$actionLinks .= Display::url(
@ -577,9 +592,7 @@ class bbb
array(),
array(),
ICON_SIZE_MEDIUM
ICON_SIZE_MEDIUM
),
),
api_get_self().'?'.
$this->unPublishUrl($meetingDB)
api_get_cidreq().
'& action=unpublish& id='.$meetingDB['id']
);
);
}
}
}
}
@ -595,8 +608,8 @@ class bbb
//created_at
//created_at
$meetingDB['created_at'] = $item['created_at']; //avoid overwrite in array_merge() below
$meetingDB['created_at'] = $item['created_at']; //avoid overwrite in array_merge() below
$item['publish_url'] = api_get_self().'?'.api_get_cidreq().'&action=publish&id='.$meetingDB['id'];
$item['publish_url'] = $this->publishUrl($meetingDB);
$item['unpublish_url'] = api_get_self().'?'.api_get_cidreq().'&action=unpublish&id='.$meetingDB['id'];
$item['unpublish_url'] = $this->unPublishUrl($meetingBBB);
if ($meetingDB['status'] == 1) {
if ($meetingDB['status'] == 1) {
$joinParams = array(
$joinParams = array(
@ -612,6 +625,7 @@ class bbb
$item = array_merge($item, $meetingDB, $meetingBBB);
$item = array_merge($item, $meetingDB, $meetingBBB);
$newMeetingList[] = $item;
$newMeetingList[] = $item;
}
}
return $newMeetingList;
return $newMeetingList;
}
}
@ -622,10 +636,12 @@ class bbb
{
{
//return BigBlueButtonBN::setPublishRecordings($id, 'true', $this->url, $this->salt);
//return BigBlueButtonBN::setPublishRecordings($id, 'true', $this->url, $this->salt);
if (empty($id)) {
if (empty($id)) {
return false;
return false;
}
}
$id = intval($id);
$id = intval($id);
Database::update($this->table, array('visibility' => 1), array('id = ? ' => $id));
Database::update($this->table, array('visibility' => 1), array('id = ? ' => $id));
return true;
return true;
}
}
@ -636,10 +652,12 @@ class bbb
{
{
//return BigBlueButtonBN::setPublishRecordings($id, 'false', $this->url, $this->salt);
//return BigBlueButtonBN::setPublishRecordings($id, 'false', $this->url, $this->salt);
if (empty($id)) {
if (empty($id)) {
return false;
return false;
}
}
$id = intval($id);
$id = intval($id);
Database::update($this->table, array('visibility' => 0), array('id = ? ' => $id));
Database::update($this->table, array('visibility' => 0), array('id = ?' => $id));
return true;
return true;
}
}
@ -653,6 +671,7 @@ class bbb
public function endMeeting($id)
public function endMeeting($id)
{
{
if (empty($id)) {
if (empty($id)) {
return false;
return false;
}
}
$meetingData = Database::select('*', $this->table, array('where' => array('id = ?' => array($id))), 'first');
$meetingData = Database::select('*', $this->table, array('where' => array('id = ?' => array($id))), 'first');
@ -663,7 +682,11 @@ class bbb
'password' => $pass, // REQUIRED - Must match moderator pass for meeting.
'password' => $pass, // REQUIRED - Must match moderator pass for meeting.
);
);
$this->api->endMeetingWithXmlResponseArray($endParams);
$this->api->endMeetingWithXmlResponseArray($endParams);
Database::update($this->table, array('status' => 0, 'closed_at' => api_get_utc_datetime()), array('id = ? ' => $id));
Database::update(
$this->table,
array('status' => 0, 'closed_at' => api_get_utc_datetime()),
array('id = ? ' => $id)
);
}
}
/**
/**
@ -672,9 +695,16 @@ class bbb
*/
*/
public function getUserMeetingPassword()
public function getUserMeetingPassword()
{
{
if ($this->isTeacher()) {
if ($this->isConferenceManager()) {
return $this->getModMeetingPassword();
return $this->getModMeetingPassword();
} else {
} else {
if ($this->isGlobalConference()) {
return 'url_'.api_get_current_access_url_id();
}
return api_get_course_id();
return api_get_course_id();
}
}
}
}
@ -685,6 +715,11 @@ class bbb
*/
*/
public function getModMeetingPassword()
public function getModMeetingPassword()
{
{
if ($this->isGlobalConference()) {
return 'url_'.api_get_current_access_url_id().'_mod';
}
return api_get_course_id().'mod';
return api_get_course_id().'mod';
}
}
@ -697,7 +732,12 @@ class bbb
{
{
$courseId = api_get_course_int_id();
$courseId = api_get_course_int_id();
$sessionId = api_get_session_id();
$sessionId = api_get_session_id();
$meetingData = Database::select('*', $this->table, array('where' => array('c_id = ? AND session_id = ? AND status = 1 ' => array($courseId, $sessionId))), 'first');
$meetingData = Database::select(
'*',
$this->table,
array('where' => array('c_id = ? AND session_id = ? AND status = 1 ' => array($courseId, $sessionId))),
'first'
);
if (empty($meetingData)) {
if (empty($meetingData)) {
return 0;
return 0;
}
}
@ -786,7 +826,6 @@ class bbb
$records = $this->api->getRecordingsWithXmlResponseArray(array('meetingId' => $meetingData['remote_id']));
$records = $this->api->getRecordingsWithXmlResponseArray(array('meetingId' => $meetingData['remote_id']));
if (!empty($records)) {
if (!empty($records)) {
$count = 1;
if (isset($records['message']) & & !empty($records['message'])) {
if (isset($records['message']) & & !empty($records['message'])) {
if ($records['messageKey'] == 'noRecordings') {
if ($records['messageKey'] == 'noRecordings') {
$recordArray[] = get_lang('NoRecording');
$recordArray[] = get_lang('NoRecording');
@ -858,4 +897,108 @@ class bbb
echo '< / script > ';
echo '< / script > ';
exit;*/
exit;*/
}
}
/**
* @return string
*/
public function getUrlParams()
{
$courseInfo = api_get_course_info();
if (empty($courseInfo)) {
if ($this->isGlobalConference()) {
return 'global=1';
}
return '';
}
return api_get_cidreq();
}
/**
* @return string
*/
public function getCurrentVideoConferenceName()
{
if ($this->isGlobalConference()) {
return 'url_'.api_get_current_access_url_id();
}
return api_get_course_id().'-'.api_get_session_id();
}
/**
* @return string
*/
public function getConferenceUrl()
{
return api_get_path(WEB_PLUGIN_PATH).'bbb/start.php?launch=1&'.$this->getUrlParams();
}
/**
* @return string
*/
public function getListingUrl()
{
return api_get_path(WEB_PLUGIN_PATH).'bbb/listing.php?'.$this->getUrlParams();
}
/**
* @param array $meeting
* @return string
*/
public function endUrl($meeting)
{
return api_get_path(WEB_PLUGIN_PATH).'bbb/listing.php?'.$this->getUrlParams().'&action=end&id='.$meeting['id'];
}
/**
* @param array $meeting
* @param array $record
* @return string
*/
public function addToCalendarUrl($meeting, $record = [])
{
$url = isset($record['playbackFormatUrl']) ? $record['playbackFormatUrl'] : '';
return api_get_path(WEB_PLUGIN_PATH).'bbb/listing.php?'.$this->getUrlParams().'&action=add_to_calendar&id='.$meeting['id'].'&start='.api_strtotime($meeting['created_at']).'&url='.$url;
}
/**
* @param array $meeting
* @return string
*/
public function publishUrl($meeting)
{
return api_get_path(WEB_PLUGIN_PATH).'bbb/listing.php?'.$this->getUrlParams().'&action=publish&id='.$meeting['id'];
}
/**
* @param array $meeting
* @return string
*/
public function unPublishUrl($meeting)
{
return api_get_path(WEB_PLUGIN_PATH).'bbb/listing.php?'.$this->getUrlParams().'&action=unpublish&id='.$meeting['id'];
}
/**
* @param array $meeting
* @return string
*/
public function deleteRecordUrl($meeting)
{
return api_get_path(WEB_PLUGIN_PATH).'bbb/listing.php?'.$this->getUrlParams().'&action=delete_record&id='.$meeting['id'];
}
/**
* @param array $meeting
* @return string
*/
public function copyToRecordToLinkTool($meeting)
{
return api_get_path(WEB_PLUGIN_PATH).'bbb/listing.php?'.$this->getUrlParams().'&action=copy_record_to_link_tool&id='.$meeting['id'];
}
}
}