'.__('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][0] .= '';
$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 '';
echo '
';
require_jquery_file ('pandora.controls');
?>