0)
$filter = " WHERE id_grupo = ". $id_group;
else {
$groups_orig = get_user_groups();
$a = 0;
$groups = array_keys($groups_orig);
$filter = " WHERE id_grupo IN (". implode(',', $groups) .")";
}
$agents = get_db_all_rows_sql("SELECT id_agente, nombre FROM tagente". $filter);
echo json_encode($agents);
return;
}
if ($get_agent_json) {
$id_agent = (int) get_parameter ('id_agent');
$agent = get_db_row ('tagente', 'id_agente', $id_agent);
echo json_encode ($agent);
return;
}
if ($get_agent_modules_json_for_multiple_agents_id) {
$idAgents = get_parameter('id_agent');
$nameModules = get_db_all_rows_sql('SELECT nombre, id_agente_modulo FROM tagente_modulo WHERE id_agente IN (' . implode(',', $idAgents) . ')');
echo json_encode($nameModules);
return;
}
if ($get_agent_modules_json_for_multiple_agents) {
$idAgents = get_parameter('id_agent');
$nameModules = get_db_all_rows_sql('SELECT DISTINCT(nombre) FROM tagente_modulo t1 WHERE delete_pending = 0 AND id_agente IN (' . implode(',', $idAgents) . ') AND (SELECT count(nombre) FROM tagente_modulo t2 WHERE delete_pending = 0 AND t1.nombre = t2.nombre AND id_agente IN (' . implode(',', $idAgents) . ')) = (' . count($idAgents) . ')');
$result = array();
foreach($nameModules as $nameModule) {
$result[] = $nameModule['nombre'];
}
echo json_encode($result);
return;
}
if ($get_agent_modules_json) {
$id_agent = (int) get_parameter ('id_agent');
$filter = (string) get_parameter ('filter');
$fields = (string) get_parameter ('fields');
$indexed = (bool) get_parameter ('indexed', true);
$agentName = (string) get_parameter ('agent_name', null);
if ($agentName != null) {
$search = array();
$search['name'] = $agentName;
}
else
$search = false;
/* Get all agents if no agent was given */
if ($id_agent == 0)
$id_agent = array_keys (get_group_agents (array_keys (get_user_groups ()), $search, "none"));
$agent_modules = get_agent_modules ($id_agent,
($fields != '' ? explode (',', $fields) : "*"),
($filter != '' ? $filter : false), $indexed);
//Hack to translate text "any" in PHP to javascript
//$agent_modules['any_text'] = __('Any');
echo json_encode ($agent_modules);
return;
}
if ($get_agent_status_tooltip) {
$id_agent = (int) get_parameter ('id_agent');
$agent = get_db_row ('tagente', 'id_agente', $id_agent);
echo '
';
echo ' ';
echo printTruncateText($agent['nombre'],25,false,true,false).'
';
echo ''.__('Main IP').': '.$agent['direccion'].'
';
echo ''.__('Group').': ';
echo ' ';
echo get_group_name ($agent['id_grupo']).'
';
echo ''.__('Last contact').': '.human_time_comparation($agent['ultimo_contacto']).'
';
echo ''.__('Last remote contact').': '.human_time_comparation($agent['ultimo_contacto_remoto']).'
';
$sql = sprintf ('SELECT tagente_modulo.descripcion, tagente_modulo.nombre
FROM tagente_estado, tagente_modulo
WHERE tagente_modulo.id_agente = %d
AND tagente_modulo.id_tipo_modulo in (2, 6, 9, 18, 21, 100)
AND tagente_estado.id_agente_modulo = tagente_modulo.id_agente_modulo
AND tagente_modulo.disabled = 0
AND tagente_estado.estado = 1', $id_agent);
$bad_modules = get_db_all_rows_sql ($sql);
$sql = sprintf ('SELECT COUNT(*)
FROM tagente_modulo
WHERE id_agente = %d
AND disabled = 0
AND id_tipo_modulo in (2, 6, 9, 18, 21, 100)', $id_agent);
$total_modules = get_db_sql ($sql);
if ($bad_modules === false)
$size_bad_modules = 0;
else
$size_bad_modules = sizeof ($bad_modules);
// Modules down
if ($size_bad_modules > 0) {
echo ''.__('Monitors down').': '.$size_bad_modules.' / '.$total_modules;
echo '';
foreach ($bad_modules as $module) {
echo '- ';
$name = $module['nombre'];
echo substr ($name, 0, 25);
if (strlen ($name) > 25)
echo '(...)';
echo '
';
}
echo '
';
}
// Alerts (if present)
$sql = sprintf ('SELECT COUNT(talert_template_modules.id)
FROM talert_template_modules, tagente_modulo, tagente
WHERE tagente.id_agente = %d
AND tagente.disabled = 0
AND tagente.id_agente = tagente_modulo.id_agente
AND tagente_modulo.disabled = 0
AND tagente_modulo.id_agente_modulo = talert_template_modules.id_agent_module
AND talert_template_modules.times_fired > 0 ',
$id_agent);
$alert_modules = get_db_sql ($sql);
if ($alert_modules > 0){
$sql = sprintf ('SELECT tagente_modulo.nombre, talert_template_modules.last_fired
FROM talert_template_modules, tagente_modulo, tagente
WHERE tagente.id_agente = %d
AND tagente.disabled = 0
AND tagente.id_agente = tagente_modulo.id_agente
AND tagente_modulo.disabled = 0
AND tagente_modulo.id_agente_modulo = talert_template_modules.id_agent_module
AND talert_template_modules.times_fired > 0 ',
$id_agent);
$alerts = get_db_all_rows_sql ($sql);
echo ''.__('Alerts fired').':';
echo "";
foreach ($alerts as $alert_item) {
echo '- ';
$name = $alert_item[0];
echo substr ($name, 0, 25);
if (strlen ($name) > 25)
echo '(...)';
echo " ";
echo human_time_comparation($alert_item[1]);
echo '
';
}
echo '
';
}
return;
}
if ($get_agentmodule_status_tooltip) {
$id_module = (int) get_parameter ('id_module');
$module = get_db_row ('tagente_modulo', 'id_agente_modulo', $id_module);
echo '';
echo ' ';
echo printTruncateText($module['nombre'],25,false,true,false).'
';
echo ''.__('Type').': ';
$agentmoduletype = get_agentmodule_type ($module['id_agente_modulo']);
echo get_moduletype_name ($agentmoduletype).' ';
echo '
';
echo ''.__('Module group').': ';
$modulegroup = get_modulegroup_name (get_agentmodule_modulegroup ($module['id_agente_modulo']));
if($modulegroup === false){
echo __('None').'
';
}
else{
echo $modulegroup.'
';
}
echo ''.__('Agent').': ';
echo printTruncateText(get_agentmodule_agent_name ($module['id_agente_modulo']),25,false,true,false).'
';
return;
}
if ($get_group_status_tooltip) {
$id_group = (int) get_parameter ('id_group');
$group = get_db_row ('tgrupo', 'id_grupo', $id_group);
echo ' ';
echo printTruncateText($group['nombre'],25,false,true,false).'
';
echo ''.__('Parent').': ';
if($group['parent'] == 0) {
echo __('None').'
';
}
else {
$group_parent = get_db_row ('tgrupo', 'id_grupo', $group['parent']);
echo ' ';
echo $group_parent['nombre'].'
';
}
echo ''.__('Sons').': ';
$groups_sons = get_db_all_fields_in_table ('tgrupo', 'parent', $group['id_grupo']);
if($groups_sons === false){
echo __('None').'
';
}
else{
echo '
';
foreach($groups_sons as $group_son) {
echo ' ';
echo $group_son['nombre'].'
';
}
}
return;
}
return;
}
$id_agente = (int) get_parameter ("id_agente", 0);
if (empty ($id_agente)) {
return;
}
$agent = get_db_row ('tagente', 'id_agente', $id_agente);
// get group for this id_agente
$id_grupo = $agent['id_grupo'];
if (! give_acl ($config['id_user'], $id_grupo, "AR")) {
audit_db ($config['id_user'], $_SERVER['REMOTE_ADDR'], "ACL Violation",
"Trying to access (read) to agent ".get_agent_name($id_agente));
include ("general/noaccess.php");
return;
}
// Check for Network FLAG change request
if (isset($_GET["flag"])) {
if ($_GET["flag"] == 1 && give_acl ($config['id_user'], $id_grupo, "AW")) {
$sql = "UPDATE tagente_modulo SET flag=1 WHERE id_agente_modulo = ".$_GET["id_agente_modulo"];
process_sql ($sql);
}
}
// Check for Network FLAG change request
if (isset($_GET["flag_agent"])){
if ($_GET["flag_agent"] == 1 && give_acl ($config['id_user'], $id_grupo, "AW")) {
$sql ="UPDATE tagente_modulo SET flag=1 WHERE id_agente = ". $id_agente;
process_sql ($sql);
}
}
if ($agent["icon_path"]) {
$icon = get_agent_icon_map($agent["id_agente"], true);
}
else {
$icon = 'images/bricks.png';
}
$tab = get_parameter ("tab", "main");
/* Manage tab */
$managetab = "";
if (give_acl ($config['id_user'],$id_grupo, "AW")) {
$managetab['text'] =''
. print_image("images/setup.png", true, array("title=" => __('Manage')))
. '';
if ($tab == 'manage')
$managetab['active'] = true;
else
$managetab['active'] = false;
}
/* Main tab */
$maintab['text'] = ''
. print_image("images/monitor.png", true, array("title=" => __('Main')))
. '';
if ($tab == 'main')
$maintab['active'] = true;
else
$maintab['active'] = false;
/* Data */
$datatab['text']= ''
. print_image("images/lightbulb.png", true, array("title=" => __('Data')))
. '';
if (($tab == 'data') OR ($tab == 'data_view'))
$datatab['active'] = true;
else
$datatab['active'] = false;
/* Alert tab */
$alerttab['text'] = ''
. print_image("images/bell.png", true, array("title=" => __('Alerts')))
. '';
if ($tab == 'alert')
$alerttab['active'] = true;
else
$alerttab['active'] = false;
/* SLA view */
$slatab['text']= ''
. print_image("images/images.png", true, array("title=" => __('S.L.A.')))
. '';
if ($tab == 'sla') {
$slatab['active'] = true;
} else {
$slatab['active'] = false;
}
/* Inventory */
$inventorytab = enterprise_hook ('inventory_tab');
if ($inventorytab == -1)
$inventorytab = "";
/* Collection */
$collectiontab = enterprise_hook('collection_tab');
if ($collectiontab == -1)
$collectiontab = "";
/* Group tab */
$grouptab['text']= ''
. print_image("images/agents_group.png", true, array( "title=" => __('Group')))
. '';
$grouptab['active']=false;
/* GIS tab */
$gistab="";
if ($config['activate_gis']) {
$gistab['text'] = ''
.print_image("images/world.png", true, array( "title=" => __('GIS data')))
.'';
if ($tab == 'gis')
$gistab['active'] = true;
else
$gistab['active'] = false;
}
$onheader = array('manage' => $managetab, 'main' => $maintab, 'data' => $datatab, 'alert' => $alerttab, 'sla' => $slatab, 'inventory' => $inventorytab, 'collection' => $collectiontab, 'group' => $grouptab, 'gis' => $gistab);
print_page_header (__('Agent').' - '.mb_substr(get_agent_name($id_agente),0,25), $icon, false, "", false, $onheader);
switch ($tab) {
case "gis":
require ("gis_view.php");
break;
case "sla":
require ("sla_view.php");
break;
case "manage":
require ("estado_generalagente.php");
break;
case "main":
require ("estado_generalagente.php");
require ("estado_monitores.php");
require ("alerts_status.php");
require ("status_events.php");
break;
case "data_view":
require ("datos_agente.php");
break;
case "data":
require ("estado_ultimopaquete.php");
break;
case "alert":
require ("alerts_status.php");
break;
case "inventory":
enterprise_include ('operation/agentes/agent_inventory.php');
break;
case 'collection':
enterprise_include ('operation/agentes/collection_view.php');
break;
}
?>