".__('Agent configuration')." » ".__('Modules').""; } enterprise_include ('godmode/agentes/module_manager.php'); $isFunctionPolicies = enterprise_include_once ('include/functions_policies.php'); // Create module/type combo echo ''; echo ''; echo "'; echo '
"; // Check if there is at least one server of each type available to assign that // kind of modules. If not, do not show server type in combo $network_available = get_db_sql ("SELECT count(*) from tserver where server_type = 1"); $wmi_available = get_db_sql ("SELECT count(*) from tserver where server_type = 6"); $plugin_available = get_db_sql ("SELECT count(*) from tserver where server_type = 4"); $prediction_available = get_db_sql ("SELECT count(*) from tserver where server_type = 5"); // Development mode to use all servers if ($develop_bypass) { $network_available = 1; $wmi_available = 1; $plugin_available = 1; $prediction_available = 1; } $modules = array (); $modules['dataserver'] = __('Create a new data server module'); if ($network_available) $modules['networkserver'] = __('Create a new network server module'); if ($plugin_available) $modules['pluginserver'] = __('Create a new plugin server module'); if ($wmi_available) $modules['wmiserver'] = __('Create a new WMI server module'); if ($prediction_available) $modules['predictionserver'] = __('Create a new prediction server module'); enterprise_hook ('set_enterprise_module_types', array (&$modules)); print_select ($modules, 'moduletype', '', '', '', '', false, false, false); print_input_hidden ('edit_module', 1); echo ''; echo ''; echo ""; echo "
"; if (! isset ($id_agente)) return; $multiple_delete = get_parameter('multiple_delete'); if ($multiple_delete) { $id_agent_modules_delete = (array)get_parameter('id_delete'); foreach($id_agent_modules_delete as $id_agent_module_del) { $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_agent_module_del < 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. NOTICE that we don't delete all data here, just marking for deletion // and delete some simple data. if (process_sql ("UPDATE tagente_modulo SET nombre = 'pendingdelete', disabled = 1, delete_pending = 1 WHERE id_agente_modulo = ".$id_agent_module_del) === false) $error++; if (process_sql ("DELETE FROM tagente_estado WHERE id_agente_modulo = ".$id_agent_module_del) === false) $error++; if (process_sql ("DELETE FROM tagente_datos_inc WHERE id_agente_modulo = ".$id_agent_module_del) === false) $error++; //Check for errors if ($error != 0) { process_sql_rollback (); print_error_message (__('There was a problem deleting the module')); } else { process_sql_commit (); print_success_message (__('Module deleted succesfully')); } } } // ========================== // MODULE VISUALIZATION TABLE // ========================== echo "

".__('Assigned modules')."

"; $modules = get_db_all_rows_filter ('tagente_modulo', array ('delete_pending' => 0, 'id_agente' => $id_agente, 'order' => 'id_module_group, nombre'), array ('id_agente_modulo', 'id_tipo_modulo', 'descripcion', 'nombre', 'max', 'min', 'module_interval', 'id_modulo', 'id_module_group', 'disabled',)); if ($modules === false) { echo "
".__('No available data to show')."
"; return; } $table->width = '95%'; $table->head = array (); $table->head[0] = __('Name'); if ($isFunctionPolicies !== ENTERPRISE_NOT_HOOK) $table->head[1] = "" . __('P.') . ""; $table->head[2] = "" . __('S.') . ""; $table->head[3] = __('Type'); $table->head[4] = __('Interval'); $table->head[5] = __('Description'); $table->head[6] = __('Max/Min'); $table->head[7] = __('Action'); $table->style = array (); $table->style[0] = 'font-weight: bold'; $table->size = array (); $table->size[2] = '35px'; $table->size[7] = '65px'; $table->align = array (); $table->align[2] = 'left'; $table->align[7] = 'left'; $table->data = array (); $agent_interval = get_agent_interval ($id_agente); $last_modulegroup = "0"; //Extract the ids only numeric modules for after show the normalize link. $tempRows = get_db_all_rows_sql("SELECT * FROM ttipo_modulo WHERE nombre NOT LIKE '%string%' AND nombre NOT LIKE '%proc%'"); $numericModules = array(); foreach($tempRows as $row) { $numericModules[$row['id_tipo']] = true; } foreach ($modules as $module) { $type = $module["id_tipo_modulo"]; $id_module = $module["id_modulo"]; $nombre_modulo = $module["nombre"]; $descripcion = $module["descripcion"]; $module_max = $module["max"]; $module_min = $module["min"]; $module_interval2 = $module["module_interval"]; $module_group2 = $module["id_module_group"]; $data = array (); if ($module['id_module_group'] != $last_modulegroup) { $last_modulegroup = $module['id_module_group']; $data[0] = ''.get_modulegroup_name ($last_modulegroup).''; $i = array_push ($table->data, $data); $table->rowclass[$i - 1] = 'datos3'; if ($isFunctionPolicies !== ENTERPRISE_NOT_HOOK) $table->colspan[$i - 1][0] = 8; else $table->colspan[$i - 1][0] = 7; $data = array (); } $data[0] = ''; if ($module["disabled"]) $data[0] .= ''.$module['nombre'].''; else $data[0] .= $module['nombre']; $data[0] .= ''; if ($isFunctionPolicies !== ENTERPRISE_NOT_HOOK) { $policyInfo = isModuleInPolicy($module['id_agente_modulo'], false); if ($policyInfo === false) $data[1] = ''; else { $img = 'images/policies.png'; $data[1] = '' . print_image($img,true, array('title' => $policyInfo['name_policy'])) . ''; } } // Module type (by server type ) $data[2] = ''; if ($module['id_modulo'] > 0) { $data[2] = show_server_type ($module['id_modulo']); } // This module is initialized ? (has real data) $module_init = get_db_value ('utimestamp', 'tagente_estado', 'id_agente_modulo', $module['id_agente_modulo']); if ($module_init == 0) $data[2] .= print_image ('images/error.png', true, array ('title' => __('Non initialized module'))); // Module type (by data type) $data[3] = ''; if ($type) { $data[3] = print_moduletype_icon ($type, true); } // Module interval if ($module['module_interval']) { $data[4] = $module['module_interval']; } else { $data[4] = $agent_interval; } $data[5] = substr ($module['descripcion'], 0, 30); // MAX / MIN values $data[6] = $module["max"] ? $module["max"] : __('N/A'); $data[6] .= ' / '.($module["min"] != $module['max']? $module["min"] : __('N/A')); // Delete module $data[7] = print_checkbox('id_delete[]', $module['id_agente_modulo'], false, true); $data[7] .= ''; $data[7] .= print_image ('images/cross.png', true, array ('title' => __('Delete'))); $data[7] .= ' '; // Make a data normalization if (isset($numericModules[$type])) { if ($numericModules[$type] === true) { $data[7] .= ''; $data[7] .= print_image ('images/chart_curve.png', true, array ('title' => __('Normalize'))); $data[7] .= ''; } } array_push ($table->data, $data); } echo '
'; print_table ($table); echo '
'; print_input_hidden ('multiple_delete', 1); print_submit_button (__('Delete'), 'multiple_delete', false, 'class="sub"'); echo '
'; echo '
' ?>