. -------------------------------------------------------------------------- */ // ---------------------------------------------------------------------- // Original Author of file: Olivier Moron // Purpose of file: // ---------------------------------------------------------------------- // Direct access to file if (strpos($_SERVER['PHP_SELF'], "dropdownUsers.php")) { include ("../../../inc/includes.php"); header("Content-Type: text/html; charset=UTF-8"); Html::header_nocache(); } if (!defined('GLPI_ROOT')) { die("Can not access directly to this file"); } Session::checkLoginUser(); $PM_DB = new PluginProcessmakerDB; $dbu = new DbUtils; if (!isset($_REQUEST['right'])) { $_REQUEST['right'] = "all"; } // Default view : Nobody if (!isset($_REQUEST['all'])) { $_REQUEST['all'] = 0; } $used = []; if (isset($_REQUEST['used']) && is_array($_REQUEST['used'])) { $used = $_REQUEST['used']; } if (!isset($_REQUEST['value'])) { $_REQUEST['value'] = 0; } $one_item = -1; if (isset($_REQUEST['_one_id'])) { $one_item = $_REQUEST['_one_id']; } if (!isset($_REQUEST['page'])) { $_REQUEST['page'] = 1; $_REQUEST['page_limit'] = $CFG_GLPI['dropdown_max']; } if ($one_item < 0) { $start = ($_REQUEST['page'] - 1) * $_REQUEST['page_limit']; $searchText = isset($_REQUEST['searchText']) ? $_REQUEST['searchText'] : ""; $res = PluginProcessmakerUser::getSqlSearchResult( $_REQUEST['specific_tags'], false, $_REQUEST['right'], $_REQUEST["entity_restrict"], $_REQUEST['value'], $used, $searchText, $start, $_REQUEST['page_limit']); } else { $res = $DB->request([ 'FIELDS' => 'glpi_users.*', 'DISTINCT' => true, 'FROM' => 'glpi_users', 'WHERE' => [ 'glpi_users.id' => $one_item ] ]); } $users = []; // Count real items returned $count = 0; foreach ($res as $data) { $users[$data["id"]] = $dbu->formatUserName($data["id"], $data["name"], $data["realname"], $data["firstname"], 0) . " (" . $data["name"] . ")"; $logins[$data["id"]] = $data["name"]; } $datas = []; // Display first if empty search if ($_REQUEST['page'] == 1 && empty($_REQUEST['searchText'])) { if (($one_item < 0) || ($one_item == 0)) { if ($_REQUEST['all'] == 0) { array_push($datas, ['id' => 0, 'text' => Dropdown::EMPTY_VALUE]); } else if ($_REQUEST['all'] == 1) { array_push($datas, ['id' => 0, 'text' => __('All')]); } } } if (count($users)) { foreach ($users as $ID => $output) { $title = sprintf('%1$s - %2$s', $output, $logins[$ID]); array_push($datas, ['id' => $ID, 'text' => $output, 'title' => $title]); $count++; } } if (($one_item >= 0) && isset($datas[0])) { echo json_encode($datas[0]); } else { $ret['results'] = $datas; $ret['count'] = $count; echo json_encode($ret); }