2010-08-31 09:27:22 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
// Pandora FMS - http://pandorafms.com
|
|
|
|
// ==================================================
|
2011-03-17 Raul Mateos <raulofpandora@gmail.com>
* extensions/dbmanager.php, extensions/pandora_logs.php, general/*.php,
index.php, ajax.php, operation/search_*.php, operation/menu.php,
operation/extensions.php, godmode/menu.php, godmode/extensions.php,
admin_access_logs.php: Cleaned code and updated page disclaimers.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4108 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-03-17 23:01:01 +01:00
|
|
|
// Copyright (c) 2005-2011 Artica Soluciones Tecnologicas
|
|
|
|
// Please see http://pandorafms.org for full contribution list
|
2010-08-31 09:27:22 +02:00
|
|
|
|
|
|
|
// This program is free software; you can redistribute it and/or
|
2011-03-23 19:48:26 +01:00
|
|
|
// modify it under the terms of the GNU General Public License
|
2011-03-17 Raul Mateos <raulofpandora@gmail.com>
* extensions/dbmanager.php, extensions/pandora_logs.php, general/*.php,
index.php, ajax.php, operation/search_*.php, operation/menu.php,
operation/extensions.php, godmode/menu.php, godmode/extensions.php,
admin_access_logs.php: Cleaned code and updated page disclaimers.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4108 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-03-17 23:01:01 +01:00
|
|
|
// as published by the Free Software Foundation; version 2
|
|
|
|
|
2010-08-31 09:27:22 +02:00
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2011-03-17 Raul Mateos <raulofpandora@gmail.com>
* extensions/dbmanager.php, extensions/pandora_logs.php, general/*.php,
index.php, ajax.php, operation/search_*.php, operation/menu.php,
operation/extensions.php, godmode/menu.php, godmode/extensions.php,
admin_access_logs.php: Cleaned code and updated page disclaimers.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4108 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-03-17 23:01:01 +01:00
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2010-08-31 09:27:22 +02:00
|
|
|
// GNU General Public License for more details.
|
|
|
|
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
$searchAgents = check_acl($config['id_user'], 0, "AR");
|
|
|
|
|
|
|
|
$selectNameUp = '';
|
|
|
|
$selectNameDown = '';
|
|
|
|
$selectOsUp = '';
|
|
|
|
$selectOsDown = '';
|
|
|
|
$selectIntervalUp = '';
|
|
|
|
$selectIntervalDown = '';
|
|
|
|
$selectGroupUp = '';
|
|
|
|
$selectGroupDown = '';
|
|
|
|
$selectLastContactUp = '';
|
|
|
|
$selectLastContactDown = '';
|
|
|
|
|
|
|
|
switch ($sortField) {
|
|
|
|
case 'name':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$selectNameUp = $selected;
|
|
|
|
$order = array('field' => 'nombre', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case 'down':
|
|
|
|
$selectNameDown = $selected;
|
|
|
|
$order = array('field' => 'nombre', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'os':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$selectOsUp = $selected;
|
|
|
|
$order = array('field' => 'id_os', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case 'down':
|
|
|
|
$selectOsDown = $selected;
|
|
|
|
$order = array('field' => 'id_os', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'interval':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$selectIntervalUp = $selected;
|
|
|
|
$order = array('field' => 'intervalo', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case 'down':
|
|
|
|
$selectIntervalDown = $selected;
|
|
|
|
$order = array('field' => 'intervalo', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'group':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$selectGroupUp = $selected;
|
|
|
|
$order = array('field' => 'id_grupo', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case 'down':
|
|
|
|
$selectGroupDown = $selected;
|
|
|
|
$order = array('field' => 'id_grupo', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'last_contact':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$selectLastContactUp = $selected;
|
|
|
|
$order = array('field' => 'ultimo_contacto', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case 'down':
|
|
|
|
$selectLastContactDown = $selected;
|
|
|
|
$order = array('field' => 'ultimo_contacto', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$selectNameUp = $selected;
|
|
|
|
$selectNameDown = '';
|
|
|
|
$selectOsUp = '';
|
|
|
|
$selectOsDown = '';
|
|
|
|
$selectIntervalUp = '';
|
|
|
|
$selectIntervalDown = '';
|
|
|
|
$selectGroupUp = '';
|
|
|
|
$selectGroupDown = '';
|
|
|
|
$selectLastContactUp = '';
|
|
|
|
$selectLastContactDown = '';
|
|
|
|
$order = array('field' => 'nombre', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
$agents = false;
|
|
|
|
if ($searchAgents) {
|
2011-02-18 16:13:34 +01:00
|
|
|
$userGroups = get_user_groups($config['id_user'], 'AR', false);
|
|
|
|
$id_userGroups = array_keys($userGroups);
|
|
|
|
|
2011-01-24 14:09:48 +01:00
|
|
|
$sql = "
|
2011-01-27 13:27:06 +01:00
|
|
|
FROM tagente AS t1
|
|
|
|
INNER JOIN tgrupo AS 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 (
|
2011-02-18 16:13:34 +01:00
|
|
|
" . implode(',', $id_userGroups) . "
|
2011-01-27 13:27:06 +01:00
|
|
|
)
|
|
|
|
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 (
|
|
|
|
t1.nombre COLLATE utf8_general_ci LIKE '%%" . $stringSearchSQL . "%%' OR
|
|
|
|
t2.nombre COLLATE utf8_general_ci LIKE '%%" . $stringSearchSQL . "%%'
|
|
|
|
)
|
2011-01-26 19:02:01 +01:00
|
|
|
";
|
2011-01-24 14:09:48 +01:00
|
|
|
|
|
|
|
|
|
|
|
$select = "SELECT t1.id_agente, t1.ultimo_contacto, t1.nombre, t1.id_os, t1.intervalo, t1.id_grupo, t1.disabled";
|
|
|
|
$limit = " ORDER BY " . $order['field'] . " " . $order['order'] .
|
|
|
|
" LIMIT " . $config['block_size'] . " OFFSET " . get_parameter ('offset',0);
|
|
|
|
|
|
|
|
$agents = process_sql($select . $sql . $limit);
|
2010-08-31 09:27:22 +02:00
|
|
|
|
|
|
|
if($agents !== false) {
|
2011-01-24 14:09:48 +01:00
|
|
|
$totalAgents = get_db_row_sql('SELECT COUNT(id_agente) AS agent_count ' . $sql);
|
2010-08-31 09:27:22 +02:00
|
|
|
|
2011-01-24 14:09:48 +01:00
|
|
|
$totalAgents = $totalAgents['agent_count'];
|
2010-08-31 09:27:22 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (!$agents) {
|
2011-01-25 11:47:40 +01:00
|
|
|
echo "<br><div class='nf'>" . __("Zero results found") . "</div>\n";
|
2010-08-31 09:27:22 +02:00
|
|
|
}
|
|
|
|
else {
|
2011-01-25 11:47:40 +01:00
|
|
|
$table->cellpadding = 4;
|
|
|
|
$table->cellspacing = 4;
|
|
|
|
$table->width = "98%";
|
|
|
|
$table->class = "databox";
|
|
|
|
|
2011-02-07 10:58:37 +01:00
|
|
|
$table->head = array ();
|
|
|
|
$table->head[0] = __('Agent') . ' ' .
|
|
|
|
'<a href="index.php?search_category=agents&keywords=' . $config['search_keywords'] . '&head_search_keywords=abc&offset=' . $offset . '&sort_field=name&sort=up">' . print_image("images/sort_up.png", true, array("style" => $selectNameUp)) . '</a>' .
|
|
|
|
'<a href="index.php?search_category=agents&keywords=' . $config['search_keywords'] . '&head_search_keywords=abc&offset=' . $offset . '&sort_field=name&sort=down">' . print_image("images/sort_down.png", true, array("style" => $selectNameDown)) . '</a>';
|
|
|
|
$table->head[1] = __('OS'). ' ' .
|
|
|
|
'<a href="index.php?search_category=agents&keywords=' . $config['search_keywords'] . '&head_search_keywords=abc&offset=' . $offset . '&sort_field=os&sort=up">' . print_image("images/sort_up.png", true, array("style" => $selectOsUp)) . '</a>' .
|
|
|
|
'<a href="index.php?search_category=agents&keywords=' . $config['search_keywords'] . '&head_search_keywords=abc&offset=' . $offset . '&sort_field=os&sort=down">' . print_image("images/sort_down.png", true, array("style" => $selectOsDown)) . '</a>';
|
|
|
|
$table->head[2] = __('Interval'). ' ' .
|
|
|
|
'<a href="index.php?search_category=agents&keywords=' . $config['search_keywords'] . '&head_search_keywords=abc&offset=' . $offset . '&sort_field=interval&sort=up">' . print_image("images/sort_up.png", true, array("style" => $selectIntervalUp)) . '</a>' .
|
|
|
|
'<a href="index.php?search_category=agents&keywords=' . $config['search_keywords'] . '&head_search_keywords=abc&offset=' . $offset . '&sort_field=interval&sort=down">' . print_image("images/sort_down.png", true, array("style" => $selectIntervalDown)) . '</a>';
|
|
|
|
$table->head[3] = __('Group'). ' ' .
|
|
|
|
'<a href="index.php?search_category=agents&keywords=' . $config['search_keywords'] . '&head_search_keywords=abc&offset=' . $offset . '&sort_field=group&sort=up">' . print_image("images/sort_up.png", true, array("style" => $selectGroupUp)) . '</a>' .
|
|
|
|
'<a href="index.php?search_category=agents&keywords=' . $config['search_keywords'] . '&head_search_keywords=abc&offset=' . $offset . '&sort_field=group&sort=down">' . print_image("images/sort_down.png", true, array("style" => $selectGroupDown)) . '</a>';
|
2011-01-25 11:47:40 +01:00
|
|
|
$table->head[4] = __('Modules');
|
|
|
|
$table->head[5] = __('Status');
|
|
|
|
$table->head[6] = __('Alerts');
|
|
|
|
$table->head[7] = __('Last contact'). ' ' .
|
2011-02-07 10:58:37 +01:00
|
|
|
'<a href="index.php?search_category=agents&keywords=' . $config['search_keywords'] . '&head_search_keywords=abc&offset=' . $offset . '&sort_field=last_contact&sort=up">' . print_image("images/sort_up.png", true, array("style" => $selectLastContactUp)) . '</a>' .
|
|
|
|
'<a href="index.php?search_category=agents&keywords=' . $config['search_keywords'] . '&head_search_keywords=abc&offset=' . $offset . '&sort_field=last_contact&sort=down">' . print_image("images/sort_down.png", true, array("style" => $selectLastContactDown)) . '</a>';
|
2011-01-25 11:47:40 +01:00
|
|
|
$table->head[8] = '';
|
|
|
|
|
|
|
|
$table->align = array ();
|
|
|
|
$table->align[0] = "left";
|
|
|
|
$table->align[1] = "center";
|
|
|
|
$table->align[2] = "center";
|
|
|
|
$table->align[3] = "center";
|
|
|
|
$table->align[4] = "center";
|
|
|
|
$table->align[5] = "center";
|
|
|
|
$table->align[6] = "center";
|
|
|
|
$table->align[7] = "right";
|
|
|
|
$table->align[8] = "center";
|
|
|
|
|
|
|
|
$table->data = array ();
|
|
|
|
|
|
|
|
foreach ($agents as $agent) {
|
|
|
|
$agent_info = get_agent_module_info ($agent["id_agente"]);
|
2010-08-31 09:27:22 +02:00
|
|
|
|
2011-01-25 11:47:40 +01:00
|
|
|
$modulesCell = '<b>'. $agent_info["modules"] . '</b>';
|
|
|
|
if ($agent_info["monitor_alertsfired"] > 0)
|
|
|
|
$modulesCell .= ' : <span class="orange">'.$agent_info["monitor_alertsfired"].'</span>';
|
|
|
|
if ($agent_info["monitor_normal"] > 0)
|
|
|
|
$modulesCell .= '</b> : <span class="green">'.$agent_info["monitor_normal"].'</span>';
|
|
|
|
if ($agent_info["monitor_warning"] > 0)
|
|
|
|
$modulesCell .= ' : <span class="yellow">'.$agent_info["monitor_warning"].'</span>';
|
|
|
|
if ($agent_info["monitor_critical"] > 0)
|
|
|
|
$modulesCell .= ' : <span class="red">'.$agent_info["monitor_critical"].'</span>';
|
|
|
|
if ($agent_info["monitor_unknown"] > 0)
|
|
|
|
$modulesCell .= ' : <span class="grey">'.$agent_info["monitor_unknown"].'</span>';
|
2010-08-31 09:27:22 +02:00
|
|
|
|
2011-01-25 11:47:40 +01:00
|
|
|
if ($agent['disabled']) {
|
2011-04-13 18:11:02 +02:00
|
|
|
$cellName = "<em>" . ui_print_agent_name ($agent["id_agente"], true, "upper") . ui_print_help_tip(__('Disabled'), true) . "</em>";
|
2011-01-25 11:47:40 +01:00
|
|
|
}
|
|
|
|
else {
|
2011-04-13 18:11:02 +02:00
|
|
|
$cellName = ui_print_agent_name ($agent["id_agente"], true, "upper");
|
2011-01-25 11:47:40 +01:00
|
|
|
}
|
2010-08-31 09:27:22 +02:00
|
|
|
|
2011-01-25 11:47:40 +01:00
|
|
|
$last_time = strtotime ($agent["ultimo_contacto"]);
|
|
|
|
$now = time ();
|
|
|
|
$diferencia = $now - $last_time;
|
2011-04-13 18:11:02 +02:00
|
|
|
$time = ui_print_timestamp ($last_time, true);
|
2011-01-25 11:47:40 +01:00
|
|
|
$time_style = $time;
|
|
|
|
if ($diferencia > ($agent["intervalo"] * 2))
|
|
|
|
$time_style = '<b><span style="color: #ff0000">'.$time.'</span></b>';
|
2010-11-05 10:57:53 +01:00
|
|
|
|
2011-01-25 11:47:40 +01:00
|
|
|
$manage_agent = '';
|
|
|
|
if (check_acl ($config['id_user'], $agent['id_grupo'], "AW")) {
|
|
|
|
$manage_agent = '<a href="index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente='. $agent["id_agente"] . '">' .
|
2011-03-17 Raul Mateos <raulofpandora@gmail.com>
* extensions/dbmanager.php, extensions/pandora_logs.php, general/*.php,
index.php, ajax.php, operation/search_*.php, operation/menu.php,
operation/extensions.php, godmode/menu.php, godmode/extensions.php,
admin_access_logs.php: Cleaned code and updated page disclaimers.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4108 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-03-17 23:01:01 +01:00
|
|
|
print_image("images/setup.png", true, array("title" => __('Manage'), "alt" => __('Manage'))) . '</a>';
|
2010-08-31 09:27:22 +02:00
|
|
|
}
|
2011-01-25 11:47:40 +01:00
|
|
|
|
|
|
|
array_push($table->data, array(
|
|
|
|
$cellName,
|
2011-04-13 18:11:02 +02:00
|
|
|
ui_print_os_icon ($agent["id_os"], false, true),
|
2011-01-25 11:47:40 +01:00
|
|
|
$agent['intervalo'],
|
2011-04-13 18:11:02 +02:00
|
|
|
ui_print_group_icon ($agent["id_grupo"], true),
|
2011-01-25 11:47:40 +01:00
|
|
|
$modulesCell,
|
|
|
|
$agent_info["status_img"],
|
|
|
|
$agent_info["alert_img"],
|
|
|
|
$time_style, $manage_agent));
|
|
|
|
}
|
|
|
|
|
|
|
|
echo "<br />";
|
2011-04-13 18:11:02 +02:00
|
|
|
ui_pagination ($totalAgents);
|
2011-01-25 11:47:40 +01:00
|
|
|
print_table ($table);
|
|
|
|
unset($table);
|
2011-04-13 18:11:02 +02:00
|
|
|
ui_pagination ($totalAgents);
|
2010-08-31 09:27:22 +02:00
|
|
|
}
|
|
|
|
?>
|