2006-03-27 05:37:27 +02:00
|
|
|
<?php
|
2007-03-12 18:58:52 +01:00
|
|
|
// 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
|
|
|
|
//
|
2006-07-11 10:49:21 +02:00
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU General Public License
|
2007-03-12 18:58:52 +01:00
|
|
|
// as published by the Free Software Foundation; version 2
|
2006-07-11 10:49:21 +02:00
|
|
|
// 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
|
|
|
|
2007-03-12 18:58:52 +01:00
|
|
|
// Load global vars
|
|
|
|
require("include/config.php");
|
|
|
|
|
|
|
|
if (give_acl($id_user, 0, "AW") != 1) {
|
|
|
|
audit_db($id_user,$REMOTE_ADDR, "ACL Violation",
|
|
|
|
"Trying to access Agent Management");
|
|
|
|
require ("general/noaccess.php");
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($_GET["offset"]))
|
|
|
|
$offset = entrada_limpia($_GET["offset"]);
|
|
|
|
else
|
|
|
|
$offset = 0;
|
2006-07-11 10:49:21 +02:00
|
|
|
|
2007-03-12 18:58:52 +01:00
|
|
|
if (isset($_GET["borrar_agente"])){ // if delete agent
|
|
|
|
$id_agente = entrada_limpia($_GET["borrar_agente"]);
|
|
|
|
$agent_name = dame_nombre_agente($id_agente);
|
|
|
|
$id_grupo = dame_id_grupo($id_agente);
|
|
|
|
if (give_acl($id_user, $id_grupo, "AW")==1){
|
|
|
|
// Firts delete from agents table
|
|
|
|
$sql_delete= "DELETE FROM tagente
|
|
|
|
WHERE id_agente = ".$id_agente;
|
|
|
|
$result=mysql_query($sql_delete);
|
|
|
|
if (! $result)
|
|
|
|
echo "<h3 class='error'>".$lang_label["delete_agent_no"]."</h3>";
|
|
|
|
else
|
|
|
|
echo "<h3 class='suc'>".$lang_label["delete_agent_ok"]."</h3>";
|
|
|
|
// Delete agent access table
|
|
|
|
$sql_delete = "DELETE FROM tagent_access
|
|
|
|
WHERE id_agent = ".$id_agente;
|
|
|
|
// Delete tagente_datos data
|
|
|
|
$result=mysql_query($sql_delete);
|
|
|
|
$sql_delete4="DELETE FROM tagente_datos
|
|
|
|
WHERE id_agente=".$id_agente;
|
|
|
|
$result=mysql_query($sql_delete4);
|
|
|
|
// Delete tagente_datos_string data
|
|
|
|
$result=mysql_query($sql_delete);
|
|
|
|
$sql_delete4="DELETE FROM tagente_datos_string
|
|
|
|
WHERE id_agente=".$id_agente;
|
|
|
|
$result=mysql_query($sql_delete4);
|
|
|
|
// Delete from tagente_datos
|
|
|
|
$sql1='SELECT * FROM tagente_modulo
|
|
|
|
WHERE id_agente = '.$id_agente;
|
|
|
|
$result1=mysql_query($sql1);
|
|
|
|
while ($row=mysql_fetch_array($result1)){
|
|
|
|
$sql_delete4="DELETE FROM tagente_datos_inc
|
|
|
|
WHERE id_agente_modulo=".$row["id_agente_modulo"];
|
|
|
|
$result=mysql_query($sql_delete4);
|
|
|
|
}
|
|
|
|
$sql_delete2 ="DELETE FROM tagente_modulo
|
|
|
|
WHERE id_agente = ".$id_agente;
|
|
|
|
$sql_delete3 ="DELETE FROM tagente_estado
|
|
|
|
WHERE id_agente = ".$id_agente;
|
|
|
|
$result=mysql_query($sql_delete2);
|
|
|
|
$result=mysql_query($sql_delete3);
|
2007-03-19 20:39:40 +01:00
|
|
|
|
|
|
|
// Delete IPs from tadress table and taddress_agent
|
|
|
|
$sql = "SELECT * FROM taddress_agent where id_agent = $id_agente";
|
|
|
|
$result=mysql_query($sql);
|
|
|
|
while ($row=mysql_fetch_array($result)){
|
|
|
|
$sql2="DELETE FROM taddress where id_a = ".$row["id_a"];
|
|
|
|
$result2=mysql_query($sql2);
|
|
|
|
}
|
|
|
|
$sql = "DELETE FROM taddress_agent where id_agent = $id_agente";
|
|
|
|
$result=mysql_query($sql);
|
|
|
|
audit_db($id_user,$REMOTE_ADDR, "Agent '$agent_name' deleted", "Agent Management");
|
2007-03-12 18:58:52 +01:00
|
|
|
} else { // NO permissions.
|
2007-03-02 18:56:07 +01:00
|
|
|
audit_db($id_user,$REMOTE_ADDR, "ACL Violation",
|
2007-03-12 18:58:52 +01:00
|
|
|
"Trying to delete agent '$agent_name'");
|
2007-03-02 18:56:07 +01:00
|
|
|
require ("general/noaccess.php");
|
|
|
|
exit;
|
|
|
|
}
|
2007-03-12 18:58:52 +01:00
|
|
|
}
|
|
|
|
echo "<h2>".$lang_label["agent_conf"]." > ".$lang_label["agent_defined2"]."
|
|
|
|
<a href='help/".$help_code."/chap3.php#3' target='_help' class='help'>
|
|
|
|
<span>".$lang_label["help"]."</span></a></h2>";
|
|
|
|
|
|
|
|
// Show group selector
|
|
|
|
if (isset($_POST["ag_group"])){
|
|
|
|
$ag_group = $_POST["ag_group"];
|
|
|
|
echo "<form method='post'
|
|
|
|
action='index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&ag_group_refresh=".$ag_group."'>";
|
|
|
|
} else {
|
|
|
|
echo "<form method='post'
|
|
|
|
action='index.php?sec=gagente&sec2=godmode/agentes/modificar_agente'>";
|
|
|
|
}
|
2007-03-02 18:56:07 +01:00
|
|
|
|
2007-06-06 18:23:24 +02:00
|
|
|
echo "<table cellpadding='4' cellspacing='4' class='databox'><tr>";
|
2007-03-12 18:58:52 +01:00
|
|
|
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>"; // Group all is always active
|
|
|
|
$mis_grupos = list_group ($id_user); //Print combo for groups and set an array with all groups
|
|
|
|
echo "</select>";
|
|
|
|
echo "<td valign='middle'>
|
|
|
|
<noscript>
|
2007-05-08 13:24:57 +02:00
|
|
|
<input name='uptbutton' type='submit' class='sub upd'
|
2007-03-12 18:58:52 +01:00
|
|
|
value='".$lang_label["show"]."'>
|
|
|
|
</noscript>
|
|
|
|
</td>
|
|
|
|
</form>
|
|
|
|
</table>";
|
2007-04-01 20:29:11 +02:00
|
|
|
if (isset($ag_group) && $ag_group> 1){
|
2007-03-12 18:58:52 +01:00
|
|
|
$sql1="SELECT id_agente, nombre, id_grupo, comentarios, id_os
|
|
|
|
FROM tagente WHERE id_grupo = $ag_group ORDER BY nombre LIMIT $offset, $block_size";
|
|
|
|
$sql2="SELECT COUNT(id_agente) FROM tagente WHERE id_grupo = $ag_group";
|
|
|
|
} else {
|
|
|
|
$sql1="SELECT id_agente, nombre, id_grupo, comentarios, id_os
|
|
|
|
FROM tagente ORDER BY nombre LIMIT $offset, $block_size";
|
2007-03-02 18:56:07 +01:00
|
|
|
$sql2="SELECT COUNT(id_agente) FROM tagente";
|
2007-03-12 18:58:52 +01:00
|
|
|
}
|
|
|
|
$result=mysql_query($sql1);
|
|
|
|
$result2=mysql_query($sql2);
|
|
|
|
$row2=mysql_fetch_array($result2);
|
|
|
|
$total_events = $row2[0];
|
2007-03-02 18:56:07 +01:00
|
|
|
|
2007-03-12 18:58:52 +01:00
|
|
|
// Prepare pagination
|
|
|
|
pagination ($total_events, "index.php?sec=gagente&sec2=godmode/agentes/modificar_agente", $offset);
|
|
|
|
echo "<div style='height: 20px'> </div>";
|
|
|
|
|
|
|
|
if (mysql_num_rows($result)){
|
2007-06-06 18:23:24 +02:00
|
|
|
echo "<table cellpadding='4' cellspacing='4' width='700' class='databox'>";
|
|
|
|
echo "<th>".$lang_label["agent_name"]."</th>";
|
|
|
|
echo "<th>".$lang_label["os"]."</th>";
|
|
|
|
echo "<th>".$lang_label["group"]."</th>";
|
|
|
|
echo "<th>".$lang_label["description"]."</th>";
|
|
|
|
echo "<th>".$lang_label["delete"]."</th>";
|
2007-03-12 18:58:52 +01:00
|
|
|
$color=1;
|
|
|
|
while ($row=mysql_fetch_array($result)){
|
|
|
|
$id_grupo = $row["id_grupo"];
|
|
|
|
if ($color == 1){
|
|
|
|
$tdcolor = "datos";
|
|
|
|
$color = 0;
|
2006-07-03 12:49:42 +02:00
|
|
|
}
|
2007-03-12 18:58:52 +01:00
|
|
|
else {
|
|
|
|
$tdcolor = "datos2";
|
|
|
|
$color = 1;
|
|
|
|
}
|
|
|
|
if (give_acl($id_user, $id_grupo, "AW")==1){
|
|
|
|
// Agent name
|
|
|
|
echo "<tr><td class='$tdcolor'>
|
|
|
|
<b><a href='index.php?sec=gagente&
|
|
|
|
sec2=godmode/agentes/configurar_agente&tab=main&
|
|
|
|
id_agente=".$row["id_agente"]."'>".$row["nombre"]."</a></b></td>";
|
|
|
|
// Operating System icon
|
|
|
|
echo "<td class='$tdcolor' align='center'>
|
|
|
|
<img src='images/".dame_so_icon($row["id_os"])."'></td>";
|
|
|
|
// Group icon and name
|
|
|
|
echo "<td class='$tdcolor'>
|
|
|
|
<img src='images/groups_small/".show_icon_group($id_grupo).".png' class='bot' border='0'>
|
|
|
|
".dame_grupo($id_grupo)."</td>";
|
|
|
|
// Description
|
|
|
|
echo "<td class='$tdcolor'>".$row["comentarios"]."</td>";
|
|
|
|
// Action
|
2007-04-21 18:14:11 +02:00
|
|
|
echo "<td class='$tdcolor' align='center'><a href='index.php?sec=gagente&sec2=godmode/agentes/modificar_agente&
|
|
|
|
borrar_agente=".$row["id_agente"]."'";
|
|
|
|
echo ' onClick="if (!confirm(\' '.$lang_label["are_you_sure"].'\')) return false;">';
|
|
|
|
echo "<img border='0' src='images/cross.png'></a></td>";
|
2006-07-03 12:49:42 +02:00
|
|
|
}
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
2007-06-06 18:23:24 +02:00
|
|
|
echo "</table>";
|
|
|
|
echo "<table width='700'><tr><td align='right'>";
|
2007-03-12 18:58:52 +01:00
|
|
|
} else {
|
|
|
|
echo "<div class='nf'>".$lang_label["no_agent_def"]."</div>";
|
2007-04-24 15:38:44 +02:00
|
|
|
echo " </td></tr><tr><td>";
|
2007-04-21 18:14:11 +02:00
|
|
|
}
|
2007-04-11 05:12:48 +02:00
|
|
|
|
2007-04-21 18:14:11 +02:00
|
|
|
// Create agent button
|
2007-03-12 18:58:52 +01:00
|
|
|
echo "<form method='post' action='index.php?sec=gagente&
|
2007-04-11 05:12:48 +02:00
|
|
|
sec2=godmode/agentes/configurar_agente&create_agent=1'>";
|
2007-05-08 13:24:57 +02:00
|
|
|
echo "<input type='submit' class='sub next' name='crt'
|
2007-03-12 18:58:52 +01:00
|
|
|
value='".$lang_label["create_agent"]."'>";
|
2007-04-24 15:38:44 +02:00
|
|
|
echo "</form></td></tr></table>";
|
2006-10-07 13:52:52 +02:00
|
|
|
?>
|