'.__('Massive modules edition').''; function process_manage_edit ($module_name) { if (is_int ($module_name) && $module_name <= 0) { echo '

'.__('No modules selected').'

'; return false; } $agents = array_keys (get_group_agents (array_keys (get_user_groups ()), false, "none")); /* List of fields which can be updated */ $fields = array ('min_warning', 'max_warning', 'min_critical', 'max_critical', 'min_ff_event'); $values = array (); foreach ($fields as $field) { $value = get_parameter ($field); if ($value != '') $values[$field] = $value; } $modules = get_db_all_rows_filter ('tagente_modulo', array ('id_agente' => $agents, 'nombre' => $module_name), array ('id_agente_modulo')); process_sql_begin (); if ($modules === false) return false; foreach ($modules as $module) { $result = update_agent_module ($module['id_agente_modulo'], $values); if ($result === false) { process_sql_rollback (); return false; } } process_sql_commit (); return true; } $module_type = (int) get_parameter ('module_type'); $module_name = (string) get_parameter ('module_name'); $update = (bool) get_parameter_post ('update'); if ($update) { $result = process_manage_edit ($module_name); print_result_message ($result, __('Successfully updated'), __('Could not be updated')); } $table->id = 'delete_table'; $table->width = '95%'; $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%'; /* Fixed using javascript */ $table->size[2] = '15%'; $table->size[3] = '35%'; if (! $module_type) { $table->rowstyle['edit1'] = 'display: none'; $table->rowstyle['edit2'] = 'display: none'; } $agents = get_group_agents (array_keys (get_user_groups ()), false, "none"); $module_types = get_db_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']; } $table->data = array (); $table->data[0][0] = __('Module type'); $table->data[0][0] .= ''; $table->data[0][1] = print_select ($types, 'module_type', $module_type, false, __('Select'), 0, true, false, false); $modules = array (); if ($module_type != '') { $names = get_agent_modules (array_keys ($agents), 'DISTINCT(nombre)', array ('id_tipo_modulo' => $module_type), false); foreach ($names as $name) { $modules[$name['nombre']] = $name['nombre']; } } $table->data[0][2] = __('Module name'); $table->data[0][3] = print_select ($modules, 'module_name', $module_name, false, __('Select'), 0, true, false, false); $table->data['edit1'][0] = __('Warning status'); $table->data['edit1'][1] = ''.__('Min.').''; $table->data['edit1'][1] .= print_input_text ('min_warning', '', '', 5, 15, true); $table->data['edit1'][1] .= '
'.__('Max.').''; $table->data['edit1'][1] .= print_input_text ('max_warning', '', '', 5, 15, true); $table->data['edit1'][2] = __('Critical status'); $table->data['edit1'][3] = ''.__('Min.').''; $table->data['edit1'][3] .= print_input_text ('min_critical', '', '', 5, 15, true); $table->data['edit1'][3] .= '
'.__('Max.').''; $table->data['edit1'][3] .= print_input_text ('max_critical', '', '', 5, 15, true); /* FF stands for Flip-flop */ $table->data['edit2'][0] = __('FF threshold').' '.print_help_icon ('ff_threshold', true); $table->data['edit2'][1] = print_input_text ('min_ff_event', '', '', 5, 15, true); $table->data['edit2'][2] = __('Historical data'); $table->data['edit2'][3] = print_checkbox ("history_data", 1, '', true); echo '
'; print_table ($table); echo '
'; print_input_hidden ('update', 1); print_submit_button (__('Update'), 'go', false, 'class="sub upd"'); echo '
'; echo '
'; echo ''; require_jquery_file ('pandora.controls'); ?>