getData($course_info['real_id'], $session_id); if (!empty($data)) { $course_legal = $data['content']; } $userData = $plugin->getUserAcceptedLegal( $user_id, $course_info['real_id'], $session_id ); if (isset($_GET['web_agreement_link'])) { $plugin->saveUserMailLegal( $_GET['web_agreement_link'], $user_id, $course_info['real_id'], $session_id ); } } // Build the form $form = new FormValidator('legal', 'GET', api_get_self().'?course_code='.$course_code.'&session_id='.$session_id); $pluginMessage = null; $hideForm = false; if ($pluginLegal && isset($userData) && !empty($userData)) { if ($userData['web_agreement'] == 1) { if (empty($userData['mail_agreement'])) { $pluginMessage = Display::return_message( $plugin->get_lang('You need to confirm your agreement to our terms first. Please check your e-mail.') ); $hideForm = true; } } } $form->addElement('header', get_lang('Legal agreement for this course')); $form->addElement('label', null, $course_legal); if ($pluginLegal && !empty($plugin)) { $form->addElement('label', null, $plugin->getCurrentFile($course_info['real_id'], $session_id)); } $form->addElement('hidden', 'course_code', $course_code); $form->addElement('hidden', 'session_id', $session_id); $form->addElement('checkbox', 'accept_legal', null, get_lang('Accept legal agreement')); $form->addButtonSave(get_lang('Accept')); $variable = 'accept_legal_'.$user_id.'_'.$course_info['real_id'].'_'.$session_id; $url = api_get_course_url($course_code, $session_id); if ($form->validate()) { $accept_legal = $form->exportValue('accept_legal'); if ($accept_legal == 1) { CourseManager::save_user_legal($user_id, $course_code, $session_id); if (api_check_user_access_to_legal($course_info['visibility'])) { Session::write($variable, true); } if ($pluginLegal) { header('Location:'.$url); exit; } } } $user_pass_open_course = false; if (api_check_user_access_to_legal($course_info['visibility']) && Session::read($variable)) { $user_pass_open_course = true; } if (empty($session_id)) { if (CourseManager::is_user_subscribed_in_course($user_id, $course_code) || api_check_user_access_to_legal($course_info['visibility']) ) { $user_accepted_legal = CourseManager::is_user_accepted_legal( $user_id, $course_code ); if ($user_accepted_legal || $user_pass_open_course) { //Redirect to course home header('Location: '.$url); exit; } } else { api_not_allowed(); } } else { if (api_is_platform_admin()) { header('Location: '.$url); } $userStatus = SessionManager::get_user_status_in_course_session($user_id, $course_info['real_id'], $session_id); if (isset($userStatus) || api_check_user_access_to_legal($course_info['visibility'])) { $user_accepted_legal = CourseManager::is_user_accepted_legal( $user_id, $course_code, $session_id ); if ($user_accepted_legal || $user_pass_open_course) { // Redirect to course session home. header('Location: '.$url); exit; } } else { api_not_allowed(); } } Display :: display_header(); echo $pluginMessage; if ($hideForm == false) { $form->display(); } Display :: display_footer();