167 lines
8.3 KiB
PHP
167 lines
8.3 KiB
PHP
<?php
|
|
// Pandora - the Free monitoring system
|
|
// ====================================
|
|
// Copyright (c) 2004-2006 Sancho Lerena, slerena@gmail.com
|
|
// Copyright (c) 2005-2006 Artica Soluciones Tecnológicas S.L, info@artica.es
|
|
// Copyright (c) 2004-2006 Raul Mateos Martin, raulofpandora@gmail.com
|
|
// 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; either version 2
|
|
// of the License, or (at your option) any later version.
|
|
// 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");
|
|
if (comprueba_login() == 0)
|
|
if (give_acl($id_user, 0, "AR")==1) {
|
|
echo "<h2>".$lang_label["ag_title"]."</h2>";
|
|
echo "<h3>".$lang_label["group_view"]."</h3>";
|
|
// Check for Network FLAG change request
|
|
if (isset($_GET["update_netgroup"])){
|
|
if (give_acl($id_user, $_GET["update_netgroup"], "AW")==1){
|
|
$sql = "SELECT * FROM tagente where id_grupo = ".$_GET["update_netgroup"];
|
|
$result=mysql_query($sql);
|
|
while ($row=mysql_fetch_array($result)){
|
|
$id_agente = $row["id_agente"];
|
|
$query2 ="UPDATE tagente_modulo SET flag=1 WHERE id_agente = ".$id_agente;
|
|
$res=mysql_query($query2);
|
|
}
|
|
echo "<h3 class='suc'>".$lang_label["network_module_refresh_exec"]."</h3>";
|
|
}
|
|
}
|
|
$iduser_temp=$_SESSION['id_usuario'];
|
|
// $mis_grupos - Define array mis_grupos to put here all groups with Agent Read permission
|
|
$sql1='SELECT * FROM tgrupo';
|
|
$result2=mysql_query($sql1);
|
|
while ($row=mysql_fetch_array($result2)){
|
|
if ($row["id_grupo"]!=1)
|
|
if (give_acl($iduser_temp,$row["id_grupo"], "AR") == 1)
|
|
$mis_grupos[]=$row["id_grupo"]; //All my groups in an array
|
|
}
|
|
$contador_grupo = 0;
|
|
$contador_agente=0;
|
|
$array_index = 0;
|
|
$estado_grupo_ok =0;
|
|
$estado_grupo_down =0;
|
|
$estado_grupo_bad =0;
|
|
// Recorro cada grupo para ver el estado de todos los modulos
|
|
foreach ($mis_grupos as $migrupo)
|
|
if ($migrupo != "") {
|
|
$grupo[$array_index]["agent"]=0;
|
|
$grupo[$array_index]["ok"]=0;
|
|
$grupo[$array_index]["down"]=0;
|
|
$grupo[$array_index]["bad"]=0;
|
|
$grupo[$array_index]["icon"]=dame_grupo_icono($migrupo);
|
|
$grupo[$array_index]["id_grupo"]=$migrupo;
|
|
$existen_agentes =0;
|
|
$sql1="SELECT * FROM tagente WHERE disabled=0 AND id_grupo =".$migrupo;
|
|
if ($result1=mysql_query($sql1))
|
|
while ($row1 = mysql_fetch_array($result1)){
|
|
$existen_agentes =1;
|
|
$id_agente=$row1["id_agente"];
|
|
$ultimo_contacto = $row1["ultimo_contacto"];
|
|
$intervalo = $row1["intervalo"];
|
|
$ahora=date("Y/m/d H:i:s");
|
|
if ($ultimo_contacto <> "")
|
|
$seconds = strtotime($ahora) - strtotime($ultimo_contacto);
|
|
else
|
|
$seconds = -100000;
|
|
# Defines if Agent is down (interval x 2 > time last contact)
|
|
$down=0;
|
|
if ($seconds >= ($intervalo*2)){ // if Agent is down an alert is shown
|
|
$grupo[$array_index]["down"]++; // Estado grupo, agent down
|
|
$estado_grupo_down++;
|
|
$down=1;
|
|
}
|
|
$grupo[$array_index]["agent"]++;
|
|
$grupo[$array_index]["group"]=dame_nombre_grupo($migrupo);
|
|
$contador_agente++; // Estado grupo, agent
|
|
if ($down ==0){
|
|
$sql2="SELECT * FROM tagente_modulo WHERE (id_tipo_modulo = 2 OR id_tipo_modulo = 6 OR id_tipo_modulo = 9 OR id_tipo_modulo = 12 OR id_tipo_modulo = 18) AND id_agente =".$row1["id_agente"];
|
|
$result2=mysql_query($sql2);
|
|
while ($row2 = mysql_fetch_array($result2)){
|
|
$sql3="SELECT * FROM tagente_estado WHERE id_agente_modulo = ".$row2["id_agente_modulo"];
|
|
$result3=mysql_query($sql3);
|
|
$row3 = mysql_fetch_array($result3);
|
|
if ($row3["datos"] !=0){
|
|
$estado_grupo_ok++;
|
|
$grupo[$array_index]["ok"]++; // Estado grupo, agent ok
|
|
}
|
|
else {
|
|
$estado_grupo_bad++;
|
|
$grupo[$array_index]["bad"]++; // Estado grupo, agent BAD
|
|
}
|
|
}
|
|
$grupo[$array_index]["ok"];
|
|
}
|
|
}
|
|
if ($existen_agentes == 1){
|
|
$array_index++;
|
|
}
|
|
}
|
|
if ($contador_agente==0) {echo "<font class='red'>".$lang_label["no_agent_def"]."</font>";}
|
|
$ancho = ceil(sqrt($array_index+1));
|
|
$real_count =0; // Puedo tener una tabla con mas items en ella que los que realmente debo mostrar, real count cuenta los que voy poniendo hasta llegar a array_index que son los que hay en el array $grupo.
|
|
echo "<table border=0 cellpadding=10 cellspacing=10>";
|
|
for ($table=0;$table < $ancho-1;$table++){
|
|
echo "<tr class='bot'>";
|
|
for ($table_row=0;$table_row < $ancho;$table_row++){
|
|
if ($real_count < $array_index){
|
|
$group_name = $grupo[$real_count]["group"];
|
|
$icono_grupo = $grupo[$real_count]["icon"];
|
|
$icono_type="";
|
|
if ($grupo[$real_count]["down"]>0) {
|
|
$icono_type="<img src='images/dot_white.gif' alt=''>";
|
|
}
|
|
if ($grupo[$real_count]["bad"]>0) {
|
|
$icono_type=$icono_type."<img src='images/dot_red.gif' alt=''>";
|
|
}
|
|
if ($grupo[$real_count]["ok"]>0) {
|
|
$icono_type=$icono_type."<img src='images/dot_green.gif' alt=''>";
|
|
}
|
|
// Icon with tooltip table inside (Raul)
|
|
$celda = "<img class='top' src='images/groups/".$icono_grupo."_1.gif' border='0' alt=''><a href='#' class='tip'> <span>";
|
|
$celda = $celda."<table border='0' cellspacing='2' cellpadding='0'>
|
|
<tr><td colspan='2' width='91' class='lb'>".$lang_label["agents"].": </td></tr>
|
|
<tr><td colspan='2' class='datos' align='center'><b>".$grupo[$real_count]["agent"]."</b></td></tr></table>
|
|
<table>
|
|
<tr><td colspan='2' width='90' class='lb'>".ucfirst($lang_label["monitors"]).":</td></tr>
|
|
<tr><td class='datos'><img src='images/b_green.gif' align='top' alt='' border='0'> ".$lang_label["ok"].": </td><td class='datos'><font class='greenb'>".$grupo[$real_count]["ok"]."</font></td></tr>
|
|
<tr><td class='datos'><img src='images/b_down.gif' align='top' alt='' border='0'> ".$lang_label["down"].": </td><td class='datos'><font class='grey'>".$grupo[$real_count]["down"]."</font></td></tr>
|
|
<tr><td class='datos'><img src='images/b_red.gif' align='top' alt='' border='0'> ".$lang_label["fail"].": </td><td class='datos'><font class='redb'>".$grupo[$real_count]["bad"]."</font></td></tr></table>
|
|
</span></a>";
|
|
// Render network exec module button, only when this group is writtable by user
|
|
if (give_acl($id_user, $grupo[$real_count]["id_grupo"], "AW")==1){
|
|
$celda = $celda . "<a href='index.php?sec=estado&sec2=operation/agentes/estado_grupo&update_netgroup=".$grupo[$real_count]["id_grupo"]."'><img src='images/target.gif' border=0></a>";
|
|
}
|
|
$celda = "<td class='bot'><a href='index.php?sec=estado&sec2=operation/agentes/estado_agente&refr=60&group_id=".$grupo[$real_count]["id_grupo"]."'>".$celda."</a><br><br>".$icono_type."<br><br><font class='gr'>".$group_name."</font>";
|
|
|
|
$celda = $celda."<table border='0' cellspacing='2' cellpadding='0'>";
|
|
$celda = $celda."<tr><td colspan='2' width='90' class='lb'>".$lang_label["agents"].": </td></tr>";
|
|
$celda = $celda."<tr><td colspan='2' class='datos' align='center'><b>".$grupo[$real_count]["agent"]."</b>";
|
|
$celda = $celda."<tr><td colspan='2' class='lb'>".ucfirst($lang_label["monitors"]).":</td></tr>";
|
|
$celda = $celda."<tr><td class='datos'><img src='images/b_green.gif' align='top' alt=''> ".$lang_label["ok"].": </td><td class='datos'><font class='greenb'>".$grupo[$real_count]["ok"]."</font></td></tr>";
|
|
$celda = $celda."<tr><td class='datos'><img src='images/b_down.gif' align='top' alt=''> ".$lang_label["down"].": </td><td class='datos'><font class='grey'>".$grupo[$real_count]["down"]."</font></td></tr>";
|
|
$celda = $celda."<tr><td class='datos'><img src='images/b_red.gif' align='top' alt=''> ".$lang_label["fail"].": </td><td class='datos'><font class='redb'>".$grupo[$real_count]["bad"]."</font></td></tr>";
|
|
$celda = $celda."<tr><td colspan='2'><div class='raya'></div></td></tr>";
|
|
$celda = $celda."</table>";
|
|
$celda = $celda."</td>";
|
|
echo $celda;
|
|
}
|
|
$real_count++;
|
|
}
|
|
echo "</tr>";
|
|
}
|
|
echo "</table>";
|
|
}
|
|
else {
|
|
audit_db($id_user,$REMOTE_ADDR, "ACL Violation","Trying to access Agent viewi (Grouped)");
|
|
require ("general/noaccess.php");
|
|
}
|
|
?>
|