'; $anyfound = false; $table = new stdClass(); $table->id = 'summary'; $table->width = '98%'; $table->style = []; $table->style[0] = 'font-weight: bold; text-align: left;'; $table->style[1] = 'font-weight: bold; text-align: left;'; $table->style[2] = 'font-weight: bold; text-align: left;'; $table->style[3] = 'font-weight: bold; text-align: left;'; $table->style[4] = 'font-weight: bold; text-align: left;'; $table->style[5] = 'font-weight: bold; text-align: left;'; $table->style[6] = 'font-weight: bold; text-align: left;'; $table->style[7] = 'font-weight: bold; text-align: left;'; $table->style[8] = 'font-weight: bold; text-align: left;'; $table->style[9] = 'font-weight: bold; text-align: left;'; $table->style[10] = 'font-weight: bold; text-align: left;'; $table->style[11] = 'font-weight: bold; text-align: left;'; $table->style[13] = 'font-weight: bold; text-align: left;'; $table->style[14] = 'font-weight: bold; text-align: left;'; $table->style[15] = 'font-weight: bold; text-align: left;'; // Get total agents. $userGroups = users_get_groups($config['id_user'], 'AR', false); $id_userGroups = array_keys($userGroups); $has_secondary = enterprise_hook('agents_is_using_secondary_groups'); $stringSearchSQL = str_replace('&', '&', $stringSearchSQL); $sql = "SELECT DISTINCT taddress_agent.id_agent FROM taddress INNER JOIN taddress_agent ON taddress.id_a = taddress_agent.id_a WHERE taddress.ip LIKE '$stringSearchSQL'"; $id = db_get_all_rows_sql($sql); if ($id != '') { $aux = $id[0]['id_agent']; $search_sql = " REPLACE(t1.nombre, ' ', ' ') LIKE '".$stringSearchSQL."' OR REPLACE(t2.nombre, ' ', ' ') LIKE '".$stringSearchSQL."' OR REPLACE(t1.alias, ' ', ' ') LIKE '".$stringSearchSQL."' OR REPLACE(t1.comentarios, ' ', ' ') LIKE '".$stringSearchSQL."' OR t1.id_agente =".$aux; $idCount = count($id); if ($idCount >= 2) { for ($i = 1; $i < $idCount; $i++) { $aux = $id[$i]['id_agent']; $search_sql .= " OR t1.id_agente = $aux"; } } } else { $search_sql = " REPLACE(t1.nombre, ' ', ' ') LIKE '".$stringSearchSQL."' OR REPLACE(t2.nombre, ' ', ' ') LIKE '".$stringSearchSQL."' OR REPLACE(t1.direccion, ' ', ' ') LIKE '".$stringSearchSQL."' OR REPLACE(t1.comentarios, ' ', ' ') LIKE '".$stringSearchSQL."' OR REPLACE(t1.alias, ' ', ' ') LIKE '".$stringSearchSQL."'"; } if ($has_secondary === true) { $search_sql .= " OR (tasg.id_group IS NOT NULL AND tasg.id_group IN (SELECT id_grupo FROM tgrupo WHERE REPLACE(nombre, ' ', ' ') LIKE '".$stringSearchSQL."'))"; } $sql = " FROM tagente t1 LEFT JOIN tagent_secondary_group tasg ON t1.id_agente = tasg.id_agent INNER JOIN tgrupo t2 ON t2.id_grupo = t1.id_grupo WHERE ( 1 = ( SELECT is_admin FROM tusuario WHERE id_user = '".$config['id_user']."' ) OR ( t1.id_grupo IN (".implode(',', $id_userGroups).') OR tasg.id_group IN ('.implode(',', $id_userGroups).") ) OR 0 IN ( SELECT id_grupo FROM tusuario_perfil WHERE id_usuario = '".$config['id_user']."' AND id_perfil IN ( SELECT id_perfil FROM tperfil WHERE agent_view = 1 ) ) ) AND ( ".$search_sql.' ) '; $totalAgents = db_get_value_sql( 'SELECT COUNT(DISTINCT id_agente) AS agent_count '.$sql ); $table->data[0][0] = html_print_image('images/agent.png', true, ['title' => __('Agents found'), 'class' => 'invert_filter']); $table->data[0][1] = "".sprintf(__('%s Found'), $totalAgents).''; $table->data[0][2] = html_print_image('images/module.png', true, ['title' => __('Modules found'), 'class' => 'invert_filter']); $table->data[0][3] = "".sprintf(__('%s Found'), $totalModules).''; // ------------------- DISABLED FOR SOME INSTALLATIONS------------------ // ~ $table->data[0][4] = html_print_image ("images/bell.png", true, array ("title" => __('Alerts found'))); // ~ $table->data[0][5] = "" . // ~ sprintf(__("%s Found"), $totalAlerts) . ""; // --------------------------------------------------------------------- $table->data[0][6] = html_print_image('images/input_user.png', true, ['title' => __('Users found')]); $table->data[0][7] = "".sprintf(__('%s Found'), $totalUsers).''; $table->data[0][8] = html_print_image('images/chart_curve.png', true, ['title' => __('Graphs found'), 'class' => 'invert_filter']); $table->data[0][9] = "".sprintf(__('%s Found'), $totalGraphs).''; $table->data[0][10] = html_print_image('images/reporting.png', true, ['title' => __('Reports found'), 'class' => 'invert_filter']); $table->data[0][11] = "".sprintf(__('%s Found'), $totalReports).''; $table->data[0][12] = html_print_image('images/visual_console_green.png', true, ['title' => __('Visual consoles'), 'class' => 'main_menu_icon invert_filter']); $table->data[0][13] = "".sprintf(__('%s Found'), $totalMaps).''; if (enterprise_installed()) { $table->data[0][14] = html_print_image('images/policy@svg.svg', true, ['title' => __('Policies'), 'class' => 'main_menu_icon invert_filter']); $table->data[0][15] = "".sprintf(__('%s Found'), $totalPolicies).''; } html_print_table($table); if ($searchAgents) { echo $list_agents; echo "".__('View all matches').''; } echo '
';