tags. if (isset($command['description'])) { $command['description'] = str_replace( [ '<', '>', "\r\n", ], [ '', '', '
', ], io_safe_output($command['description']) ); } // Descriptions are stored in json. $fields_descriptions = empty($command['fields_descriptions']) ? '' : json_decode(io_safe_output($command['fields_descriptions']), true); // Fields values are stored in json. $fields_values = empty($command['fields_values']) ? '' : io_safe_output(json_decode($command['fields_values'], true)); // Fields hidden conditions are stored in json. $fields_hidden_checked = empty($command['fields_hidden']) ? '' : io_safe_output(json_decode($command['fields_hidden'], true)); $fields_rows = []; for ($i = 1; $i <= $config['max_macro_fields']; $i++) { $field_description = $fields_descriptions[($i - 1)]; $field_value = $fields_values[($i - 1)]; $field_hidden = $fields_hidden_checked[($i - 1)]; if (!empty($field_description)) { // If the value is 5, this because severity in snmp alerts is not permit to show. if (($i > 5) && ($command['id'] === 3)) { $fdesc = $field_description.'
'.sprintf( __('Field %s'), ($i - 1) ).''; } else { $fdesc = $field_description.'
'.sprintf( __('Field %s'), $i ).''; } // If the field is the number one, print the help message. if ($i == 1) { // If our context is snmpconsole, show snmp_alert helps. if ((!isset($_SERVER['HTTP_REFERER'])) && ( preg_match('/snmp_alert/', $_SERVER['HTTP_REFERER']) > 0 )) { $fdesc .= ui_print_help_icon('alert_config', true); } } } else { // If the macro hasn't description and doesnt appear in command, set with empty description to dont show it. if (($i > 5) && ($command['id'] === 3)) { if (substr_count($command['command'], '_field'.($i - 1).'_') > 0) { $fdesc = sprintf(__('Field %s'), ($i - 1)); } else { $fdesc = ''; } } else { if (substr_count($command['command'], '_field'.$i.'_') > 0) { $fdesc = sprintf(__('Field %s'), $i); } else { $fdesc = ''; } } } $style = ((int) $field_hidden === 1) ? '-webkit-text-security: disc; font-family: text-security-disc;' : ''; $recovery_disabled = 0; if (empty($command) === false && $command['name'] === io_safe_input('Pandora ITSM Ticket')) { if ($management_is_not_allowed == 0) { if (preg_match('/^_html_editor_$/i', $field_value) || $field_description === 'Ticket status') { $recovery_disabled = 0; } else { $recovery_disabled = 1; } } } if (!empty($field_value)) { $field_value = io_safe_output($field_value); // HTML type. if (preg_match('/^_html_editor_$/i', $field_value)) { $editor_type_chkbx = '
'; $editor_type_chkbx .= __('Basic'); $editor_type_chkbx .= ui_print_help_tip( __('For sending emails, text must be HTML format, if you want to use plain text, type it between the following labels:
'),
                        true
                    );
                    $editor_type_chkbx .= html_print_radio_button_extended(
                        'editor_type_value_'.$i,
                        0,
                        '',
                        false,
                        $management_is_not_allowed,
                        "UndefineTinyMCE('#textarea_field".$i."_value')",
                        '',
                        true
                    );
                    $editor_type_chkbx .= '    ';
                    $editor_type_chkbx .= __('Advanced').'  ';
                    $editor_type_chkbx .= html_print_radio_button_extended(
                        'editor_type_value_'.$i,
                        0,
                        '',
                        true,
                        $management_is_not_allowed,
                        "defineTinyMCE('#textarea_field".$i."_value')",
                        '',
                        true
                    );
                    $editor_type_chkbx .= '
'; $ffield = $editor_type_chkbx; $ffield .= html_print_textarea( 'field'.$i.'_value', 5, 1, '', 'class="fields w100p"', true, '', $management_is_not_allowed ); $editor_type_chkbx = '
'; $editor_type_chkbx .= __('Basic').'  '; $editor_type_chkbx .= html_print_radio_button_extended( 'editor_type_recovery_value_'.$i, 0, '', false, $management_is_not_allowed, "UndefineTinyMCE('#textarea_field".$i."_recovery_value')", '', true ); $editor_type_chkbx .= '    '; $editor_type_chkbx .= __('Advanced').'  '; $editor_type_chkbx .= html_print_radio_button_extended( 'editor_type_recovery_value_'.$i, 0, '', true, $management_is_not_allowed, "defineTinyMCE('#textarea_field".$i."_recovery_value')", '', true ); $editor_type_chkbx .= '
'; $rfield = $editor_type_chkbx; $rfield .= html_print_textarea( 'field'.$i.'_recovery_value', 5, 1, '', 'class="fields_recovery"', true, '', $management_is_not_allowed || $recovery_disabled ); } else if (preg_match('/^_content_type_$/i', $field_value)) { $editor_type_chkbx = '
'; $editor_type_chkbx .= __('Text/plain'); $editor_type_chkbx .= ui_print_help_tip( __('For sending emails only text plain'), true ); $editor_type_chkbx .= html_print_radio_button_extended( 'field'.$i.'_value', 'text/plain', '', '', $management_is_not_allowed, '', '', true ); $editor_type_chkbx .= '    '; $editor_type_chkbx .= __('Text/html').'  '; $editor_type_chkbx .= html_print_radio_button_extended( 'field'.$i.'_value', 'text/html', '', 'text/html', $management_is_not_allowed, '', '', true ); $editor_type_chkbx .= '
'; $ffield = $editor_type_chkbx; $editor_type_chkbx = '
'; $editor_type_chkbx .= __('Text/plain'); $editor_type_chkbx .= ui_print_help_tip( __('For sending emails only text plain'), true ); $editor_type_chkbx .= html_print_radio_button_extended( 'field'.$i.'_recovery_value', 'text/plain', '', '', $management_is_not_allowed, '', '', true ); $editor_type_chkbx .= '    '; $editor_type_chkbx .= __('Text/html').'  '; $editor_type_chkbx .= html_print_radio_button_extended( 'field'.$i.'_recovery_value', 'text/html', '', 'text/html', $management_is_not_allowed, '', '', true ); $editor_type_chkbx .= '
'; $rfield = $editor_type_chkbx; // Select type. } else if (preg_match('/^_custom_field_ITSM_$/i', $field_value)) { $ffield = ''; $rfield = ''; $ffield .= '
'.html_print_switch( [ 'name' => 'field'.$i.'_value[]', 'value' => '', ] ).'
'; $rfield .= '
'.html_print_switch( [ 'name' => 'field'.$i.'_recovery_value[]', 'value' => '', 'disabled' => $management_is_not_allowed || $recovery_disabled, ] ).'
'; $ffield .= html_print_select( '', 'field'.$i.'_value[]', '', '', __('None'), '', true, false, false, 'fields', $management_is_not_allowed, 'width: 100%;', false, false, false, '', false, false, false, false, false ); $rfield .= html_print_select( '', 'field'.$i.'_recovery_value[]', '', '', __('None'), '', true, false, false, 'fields', $management_is_not_allowed || $recovery_disabled, 'width: 100%;', false, false, false, '', false, false, false, false, false ); $ffield .= html_print_input_text( 'field'.$i.'_value[]', '', '', 50, 50, true, false, false, '', 'datepicker', '', 'off', false, '', '', '', $management_is_not_allowed ); $rfield .= html_print_input_text( 'field'.$i.'_recovery_value[]', '', '', 50, 50, true, false, false, '', 'datepicker', '', 'off', false, '', '', '', $management_is_not_allowed || $recovery_disabled ); $ffield .= html_print_textarea( 'field'.$i.'_value[]', 5, 1, '', 'style="min-height:40px; '.$style.'" class="fields"', true, '', $management_is_not_allowed ); $rfield .= html_print_textarea( 'field'.$i.'_recovery_value[]', 5, 1, '', 'style="min-height:40px; '.$style.'" class="fields_recovery', true, '', $management_is_not_allowed || $recovery_disabled ); $values_input_number = [ 'name' => 'field'.$i.'_value[]', 'value' => 0, 'id' => 'field'.$i.'_value', 'return' => true, ]; if ($management_is_not_allowed === true) { $values_input_number['disabled'] = true; } $ffield .= html_print_input_number($values_input_number); $values_input_number_recovery = [ 'name' => 'field'.$i.'_recovery_value[]', 'value' => 0, 'id' => 'field'.$i.'_recovery_value', 'return' => true, ]; if ($management_is_not_allowed || $recovery_disabled) { $values_input_number_recovery['disabled'] = true; } $rfield .= html_print_input_number($values_input_number_recovery); $ffield .= html_print_input_text( 'field'.$i.'_value[]', '', '', 50, 255, true, false, false, '', 'normal w98p', '', 'off', false, false, '', '', $management_is_not_allowed ); $rfield .= html_print_input_text( 'field'.$i.'_recovery_value[]', '', '', 50, 255, true, false, false, '', 'normal w98p', '', 'off', false, false, '', '', $management_is_not_allowed || $recovery_disabled ); } else if (str_starts_with($field_value, '_ITSM_')) { $nothing = ''; $nothing_value = 0; $mode = 'select'; switch ($field_value) { case '_ITSM_groups_': $fields_array = []; try { $ITSM = new ITSM(); $fields_array = $ITSM->getGroups(); } catch (\Throwable $th) { $error = $th->getMessage(); $fields_array = []; } break; case '_ITSM_priorities_': $fields_array = []; try { $ITSM = new ITSM(); $fields_array = $ITSM->getPriorities(); } catch (\Throwable $th) { $error = $th->getMessage(); $fields_array = []; } break; case '_ITSM_types_': $fields_array = []; try { $ITSM = new ITSM(); $fields_array = $ITSM->getObjectypes(); } catch (\Throwable $th) { $error = $th->getMessage(); $fields_array = []; } $nothing = __('None'); $nothing_value = 0; break; case '_ITSM_status_': $fields_array = []; try { $ITSM = new ITSM(); $fields_array = $ITSM->getStatus(); } catch (\Throwable $th) { $error = $th->getMessage(); $fields_array = []; } break; default: // Nothing. $mode = ''; break; } if ($mode === 'select') { $ffield = html_print_select( $fields_array, 'field'.$i.'_value', '', '', $nothing, $nothing_value, true, false, false, 'fields', $management_is_not_allowed ); $rfield = html_print_select( $fields_array, 'field'.$i.'_recovery_value', '', '', $nothing, $nothing_value, true, false, false, 'fields_recovery', $management_is_not_allowed || $recovery_disabled ); } else { $ffield = html_print_autocomplete_users_from_pandora_itsm( 'field'.$i.'_value', '', true, 0, $management_is_not_allowed, false, 'ITSM_users' ); $rfield = html_print_autocomplete_users_from_pandora_itsm( 'field'.$i.'_recovery_value', '', true, 0, $management_is_not_allowed || $recovery_disabled, false, 'ITSM_users' ); } } else { $fields_value_select = []; $force_print_select = false; // Exception for dynamically filled select boxes. if (preg_match('/^_reports_$/i', $field_value)) { // Filter normal and metaconsole reports. if (is_metaconsole() === true) { $filter['metaconsole'] = 1; } else { $filter['metaconsole'] = 0; } $own_info = get_user_info($config['id_user']); if ($own_info['is_admin'] || check_acl($config['id_user'], 0, 'RM') || check_acl($config['id_user'], 0, 'RR')) { $return_all_group = true; } else { $return_all_group = false; } if (is_user_admin($config['id_user']) === false) { $filter[] = sprintf( 'private = 0 OR (private = 1 AND id_user = "%s")', $config['id_user'] ); } $reports = reports_get_reports( $filter, [ 'name', 'id_report', ], $return_all_group, 'RR' ); $fv = array_map( function ($report) { return $report['id_report'].','.$report['name']; }, $reports ); $force_print_select = true; } else if (preg_match('/^_report_templates_$/i', $field_value)) { // Filter normal and metaconsole reports. if (is_metaconsole() === true) { $filter['metaconsole'] = 1; } else { $filter['metaconsole'] = 0; } $own_info = get_user_info($config['id_user']); if ($own_info['is_admin'] || check_acl($config['id_user'], 0, 'RM') || check_acl($config['id_user'], 0, 'RR')) { $return_all_group = true; } else { $return_all_group = false; } if (is_user_admin($config['id_user']) === false) { $filter[] = sprintf( 'private = 0 OR (private = 1 AND id_user = "%s")', $config['id_user'] ); } $templates = reports_get_report_templates( $filter, [ 'name', 'id_report', ], $return_all_group, 'RR' ); $fv = array_map( function ($template) { return $template['id_report'].','.$template['name']; }, $templates ); $force_print_select = true; } else { $fv = explode(';', $field_value); } if (count($fv) > 1 || $force_print_select === true) { if (!empty($fv)) { foreach ($fv as $fv_option) { $fv_option = explode(',', $fv_option); if (empty($fv_option)) { continue; } if (!isset($fv_option[1])) { $fv_option[1] = $fv_option[0]; } $fields_value_select[$fv_option[0]] = $fv_option[1]; } } $ffield = html_print_select( $fields_value_select, 'field'.$i.'_value', '', '', __('None'), '', true, false, false, 'fields', $management_is_not_allowed ); $rfield = html_print_select( $fields_value_select, 'field'.$i.'_recovery_value', '', '', __('None'), 0, true, false, false, 'fields_recovery', $management_is_not_allowed || $recovery_disabled ); } else { $ffield = html_print_textarea( 'field'.$i.'_value', 5, 1, $fv[0], 'style="'.$style.'" class="fields min-height-40px w100p"', true, '', $management_is_not_allowed ); $rfield = html_print_textarea( 'field'.$i.'_recovery_value', 5, 1, $fv[0], 'style="'.$style.'" class="fields_recovery min-height-40px w100p', true, '', $management_is_not_allowed || $recovery_disabled ); } } } else { $ffield = html_print_textarea( 'field'.$i.'_value', 5, 1, '', 'style="'.$style.'" class="fields min-height-40px w100p"', true, '', $management_is_not_allowed ); $rfield = html_print_textarea( 'field'.$i.'_recovery_value', 5, 1, '', 'style="'.$style.'" class="fields_recovery min-height-40px w100p"', true, '', $management_is_not_allowed || $recovery_disabled ); } // The empty descriptions will be ignored. if ($fdesc == '') { $fields_rows[$i] = ''; } else { $fields_rows[$i] = ''; $fields_rows[$i] .= ''.$fdesc.''; $fields_rows[$i] .= ''.$ffield.''; if ($get_recovery_fields) { $fields_rows[$i] .= ''.$rfield.''; } $fields_rows[$i] .= ''; } } // If command is PandoraFMS event, field 5 must be empty because "severity" must be set by the alert. $command['fields_rows'] = $fields_rows; echo json_encode($command); } return; } // This check should be after ajax. Because, ajax will be called from configure_alert_action. if (!check_acl($config['id_user'], 0, 'PM') && !is_user_admin( $config['id_user '] ) ) { echo "
"; echo "

".__( 'Command management is limited to administrator users or user profiles with permissions PM' ).'

'; echo '
'; } if ($update_command) { include_once 'configure_alert_command.php'; return; } // Header. if (defined('METACONSOLE')) { alerts_meta_print_header(); } else { ui_print_standard_header( __('Alerts'), 'images/gm_alerts.png', false, '', true, [], [ [ 'link' => '', 'label' => __('Alert commands'), ], ] ); } if ($create_command) { $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['description'] = $description; $values['id_group'] = $id_group; $name_check = db_get_value('name', 'talert_commands', 'name', $name); if (!$name_check) { $result = alerts_create_alert_command( $name, $command, $values ); $info = '{"Name":"'.$name.'","Command":"'.$command.'","Description":"'.$description.' '.$info_fields.'"}'; } else { $result = ''; } if ($result) { db_pandora_audit( AUDIT_LOG_ALERT_MANAGEMENT, 'Create alert command #'.$result, false, false, $info ); } else { db_pandora_audit( AUDIT_LOG_ALERT_MANAGEMENT, 'Fail try to create alert command', false, false ); } // Show errors. if (!isset($messageAction)) { $messageAction = __('Could not be created'); } if ($name == '') { $messageAction = __('No name specified'); } if ($command == '') { $messageAction = __('No command specified'); } $messageAction = ui_print_result_message( $result, __('Successfully created'), $messageAction ); } if ($delete_command) { $id = (int) get_parameter('id'); // Internal commands cannot be deleted. if (alerts_get_alert_command_internal($id)) { db_pandora_audit( AUDIT_LOG_ACL_VIOLATION, 'Trying to access Alert Management' ); include 'general/noaccess.php'; return; } $result = alerts_delete_alert_command($id); $auditMessage = ((bool) $result === true) ? sprintf('Delete alert command #%s', $id) : sprintf('Fail try to delete alert command #%s', $id); db_pandora_audit( AUDIT_LOG_ALERT_MANAGEMENT, $auditMessage ); ui_print_result_message( $result, __('Successfully deleted'), __('Could not be deleted') ); } if ($copy_command) { $id = (int) get_parameter('id'); // Get the info from the source command. $command_to_copy = db_get_row('talert_commands', 'id', $id); if ($command_to_copy === false) { ui_print_error_message(__("Command with id $id does not found.")); } else { // Prepare to insert the copy with same values. unset($command_to_copy['id']); $command_to_copy['name'] .= __(' (copy)'); $result = db_process_sql_insert('talert_commands', $command_to_copy); // Print the result. ui_print_result_message( $result, __('Successfully copied'), __('Could not be copied') ); } } $is_management_allowed = is_management_allowed(); if ($is_management_allowed === false) { if (is_metaconsole() === false) { $url_redirect = ''.__('metaconsole').''; } else { $url_redirect = __('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_redirect ) ); } $table = new stdClass; $table->width = '100%'; $table->class = 'info_table'; $table->data = []; $table->head = []; $table->head['name'] = __('Name'); $table->head['id'] = __('ID'); $table->head['group'] = __('Group'); $table->head['description'] = __('Description'); $table->head['action'] = __('Actions'); $table->style = []; $table->style['name'] = 'font-weight: bold'; $table->size = []; $table->size['action'] = '40px'; $table->align = []; $table->align['action'] = 'left'; $commands = db_get_all_rows_filter( 'talert_commands', ['id_group' => array_keys(users_get_groups(false, 'LM'))] ); if ($commands === false) { $commands = []; } // Pagination. $total_commands = count($commands); $offset = (int) get_parameter('offset'); $limit = (int) $config['block_size']; $commands = array_slice($commands, $offset, $limit); foreach ($commands as $command) { $data = []; if ((isset($config['ITSM_enabled']) === false || (bool) $config['ITSM_enabled'] === false) && $command['name'] === 'Pandora ITSM Ticket' ) { continue; } $data['name'] = ''; // (IMPORTANT, DO NOT CHANGE!) only users with permissions over "All" group have access to edition of commands belonging to "All" group. if (!$command['internal'] && check_acl_restricted_all($config['id_user'], $command['id_group'], 'PM')) { $data['name'] .= ''.$command['name'].''; } else { $data['name'] .= $command['name']; } $data['name'] .= ''; $data['id'] = $command['id']; $data['group'] = ui_print_group_icon($command['id_group'], true); $data['description'] = str_replace( [ '<', '>', "\r\n", ], [ '', '', '
', ], io_safe_output($command['description']) ); $data['action'] = ''; $table->cellclass[]['action'] = 'table_action_buttons'; $offset_delete = ($offset >= ($total_commands - 1)) ? ($offset - $limit) : $offset; // (IMPORTANT, DO NOT CHANGE!) only users with permissions over "All" group have access to edition of commands belonging to "All" group. if ($is_management_allowed === true && !$command['internal'] && check_acl_restricted_all($config['id_user'], $command['id_group'], 'LM')) { if (is_user_admin($config['id_user']) === true) { $data['action'] = ''; $data['action'] .= ''.html_print_image('images/copy.svg', true, ['class' => 'main_menu_icon invert_filter ', 'title' => 'Duplicate']).''; $data['action'] .= ''.html_print_image('images/delete.svg', true, ['class' => 'main_menu_icon invert_filter', 'title' => 'Delete']).''; $data['action'] .= ''; } } array_push($table->data, $data); } if (isset($data) === true && count($table->data) > 0) { html_print_table($table); $pagination = ui_pagination($total_commands, $url, 0, 0, true, 'offset', false, ''); } else { ui_print_info_message( [ 'no_close' => true, 'message' => __('No alert commands configured'), ] ); } // Commands can only be created by the super administrator. if (users_is_admin() === true) { echo '
'; $buttonSubmit = html_print_submit_button( __('Create'), 'create', false, ['icon' => 'wand'], true ); html_print_input_hidden('create_alert', 1); html_print_action_buttons($buttonSubmit, ['right_content' => $pagination]); echo '
'; } ?>