12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * Class bbb
- * This script initiates a video conference session, calling the BigBlueButton
- * API
- * @package chamilo.plugin.bigbluebutton
- *
- * BigBlueButton-Chamilo connector class
- */
- //namespace Chamilo\Plugin\BBB;
- /**
- * Class bbb
- * @package Chamilo\Plugin\BBB
- */
- class bbb
- {
- public $url;
- public $salt;
- public $api;
- public $userCompleteName = '';
- public $protocol = 'http://';
- public $debug = false;
- public $logoutUrl = '';
- public $pluginEnabled = false;
- public $enableGlobalConference = false;
- public $enableGlobalConferencePerUser = false;
- public $isGlobalConference = false;
- public $groupSupport = false;
- public $userSupport = false;
- public $accessUrl = 1;
- public $userId = 0;
- public $plugin;
- private $courseCode;
- private $courseId;
- private $sessionId;
- private $groupId;
- private $maxUsersLimit;
- /**
- * Constructor (generates a connection to the API and the Chamilo settings
- * required for the connection to the video conference server)
- * @param string $host
- * @param string $salt
- * @param bool $isGlobalConference
- * @param int $isGlobalPerUser
- */
- public function __construct(
- $host = '',
- $salt = '',
- $isGlobalConference = false,
- $isGlobalPerUser = 0
- ) {
- $this->courseCode = api_get_course_id();
- $this->courseId = api_get_course_int_id();
- $this->sessionId = api_get_session_id();
- $this->groupId = api_get_group_id();
- // Initialize video server settings from global settings
- $this->plugin = BBBPlugin::create();
- $bbbPluginEnabled = $this->plugin->get('tool_enable');
- $bbb_host = !empty($host) ? $host : $this->plugin->get('host');
- $bbb_salt = !empty($salt) ? $salt : $this->plugin->get('salt');
- $this->table = Database::get_main_table('plugin_bbb_meeting');
- $this->enableGlobalConference = $this->plugin->get('enable_global_conference') === 'true' ? true : false;
- $this->isGlobalConference = (bool) $isGlobalConference;
- $columns = Database::listTableColumns($this->table);
- $this->groupSupport = isset($columns['group_id']) ? true : false;
- $this->userSupport = isset($columns['user_id']) ? true : false;
- $this->accessUrl = api_get_current_access_url_id();
- $this->enableGlobalConferencePerUser = false;
- if ($this->userSupport && !empty($isGlobalPerUser)) {
- $this->enableGlobalConferencePerUser = $this->plugin->get('enable_global_conference_per_user') === 'true' ? true : false;
- $this->userId = $isGlobalPerUser;
- }
- if ($this->groupSupport) {
- // Plugin check
- $this->groupSupport = $this->plugin->get('enable_conference_in_course_groups') === 'true' ? true : false;
- if ($this->groupSupport) {
- // Platform check
- $bbbSetting = api_get_setting('bbb_enable_conference_in_course_groups');
- $bbbSetting = isset($bbbSetting['bbb']) ? $bbbSetting['bbb'] === 'true' : false;
- if ($bbbSetting) {
- // Course check
- $courseInfo = api_get_course_info();
- if ($courseInfo) {
- $this->groupSupport = api_get_course_setting('bbb_enable_conference_in_groups', $courseInfo['code']) === '1';
- }
- }
- }
- }
- $this->maxUsersLimit = $this->plugin->get('max_users_limit');
- if ($bbbPluginEnabled === 'true') {
- $userInfo = api_get_user_info();
- if (empty($userInfo) && !empty($isGlobalPerUser)) {
- // If we are following a link to a global "per user" conference
- // then generate a random guest name to join the conference
- // because there is no part of the process where we give a name
- $this->userCompleteName = 'Guest'.rand(1000, 9999);
- } else {
- $this->userCompleteName = $userInfo['complete_name'];
- }
- $this->salt = $bbb_salt;
- $info = parse_url($bbb_host);
- $this->url = $bbb_host.'/bigbluebutton/';
- if (isset($info['scheme'])) {
- $this->protocol = $info['scheme'].'://';
- $this->url = str_replace($this->protocol, '', $this->url);
- $urlWithProtocol = $bbb_host;
- } else {
- // We asume it's an http, if user wants to use https host must include the protocol.
- $urlWithProtocol = 'http://'.$bbb_host;
- }
- // Setting BBB api
- define('CONFIG_SECURITY_SALT', $this->salt);
- define('CONFIG_SERVER_URL_WITH_PROTOCOL', $urlWithProtocol);
- define('CONFIG_SERVER_BASE_URL', $this->url);
- $this->api = new BigBlueButtonBN();
- $this->pluginEnabled = true;
- $this->logoutUrl = $this->getListingUrl();
- }
- }
- /**
- * Force the course, session and/or group IDs
- * @param string $courseCode
- * @param int $sessionId
- * @param int $groupId
- */
- public function forceCIdReq($courseCode, $sessionId = 0, $groupId = 0)
- {
- $this->courseCode = $courseCode;
- $this->sessionId = intval($sessionId);
- $this->groupId = intval($groupId);
- }
- /**
- * @return bool
- */
- public function isGlobalConferenceEnabled()
- {
- return $this->enableGlobalConference;
- }
- /**
- * @return bool
- */
- public function isGlobalConferencePerUserEnabled()
- {
- return $this->enableGlobalConferencePerUser;
- }
- /**
- * @return bool
- */
- public function isGlobalConference()
- {
- if ($this->isGlobalConferenceEnabled() === false) {
- return false;
- }
- return (bool) $this->isGlobalConference;
- }
- /**
- * @return bool
- */
- public function hasGroupSupport()
- {
- return $this->groupSupport;
- }
- /**
- * 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
- */
- public function isConferenceManager()
- {
- if (api_is_coach() || api_is_platform_admin()) {
- return true;
- }
- if ($this->isGlobalConferencePerUserEnabled()) {
- $currentUserId = api_get_user_id();
- if ($this->userId === $currentUserId) {
- return true;
- } else {
- return false;
- }
- }
- $courseInfo = api_get_course_info();
- if (!empty($courseInfo)) {
- return api_is_course_admin();
- }
- return false;
- }
- /**
- * Gets the global limit of users in a video-conference room.
- * This value can be overridden by course-specific values
- * @return int Maximum number of users set globally
- */
- public function getMaxUsersLimit()
- {
- $limit = $this->maxUsersLimit;
- if ($limit <= 0) {
- $limit = 0;
- }
- $courseLimit = 0;
- $sessionLimit = 0;
- // Check the extra fields for this course and session
- // Session limit takes priority over course limit
- // Course limit takes priority over global limit
- if (!empty($this->courseId)) {
- $extraField = new ExtraField('course');
- $fieldId = $extraField->get_all(
- array('variable = ?' => 'plugin_bbb_course_users_limit')
- );
- $extraValue = new ExtraFieldValue('course');
- $value = $extraValue->get_values_by_handler_and_field_id($this->courseId, $fieldId[0]['id']);
- if (!empty($value['value'])) {
- $courseLimit = (int) $value['value'];
- }
- }
- if (!empty($this->sessionId)) {
- $extraField = new ExtraField('session');
- $fieldId = $extraField->get_all(
- array('variable = ?' => 'plugin_bbb_session_users_limit')
- );
- $extraValue = new ExtraFieldValue('session');
- $value = $extraValue->get_values_by_handler_and_field_id($this->sessionId, $fieldId[0]['id']);
- if (!empty($value['value'])) {
- $sessionLimit = (int) $value['value'];
- }
- }
- if (!empty($sessionLimit)) {
- return $sessionLimit;
- } elseif (!empty($courseLimit)) {
- return $courseLimit;
- }
- return (int) $limit;
- }
- /**
- * Sets the global limit of users in a video-conference room.
- * @param int Maximum number of users (globally)
- */
- public function setMaxUsersLimit($max)
- {
- if ($max < 0) {
- $max = 0;
- }
- $this->maxUsersLimit = intval($max);
- }
- /**
- * See this file in you BBB to set up default values
- * @param array $params Array of parameters that will be completed if not containing all expected variables
- /var/lib/tomcat6/webapps/bigbluebutton/WEB-INF/classes/bigbluebutton.properties
- *
- More record information:
- http://code.google.com/p/bigbluebutton/wiki/RecordPlaybackSpecification
- # Default maximum number of users a meeting can have.
- # Doesn't get enforced yet but is the default value when the create
- # API doesn't pass a value.
- defaultMaxUsers=20
- # Default duration of the meeting in minutes.
- # Current default is 0 (meeting doesn't end).
- defaultMeetingDuration=0
- # Remove the meeting from memory when the end API is called.
- # This allows 3rd-party apps to recycle the meeting right-away
- # instead of waiting for the meeting to expire (see below).
- removeMeetingWhenEnded=false
- # The number of minutes before the system removes the meeting from memory.
- defaultMeetingExpireDuration=1
- # The number of minutes the system waits when a meeting is created and when
- # a user joins. If after this period, a user hasn't joined, the meeting is
- # removed from memory.
- defaultMeetingCreateJoinDuration=5
- *
- * @return mixed
- */
- public function createMeeting($params)
- {
- $courseCode = api_get_course_id();
- $params['c_id'] = api_get_course_int_id();
- $params['session_id'] = api_get_session_id();
- if ($this->hasGroupSupport()) {
- $params['group_id'] = api_get_group_id();
- }
- if ($this->isGlobalConferencePerUserEnabled() && !empty($this->userId)) {
- $params['user_id'] = (int) $this->userId;
- }
- $params['attendee_pw'] = isset($params['attendee_pw']) ? $params['attendee_pw'] : $this->getUserMeetingPassword();
- $attendeePassword = $params['attendee_pw'];
- $params['moderator_pw'] = isset($params['moderator_pw']) ? $params['moderator_pw'] : $this->getModMeetingPassword();
- $moderatorPassword = $params['moderator_pw'];
- $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 = isset($max) ? $max : -1;
- $params['status'] = 1;
- // Generate a pseudo-global-unique-id to avoid clash of conferences on
- // the same BBB server with several Chamilo portals
- $params['remote_id'] = uniqid(true, true);
- // Each simultaneous conference room needs to have a different
- // voice_bridge composed of a 5 digits number, so generating a random one
- $params['voice_bridge'] = rand(10000, 99999);
- if ($this->debug) {
- error_log("enter create_meeting ".print_r($params, 1));
- }
- $params['created_at'] = api_get_utc_datetime();
- $params['access_url'] = $this->accessUrl;
- // Check interface feature is installed
- $interfaceFeature = $this->plugin->get('interface');
- if ($interfaceFeature === false) {
- if (isset($params['interface'])) {
- unset($params['interface']);
- }
- }
- $id = Database::insert($this->table, $params);
- if ($id) {
- if ($this->debug) {
- error_log("create_meeting: $id ");
- }
- $meetingName = isset($params['meeting_name']) ? $params['meeting_name'] : $this->getCurrentVideoConferenceName();
- $welcomeMessage = isset($params['welcome_msg']) ? $params['welcome_msg'] : null;
- $record = isset($params['record']) && $params['record'] ? 'true' : 'false';
- $duration = isset($params['duration']) ? intval($params['duration']) : 0;
- // This setting currently limits the maximum conference duration,
- // to avoid lingering sessions on the video-conference server #6261
- $duration = 300;
- $bbbParams = array(
- 'meetingId' => $params['remote_id'], // REQUIRED
- 'meetingName' => $meetingName, // REQUIRED
- 'attendeePw' => $attendeePassword, // Match this value in getJoinMeetingURL() to join as attendee.
- 'moderatorPw' => $moderatorPassword, // Match this value in getJoinMeetingURL() to join as moderator.
- 'welcomeMsg' => $welcomeMessage, // ''= use default. Change to customize.
- 'dialNumber' => '', // The main number to call into. Optional.
- 'voiceBridge' => $params['voice_bridge'], // PIN to join voice. Required.
- 'webVoice' => '', // Alphanumeric to join voice. Optional.
- 'logoutUrl' => $this->logoutUrl,
- 'maxParticipants' => $max, // Optional. -1 = unlimitted. Not supported in BBB. [number]
- 'record' => $record, // New. 'true' will tell BBB to record the meeting.
- 'duration' => $duration, // Default = 0 which means no set duration in minutes. [number]
- //'meta_category' => '', // Use to pass additional info to BBB server. See API docs.
- );
- if ($this->debug) {
- error_log("create_meeting params: ".print_r($bbbParams, 1));
- }
- $status = false;
- $meeting = null;
- while ($status === false) {
- $result = $this->api->createMeetingWithXmlResponseArray(
- $bbbParams
- );
- if (isset($result) && strval($result['returncode']) == 'SUCCESS') {
- if ($this->debug) {
- error_log(
- "create_meeting result: ".print_r($result, 1)
- );
- }
- $meeting = $this->joinMeeting($meetingName, true);
- return $meeting;
- }
- }
- return false;
- }
- return false;
- }
- /**
- * Save a participant in a meeting room
- * @param int $meetingId
- * @param int $participantId
- * @param int $interface
- *
- * @return false|int The last inserted ID. Otherwise return false
- */
- public function saveParticipant($meetingId, $participantId, $interface = 0)
- {
- $params = [
- 'meeting_id' => $meetingId,
- 'participant_id' => $participantId,
- 'in_at' => api_get_utc_datetime(),
- 'out_at' => api_get_utc_datetime()
- ];
- if ($this->plugin->get('interface') !== false) {
- $params['interface'] = $interface;
- }
- return Database::insert(
- 'plugin_bbb_room',
- $params
- );
- }
- /**
- * @param string $meetingName
- *
- * @return array
- */
- public function getMeetingByName($meetingName)
- {
- if (empty($meetingName)) {
- return [];
- }
- $courseId = api_get_course_int_id();
- $sessionId = api_get_session_id();
- $conditions = array(
- 'where' => array(
- 'c_id = ? AND session_id = ? AND meeting_name = ? AND status = 1 AND access_url = ?' =>
- array($courseId, $sessionId, $meetingName, $this->accessUrl)
- )
- );
- if ($this->hasGroupSupport()) {
- $groupId = api_get_group_id();
- $conditions = array(
- 'where' => array(
- 'c_id = ? AND session_id = ? AND meeting_name = ? AND group_id = ? AND status = 1 AND access_url = ?' =>
- array(
- $courseId,
- $sessionId,
- $meetingName,
- $groupId,
- $this->accessUrl
- )
- )
- );
- }
- $meetingData = Database::select(
- '*',
- $this->table,
- $conditions,
- 'first'
- );
- if ($this->debug) {
- error_log('meeting_exists '.print_r($meetingData, 1));
- }
- return $meetingData;
- }
- /**
- * Tells whether the given meeting exists and is running
- * (using course code as name)
- * @param string $meetingName Meeting name (usually the course code)
- *
- * @return bool True if meeting exists, false otherwise
- * @assert ('') === false
- * @assert ('abcdefghijklmnopqrstuvwxyzabcdefghijklmno') === false
- */
- public function meetingExists($meetingName)
- {
- $meetingData = $this->getMeetingByName($meetingName);
- return !empty($meetingData);
- }
- /**
- * Returns a meeting "join" URL
- * @param string The name of the meeting (usually the course code)
- * @return mixed The URL to join the meeting, or false on error
- * @todo implement moderator pass
- * @assert ('') === false
- * @assert ('abcdefghijklmnopqrstuvwxyzabcdefghijklmno') === false
- */
- public function joinMeeting($meetingName)
- {
- if ($this->debug) {
- error_log("joinMeeting: $meetingName");
- }
- if (empty($meetingName)) {
- return false;
- }
- $manager = $this->isConferenceManager();
- if ($manager) {
- $pass = $this->getModMeetingPassword();
- } else {
- $pass = $this->getUserMeetingPassword();
- }
- $meetingData = Database::select(
- '*',
- $this->table,
- array(
- 'where' => array(
- 'meeting_name = ? AND status = 1 AND access_url = ?' => array(
- $meetingName,
- $this->accessUrl
- )
- )
- ),
- 'first'
- );
- if (empty($meetingData) || !is_array($meetingData)) {
- if ($this->debug) {
- error_log("meeting does not exist: $meetingName");
- }
- return false;
- }
- $params = array(
- 'meetingId' => $meetingData['remote_id'],
- // -- REQUIRED - The unique id for the meeting
- 'password' => $this->getModMeetingPassword()
- // -- REQUIRED - The moderator password for the meeting
- );
- $meetingInfoExists = false;
- $meetingIsRunningInfo = $this->getMeetingInfo($params);
- if ($this->debug) {
- error_log('Searching meeting with params:');
- error_log(print_r($params, 1));
- error_log('Result:');
- error_log(print_r($meetingIsRunningInfo, 1));
- }
- if ($meetingIsRunningInfo === false) {
- // checking with the remote_id didn't work, so just in case and
- // to provide backwards support, check with the id
- $params = array(
- 'meetingId' => $meetingData['id'],
- // -- REQUIRED - The unique id for the meeting
- 'password' => $this->getModMeetingPassword()
- // -- REQUIRED - The moderator password for the meeting
- );
- $meetingIsRunningInfo = $this->getMeetingInfo($params);
- if ($this->debug) {
- error_log('Searching meetingId with params:');
- error_log(print_r($params, 1));
- error_log('Result:');
- error_log(print_r($meetingIsRunningInfo, 1));
- }
- }
- if (strval($meetingIsRunningInfo['returncode']) == 'SUCCESS' &&
- isset($meetingIsRunningInfo['meetingName']) &&
- !empty($meetingIsRunningInfo['meetingName'])
- ) {
- $meetingInfoExists = true;
- }
- if ($this->debug) {
- error_log(
- "meeting is running: ".intval($meetingInfoExists)
- );
- }
- $url = false;
- if ($meetingInfoExists) {
- $joinParams = [
- 'meetingId' => $meetingData['remote_id'], // -- REQUIRED - A unique id for the meeting
- 'username' => $this->userCompleteName, //-- REQUIRED - The name that will display for the user in the meeting
- 'password' => $pass, //-- REQUIRED - The attendee or moderator password, depending on what's passed here
- //'createTime' => api_get_utc_datetime(), //-- OPTIONAL - string. Leave blank ('') unless you set this correctly.
- 'userID' => api_get_user_id(), //-- OPTIONAL - string
- 'webVoiceConf' => '', // -- OPTIONAL - string
- 'interface' => $this->checkInterface($meetingData),
- ];
- $url = $this->api->getJoinMeetingURL($joinParams);
- $url = $this->protocol.$url;
- }
- if ($this->debug) {
- error_log("return url :".$url);
- }
- return $url;
- }
- /**
- * Get information about the given meeting
- * @param array ...?
- * @return mixed Array of information on success, false on error
- * @assert (array()) === false
- */
- public function getMeetingInfo($params)
- {
- try {
- $result = $this->api->getMeetingInfoWithXmlResponseArray($params);
- if ($result == null) {
- if ($this->debug) {
- error_log("Failed to get any response. Maybe we can't contact the BBB server.");
- }
- } else {
- return $result;
- }
- } catch (Exception $e) {
- if ($this->debug) {
- error_log('Caught exception: ', $e->getMessage(), "\n");
- }
- }
- return false;
- }
- /**
- * @param int $courseId
- * @param int $sessionId
- * @param int $status
- *
- * @return array
- */
- public function getAllMeetingsInCourse($courseId, $sessionId, $status)
- {
- $conditions = array(
- 'where' => array(
- 'status = ? AND c_id = ? AND session_id = ? ' => array(
- $status,
- $courseId,
- $sessionId,
- ),
- ),
- );
- $meetingList = Database::select(
- '*',
- $this->table,
- $conditions
- );
- return $meetingList;
- }
- /**
- * Gets all the course meetings saved in the plugin_bbb_meeting table
- * @param int $courseId
- * @param int $sessionId
- * @param int $groupId
- * @param bool $isAdminReport Optional. Set to true then the report is for admins
- * @param array $dateRange Optional
- * @return array Array of current open meeting rooms
- */
- public function getMeetings(
- $courseId = 0,
- $sessionId = 0,
- $groupId = 0,
- $isAdminReport = false,
- $dateRange = []
- ) {
- $em = Database::getManager();
- $manager = $this->isConferenceManager();
- $conditions = [];
- if ($courseId || $sessionId || $groupId) {
- $conditions = array(
- 'where' => array(
- 'c_id = ? AND session_id = ? ' => array($courseId, $sessionId),
- ),
- );
- if ($this->hasGroupSupport()) {
- $conditions = array(
- 'where' => array(
- 'c_id = ? AND session_id = ? AND group_id = ? ' => array(
- $courseId,
- $sessionId,
- $groupId
- )
- )
- );
- }
- if ($this->isGlobalConferencePerUserEnabled()) {
- $conditions = array(
- 'where' => array(
- 'c_id = ? AND session_id = ? AND user_id = ?' => array(
- $courseId,
- $sessionId,
- $this->userId
- ),
- ),
- );
- }
- }
- if (!empty($dateRange)) {
- $dateStart = date_create($dateRange['search_meeting_start']);
- $dateStart = date_format($dateStart, 'Y-m-d H:i:s');
- $dateEnd = date_create($dateRange['search_meeting_end']);
- $dateEnd = $dateEnd->add(new DateInterval('P1D'));
- $dateEnd = date_format($dateEnd, 'Y-m-d H:i:s');
- $conditions = array(
- 'where' => array(
- 'created_at BETWEEN ? AND ? ' => array($dateStart, $dateEnd),
- ),
- );
- }
- $conditions['order'] = 'created_at ASC';
- $meetingList = Database::select(
- '*',
- $this->table,
- $conditions
- );
- $isGlobal = $this->isGlobalConference();
- $newMeetingList = array();
- foreach ($meetingList as $meetingDB) {
- $item = array();
- $courseId = $meetingDB['c_id'];
- $courseInfo = api_get_course_info_by_id($courseId);
- $courseCode = '';
- if (!empty($courseInfo)) {
- $courseCode = $courseInfo['code'];
- }
- if ($manager) {
- $pass = $this->getUserMeetingPassword($courseCode);
- } else {
- $pass = $this->getModMeetingPassword($courseCode);
- }
- $meetingBBB = $this->getMeetingInfo(
- [
- 'meetingId' => $meetingDB['remote_id'],
- 'password' => $pass
- ]
- );
- if ($meetingBBB === false) {
- //checking with the remote_id didn't work, so just in case and
- // to provide backwards support, check with the id
- $params = array(
- 'meetingId' => $meetingDB['id'],
- // -- REQUIRED - The unique id for the meeting
- 'password' => $pass
- // -- REQUIRED - The moderator password for the meeting
- );
- $meetingBBB = $this->getMeetingInfo($params);
- }
- if ($meetingDB['visibility'] == 0 && $this->isConferenceManager() === false) {
- continue;
- }
- $meetingBBB['end_url'] = $this->endUrl($meetingDB);
- if (isset($meetingBBB['returncode']) && (string) $meetingBBB['returncode'] == 'FAILED') {
- if ($meetingDB['status'] == 1 && $this->isConferenceManager()) {
- $this->endMeeting($meetingDB['id'], $courseCode);
- }
- } else {
- $meetingBBB['add_to_calendar_url'] = $this->addToCalendarUrl($meetingDB);
- }
- if ($meetingDB['record'] == 1) {
- // backwards compatibility (when there was no remote ID)
- $mId = $meetingDB['remote_id'];
- if (empty($mId)) {
- $mId = $meetingDB['id'];
- }
- if (empty($mId)) {
- // if the id is still empty (should *never* occur as 'id' is
- // the table's primary key), skip this conference
- continue;
- }
- $record = [];
- //if (empty($meetingDB['video_url'])) {
- $recordingParams = ['meetingId' => $mId];
- $records = $this->api->getRecordingsWithXmlResponseArray($recordingParams);
- if (!empty($records)) {
- if (!isset($records['messageKey']) || $records['messageKey'] != 'noRecordings') {
- $record = end($records);
- if (!is_array($record) || !isset($record['recordId'])) {
- continue;
- }
- if (!empty($record['playbackFormatUrl'])) {
- $this->updateMeetingVideoUrl($meetingDB['id'], $record['playbackFormatUrl']);
- }
- if (!$this->isConferenceManager()) {
- $record = [];
- }
- }
- }
- //}
- /* else {
- $record['playbackFormatUrl'] = $meetingDB['video_url'];
- }*/
- $recordLink = isset($record['playbackFormatUrl']) && !empty($record['playbackFormatUrl'])
- ? Display::url(
- $this->plugin->get_lang('ViewRecord'),
- $record['playbackFormatUrl'],
- ['target' => '_blank']
- )
- : $this->plugin->get_lang('NoRecording');
- if ($isAdminReport) {
- $this->forceCIdReq(
- $courseInfo['code'],
- $meetingDB['session_id'],
- $meetingDB['group_id']
- );
- }
- $actionLinks = $this->getActionLinks(
- $meetingDB,
- $record,
- $isGlobal,
- $isAdminReport
- );
- $item['show_links'] = $recordLink;
- } else {
- $actionLinks = $this->getActionLinks(
- $meetingDB,
- [],
- $isGlobal,
- $isAdminReport
- );
- $item['show_links'] = $this->plugin->get_lang('NoRecording');
- }
- $item['action_links'] = implode(PHP_EOL, $actionLinks);
- $item['created_at'] = api_convert_and_format_date($meetingDB['created_at']);
- // created_at
- $meetingDB['created_at'] = $item['created_at']; //avoid overwrite in array_merge() below
- $item['publish_url'] = $this->publishUrl($meetingDB);
- $item['unpublish_url'] = $this->unPublishUrl($meetingBBB);
- if ($meetingDB['status'] == 1) {
- $joinParams = [
- 'meetingId' => $meetingDB['remote_id'], //-- REQUIRED - A unique id for the meeting
- 'username' => $this->userCompleteName, //-- REQUIRED - The name that will display for the user in the meeting
- 'password' => $pass, //-- REQUIRED - The attendee or moderator password, depending on what's passed here
- 'createTime' => '', //-- OPTIONAL - string. Leave blank ('') unless you set this correctly.
- 'userID' => '', // -- OPTIONAL - string
- 'webVoiceConf' => '', // -- OPTIONAL - string
- 'interface' => $this->checkInterface($meetingDB),
- ];
- $item['go_url'] = $this->protocol.$this->api->getJoinMeetingURL($joinParams);
- }
- $item = array_merge($item, $meetingDB, $meetingBBB);
- $item['course'] = $em->find('ChamiloCoreBundle:Course', $item['c_id']);
- $item['session'] = $em->find('ChamiloCoreBundle:Session', $item['session_id']);
- $newMeetingList[] = $item;
- }
- return $newMeetingList;
- }
- /**
- * @param $meetingInfo
- *
- * @return int
- */
- public function checkInterface($meetingInfo)
- {
- $interface = BBBPlugin::LAUNCH_TYPE_DEFAULT;
- $type = $this->plugin->get('launch_type');
- switch ($type) {
- case BBBPlugin::LAUNCH_TYPE_DEFAULT:
- $interface = $this->plugin->get('interface');
- break;
- case BBBPlugin::LAUNCH_TYPE_SET_BY_TEACHER:
- if (isset($meetingInfo['interface'])) {
- $interface = $meetingInfo['interface'];
- }
- break;
- case BBBPlugin::LAUNCH_TYPE_SET_BY_STUDENT:
- if (isset($meetingInfo['id'])) {
- $roomInfo = $this->getMeetingParticipantInfo($meetingInfo['id'], api_get_user_id());
- if (!empty($roomInfo) && isset($roomInfo['interface'])) {
- $interface = $roomInfo['interface'];
- } else {
- if (isset($_REQUEST['interface'])) {
- $interface = isset($_REQUEST['interface']) ? (int) $_REQUEST['interface'] : 0;
- }
- }
- }
- break;
- }
- return $interface;
- }
- /**
- * Function disabled
- */
- public function publishMeeting($id)
- {
- //return BigBlueButtonBN::setPublishRecordings($id, 'true', $this->url, $this->salt);
- if (empty($id)) {
- return false;
- }
- $id = intval($id);
- Database::update($this->table, array('visibility' => 1), array('id = ? ' => $id));
- return true;
- }
- /**
- * Function disabled
- */
- public function unpublishMeeting($id)
- {
- //return BigBlueButtonBN::setPublishRecordings($id, 'false', $this->url, $this->salt);
- if (empty($id)) {
- return false;
- }
- $id = intval($id);
- Database::update($this->table, array('visibility' => 0), array('id = ?' => $id));
- return true;
- }
- /**
- * Closes a meeting (usually when the user click on the close button from
- * the conferences listing.
- * @param string The internal ID of the meeting (id field for this meeting)
- * @param string $courseCode
- *
- * @return void
- * @assert (0) === false
- */
- public function endMeeting($id, $courseCode = null)
- {
- if (empty($id)) {
- return false;
- }
- $meetingData = Database::select(
- '*',
- $this->table,
- array('where' => array('id = ?' => array($id))),
- 'first'
- );
- $manager = $this->isConferenceManager();
- if ($manager) {
- $pass = $this->getUserMeetingPassword($courseCode);
- } else {
- $pass = $this->getModMeetingPassword($courseCode);
- }
- $endParams = array(
- 'meetingId' => $meetingData['remote_id'], // REQUIRED - We have to know which meeting to end.
- 'password' => $pass, // REQUIRED - Must match moderator pass for meeting.
- );
- $this->api->endMeetingWithXmlResponseArray($endParams);
- Database::update(
- $this->table,
- array('status' => 0, 'closed_at' => api_get_utc_datetime()),
- array('id = ? ' => $id)
- );
- }
- /**
- * Gets the password for a specific meeting for the current user
- * @param string $courseCode
- * @return string A moderator password if user is teacher, or the course code otherwise
- *
- */
- public function getUserMeetingPassword($courseCode = null)
- {
- if ($this->isGlobalConferencePerUserEnabled()) {
- return 'url_'.$this->userId.'_'.api_get_current_access_url_id();
- }
- if ($this->isGlobalConference()) {
- return 'url_'.api_get_current_access_url_id();
- }
- $courseCode = empty($courseCode) ? api_get_course_id() : $courseCode;
- return $courseCode;
- }
- /**
- * Generated a moderator password for the meeting.
- *
- * @param string $courseCode
- *
- * @return string A password for the moderation of the videoconference
- */
- public function getModMeetingPassword($courseCode = null)
- {
- if ($this->isGlobalConferencePerUserEnabled()) {
- return 'url_'.$this->userId.'_'.api_get_current_access_url_id().'_mod';
- }
- if ($this->isGlobalConference()) {
- return 'url_'.api_get_current_access_url_id().'_mod';
- }
- $courseCode = empty($courseCode) ? api_get_course_id() : $courseCode;
- return $courseCode.'mod';
- }
- /**
- * Get users online in the current course room.
- *
- * @return int The number of users currently connected to the videoconference
- * @assert () > -1
- */
- public function getUsersOnlineInCurrentRoom()
- {
- $courseId = api_get_course_int_id();
- $sessionId = api_get_session_id();
- $conditions = array(
- 'where' => array(
- 'c_id = ? AND session_id = ? AND status = 1 AND access_url = ?' => array(
- $courseId,
- $sessionId,
- $this->accessUrl
- ),
- ),
- );
- if ($this->hasGroupSupport()) {
- $groupId = api_get_group_id();
- $conditions = array(
- 'where' => array(
- 'c_id = ? AND session_id = ? AND group_id = ? AND status = 1 AND access_url = ?' => array(
- $courseId,
- $sessionId,
- $groupId,
- $this->accessUrl
- ),
- ),
- );
- }
- if ($this->isGlobalConferencePerUserEnabled()) {
- $conditions = array(
- 'where' => array(
- 'user_id = ? AND status = 1 AND access_url = ?' => array(
- $this->userId,
- $this->accessUrl
- ),
- ),
- );
- }
- $meetingData = Database::select(
- '*',
- $this->table,
- $conditions,
- 'first'
- );
- if (empty($meetingData)) {
- return 0;
- }
- $pass = $this->getModMeetingPassword();
- $info = $this->getMeetingInfo(array('meetingId' => $meetingData['remote_id'], 'password' => $pass));
- if ($info === false) {
- //checking with the remote_id didn't work, so just in case and
- // to provide backwards support, check with the id
- $params = array(
- 'meetingId' => $meetingData['id'],
- // -- REQUIRED - The unique id for the meeting
- 'password' => $pass
- // -- REQUIRED - The moderator password for the meeting
- );
- $info = $this->getMeetingInfo($params);
- }
- if (!empty($info) && isset($info['participantCount'])) {
- return $info['participantCount'];
- }
- return 0;
- }
- /**
- * @param int $id
- * @param int $recordId
- *
- * @return bool
- */
- public function regenerateRecording($id, $recordId)
- {
- if (empty($id)) {
- return false;
- }
- $meetingData = Database::select(
- '*',
- $this->table,
- array('where' => array('id = ?' => array($id))),
- 'first'
- );
- // Check if there are recordings for this meeting
- $recordings = $this->api->getRecordings(['meetingId' => $meetingData['remote_id']]);
- if (!empty($recordings) && isset($recordings['messageKey']) && $recordings['messageKey'] == 'noRecordings') {
- return false;
- } else {
- if (!empty($recordings['records'])) {
- $recordExists = false;
- foreach ($recordings['records'] as $record) {
- if ($recordId == $record['recordId']) {
- $recordExists = true;
- break;
- }
- }
- if ($recordExists) {
- return $this->api->generateRecording(['recordId' => $recordId]);
- }
- }
- }
- return false;
- }
- /**
- * Deletes a recording of a meeting
- *
- * @param int $id ID of the recording
- *
- * @return bool
- *
- * @assert () === false
- * @todo Also delete links and agenda items created from this recording
- */
- public function deleteRecording($id)
- {
- if (empty($id)) {
- return false;
- }
- $meetingData = Database::select(
- '*',
- $this->table,
- array('where' => array('id = ?' => array($id))),
- 'first'
- );
- $delete = false;
- // Check if there are recordings for this meeting
- $recordings = $this->api->getRecordings(['meetingId' => $meetingData['remote_id']]);
- if (!empty($recordings) && isset($recordings['messageKey']) && $recordings['messageKey'] == 'noRecordings') {
- $delete = true;
- } else {
- $recordsToDelete = [];
- if (!empty($recordings['records'])) {
- foreach ($recordings['records'] as $record) {
- $recordsToDelete[] = $record['recordId'];
- }
- $recordingParams = ['recordId' => implode(',', $recordsToDelete)];
- $result = $this->api->deleteRecordingsWithXmlResponseArray($recordingParams);
- if (!empty($result) && isset($result['deleted']) && $result['deleted'] === 'true') {
- $delete = true;
- }
- }
- }
- if ($delete) {
- Database::delete(
- 'plugin_bbb_room',
- array('meeting_id = ?' => array($id))
- );
- Database::delete(
- $this->table,
- array('id = ?' => array($id))
- );
- }
- return $delete;
- }
- /**
- * Creates a link in the links tool from the given videoconference recording
- * @param int $id ID of the item in the plugin_bbb_meeting table
- * @param string Hash identifying the recording, as provided by the API
- * @return mixed ID of the newly created link, or false on error
- * @assert (null, null) === false
- * @assert (1, null) === false
- * @assert (null, 'abcdefabcdefabcdefabcdef') === false
- */
- public function copyRecordingToLinkTool($id)
- {
- if (empty($id)) {
- return false;
- }
- //$records = BigBlueButtonBN::getRecordingsUrl($id);
- $meetingData = Database::select(
- '*',
- $this->table,
- array('where' => array('id = ?' => array($id))),
- 'first'
- );
- $records = $this->api->getRecordingsWithXmlResponseArray(
- array('meetingId' => $meetingData['remote_id'])
- );
- if (!empty($records)) {
- if (isset($records['message']) && !empty($records['message'])) {
- if ($records['messageKey'] == 'noRecordings') {
- $recordArray[] = $this->plugin->get_lang('NoRecording');
- } else {
- //$recordArray[] = $records['message'];
- }
- return false;
- } else {
- $record = $records[0];
- if (is_array($record) && isset($record['recordId'])) {
- $url = $record['playbackFormatUrl'];
- $link = new Link();
- $params['url'] = $url;
- $params['title'] = $meetingData['meeting_name'];
- $id = $link->save($params);
- return $id;
- }
- }
- }
- return false;
- }
- /**
- * Checks if the video conference server is running.
- * Function currently disabled (always returns 1)
- * @return bool True if server is running, false otherwise
- * @assert () === false
- */
- public function isServerRunning()
- {
- return true;
- //return BigBlueButtonBN::isServerRunning($this->protocol.$this->url);
- }
- /**
- * Get active session in the all platform
- */
- public function getActiveSessionsCount()
- {
- $meetingList = Database::select(
- 'count(id) as count',
- $this->table,
- array('where' => array('status = ? AND access_url = ?' => array(1, $this->accessUrl))),
- 'first'
- );
- return $meetingList['count'];
- }
- /**
- * @param string $url
- */
- public function redirectToBBB($url)
- {
- if (file_exists(__DIR__.'/../config.vm.php')) {
- // Using VM
- echo Display::url($this->plugin->get_lang('ClickToContinue'), $url);
- exit;
- } else {
- // Classic
- header("Location: $url");
- exit;
- }
- }
- /**
- * @return string
- */
- public function getUrlParams()
- {
- if (empty($this->courseCode)) {
- if ($this->isGlobalConferencePerUserEnabled()) {
- return 'global=1&user_id='.$this->userId;
- }
- if ($this->isGlobalConference()) {
- return 'global=1';
- }
- return '';
- }
- return http_build_query([
- 'cidReq' => $this->courseCode,
- 'id_session' => $this->sessionId,
- 'gidReq' => $this->groupId
- ]);
- }
- /**
- * @return string
- */
- public function getCurrentVideoConferenceName()
- {
- if ($this->isGlobalConferencePerUserEnabled()) {
- return 'url_'.$this->userId.'_'.api_get_current_access_url_id();
- }
- if ($this->isGlobalConference()) {
- return 'url_'.api_get_current_access_url_id();
- }
- if ($this->hasGroupSupport()) {
- return api_get_course_id().'-'.api_get_session_id().'-'.api_get_group_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)
- {
- if (!isset($meeting['id'])) {
- return '';
- }
- 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)
- {
- if (!isset($meeting['id'])) {
- return '';
- }
- 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)
- {
- if (!isset($meeting['id'])) {
- return null;
- }
- 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)
- {
- if (!isset($meeting['id'])) {
- return '';
- }
- return api_get_path(WEB_PLUGIN_PATH).'bbb/listing.php?'.$this->getUrlParams().'&action=delete_record&id='.$meeting['id'];
- }
- /**
- * @param array $meeting
- * @param array $recordInfo
- *
- * @return string
- */
- public function regenerateRecordUrl($meeting, $recordInfo)
- {
- if ($this->plugin->get('allow_regenerate_recording') !== 'true') {
- return '';
- }
- if (!isset($meeting['id'])) {
- return '';
- }
- if (empty($recordInfo) || (!empty($recordInfo['recordId']) && !isset($recordInfo['recordId']))) {
- return '';
- }
- return api_get_path(WEB_PLUGIN_PATH).'bbb/listing.php?'.$this->getUrlParams().
- '&action=regenerate_record&id='.$meeting['id'].'&record_id='.$recordInfo['recordId'];
- }
- /**
- * @param array $meeting
- * @return string
- */
- public function copyToRecordToLinkTool($meeting)
- {
- if (!isset($meeting['id'])) {
- return '';
- }
- return api_get_path(WEB_PLUGIN_PATH).
- 'bbb/listing.php?'.$this->getUrlParams().'&action=copy_record_to_link_tool&id='.$meeting['id'];
- }
- /**
- * Get the meeting info from DB by its name
- * @param string $name
- *
- * @return array
- */
- public function findMeetingByName($name)
- {
- $meetingData = Database::select(
- '*',
- 'plugin_bbb_meeting',
- array('where' => array('meeting_name = ? AND status = 1 ' => $name)),
- 'first'
- );
- return $meetingData;
- }
- /**
- * Get the meeting info from DB by its name
- * @param int $id
- *
- * @return array
- */
- public function getMeeting($id)
- {
- $meetingData = Database::select(
- '*',
- 'plugin_bbb_meeting',
- array('where' => array('id = ?' => $id)),
- 'first'
- );
- return $meetingData;
- }
- /**
- * @param int $meetingId
- * @return array
- */
- public function findConnectedMeetingParticipants($meetingId)
- {
- $meetingData = Database::select(
- '*',
- 'plugin_bbb_room',
- array('where' => array('meeting_id = ? AND in_at IS NOT NULL' => $meetingId))
- );
- $participantIds = [];
- $return = [];
- foreach ($meetingData as $participantInfo) {
- if (in_array($participantInfo['participant_id'], $participantIds)) {
- continue;
- }
- $participantIds[] = $participantInfo['participant_id'];
- $return[] = [
- 'id' => $participantInfo['id'],
- 'meeting_id' => $participantInfo['meeting_id'],
- 'participant' => api_get_user_entity($participantInfo['participant_id']),
- 'in_at' => $participantInfo['in_at'],
- 'out_at' => $participantInfo['out_at']
- ];
- }
- return $return;
- }
- /**
- * @param int $meetingId
- * @param int $userId
- *
- * @return array
- */
- public function getMeetingParticipantInfo($meetingId, $userId)
- {
- $meetingData = Database::select(
- '*',
- 'plugin_bbb_room',
- array('where' => array('meeting_id = ? AND participant_id = ?' => [$meetingId, $userId])),
- 'first'
- );
- if ($meetingData) {
- return $meetingData;
- }
- return [];
- }
- /**
- * @param array $meetingInfo
- * @param array $recordInfo
- * @param bool $isGlobal
- * @param bool $isAdminReport
- * @return array
- */
- private function getActionLinks(
- $meetingInfo,
- $recordInfo,
- $isGlobal = false,
- $isAdminReport = false
- ) {
- $isVisible = $meetingInfo['visibility'] != 0;
- $linkVisibility = $isVisible
- ? Display::url(
- Display::return_icon('visible.png', get_lang('MakeInvisible')),
- $this->unPublishUrl($meetingInfo)
- )
- : Display::url(
- Display::return_icon('invisible.png', get_lang('MakeVisible')),
- $this->publishUrl($meetingInfo)
- );
- $links = [];
- if (empty($recordInfo)) {
- if (!$isAdminReport) {
- $links[] = Display::url(
- Display::return_icon('delete.png', get_lang('Delete')),
- $this->deleteRecordUrl($meetingInfo)
- );
- $links[] = $linkVisibility;
- return $links;
- } else {
- $links[] = Display::url(
- Display::return_icon('course_home.png', get_lang('GoToCourse')),
- $this->getListingUrl()
- );
- return $links;
- }
- }
- if (!$isGlobal) {
- $links[] = Display::url(
- Display::return_icon('link.gif', get_lang('UrlMeetingToShare')),
- $this->copyToRecordToLinkTool($meetingInfo)
- );
- $links[] = Display::url(
- Display::return_icon('agenda.png', get_lang('AddToCalendar')),
- $this->addToCalendarUrl($meetingInfo, $recordInfo)
- );
- }
- $hide = $this->plugin->get('disable_download_conference_link') === 'true' ? true : false;
- if ($hide == false) {
- if ($meetingInfo['has_video_m4v']) {
- $links[] = Display::url(
- Display::return_icon('save.png', get_lang('DownloadFile')),
- $recordInfo['playbackFormatUrl'].'/capture.m4v',
- ['target' => '_blank']
- );
- } else {
- $links[] = Display::url(
- Display::return_icon('save.png', get_lang('DownloadFile')),
- '#',
- [
- 'id' => "btn-check-meeting-video-{$meetingInfo['id']}",
- 'class' => 'check-meeting-video',
- 'data-id' => $meetingInfo['id']
- ]
- );
- }
- }
- if (!empty($recordInfo)) {
- $links[] = Display::url(
- Display::return_icon('reload.png', get_lang('RegenerateRecord')),
- $this->regenerateRecordUrl($meetingInfo, $recordInfo)
- );
- }
- if (!$isAdminReport) {
- $links[] = Display::url(
- Display::return_icon('delete.png', get_lang('Delete')),
- $this->deleteRecordUrl($meetingInfo)
- );
- $links[] = $linkVisibility;
- } else {
- $links[] = Display::url(
- Display::return_icon('course_home.png', get_lang('GoToCourse')),
- $this->getListingUrl()
- );
- }
- return $links;
- }
- /**
- * @param int $meetingId
- * @param string $videoUrl
- * @return bool|int
- */
- public function updateMeetingVideoUrl($meetingId, $videoUrl)
- {
- return Database::update(
- 'plugin_bbb_meeting',
- ['video_url' => $videoUrl],
- ['id = ?' => intval($meetingId)]
- );
- }
- /**
- * Check if the meeting has a capture.m4v video file. If exists then the has_video_m4v field is updated
- * @param int $meetingId
- * @return bool
- */
- public function checkDirectMeetingVideoUrl($meetingId)
- {
- $meetingInfo = Database::select(
- '*',
- 'plugin_bbb_meeting',
- [
- 'where' => ['id = ?' => intval($meetingId)]
- ],
- 'first'
- );
- if (!isset($meetingInfo['video_url'])) {
- return false;
- }
- $hasCapture = SocialManager::verifyUrl($meetingInfo['video_url'].'/capture.m4v');
- if ($hasCapture) {
- return Database::update(
- 'plugin_bbb_meeting',
- ['has_video_m4v' => true],
- ['id = ?' => intval($meetingId)]
- );
- }
- return $hasCapture;
- }
- /**
- * @param array $userInfo
- * @return bool
- */
- public static function showGlobalConferenceLink($userInfo)
- {
- if (empty($userInfo)) {
- return false;
- }
- $setting = api_get_plugin_setting('bbb', 'enable_global_conference');
- $settingLink = api_get_plugin_setting('bbb', 'enable_global_conference_link');
- if ($setting === 'true' && $settingLink === 'true') {
- //$content = Display::url(get_lang('LaunchVideoConferenceRoom'), $url);
- $allowedRoles = api_get_plugin_setting(
- 'bbb',
- 'global_conference_allow_roles'
- );
- if (api_is_platform_admin()) {
- $userInfo['status'] = PLATFORM_ADMIN;
- }
- $showGlobalLink = true;
- if (!empty($allowedRoles)) {
- if (!in_array($userInfo['status'], $allowedRoles)) {
- $showGlobalLink = false;
- }
- }
- return $showGlobalLink;
- }
- }
- }
|