public/plugin/bbb/admin.php
<?php
/* For license terms, see /license.txt */
use Chamilo\CoreBundle\Entity\User;
/**
* This script initiates a video conference session, calling the BigBlueButton API.
*/
$course_plugin = 'bbb'; //needed in order to load the plugin lang variables
$cidReset = true;
require_once __DIR__.'/../../main/inc/global.inc.php';
api_protect_admin_script();
$plugin = BBBPlugin::create();
$tool_name = $plugin->get_lang('Videoconference');
$isGlobal = isset($_GET['global']);
$bbb = new bbb('', '', $isGlobal);
$action = $_GET['action'] ?? null;
$currentMonth = date('n');
$dateStart = $_REQUEST['search_meeting_start'] ?? date('Y-m-d', mktime(1, 1, 1, $currentMonth, 1, date('Y')));
$dateEnd = $_REQUEST['search_meeting_end'] ?? date('Y-m-d', mktime(1, 1, 1, ++$currentMonth, 0, date('Y')));
$dateRange = [
'search_meeting_start' => $dateStart,
'search_meeting_end' => $dateEnd,
];
$form = new FormValidator(get_lang('Search'));
$form->addDatePicker('search_meeting_start', get_lang('Start date'));
$form->addDatePicker('search_meeting_end', get_lang('End date'));
$form->addButtonSearch(get_lang('Search'));
$form->setDefaults($dateRange);
if ($form->validate()) {
$dateRange = $form->getSubmitValues();
}
$meetings = $bbb->getMeetings(0, 0, 0, true, $dateRange);
foreach ($meetings as &$meeting) {
$participants = $bbb->findConnectedMeetingParticipants($meeting['id']);
foreach ($participants as $meetingParticipant) {
/** @var User $participant */
$participant = $meetingParticipant['participant'];
if ($participant) {
$meeting['participants'][] = UserManager::formatUserFullName($participant).' ('.$participant->getEmail().')';
}
}
}
if ($action) {
switch ($action) {
case 'export':
$dataToExport = [
[$tool_name, $plugin->get_lang('RecordList')],
[],
[
get_lang('CreatedAt'),
get_lang('Status'),
$plugin->get_lang('Records'),
get_lang('Course'),
get_lang('Session'),
get_lang('Participants'),
],
];
foreach ($meetings as $meeting) {
$dataToExport[] = [
$meeting['created_at'],
1 == $meeting['status'] ? $plugin->get_lang('MeetingOpened') : $plugin->get_lang('MeetingClosed'),
1 == $meeting['record'] ? get_lang('Yes') : get_lang('No'),
$meeting['course'] ? $meeting['course']->getTitle() : '-',
$meeting['session'] ? $meeting['session']->getTitle() : '-',
isset($meeting['participants']) ? implode(PHP_EOL, $meeting['participants']) : null,
];
}
Export::arrayToXls($dataToExport);
break;
}
}
if (!empty($meetings)) {
$meetings = array_reverse($meetings);
}
if (!$bbb->isServerRunning()) {
Display::addFlash(
Display::return_message(get_lang('ServerIsNotRunning'), 'error')
);
}
$htmlHeadXtra[] = api_get_js_simple(
api_get_path(WEB_PLUGIN_PATH).'bbb/resources/utils.js'
);
$htmlHeadXtra[] = "<script>var _p = {web_plugin: '".api_get_path(WEB_PLUGIN_PATH)."'}</script>";
$tpl = new Template($tool_name);
$tpl->assign('meetings', $meetings);
$tpl->assign('search_form', $form->returnForm());
$settingsForm = new FormValidator('settings', api_get_self());
$settingsForm->addHeader($plugin->get_lang('UpdateAllCourseSettings'));
$settingsForm->addHtml(Display::return_message($plugin->get_lang('ThisWillUpdateAllSettingsInAllCourses')));
$settings = $plugin->course_settings;
$defaults = [];
foreach ($settings as $setting) {
$setting = $setting['name'];
$text = $settingsForm->addText($setting, $plugin->get_lang($setting), false);
$text->freeze();
$defaults[$setting] = 'true' === api_get_plugin_setting('bbb', $setting) ? get_lang('Yes') : get_lang('No');
}
$settingsForm->addButtonSave($plugin->get_lang('UpdateAllCourses'));
if ($settingsForm->validate()) {
$table = Database::get_course_table(TABLE_COURSE_SETTING);
foreach ($settings as $setting) {
$setting = $setting['name'];
$setting = Database::escape_string($setting);
if (empty($setting)) {
continue;
}
$value = api_get_plugin_setting('bbb', $setting);
if ('true' === $value) {
$value = 1;
} else {
$value = '';
}
$sql = "UPDATE $table SET value = '$value' WHERE variable = '$setting'";
Database::query($sql);
}
Display::addFlash(Display::return_message(get_lang('Updated')));
header('Location: '.api_get_self());
exit;
}
$settingsForm->setDefaults($defaults);
$tpl->assign('settings_form', $settingsForm->returnForm());
$content = $tpl->fetch('bbb/view/admin.tpl');
if ($meetings) {
$actions = Display::toolbarButton(
get_lang('Export in Excel format'),
api_get_self().'?'.http_build_query([
'action' => 'export',
'search_meeting_start' => $dateStart,
'search_meeting_end' => $dateEnd,
]),
'file-excel-o',
'success'
);
$tpl->assign(
'actions',
Display::toolbarAction('toolbar', [$actions])
);
}
$tpl->assign('header', $plugin->get_lang('RecordList'));
$tpl->assign('content', $content);
$tpl->display_one_col_template();