".__('Modules').""; } enterprise_include ('godmode/agentes/module_manager.php'); $isFunctionPolicies = enterprise_include_once ('include/functions_policies.php'); // Create module/type combo echo ''; echo ''; echo "'; 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"); //POSTGRESQL COMPATIBLE $wmi_available = get_db_sql ("SELECT count(*) from tserver where server_type = 6"); //POSTGRESQL COMPATIBLE $plugin_available = get_db_sql ("SELECT count(*) from tserver where server_type = 4"); //POSTGRESQL COMPATIBLE $prediction_available = get_db_sql ("SELECT count(*) from tserver where server_type = 5"); //POSTGRESQL COMPATIBLE // 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)); $sec2 = get_parameter('sec2', ''); if (strstr($sec2, "enterprise/godmode/policies/policies") !== false) { unset($modules['predictionserver']); } print_select ($modules, 'moduletype', '', '', '', '', false, false, false); print_input_hidden ('edit_module', 1); echo ''; echo ''; echo '
"; if (! isset ($id_agente)) return; $multiple_delete = (bool) 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) get_agent_group($id_agente); if (! check_acl ($config["id_user"], $id_grupo, "AW")) { pandora_audit("ACL Violation", "Trying to delete a module without admin rights"); require ("general/noaccess.php"); exit; } if ($id_agent_module_del < 1) { pandora_audit("HACK Attempt", "Expected variable from form is not correct"); die ("Nice try buddy"); exit; } enterprise_include_once('include/functions_config_agents.php'); enterprise_hook('deleteLocalModuleInConf', array(get_agentmodule_agent($id_agent_module_del), get_agentmodule_name($id_agent_module_del))); //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++; $result = process_sql_delete('tagente_estado', array('id_agente_modulo' => $id_agent_module_del)); if ($result === false) $error++; $result = process_sql_delete('tagente_datos_inc', array('id_agente_modulo' => $id_agent_module_del)); if ($result === 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')."

"; $url = 'index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&tab=module&id_agente=' . $id_agente; $selectNameUp = ''; $selectNameDown = ''; $selectServerUp = ''; $selectServerDown = ''; $selectTypeUp = ''; $selectTypeDown = ''; $selectIntervalUp = ''; $selectIntervalDown = ''; $sortField = get_parameter('sort_field'); $sort = get_parameter('sort', 'none'); $selected = 'border: 1px solid black;'; $order[] = array('field' => 'id_module_group', 'order' => 'ASC'); switch ($sortField) { case 'name': switch ($sort) { case 'up': $selectNameUp = $selected; $order[] = array('field' => 'tagente_modulo.nombre', 'order' => 'ASC'); break; case 'down': $selectNameDown = $selected; $order[] = array('field' => 'tagente_modulo.nombre', 'order' => 'DESC'); break; } break; case 'server': switch ($sort) { case 'up': $selectServerUp = $selected; $order[] = array('field' => 'id_modulo', 'order' => 'ASC'); break; case 'down': $selectServerDown = $selected; $order[] = array('field' => 'id_modulo', 'order' => 'DESC'); break; } break; case 'type': switch ($sort) { case 'up': $selectTypeUp = $selected; $order[] = array('field' => 'id_tipo_modulo', 'order' => 'ASC'); break; case 'down': $selectTypeDown = $selected; $order[] = array('field' => 'id_tipo_modulo', 'order' => 'DESC'); break; } break; case 'interval': switch ($sort) { case 'up': $selectIntervalUp = $selected; $order[] = array('field' => 'module_interval', 'order' => 'ASC'); break; case 'down': $selectIntervalDown = $selected; $order[] = array('field' => 'module_interval', 'order' => 'DESC'); break; } break; default: $selectNameUp = $selected; $selectNameDown = ''; $selectServerUp = ''; $selectServerDown = ''; $selectTypeUp = ''; $selectTypeDown = ''; $selectIntervalUp = ''; $selectIntervalDown = ''; $order[] = array('field' => 'nombre', 'order' => 'ASC'); break; } $modules = get_db_all_rows_filter ('tagente_modulo', array ('delete_pending' => 0, 'id_agente' => $id_agente, 'order' => $order), 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') . ' ' . '' . print_image("images/sort_up.png", true, array("style" => $selectNameUp)) . '' . '' . print_image("images/sort_down.png", true, array("style" => $selectNameDown)) . ''; if ($isFunctionPolicies !== ENTERPRISE_NOT_HOOK) $table->head[1] = "" . __('P.') . ""; $table->head[2] = "" . __('S.') . "" . ' ' . '' . print_image("images/sort_up.png", true, array("style" => $selectServerUp)) . '' . '' . print_image("images/sort_down.png", true, array("style" => $selectServerDown)) . ''; $table->head[3] = __('Type') . ' ' . '' . print_image("images/sort_up.png", true, array("style" => $selectTypeUp)) .'' . '' . print_image("images/sort_down.png", true, array("style" => $selectTypeDown)) . ''; $table->head[4] = __('Interval') . ' ' . '' . print_image("images/sort_up.png", true, array("style" => $selectIntervalUp)) . '' . '' . print_image("images/sort_down.png", true, array("style" => $selectIntervalDown)) . ''; $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] = '55px'; $table->size[7] = '90px'; $table->align = array (); $table->align[2] = 'center'; $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] .= ''.printTruncateText($module['nombre'], 25, false).''; else $data[0] .= printTruncateText($module['nombre'], 25, false); $data[0] .= ''; if ($isFunctionPolicies !== ENTERPRISE_NOT_HOOK) { $policyInfo = infoModulePolicy($module['id_agente_modulo']); if ($policyInfo === false) $data[1] = ''; else { $linked = isModuleLinked($module['id_agente_modulo']); $adopt = false; if (isModuleAdopt($module['id_agente_modulo'])) { $adopt = true; } if ($linked) { if ($adopt) { $img = 'images/policies_brick.png'; $title = __('(Adopt) ') . $policyInfo['name_policy']; } else { $img = 'images/policies.png'; $title = $policyInfo['name_policy']; } } else { if ($adopt) { $img = 'images/policies_not_brick.png'; $title = __('(Adopt) (Unlinked) ') . $policyInfo['name_policy']; } else { $img = 'images/unlinkpolicy.png'; $title = __('(Unlinked) ') . $policyInfo['name_policy']; } } $data[1] = '' . print_image($img,true, array('title' => $title)) . ''; } } // 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] = printTruncateText($module['descripcion'], 25, false); // 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] .= ' '; $data[7] .= ''; $data[7] .= print_image ('images/copy.png', true, array ('title' => __('Duplicate'))); $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 delete"'); echo '
'; echo '
' ?>