2019-08-05 13:42:01 +02:00
< ? php
/**
2022-10-26 10:51:12 +02:00
* Integria setup .
*
* @ category Setup
* @ package Pandora FMS
* @ subpackage Opensource
* @ version 1.0 . 0
* @ license See below
*
2019-08-05 13:42:01 +02:00
* ______ ___ _______ _______ ________
* | __ \ .-----.--.--.--| |.-----.----.-----. | ___ | | | __ |
* | __ /| _ | | _ || _ | _ | _ | | ___ | | __ |
* | ___ | | ___ . _ | __ | __ | _____ || _____ | __ | | ___ . _ | | ___ | | __ | _ | __ | _______ |
*
* ============================================================================
2022-10-26 10:51:12 +02:00
* Copyright ( c ) 2005 - 2022 Artica Soluciones Tecnologicas
2019-08-05 13:42:01 +02:00
* Please see http :// pandorafms . org for full contribution list
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation for version 2.
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
* ============================================================================
*/
2022-10-26 10:51:12 +02:00
// Load globals.
2019-08-05 13:42:01 +02:00
global $config ;
check_login ();
if ( ! check_acl ( $config [ 'id_user' ], 0 , 'PM' ) && ! is_user_admin ( $config [ 'id_user' ])) {
2022-02-01 13:39:18 +01:00
db_pandora_audit (
AUDIT_LOG_ACL_VIOLATION ,
'Trying to access Setup Management'
);
2019-08-05 13:42:01 +02:00
include 'general/noaccess.php' ;
return ;
}
2019-09-23 15:16:31 +02:00
require_once $config [ 'homedir' ] . '/include/functions_integriaims.php' ;
2022-10-26 10:51:12 +02:00
if ( is_ajax () === true ) {
2021-02-25 13:18:04 +01:00
$operation = ( string ) get_parameter ( 'operation' , '' );
2019-09-02 17:01:41 +02:00
$integria_user = get_parameter ( 'integria_user' , '' );
$integria_pass = get_parameter ( 'integria_pass' , '' );
$integria_api_hostname = get_parameter ( 'api_hostname' , '' );
$integria_api_pass = get_parameter ( 'api_pass' , '' );
2021-05-07 14:29:29 +02:00
$user_level_conf = get_parameter ( 'user_level_conf' , 0 );
2022-10-26 10:51:12 +02:00
$user_level_conf_bool = (( bool ) $user_level_conf === true );
2019-09-02 17:01:41 +02:00
2021-05-07 14:29:29 +02:00
$login_result = integria_api_call ( $integria_api_hostname , $integria_user , $integria_pass , $integria_api_pass , 'get_login' , [], false , '' , '' , $user_level_conf_bool );
2019-09-02 17:01:41 +02:00
2022-10-26 10:51:12 +02:00
echo json_encode ([ 'login' => ( $login_result !== false ) ? 1 : 0 ]);
2019-09-02 17:01:41 +02:00
return ;
}
2021-05-07 14:29:29 +02:00
$has_connection = integria_api_call ( null , null , null , null , 'get_login' , []);
2019-09-02 17:01:41 +02:00
2019-09-26 09:44:58 +02:00
if ( $has_connection === false && $config [ 'integria_enabled' ]) {
2019-09-02 17:01:41 +02:00
ui_print_error_message ( __ ( 'Integria IMS API is not reachable' ));
}
2019-08-08 13:36:12 +02:00
if ( get_parameter ( 'update_config' , 0 ) == 1 ) {
// Try to retrieve event response 'Create incident in IntegriaIMS from event' to check if it exists.
2019-09-25 16:13:37 +02:00
$event_response_exists = db_get_row_filter ( 'tevent_response' , [ 'name' => io_safe_input ( 'Create ticket in IntegriaIMS from event' )]);
2019-09-02 17:01:41 +02:00
// 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' )]);
2019-08-08 13:36:12 +02:00
if ( $config [ 'integria_enabled' ] == 1 ) {
2019-09-02 17:01:41 +02:00
if ( $event_response_exists === false ) {
2019-08-08 13:36:12 +02:00
// Create 'Create incident in IntegriaIMS from event' event response only when user enables IntegriaIMS integration and it does not exist in database.
2019-09-23 12:48:20 +02:00
db_process_sql_insert (
'tevent_response' ,
[
2019-09-25 16:13:37 +02:00
'name' => io_safe_input ( 'Create ticket in IntegriaIMS from event' ),
'description' => io_safe_input ( 'Create a ticket in Integria IMS from an event' ),
2019-09-23 12:48:20 +02:00
'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' ,
]
);
2019-09-02 17:01:41 +02:00
}
2021-05-07 14:29:29 +02:00
$ticket_types = integria_api_call ( null , null , null , null , 'get_types' , '' , false , 'json' );
2021-02-25 13:18:04 +01:00
$types_string = '' ;
if ( $ticket_types !== '' ) {
foreach ( json_decode ( $ticket_types , true ) as $key => $value ) {
$types_string .= $value [ 'id' ] . ',' . $value [ 'name' ] . ';' ;
}
}
2019-09-02 17:01:41 +02:00
if ( $command_exists === false ) {
// Create 'Integria IMS Ticket' command only when user enables IntegriaIMS integration and it does not exist in database.
2019-09-23 12:48:20 +02:00
$id_command_inserted = db_process_sql_insert (
'talert_commands' ,
[
'name' => io_safe_input ( 'Integria IMS Ticket' ),
2019-09-26 09:44:58 +02:00
'command' => io_safe_input ( 'Internal type' ),
2019-09-23 12:48:20 +02:00
'internal' => 1 ,
2019-09-25 16:13:37 +02:00
'description' => io_safe_input ( 'Create a ticket in Integria IMS' ),
2021-03-10 10:28:27 +01:00
'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_"]' ,
2019-09-23 12:48:20 +02:00
]
);
2019-09-02 17:01:41 +02:00
// 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' ]),
2019-09-26 09:44:58 +02:00
'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' ]),
2019-09-02 17:01:41 +02:00
'id_group' => 0 ,
'action_threshold' => 0 ,
];
alerts_create_alert_action ( io_safe_input ( 'Create Integria IMS ticket' ), $id_command_inserted , $action_values );
} else {
2021-02-25 13:18:04 +01:00
// Update 'Integria IMS Ticket' command with ticket types retrieved from Integria IMS.
$sql_update_command_values = sprintf (
'
UPDATE talert_commands
2021-03-10 10:28:27 +01:00
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_ " ] \ '
2021-02-25 13:18:04 +01:00
WHERE name = " %s " ' ,
$types_string ,
io_safe_input ( 'Integria IMS Ticket' )
2019-09-02 17:01:41 +02:00
);
2021-02-25 13:18:04 +01:00
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 );
}
2019-08-08 13:36:12 +02:00
}
} else {
2021-02-25 13:18:04 +01:00
if ( $event_response_exists !== false ) {
2019-09-02 17:01:41 +02:00
// Delete 'Create incident in IntegriaIMS from event' event response if it does exist and IntegriaIMS integration is disabled.
2019-09-25 16:13:37 +02:00
db_process_sql_delete ( 'tevent_response' , [ 'name' => io_safe_input ( 'Create ticket in IntegriaIMS from event' )]);
2019-09-02 17:01:41 +02:00
}
2019-08-08 13:36:12 +02:00
}
}
2019-09-02 17:01:41 +02:00
// Get parameters from Integria IMS API.
2019-09-17 13:38:17 +02:00
$integria_group_values = [];
2019-09-02 17:01:41 +02:00
$integria_criticity_values = [];
$integria_users_values = [];
$integria_types_values = [];
2019-09-17 13:38:17 +02:00
$integria_status_values = [];
2019-09-02 17:01:41 +02:00
2021-05-07 14:29:29 +02:00
$integria_groups_csv = integria_api_call ( null , null , null , null , 'get_groups' , []);
2019-09-02 17:01:41 +02:00
2019-09-17 13:38:17 +02:00
get_array_from_csv_data_pair ( $integria_groups_csv , $integria_group_values );
2021-05-07 14:29:29 +02:00
$integria_status_csv = integria_api_call ( null , null , null , null , 'get_incidents_status' , []);
2019-09-17 13:38:17 +02:00
get_array_from_csv_data_pair ( $integria_status_csv , $integria_status_values );
2019-09-02 17:01:41 +02:00
2021-05-07 14:29:29 +02:00
$integria_criticity_levels_csv = integria_api_call ( null , null , null , null , 'get_incident_priorities' , []);
2019-09-02 17:01:41 +02:00
2019-09-17 13:38:17 +02:00
get_array_from_csv_data_pair ( $integria_criticity_levels_csv , $integria_criticity_values );
2019-09-02 17:01:41 +02:00
2021-05-07 14:29:29 +02:00
$integria_users_csv = integria_api_call ( null , null , null , null , 'get_users' , []);
2019-09-02 17:01:41 +02:00
$csv_array = explode ( " \n " , $integria_users_csv );
foreach ( $csv_array as $csv_line ) {
2022-10-28 15:01:00 +02:00
if ( empty ( $csv_line ) === false ) {
2019-09-02 17:01:41 +02:00
$integria_users_values [ $csv_line ] = $csv_line ;
}
}
2021-05-07 14:29:29 +02:00
$integria_types_csv = integria_api_call ( null , null , null , null , 'get_types' , []);
2019-09-02 17:01:41 +02:00
2019-09-17 13:38:17 +02:00
get_array_from_csv_data_pair ( $integria_types_csv , $integria_types_values );
2019-09-02 17:01:41 +02:00
2019-08-05 13:42:01 +02:00
// 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 = [];
2019-09-25 16:13:37 +02:00
$row [ 'name' ] = __ ( 'Enable Integria IMS' );
2019-08-05 13:42:01 +02:00
$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' ;
2023-03-22 16:42:03 +01:00
$table_remote -> class = 'databox filters filter-table-adv' ;
$table_remote -> size [ 'hostname' ] = '50%' ;
$table_remote -> size [ 'api_pass' ] = '50%' ;
2019-08-05 13:42:01 +02:00
2023-03-22 16:42:03 +01:00
// Enable Integria user configuration.
2021-05-07 14:29:29 +02:00
$row = [];
2023-03-22 16:42:03 +01:00
$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
)
);
2021-05-07 14:29:29 +02:00
$table_remote -> data [ 'integria_user_level_conf' ] = $row ;
2019-09-02 17:01:41 +02:00
// Integria user.
2019-08-05 13:42:01 +02:00
$row = [];
2023-03-22 16:42:03 +01:00
$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' ]
);
2019-08-05 13:42:01 +02:00
2019-09-02 17:01:41 +02:00
// Integria password.
2023-03-22 16:42:03 +01:00
$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' ]
);
2019-08-05 13:42:01 +02:00
$table_remote -> data [ 'integria_pass' ] = $row ;
2019-09-02 17:01:41 +02:00
// Integria hostname.
2019-08-05 13:42:01 +02:00
$row = [];
2023-03-22 16:42:03 +01:00
$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' ]
);
2019-08-05 13:42:01 +02:00
2019-09-02 17:01:41 +02:00
// API password.
2023-03-22 16:42:03 +01:00
$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' ]
);
2019-09-02 17:01:41 +02:00
$table_remote -> data [ 'integria_api_pass' ] = $row ;
2019-08-05 13:42:01 +02:00
// Request timeout.
$row = [];
2023-03-22 16:42:03 +01:00
$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' ]
);
2019-08-05 13:42:01 +02:00
$table_remote -> data [ 'integria_req_timeout' ] = $row ;
2021-02-25 13:18:04 +01:00
$row = [];
2023-03-22 16:42:03 +01:00
$row [ 'control' ] = __ ( 'Inventory' );
$row [ 'control' ] .= html_print_button (
2022-10-26 10:51:12 +02:00
__ ( 'Sync inventory' ),
'sync-inventory' ,
false ,
'' ,
[
'icon' => 'cog' ,
'mode' => 'secondary mini' ,
],
true
);
2021-02-25 13:18:04 +01:00
$row [ 'control' ] .= '<span id="test-integria-spinner-sync" style="display:none;"> ' . html_print_image ( 'images/spinner.gif' , true ) . '</span>' ;
$row [ 'control' ] .= '<span id="test-integria-success-sync" style="display:none;"> ' . html_print_image ( 'images/status_sets/default/severity_normal.png' , true ) . '</span>' ;
$row [ 'control' ] .= '<span id="test-integria-failure-sync" style="display:none;"> ' . html_print_image ( 'images/status_sets/default/severity_critical.png' , true ) . '</span>' ;
$table_remote -> data [ 'integria_sync_inventory' ] = $row ;
2019-09-26 13:22:10 +02:00
// 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' ;
2023-03-23 17:44:04 +01:00
$table_alert_settings -> class = 'databox filters filter-table-adv' ;
$table_alert_settings -> size [ 0 ] = '50%' ;
$table_alert_settings -> size [ 1 ] = '50%' ;
2019-09-26 13:22:10 +02:00
2019-09-26 13:36:14 +02:00
// Alert incident title.
2019-09-26 13:22:10 +02:00
$row = [];
2023-03-23 17:44:04 +01:00
$row [ 0 ] = html_print_label_input_block (
__ ( 'Title' ),
html_print_input_text (
'incident_title' ,
$config [ 'incident_title' ],
__ ( 'Name' ),
50 ,
100 ,
true ,
false ,
false
)
2021-05-05 13:02:53 +02:00
);
2019-09-26 13:22:10 +02:00
2019-09-26 13:36:14 +02:00
// Alert incident description.
2023-03-23 17:44:04 +01:00
$row [ 1 ] = html_print_label_input_block (
__ ( 'Ticket body' ),
html_print_textarea (
'incident_content' ,
3 ,
25 ,
$config [ 'incident_content' ],
'' ,
true
)
2021-05-05 13:02:53 +02:00
);
2023-03-23 17:44:04 +01:00
$table_alert_settings -> data [ 0 ] = $row ;
2019-09-26 13:22:10 +02:00
2019-09-26 13:36:14 +02:00
// Alert default group.
2019-09-26 13:22:10 +02:00
$row = [];
2023-03-23 17:44:04 +01:00
$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
)
2019-09-26 13:22:10 +02:00
);
2019-09-26 13:36:14 +02:00
// Alert default criticity.
2023-03-23 17:44:04 +01:00
$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
)
2019-09-26 13:22:10 +02:00
);
2023-03-23 17:44:04 +01:00
$table_alert_settings -> data [ 1 ] = $row ;
2019-09-26 13:22:10 +02:00
2019-09-26 13:36:14 +02:00
// Alert default owner.
2019-09-26 13:22:10 +02:00
$row = [];
2023-03-23 17:44:04 +01:00
$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' ]
2019-09-26 13:22:10 +02:00
);
2019-09-26 13:36:14 +02:00
// Alert default incident type.
2023-03-23 17:44:04 +01:00
$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
)
2019-09-26 13:22:10 +02:00
);
2023-03-23 17:44:04 +01:00
$table_alert_settings -> data [ 2 ] = $row ;
2019-09-26 13:22:10 +02:00
2019-09-26 13:36:14 +02:00
// Alert default incident status.
2019-09-26 13:22:10 +02:00
$row = [];
2023-03-23 17:44:04 +01:00
$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
)
2019-09-26 13:22:10 +02:00
);
2023-03-23 17:44:04 +01:00
$table_alert_settings -> data [ 3 ] = $row ;
2019-09-26 13:22:10 +02:00
2019-09-02 17:01:41 +02:00
// 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' ;
2023-03-23 17:44:04 +01:00
$table_cr_settings -> class = 'databox filters filter-table-adv' ;
$table_cr_settings -> size [ 0 ] = '50%' ;
$table_cr_settings -> size [ 1 ] = '50%' ;
2019-09-02 17:01:41 +02:00
2019-09-17 13:38:17 +02:00
// Custom response incident title.
$row = [];
2023-03-23 17:44:04 +01:00
$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
)
2021-05-05 13:02:53 +02:00
);
2019-09-17 13:38:17 +02:00
// Custom response incident description.
2023-03-23 17:44:04 +01:00
$row [ 1 ] = html_print_label_input_block (
__ ( 'Ticket body' ),
html_print_textarea (
'cr_incident_content' ,
3 ,
25 ,
$config [ 'cr_incident_content' ],
'' ,
true
)
2021-05-05 13:02:53 +02:00
);
2023-03-23 17:44:04 +01:00
$table_cr_settings -> data [ 0 ] = $row ;
2019-09-17 13:38:17 +02:00
2019-09-02 17:01:41 +02:00
// Custom response default group.
$row = [];
2023-03-23 17:44:04 +01:00
$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
)
2019-09-02 17:01:41 +02:00
);
// Custom response default criticity.
2023-03-23 17:44:04 +01:00
$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
)
2019-09-02 17:01:41 +02:00
);
2023-03-23 17:44:04 +01:00
$table_cr_settings -> data [ 1 ] = $row ;
2019-09-02 17:01:41 +02:00
// Custom response default owner.
$row = [];
2023-03-23 17:44:04 +01:00
$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' ]
2019-09-02 17:01:41 +02:00
);
2019-09-17 13:38:17 +02:00
2019-09-02 17:01:41 +02:00
// Custom response default incident type.
2023-03-23 17:44:04 +01:00
$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
)
2019-09-02 17:01:41 +02:00
);
2023-03-23 17:44:04 +01:00
$table_cr_settings -> data [ 2 ] = $row ;
2019-09-02 17:01:41 +02:00
2019-09-17 13:38:17 +02:00
// Custom response default incident status.
2019-09-02 17:01:41 +02:00
$row = [];
2023-03-23 17:44:04 +01:00
$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
)
2019-09-17 13:38:17 +02:00
);
2023-03-23 17:44:04 +01:00
$table_cr_settings -> data [ 3 ] = $row ;
2019-09-02 17:01:41 +02:00
2019-08-05 13:42:01 +02:00
// Test.
$row = [];
2023-05-08 12:16:12 +02:00
$row [ 'control' ] = __ ( 'Test connection' );
2023-03-22 16:42:03 +01:00
$row [ 'control' ] .= html_print_button (
2023-05-08 12:16:12 +02:00
__ ( 'Test' ),
2022-10-26 10:51:12 +02:00
'test-integria' ,
false ,
'' ,
[
'icon' => 'cog' ,
'mode' => 'secondary mini' ,
],
true
);
2021-03-11 15:40:23 +01:00
$row [ 'control' ] .= '<span id="test-integria-spinner" class="invisible"> ' . html_print_image ( 'images/spinner.gif' , true ) . '</span>' ;
2023-05-08 12:16:12 +02:00
$row [ 'control' ] .= '<span id="test-integria-success" class="invisible"> ' . html_print_image ( 'images/status_sets/default/severity_normal.png' , true ) . ' ' . __ ( 'Connection its OK' ) . '</span>' ;
$row [ 'control' ] .= '<span id="test-integria-failure" class="invisible"> ' . html_print_image ( 'images/status_sets/default/severity_critical.png' , true ) . ' ' . __ ( 'Connection failed' ) . '</span>' ;
2021-03-11 15:40:23 +01:00
$row [ 'control' ] .= ' <span id="test-integria-message" class="invisible"></span>' ;
2019-08-05 13:42:01 +02:00
$table_remote -> data [ 'integria_test' ] = $row ;
// Print.
2023-03-22 16:42:03 +01:00
echo '<div class="center pdd_b_10px mrgn_btn_20px white_box max_floating_element_size">' ;
2019-09-27 09:07:09 +02:00
echo '<a target="_blank" rel="noopener noreferrer" href="http://integriaims.com">' ;
2022-03-09 17:20:24 +01:00
html_print_image (
'images/integria_logo.svg' ,
false ,
2023-03-22 16:42:03 +01:00
[ 'class' => 'w400px mrgn_top_15px' ]
2022-03-09 17:20:24 +01:00
);
2019-08-05 13:42:01 +02:00
echo '</a>' ;
echo '<br />' ;
2021-03-11 15:40:23 +01:00
echo '<div clsas="integria_title">' ;
2019-09-02 17:01:41 +02:00
echo __ ( 'Integria IMS' );
2019-08-05 13:42:01 +02:00
echo '</div>' ;
2019-09-02 17:01:41 +02:00
echo '<a target="_blank" rel="noopener noreferrer" href="https://integriaims.com">' ;
echo 'https://integriaims.com' ;
2019-08-05 13:42:01 +02:00
echo '</a>' ;
echo '</div>' ;
2023-03-22 16:42:03 +01:00
echo " <form method='post' class='max_floating_element_size'> " ;
2019-09-02 17:01:41 +02:00
html_print_input_hidden ( 'update_config' , 1 );
2019-08-05 13:42:01 +02:00
// Form enable.
echo '<div id="form_enable">' ;
html_print_table ( $table_enable );
echo '</div>' ;
// Form remote.
2019-09-02 17:01:41 +02:00
echo '<div id="form_remote">' ;
echo '<fieldset>' ;
echo '<legend>' . __ ( 'Integria API settings' ) . '</legend>' ;
html_print_table ( $table_remote );
echo '</fieldset>' ;
echo '</div>' ;
if ( $has_connection != false ) {
2019-09-26 13:22:10 +02:00
// Form alert default settings.
echo '<div id="form_alert_settings">' ;
2023-03-23 17:44:04 +01:00
echo '<fieldset class="mrgn_top_15px">' ;
2021-05-05 13:02:53 +02:00
echo '<legend>' . __ ( 'Alert default values' ) . ' ' . ui_print_help_icon ( 'alert_macros' , true ) . '</legend>' ;
2019-09-26 13:22:10 +02:00
html_print_table ( $table_alert_settings );
echo '</fieldset>' ;
echo '</div>' ;
// Form custom response default settings.
2019-09-02 17:01:41 +02:00
echo '<div id="form_custom_response_settings">' ;
2023-03-23 17:44:04 +01:00
echo '<fieldset class="mrgn_top_15px">' ;
2021-05-05 13:02:53 +02:00
echo '<legend>' . __ ( 'Event custom response default values' ) . ' ' . ui_print_help_icon ( 'alert_macros' , true ) . '</legend>' ;
2019-09-02 17:01:41 +02:00
html_print_table ( $table_cr_settings );
2019-08-05 13:42:01 +02:00
echo '</fieldset>' ;
echo '</div>' ;
2019-09-02 17:01:41 +02:00
2023-03-22 16:42:03 +01:00
$update_button = html_print_submit_button (
__ ( 'Update' ),
'update_button' ,
false ,
[ 'icon' => 'update' ],
true
2022-10-26 10:51:12 +02:00
);
2019-09-02 17:01:41 +02:00
} else {
2023-03-22 16:42:03 +01:00
$update_button = html_print_submit_button (
__ ( 'Update and continue' ),
'update_button' ,
false ,
[ 'icon' => 'update' ],
true
2022-10-26 10:51:12 +02:00
);
2019-09-02 17:01:41 +02:00
}
2023-03-22 16:42:03 +01:00
html_print_action_buttons ( $update_button );
2019-09-02 17:01:41 +02:00
echo '</form>' ;
2019-08-05 13:42:01 +02:00
?>
< script type = " text/javascript " >
2021-05-07 14:29:29 +02:00
if ( $ ( 'input:checkbox[name="integria_user_level_conf"]' ) . is ( ':checked' ))
{
2023-03-22 16:42:03 +01:00
$ ( '.integria-remote-setup-integria_user' ) . hide ();
$ ( '.integria-remote-setup-integria_pass' ) . hide ()
2021-05-07 14:29:29 +02:00
}
var handleUserLevel = function ( event ) {
var is_checked = $ ( 'input:checkbox[name="integria_enabled"]' ) . is ( ':checked' );
var is_checked_userlevel = $ ( 'input:checkbox[name="integria_user_level_conf"]' ) . is ( ':checked' );
2022-10-26 10:51:12 +02:00
2021-05-07 14:29:29 +02:00
if ( event . target . value == '1' && is_checked && ! is_checked_userlevel ) {
showUserPass ();
$ ( 'input:checkbox[name="integria_user_level_conf"]' ) . attr ( 'checked' , true );
}
else {
hideUserPass ();
$ ( 'input:checkbox[name="integria_user_level_conf"]' ) . attr ( 'checked' , false );
};
}
$ ( 'input:checkbox[name="integria_enabled"]' ) . change ( handleEnable );
$ ( 'input:checkbox[name="integria_user_level_conf"]' ) . change ( handleUserLevel );
2019-09-02 17:01:41 +02:00
if ( ! $ ( 'input:checkbox[name="integria_enabled"]' ) . is ( ':checked' )) {
$ ( '#form_remote' ) . hide ();
$ ( '#form_custom_response_settings' ) . hide ();
} else {
$ ( '#form_remote' ) . show ();
$ ( '#form_custom_response_settings' ) . show ();
}
2019-08-05 13:42:01 +02:00
2019-09-02 17:01:41 +02:00
$ ( '#form_enable' ) . css ( 'margin-bottom' , '20px' );
2019-08-05 13:42:01 +02:00
var showFields = function () {
$ ( '#form_remote' ) . show ();
2019-09-02 17:01:41 +02:00
$ ( '#form_custom_response_settings' ) . show ();
2019-08-05 13:42:01 +02:00
}
var hideFields = function () {
$ ( '#form_remote' ) . hide ();
2019-09-02 17:01:41 +02:00
$ ( '#form_custom_response_settings' ) . hide ();
2019-08-05 13:42:01 +02:00
}
var hideUserPass = function () {
2023-03-22 16:42:03 +01:00
$ ( '.integria-remote-setup-integria_user' ) . hide ();
$ ( '.integria-remote-setup-integria_pass' ) . hide ();
2019-08-05 13:42:01 +02:00
}
var showUserPass = function () {
2023-03-22 16:42:03 +01:00
$ ( '.integria-remote-setup-integria_user' ) . show ();
$ ( '.integria-remote-setup-integria_pass' ) . show ();
2019-08-05 13:42:01 +02:00
}
var handleEnable = function ( event ) {
var is_checked = $ ( 'input:checkbox[name="integria_enabled"]' ) . is ( ':checked' );
if ( event . target . value == '1' && is_checked ) {
showFields ();
$ ( 'input:checkbox[name="integria_enabled"]' ) . attr ( 'checked' , true );
}
else {
hideFields ();
$ ( 'input:checkbox[name="integria_enabled"]' ) . attr ( 'checked' , false );
};
}
$ ( 'input:checkbox[name="integria_enabled"]' ) . change ( handleEnable );
var handleTest = function ( event ) {
var user = $ ( 'input#text-integria_user' ) . val ();
var pass = $ ( 'input#password-integria_pass' ) . val ();
var host = $ ( 'input#text-integria_hostname' ) . val ();
var timeout = Number . parseInt ( $ ( 'input#text-integria_req_timeout' ) . val (), 10 );
var timeoutMessage = '<?php echo __(' Connection timeout '); ?>' ;
var badRequestMessage = '<?php echo __(' Empty user or password '); ?>' ;
var notFoundMessage = '<?php echo __(' User not found '); ?>' ;
var invalidPassMessage = '<?php echo __(' Invalid password '); ?>' ;
var hideLoadingImage = function () {
$ ( 'span#test-integria-spinner' ) . hide ();
}
var showLoadingImage = function () {
$ ( 'span#test-integria-spinner' ) . show ();
}
var hideSuccessImage = function () {
$ ( 'span#test-integria-success' ) . hide ();
}
var showSuccessImage = function () {
$ ( 'span#test-integria-success' ) . show ();
}
var hideFailureImage = function () {
$ ( 'span#test-integria-failure' ) . hide ();
}
var showFailureImage = function () {
$ ( 'span#test-integria-failure' ) . show ();
}
var hideMessage = function () {
$ ( 'span#test-integria-message' ) . hide ();
}
var showMessage = function () {
$ ( 'span#test-integria-message' ) . show ();
}
var changeTestMessage = function ( message ) {
$ ( 'span#test-integria-message' ) . text ( message );
}
hideSuccessImage ();
hideFailureImage ();
hideMessage ();
showLoadingImage ();
2019-09-02 17:01:41 +02:00
var integria_user = $ ( 'input[name=integria_user]' ) . val ();
var integria_pass = $ ( 'input[name=integria_pass]' ) . val ();
var api_hostname = $ ( 'input[name=integria_hostname]' ) . val ();
var api_pass = $ ( 'input[name=integria_api_pass]' ) . val ();
2021-05-07 14:29:29 +02:00
var user_level_conf = $ ( 'input:checkbox[name="integria_user_level_conf"]' ) . is ( ':checked' );
2019-09-02 17:01:41 +02:00
var data = {
2021-02-25 13:18:04 +01:00
page : 'godmode/setup/setup_integria' ,
operation : 'check_api_access' ,
2019-09-02 17:01:41 +02:00
integria_user : integria_user ,
integria_pass : integria_pass ,
api_hostname : api_hostname ,
api_pass : api_pass ,
2021-05-07 14:29:29 +02:00
user_level_conf : user_level_conf ,
2019-09-02 17:01:41 +02:00
}
// AJAX call to check API connection.
2019-08-05 13:42:01 +02:00
$ . ajax ({
2019-09-02 17:01:41 +02:00
type : " POST " ,
url : " ajax.php " ,
dataType : " json " ,
2019-09-17 13:38:17 +02:00
timeout : timeout ? timeout * 1000 : 0 ,
2019-09-02 17:01:41 +02:00
data : data
2019-08-05 13:42:01 +02:00
})
. done ( function ( data , textStatus , xhr ) {
2019-09-02 17:01:41 +02:00
if ( data . login == '1' ) {
showSuccessImage ();
} else {
showFailureImage ();
showMessage ();
}
2019-08-05 13:42:01 +02:00
})
. fail ( function ( xhr , textStatus , errorThrown ) {
showFailureImage ();
showMessage ();
})
. always ( function ( xhr , textStatus ) {
hideLoadingImage ();
});
}
2021-02-25 13:18:04 +01:00
var handleInventorySync = function ( event ) {
2022-10-26 10:51:12 +02:00
2021-02-25 13:18:04 +01:00
var badRequestMessage = '<?php echo __(' Empty user or password '); ?>' ;
var notFoundMessage = '<?php echo __(' User not found '); ?>' ;
var invalidPassMessage = '<?php echo __(' Invalid password '); ?>' ;
2022-10-26 10:51:12 +02:00
2021-02-25 13:18:04 +01:00
var hideLoadingImage = function () {
$ ( 'span#test-integria-spinner-sync' ) . hide ();
}
var showLoadingImage = function () {
$ ( 'span#test-integria-spinner-sync' ) . show ();
}
var hideSuccessImage = function () {
$ ( 'span#test-integria-success-sync' ) . hide ();
}
var showSuccessImage = function () {
$ ( 'span#test-integria-success-sync' ) . show ();
}
var hideFailureImage = function () {
$ ( 'span#test-integria-failure-sync' ) . hide ();
}
var showFailureImage = function () {
$ ( 'span#test-integria-failure-sync' ) . show ();
}
hideSuccessImage ();
hideFailureImage ();
showLoadingImage ();
var integria_user = $ ( 'input[name=integria_user]' ) . val ();
var integria_pass = $ ( 'input[name=integria_pass]' ) . val ();
var api_hostname = $ ( 'input[name=integria_hostname]' ) . val ();
var api_pass = $ ( 'input[name=integria_api_pass]' ) . val ();
if ( ! api_hostname . match ( /^ [ a - zA - Z ] +: \ / \ //))
{
api_hostname = 'http://' + api_hostname ;
}
var url = api_hostname + '/integria/include/api.php' ;
< ? php
// Retrieve all agents and codify string in the format that will be sent over in Ajax call.
$agent_fields = [
'nombre' ,
'alias' ,
'id_os' ,
'direccion' ,
'id_agente' ,
'id_grupo' ,
];
$agents = agents_get_agents ( false , $agent_fields );
$agents_query_string_array = [];
foreach ( $agents as $agent_data ) {
$agents_query_string_array [] = implode ( '|;|' , $agent_data );
}
?>
var agents_query_string_array = < ? php echo json_encode ( $agents_query_string_array ); ?> ;
var data = {
op : 'sync_pandora_agents_inventory' ,
user : integria_user ,
user_pass : integria_pass ,
pass : api_pass ,
params : agents_query_string_array ,
token : '|;|'
}
// AJAX call to check API connection.
$ . ajax ({
2021-04-15 12:12:06 +02:00
type : " POST " ,
2021-02-25 13:18:04 +01:00
url : url ,
dataType : " json " ,
data : data
})
. done ( function ( data , textStatus , xhr ) {
showSuccessImage ();
})
. fail ( function ( xhr , textStatus , errorThrown ) {
showFailureImage ();
})
. always ( function ( xhr , textStatus ) {
hideLoadingImage ();
});
}
2022-10-26 10:51:12 +02:00
$ ( '#button-test-integria' ) . click ( handleTest );
$ ( '#button-sync-inventory' ) . click ( handleInventorySync );
2019-08-05 13:42:01 +02:00
</ script >