0) { CourseManager::unsubscribe_user($user_ids, $_SESSION['_course']['sysCode']); $message = get_lang('UsersUnsubscribed'); } } } } } 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); $session_id = 0; $is_western_name_order = api_is_western_name_order(PERSON_NAME_DATA_EXPORT); $data = array(); $a_users = array(); if ($_configuration['multiple_access_urls']) { $current_access_url_id = api_get_current_access_url_id(); } // users subscribed to the course through a session if (api_get_setting('use_session_mode') == 'true') { $session_id = intval($_SESSION['id_session']); $table_session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER); $sql_query = "SELECT DISTINCT user.user_id, ".($is_western_name_order ? "user.firstname, user.lastname" : "user.lastname, user.firstname").", user.email, user.official_code FROM $table_session_course_user as session_course_user, $table_users as user "; if ($_configuration['multiple_access_urls']) { $sql_query .= ' , '.Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER).' au '; } $sql_query .="WHERE course_code = '$currentCourseID' AND session_course_user.id_user = user.user_id "; if ($session_id != 0) { $sql_query .= ' AND id_session = '.$session_id; } if ($_configuration['multiple_access_urls']) { $sql_query .= " AND user.user_id = au.user_id AND access_url_id = $current_access_url_id "; } $sql_query .= $sort_by_first_name ? ' ORDER BY user.firstname, user.lastname' : ' ORDER BY user.lastname, user.firstname'; $rs = Database::query($sql_query); while ($user = Database:: fetch_array($rs, 'ASSOC')) { $data[] = $user; //$user_infos = Database :: get_user_info_from_id($user['user_id']); $a_users[$user['user_id']] = $user; } } 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.email, user.official_code FROM $table_course_user as course_user, $table_users as user"; if ($_configuration['multiple_access_urls']) { $sql_query .= ' , '.Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER).' au '; } $sql_query .= "WHERE course_code = '$currentCourseID' AND course_user.relation_type<>".COURSE_RELATION_TYPE_RRHH." AND course_user.user_id = user.user_id "; if ($_configuration['multiple_access_urls']) { $sql_query .= " AND user.user_id = au.user_id AND access_url_id = $current_access_url_id "; } $sql_query .= ($sort_by_first_name ? "ORDER BY user.firstname, user.lastname" : "ORDER BY user.lastname, user.firstname"); $rs = Database::query($sql_query); while ($user = Database::fetch_array($rs, 'ASSOC')) { $data[] = $user; $a_users[$user['user_id']] = $user; } } switch ($_GET['type']) { case 'csv' : Export::export_table_csv($a_users); exit; case 'xls' : Export::export_table_xls($a_users); exit; } } } } // end if allowed to edit if (api_is_allowed_to_edit(null, true)) { // Unregister user from course if ($_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 '.$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.course_code = "'.$currentCourseID.'"'; $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'], $_SESSION['_course']['sysCode']); $message = get_lang('UserUnsubscribed'); } else { $message = get_lang('ThisStudentIsSubscribeThroughASession'); } } } } // end if allowed to edit /* ============================================================================== FUNCTIONS ============================================================================== */ function display_user_search_form() { echo '
'; echo get_lang("SearchForUser") . "  "; echo ''; echo ''; echo '
'; } /** * This function displays a list if users for each virtual course linked to the current * real course. * * defines globals * * @version 1.0 * @author Roan Embrechts * @todo users from virtual courses always show "-" for the group related output. Edit and statistics columns are disabled * for these users, for now. */ function show_users_in_virtual_courses() { global $_course, $_user, $origin; $real_course_code = $_course['sysCode']; $real_course_info = Database::get_course_info($real_course_code); $user_subscribed_virtual_course_list = CourseManager::get_list_of_virtual_courses_for_specific_user_and_real_course($_user['user_id'], $real_course_code); $number_of_virtual_courses = count($user_subscribed_virtual_course_list); $row = 0; $column_header[$row++] = "ID"; $column_header[$row++] = get_lang("FullUserName"); $column_header[$row++] = get_lang("Role"); $column_header[$row++] = get_lang("Group"); if (api_is_allowed_to_edit()) { $column_header[$row++] = get_lang("Tutor"); } if (api_is_allowed_to_edit()) { $column_header[$row++] = get_lang("CourseManager"); } if (!is_array($user_subscribed_virtual_course_list)) { return; } foreach ($user_subscribed_virtual_course_list as $virtual_course) { $virtual_course_code = $virtual_course["code"]; $virtual_course_user_list = CourseManager::get_user_list_from_course_code($virtual_course_code); $message = get_lang("RegisteredInVirtualCourse")." ".$virtual_course["title"]."  (".$virtual_course["code"].")"; echo "
"; echo "

".$message."

"; $properties["width"] = "100%"; $properties["cellspacing"] = "1"; Display::display_complex_table_header($properties, $column_header); foreach ($virtual_course_user_list as $this_user) { $user_id = $this_user["user_id"]; $loginname = $this_user["username"]; $lastname = $this_user["lastname"]; $firstname = $this_user["firstname"]; $status = $this_user["status"]; $role = $this_user["role"]; if ($status == "1") { $status = get_lang("CourseManager"); } else { $status = " - "; } $full_name = api_get_person_name($firstname, $lastname); if ($lastname == '' || $firstname == '') { $full_name = $loginname; } $user_info_hyperlink = "".$full_name.""; $row = 0; $table_row[$row++] = $user_id; $table_row[$row++] = $user_info_hyperlink; //Full name $table_row[$row++] = $role; //Description $table_row[$row++] = " - "; //Group, for the moment groups don't work for students in virtual courses if (api_is_allowed_to_edit()) { $table_row[$row ++] = " - "; //Tutor column $table_row[$row ++] = $status; //Course Manager column } Display::display_table_row(null, $table_row, true); } Display::display_table_footer(); } } if (!$is_allowed_in_course) { api_not_allowed(true); } /* ----------------------------------------------------------- Header ----------------------------------------------------------- */ if ($origin != 'learnpath') { 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"); } else { ?> "; // the action links $actions .= ''.Display::return_icon('csv.gif', get_lang('ExportAsCSV')).' '.get_lang('ExportAsCSV').' '; $actions .= ''.Display::return_icon('excel.gif', get_lang('ExportAsXLS')).' '.get_lang('ExportAsXLS').' '; if (api_get_setting('allow_user_course_subscription_by_course_admin') == 'true') { $actions .= ''.Display::return_icon('add_user_big.gif',get_lang("SubscribeUserToCourse")).' '.get_lang("SubscribeUserToCourse").' '; $actions .= "".Display::return_icon('add_teacher_big.gif', get_lang("SubscribeUserToCourseAsTeacher"))." ".get_lang("SubscribeUserToCourseAsTeacher")." "; } $actions .= "".Display::return_icon('group.gif', get_lang("GroupUserManagement"))." ".get_lang("GroupUserManagement").""; if (api_get_setting('use_session_mode') == 'false') { $actions .= ' '.get_lang('Classes').''; } // 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 (1) // platform setting api_get_setting('subscribe_user_by_coach') { if (!api_is_allowed_to_edit() && $is_courseTutor) { echo "
"; echo ''.Display::return_icon('add_user_big.gif',get_lang("SubscribeUserToCourse")).' '.get_lang("SubscribeUserToCourse").''; echo "
"; } }*/ /* -------------------------------------- DISPLAY USERS LIST -------------------------------------- Also shows a "next page" button if there are more than 50 users. There's a bug in here somewhere - some users count as more than one if they are in more than one group --> code for > 50 users should take this into account (Roan, Feb 2004) */ if (CourseManager::has_virtual_courses_from_code($course_id, $user_id)) { $real_course_code = $_course['sysCode']; $real_course_info = Database::get_course_info($real_course_code); $message = get_lang("RegisteredInRealCourse")." ".$real_course_info["title"]."  (".$real_course_info["official_code"].")"; echo "

".$message."

"; } /* ============================================================================== DISPLAY LIST OF USERS ============================================================================== */ /** * * Get the users to display on the current page. */ function get_number_of_users() { $counter = 0; if (!empty($_SESSION["id_session"])){ $a_course_users = CourseManager :: get_user_list_from_course_code($_SESSION['_course']['id'], true, $_SESSION['id_session']); } else { $a_course_users = CourseManager :: get_user_list_from_course_code($_SESSION['_course']['id'], false); } foreach ($a_course_users as $user_id => $o_course_user) { if ((isset($_GET['keyword']) && search_keyword($o_course_user['firstname'], $o_course_user['lastname'], $o_course_user['username'], $o_course_user['official_code'], $_GET['keyword'])) || !isset($_GET['keyword']) || empty($_GET['keyword'])) { $counter++; } } return $counter; } function search_keyword($firstname, $lastname, $username, $official_code, $keyword) { if (api_strripos($firstname, $keyword) !== false || api_strripos($lastname, $keyword) !== false || api_strripos($username, $keyword) !== false || api_strripos($official_code, $keyword) !== false) { return true; } else { return false; } } /** * Get the users to display on the current page. */ function get_user_data($from, $number_of_items, $column, $direction) { global $origin; global $is_western_name_order; global $sort_by_first_name; $a_users = array(); // limit if (!isset($_GET['keyword']) || empty($_GET['keyword'])) { $limit = 'LIMIT '.intval($from).','.intval($number_of_items); } if (!in_array($direction, array('ASC', 'DESC'))) { $direction = 'ASC'; } // order by if (api_is_allowed_to_edit()) { $column--; } switch ($column) { case 1: 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 2: 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: $order_by = 'ORDER BY user.official_code '.$direction; break; default: if ($sort_by_first_name) { $order_by = 'ORDER BY user.firstname '.$direction.', user.lastname '.$direction; } else { $order_by = 'ORDER BY user.lastname '.$direction.', user.firstname '.$direction; } break; } if (!empty($_SESSION["id_session"])) { $a_course_users = CourseManager :: get_user_list_from_course_code($_SESSION['_course']['id'], true, $_SESSION['id_session'], $limit, $order_by); } else { $a_course_users = CourseManager :: get_user_list_from_course_code($_SESSION['_course']['id'], false, 0, $limit, $order_by); } foreach ($a_course_users as $user_id => $o_course_user) { if ((isset ($_GET['keyword']) && search_keyword($o_course_user['firstname'], $o_course_user['lastname'], $o_course_user['username'], $o_course_user['official_code'], $_GET['keyword'])) || !isset($_GET['keyword']) || empty($_GET['keyword'])) { $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; 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['role']; $temp[] = implode(', ', $groups_name); //Group $temp[] = $o_course_user['official_code']; // deprecated feature 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)) { $temp[] = get_lang('CourseManager'); } elseif (isset($o_course_user['tutor_id']) && $o_course_user['tutor_id'] == 1) { $temp[] = get_lang('Tutor'); } else { $temp[] = '-'; } $temp[] = $o_course_user['active']; $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[] = $photo; 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['role']; $temp[] = implode(', ', $groups_name);//Group $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='right'; } if ($active=='0') { $action='AccountInactive'; $image='wrong'; } 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 = '
'.get_lang(ucfirst($action)).'
'; } 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, $_user, $_course, $is_allowed_to_track, $charset; $result="
"; if ($is_allowed_to_track) { $result .= ''.get_lang('Tracking').' '; } if (api_is_allowed_to_edit(null, true)) { if (api_get_setting('allow_user_course_subscription_by_course_admin') == 'true') { // edit $result .= ''.get_lang('Edit').' '; // unregister if ($user_id != $_user['user_id']) { $result .= ''.get_lang('; } else { $result .= ''.get_lang('; } } } $result .= "
"; return $result; } $default_column = ($is_western_name_order xor $sort_by_first_name) ? 3 : 2; $default_column = api_is_allowed_to_edit() ? 2 : 1; $table = new SortableTable('user_list', 'get_number_of_users', 'get_user_data', $default_column); $parameters['keyword'] = Security::remove_XSS($_GET['keyword']); $table->set_additional_parameters($parameters); $header_nr = 0; if (api_is_allowed_to_edit(null, true)) { if (api_get_setting('allow_user_course_subscription_by_course_admin') == 'true') { $table->set_header($header_nr++, '', false); } } $table->set_header($header_nr++, get_lang('Photo'), false); 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('Description'), false); $table->set_header($header_nr++, get_lang('GroupSingle'), false); $table->set_header($header_nr++, get_lang('OfficialCode')); if (api_is_allowed_to_edit(null, true)) { // deprecated feature //$table->set_header($header_nr++, get_lang('Tutor'), false); $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(8, 'active_filter'); } else { $table->set_column_filter(7, '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'); } } $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' && $is_courseAdmin && api_is_allowed_to_edit() && $origin != 'learnpath') { // only course administrators see this line echo "
", "
", get_lang("CourseAdministratorOnly"), " : ", "", "
", "
\n"; } //User list of the virtual courses linked to this course. //show_users_in_virtual_courses($is_allowed_to_track); /* ============================================================================== FOOTER ============================================================================== */ if ($origin != 'learnpath') { Display::display_footer(); }