403 lines
14 KiB
PHP
403 lines
14 KiB
PHP
|
<?php
|
||
|
|
||
|
// Pandora FMS - the Free monitoring system
|
||
|
// ========================================
|
||
|
// Copyright (c) 2004-2007 Sancho Lerena, slerena@gmail.com
|
||
|
// Main PHP/SQL code development and project architecture and management
|
||
|
// Copyright (c) 2004-2007 Raul Mateos Martin, raulofpandora@gmail.com
|
||
|
// CSS and some PHP additions
|
||
|
// Copyright (c) 2006-2007 Jonathan Barajas, jonathan.barajas[AT]gmail[DOT]com
|
||
|
// Javascript Active Console code.
|
||
|
// Copyright (c) 2006 Jose Navarro <contacto@indiseg.net>
|
||
|
// Additions to Pandora FMS 1.2 graph code and new XML reporting template management
|
||
|
// Copyright (c) 2005-2007 Artica Soluciones Tecnologicas, info@artica.es
|
||
|
//
|
||
|
// This program is free software; you can redistribute it and/or
|
||
|
// modify it under the terms of the GNU General Public License
|
||
|
// as published by the Free Software Foundation; version 2
|
||
|
// This program is distributed in the hope that it will be useful,
|
||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
// GNU General Public License for more details.
|
||
|
// You should have received a copy of the GNU General Public License
|
||
|
// along with this program; if not, write to the Free Software
|
||
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
|
|
||
|
// Load global vars
|
||
|
require("include/config.php");
|
||
|
require("include/functions_reporting.php");
|
||
|
$id_user = $_SESSION["id_usuario"];
|
||
|
|
||
|
if (give_acl ($id_user, 0, "AR") != 1) {
|
||
|
audit_db ($id_user, $REMOTE_ADDR, "ACL Violation",
|
||
|
"Trying to access Agent view (Grouped)");
|
||
|
require ("general/noaccess.php");
|
||
|
exit;
|
||
|
}
|
||
|
echo "<h2>".$lang_label["tactical_view"]."</h2>";
|
||
|
|
||
|
|
||
|
/*
|
||
|
// Get group list that user has access
|
||
|
$mis_grupos = list_group2 ($id_user);
|
||
|
$contador_grupo = 0;
|
||
|
$contador_agente = 0;
|
||
|
$array_index = 0;
|
||
|
|
||
|
// Init final counters
|
||
|
$monitor_checks = 0;
|
||
|
$monitor_ok = 0;
|
||
|
$monitor_bad = 0;
|
||
|
$monitor_unknown =0;
|
||
|
$monitor_alert = 0;
|
||
|
$total_agents = 0;
|
||
|
$data_checks = 0;
|
||
|
$data_unknown =0;
|
||
|
$data_alert = 0;
|
||
|
$data_alert_total = 0;
|
||
|
$monitor_alert_total = 0;
|
||
|
|
||
|
|
||
|
$monitor->checks = 0;
|
||
|
$monitor->ok = 0;
|
||
|
$monitor->bad =0;
|
||
|
$monitor->unknown = 0;
|
||
|
$monitor->alert = 0;
|
||
|
$monitor->alert_total = 0;
|
||
|
|
||
|
$total->agents = 0;
|
||
|
|
||
|
$data->checks = 0;
|
||
|
$data->unknown = 0;
|
||
|
$data->alert = 0;
|
||
|
$data->alert_total= 0;
|
||
|
|
||
|
$ahora=date("Y/m/d H:i:s");
|
||
|
$ahora_sec = strtotime($ahora);
|
||
|
|
||
|
// Prepare data to show
|
||
|
// For each valid group for this user, take data from agent and modules
|
||
|
foreach ($mis_grupos as $migrupo) {
|
||
|
if ($migrupo != "") {
|
||
|
$existen_agentes = 0;
|
||
|
$sql0 = "SELECT COUNT(id_agente) FROM tagente WHERE id_grupo = $migrupo AND disabled = 0";
|
||
|
$result0 = mysql_query ($sql0);
|
||
|
$row0 = mysql_fetch_array ($result0);
|
||
|
$total_agents = $total_agents + $row0[0];
|
||
|
if ($row0[0] > 0)
|
||
|
$existen_agentes = 1;
|
||
|
|
||
|
// SQL Join to get monitor status for agents belong this group
|
||
|
$sql1 = "SELECT tagente.id_agente, tagente_estado.estado, tagente_estado.datos, tagente_estado.current_interval, tagente_estado.utimestamp, tagente_estado.id_agente_modulo FROM tagente, tagente_estado WHERE tagente.disabled = 0 AND tagente.id_grupo = $migrupo AND tagente.id_agente = tagente_estado.id_agente";
|
||
|
if ($result1 = mysql_query ($sql1)){
|
||
|
while ($row1 = mysql_fetch_array ($result1)) {
|
||
|
$id_agente = $row1[0];
|
||
|
$estado = $row1[1];
|
||
|
$datos = $row1[2];
|
||
|
$module_interval = $row1[3];
|
||
|
$seconds = $ahora_sec - $row1[4];
|
||
|
$id_agente_modulo = $row1[5];
|
||
|
if ($estado != 100){
|
||
|
// Monitor check
|
||
|
$monitor_checks++;
|
||
|
if ($seconds >= ($module_interval*2))
|
||
|
$monitor_unknown++;
|
||
|
elseif ($datos != 0) {
|
||
|
$monitor_ok++;
|
||
|
} else {
|
||
|
$monitor_bad++;
|
||
|
}
|
||
|
// Alert
|
||
|
$sql2 = "SELECT times_fired FROM talerta_agente_modulo WHERE id_agente_modulo = $id_agente_modulo";
|
||
|
if ($result2 = mysql_query ($sql2)){
|
||
|
if ($row2 = mysql_fetch_array ($result2)){
|
||
|
$monitor_alert_total++;
|
||
|
if ($row2[0] > 0)
|
||
|
$monitor_alert++;
|
||
|
}
|
||
|
}
|
||
|
} else {
|
||
|
// Data check
|
||
|
if ($seconds >= ($module_interval*2))
|
||
|
$data_unknown++;
|
||
|
$data_checks++;
|
||
|
// Alert
|
||
|
$sql2 = "SELECT times_fired FROM talerta_agente_modulo WHERE id_agente_modulo = $id_agente_modulo";
|
||
|
if ($result2 = mysql_query ($sql2)){
|
||
|
if ($row2 = mysql_fetch_array ($result2)) {
|
||
|
$data_alert_total++;
|
||
|
if ($row2[0] > 0)
|
||
|
$data_alert++;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
*/
|
||
|
$data = general_stats($id_user,0);
|
||
|
$monitor_checks = $data[0];
|
||
|
$monitor_ok = $data[1];
|
||
|
$monitor_bad = $data[2];
|
||
|
$monitor_unknown = $data[3];
|
||
|
$monitor_alert = $data[4];
|
||
|
$total_agents = $data[5];
|
||
|
$data_checks = $data[6];
|
||
|
$data_unknown = $data[7];
|
||
|
$data_alert = $data[8];
|
||
|
$data_alert_total = $data[9];
|
||
|
$monitor_alert_total = $data[10];
|
||
|
|
||
|
$total_checks = $data_checks + $monitor_checks;
|
||
|
|
||
|
// Monitor checks
|
||
|
// ~~~~~~~~~~~~~~~
|
||
|
echo "<table width=700 border=0>";
|
||
|
echo "<tr><td>";
|
||
|
echo "<table class='databox' celldpadding=4 cellspacing=4 width=250>";
|
||
|
echo "<th colspan=2>".$lang_label["monitor_checks"]."</th>";
|
||
|
echo "<tr><td class=datos2><b>"."Monitor checks";
|
||
|
echo "<td class=datos2 style='font: bold 2em Arial, Sans-serif; color: #000000;'>".$monitor_checks;
|
||
|
echo "<tr><td class=datos><b>"."Monitor OK";
|
||
|
echo "<td class=datos style='font: bold 2em Arial, Sans-serif; color: #000000;'>".$monitor_ok;
|
||
|
echo "<tr><td class=datos2><b>"."Monitor BAD";
|
||
|
echo "<td class=datos2 style='font: bold 2em Arial, Sans-serif; color: #ff0000;'>";
|
||
|
if ($monitor_bad > 0)
|
||
|
echo $monitor_bad;
|
||
|
else
|
||
|
echo "-";
|
||
|
echo "<tr><td class=datos><b>"."Monitor Unknown";
|
||
|
echo "<td class=datos style='font: bold 2em Arial, Sans-serif; color: #888;'>";
|
||
|
if ($monitor_unknown > 0)
|
||
|
echo $monitor_unknown;
|
||
|
else
|
||
|
echo "-";
|
||
|
echo "<tr><td class=datos2><b>"."Alerts Fired";
|
||
|
echo "<td class=datos2 style='font: bold 2em Arial, Sans-serif; color: #ff0000;'>";
|
||
|
if ($monitor_alert > 0)
|
||
|
echo $monitor_alert;
|
||
|
else
|
||
|
echo "-";
|
||
|
echo "<tr><td class=datos><b>"."Alerts Total";
|
||
|
echo "<td class=datos style='font: bold 2em Arial, Sans-serif; color: #000000;'>".$monitor_alert_total;
|
||
|
echo "</table>";
|
||
|
|
||
|
// Data checks
|
||
|
// ~~~~~~~~~~~~~~~
|
||
|
echo "<table class='databox' celldpadding=4 cellspacing=4 width=250>";
|
||
|
echo "<th colspan=2>".$lang_label["data_checks"]."</th>";
|
||
|
echo "<tr><td class=datos2><b>"."Data checks";
|
||
|
echo "<td class=datos2 style='font: bold 2em Arial, Sans-serif; color: #000000;'>".$data_checks;
|
||
|
echo "<tr><td class=datos><b>"."Data Unknown";
|
||
|
echo "<td class=datos style='font: bold 2em Arial, Sans-serif; color: #888;'>";
|
||
|
if ($data_unknown > 0)
|
||
|
echo $data_unknown;
|
||
|
else
|
||
|
echo "-";
|
||
|
echo "<tr><td class=datos2><b>"."Alerts Fired";
|
||
|
echo "<td class=datos2 style='font: bold 2em Arial, Sans-serif; color: #ff0000;'>";
|
||
|
if ($data_alert > 0)
|
||
|
echo $data_alert;
|
||
|
else
|
||
|
echo "-";
|
||
|
echo "<tr><td class=datos><b>"."Alerts Total";
|
||
|
echo "<td class=datos style='font: bold 2em Arial, Sans-serif; color: #000000;'>".$data_alert_total;
|
||
|
echo "</table>";
|
||
|
|
||
|
// Summary
|
||
|
// ~~~~~~~~~~~~~~~
|
||
|
echo "<table class='databox' celldpadding=4 cellspacing=4 width=250>";
|
||
|
echo "<th colspan=2>".$lang_label["summary"]."</th>";
|
||
|
echo "<tr><td class=datos2><b>"."Total agents";
|
||
|
echo "<td class=datos2 style='font: bold 2em Arial, Sans-serif; color: #000000;'>".$total_agents;
|
||
|
echo "<tr><td class=datos2><b>"."Total checks";
|
||
|
echo "<td class=datos2 style='font: bold 2em Arial, Sans-serif; color: #000000;'>".$total_checks;
|
||
|
echo "</table>";
|
||
|
|
||
|
echo "<td>";
|
||
|
|
||
|
// Odometer Graph
|
||
|
// ~~~~~~~~~~~~~~~
|
||
|
$monitor_health = format_numeric (($monitor_ok / $monitor_checks) * 100,1);
|
||
|
$data_health = format_numeric ( (($data_checks -($data_unknown + $data_alert)) / $data_checks ) * 100,1);;
|
||
|
$global_health = format_numeric( ((($monitor_ok)+($data_checks -($data_unknown + $data_alert))) / ($data_checks + $monitor_checks) ) * 100, 1);
|
||
|
echo "<h3>".$lang_label["tactical_indicator"]."</h3>";
|
||
|
echo "<img src='reporting/fgraph.php?tipo=odo_tactic&value1=$global_health&value2=$data_health&value3=$monitor_health'>";
|
||
|
|
||
|
|
||
|
|
||
|
// Server information
|
||
|
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
|
|
||
|
$sql='SELECT * FROM tserver';
|
||
|
echo "<h2>".$lang_label["tactical_server_information"]."</h2>";
|
||
|
// Get total modules defined (network)
|
||
|
$sql1='SELECT COUNT(id_agente_modulo) FROM tagente_modulo WHERE id_tipo_modulo > 4';
|
||
|
$result1=mysql_query($sql1);
|
||
|
$row1=mysql_fetch_array($result1);
|
||
|
$total_modules = $row1[0];
|
||
|
|
||
|
// Get total modules defined (data)
|
||
|
$sql1='SELECT COUNT(processed_by_server) FROM tagente_estado WHERE processed_by_server LIKE "%_Data" ';
|
||
|
if ($result1=mysql_query($sql1)){
|
||
|
$row1=mysql_fetch_array($result1);
|
||
|
$total_modules_data = $row1[0];
|
||
|
} else
|
||
|
$total_modules_data = 0;
|
||
|
|
||
|
// Connect DataBase
|
||
|
$result=mysql_query($sql);
|
||
|
if (mysql_num_rows($result)){
|
||
|
echo "<table cellpadding='4' cellspacing='4' witdh='720' class='databox'>";
|
||
|
echo "<tr><th class='datos'>".$lang_label["name"]."</th>";
|
||
|
echo "<th class='datos'>".$lang_label['status']."</th>";
|
||
|
echo "<th class='datos'>".$lang_label['load']."</th>";
|
||
|
echo "<th class='datos'>".$lang_label['modules']."</th>";
|
||
|
echo "<th class='datos'>".$lang_label['lag']."</th>";
|
||
|
$color=1;
|
||
|
while ($row=mysql_fetch_array($result)){
|
||
|
if ($color == 1){
|
||
|
$tdcolor = "datos";
|
||
|
$color = 0;
|
||
|
}
|
||
|
else {
|
||
|
$tdcolor = "datos2";
|
||
|
$color = 1;
|
||
|
}
|
||
|
$id_server = $row["id_server"];
|
||
|
$name = $row["name"];
|
||
|
$address = $row["ip_address"];
|
||
|
$status = $row["status"];
|
||
|
$laststart = $row["laststart"];
|
||
|
$keepalive = $row["keepalive"];
|
||
|
$network_server = $row["network_server"];
|
||
|
$data_server = $row["data_server"];
|
||
|
$snmp_server = $row["snmp_server"];
|
||
|
$recon_server = $row["recon_server"];
|
||
|
$master = $row["master"];
|
||
|
$checksum = $row["checksum"];
|
||
|
$description = $row["description"];
|
||
|
$version = $row["version"];
|
||
|
$modules_server = 0;
|
||
|
if (($network_server == 1) OR ($data_server == 1)){
|
||
|
if ($network_server == 1){
|
||
|
// Get total modules defined for this server (network modules)
|
||
|
$sql1='SELECT * FROM tagente where id_server = '.$row["id_server"];
|
||
|
$result1=mysql_query($sql1);
|
||
|
while ($row1=mysql_fetch_array($result1)){
|
||
|
$sql2='SELECT COUNT(id_agente_modulo) FROM tagente_modulo WHERE id_tipo_modulo > 4 AND id_agente = '.$row1["id_agente"];
|
||
|
$result2=mysql_query($sql2);
|
||
|
$row2=mysql_fetch_array($result2);
|
||
|
$modules_server = $modules_server + $row2[0];
|
||
|
}
|
||
|
}
|
||
|
echo "<tr><td class='$tdcolor'>";
|
||
|
echo "<b>$name</b>";
|
||
|
echo "<td class='$tdcolor' align='middle'>";
|
||
|
if ($status ==0){
|
||
|
echo "<img src='images/dot_red.gif'>";
|
||
|
} else {
|
||
|
echo "<img src='images/dot_green.gif'>";
|
||
|
}
|
||
|
echo "<td class='$tdcolor' align='middle'>";
|
||
|
if (($network_server == 1) OR ($data_server == 1)){
|
||
|
// Progress bar calculations
|
||
|
if ($network_server == 1){
|
||
|
if ($total_modules == 0)
|
||
|
$percentil = 0;
|
||
|
if ($total_modules > 0)
|
||
|
$percentil = $modules_server / ($total_modules / 100);
|
||
|
else
|
||
|
$percentil = 0;
|
||
|
$total_modules_temp = $total_modules;
|
||
|
} else {
|
||
|
if ($total_modules_data == 0)
|
||
|
$percentil = 0;
|
||
|
else
|
||
|
$percentil = $modules_server / ($total_modules_data / 100);
|
||
|
$total_modules_temp = $total_modules_data;
|
||
|
}
|
||
|
} elseif ($recon_server == 1){
|
||
|
|
||
|
$sql2 = "SELECT COUNT(id_rt) FROM trecon_task WHERE id_network_server = $id_server";
|
||
|
$result2=mysql_query($sql2);
|
||
|
$row2=mysql_fetch_array($result2);
|
||
|
$modules_server = $row2[0];
|
||
|
|
||
|
$sql2 = "SELECT COUNT(id_rt) FROM trecon_task";
|
||
|
$result2=mysql_query($sql2);
|
||
|
$row2=mysql_fetch_array($result2);
|
||
|
$total_modules = $row2[0];
|
||
|
if ($total_modules == 0)
|
||
|
$percentil = 0;
|
||
|
else
|
||
|
$percentil = $modules_server / ($total_modules / 100);
|
||
|
$total_modules_temp = $total_modules;
|
||
|
}
|
||
|
else
|
||
|
echo "-";
|
||
|
|
||
|
if (($network_server == 1) OR ($data_server == 1) OR ($recon_server == 1))
|
||
|
// Progress bar render
|
||
|
echo '<img src="reporting/fgraph.php?tipo=progress&percent='.$percentil.'&height=18&width=80">';
|
||
|
|
||
|
// Number of modules
|
||
|
echo "<td class='$tdcolor'>";
|
||
|
if (($recon_server ==1) OR ($network_server == 1) OR ($data_server == 1))
|
||
|
echo $modules_server . " / ". $total_modules_temp;
|
||
|
else
|
||
|
echo "-";
|
||
|
|
||
|
// LAG CHECK
|
||
|
echo "<td class='$tdcolor'>";
|
||
|
// Calculate lag: get oldest module of any proc_type, for this server,
|
||
|
// and calculate difference in seconds
|
||
|
// Get total modules defined for this server
|
||
|
if (($network_server == 1) OR ($data_server == 1)){
|
||
|
$sql1 = "SELECT utimestamp, current_interval FROM tagente_estado WHERE processed_by_server = '$name' AND estado < 100";
|
||
|
|
||
|
$nowtime = time();
|
||
|
$maxlag=0;
|
||
|
if ($result1=mysql_query($sql1))
|
||
|
while ($row1=mysql_fetch_array($result1)){
|
||
|
if (($row1["utimestamp"] + $row1["current_interval"]) < $nowtime)
|
||
|
$maxlag2 = $nowtime - ($row1["utimestamp"] + $row1["current_interval"]);
|
||
|
if ($maxlag2 > $maxlag)
|
||
|
$maxlag = $maxlag2;
|
||
|
}
|
||
|
if ($maxlag < 60)
|
||
|
echo $maxlag." sec";
|
||
|
elseif ($maxlag < 86400)
|
||
|
echo format_numeric($maxlag/60) . " min";
|
||
|
elseif ($maxlag > 86400)
|
||
|
echo "+1 ".$lang_label["day"];
|
||
|
} elseif ($recon_server == 1) {
|
||
|
$sql1 = "SELECT * FROM trecon_task WHERE id_network_server = $id_server";
|
||
|
$result1=mysql_query($sql1);
|
||
|
$nowtime = time();
|
||
|
$maxlag=0;$maxlag2=0;
|
||
|
while ($row1=mysql_fetch_array($result1)){
|
||
|
if (($row1["utimestamp"] + $row1["interval_sweep"]) < $nowtime){
|
||
|
$maxlag2 = $nowtime - ($row1["utimestamp"] + $row1["interval_sweep"]);
|
||
|
if ($maxlag2 > $maxlag)
|
||
|
$maxlag = $maxlag2;
|
||
|
}
|
||
|
}
|
||
|
if ($maxlag < 60)
|
||
|
echo $maxlag." sec";
|
||
|
elseif ($maxlag < 86400)
|
||
|
echo format_numeric($maxlag/60) . " min";
|
||
|
elseif ($maxlag > 86400)
|
||
|
echo "+1 ".$lang_label["day"];
|
||
|
} else
|
||
|
echo "--";
|
||
|
}
|
||
|
}
|
||
|
echo '</table>';
|
||
|
}
|
||
|
echo "</table>";
|
||
|
|
||
|
|
||
|
?>
|