'.__('No modules selected').''; return false; } /* List of fields which can be updated */ $fields = array ('min_warning', 'max_warning', 'str_warning', 'min_critical', 'max_critical', 'str_critical', 'min_ff_event', 'module_interval', 'disabled', 'post_process', 'snmp_community', 'tcp_send', 'min', 'max', 'id_module_group', 'plugin_user', 'plugin_pass', 'id_export', 'history_data'); $values = array (); foreach ($fields as $field) { $value = get_parameter ($field, ''); if ($value != '') $values[$field] = $value; } if (strlen(get_parameter('history_data')) > 0) { $values['history_data'] = get_parameter('history_data'); } // Whether to update module tag info $update_tags = get_parameter('id_tag', false); if (array_search(0, $agents_select) !== false) { $modules = db_get_all_rows_filter ('tagente_modulo', array ('nombre' => $module_name), array ('id_agente_modulo')); } else { $modules = db_get_all_rows_filter ('tagente_modulo', array ('id_agente' => $agents_select, 'nombre' => $module_name), array ('id_agente_modulo')); } db_process_sql_begin (); if ($modules === false) return false; foreach ($modules as $module) { $result = modules_update_agent_module ($module['id_agente_modulo'], $values, true, $update_tags); if ($result === false) { db_process_sql_rollback (); return false; } } db_process_sql_commit (); return true; } $module_type = (int) get_parameter ('module_type'); $idGroupMassive = (int) get_parameter('id_group_massive'); $idAgentMassive = (int) get_parameter('id_agent_massive'); $group_select = get_parameter('groups_select'); $module_name = get_parameter ('module_name'); $agents_select = get_parameter('agents'); $agents_id = get_parameter('id_agents'); $modules_select = get_parameter('module'); $selection_mode = get_parameter('selection_mode', 'modules'); $recursion = get_parameter('recursion'); $update = (bool) get_parameter_post ('update'); if ($update) { if($selection_mode == 'modules') { $force = get_parameter('force_type', false); if($agents_select == false) { $agents_select = array(); $agents_ = array(); } foreach($agents_select as $agent_name) { $agents_[] = agents_get_agent_id($agent_name); } $modules_ = $module_name; } else if($selection_mode == 'agents') { $force = get_parameter('force_group', false); $agents_ = $agents_id; $modules_ = $modules_select; } $success = 0; $count = 0; if($agents_ == false) { $agents_ = array(); } // If the option to select all of one group or module type is checked if($force) { if($force == 'type') { $condition = ''; if($module_type != 0) $condition = ' AND t2.id_tipo_modulo = '.$module_type; $agents_ = db_get_all_rows_sql('SELECT DISTINCT(t1.id_agente) FROM tagente t1, tagente_modulo t2 WHERE t1.id_agente = t2.id_agente'); foreach($agents_ as $id_agent) { $module_name = db_get_all_rows_filter('tagente_modulo', array('id_agente' => $id_agent, 'id_tipo_modulo' => $module_type),'nombre'); if($module_name == false) { $module_name = array(); } foreach($module_name as $mod_name) { $result = process_manage_edit ($mod_name['nombre'], $id_agent['id_agente']); $count ++; $success += (int)$result; } } } else if($force == 'group') { $agents_ = array_keys (agents_get_group_agents ($group_select, false, "none")); foreach($agents_ as $id_agent) { $module_name = db_get_all_rows_filter('tagente_modulo', array('id_agente' => $id_agent),'nombre'); if($module_name == false) { $module_name = array(); } foreach($module_name as $mod_name) { $result = process_manage_edit ($mod_name['nombre'], $id_agent); $count ++; $success += (int)$result; } } } // We empty the agents array to skip the standard procedure $agents_ = array(); } foreach($agents_ as $agent_) { if($modules_ == false) { $modules_ = array(); } foreach($modules_ as $module_) { $result = process_manage_edit ($module_, $agents_); $count ++; $success += (int)$result; } } ui_print_result_message ($success > 0, __('Successfully updated')."(".$success."/".$count.")", __('Could not be updated')); $info = 'Modules: ' . json_encode($modules_) . ' Agents: ' . json_encode($agents_); if ($success > 0) { db_pandora_audit("Masive management", "Edit module", false, false, $info); } else { db_pandora_audit("Masive management", "Fail try to edit module", false, false, $info); } } $table->id = 'delete_table'; $table->width = '98%'; $table->data = array (); $table->style = array (); $table->style[0] = 'font-weight: bold; vertical-align:top'; $table->style[2] = 'font-weight: bold'; $table->rowstyle = array (); $table->size = array (); $table->size[0] = '15%'; $table->size[1] = '35%'; $table->size[2] = '15%'; $table->size[3] = '35%'; if (! $module_type) { $table->rowstyle['edit1'] = 'display: none'; $table->rowstyle['edit2'] = 'display: none'; $table->rowstyle['edit3'] = 'display: none'; $table->rowstyle['edit35'] = 'display: none'; $table->rowstyle['edit4'] = 'display: none'; $table->rowstyle['edit5'] = 'display: none'; $table->rowstyle['edit6'] = 'display: none'; $table->rowstyle['edit7'] = 'display: none'; } $agents = agents_get_group_agents (array_keys (users_get_groups ()), false, "none"); $module_types = db_get_all_rows_filter ('tagente_modulo,ttipo_modulo', array ('tagente_modulo.id_tipo_modulo = ttipo_modulo.id_tipo', 'id_agente' => array_keys ($agents), 'disabled' => 0, 'order' => 'ttipo_modulo.nombre'), array ('DISTINCT(id_tipo)', 'CONCAT(ttipo_modulo.descripcion," (",ttipo_modulo.nombre,")") AS description')); if ($module_types === false) $module_types = array (); $types = ''; foreach ($module_types as $type) { $types[$type['id_tipo']] = $type['description']; } $snmp_versions['1'] = 'v. 1'; $snmp_versions['2'] = 'v. 2'; $snmp_versions['2c'] = 'v. 2c'; $snmp_versions['3'] = 'v. 3'; $table->data = array (); $table->data[0][0] = __('Selection mode'); $table->data[0][1] = __('Select modules first').' '.html_print_radio_button_extended ("selection_mode", 'modules', '', $selection_mode, false, '', 'style="margin-right: 40px;"', true); $table->data[0][2] = ''; $table->data[0][3] = __('Select agents first').' '.html_print_radio_button_extended ("selection_mode", 'agents', '', $selection_mode, false, '', 'style="margin-right: 40px;"', true); $table->rowclass[1] = 'select_modules_row'; $table->data[1][0] = __('Module type'); $table->data[1][0] .= ''; $types[0] = __('All'); $table->colspan[1][1] = 2; $table->data[1][1] = html_print_select ($types, 'module_type', '', false, __('Select'), -1, true, false, true); $table->data[1][3] = __('Select all modules of this type').' '.html_print_checkbox_extended ("force_type", 'type', '', '', false, '', 'style="margin-right: 40px;"', true); $modules = array (); if ($module_type != '') { $filter = array ('id_tipo_modulo' => $module_type); } else { $filter = false; } $names = agents_get_modules (array_keys ($agents), 'DISTINCT(nombre)', $filter, false); foreach ($names as $name) { $modules[$name['nombre']] = $name['nombre']; } $table->rowclass[2] = 'select_agents_row'; $table->data[2][0] = __('Agent group'); $groups = groups_get_all(true); $groups[0] = __('All'); $table->colspan[2][1] = 2; $table->data[2][1] = html_print_select ($groups, 'groups_select', '', true, __('Select'), -1, true, false, true). ' '.__('Group recursion').' '.html_print_checkbox ("recursion", 1, false, true, false); $table->data[2][3] = __('Select all modules of this group').' '.html_print_checkbox_extended ("force_group", 'group', '', '', false, '', 'style="margin-right: 40px;"', true); $table->rowstyle[3] = 'vertical-align: top;'; $table->rowclass[3] = 'select_modules_row select_modules_row_2'; $table->data[3][0] = __('Modules'); $table->data[3][1] = html_print_select ($modules, 'module_name[]', $module_name, false, __('Select'), -1, true, true, true); $table->data[3][2] = __('Agents'); $table->data[3][3] = html_print_select (array(), 'agents[]', $agents_select, false, __('None'), 0, true, true, false); $table->rowstyle[4] = 'vertical-align: top;'; $table->rowclass[4] = 'select_agents_row select_agents_row_2'; $table->data[4][0] = __('Agents'); $table->data[4][1] = html_print_select ($agents, 'id_agents[]', $agents_id, false, '', '', true, true, false); $table->data[4][2] = __('Modules'); $table->data[4][3] = html_print_select (array(), 'module[]', $modules_select, false, '', '', true, true, false); $table->data['edit1'][0] = __('Warning status'); $table->data['edit1'][1] = ''.__('Min.').''; $table->data['edit1'][1] .= html_print_input_text ('min_warning', '', '', 5, 15, true); $table->data['edit1'][1] .= '
'.__('Max.').''; $table->data['edit1'][1] .= html_print_input_text ('max_warning', '', '', 5, 15, true); $table->data['edit1'][1] .= '
'.__('Str.').''; $table->data['edit1'][1] .= html_print_input_text ('str_warning', '', '', 5, 15, true); $table->data['edit1'][2] = __('Critical status'); $table->data['edit1'][3] = ''.__('Min.').''; $table->data['edit1'][3] .= html_print_input_text ('min_critical', '', '', 5, 15, true); $table->data['edit1'][3] .= '
'.__('Max.').''; $table->data['edit1'][3] .= html_print_input_text ('max_critical', '', '', 5, 15, true); $table->data['edit1'][3] .= '
'.__('Str.').''; $table->data['edit1'][3] .= html_print_input_text ('str_critical', '', '', 5, 15, true); $table->data['edit2'][0] = __('Interval'); $table->data['edit2'][1] = html_print_input_text ('module_interval', '', '', 5, 15, true); $table->data['edit2'][2] = __('Disabled'); //$table->data['edit2'][3] = html_print_checkbox ("disabled", 1, '', true); $table->data['edit2'][3] = html_print_select(array('' => '', '1' => __('Yes'), '0' => __('No')),'disabled','','','', '', true); $table->data['edit3'][0] = __('Post process'); $table->data['edit3'][1] = html_print_input_text ('post_process', '', '', 10, 15, true); $table->data['edit3'][2] = __('SMNP community'); $table->data['edit3'][3] = html_print_input_text ('snmp_community', '', '', 10, 15, true); $table->data['edit35'][0] = ''; $table->data['edit35'][1] = ''; $table->data['edit35'][2] = __('SNMP version'); $table->data['edit35'][3] = html_print_select ($snmp_versions, 'tcp_send', '', '', __('Select'), '', true, false, false, ''); $table->data['edit4'][0] = __('Value'); $table->data['edit4'][1] = ''.__('Min.').''; $table->data['edit4'][1] .= html_print_input_text ('min', '', '', 5, 15, true); $table->data['edit4'][1] .= '
'.__('Max.').''; $table->data['edit4'][1] .= html_print_input_text ('max', '', '', 5, 15, true); $table->data['edit4'][2] = __('Module group'); $table->data['edit4'][3] = html_print_select (modules_get_modulegroups(), 'id_module_group', '', '', __('Select'), 0, true, false, false); $table->data['edit5'][0] = __('Username'); $table->data['edit5'][1] = html_print_input_text ('plugin_user', '', '', 15, 60, true); $table->data['edit5'][2] = __('Password'); $table->data['edit5'][3] = html_print_input_password ('plugin_pass', '', '', 15, 60, true); $table->data['edit6'][0] = __('Export target'); $table->data['edit6'][1] = html_print_select_from_sql ('SELECT id, name FROM tserver_export ORDER BY name', 'id_export', '', '',__('None'),'0', true, false, false); /* FF stands for Flip-flop */ $table->data['edit7'][0] = __('FF threshold') . ' ' . ui_print_help_icon ('ff_threshold', true); $table->data['edit7'][1] = html_print_input_text ('min_ff_event', '', '', 5, 15, true); $table->data['edit7'][2] = __('Historical data'); $table->data['edit7'][3] = html_print_select(array('' => '', '1' => __('Yes'), '0' => __('No')),'history_data','','','', '', true); /* Tags avalaible */ $id_tag = array(); $table->data['edit8'][2] = __('Tags'); $table->data['edit8'][3] = html_print_select_from_sql ('SELECT id_tag, name FROM ttag ORDER BY name', 'id_tag[]', $id_tag, '',__('None'),'0', true, true, false, false); echo '
'; html_print_table ($table); echo '
'; html_print_input_hidden ('update', 1); html_print_submit_button (__('Update'), 'go', false, 'class="sub upd"'); echo '
'; echo '
'; echo ''; //Hack to translate text "none" in PHP to javascript echo ''; ui_require_jquery_file ('pandora.controls'); if($selection_mode == 'modules'){ $modules_row = ''; $agents_row = 'none'; } else { $modules_row = 'none'; $agents_row = ''; } ?>