%PDF- %PDF-
Direktori : /home2/vacivi36/ava/mod/bigbluebuttonbn/ |
Current File : //home2/vacivi36/ava/mod/bigbluebuttonbn/guest.php |
<?php // This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /** * Guest access implementation * * @package mod_bigbluebuttonbn * @copyright 2022 onwards, Blindside Networks Inc * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @author Laurent David (laurent [at] call-learning [dt] fr) */ use mod_bigbluebuttonbn\form\guest_login; use mod_bigbluebuttonbn\local\exceptions\server_not_available_exception; use mod_bigbluebuttonbn\local\proxy\bigbluebutton_proxy; use mod_bigbluebuttonbn\meeting; use mod_bigbluebuttonbn\plugin; require(__DIR__.'/../../config.php'); global $PAGE, $OUTPUT, $DB, $SITE; // Note here that we do not use require_login as the $CFG->forcelogin would prevent guest user from accessing this page. $PAGE->set_course($SITE); // Intialise the page and run through the setup. $uid = required_param('uid', PARAM_ALPHANUMEXT); $bbid = $DB->get_field('bigbluebuttonbn', 'id', ['guestlinkuid' => trim($uid)]); if (empty($bbid)) { throw new moodle_exception('guestaccess_activitynotfound', 'mod_bigbluebuttonbn'); } $instance = \mod_bigbluebuttonbn\instance::get_from_instanceid($bbid); // Prevent access to this page if the guest access has been disabled on this instance. if (!$instance->is_guest_allowed()) { throw new moodle_exception('guestaccess_feature_disabled', 'mod_bigbluebuttonbn'); } // Get the guest matching guest access link. $PAGE->set_url('/mod/bigbluebuttonbn/guest.php', ['uid' => $uid]); $title = $instance->get_course()->shortname . ': ' . format_string($instance->get_meeting_name()); $PAGE->set_title($title); $PAGE->set_heading($title); $PAGE->set_pagelayout('standard'); $form = new guest_login(null, ['uid' => $uid, 'instance' => $instance]); // Specific for the tests: we allow to set the password in the form here. if (defined('BEHAT_SITE_RUNNING')) { $form->set_data(['password' => optional_param('password', '', PARAM_RAW)]); } if ($data = $form->get_data()) { $username = $data->username; try { $meeting = new meeting($instance); // As the meeting doesn't exist, we raise an exception. if (!empty($meeting->get_meeting_info()->createtime)) { $url = $meeting->get_guest_join_url($username); redirect($url); } else { \core\notification::add( get_string('guestaccess_meeting_not_started', 'mod_bigbluebuttonbn'), \core\output\notification::NOTIFY_ERROR ); } } catch (server_not_available_exception $e) { bigbluebutton_proxy::handle_server_not_available($instance); } } echo $OUTPUT->header(); echo $form->render(); echo $OUTPUT->footer();