254 lines
9.5 KiB
PHP
254 lines
9.5 KiB
PHP
<?php
|
|
// Pandora - the Free monitoring system
|
|
// ====================================
|
|
// Copyright (c) 2004-2006 Sancho Lerena, slerena@gmail.com
|
|
// Copyright (c) 2005-2006 Artica Soluciones Tecnologicas 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");
|
|
|
|
|
|
// Login check
|
|
$id_usuario=$_SESSION["id_usuario"];
|
|
global $REMOTE_ADDR;
|
|
|
|
if (comprueba_login() != 0) {
|
|
audit_db($id_usuario,$REMOTE_ADDR, "ACL Violation","Trying to access alert view");
|
|
include ("general/noaccess.php");
|
|
exit;
|
|
}
|
|
|
|
if ((give_acl($id_user, 0, "AR")!=1) AND (!give_acl($id_user,0,"AW")) AND (dame_admin($id_user)!=1)) {
|
|
audit_db($id_usuario,$REMOTE_ADDR, "ACL Violation","Trying to access alert view");
|
|
include ("general/noaccess.php");
|
|
exit;
|
|
}
|
|
|
|
|
|
// -------------------------------
|
|
// Show alerts for specific agent
|
|
// -------------------------------
|
|
if (isset($_GET["id_agente"])){
|
|
|
|
if (isset($_GET["tab"])){
|
|
echo "<h2>".$lang_label["ag_title"]." > ".$lang_label["alert_listing"]."<a href='help/".$help_code."/chap3.php#3324' target='_help' class='help'><span>".$lang_label["help"]."</span></a></h2>";
|
|
}
|
|
$id_agente = $_GET["id_agente"];
|
|
$query_gen='SELECT talerta_agente_modulo.alert_text, talerta_agente_modulo.id_alerta, talerta_agente_modulo.descripcion, talerta_agente_modulo.last_fired, talerta_agente_modulo.times_fired, tagente_modulo.nombre, talerta_agente_modulo.dis_max, talerta_agente_modulo.dis_min, talerta_agente_modulo.max_alerts, talerta_agente_modulo.time_threshold, talerta_agente_modulo.min_alerts, talerta_agente_modulo.id_agente_modulo, tagente_modulo.id_agente_modulo FROM tagente_modulo, talerta_agente_modulo WHERE tagente_modulo.id_agente = '.$id_agente.' AND tagente_modulo.id_agente_modulo = talerta_agente_modulo.id_agente_modulo ORDER BY tagente_modulo.nombre';
|
|
$result_gen=mysql_query($query_gen);
|
|
if (mysql_num_rows ($result_gen)) {
|
|
|
|
if (!isset($_GET["tab"])) {
|
|
echo "<h3>".$lang_label["alert_listing"]."<a href='help/".$help_code."/chap3.php#3324' target='_help' class='help'><span>".$lang_label["help"]."</span></a></h3>";
|
|
}
|
|
|
|
echo "<table cellpadding='4' cellspacing='4' width=750 border=0 class='databox'>";
|
|
echo "<tr>
|
|
<th>".$lang_label["type"]."<th>".$lang_label["name"]."</th>
|
|
<th>".$lang_label["description"]."</th>
|
|
<th>".$lang_label["min_max"]."</th>
|
|
<th>".$lang_label["time_threshold"]."</th>
|
|
<th>".$lang_label["last_fired"]."</th>
|
|
<th>".$lang_label["times_fired"]."</th>
|
|
<th>".$lang_label["status"]."</th>";
|
|
$color=1;
|
|
while ($data=mysql_fetch_array($result_gen)){
|
|
if ($color == 1){
|
|
$tdcolor = "datos";
|
|
$color = 0;
|
|
}
|
|
else {
|
|
$tdcolor = "datos2";
|
|
$color = 1;
|
|
}
|
|
echo "<tr>";
|
|
echo "<td class='".$tdcolor."'>".dame_nombre_alerta($data["id_alerta"])."</td>";
|
|
echo "<td class='".$tdcolor."'>".$data["nombre"]."</td>";
|
|
echo "<td class='".$tdcolor."'>".$data["descripcion"]."</td>";
|
|
|
|
$mytempdata = fmod($data["dis_min"], 1);
|
|
if ($mytempdata == 0)
|
|
$mymin = intval($data["dis_min"]);
|
|
else
|
|
$mymin = $data["dis_min"];
|
|
$mymin = format_for_graph($mymin );
|
|
|
|
$mytempdata = fmod($data["dis_max"], 1);
|
|
if ($mytempdata == 0)
|
|
$mymax = intval($data["dis_max"]);
|
|
else
|
|
$mymax = $data["dis_max"];
|
|
$mymax = format_for_graph($mymax );
|
|
// Text alert ?
|
|
if ($data["alert_text"] != "")
|
|
echo "<td class='".$tdcolor."'>".$lang_label["text"]."</td>";
|
|
else
|
|
echo "<td class='".$tdcolor."'>".$mymin." / ".$mymax."</td>";
|
|
echo "<td class='".$tdcolor."'>".$data["time_threshold"];
|
|
if ($data["last_fired"] == "0000-00-00 00:00:00") {
|
|
echo "<td class='".$tdcolor."f9'>".$lang_label["never"]."</td>";
|
|
}
|
|
else {
|
|
echo "<td class='".$tdcolor."f9'>".$data["last_fired"]."</td>";
|
|
}
|
|
echo "<td class='".$tdcolor."'>".$data["times_fired"]."</td>";
|
|
if ($data["times_fired"] <> 0)
|
|
echo "<td class='".$tdcolor."' align='center'><img src='images/dot_red.gif'></td>";
|
|
else
|
|
echo "<td class='".$tdcolor."' align='center'><img src='images/dot_green.gif'></td>";
|
|
}
|
|
echo '</table>';
|
|
|
|
} else {
|
|
echo "<div class='nf'>".$lang_label["no_alerts"]."</div>";
|
|
}
|
|
|
|
} else {
|
|
// -------------------------------
|
|
// SHOW ALL ALERTS (GENERAL PAGE)
|
|
// -------------------------------
|
|
|
|
echo "<h2>".$lang_label["ag_title"]." > ";
|
|
echo $lang_label["alert_listing"]."<a href='help/".$help_code."/chap3.php#335' target='_help' class='help'> <span>".$lang_label["help"]."</span></a></h2>";
|
|
$iduser_temp=$_SESSION['id_usuario'];
|
|
if (isset($_POST["ag_group"]))
|
|
$ag_group = $_POST["ag_group"];
|
|
elseif (isset($_GET["group_id"]))
|
|
$ag_group = $_GET["group_id"];
|
|
else
|
|
$ag_group = -1;
|
|
if (isset($_GET["ag_group_refresh"])){
|
|
$ag_group = $_GET["ag_group_refresh"];
|
|
}
|
|
|
|
if (isset($_POST["ag_group"])){
|
|
$ag_group = $_POST["ag_group"];
|
|
echo "<form method='post' action='index.php?sec=estado&sec2=operation/agentes/estado_alertas&refr=60&ag_group_refresh=".$ag_group."'>";
|
|
} else {
|
|
echo "<form method='post' action='index.php?sec=estado&sec2=operation/agentes/estado_alertas&refr=60'>";
|
|
}
|
|
echo "<table cellpadding='4' cellspacing='4' class='databox'><tr>";
|
|
echo "<td>".$lang_label["group"]."</td>";
|
|
echo "<td valign='middle'>";
|
|
echo "<select name='ag_group' onChange='javascript:this.form.submit();' class='w130'>";
|
|
|
|
if ( $ag_group > 1 ){
|
|
echo "<option value='".$ag_group."'>".dame_nombre_grupo($ag_group)."</option>";
|
|
}
|
|
echo "<option value=1>".dame_nombre_grupo(1)."</option>";
|
|
list_group ($id_user);
|
|
echo "</select></td>";
|
|
echo "<td valign='middle'><noscript><input name='uptbutton' type='submit' class='sub' value='".$lang_label["show"]."'></noscript></td></form>";
|
|
// Show only selected groups
|
|
|
|
if ($ag_group > 1)
|
|
$sql='SELECT id_agente, nombre, disabled FROM tagente WHERE id_grupo='.$ag_group.' ORDER BY nombre';
|
|
else
|
|
$sql='SELECT id_agente, nombre, disabled FROM tagente ORDER BY id_grupo, nombre';
|
|
|
|
$result=mysql_query($sql);
|
|
if (mysql_num_rows($result)){
|
|
$color=1;
|
|
while ($row=mysql_fetch_array($result)){ //while there are agents
|
|
if ($row["disabled"] == 0) {
|
|
$id_agente = $row['id_agente'];
|
|
$nombre_agente = $row["nombre"];
|
|
$query_gen='SELECT talerta_agente_modulo.id_alerta,
|
|
talerta_agente_modulo.descripcion,
|
|
talerta_agente_modulo.last_fired,
|
|
talerta_agente_modulo.times_fired,
|
|
talerta_agente_modulo.id_agente_modulo,
|
|
tagente_modulo.id_agente_modulo
|
|
FROM tagente_modulo, talerta_agente_modulo
|
|
WHERE tagente_modulo.id_agente = '.$id_agente.'
|
|
AND tagente_modulo.id_agente_modulo = talerta_agente_modulo.id_agente_modulo';
|
|
$result_gen=mysql_query($query_gen);
|
|
if (mysql_num_rows ($result_gen)) {
|
|
while ($data=mysql_fetch_array($result_gen)){
|
|
if ($color == 1){
|
|
$tdcolor = "datos";
|
|
$color = 0;
|
|
}
|
|
else {
|
|
$tdcolor = "datos2";
|
|
$color = 1;
|
|
}
|
|
if (!isset($string)) {
|
|
$string='';
|
|
}
|
|
$string = $string."<tr><td class='".$tdcolor."'>
|
|
<a href='index.php?sec=estado&
|
|
sec2=operation/agentes/ver_agente&
|
|
id_agente=".$id_agente."'>
|
|
<b>".$nombre_agente."</b>";
|
|
|
|
$string = $string."<td class='".$tdcolor."'>"
|
|
.dame_nombre_alerta($data["id_alerta"])."</td>";
|
|
$string=$string."<td class='".$tdcolor."'>".
|
|
$data["descripcion"]."</td>";
|
|
if ($data["last_fired"] == "0000-00-00 00:00:00") {
|
|
$string=$string."<td class='".$tdcolor."'>".
|
|
$lang_label["never"]."</td>";
|
|
}
|
|
else {
|
|
$string=$string."<td class='".$tdcolor."'>".
|
|
$data["last_fired"]."</td>";
|
|
}
|
|
$string=$string."<td class='".$tdcolor."'>".
|
|
$data["times_fired"]."</td>";
|
|
if ($data["times_fired"] <> 0)
|
|
$string=$string."<td class='".$tdcolor."'
|
|
align='center'>
|
|
<img src='images/dot_red.gif'></td>";
|
|
else
|
|
$string=$string."<td class='".$tdcolor."'
|
|
align='center'>
|
|
<img src='images/dot_green.gif'></td>";
|
|
}
|
|
}
|
|
else if($ag_group>1) {
|
|
unset($string);
|
|
} //end result
|
|
} //end disabled=0
|
|
|
|
} //end while
|
|
if (isset($string)) {
|
|
echo "<td class='f9' style='padding-left: 30px;'>";
|
|
echo "<img src='images/dot_red.gif'> - ".$lang_label["fired"]."</td>";
|
|
echo "<td class='f9' style='padding-left: 30px;'>";
|
|
echo "<img src='images/dot_green.gif'> - ".$lang_label["not_fired"];
|
|
echo "</td></tr></table>";
|
|
echo "<br>";
|
|
echo "<table cellpadding='4' cellspacing='4' width='700' class='databox'>";
|
|
echo "<tr>
|
|
<th>".$lang_label["agent"]."</th>
|
|
<th>".$lang_label["type"]."</th>
|
|
<th>".$lang_label["description"]."</th>
|
|
<th>".$lang_label["last_fired"]."</th>
|
|
<th>".$lang_label["times_fired"]."</th>
|
|
<th>".$lang_label["status"]."</th>";
|
|
echo $string; //built table of alerts
|
|
echo "</table>";
|
|
}
|
|
else {
|
|
echo "</table><br><div class='nf'>".
|
|
$lang_label["no_alert"]."</div>";
|
|
}
|
|
} else echo "</table><br><div class='nf'>".
|
|
$lang_label["no_agent"].$lang_label["no_agent_alert"]."</div>";
|
|
}
|
|
|
|
?>
|