$nombre_agente, 'direccion' => $direccion_agente, 'id_grupo' => $grupo, 'intervalo' => $intervalo, 'comentarios' => $comentarios, 'modo' => $modo, 'id_os' => $id_os, 'disabled' => $disabled, 'server_name' => $server_name, 'id_parent' => $id_parent, 'custom_id' => $custom_id)); enterprise_hook ('update_agent', array ($id_agente)); if ($id_agente !== false) { // Create address for this agent in taddress agent_add_address ($id_agente, $direccion_agente); $agent_created_ok = true; // Create special module agent_keepalive $id_agent_module = process_sql_insert ('tagente_modulo', array ('nombre' => 'agent_keepalive', 'id_agente' => $id_agente, 'id_tipo_modulo' => 100, 'descripcion' => __('Agent keepalive monitor'), 'id_modulo' => 1, 'min_warning' => 0, 'max_warning' => 1)); if ($id_agent_module !== false) { // Create agent_keepalive in tagente_estado table $result = process_sql_insert ('tagente_estado', array ('id_agente_modulo' => $id_agent_module, 'datos' => '', 'timestamp' => 0, 'estado' => 0, 'id_agente' => $id_agente, 'last_try' => 0, 'utimestamp' => 0, 'current_interval' => 0, 'running_by' => 0, 'last_execution_try' => 0)); if ($result === false) $agent_created_ok = false; } else { $agent_created_ok = false; } } else { $id_agente = 0; $agent_creation_error = __('Could not be created'); } } } // Show tabs $img_style = array ("class" => "top", "width" => 16); if ($id_agente) { echo '"; // Make some space between tabs and title // IE might not always show an empty div, added space echo '
 
'; } // Show agent creation results if ($create_agent) { print_result_message ($agent_created_ok, __('Successfully created'), __('Could not be created')); } // Fix / Normalize module data // =========================== if (isset($_GET["fix_module"])){ $id_module = get_parameter_get ("fix_module",0); // get info about this module $media = get_agentmodule_data_average ($id_module, 30758400); //Get average over the year $media *= 1.3; $error = ""; //If the value of media is 0 or something went wrong, don't delete if (!empty ($media)) { $sql = sprintf ("DELETE FROM tagente_datos WHERE datos > %f AND id_agente_modulo = %d", $media, $id_module); $result = process_sql ($sql); } else { $result = false; $error = " - ".__('No data to normalize'); } print_result_message ($result, __('Deleted data above %d', $media), __('Error normalizing module %s', $error)); } // ================ // Update AGENT // ================ if (isset($_POST["update_agent"])) { // if modified some agent paramenter $id_agente = (int) get_parameter_post ("id_agente"); $nombre_agente = (string) get_parameter_post ("agente"); $direccion_agente = (string) get_parameter_post ("direccion"); $address_list = (string) get_parameter_post ("address_list"); if ($address_list != $direccion_agente && $direccion_agente == get_agent_address ($id_agente) && $address_list != get_agent_address ($id_agente)) { //If we selected another IP in the drop down list to be 'primary': // a) field is not the same as selectbox // b) field has not changed from current IP // c) selectbox is not the current IP $direccion_agente = $address_list; } $grupo = (int) get_parameter_post ("grupo", 0); $intervalo = (int) get_parameter_post ("intervalo", 300); $comentarios = (string) get_parameter_post ("comentarios"); $modo = (bool) get_parameter_post ("modo", 0); //Mode: Learning or Normal $id_os = (int) get_parameter_post ("id_os"); $disabled = (bool) get_parameter_post ("disabled"); $server_name = (string) get_parameter_post ("server_name"); $id_parent = (int) get_parameter_post ("id_parent", 0); $custom_id = (string) get_parameter_post ("custom_id", ""); //Verify if there is another agent with the same name but different ID if ($nombre_agente == "") { echo '

'.__('No agent name specified').'

'; //If there is an agent with the same name, but a different ID } elseif (get_agent_id ($nombre_agente) > 0 && get_agent_id ($nombre_agente) != $id_agente) { echo '

'.__('There is already an agent in the database with this name').'

'; } else { //If different IP is specified than previous, add the IP if ($direccion_agente != '' && $direccion_agente != get_agent_address ($id_agente)) agent_add_address ($id_agente, $direccion_agente); //If IP is set for deletion, delete first if (isset ($_POST["delete_ip"])) { $delete_ip = get_parameter_post ("address_list"); agent_delete_address ($id_agente, $delete_ip); } $result = process_sql_update ('tagente', array ('disabled' => $disabled, 'id_parent' => $id_parent, 'id_os' => $id_os, 'modo' => $modo, 'nombre' => $nombre_agente, 'direccion' => $direccion_agente, 'id_grupo' => $grupo, 'intervalo' => $intervalo, 'comentarios' => $comentarios, 'server_name' => $server_name, 'custom_id' => $custom_id), array ('id_agente' => $id_agente)); if ($result === false) { echo '

'.__('There was a problem updating agent').'

'; } else { enterprise_hook ('update_agent', array ($id_agente)); echo '

'.__('Agent successfully updated').'

'; } } } // Read agent data // This should be at the end of all operation checks, to read the changes - $id_agente doesn't have to be retrieved if ($id_agente) { //This has been done in the beginning of the page, but if an agent was created, this id might change $id_grupo = get_agent_group ($id_agente); if (give_acl ($config["id_user"], $id_grupo, "AW") != 1) { audit_db($config["id_user"],$REMOTE_ADDR, "ACL Violation","Trying to admin an agent without access"); require ("general/noaccess.php"); exit; } $agent = get_db_row ('tagente', 'id_agente', $id_agente); if (empty ($agent)) { //Close out the page echo '

'.__('There was a problem loading agent').'

'; return; } $intervalo = $agent["intervalo"]; // Define interval in seconds $nombre_agente = $agent["nombre"]; $direccion_agente = $agent["direccion"]; $grupo = $agent["id_grupo"]; $ultima_act = $agent["ultimo_contacto"]; $comentarios = $agent["comentarios"]; $server_name = $agent["server_name"]; $modo = $agent["modo"]; $id_os = $agent["id_os"]; $disabled = $agent["disabled"]; $id_parent = $agent["id_parent"]; $custom_id = $agent["custom_id"]; } $update_module = (bool) get_parameter ('update_module'); $create_module = (bool) get_parameter ('create_module'); $edit_module = (bool) get_parameter ('edit_module'); // GET DATA for MODULE UPDATE OR MODULE INSERT if ($update_module || $create_module) { $id_grupo = get_agent_group ($id_agente); if (! give_acl ($config["id_user"], $id_grupo, "AW")) { audit_db ($config["id_user"], $REMOTE_ADDR, "ACL Violation", "Trying to create a module without admin rights"); require ("general/noaccess.php"); exit; } $id_module_type = (int) get_parameter ('id_module_type'); $name = (string) get_parameter ('name'); $description = (string) get_parameter ('description'); $id_module_group = (int) get_parameter ('id_module_group'); $flag = (bool) get_parameter ('flag'); $post_process = (float) get_parameter ('post_process'); $prediction_module = (int) get_parameter ('prediction_module'); $max_timeout = (int) get_parameter ('max_timeout'); $minvalue = (int) get_parameter_post ("min"); $maxvalue = (int) get_parameter ('max'); $interval = (int) get_parameter ('module_interval', $intervalo); $id_prediction_module = (int) get_parameter ('id_prediction_module'); $id_plugin = (int) get_parameter ('id_plugin'); $id_export = (int) get_parameter ('id_export'); $disabled = (bool) get_parameter ('disabled'); $tcp_send = (string) get_parameter ('tcp_send'); $tcp_rcv = (string) get_parameter ('tcp_rcv'); $tcp_port = (int) get_parameter ('tcp_port'); $snmp_community = (string) get_parameter ('snmp_community'); $snmp_oid = (string) get_parameter ('snmp_oid'); if (empty ($snmp_oid)) { /* The user did not set any OID manually but did a SNMP walk */ $snmp_oid = (string) get_parameter ('select_snmp_oid'); } $ip_target = (string) get_parameter ('ip_target'); $plugin_user = (string) get_parameter ('plugin_user'); $plugin_pass = (string) get_parameter ('plugin_pass'); $plugin_parameter = (string) get_parameter ('plugin_parameter'); $custom_id = (string) get_parameter ('custom_id'); $history_data = (int) get_parameter('history_data'); $min_warning = (float) get_parameter ('min_warning'); $max_warning = (float) get_parameter ('max_warning'); $min_critical = (float) get_parameter ('min_critical'); $max_critical = (float) get_parameter ('max_critical'); $ff_event = (int) get_parameter ('ff_event'); } // MODULE UPDATE if ($update_module) { $id_agent_module = (int) get_parameter ('id_agent_module'); $result = process_sql_update ('tagente_modulo', array ('descripcion' => $description, 'id_module_group' => $id_module_group, 'nombre' => $name, 'max' => $maxvalue, 'min' => $minvalue, 'module_interval' => $interval, 'tcp_port' => $tcp_port, 'tcp_send' => $tcp_send, 'tcp_rcv' => $tcp_rcv, 'snmp_community' => $snmp_community, 'snmp_oid' => $snmp_oid, 'ip_target' => $ip_target, 'flag' => $flag, 'disabled' => $disabled, 'id_export' => $id_export, 'plugin_user' => $plugin_user, 'plugin_pass' => $plugin_pass, 'plugin_parameter' => $plugin_parameter, 'id_plugin' => $id_plugin, 'post_process' => $post_process, 'prediction_module' => $prediction_module, 'max_timeout' => $max_timeout, 'custom_id' => $custom_id, 'history_data' => $history_data, 'min_warning' => $min_warning, 'max_warning' => $max_warning, 'min_critical' => $min_critical, 'max_critical' => $max_critical, 'min_ff_event' => $ff_event ), 'id_agente_modulo = '.$id_agent_module); if ($result === false) { echo '

'.__('There was a problem updating module').'

'; } else { echo '

'.__('Module successfully updated').'

'; $id_agent_module = false; $edit_module = false; } } // MODULE INSERT if ($create_module) { if (isset ($_POST["combo_snmp_oid"])) { $combo_snmp_oid = get_parameter_post ("combo_snmp_oid"); } if ($snmp_oid == ""){ $snmp_oid = $combo_snmp_oid; } $id_module = (int) get_parameter ('id_module'); $id_agent_module = process_sql_insert ('tagente_modulo', array ('id_agente' => $id_agente, 'id_tipo_modulo' => $id_module_type, 'nombre' => $name, 'descripcion' => $description, 'max' => $maxvalue, 'min' => $minvalue, 'snmp_oid' => $snmp_oid, 'snmp_community' => $snmp_community, 'id_module_group' => $id_module_group, 'module_interval' => $interval, 'ip_target' => $ip_target, 'tcp_port' => $tcp_port, 'tcp_rcv' => $tcp_rcv, 'tcp_send' => $tcp_send, 'id_export' => $id_export, 'plugin_user' => $plugin_user, 'plugin_pass' => $plugin_pass, 'plugin_parameter' => $plugin_parameter, 'id_plugin' => $id_plugin, 'post_process' => $post_process, 'prediction_module' => $id_prediction_module, 'max_timeout' => $max_timeout, 'disabled' => $disabled, 'id_modulo' => $id_module, 'custom_id' => $custom_id, 'history_data' => $history_data, 'min_warning' => $min_warning, 'max_warning' => $max_warning, 'min_critical' => $min_critical, 'max_critical' => $max_critical, 'min_ff_event' => $ff_event )); if ($id_agent_module === false) { echo '

'.__('There was a problem adding module').'

'; $edit_module = true; } else { $result = process_sql_insert ('tagente_estado', array ('id_agente_modulo' => $id_agent_module, 'datos' => 0, 'timestamp' => '0000-00-00 00:00:00', 'estado' => 0, 'id_agente' => $id_agente, 'utimestamp' => 0, 'status_changes' => 0, 'last_status' => 0 )); if ($result !== false) { echo '

'.__('Module added successfully').'

'; } else { echo '

'.__('Module added successfully').' - '.__('Status init unsuccessful').'

'; } $id_agent_module = false; $edit_module = false; } } // MODULE DELETION // ================= if (isset ($_GET["delete_module"])){ // DELETE agent module ! $id_borrar_modulo = (int) get_parameter_get ("delete_module",0); $id_grupo = (int) dame_id_grupo ($id_agente); if (! give_acl ($config["id_user"], $id_grupo, "AW")) { audit_db($config["id_user"],$REMOTE_ADDR, "ACL Violation", "Trying to delete a module without admin rights"); require ("general/noaccess.php"); exit; } if ($id_borrar_modulo < 1) { audit_db ($config["id_user"],$REMOTE_ADDR, "HACK Attempt", "Expected variable from form is not correct"); die ("Nice try buddy"); exit; } //Init transaction $error = 0; process_sql_begin (); // First delete from tagente_modulo -> if not successful, increment // error if (process_sql ("UPDATE tagente_modulo SET nombre = 'pendingdelete', disabled = 1, delete_pending = 1 WHERE id_agente_modulo = ".$id_borrar_modulo) === false) $error++; if (process_sql ("DELETE FROM tagente_estado WHERE id_agente_modulo = ".$id_borrar_modulo) === false) $error++; if (process_sql ("DELETE FROM tagente_datos_inc WHERE id_agente_modulo = ".$id_borrar_modulo) === false) $error++; //Check for errors if ($error != 0) { echo '

'.__('There was a problem deleting the module').'

'; process_sql_rollback (); } else { echo '

'.__('Module deleted successfully').'

'; process_sql_commit (); } } // ----------------------------------- // Load page depending on tab selected // ----------------------------------- switch ($tab) { case "main": require ("agent_manager.php"); break; case "module": if ($id_agent_module || $edit_module) { require ("module_manager_editor.php"); } else { require ("module_manager.php"); } break; case "alert": /* Because $id_agente is set, it will show only agent alerts */ require ("godmode/alerts/alert_list.php"); break; case "template": require ("agent_template.php"); break; default: if (enterprise_hook ('switch_agent_tab', array ($tab))) //This will make sure that blank pages will have at least some //debug info in them echo '

DEBUG: Invalid tab specified in '.__FILE__.':'.__LINE__.'

'; } ?>