2006-03-27 05:37:27 +02:00
|
|
|
<?php
|
2006-07-09 16:20:10 +02:00
|
|
|
// 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.
|
2006-03-27 05:37:27 +02:00
|
|
|
|
|
|
|
// Load global vars
|
|
|
|
require("include/config.php");
|
|
|
|
if (comprueba_login() == 0) {
|
|
|
|
if ((give_acl($id_user, 0, "AR")==1) or (give_acl($id_user,0,"AW")) or (dame_admin($id_user)==1)) {
|
|
|
|
|
2007-05-27 04:55:55 +02:00
|
|
|
echo "<h2>".$lang_label["ag_title"]." > ";
|
|
|
|
echo $lang_label["monitor_listing"]."<a href='help/".$help_code."/chap3.php#334' target='_help' class='help'>
|
|
|
|
<span>".$lang_label["help"]."</span></a></h2>";
|
2006-03-27 05:37:27 +02:00
|
|
|
|
|
|
|
|
|
|
|
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/status_monitor&refr=60&ag_group_refresh=".$ag_group."'>";
|
|
|
|
} else {
|
|
|
|
echo "<form method='post' action='index.php?sec=estado&sec2=operation/agentes/status_monitor&refr=60'>";
|
|
|
|
}
|
2007-06-07 16:45:33 +02:00
|
|
|
echo "<table cellspacing='4' cellpadding='4' width='600' class='databox'>";
|
2006-12-03 03:07:36 +01:00
|
|
|
echo "<tr><td valign='middle'>".$lang_label["group"]."</td>";
|
2006-03-27 05:37:27 +02:00
|
|
|
echo "<td valign='middle'>";
|
2006-10-09 17:22:28 +02:00
|
|
|
echo "<select name='ag_group' onChange='javascript:this.form.submit();' class='w130'>";
|
2006-03-27 05:37:27 +02:00
|
|
|
|
|
|
|
if ( $ag_group > 1 ){
|
2006-12-25 19:15:57 +01:00
|
|
|
echo "<option value='".$ag_group."'>".dame_nombre_grupo($ag_group)."</option>";
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
2006-12-25 19:15:57 +01:00
|
|
|
echo "<option value=1>".dame_nombre_grupo(1)."</option>";
|
|
|
|
list_group ($id_user);
|
2006-03-27 05:37:27 +02:00
|
|
|
echo "</select>";
|
|
|
|
|
|
|
|
// Module name selector
|
|
|
|
// This code thanks for an idea from Nikum, nikun_h@hotmail.com
|
|
|
|
if (isset($_POST["ag_modulename"])){
|
|
|
|
$ag_modulename = $_POST["ag_modulename"];
|
2006-12-25 19:15:57 +01:00
|
|
|
echo "<form method='post' action='index.php?sec=estado&
|
|
|
|
sec2=operation/agentes/status_monitor&
|
|
|
|
refr=60&ag_modulename=".$ag_modulename."'>";
|
2006-03-27 05:37:27 +02:00
|
|
|
} else {
|
2006-12-25 19:15:57 +01:00
|
|
|
echo "<form method='post' action='index.php?sec=estado&
|
|
|
|
sec2=operation/agentes/status_monitor&refr=60'>";
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
2006-11-21 20:10:23 +01:00
|
|
|
|
2007-06-07 16:45:33 +02:00
|
|
|
echo "<td class='f9' style='padding-left: 10px;'>";
|
2007-06-27 19:45:42 +02:00
|
|
|
echo "<img src='images/b_green.png'> - ".$lang_label["green_light"]."</td>";
|
2007-06-07 16:45:33 +02:00
|
|
|
echo "<td class='f9' style='padding-left: 10px;'>";
|
2007-06-27 19:45:42 +02:00
|
|
|
echo "<img src='images/b_red.png'> - ".$lang_label["red_light"]."</td>";
|
2006-11-21 20:10:23 +01:00
|
|
|
echo "</td>";
|
|
|
|
echo "</tr>";
|
|
|
|
echo "<tr>";
|
|
|
|
echo "<td valign='middle'>".$lang_label["module_name"]."</td>";
|
2006-12-25 19:15:57 +01:00
|
|
|
echo "<td valign='middle'>
|
|
|
|
<select name='ag_modulename' onChange='javascript:this.form.submit();'>";
|
2006-03-27 05:37:27 +02:00
|
|
|
if ( isset($ag_modulename)){
|
2006-11-21 20:10:23 +01:00
|
|
|
echo "<option>".$ag_modulename."</option>";
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
2007-06-07 16:45:33 +02:00
|
|
|
echo "<option>".$lang_label["all"]."</option>";
|
2006-12-25 19:15:57 +01:00
|
|
|
$sql='SELECT DISTINCT nombre
|
|
|
|
FROM tagente_modulo
|
|
|
|
WHERE (id_tipo_modulo = 2)
|
|
|
|
OR (id_tipo_modulo = 9)
|
|
|
|
OR (id_tipo_modulo = 12)
|
|
|
|
OR (id_tipo_modulo = 18)
|
|
|
|
OR (id_tipo_modulo = 6) ';
|
2006-03-27 05:37:27 +02:00
|
|
|
$result=mysql_query($sql);
|
|
|
|
while ($row=mysql_fetch_array($result)){
|
2006-11-21 20:10:23 +01:00
|
|
|
echo "<option>".$row['0']."</option>";
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
|
|
|
echo "</select>";
|
2006-12-25 19:15:57 +01:00
|
|
|
echo "<td valign='middle'>
|
|
|
|
<noscript><input name='uptbutton' type='submit' class='sub'
|
|
|
|
value='".$lang_label["show"]."'></noscript>
|
|
|
|
</form>";
|
2006-03-27 05:37:27 +02:00
|
|
|
|
|
|
|
|
|
|
|
// Show only selected names & groups
|
|
|
|
if ($ag_group > 1)
|
2006-12-25 19:15:57 +01:00
|
|
|
$sql='SELECT * FROM tagente WHERE id_grupo='.$ag_group.'
|
|
|
|
ORDER BY nombre';
|
2006-03-27 05:37:27 +02:00
|
|
|
else
|
|
|
|
$sql='SELECT * FROM tagente ORDER BY id_grupo, nombre';
|
|
|
|
|
|
|
|
echo "</table>";
|
|
|
|
echo "<br>";
|
2006-07-05 15:33:13 +02:00
|
|
|
$color =1;
|
2006-03-27 05:37:27 +02:00
|
|
|
$result=mysql_query($sql);
|
|
|
|
if (mysql_num_rows($result)){
|
2007-06-07 16:45:33 +02:00
|
|
|
while ($row=mysql_fetch_array($result)){ //while there are agents
|
2006-03-27 05:37:27 +02:00
|
|
|
if ($row["disabled"] == 0) {
|
2006-11-21 18:35:59 +01:00
|
|
|
if ((isset($ag_modulename)) && ($ag_modulename != "ALL"))
|
2006-12-25 19:15:57 +01:00
|
|
|
$query_gen='SELECT * FROM tagente_modulo
|
|
|
|
WHERE id_agente = '.$row["id_agente"].'
|
|
|
|
AND nombre = "'.entrada_limpia($_POST["ag_modulename"]).'"
|
|
|
|
AND (
|
|
|
|
(id_tipo_modulo = 2)
|
|
|
|
OR (id_tipo_modulo = 9)
|
|
|
|
OR (id_tipo_modulo = 12)
|
|
|
|
OR (id_tipo_modulo = 18)
|
|
|
|
OR (id_tipo_modulo = 6)
|
|
|
|
)';
|
2006-03-27 05:37:27 +02:00
|
|
|
else
|
2006-12-25 19:15:57 +01:00
|
|
|
$query_gen='SELECT * FROM tagente_modulo
|
|
|
|
WHERE id_agente = '.$row["id_agente"].'
|
|
|
|
AND (
|
|
|
|
(id_tipo_modulo = 2)
|
|
|
|
OR (id_tipo_modulo = 9)
|
|
|
|
OR (id_tipo_modulo = 12)
|
|
|
|
OR (id_tipo_modulo = 18)
|
|
|
|
OR (id_tipo_modulo = 6)
|
|
|
|
)';
|
2006-03-27 05:37:27 +02:00
|
|
|
$result_gen=mysql_query($query_gen);
|
|
|
|
if (mysql_num_rows ($result_gen)) {
|
|
|
|
while ($data=mysql_fetch_array($result_gen)){
|
2006-07-05 15:33:13 +02:00
|
|
|
if ($color == 1){
|
|
|
|
$tdcolor="datos";
|
|
|
|
$color =0;
|
|
|
|
} else {
|
|
|
|
$tdcolor="datos2";
|
|
|
|
$color =1;
|
|
|
|
}
|
|
|
|
if (!isset($string)) {$string='';}
|
2007-05-20 19:12:31 +02:00
|
|
|
$string=$string. "<tr><td class='$tdcolor'>";
|
|
|
|
$string=$string. "<a href='index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=".$data["id_agente"]."&id_agente_modulo=".$data["id_agente_modulo"]."&flag=1&tab=data&refr=60'>";
|
2007-06-27 19:45:42 +02:00
|
|
|
$string=$string."<img src='images/target.png'></a>";
|
|
|
|
$string=$string. "</td><td class='$tdcolor'>";
|
|
|
|
$string=$string."<b><a href='index.php?sec=estado&
|
2006-12-25 19:15:57 +01:00
|
|
|
sec2=operation/agentes/ver_agente&
|
|
|
|
id_agente=".$data["id_agente"]."'>".
|
2007-06-27 19:45:42 +02:00
|
|
|
strtoupper(substr(dame_nombre_agente($data["id_agente"]),0,21))."</a></b>";
|
|
|
|
$string=$string."</td><td class='$tdcolor'>";
|
2006-12-25 19:15:57 +01:00
|
|
|
$string=$string."
|
2006-12-31 01:29:40 +01:00
|
|
|
<img src='images/".show_icon_type($data["id_tipo_modulo"])."' border=0>
|
|
|
|
</td>";
|
2006-12-25 19:15:57 +01:00
|
|
|
$string=$string."<td class='$tdcolor'>".
|
2007-06-12 13:57:03 +02:00
|
|
|
substr($data["nombre"],0,21)."</td>";
|
2006-12-25 19:15:57 +01:00
|
|
|
$string=$string."<td class='".$tdcolor."f9'>".
|
|
|
|
substr($data["descripcion"],0,30)."</td>";
|
2007-06-12 13:57:03 +02:00
|
|
|
$string=$string."<td align='center' class='$tdcolor' width=25>";
|
|
|
|
if ($data["max"] == $data["min"])
|
|
|
|
$string .= "--";
|
|
|
|
else
|
2006-12-25 19:15:57 +01:00
|
|
|
$data["max"]."/".$data["min"]."</td>";
|
2007-06-12 13:57:03 +02:00
|
|
|
$string=$string."<td class='$tdcolor' align='center' width=25>";
|
2006-03-27 05:37:27 +02:00
|
|
|
if ($data["module_interval"] == 0){
|
2007-06-12 13:57:03 +02:00
|
|
|
$my_interval = give_agentinterval($data["id_agente"]);
|
2006-03-27 05:37:27 +02:00
|
|
|
} else {
|
2007-06-12 13:57:03 +02:00
|
|
|
$my_interval = $data["module_interval"];
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
2007-06-12 13:57:03 +02:00
|
|
|
$string .= $my_interval;
|
|
|
|
|
2006-12-25 19:15:57 +01:00
|
|
|
$query_gen2='SELECT * FROM tagente_estado
|
|
|
|
WHERE id_agente_modulo = '.$data["id_agente_modulo"];
|
2006-03-27 05:37:27 +02:00
|
|
|
$result_gen2=mysql_query($query_gen2);
|
|
|
|
$data2=mysql_fetch_array($result_gen2);
|
2006-07-05 15:33:13 +02:00
|
|
|
$string=$string."<td class='$tdcolor' align='center' width=20>";
|
2006-03-27 05:37:27 +02:00
|
|
|
if ($data2["datos"] > 0){
|
2007-06-27 19:45:42 +02:00
|
|
|
$string=$string."<img src='images/b_green.png'>";
|
2006-03-27 05:37:27 +02:00
|
|
|
} else {
|
2007-06-27 19:45:42 +02:00
|
|
|
$string=$string."<img src='images/b_red.png'>";
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
2007-06-12 13:57:03 +02:00
|
|
|
|
|
|
|
$string=$string."<td class='".$tdcolor."f9'>";
|
|
|
|
$seconds = time() - $data2["utimestamp"];
|
|
|
|
if ($seconds >= ($my_interval*2))
|
|
|
|
$string .= "<span class='redb'>";
|
|
|
|
else
|
|
|
|
$string .= "<span>";
|
|
|
|
|
|
|
|
$string .= human_time_comparation($data2["timestamp"])."</td></tr>";
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
|
|
|
}
|
2006-07-06 17:31:31 +02:00
|
|
|
else if($ag_group>1) {unset($string);}
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
|
|
|
}
|
2006-07-05 15:33:13 +02:00
|
|
|
if (isset($string)) {
|
2007-06-07 16:45:33 +02:00
|
|
|
echo "
|
|
|
|
<table cellpadding='4' cellspacing='4' width='750' class='databox'>
|
2006-12-25 19:15:57 +01:00
|
|
|
<tr>
|
2007-05-20 19:12:31 +02:00
|
|
|
<th>
|
2006-12-25 19:15:57 +01:00
|
|
|
<th>".$lang_label["agent"]."</th>
|
|
|
|
<th>".$lang_label["type"]."</th>
|
|
|
|
<th>".$lang_label["name"]."</th>
|
|
|
|
<th>".$lang_label["description"]."</th>
|
|
|
|
<th>".$lang_label["max_min"]."</th>
|
|
|
|
<th>".$lang_label["interval"]."</th>
|
|
|
|
<th>".$lang_label["status"]."</th>
|
|
|
|
<th>".$lang_label["timestamp"]."</th>";
|
2006-07-05 15:33:13 +02:00
|
|
|
echo $string; //the built table of monitors
|
2007-05-20 19:12:31 +02:00
|
|
|
echo "</table>";
|
2006-07-05 15:33:13 +02:00
|
|
|
}
|
|
|
|
else {
|
2006-12-03 03:07:36 +01:00
|
|
|
echo "<div class='nf'>".$lang_label["no_monitors_g"]."</div>";
|
2006-07-05 15:33:13 +02:00
|
|
|
}
|
2006-03-27 05:37:27 +02:00
|
|
|
} else {
|
2006-12-03 03:07:36 +01:00
|
|
|
echo "<div class='nf'>".$lang_label["no_agent"]."</div>";
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
} //end acl
|
|
|
|
} //end login
|
|
|
|
|
|
|
|
?>
|