0) { $alert = alerts_get_alert_command($id); if ($alert['internal'] || !check_acl_restricted_all($config['id_user'], $alert['id_group'], 'PM')) { db_pandora_audit( AUDIT_LOG_ACL_VIOLATION, 'Trying to access Alert Management' ); include 'general/noaccess.php'; exit; } } if ($update_command) { $alert = alerts_get_alert_command($id); $name = (string) get_parameter('name'); $command = (string) get_parameter('command'); $description = (string) get_parameter('description'); $id_group = (string) get_parameter('id_group', 0); $fields_descriptions = []; $fields_values = []; $fields_hidden = []; $info_fields = ''; $values = []; for ($i = 1; $i <= $config['max_macro_fields']; $i++) { $fields_descriptions[] = (string) get_parameter('field'.$i.'_description'); $fields_values[] = (string) get_parameter('field'.$i.'_values'); $fields_hidden[] = get_parameter('field'.$i.'_hide'); $info_fields .= ' Field'.$i.': '.$fields_values[($i - 1)]; } $values['fields_values'] = io_json_mb_encode($fields_values); $values['fields_descriptions'] = io_json_mb_encode($fields_descriptions); $values['fields_hidden'] = io_json_mb_encode($fields_hidden); $values['name'] = $name; $values['command'] = $command; $values['description'] = $description; $values['id_group'] = $id_group; // Only for Metaconsole. Save the previous name for synchronizing. if (is_metaconsole() === true) { $values['previous_name'] = db_get_value('name', 'talert_commands', 'id', $id); } // Check it the new name is used in the other command. $id_check = db_get_value('id', 'talert_commands', 'name', $name); if (($id_check != $id) && (!empty($id_check))) { $result = false; } else { $result = (bool) alerts_update_alert_command($id, $values); if ($result === true) { $info = '{"Name":"'.$name.'","Command":"'.$command.'","Description":"'.$description.' '.$info_fields.'"}'; $alert['fields_values'] = io_json_mb_encode($fields_values); $alert['fields_descriptions'] = io_json_mb_encode($fields_descriptions); $alert['name'] = $name; $alert['command'] = $command; $alert['description'] = $description; $alert['id_group'] = $id_group; $alert['fields_hidden'] = io_json_mb_encode($fields_hidden); } } $auditMessage = ((bool) $result === true) ? 'Update alert command' : 'Fail to update alert command'; db_pandora_audit( AUDIT_LOG_ALERT_MANAGEMENT, sprintf('%s #%s', $auditMessage, $id), false, false, $info ); ui_print_result_message( $result, __('Successfully updated'), __('Could not be updated') ); } $name = ''; $command = ''; $description = ''; $fields_descriptions = ''; $fields_values = ''; $id_group = 0; if ($id) { if ($result === false) { $alert = alerts_get_alert_command($id); } $name = $alert['name']; $command = $alert['command']; $description = $alert['description']; $id_group = $alert['id_group']; $fields_descriptions = $alert['fields_descriptions']; $fields_values = $alert['fields_values']; $fields_hidden = $alert['fields_hidden']; } if (empty($fields_descriptions) === false) { $fields_descriptions = json_decode($fields_descriptions, true); } if (empty($fields_values) === false) { $fields_values = json_decode($fields_values, true); } if (empty($fields_hidden) === false) { $fields_hidden = json_decode($fields_hidden, true); } $is_management_allowed = is_management_allowed(); if ($is_management_allowed === false) { if (is_metaconsole() === false) { $url = ''.__('metaconsole').''; } else { $url = __('any node'); } ui_print_warning_message( __( 'This node is configured with centralized mode. All alert commands information is read only. Go to %s to manage it.', $url ) ); } $table = new stdClass(); $table->width = '100%'; $table->class = 'databox filters'; if (is_metaconsole() === true) { $table->head[0] = ($id) ? __('Update Command') : __('Create Command'); $table->head_colspan[0] = 4; $table->headstyle[0] = 'text-align: center'; } $table->style = []; if (is_metaconsole() === false) { $table->style[0] = 'font-weight: bold'; $table->style[2] = 'font-weight: bold'; $table->style[4] = 'font-weight: bold'; } $table->size = []; $table->size[0] = '20%'; $table->data = []; $table->colspan['name'][1] = 3; $table->data['name'][0] = __('Name'); $table->data['name'][2] = html_print_input_text( 'name', $name, '', 35, 255, true, false, false, '', '', '', '', false, '', '', '', !$is_management_allowed ); $table->colspan['command'][1] = 3; $table->data['command'][0] = __('Command'); $table->data['command'][1] = html_print_textarea( 'command', 8, 30, $command, '', true, '', !$is_management_allowed ); $return_all_group = false; if (users_can_manage_group_all('LM') === true) { $return_all_group = true; } $table->colspan['group'][1] = 3; $table->data['group'][0] = __('Group'); $table->data['group'][1] = '
'.html_print_select_groups( false, 'LM', $return_all_group, 'id_group', $id_group, false, '', 0, true, false, true, '', !$is_management_allowed ).'
'; $table->colspan['description'][1] = 3; $table->data['description'][0] = __('Description'); $table->data['description'][1] = html_print_textarea( 'description', 10, 30, $description, '', true, '', !$is_management_allowed ); for ($i = 1; $i <= $config['max_macro_fields']; $i++) { $table->data['field'.$i][0] = sprintf(__('Field %s description'), $i); if (empty($fields_descriptions) === false) { $field_description = $fields_descriptions[($i - 1)]; } else { $field_description = ''; } $table->data['field'.$i][1] = html_print_input_text( 'field'.$i.'_description', $field_description, '', 30, 255, true, false, false, '', '', '', '', false, '', '', '', !$is_management_allowed ); $table->data['field'.$i][2] = sprintf(__('Field %s values'), $i); $table->data['field'.$i][2] .= ui_print_help_tip( __('value1,tag1;value2,tag2;value3,tag3'), true ); if (empty($fields_values) === false) { $field_values = $fields_values[($i - 1)]; } else { $field_values = ''; } if (empty($fields_hidden) === false) { $selected = (bool) $fields_hidden[($i - 1)]; } else { $selected = false; } $table->data['field'.$i][3] = html_print_input_text( 'field'.$i.'_values', $field_values, '', 55, 1000, true, false, false, '', 'field_value', '', '', false, '', '', '', !$is_management_allowed ); $table->data['field'.$i][4] = __('Hide'); $table->data['field'.$i][5] = html_print_checkbox_extended( 'field'.$i.'_hide', 1, $selected, !$is_management_allowed, 'cursor: \'pointer\'', 'class="hide_inputs"', true ); } echo '
'; html_print_table($table); if ($is_management_allowed === true) { echo '
'; if ($id) { html_print_input_hidden('id', $id); html_print_input_hidden('update_command', 1); html_print_submit_button(__('Update'), 'create', false, 'class="sub upd"'); } else { html_print_input_hidden('create_command', 1); html_print_submit_button(__('Create'), 'create', false, 'class="sub wand"'); } echo '
'; } echo '
'; enterprise_hook('close_meta_frame'); ?>