2007-10-12 18:27:50 +02:00
< ? PHP
2008-07-25 20:37:32 +02:00
// Pandora FMS - the Flexible Monitoring System
// ============================================
2008-04-01 15:53:11 +02:00
// Copyright (c) 2008 Artica Soluciones Tecnológicas, http://www.artica.es
2008-01-10 17:40:00 +01:00
// Please see http://pandora.sourceforge.net for full contribution list
2006-03-27 05:37:27 +02:00
2008-04-01 15:53:11 +02:00
// 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 for 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.
2006-03-27 05:37:27 +02:00
require ( " include/config.php " );
2008-06-19 02:24:05 +02:00
check_login ();
2006-03-27 05:37:27 +02:00
2008-06-19 02:24:05 +02:00
if ( isset ( $_GET [ " id_agente " ])){
$id_agente = $_GET [ " id_agente " ];
}
2006-03-27 05:37:27 +02:00
2008-06-19 02:24:05 +02:00
// View last data packet
// Get timestamp of last packet
$sql_t = 'SELECT * FROM tagente WHERE id_agente = ' . $id_agente ;
$result_t = mysql_query ( $sql_t );
$row_t = mysql_fetch_array ( $result_t );
$timestamp_ref = $row_t [ " ultimo_contacto_remoto " ];
$timestamp_lof = $row_t [ " ultimo_contacto " ];
$intervalo_agente = $row_t [ " intervalo " ];
2006-03-27 05:37:27 +02:00
2008-06-19 02:24:05 +02:00
// Get last packet
2008-06-23 16:36:22 +02:00
$sql3 = 'SELECT * FROM tagente_modulo, tagente_estado WHERE tagente_modulo.disabled = 0 AND tagente_modulo.id_agente = ' . $id_agente . ' AND tagente_estado.utimestamp != 0 AND tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo ORDER BY id_module_group, nombre' ;
2008-06-19 02:24:05 +02:00
$label_group = 0 ;
$last_label = " " ;
echo " <h2> " . $lang_label [ " ag_title " ] . " > " ;
echo $lang_label [ " last_data_chunk " ] . " </h2> " ;
$result3 = mysql_query ( $sql3 );
if ( mysql_num_rows ( $result3 )) {
2007-05-18 14:56:05 +02:00
echo " <table width='750' cellpadding='3' cellspacing='3' class='databox'> " ;
echo " <th></th> " ;
2006-11-21 20:10:23 +01:00
echo " <th> " . $lang_label [ " module_name " ] . " </th> " ;
echo " <th> " . $lang_label [ " type " ] . " </th> " ;
echo " <th> " . $lang_label [ " int " ] . " </th> " ;
echo " <th> " . $lang_label [ " description " ] . " </th> " ;
echo " <th> " . $lang_label [ " data " ] . " </th> " ;
echo " <th> " . $lang_label [ " graph " ] . " </th> " ;
echo " <th> " . $lang_label [ " raw_data " ] . " </th> " ;
echo " <th> " . $lang_label [ " timestamp " ] . " </th> " ;
2007-03-28 18:07:29 +02:00
$texto = '' ; $last_modulegroup = 0 ;
2006-07-01 03:48:56 +02:00
$color = 1 ;
2006-03-27 05:37:27 +02:00
while ( $row3 = mysql_fetch_array ( $result3 )){
2008-06-19 02:24:05 +02:00
// Calculate table line color
if ( $color == 1 ){
$tdcolor = " datos " ;
$color = 0 ;
}
else {
$tdcolor = " datos2 " ;
$color = 1 ;
}
if ( $row3 [ " id_module_group " ] != $last_modulegroup ){
// Render module group names (fixed code)
2006-03-27 05:37:27 +02:00
$nombre_grupomodulo = dame_nombre_grupomodulo ( $row3 [ " id_module_group " ]);
2008-06-19 02:24:05 +02:00
$last_modulegroup = $row3 [ " id_module_group " ];
echo " <tr><td class='datos3' align='center' colspan='9'>
< b > " . $nombre_grupomodulo . " </ b ></ td ></ tr > " ;
}
// Begin to render data ...
echo " <tr><td class=' $tdcolor '> " ;
// Render network exec module button, only when
// Agent Write for this module and group, is given
// Is a network module
// Has flag = 0
$id_grupo = $row_t [ " id_grupo " ];
$id_usuario = $_SESSION [ " id_usuario " ];
if ( give_acl ( $id_usuario , $id_grupo , " AW " ) == 1 ){
if (( $row3 [ " id_modulo " ] > 1 ) AND ( $row3 [ " id_tipo_modulo " ] < 100 )) {
if ( $row3 [ " flag " ] == 0 ){
echo " <a href='index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente= " . $id_agente . " &id_agente_modulo= " . $row3 [ " id_agente_modulo " ] . " &flag=1&tab=data&refr=60'><img src='images/target.png' border='0'></a> " ;
} else {
echo " <a href='index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente= " . $id_agente . " &id_agente_modulo= " . $row3 [ " id_agente_modulo " ] . " &tab=data&refr=60'><img src='images/refresh.png' border='0'></a> " ;
2006-03-27 05:37:27 +02:00
}
2008-06-19 02:24:05 +02:00
}
}
echo " </td> " ;
$nombre_grupomodulo = dame_nombre_grupomodulo ( $row3 [ " id_module_group " ]);
if ( $nombre_grupomodulo != " " ){
if (( $label_group == 0 ) || ( $last_label != $nombre_grupomodulo )){ // Show label module group
$label_group = - 1 ;
$last_label = $nombre_grupomodulo ;
$texto = $texto . "
< td class = '$tdcolor' align = 'center' colspan = '7' >
< b > " . $nombre_grupomodulo . " </ b ></ td > " ;
2006-03-27 05:37:27 +02:00
}
2008-06-19 02:24:05 +02:00
}
$nombre_tipo_modulo = dame_nombre_tipo_modulo ( $row3 [ " id_tipo_modulo " ]);
echo " <td class=' " . $tdcolor . " _id' title=' " . salida_limpia ( $row3 [ " nombre " ]) . " '> " ;
echo salida_limpia ( substr ( $row3 [ " nombre " ], 0 , 15 ));
echo " </td><td class=' " . $tdcolor . " '> " ;
echo " <img src='images/ " . show_icon_type ( $row3 [ " id_tipo_modulo " ]) . " ' border=0> " ;
echo " </td><td class=' " . $tdcolor . " '> " ;
if ( $row3 [ " module_interval " ] != 0 ){
echo $row3 [ " module_interval " ];
$real_interval = $row3 [ " module_interval " ];
} else {
echo $intervalo_agente ;
$real_interval = $intervalo_agente ;
}
if (( $row3 [ " id_tipo_modulo " ] != 3 )
AND ( $row3 [ " id_tipo_modulo " ] != 10 )
AND ( $row3 [ " id_tipo_modulo " ] != 17 )
AND ( $row3 [ " id_tipo_modulo " ] != 23 )){
echo " </td><td class=' " . $tdcolor . " f9' title=' " . salida_limpia ( $row3 [ " descripcion " ]) . " '> " ;
echo salida_limpia ( substr ( $row3 [ " descripcion " ], 0 , 32 ));
2006-03-27 05:37:27 +02:00
if ( strlen ( $row3 [ " descripcion " ]) > 32 ){
echo " ... " ;
}
2008-06-19 02:24:05 +02:00
echo " </td> " ;
}
if ( $row3 [ " id_tipo_modulo " ] == 100 ) {
echo " <td class=' " . $tdcolor . " f9' colspan='2' title=' " . $row3 [ " datos " ] . " '> " ;
echo substr ( salida_limpia ( $row3 [ " datos " ]), 0 , 12 );
} else {
// String uses colspan2 and different graphtype
if (( $row3 [ " id_tipo_modulo " ] == 3 )
OR ( $row3 [ " id_tipo_modulo " ] == 10 )
OR ( $row3 [ " id_tipo_modulo " ] == 17 )
OR ( $row3 [ " id_tipo_modulo " ] == 23 )){
$graph_type = " string " ;
echo " <td class=' " . $tdcolor . " f9' colspan=2 title=' " . salida_limpia ( $row3 [ " datos " ]) . " '> " ;
}
elseif (( $row3 [ " id_tipo_modulo " ] == 2 )
OR ( $row3 [ " id_tipo_modulo " ] == 6 )
OR ( $row3 [ " id_tipo_modulo " ] == 21 )
OR ( $row3 [ " id_tipo_modulo " ] == 18 )
OR ( $row3 [ " id_tipo_modulo " ] == 9 )) {
$graph_type = " boolean " ;
echo " <td class= " . $tdcolor . " > " ;
}
else {
$graph_type = " sparse " ;
2006-11-22 19:26:23 +01:00
echo " <td class= " . $tdcolor . " > " ;
2008-06-19 02:24:05 +02:00
}
2007-04-18 11:58:26 +02:00
2008-06-19 02:24:05 +02:00
// Kind of data
if ( is_numeric ( $row3 [ " datos " ])) {
$mytempdata = fmod ( $row3 [ " datos " ], 1 );
if ( $mytempdata == 0 )
$myvalue = intval ( $row3 [ " datos " ]);
2007-08-06 13:44:49 +02:00
else
2008-06-19 02:24:05 +02:00
$myvalue = $row3 [ " datos " ];
echo format_for_graph ( $myvalue );
} else
echo substr ( salida_limpia ( $row3 [ " datos " ]), 0 , 42 );
2006-03-27 05:37:27 +02:00
2008-06-19 02:24:05 +02:00
$handle = " stat " . $nombre_tipo_modulo . " _ " . $row3 [ " id_agente_modulo " ];
$url = 'reporting/procesos.php?agente=' . $row3 [ " id_agente_modulo " ];
$win_handle = dechex ( crc32 ( $row3 [ " id_agente_modulo " ] . $row3 [ " nombre " ]));
echo " <td class= " . $tdcolor . " width='78'> " ;
$graph_label = output_clean_strict ( $row3 [ " nombre " ]);
2006-03-27 05:37:27 +02:00
2008-06-19 02:24:05 +02:00
echo " <a href='javascript:winopeng( \" reporting/stat_win.php?type= $graph_type &period=2419200&id= " . $row3 [ " id_agente_modulo " ] . " &label= " . $graph_label . " refresh=180000 \" , \" month_ " . $win_handle . " \" )'><img src='images/grafica_m.png' border=0></a> " ;
$link = " winopeng('reporting/stat_win.php?type= $graph_type &period=604800&id= " . $row3 [ " id_agente_modulo " ] . " &label= " . $graph_label . " &refresh=6000','week_ " . $win_handle . " ') " ;
echo '<a href="javascript:' . $link . '"><img src="images/grafica_w.png" border=0></a> ' ;
$link = " winopeng('reporting/stat_win.php?type= $graph_type &period=86400&id= " . $row3 [ " id_agente_modulo " ] . " &label= " . $graph_label . " &refresh=600','day_ " . $win_handle . " ') " ;
echo '<a href="javascript:' . $link . '"><img src="images/grafica_d.png" border=0></a> ' ;
$link = " winopeng('reporting/stat_win.php?type= $graph_type &period=3600&id= " . $row3 [ " id_agente_modulo " ] . " &label= " . $graph_label . " &refresh=60','hour_ " . $win_handle . " ') " ;
echo '<a href="javascript:' . $link . '"><img src="images/grafica_h.png" border=0></a>' ;
}
// RAW Table data
echo " <td class= " . $tdcolor . " width=70> " ;
echo " <a href='index.php?sec=estado&sec2=operation/agentes/datos_agente&tipo=mes&id= " . $row3 [ " id_agente_modulo " ] . " '><img border=0 src='images/data_m.png'></a> " ;
echo " <a href='index.php?sec=estado&sec2=operation/agentes/datos_agente&tipo=semana&id= " . $row3 [ " id_agente_modulo " ] . " '><img border=0 src='images/data_w.png'></a> " ;
echo " <a href='index.php?sec=estado&sec2=operation/agentes/datos_agente&tipo=dia&id= " . $row3 [ " id_agente_modulo " ] . " '><img border=0 src='images/data_d.png'></a> " ;
echo " <td class=' " . $tdcolor . " f9'> " ;
if ( $row3 [ " timestamp " ] == " 0000-00-00 00:00:00 " ){
echo $lang_label [ " never " ];
} else {
$ahora = time ();
2008-07-25 20:37:32 +02:00
// Async modules
2008-07-08 22:30:15 +02:00
if (( $row3 [ " id_tipo_modulo " ] > 20 ) AND ( $row3 [ " id_tipo_modulo " ] < 100 )){
echo human_time_comparation ( $row3 [ " timestamp " ]);
} else {
if ( ( $ahora - $row3 [ " utimestamp " ]) > ( $real_interval * 2 )) {
echo " <font color='red'> " ;
echo human_time_comparation ( $row3 [ " timestamp " ]);
echo " </font> " ;
} else
echo human_time_comparation ( $row3 [ " timestamp " ]);
}
2008-06-19 02:24:05 +02:00
}
echo " </td></tr> " ;
}
echo '</table>' ;
2006-03-27 05:37:27 +02:00
}
2006-12-08 17:57:43 +01:00
else {
echo " <div class='nf'> " . $lang_label [ " no_modules " ] . " </div> " ;
}
2008-06-19 02:24:05 +02:00
2006-07-09 01:32:38 +02:00
?>