0) { CourseManager::unsubscribe_user($user_ids, $courseId); $message = get_lang('UsersUnsubscribed'); } } } } } $user_image_pdf_size = 80; if (api_is_allowed_to_edit(null, true)) { if (isset($_GET['action'])) { switch ($_GET['action']) { case 'export' : $table_course_user = Database::get_main_table(TABLE_MAIN_COURSE_USER); $table_users = Database::get_main_table(TABLE_MAIN_USER); $is_western_name_order = api_is_western_name_order(); $data = array(); $a_users = array(); if (api_is_multiple_url_enabled()) { $current_access_url_id = api_get_current_access_url_id(); } $extra_fields = UserManager::get_extra_user_data(api_get_user_id(), false, false, false, true); $extra_fields = array_keys($extra_fields); $select_email_condition = ''; if (api_get_setting('show_email_addresses') == 'true') { $select_email_condition = ' user.email, '; if ($sort_by_first_name) { $a_users[0] = array('id', get_lang('FirstName'), get_lang('LastName'), get_lang('Username'), get_lang('Email'), get_lang('Phone'), get_lang('OfficialCode'), get_lang('Active')); } else { $a_users[0] = array('id', get_lang('LastName'), get_lang('FirstName'), get_lang('Username'), get_lang('Email'), get_lang('Phone'), get_lang('OfficialCode'), get_lang('Active')); } } else { if ($sort_by_first_name) { $a_users[0] = array('id', get_lang('FirstName'), get_lang('LastName'), get_lang('Username'), get_lang('Phone'), get_lang('OfficialCode'), get_lang('Active')); } else { $a_users[0] = array('id', get_lang('LastName'), get_lang('FirstName'), get_lang('Username'), get_lang('Phone'), get_lang('OfficialCode'), get_lang('Active')); } } $legal = ''; if (isset($course_info['activate_legal']) AND $course_info['activate_legal'] == 1) { $legal = ', legal_agreement'; $a_users[0][] = get_lang('LegalAgreementAccepted'); } if ($_GET['type'] == 'pdf') { if ($is_western_name_order) { $a_users[0] = array('#', get_lang('UserPicture'), get_lang('OfficialCode'), get_lang('FirstName').', '.get_lang('LastName')); } else { $a_users[0] = array('#', get_lang('UserPicture'), get_lang('OfficialCode'), get_lang('LastName').', '.get_lang('FirstName')); } } $a_users[0] = array_merge($a_users[0], $extra_fields); // users subscribed to the course through a session if (api_get_session_id()) { $table_session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER); $table_session_user = Database::get_main_table(TABLE_MAIN_SESSION_USER); $sql_query = "SELECT DISTINCT user.user_id, ".($is_western_name_order ? "user.firstname, user.lastname" : "user.lastname, user.firstname").", user.username, $select_email_condition phone, user.official_code, active $legal FROM $table_session_course_user as session_course_user, $table_users as user, $table_session_user as su"; if (api_is_multiple_url_enabled()) { $sql_query .= ' , '.Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER).' au '; } $sql_query .=" WHERE su.c_id = '$courseId' AND session_course_user.id_user = user.user_id AND su.id_user = session_course_user.id_user AND session_course_user.id_session = su.id_session AND su.moved_to = 0 AND su.moved_status <> ".SessionManager::SESSION_CHANGE_USER_REASON_ENROLLMENT_ANNULATION." AND session_course_user.id_session = $session_id"; if (api_is_multiple_url_enabled()) { $sql_query .= " AND user.user_id = au.user_id AND access_url_id = $current_access_url_id "; } //only users no coaches/teachers $sql_query .= " AND session_course_user.status = 0 "; $sql_query .= $sort_by_first_name ? ' ORDER BY user.firstname, user.lastname' : ' ORDER BY user.lastname, user.firstname'; $rs = Database::query($sql_query); $counter = 1; while ($user = Database:: fetch_array($rs, 'ASSOC')) { if (isset($user['legal_agreement'])) { if ($user['legal_agreement'] == 1) { $user['legal_agreement'] = get_lang('Yes'); } else { $user['legal_agreement'] = get_lang('No'); } } $extra_fields = UserManager::get_extra_user_data($user['user_id'], false, false, false, true); if (!empty($extra_fields)) { foreach($extra_fields as $key => $extra_value) { $user[$key] = $extra_value; } } $data[] = $user; if ($_GET['type'] == 'pdf') { $user_info = api_get_user_info($user['user_id']); $user_image = Display::img($user_info['avatar'], null, array('width' => $user_image_pdf_size.'px')); if ($is_western_name_order) { $user_pdf = array($counter, $user_image, $user['official_code'], $user['firstname'].', '.$user['lastname'] ); } else { $user_pdf = array($counter, $user_image, $user['official_code'], $user['lastname'].', '.$user['firstname'] ); } $a_users[] = $user_pdf; } else { $a_users[] = $user; } $counter++; } } if ($session_id == 0) { // users directly subscribed to the course $table_course_user = Database :: get_main_table(TABLE_MAIN_COURSE_USER); $sql_query = "SELECT DISTINCT user.user_id, ".($is_western_name_order ? "user.firstname, user.lastname" : "user.lastname, user.firstname").", user.username, $select_email_condition phone, user.official_code, active $legal FROM $table_course_user as course_user, $table_users as user "; if (api_is_multiple_url_enabled()) { $sql_query .= ' , '.Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER).' au '; } $sql_query .= " WHERE course_user.c_id = '$courseId' AND course_user.relation_type<>".COURSE_RELATION_TYPE_RRHH." AND course_user.user_id = user.user_id "; if (api_is_multiple_url_enabled()) { $sql_query .= " AND user.user_id = au.user_id AND access_url_id = $current_access_url_id "; } //only users no teachers/coaches $sql_query .= " AND course_user.status = 5 "; $sql_query .= ($sort_by_first_name ? " ORDER BY user.firstname, user.lastname" : " ORDER BY user.lastname, user.firstname"); $rs = Database::query($sql_query); $counter = 1; while ($user = Database::fetch_array($rs, 'ASSOC')) { if (isset($user['legal_agreement'])) { if ($user['legal_agreement'] == 1) { $user['legal_agreement'] = get_lang('Yes'); } else { $user['legal_agreement'] = get_lang('No'); } } $extra_fields = UserManager::get_extra_user_data($user['user_id'], false, false, false, true); if (!empty($extra_fields)) { foreach ($extra_fields as $key => $extra_value) { $user[$key] = $extra_value; } } if ($_GET['type'] == 'pdf') { $user_info = api_get_user_info($user['user_id']); $user_image = Display::img($user_info['avatar'], null, array('width' => $user_image_pdf_size.'px')); if ($is_western_name_order) { $user_pdf = array($counter, $user_image, $user['official_code'], $user['firstname'].', '.$user['lastname'] ); } else { $user_pdf = array($counter, $user_image, $user['official_code'], $user['lastname'].', '.$user['firstname'] ); } $a_users[] = $user_pdf; } else { $a_users[] = $user; } $data[] = $user; $counter++; } } switch ($_GET['type']) { case 'csv' : Export::export_table_csv_utf8($a_users); exit; case 'xls' : Export::export_table_xls($a_users); exit; case 'pdf' : $description = ''; if (api_get_session_id()) { $description .= ''; } $description .= ''; $teachers = CourseManager::get_teacher_list_from_course_code($course_info['real_id']); //If I'm a teacher in this course show just my name if (isset($teachers[$user_id])) { if (!empty($teachers)) { $teacher_info = $teachers[$user_id]; $description .= ''; } } else { //If not show all teachers $teachers = CourseManager::get_teacher_list_from_course_code_to_string($course_info['real_id']); if (!empty($teachers)) { $description .= ''; } } if (!empty($session_id)) { //If I'm a coach $coaches = CourseManager::get_coach_list_from_course_code($course_info['real_id'], $session_id); if (isset($coaches) && isset($coaches[$user_id])) { $user_info = api_get_user_info($user_id); $description .= ''; } else { //If not show everything $teachers = CourseManager::get_coach_list_from_course_code_to_string($course_info['real_id'], $session_id); if (!empty($teachers)) { $description .= ''; } } } $description .= ''; $description .= '
'.get_lang('Session').': '.api_get_session_name(api_get_session_id()).'
'.get_lang('Course').': '.$course_info['name'].'
'.get_lang('Teacher').': '.api_get_person_name($teacher_info['firstname'], $teacher_info['lastname']).'
'.get_lang('Teachers').': '.$teachers.'
'.get_lang('Coach').': '.$user_info['complete_name'].'
'.get_lang('Coachs').': '.$coaches.'
'.get_lang('Date').': '.api_convert_and_format_date(time(), DATE_TIME_FORMAT_LONG).'
'; $header_attributes = array( array('style' => 'width:10px'), array('style' => 'width:30px'), array('style' => 'width:50px'), array('style' => 'width:500px'), ); $params = array( 'add_signatures' => false, 'filename' => get_lang('UserList'), 'pdf_title' => get_lang('StudentList'), 'pdf_description' => $description, 'header_attributes' => $header_attributes ); Export::export_table_pdf($a_users, $params); exit; } } } } // end if allowed to edit if (api_is_allowed_to_edit(null, true)) { // Unregister user from course if (isset($_REQUEST['unregister']) && $_REQUEST['unregister']) { if (isset($_GET['user_id']) && is_numeric($_GET['user_id']) && $_GET['user_id'] != $_user['user_id']) { $user_id = Database::escape_string($_GET['user_id']); $tbl_user = Database::get_main_table(TABLE_MAIN_USER); $tbl_session_rel_course = Database::get_main_table(TABLE_MAIN_SESSION_COURSE); $tbl_session_rel_user = Database::get_main_table(TABLE_MAIN_SESSION_USER); $sql = 'SELECT DISTINCT '.$tbl_user.'.user_id FROM '.$tbl_user.' user INNER JOIN '.$tbl_session_rel_user.' reluser ON user.user_id = reluser.id_user AND reluser.relation_type<>'.SESSION_RELATION_TYPE_RRHH.' INNER JOIN '.$tbl_session_rel_course.' rel_course ON rel_course.id_session = reluser.id_session WHERE user.user_id = "'.$user_id.'" AND rel_course.c_id = "'.$courseId.'"'; $result = Database::query($sql); $row = Database::fetch_array($result, 'ASSOC'); if ($row['user_id'] == $user_id || $row['user_id'] == "") { CourseManager::unsubscribe_user($_GET['user_id'], $courseId); $message = get_lang('UserUnsubscribed'); } else { $message = get_lang('ThisStudentIsSubscribeThroughASession'); } } } } else { //if student can unsubsribe if (isset($_REQUEST['unregister']) && $_REQUEST['unregister'] == 'yes') { if ($course_info['unsubscribe'] == 1) { $user_id = api_get_user_id(); CourseManager::unsubscribe_user($user_id, $courseId); header('Location: '.api_get_path(WEB_PATH).'user_portal.php'); exit; } } } /* FUNCTIONS */ function display_user_search_form() { echo '
'; echo get_lang("SearchForUser") . "  "; echo ''; echo ''; echo '
'; } /* Header */ if (isset($origin) && $origin == 'learnpath') { Display::display_reduced_header(); } else { if (isset($_GET['keyword']) && !empty($_GET['keyword'])) { $interbreadcrumb[] = array ("url" => "user.php", "name" => get_lang("Users")); $tool_name = get_lang('SearchResults'); } else { $tool_name = get_lang('Users'); $origin = 'users'; } Display::display_header($tool_name, "User"); } //statistics event_access_tool(TOOL_USER); /* Setting the permissions for this page */ $is_allowed_to_track = (api_is_course_admin() || $is_courseTutor); // Tool introduction Display::display_introduction_section(TOOL_USER, 'left'); $actions = ''; if ( api_is_allowed_to_edit(null, true)) { echo '
'; // the action links if (api_get_setting('allow_user_course_subscription_by_course_admin') == 'true' or api_is_platform_admin()) { $actions .= ''.Display::return_icon('user_subscribe_course.png',get_lang("SubscribeUserToCourse"),'',ICON_SIZE_MEDIUM).' '; $actions .= "".Display::return_icon('teacher_subscribe_course.png', get_lang("SubscribeUserToCourseAsTeacher"),'',ICON_SIZE_MEDIUM)." "; } $actions .= ''.Display::return_icon('export_csv.png', get_lang('ExportAsCSV'),'',ICON_SIZE_MEDIUM).' '; $actions .= ''.Display::return_icon('export_excel.png', get_lang('ExportAsXLS'),'',ICON_SIZE_MEDIUM).' '; if (api_get_setting('allow_user_course_subscription_by_course_admin') == 'true' or api_is_platform_admin()) { $actions .= ''.Display::return_icon('import_csv.png', get_lang('ImportUsersToACourse'),'',ICON_SIZE_MEDIUM).' '; } $actions .= ''.Display::return_icon('pdf.png', get_lang('ExportToPDF'),'',ICON_SIZE_MEDIUM).' '; $actions .= "".Display::return_icon('group.png', get_lang("GroupUserManagement"),'',ICON_SIZE_MEDIUM).""; if (api_get_setting('allow_user_course_subscription_by_course_admin') == 'true' or api_is_platform_admin()) { $actions .= ' '.get_lang('Classes').''; } //$actions .= ' '.get_lang('SocialGroups').''; // Build search-form $form = new FormValidator('search_user', 'get', '', '', null, false); $renderer = $form->defaultRenderer(); $renderer->setElementTemplate('{element} '); $form->add_textfield('keyword', '', false); $form->addElement('style_submit_button', 'submit', get_lang('SearchButton'), 'class="search"'); $form->addElement('static', 'additionalactions', null, $actions); $form->display(); echo '
'; } if (isset($message)) { Display::display_confirmation_message($message); } /* DISPLAY LIST OF USERS */ /** * * Get the users to display on the current page. */ function get_number_of_users() { $keyword = isset($_GET['keyword']) ? $_GET['keyword'] : null; return CourseManager::get_users_count_in_course(api_get_course_id(), api_get_session_id(), null, null, null, $keyword); } /** * Get the users to display on the current page. */ function get_user_data($from, $number_of_items, $column, $direction) { global $origin; global $course_info; global $is_western_name_order; global $session_id; $a_users = array(); // limit $limit = 'LIMIT '.intval($from).','.intval($number_of_items); if (!in_array($direction, array('ASC', 'DESC'))) { $direction = 'ASC'; } switch ($column) { case 2: //official code $order_by = 'ORDER BY user.official_code '.$direction; break; case 3: if ($is_western_name_order) { $order_by = 'ORDER BY user.firstname '.$direction.', user.lastname '.$direction; } else { $order_by = 'ORDER BY user.lastname '.$direction.', user.firstname '.$direction; } break; case 4: if ($is_western_name_order) { $order_by = 'ORDER BY user.lastname '.$direction.', user.firstname '.$direction; } else { $order_by = 'ORDER BY user.firstname '.$direction.', user.lastname '.$direction; } break; case 5: //username $order_by = 'ORDER BY user.username '.$direction; break; default: if ($is_western_name_order) { $order_by = 'ORDER BY user.lastname '.$direction.', user.firstname '.$direction; } else { $order_by = 'ORDER BY user.firstname '.$direction.', user.lastname '.$direction; } break; } $session_id = api_get_session_id(); $course_code = api_get_course_id(); $keyword = isset($_REQUEST['keyword']) ? $_REQUEST['keyword'] : null; $a_course_users = CourseManager :: get_user_list_from_course_code($course_code, $session_id, $limit, $order_by, null, $keyword); foreach ($a_course_users as $user_id => $o_course_user) { $groups_name = GroupManager :: get_user_group_name($user_id); $temp = array(); if (api_is_allowed_to_edit(null, true)) { //if (api_get_setting('allow_user_course_subscription_by_course_admin') == 'true') { $temp[] = $user_id; //} $image_path = UserManager::get_user_picture_path_by_id($user_id, 'web', false, true); $user_profile = UserManager::get_picture_user($user_id, $image_path['file'], 22, USER_IMAGE_SIZE_SMALL, ' width="22" height="22" '); if (!api_is_anonymous()) { $photo = ''.api_get_person_name($o_course_user['firstname'], $o_course_user['lastname']).''; } else { $photo = ''.api_get_person_name($o_course_user['firstname'], $o_course_user['lastname']).''; } $temp[] = $photo; $temp[] = $o_course_user['official_code']; if ($is_western_name_order) { $temp[] = $o_course_user['firstname']; $temp[] = $o_course_user['lastname']; } else { $temp[] = $o_course_user['lastname']; $temp[] = $o_course_user['firstname']; } $temp[] = $o_course_user['username']; $temp[] = isset($o_course_user['role']) ? $o_course_user['role'] : null; //Description $temp[] = implode(', ', $groups_name); //Group // Status $default_status = '-'; if ((isset($o_course_user['status_rel']) && $o_course_user['status_rel'] == 1) || (isset($o_course_user['status_session']) && $o_course_user['status_session'] == 2)) { $default_status = get_lang('CourseManager'); } elseif (isset($o_course_user['tutor_id']) && $o_course_user['tutor_id'] == 1) { $default_status = get_lang('Tutor'); } $temp[] = $default_status; //Active $temp[] = $o_course_user['active']; //User id for actions $temp[] = $user_id; } else { $image_path = UserManager::get_user_picture_path_by_id($user_id, 'web', false, true); $image_repository = $image_path['dir']; $existing_image = $image_path['file']; if (!api_is_anonymous()) { $photo= ''.api_get_person_name($o_course_user['firstname'], $o_course_user['lastname']).''; } else { $photo= ''.api_get_person_name($o_course_user['firstname'], $o_course_user['lastname']).''; } $temp[] = $user_id; $temp[] = $photo; $temp[] = $o_course_user['official_code']; if ($is_western_name_order) { $temp[] = $o_course_user['firstname']; $temp[] = $o_course_user['lastname']; } else { $temp[] = $o_course_user['lastname']; $temp[] = $o_course_user['firstname']; } $temp[] = $o_course_user['username']; $temp[] = $o_course_user['role']; $temp[] = implode(', ', $groups_name);//Group if ($course_info['unsubscribe'] == 1) { //User id for actions $temp[] = $user_id; } //$temp[] = $o_course_user['official_code']; } $a_users[$user_id] = $temp; } return $a_users; } /** * Build the active-column of the table to lock or unlock a certain user * lock = the user can no longer use this account * @author Patrick Cool , Ghent University * @param int $active the current state of the account * @param int $user_id The user id * @param string $url_params * @return string Some HTML-code with the lock/unlock button */ function active_filter($active, $url_params, $row) { global $_user; if ($active=='1') { $action='AccountActive'; $image='accept'; } if ($active=='0') { $action='AccountInactive'; $image='error'; } $result = ''; if ($row[count($row)-1]<>$_user['user_id']) { // you cannot lock yourself out otherwise you could disable all the accounts including your own => everybody is locked out and nobody can change it anymore. $result = Display::return_icon($image.'.png', get_lang(ucfirst($action)), array(), ICON_SIZE_TINY); } return $result; } /** * Build the modify-column of the table * @param int $user_id The user id * @return string Some HTML-code */ function modify_filter($user_id) { global $origin, $_course, $is_allowed_to_track, $charset, $course_info; $current_user_id = api_get_user_id(); $result = ""; if ($is_allowed_to_track) { $result .= ' '.Display::return_icon('stats.png', get_lang('Tracking')).''; } //if platform admin, show the login_as icon (this drastically shortens // time taken by support to test things out) if (api_is_platform_admin()) { // If not forbidden globally if (empty($_configuration['login_as_forbidden_globally'])) { // If global admin, authorize, otherwise check db setting allows it if (api_is_global_platform_admin() or api_get_setting('login_as_allowed')==='true') { $result .= ' '.Display::return_icon('login_as.gif', get_lang('LoginAs')).'  '; } } } if (api_is_allowed_to_edit(null, true)) { // edit $result .= ''.Display::return_icon('edit.png', get_lang('Edit'),'',ICON_SIZE_SMALL).' '; if (api_get_setting('allow_user_course_subscription_by_course_admin') == 'true' or api_is_platform_admin()) { // unregister if ($user_id != $current_user_id) { $result .= ''.get_lang('Unreg').' '; } else { //$result .= Display::return_icon('unsubscribe_course_na.png', get_lang('Unreg'),'',ICON_SIZE_SMALL).' '; } } } else { //Show buttons for unsubscribe if ($course_info['unsubscribe'] == 1) { if ($user_id == $current_user_id) { $result .= ''.get_lang('Unreg').' '; } } } return $result; } function hide_field() { return null; } $default_column = 3; $table = new SortableTable('user_list', 'get_number_of_users', 'get_user_data', $default_column); $parameters['keyword'] = isset($_GET['keyword']) ? Security::remove_XSS($_GET['keyword']) : null; // Create a sortable table with user-data $parameters['sec_token'] = Security::get_token(); $table->set_additional_parameters($parameters); $header_nr = 0; $table->set_header($header_nr++, '', false); $table->set_header($header_nr++, get_lang('Photo'), false); $table->set_header($header_nr++, get_lang('OfficialCode')); if ($is_western_name_order) { $table->set_header($header_nr++, get_lang('FirstName')); $table->set_header($header_nr++, get_lang('LastName')); } else { $table->set_header($header_nr++, get_lang('LastName')); $table->set_header($header_nr++, get_lang('FirstName')); } $table->set_header($header_nr++, get_lang('LoginName')); // $table->set_header($header_nr++, get_lang('Description'), false); $table->set_header($header_nr++, get_lang('GroupSingle'), false); if (api_is_allowed_to_edit(null, true) && api_get_setting('allow_user_course_subscription_by_course_admin') == 'true') { } else { $table->set_column_filter(0, 'hide_field'); } if (api_is_allowed_to_edit(null, true)) { $table->set_header($header_nr++, get_lang('Status'), false); $table->set_header($header_nr++, get_lang('Active'), false); if (api_get_setting('allow_user_course_subscription_by_course_admin') == 'true') { $table->set_column_filter(9, 'active_filter'); } else { $table->set_column_filter(9, 'active_filter'); } //actions column $table->set_header($header_nr++, get_lang('Action'), false); $table->set_column_filter($header_nr-1, 'modify_filter'); if (api_get_setting('allow_user_course_subscription_by_course_admin') == 'true') { $table->set_form_actions(array('unsubscribe' => get_lang('Unreg')), 'user'); } } else { if ($course_info['unsubscribe'] == 1) { $table->set_header($header_nr++, get_lang('Action'), false); $table->set_column_filter($header_nr-1, 'modify_filter'); } } $table->display(); if (!empty($_GET['keyword']) && !empty($_GET['submit'])) { $keyword_name = Security::remove_XSS($_GET['keyword']); echo '
'.get_lang('SearchResultsFor').' '.$keyword_name.'
'; } if (api_get_setting('allow_user_headings') == 'true' && api_is_course_admin() && api_is_allowed_to_edit() && $origin != 'learnpath') { // only course administrators see this line echo "
", "
", get_lang("CourseAdministratorOnly"), " : ", "", "
", "
\n"; } if ($origin != 'learnpath') { Display::display_footer(); }