($login_result !== false) ? 1 : 0]); return; } $has_connection = integria_api_call(null, null, null, null, 'get_login', []); if ($has_connection === false && $config['integria_enabled']) { ui_print_error_message(__('Integria IMS API is not reachable')); } if (get_parameter('update_config', 0) == 1) { // Try to retrieve event response 'Create incident in IntegriaIMS from event' to check if it exists. $event_response_exists = db_get_row_filter('tevent_response', ['name' => io_safe_input('Create ticket in IntegriaIMS from event')]); // Try to retrieve command 'Integia IMS Ticket' to check if it exists. $command_exists = db_get_row_filter('talert_commands', ['name' => io_safe_input('Integria IMS Ticket')]); if ($config['integria_enabled'] == 1) { if ($event_response_exists === false) { // Create 'Create incident in IntegriaIMS from event' event response only when user enables IntegriaIMS integration and it does not exist in database. db_process_sql_insert( 'tevent_response', [ 'name' => io_safe_input('Create ticket in IntegriaIMS from event'), 'description' => io_safe_input('Create a ticket in Integria IMS from an event'), 'target' => io_safe_input('index.php?sec=incident&sec2=operation/incidents/configure_integriaims_incident&from_event=_event_id_'), 'type' => 'url', 'id_group' => '0', 'modal_width' => '0', 'modal_height' => '0', 'new_window' => '1', 'params' => '', 'server_to_exec' => '0', ] ); } $ticket_types = integria_api_call(null, null, null, null, 'get_types', '', false, 'json'); $types_string = ''; if ($ticket_types !== '') { foreach (json_decode($ticket_types, true) as $key => $value) { $types_string .= $value['id'].','.$value['name'].';'; } } if ($command_exists === false) { // Create 'Integria IMS Ticket' command only when user enables IntegriaIMS integration and it does not exist in database. $id_command_inserted = db_process_sql_insert( 'talert_commands', [ 'name' => io_safe_input('Integria IMS Ticket'), 'command' => io_safe_input('Internal type'), 'internal' => 1, 'description' => io_safe_input('Create a ticket in Integria IMS'), 'fields_descriptions' => '["'.io_safe_input('Ticket title').'","'.io_safe_input('Ticket group ID').'","'.io_safe_input('Ticket priority').'","'.io_safe_input('Ticket owner').'","'.io_safe_input('Ticket type').'","'.io_safe_input('Ticket status').'","'.io_safe_input('Ticket description').'","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_"]', 'fields_values' => '["", "", "","","'.$types_string.'","","","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_"]', ] ); // Create 'Create Integria IMS Ticket' action only when user enables IntegriaIMS integration and command exists in database. $action_values = [ 'field1' => io_safe_input($config['incident_title']), 'field1_recovery' => io_safe_input($config['incident_title']), 'field2' => io_safe_input($config['default_group']), 'field2_recovery' => io_safe_input($config['default_group']), 'field3' => io_safe_input($config['default_criticity']), 'field3_recovery' => io_safe_input($config['default_criticity']), 'field4' => io_safe_input($config['default_owner']), 'field4_recovery' => io_safe_input($config['default_owner']), 'field5' => io_safe_input($config['incident_type']), 'field5_recovery' => io_safe_input($config['incident_type']), 'field6' => io_safe_input($config['incident_status']), 'field6_recovery' => io_safe_input($config['incident_status']), 'field7' => io_safe_input($config['incident_content']), 'field7_recovery' => io_safe_input($config['incident_content']), 'id_group' => 0, 'action_threshold' => 0, ]; alerts_create_alert_action(io_safe_input('Create Integria IMS ticket'), $id_command_inserted, $action_values); } else { // Update 'Integria IMS Ticket' command with ticket types retrieved from Integria IMS. $sql_update_command_values = sprintf( ' UPDATE talert_commands SET fields_values = \'["","","","","%s","","","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_","_integria_type_custom_field_"]\' WHERE name="%s"', $types_string, io_safe_input('Integria IMS Ticket') ); db_process_sql($sql_update_command_values); // Update those actions that make use of 'Integria IMS Ticket' command when setup default fields are updated. Empty fields in actions will be filled in with default values. $update_action_values = [ $config['incident_title'], $config['default_group'], $config['default_criticity'], $config['default_owner'], $config['incident_type'], $config['incident_status'], $config['incident_content'], ]; foreach ($update_action_values as $key => $value) { $field_key = ($key + 1); $sql_update_action_field = sprintf( ' UPDATE talert_actions taa INNER JOIN talert_commands tac ON taa.id_alert_command=tac.id SET field%s= "%s" WHERE tac.name="Integria IMS Ticket" AND ( taa.field%s IS NULL OR taa.field%s="" )', $field_key, $value, $field_key, $field_key, $field_key ); db_process_sql($sql_update_action_field); } foreach ($update_action_values as $key => $value) { $field_key = ($key + 1); $sql_update_action_recovery_field = sprintf( ' UPDATE talert_actions taa INNER JOIN talert_commands tac ON taa.id_alert_command=tac.id SET field%s_recovery = "%s" WHERE tac.name="Integria IMS Ticket" AND ( taa.field%s_recovery IS NULL OR taa.field%s_recovery="" )', $field_key, $value, $field_key, $field_key, $field_key ); db_process_sql($sql_update_action_recovery_field); } } } else { if ($event_response_exists !== false) { // Delete 'Create incident in IntegriaIMS from event' event response if it does exist and IntegriaIMS integration is disabled. db_process_sql_delete('tevent_response', ['name' => io_safe_input('Create ticket in IntegriaIMS from event')]); } } } // Get parameters from Integria IMS API. $integria_group_values = []; $integria_criticity_values = []; $integria_users_values = []; $integria_types_values = []; $integria_status_values = []; $integria_groups_csv = integria_api_call(null, null, null, null, 'get_groups', []); get_array_from_csv_data_pair($integria_groups_csv, $integria_group_values); $integria_status_csv = integria_api_call(null, null, null, null, 'get_incidents_status', []); get_array_from_csv_data_pair($integria_status_csv, $integria_status_values); $integria_criticity_levels_csv = integria_api_call(null, null, null, null, 'get_incident_priorities', []); get_array_from_csv_data_pair($integria_criticity_levels_csv, $integria_criticity_values); $integria_users_csv = integria_api_call(null, null, null, null, 'get_users', []); $csv_array = explode("\n", $integria_users_csv); foreach ($csv_array as $csv_line) { if (empty($csv_line) === false) { $integria_users_values[$csv_line] = $csv_line; } } $integria_types_csv = integria_api_call(null, null, null, null, 'get_types', []); get_array_from_csv_data_pair($integria_types_csv, $integria_types_values); // Enable table. $table_enable = new StdClass(); $table_enable->data = []; $table_enable->width = '100%'; $table_enable->id = 'integria-enable-setup'; $table_enable->class = 'databox filters'; $table_enable->size['name'] = '30%'; $table_enable->style['name'] = 'font-weight: bold'; // Enable Integria. $row = []; $row['name'] = __('Enable Integria IMS'); $row['control'] = html_print_checkbox_switch('integria_enabled', 1, $config['integria_enabled'], true); $table_enable->data['integria_enabled'] = $row; // Remote config table. $table_remote = new StdClass(); $table_remote->data = []; $table_remote->width = '100%'; $table_remote->styleTable = 'margin-bottom: 10px;'; $table_remote->id = 'integria-remote-setup'; $table_remote->class = 'databox filters filter-table-adv'; $table_remote->size['hostname'] = '50%'; $table_remote->size['api_pass'] = '50%'; // Enable Integria user configuration. $row = []; $row['user_level'] = html_print_label_input_block( __('Integria configuration at user level'), html_print_checkbox_switch( 'integria_user_level_conf', 1, $config['integria_user_level_conf'], true ) ); $table_remote->data['integria_user_level_conf'] = $row; // Integria user. $row = []; $row['user'] = html_print_label_input_block( __('User'), html_print_input_text( 'integria_user', $config['integria_user'], '', 30, 100, true ), ['div_class' => 'integria-remote-setup-integria_user'] ); // Integria password. $row['password'] = html_print_label_input_block( __('Password'), html_print_input_password( 'integria_pass', io_output_password($config['integria_pass']), '', 30, 100, true ), ['div_class' => 'integria-remote-setup-integria_pass'] ); $table_remote->data['integria_pass'] = $row; // Integria hostname. $row = []; $row['hostname'] = html_print_label_input_block( __('URL to Integria IMS setup').ui_print_help_tip(__('Full URL to your Integria IMS setup (e.g., http://192.168.1.20/integria, https://support.mycompany.com).'), true), html_print_input_text( 'integria_hostname', $config['integria_hostname'], '', 30, 100, true ), ['div_class' => 'integria-remote-setup-integria_hostname'] ); // API password. $row['api_pass'] = html_print_label_input_block( __('API Password'), html_print_input_password( 'integria_api_pass', io_output_password($config['integria_api_pass']), '', 30, 100, true ), ['div_class' => 'integria-remote-setup-integria_api_pass'] ); $table_remote->data['integria_api_pass'] = $row; // Request timeout. $row = []; $row['req_timeout'] = html_print_label_input_block( __('Request timeout'), html_print_input_text( 'integria_req_timeout', $config['integria_req_timeout'], '', 3, 10, true ), ['div_class' => 'integria-remote-setup-integria_req_timeout'] ); $table_remote->data['integria_req_timeout'] = $row; $row = []; $row['control'] = __('Inventory'); $row['control'] .= html_print_button( __('Sync inventory'), 'sync-inventory', false, '', [ 'icon' => 'cog', 'mode' => 'secondary mini', ], true ); $row['control'] .= ''; $row['control'] .= ''; $row['control'] .= ''; $table_remote->data['integria_sync_inventory'] = $row; // Alert settings. $table_alert_settings = new StdClass(); $table_alert_settings->data = []; $table_alert_settings->width = '100%'; $table_alert_settings->styleTable = 'margin-bottom: 10px;'; $table_alert_settings->id = 'integria-cr-settings-setup'; $table_alert_settings->class = 'databox filters filter-table-adv'; $table_alert_settings->size[0] = '50%'; $table_alert_settings->size[1] = '50%'; // Alert incident title. $row = []; $row[0] = html_print_label_input_block( __('Title'), html_print_input_text( 'incident_title', $config['incident_title'], __('Name'), 50, 100, true, false, false ) ); // Alert incident description. $row[1] = html_print_label_input_block( __('Ticket body'), html_print_textarea( 'incident_content', 3, 25, $config['incident_content'], '', true ) ); $table_alert_settings->data[0] = $row; // Alert default group. $row = []; $row[0] = html_print_label_input_block( __('Group'), html_print_select( $integria_group_values, 'default_group', $config['default_group'], '', __('Select'), 0, true, false, true, '', false ) ); // Alert default criticity. $row[1] = html_print_label_input_block( __('Priority'), html_print_select( $integria_criticity_values, 'default_criticity', $config['default_criticity'], '', __('Select'), 0, true, false, true, '', false ) ); $table_alert_settings->data[1] = $row; // Alert default owner. $row = []; $row[0] = html_print_label_input_block( __('Owner'), html_print_autocomplete_users_from_integria( 'default_owner', $config['default_owner'], true, '30', false, false, 'w100p' ), ['div_class' => 'inline'] ); // Alert default incident type. $row[1] = html_print_label_input_block( __('Type'), html_print_select( $integria_types_values, 'incident_type', $config['incident_type'], '', __('Select'), 0, true, false, true, '', false ) ); $table_alert_settings->data[2] = $row; // Alert default incident status. $row = []; $row[0] = html_print_label_input_block( __('Status'), html_print_select( $integria_status_values, 'incident_status', $config['incident_status'], '', __('Select'), 0, true, false, true, '', false ) ); $table_alert_settings->data[3] = $row; // Custom response settings. $table_cr_settings = new StdClass(); $table_cr_settings->data = []; $table_cr_settings->width = '100%'; $table_cr_settings->styleTable = 'margin-bottom: 10px;'; $table_cr_settings->id = 'integria-cr-settings-setup'; $table_cr_settings->class = 'databox filters filter-table-adv'; $table_cr_settings->size[0] = '50%'; $table_cr_settings->size[1] = '50%'; // Custom response incident title. $row = []; $row[0] = html_print_label_input_block( __('Title'), html_print_input_text( 'cr_incident_title', $config['cr_incident_title'], __('Name'), 50, 100, true, false, false ) ); // Custom response incident description. $row[1] = html_print_label_input_block( __('Ticket body'), html_print_textarea( 'cr_incident_content', 3, 25, $config['cr_incident_content'], '', true ) ); $table_cr_settings->data[0] = $row; // Custom response default group. $row = []; $row[0] = html_print_label_input_block( __('Group'), html_print_select( $integria_group_values, 'cr_default_group', $config['cr_default_group'], '', __('Select'), 0, true, false, true, '', false ) ); // Custom response default criticity. $row[1] = html_print_label_input_block( __('Priority'), html_print_select( $integria_criticity_values, 'cr_default_criticity', $config['cr_default_criticity'], '', __('Select'), 0, true, false, true, '', false ) ); $table_cr_settings->data[1] = $row; // Custom response default owner. $row = []; $row[0] = html_print_label_input_block( __('Owner'), html_print_autocomplete_users_from_integria( 'cr_default_owner', $config['cr_default_owner'], true, '30', false, false, 'w100p' ), ['div_class' => 'inline'] ); // Custom response default incident type. $row[1] = html_print_label_input_block( __('Type'), html_print_select( $integria_types_values, 'cr_incident_type', $config['cr_incident_type'], '', __('Select'), 0, true, false, true, '', false ) ); $table_cr_settings->data[2] = $row; // Custom response default incident status. $row = []; $row[0] = html_print_label_input_block( __('Status'), html_print_select( $integria_status_values, 'cr_incident_status', $config['cr_incident_status'], '', __('Select'), 0, true, false, true, '', false ) ); $table_cr_settings->data[3] = $row; // Test. $row = []; $row['control'] = __('Test connection'); $row['control'] .= html_print_button( __('Test'), 'test-integria', false, '', [ 'icon' => 'cog', 'mode' => 'secondary mini', ], true ); $row['control'] .= ''; $row['control'] .= ''; $row['control'] .= ''; $row['control'] .= ' '; $table_remote->data['integria_test'] = $row; // Print. echo '
'; echo ''; html_print_image( 'images/integria_logo.svg', false, ['class' => 'w400px mrgn_top_15px'] ); echo ''; echo '
'; echo '
'; echo __('Integria IMS'); echo '
'; echo ''; echo 'https://integriaims.com'; echo ''; echo '
'; echo "
"; html_print_input_hidden('update_config', 1); // Form enable. echo '
'; html_print_table($table_enable); echo '
'; // Form remote. echo '
'; echo '
'; echo ''.__('Integria API settings').''; html_print_table($table_remote); echo '
'; echo '
'; if ($has_connection != false) { // Form alert default settings. echo '
'; echo '
'; echo ''.__('Alert default values').' '.ui_print_help_icon('alert_macros', true).''; html_print_table($table_alert_settings); echo '
'; echo '
'; // Form custom response default settings. echo '
'; echo '
'; echo ''.__('Event custom response default values').' '.ui_print_help_icon('alert_macros', true).''; html_print_table($table_cr_settings); echo '
'; echo '
'; $update_button = html_print_submit_button( __('Update'), 'update_button', false, ['icon' => 'update'], true ); } else { $update_button = html_print_submit_button( __('Update and continue'), 'update_button', false, ['icon' => 'update'], true ); } html_print_action_buttons($update_button); echo '
'; ?>