*/ // name of the language file that needs to be included $language_file = 'admin'; $cidReset = true; require_once '../inc/global.inc.php'; $this_section = SECTION_PLATFORM_ADMIN; api_protect_global_admin_script(); if (!api_get_multiple_access_url()) { header('Location: index.php'); exit; } /* Global constants and variables */ $form_sent = 0; $first_letter_user = ''; $first_letter_course = ''; $courses = array (); $url_list = array(); $users = array(); $tbl_access_url_rel_user = Database :: get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER); $tbl_access_url = Database :: get_main_table(TABLE_MAIN_ACCESS_URL); $tbl_user = Database :: get_main_table(TABLE_MAIN_USER); /* Header */ $tool_name = get_lang('AddUsersToURL'); $interbreadcrumb[] = array ('url' => 'index.php', 'name' => get_lang('PlatformAdmin')); $interbreadcrumb[] = array ('url' => 'access_urls.php', 'name' => get_lang('MultipleAccessURLs')); /* MAIN CODE */ Display :: display_header($tool_name); echo '
'; echo Display::url(Display::return_icon('edit.gif',get_lang('EditUsersToURL'),''), api_get_path(WEB_CODE_PATH).'admin/access_url_edit_users_to_url.php">'); echo '
'; api_display_tool_title($tool_name); if ($_POST['form_sent']) { $form_sent = $_POST['form_sent']; $users = is_array($_POST['user_list']) ? $_POST['user_list'] : array() ; $url_list = is_array($_POST['url_list']) ? $_POST['url_list'] : array() ; $first_letter_user = $_POST['first_letter_user']; foreach($users as $key => $value) { $users[$key] = intval($value); } if ($form_sent == 1) { if ( count($users) == 0 || count($url_list) == 0) { Display :: display_error_message(get_lang('AtLeastOneUserAndOneURL')); //header('Location: access_urls.php?action=show_message&message='.get_lang('AtLeastOneUserAndOneURL')); } else { UrlManager::add_users_to_urls($users,$url_list); Display :: display_confirmation_message(get_lang('UsersBelongURL')); //header('Location: access_urls.php?action=show_message&message='.get_lang('UsersBelongURL')); } } } /* Display GUI */ if (empty($first_letter_user)) { $sql = "SELECT count(*) as nb_users FROM $tbl_user"; $result = Database::query($sql); $num_row = Database::fetch_array($result); if($num_row['nb_users']>1000) { //if there are too much users to gracefully handle with the HTML select list, // assign a default filter on users names $first_letter_user = 'A'; } unset($result); } $first_letter_user = Database::escape_string($first_letter_user); $target_name = api_sort_by_first_name() ? 'firstname' : 'lastname'; $target_name = 'lastname'; $sql = "SELECT user_id,lastname,firstname,username FROM $tbl_user WHERE ".$target_name." LIKE '".$first_letter_user."%' OR ".$target_name." LIKE '".api_strtolower($first_letter_user)."%' ORDER BY ". (count($users) > 0 ? "(user_id IN(".implode(',', $users).")) DESC," : "")." ".$target_name; $result = Database::query($sql); $db_users = Database::store_result($result); unset($result); $sql = "SELECT id, url FROM $tbl_access_url WHERE active=1 ORDER BY url"; $result = Database::query($sql); $db_urls = Database::store_result($result); unset($result); ?>


  :