0) { $agent_creation_error = __('There is already an agent in the database with this name'); $agent_created_ok = 0; } else { $sql = sprintf ("INSERT INTO tagente (nombre, direccion, id_grupo, intervalo, comentarios, modo, id_os, disabled, id_network_server, id_plugin_server, id_wmi_server, id_prediction_server, id_parent, custom_id) VALUES ('%s', '%s', %d, %d, '%s', %d, %d, %d, %d, %d, %d, %d, %d, '%s')", $nombre_agente, $direccion_agente, $grupo, $intervalo, $comentarios, $modo, $id_os, $disabled, $id_network_server, $id_plugin_server, $id_wmi_server, $id_prediction_server, $id_parent, $custom_id); $id_agente = process_sql ($sql, "insert_id"); enterprise_hook ('update_agent', array ($id_agente)); if ($id_agente !== false) { $agent_created_ok = 1; $agent_creation_error = ""; // Create special module agent_keepalive $sql = "INSERT INTO tagente_modulo (nombre, id_agente, id_tipo_modulo, descripcion, id_modulo,min_warning, max_warning ) VALUES ('agent_keepalive',".$id_agente.",100,'Agent Keepalive monitor',1 ,0,1)"; $id_agent_module = process_sql ($sql, "insert_id"); if ($id_agent_module !== false) { // Create agent_keepalive in tagente_estado table $sql = "INSERT INTO tagente_estado (id_agente_modulo, datos, timestamp, estado, id_agente, last_try, utimestamp, current_interval, running_by, last_execution_try) VALUES (".$id_agent_module.",'',0,0,".$id_agente.",0,0,0,0,0)"; $result = process_sql ($sql); if ($result === false) { $agent_created_ok = 0; // Do not translate tagente_estado, is the table name $agent_creation_error = __("There was a problem creating record in tagente_estado table"); } } else { $agent_created_ok = 0; $agent_creation_error = __("There was a problem creating agent_keepalive module"); } // Create address for this agent in taddress agent_add_address ($id_agente, $direccion_agente); } else { $id_agente = -1; $agent_created_ok = 0; $agent_creation_error = __("There was a problem creating the agent"); } } } // Show tabs // ----------------- echo ""; // menu_tab_frame // Make some space between tabs and title echo "
 
"; //Some browsers (IE) might not always show an empty div, added space // Show agent creation results if (isset ($_POST["create_agent"])) { if ($agent_created_ok == 0){ echo "

".__('There was a problem creating agent')."

"; echo $agent_creation_error; } else { echo "

".__('Agent successfully 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'); } if ($result !== false) { echo '

'.__('Deleted data above').' '.$media.'

'; } else { echo '

'.__('Error normalizing module').$error.'

'; } } // Delete Alert // ============= if (isset($_GET["delete_alert"])){ // if modified some parameter $id_borrar_modulo = get_parameter_get ("delete_alert",0); // get info about agent $sql = sprintf ("DELETE FROM talerta_agente_modulo WHERE id_aam = %d", $id_borrar_modulo); $result = process_sql ($sql); if ($result === false) { echo '

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

'; } else { echo '

'.__('Alert successfully deleted').'

'; } } // Delete Alert component (from a combined) // ========================================== if (isset($_GET["delete_alert_comp"])) { // if modified some parameter $id_borrar_modulo = get_parameter_get ("delete_alert_comp",0); // get info about agent $sql = sprintf ("DELETE FROM tcompound_alert WHERE id_aam = %d", $id_borrar_modulo); $result = process_sql ($sql); if ($result === false) { echo '

'.__('There was a problem deleting alert').'

'; } else { echo '

'.__('Alert successfully deleted').'

'; } } // Create alert // ============= if (isset($_POST["insert_alert"])){ // if created alert $combined = get_parameter ("combined",0); $id_agente_modulo = get_parameter ("agente_modulo",0); $maximo = get_parameter ("maximo",0); $minimo = get_parameter ("minimo",0); $descripcion= get_parameter ('descripcion', ''); $campo_1 = get_parameter ('campo_1', ''); $campo_2 = get_parameter ('campo_2', ''); $campo_3 = get_parameter ('campo_3', ''); $tipo_alerta = get_parameter ("tipo_alerta",3); $alert_text = get_parameter ("alert_text",''); $time_threshold = get_parameter ("time_threshold",900); $max_alerts = get_parameter ("max_alerts",1); $min_alerts = get_parameter ("min_alerts",0); $time_from = get_parameter ("time_from"); $time_to= get_parameter ("time_to"); $other = get_parameter ("other",0); $disable_alert = get_parameter ("disable_alert"); $alert_d1 = get_parameter("alert_d1",0); $alert_d2 = get_parameter("alert_d2",0); $alert_d3 = get_parameter("alert_d3",0); $alert_d4 = get_parameter("alert_d4",0); $alert_d5 = get_parameter("alert_d5",0); $alert_d6 = get_parameter("alert_d6",0); $alert_d7 = get_parameter("alert_d7",0); $alert_recovery = get_parameter("alert_recovery", 1); $alert_priority = get_parameter("alert_priority", 0); $campo2_rec = get_parameter ("campo_2_rec",""); $campo3_rec = get_parameter ("campo_3_rec",""); if ($combined == 1) { $alert_id_agent = $id_agente; } else { $alert_id_agent = 0; } if ($time_threshold == -1) { $time_threshold = $other; } $sql = sprintf ("INSERT INTO talerta_agente_modulo (id_agente_modulo, id_alerta, al_campo1, al_campo2, al_campo3, descripcion, dis_max, dis_min, time_threshold, max_alerts, min_alerts, alert_text, disable, time_from, time_to, id_agent, monday, tuesday, wednesday, thursday, friday, saturday, sunday, recovery_notify, priority, al_f2_recovery, al_f3_recovery) VALUES (%d,%d,'%s','%s','%s','%s',%f,%f,%d,%d,%d,'%s',%d,'%s','%s',%d,%d,%d,%d,%d,%d,%d,%d,%d,%d,'%s','%s')", $id_agente_modulo, $tipo_alerta, $campo_1, $campo_2, $campo_3, $descripcion, $maximo, $minimo, $time_threshold, $max_alerts, $min_alerts, $alert_text, $disable_alert, $time_from, $time_to, $alert_id_agent, $alert_d1, $alert_d2, $alert_d3, $alert_d4, $alert_d5, $alert_d6, $alert_d7, $alert_recovery, $alert_priority, $campo2_rec, $campo3_rec); $id_alerta_agente_modulo = process_sql ($sql, "insert_id"); //False or 0 is invalid if (empty ($id_alerta_agente_modulo)) { echo '

'.__('There was a problem creating alert').'

'; } else { echo '

'.__('Alert successfully created').'

'; } } // Combined ALERT - Add component // ================================ if (isset($_POST["add_alert_combined"])){ // Update an existing alert $alerta_id_aam = get_parameter ("update_alert",-1); $component_item = get_parameter ("component_item",-1); $component_operation = get_parameter ("component_operation","AND"); $sql = sprintf ("INSERT INTO tcompound_alert (id, id_aam, operation) VALUES (%d, %d, '%s')", $alerta_id_aam, $component_item, $component_operation); $result = process_sql ($sql); if ($result === false) { echo '

'.__('There was a problem creating the combined alert').'

'; } else { echo '

'.__('Combined alert successfully created').'

'; } } // Update ALERT // ============= if (isset($_POST["update_alert"])) { // Update an existing alert $id_agente_modulo = get_parameter ("agente_modulo",0); $id_aam = get_parameter ("id_aam",0); $maximo = get_parameter ("maximo",0); $minimo = get_parameter ("minimo",0); $descripcion= get_parameter ('descripcion', ''); $campo_1 = get_parameter ('campo_1', ''); $campo_2 = get_parameter ('campo_2', ''); $campo_3 = get_parameter ('campo_3', ''); $tipo_alerta = get_parameter ("tipo_alerta",3); $alert_text = get_parameter ("alert_text",''); $time_threshold = get_parameter ("time_threshold",900); $max_alerts = get_parameter ("max_alerts",1); $min_alerts = get_parameter ("min_alerts",0); $time_from = get_parameter ("time_from"); $time_to= get_parameter ("time_to"); $other = get_parameter ("other",0); $disable_alert = get_parameter ("disable_alert"); $alert_d1 = get_parameter("alert_d1",0); $alert_d2 = get_parameter("alert_d2",0); $alert_d3 = get_parameter("alert_d3",0); $alert_d4 = get_parameter("alert_d4",0); $alert_d5 = get_parameter("alert_d5",0); $alert_d6 = get_parameter("alert_d6",0); $alert_d7 = get_parameter("alert_d7",0); $alert_recovery = get_parameter("alert_recovery", 1); $alert_priority = get_parameter("alert_priority", 0); $campo2_rec = get_parameter ("campo_2_rec",""); $campo3_rec = get_parameter ("campo_3_rec",""); $alert_d1 = get_parameter("alert_d1",0); $alert_d2 = get_parameter("alert_d2",0); $alert_d3 = get_parameter("alert_d3",0); $alert_d4 = get_parameter("alert_d4",0); $alert_d5 = get_parameter("alert_d5",0); $alert_d6 = get_parameter("alert_d6",0); $alert_d7 = get_parameter("alert_d7",0); $alert_recovery = get_parameter("alert_recovery", 1); $alert_priority = get_parameter("alert_priority", 0); $campo2_rec = get_parameter ("campo_2_rec",""); $campo3_rec = get_parameter ("campo_3_rec",""); if ($time_threshold == -1) { $time_threshold = $other; } $sql = sprintf ("UPDATE talerta_agente_modulo SET id_alerta = %d, max_alerts = %d, min_alerts = %d, time_threshold = '%s', dis_min = %f, dis_max = %f, al_campo3 = '%s', al_campo2 = '%s', al_campo1 = '%s', descripcion = '%s', alert_text = '%s', time_to = '%s', time_from = '%s', disable = %d, monday = %d, tuesday = %d, wednesday = %d, thursday = %d, friday = %d, saturday = %d, sunday = %d, recovery_notify = %d, priority = %d, al_f2_recovery = '%s', al_f3_recovery = '%s' WHERE id_aam = %d", $tipo_alerta, $max_alerts, $min_alerts, $time_threshold, $minimo, $maximo, $campo_3, $campo_2, $campo_1, $descripcion, $alert_text, $time_to, $time_from, $disable_alert, $alert_d1, $alert_d2, $alert_d3, $alert_d4, $alert_d5, $alert_d6, $alert_d7, $alert_recovery, $alert_priority, $campo2_rec, $campo3_rec, $id_aam); $result = process_sql ($sql); if ($result === false) { echo '

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

'; } else { echo '

'.__('Alert successfully updated').'

'; } } // ================ // Update AGENT // ================ if (isset($_POST["update_agent"])) { // if modified some agent paramenter $id_agente = (int) get_parameter_post ("id_agente", 0); $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"); $id_network_server = (int) get_parameter_post ("network_server", 0); $id_plugin_server = (int) get_parameter_post ("plugin_server", 0); $id_wmi_server = (int) get_parameter_post ("wmi_server", 0); $id_prediction_server = (int) get_parameter_post ("prediction_server", 0); $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 (dame_agente_id ($nombre_agente) > 0 && dame_agente_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); } //Now update the thing $sql = sprintf ("UPDATE tagente SET disabled = %d, id_parent = %d, id_os = %d, modo = %d, nombre = '%s', direccion = '%s', id_grupo = %d, intervalo = %d, comentarios = '%s', id_network_server = %d, id_plugin_server = %d, id_wmi_server = %d, id_prediction_server = %d, custom_id = '%s' WHERE id_agente = %d", $disabled, $id_parent, $id_os, $modo, $nombre_agente, $direccion_agente, $grupo, $intervalo, $comentarios, $id_network_server, $id_plugin_server, $id_wmi_server, $id_prediction_server, $custom_id, $id_agente); $result = process_sql ($sql); if ($result === false) { echo '

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

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

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

'; } } } if ((isset($agent_created_ok)) && ($agent_created_ok == 1)){ $_GET["id_agente"] = $id_agente; } // Read agent data // This should be at the end of all operation checks, to read the changess if (isset($_GET["id_agente"])) { //This has been done in the beginning of the page, but if an agent was created, this id might change $id_agente = get_parameter_get ("id_agente"); $id_grupo = dame_id_grupo ($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').'

'; echo '"; exit; } $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"]; $id_plugin_server = $agent["id_plugin_server"]; $id_network_server = $agent["id_network_server"]; $id_prediction_server = $agent["id_prediction_server"]; $id_wmi_server = $agent["id_wmi_server"]; $modo = $agent["modo"]; $id_os = $agent["id_os"]; $disabled = $agent["disabled"]; $id_parent = $agent["id_parent"]; $custom_id = $agent["custom_id"]; } // Read data module if editing module // ================================== if ((isset ($_GET["update_module"])) && (!isset ($_POST["oid"])) && (!isset ($_POST["update_module"]))) { $update_module = 1; $id_agente_modulo = (int) get_parameter_get ("update_module",0); $module = get_db_row ('tagente_modulo', 'id_agente_modulo', $id_agente_modulo); if ($module === false) { echo '

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

'; } else { $modulo_id_agente = $module["id_agente"]; $modulo_id_tipo_modulo = $module["id_tipo_modulo"]; $modulo_nombre = $module["nombre"]; $modulo_descripcion = $module["descripcion"]; $tcp_send = $module["tcp_send"]; $tcp_rcv = $module["tcp_rcv"]; $ip_target = $module["ip_target"]; $snmp_community = $module["snmp_community"]; $snmp_oid = $module["snmp_oid"]; $id_module_group = $module["id_module_group"]; $module_interval = $module["module_interval"]; $modulo_max = $module["max"]; if (empty ($modulo_max)) $modulo_max = "N/A"; if (empty ($modulo_min)) $modulo_min = "N/A"; $custom_id = $module["custom_id"]; } } // Read ALERT data if editing alert // ================================== if (isset ($_GET["update_alert"])) { $id_grupo = dame_id_grupo ($id_agente); if (give_acl ($config["id_user"], $id_grupo, "LW") == 0){ audit_db($config["id_user"],$REMOTE_ADDR, "ACL Violation","Trying to update an alert without admin rights"); require ("general/noaccess.php"); exit; } $update_alert = 1; $id_aam = (int) get_parameter_get ("update_alert",0); $alert = get_db_row ('talerta_agente_modulo', 'id_aam', $id_aam); if ($alert === false) { echo '

'.__('There was a problem loading the alert').'

'; } else { $alerta_id_aam = $alert["id_aam"]; $alerta_campo1 = $alert["al_campo1"]; $alerta_campo2 = $alert["al_campo2"]; $alerta_campo3 = $alert["al_campo3"]; $alerta_campo2_rec = $alert["al_f2_recovery"]; $alerta_campo3_rec = $alert["al_f3_recovery"]; $alerta_dis_max = $alert["dis_max"]; $alerta_dis_min = $alert["dis_min"]; $tipo_alerta = $alert["id_alerta"]; $alert_text = $alert["alert_text"]; $alerta_max_alerts = $alert["max_alerts"]; $alerta_min_alerts = $alert["min_alerts"]; $alerta_time_threshold = $alert["time_threshold"]; $alerta_descripcion = $alert["descripcion"]; $alerta_disable = $alert["disable"]; $time_from = $alert["time_from"]; $time_to = $alert["time_to"]; $alerta_id_agentemodulo = $alert["id_agente_modulo"]; // Only to show, cannot be changed $alert_id_agent = $alert["id_agent"]; $alert_d1 = $alert["monday"]; $alert_d2 = $alert["tuesday"]; $alert_d3 = $alert["wednesday"]; $alert_d4 = $alert["thursday"]; $alert_d5 = $alert["friday"]; $alert_d6 = $alert["saturday"]; $alert_d7 = $alert["sunday"]; $alert_recovery = $alert["recovery_notify"]; $alert_priority = $alert["priority"]; } } // GET DATA for MODULE UPDATE OR MODULE INSERT // =========================================== if ((isset ($_POST["update_module"])) || (isset ($_POST["insert_module"]))) { if (isset ($_POST["update_module"])) { $update_module = 1; $id_agente_modulo = get_parameter_post ("id_agente_modulo",0); } $id_grupo = dame_id_grupo ($id_agente); if (give_acl ($config["id_user"], $id_grupo, "AW") == 0) { audit_db ($config["id_user"],$REMOTE_ADDR, "ACL Violation","Trying to create a module without admin rights"); require ("general/noaccess.php"); exit; } $form_id_tipo_modulo = (int) get_parameter ("form_id_tipo_modulo",0); $form_name = (string) get_parameter ("form_name",0); $form_description = (string) get_parameter ("form_description",""); $form_id_module_group = (int) get_parameter ("form_id_module_group",0); $form_flag = (bool) get_parameter ("form_flag",0); $form_post_process = (float) get_parameter ("form_post_process",0); $form_prediction_module = (int) get_parameter ("form_prediction_module",0); $form_max_timeout = (int) get_parameter ("form_max_timeout",0); $form_minvalue = (int) get_parameter_post ("form_minvalue",0); $form_maxvalue = (int) get_parameter ("form_maxvalue",0); $form_interval = (int) get_parameter ("form_interval",300); $form_id_prediction_module = (int) get_parameter ("form_id_prediction_module",0); $form_id_plugin = (int) get_parameter ("form_id_plugin",0); $form_id_export = (int) get_parameter ("form_id_export",0); $form_disabled = (bool) get_parameter ("form_disabled",0); $form_tcp_send = (string) get_parameter ("form_tcp_send",""); $form_tcp_rcv = (string) get_parameter ("form_tcp_rcv",""); $form_tcp_port = (int) get_parameter ("form_tcp_port",0); $form_snmp_community = (string) get_parameter ("form_snmp_community",""); $form_snmp_oid = (string) get_parameter ("form_snmp_oid",""); $form_ip_target = (string) get_parameter ("form_ip_target",""); $form_plugin_user = (string) get_parameter ("form_plugin_user",""); $form_plugin_pass = (string) get_parameter ("form_plugin_pass",""); $form_plugin_parameter = (string) get_parameter ("form_plugin_parameter",""); $form_id_modulo = (int) get_parameter ("form_id_modulo",0); $form_custom_id = (string) get_parameter ("form_custom_id",""); $form_history_data = (int) get_parameter('form_history_data',0); $form_min_warning = (float) get_parameter ('form_min_warning', 0); $form_max_warning = (float) get_parameter ('form_max_warning', 0); $form_min_critical = (float) get_parameter ('form_min_critical', 0); $form_max_critical = (float) get_parameter ('form_max_critical', 0); $form_ff_event = (int) get_parameter ('form_ff_event', 0); } // MODULE UPDATE // ================= if ((isset ($_POST["update_module"])) && (!isset ($_POST["oid"]))) { // if modified something if (isset ($_POST["form_combo_snmp_oid"])) { $form_combo_snmp_oid = get_parameter_post ("form_combo_snmp_oid"); if ($snmp_oid == "") { $snmp_oid = $form_combo_snmp_oid; } } $sql = sprintf ("UPDATE tagente_modulo SET descripcion = '%s', id_module_group = %d, nombre = '%s', max = %d, min = %d, module_interval = %d, tcp_port = %d, tcp_send = '%s', tcp_rcv = '%s', snmp_community = '%s', snmp_oid = '%s', ip_target = '%s', flag = %d, id_modulo = %d, disabled = %d, id_export = %d, plugin_user = '%s', plugin_pass = '%s', plugin_parameter = '%s', id_plugin = %d, post_process = %f, prediction_module = %d, max_timeout = %d, custom_id = '%s', history_data = %d, min_warning = %f, max_warning = %f, min_critical = %f, max_critical = %f, min_ff_event = %d WHERE id_agente_modulo = %d", $form_description, $form_id_module_group, $form_name, $form_maxvalue, $form_minvalue, $form_interval, $form_tcp_port, $form_tcp_send, $form_tcp_rcv, $form_snmp_community, $form_snmp_oid, $form_ip_target, $form_flag, $form_id_modulo, $form_disabled, $form_id_export, $form_plugin_user, $form_plugin_pass, $form_plugin_parameter, $form_id_plugin, $form_post_process, $form_prediction_module, $form_max_timeout, $form_custom_id, $form_history_data, $form_min_warning, $form_max_warning, $form_min_critical, $form_max_critical, $form_ff_event, $id_agente_modulo); $result = process_sql ($sql); if ($result === false) { echo '

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

'; } else { echo '

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

'; } } // ========================================================= // OID Refresh button to get SNMPWALK from data in form // This code is also applied when submitting a new module (insert_module = 1) // ========================================================= if (isset ($_POST["oid"])){ snmp_set_quick_print (1); $snmpwalk = snmprealwalk ($form_ip_target, $form_snmp_community, ''); if (empty ($snmpwalk)) { echo '

'.__('Cannot read from SNMP source').'

'; } else { echo '

'.__('SNMP source has been scanned').'

'; } } // ========================================================= // MODULE INSERT // ========================================================= if (((!isset ($_POST["nc"]) OR ($_POST["nc"] == -1))) && (!isset ($_POST["oid"])) && (isset ($_POST["insert_module"])) && (isset ($_POST['crtbutton']))) { if (isset ($_POST["form_combo_snmp_oid"])) { $combo_snmp_oid = get_parameter_post ("form_combo_snmp_oid"); } if ($form_snmp_oid == ""){ $form_snmp_oid = $combo_snmp_oid; } if ($form_tcp_port == "") { $form_tcp_port= "0"; } $sql = sprintf ("INSERT INTO tagente_modulo (id_agente, id_tipo_modulo, nombre, descripcion, max, min, snmp_oid, snmp_community, id_module_group, module_interval, ip_target, tcp_port, tcp_rcv, tcp_send, id_export, plugin_user, plugin_pass, plugin_parameter, id_plugin, post_process, prediction_module, max_timeout, disabled, id_modulo, custom_id, history_data, min_warning, max_warning, min_critical, max_critical, min_ff_event) VALUES (%d,%d,'%s','%s',%d,%d,'%s','%s',%d,%d,'%s',%d,'%s','%s',%d,'%s','%s','%s',%d,%d,%d,%d,%d,%d,'%s', %d, %f, %f, %f, %f, %d)", $id_agente, $form_id_tipo_modulo, $form_name, $form_description, $form_maxvalue, $form_minvalue, $form_snmp_oid, $form_snmp_community, $form_id_module_group, $form_interval, $form_ip_target, $form_tcp_port, $form_tcp_rcv, $form_tcp_send, $form_id_export, $form_plugin_user, $form_plugin_pass, $form_plugin_parameter, $form_id_plugin, $form_post_process, $form_id_prediction_module, $form_max_timeout, $form_disabled, $form_id_modulo, $form_custom_id, $form_history_data, $form_min_warning, $form_max_warning, $form_min_critical, $form_max_critical, $form_ff_event); $id_agente_modulo = process_sql ($sql, 'insert_id'); if ($id_agente_modulo === false){ echo '

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

'; } else { $sql = sprintf ("INSERT INTO tagente_estado (id_agente_modulo,datos,timestamp,estado,id_agente, utimestamp, status_changes, last_status) VALUES (%d, 0,'0000-00-00 00:00:00',0,%d,0,0,0)",$id_agente_modulo,$id_agente); $result = process_sql ($sql); if ($result !== false) { echo '

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

'; } else { echo '

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

'; } } } // 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") == 0){ 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 ("SET AUTOCOMMIT=0;"); process_sql ("START TRANSACTION;"); // First delete from tagente_modulo -> if not successful, increment // error if (process_sql ("UPDATE tagente_modulo SET 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++; //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;"); } //End transaction process_sql ("SET AUTOCOMMIT=1;"); } // ----------------------------------- // Load page depending on tab selected // ----------------------------------- switch ($tab) { case "main": require "agent_manager.php"; break; case "module": if (($form_moduletype == "") && ($moduletype == "")) { require "module_manager.php"; } else { require "module_manager_editor.php"; } break; case "alert": if (($form_alerttype == "") && (!isset($_GET["update_alert"]))) { require "alert_manager.php"; } else { require "alert_manager_editor.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__.'

'; } ?>