get('tool_enable'); $om_host = $plugin->get('host'); $om_user = $plugin->get('user'); $om_pass = $plugin->get('pass'); $accessUrl = api_get_access_url(api_get_current_access_url_id()); $this->externalType = substr($accessUrl['url'], strpos($accessUrl['url'], '://')+3, -1); if (strcmp($this->externalType, 'localhost') == 0) { $this->externalType = substr(api_get_path(WEB_PATH), strpos(api_get_path(WEB_PATH), '://')+3, -1); } $this->externalType = 'chamilolms.'.$this->externalType; $this->table = \Database::get_main_table('plugin_openmeetings'); if ($om_plugin) { $user_info = api_get_user_info(); $this->user_complete_name = $user_info['complete_name']; $this->user = $om_user; $this->pass = $om_pass; $this->url = $om_host; // Setting OM api define('CONFIG_OPENMEETINGS_USER', $this->user); define('CONFIG_OPENMEETINGS_PASS', $this->pass); define('CONFIG_OPENMEETINGS_SERVER_URL', $this->url); $this->gateway = new \OpenMeetingsGateway($this->url, $this->user, $this->pass); $this->plugin_enabled = $om_plugin; // The room has a name composed of C + course ID + '-' + session ID $this->chamiloCourseId = api_get_course_int_id(); $this->chamiloSessionId = api_get_session_id(); $this->roomName = 'C'.$this->chamiloCourseId.'-'.$this->chamiloSessionId; $return = $this->gateway->loginUser(); if ($return == 0) { $msg = 'Could not initiate session with server through OpenMeetingsGateway::loginUser()'; error_log(__FILE__.'+'.__LINE__.': '.$msg); die($msg); } $this->sessionId = $this->gateway->sessionId; } } /** * 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 isTeacher() { return api_is_course_admin() || api_is_coach() || api_is_platform_admin(); } /** * Login the user with OM Server. This generates a session ID that is * specific to the current user, but that does not require specific user data * * It is similar to opening a PHP session. In fact, the session ID is kept * inside the $_SESSION['openmeetings_session'] session variable * @return bool True if the user is correct and false when is incorrect * @deprecated loginUser now called at object instanciation */ /** function loginUser() { try { //Verifying if there is already an active session if (empty($_SESSION['openmeetings_session'])) { // Login user returns either 0 or >0, depending on the results // Technically, as long as the SOAP user has been configured in OpenMeetings and OpenMeetings is on, this should always succeed. if ($this->gateway->loginUser()) { $this->sessionId = $_SESSION['openmeetings_session'] = $this->gateway->session_id; return true; } else { error_log('loginUser did not succeed'); return false; } } else { $this->sessionId = $_SESSION['openmeetings_session']; return true; } } catch (SoapFault $e) { error_log(__FILE__.'+'.__LINE__.' Warning: We have detected some problems. Fault: '.$e->faultstring); return false; } } */ /* * Creating a Room for the meeting * @return bool True if the user is correct and false when is incorrect */ public function createMeeting($params) { // First, try to see if there is an active room for this course and session. $roomId = null; $meetingData = \Database::select( '*', $this->table, array( 'where' => array( 'c_id = ?' => $this->chamiloCourseId, ' AND session_id = ? ' => $this->chamiloSessionId, ' AND status <> ? ' => 2, ) ), 'first' ); if ($meetingData != false && count($meetingData) > 0) { //error_log(print_r($meetingData,1)); //error_log('Found previous room reference - reusing'); // There has been a room in the past for this course. It should // still be on the server, so update (instead of creating a new one) // This fills the following attributes: status, name, comment, chamiloCourseId, chamiloSessionId $room = new Room(); $room->loadRoomId($meetingData['room_id']); $roomArray = (array)$room; $roomArray['SID'] = $this->sessionId; $roomId = $this->gateway->updateRoomWithModeration($room); if ($roomId != $meetingData['room_id']) { $msg = 'Something went wrong: the updated room ID ('.$roomId.') is not the same as the one we had ('.$meetingData['room_id'].')'; error_log($msg); die($msg); } } else { //error_log('Found no previous room - creating'); $room = new Room(); $room->SID = $this->sessionId; $room->name = $this->roomName; //$room->roomtypes_id = $room->roomtypes_id; $room->comment = urlencode(get_lang('Course').': ' . $params['meeting_name'] . ' - '.api_get_configuration_value('software_name')); //$room->numberOfPartizipants = $room->numberOfPartizipants; $room->ispublic = $room->getString('isPublic', 'false'); //$room->appointment = $room->getString('appointment'); //$room->isDemoRoom = $room->getString('isDemoRoom'); //$room->demoTime = $room->demoTime; //$room->isModeratedRoom = $room->getString('isModeratedRoom'); $roomId = $this->gateway->createRoomWithModAndType($room); } if (!empty($roomId)) { /* // Find the biggest room_id so far, and create a new one if (empty($roomId)) { $roomData = \Database::select('MAX(room_id) as room_id', $this->table, array(), 'first'); $roomId = $roomData['room_id'] + 1; }*/ $params['status'] = '1'; $params['meeting_name'] = $room->name; $params['created_at'] = api_get_utc_datetime(); $params['room_id'] = $roomId; $params['c_id'] = api_get_course_int_id(); $params['session_id'] = api_get_session_id(); $params['record'] = ($room->allowRecording?1:0); $id = \Database::insert($this->table, $params); $this->joinMeeting($id); } else { return -1; } } /** * 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($meetingId) { if (empty($meetingId)) { return false; } $meetingData = \Database::select( '*', $this->table, array('where' => array('id = ? AND status = 1 ' => $meetingId)), 'first' ); if (empty($meetingData)) { if ($this->debug) { error_log("meeting does not exist: $meetingId "); } return false; } $params = array('room_id' => $meetingData['room_id']); $returnVal = $this->setUserObjectAndGenerateRoomHashByURLAndRecFlag($params); $iframe = $this->url . "/?" ."secureHash=" . $returnVal; printf("