Merge branch 'ent-4461-Configuracion-integracion-integria' of https://brutus.artica.lan:8081/artica/pandorafms into ent-4461-Configuracion-integracion-integria
This commit is contained in:
commit
e09db0b9a9
|
@ -5597,3 +5597,105 @@ function ui_print_integria_incident_priority($priority, $priority_label)
|
|||
|
||||
return $output;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get tickets from Integria IMS.
|
||||
*
|
||||
* @param array $tickets_filters Filters to send to API.
|
||||
*
|
||||
* @return array Tickets returned by API call.
|
||||
*/
|
||||
function get_tickets_integriaims($tickets_filters)
|
||||
{
|
||||
global $config;
|
||||
|
||||
// Filters.
|
||||
$incident_text = $tickets_filters['incident_text'];
|
||||
$incident_status = $tickets_filters['incident_status'];
|
||||
$incident_group = $tickets_filters['incident_group'];
|
||||
$incident_owner = $tickets_filters['incident_owner'];
|
||||
$incident_creator = $tickets_filters['incident_creator'];
|
||||
$incident_priority = $tickets_filters['incident_priority'];
|
||||
$incident_resolution = $tickets_filters['incident_resolution'];
|
||||
$created_from = $tickets_filters['created_from'];
|
||||
$created_to = $tickets_filters['created_to'];
|
||||
|
||||
// API call.
|
||||
$result_api_call_list = integria_api_call(
|
||||
$config['integria_hostname'],
|
||||
$config['integria_user'],
|
||||
$config['integria_pass'],
|
||||
$config['integria_api_pass'],
|
||||
'get_incidents',
|
||||
[
|
||||
$incident_text,
|
||||
$incident_status,
|
||||
$incident_group,
|
||||
$incident_priority,
|
||||
'0',
|
||||
$incident_owner,
|
||||
$incident_creator,
|
||||
]
|
||||
);
|
||||
|
||||
// Return array of api call 'get_incidents'.
|
||||
$array_get_incidents = [];
|
||||
get_array_from_csv_data_all($result_api_call_list, $array_get_incidents);
|
||||
|
||||
// Modify $array_get_incidents if filter for resolution exists.
|
||||
$filter_resolution = [];
|
||||
foreach ($array_get_incidents as $key => $value) {
|
||||
if ($incident_resolution !== '' && ($array_get_incidents[$key][12] == $incident_resolution)) {
|
||||
$filter_resolution[$key] = $array_get_incidents[$key];
|
||||
continue;
|
||||
}
|
||||
}
|
||||
|
||||
if ($incident_resolution !== '') {
|
||||
$array_get_incidents = $filter_resolution;
|
||||
}
|
||||
|
||||
// Modify $array_get_incidents if filter for date is selected.
|
||||
if ($created_from !== '' && $created_to !== '') {
|
||||
$date = [];
|
||||
$date_utimestamp = [];
|
||||
foreach ($array_get_incidents as $key => $value) {
|
||||
// Change format date / to -.
|
||||
$date[$key] = date('Y-m-d', strtotime($array_get_incidents[$key][9]));
|
||||
// Covert date to utimestamp.
|
||||
$date_utimestamp[$key] = strtotime($date[$key]);
|
||||
}
|
||||
|
||||
// Change format date / to -.
|
||||
$created_from_date = date('Y-m-d', strtotime($created_from));
|
||||
$created_to_date = date('Y-m-d', strtotime($created_to));
|
||||
|
||||
// Covert date to utimestamp.
|
||||
$created_from_timestamp = strtotime($created_from_date);
|
||||
$created_to_timestamp = strtotime($created_to_date);
|
||||
|
||||
// Dates within the selected period.
|
||||
$selected_period = array_filter(
|
||||
$date_utimestamp,
|
||||
function ($value) use ($created_from_timestamp, $created_to_timestamp) {
|
||||
return ($value >= $created_from_timestamp && $value <= $created_to_timestamp);
|
||||
}
|
||||
);
|
||||
|
||||
// Return incidents with the correct dates.
|
||||
$filter_date = [];
|
||||
foreach ($array_get_incidents as $key => $value) {
|
||||
foreach ($selected_period as $index => $value) {
|
||||
if ($array_get_incidents[$key][0] == $index) {
|
||||
$filter_date[$key] = $array_get_incidents[$key];
|
||||
continue;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$array_get_incidents = $filter_date;
|
||||
}
|
||||
|
||||
return $array_get_incidents;
|
||||
}
|
||||
|
|
|
@ -3423,7 +3423,6 @@ function html_print_autocomplete_users_from_integria(
|
|||
timeout: 10000,
|
||||
dataType: "json",
|
||||
success: function (data) {
|
||||
console.log(data);
|
||||
temp = [];
|
||||
$.each(data, function (id, module) {
|
||||
temp.push({
|
||||
|
|
|
@ -0,0 +1,138 @@
|
|||
<?php
|
||||
|
||||
// Pandora FMS - http://pandorafms.com
|
||||
// ==================================================
|
||||
// Copyright (c) 2005-2019 Artica Soluciones Tecnologicas
|
||||
// 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.
|
||||
// Load global vars
|
||||
global $config;
|
||||
|
||||
require_once '../../include/config.php';
|
||||
require_once '../../include/functions.php';
|
||||
|
||||
check_login();
|
||||
|
||||
if (! check_acl($config['id_user'], 0, 'IR') && ! check_acl($config['id_user'], 0, 'IW') && ! check_acl($config['id_user'], 0, 'IM')) {
|
||||
// Doesn't have access to this page.
|
||||
db_pandora_audit('ACL Violation', 'Trying to access IntegriaIMS ticket creation');
|
||||
include 'general/noaccess.php';
|
||||
exit;
|
||||
}
|
||||
|
||||
// Get status.
|
||||
$status_api_call = integria_api_call($config['integria_hostname'], $config['integria_user'], $config['integria_pass'], $config['integria_api_pass'], 'get_incidents_status');
|
||||
$status_incident = [];
|
||||
get_array_from_csv_data_pair($status_api_call, $status_incident);
|
||||
|
||||
// Get group.
|
||||
$group_api_call = integria_api_call($config['integria_hostname'], $config['integria_user'], $config['integria_pass'], $config['integria_api_pass'], 'get_groups');
|
||||
$group_incident = [];
|
||||
get_array_from_csv_data_pair($group_api_call, $group_incident);
|
||||
|
||||
// Get priority.
|
||||
$priority_api_call = integria_api_call($config['integria_hostname'], $config['integria_user'], $config['integria_pass'], $config['integria_api_pass'], 'get_incident_priorities');
|
||||
$priority_incident = [];
|
||||
get_array_from_csv_data_pair($priority_api_call, $priority_incident);
|
||||
|
||||
// Get resolution.
|
||||
$resolution_api_call = integria_api_call($config['integria_hostname'], $config['integria_user'], $config['integria_pass'], $config['integria_api_pass'], 'get_incidents_resolutions');
|
||||
$resolution_incident = [];
|
||||
get_array_from_csv_data_pair($resolution_api_call, $resolution_incident);
|
||||
|
||||
|
||||
// Get data to export.
|
||||
$tickets_filters = json_decode(
|
||||
base64_decode(
|
||||
get_parameter('tickets_filters', '')
|
||||
),
|
||||
true
|
||||
);
|
||||
|
||||
$tickets_csv_array = get_tickets_integriaims($tickets_filters);
|
||||
|
||||
|
||||
// Build a new array to show only the fields in the table.
|
||||
$tickets_csv_array_filter = [];
|
||||
foreach ($tickets_csv_array as $key => $value) {
|
||||
// Status.
|
||||
if ($tickets_csv_array[$key][6] == 0) {
|
||||
$tickets_csv_array[$key][6] = 'None';
|
||||
} else {
|
||||
$tickets_csv_array[$key][6] = $status_incident[$tickets_csv_array[$key][6]];
|
||||
}
|
||||
|
||||
// Priority.
|
||||
$tickets_csv_array[$key][7] = $priority_incident[$tickets_csv_array[$key][7]];
|
||||
|
||||
// Group.
|
||||
$tickets_csv_array[$key][8] = $group_incident[$tickets_csv_array[$key][8]];
|
||||
|
||||
// Resolution.
|
||||
if ($tickets_csv_array[$key][12] == 0) {
|
||||
$tickets_csv_array[$key][12] = 'None';
|
||||
} else {
|
||||
$tickets_csv_array[$key][12] = $resolution_incident[$tickets_csv_array[$key][12]];
|
||||
}
|
||||
|
||||
$tickets_csv_array_filter[$key] = [
|
||||
'id_incidencia' => $tickets_csv_array[$key][0],
|
||||
'titulo' => $tickets_csv_array[$key][3],
|
||||
'id_grupo' => $tickets_csv_array[$key][8],
|
||||
'estado_resolution' => $tickets_csv_array[$key][6].' / '.$tickets_csv_array[$key][12],
|
||||
'prioridad' => $tickets_csv_array[$key][7],
|
||||
'actualizacion' => $tickets_csv_array[$key][9],
|
||||
'id_creator' => $tickets_csv_array[$key][10],
|
||||
'owner' => $tickets_csv_array[$key][5],
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
// Header for CSV file.
|
||||
$header = [
|
||||
__('ID Ticket'),
|
||||
__('Title'),
|
||||
__('Group/Company'),
|
||||
__('Status/Resolution'),
|
||||
__('Priority'),
|
||||
__('Updated/Started'),
|
||||
__('Creator'),
|
||||
__('Owner'),
|
||||
];
|
||||
|
||||
$header_csv = '';
|
||||
foreach ($header as $key => $value) {
|
||||
$header_csv .= $value.',';
|
||||
}
|
||||
|
||||
$header_csv = io_safe_output($header_csv).PHP_EOL;
|
||||
|
||||
|
||||
// Join header and content.
|
||||
$tickets_csv = '';
|
||||
foreach ($tickets_csv_array_filter as $key => $value) {
|
||||
$tickets_csv .= implode(',', $tickets_csv_array_filter[$key]).PHP_EOL;
|
||||
}
|
||||
|
||||
$tickets_csv = $header_csv.$tickets_csv;
|
||||
|
||||
|
||||
// Create csv file.
|
||||
$filename = 'tickets_export-'.date('Ymd').'-'.date('His').'.csv';
|
||||
|
||||
ob_clean();
|
||||
|
||||
header('Content-Type: text/csv; charset=utf-8');
|
||||
header('Content-Disposition: attachment; filename='.$filename);
|
||||
|
||||
// BOM.
|
||||
echo pack('C*', 0xEF, 0xBB, 0xBF);
|
||||
|
||||
// CSV file.
|
||||
echo io_safe_output($tickets_csv);
|
|
@ -40,14 +40,15 @@ if ($has_connection === false) {
|
|||
}
|
||||
|
||||
// Get parameters for filters.
|
||||
$incident_text = (string) get_parameter('text_filter', '');
|
||||
$incident_text = (string) get_parameter('incident_text', '');
|
||||
$incident_status = (int) get_parameter('incident_status', 0);
|
||||
$incident_group = (int) get_parameter('incident_group', 1);
|
||||
$incident_owner = (string) get_parameter('incident_owner', '');
|
||||
$incident_creator = (string) get_parameter('incident_creator', '');
|
||||
$incident_priority = (int) get_parameter('incident_priority', -1);
|
||||
$incident_resolution = (string) get_parameter('incident_resolution', '');
|
||||
$incident_date = (string) get_parameter('incident_date', '');
|
||||
$created_from = (string) get_parameter('created_from', '');
|
||||
$created_to = (string) get_parameter('created_to', '');
|
||||
|
||||
$offset = (int) get_parameter('offset');
|
||||
|
||||
|
@ -74,9 +75,9 @@ if ($delete_incident) {
|
|||
|
||||
// Full url with all filters.
|
||||
$url = ui_get_full_url(
|
||||
'index.php?sec=incident&sec2=operation/incidents/list_integriaims_incidents&incident_text='.$incident_text.'&incident_status='.$incident_status.'&incident_group='.$incident_group.'&incident_owner='.$incident_owner.'&incident_creator='.$incident_creator.'&incident_priority='.$incident_priority.'&incident_resolution='.$incident_resolution.'&incident_date='.$incident_date.'&offset='.$offset
|
||||
'index.php?sec=incident&sec2=operation/incidents/list_integriaims_incidents&incident_text='.$incident_text.'&incident_status='.$incident_status.'&incident_group='.$incident_group.'&incident_owner='.$incident_owner.'&incident_creator='.$incident_creator.'&incident_priority='.$incident_priority.'&incident_resolution='.$incident_resolution.'&created_from='.$created_from.'&created_to='.$created_to.'&offset='.$offset
|
||||
);
|
||||
hd($url);
|
||||
|
||||
|
||||
// ---- FILTERS ----
|
||||
// API calls to fill the filters.
|
||||
|
@ -109,7 +110,7 @@ $table->cellspacing = '0';
|
|||
$table->data = [];
|
||||
|
||||
$table->data[0][0] = __('Text filter');
|
||||
$table->data[0][1] = html_print_input_text('text_filter', $text_filter, '', 20, 40, true);
|
||||
$table->data[0][1] = html_print_input_text('incident_text', $incident_text, '', 30, 100, true);
|
||||
|
||||
$table->data[0][2] = __('Status');
|
||||
$table->data[0][3] = html_print_select(
|
||||
|
@ -163,17 +164,65 @@ $table->data[2][1] = html_print_select(
|
|||
|
||||
// TODO: field type date.
|
||||
$table->data[2][2] = __('Date');
|
||||
$table->data[2][3] = 'FECHA';
|
||||
$table->data[2][3] = html_print_input_text_extended(
|
||||
'created_from',
|
||||
$created_from,
|
||||
'created_from',
|
||||
'',
|
||||
12,
|
||||
50,
|
||||
false,
|
||||
'',
|
||||
'placeholder="'.__('Created from').'"',
|
||||
true
|
||||
);
|
||||
$table->data[2][3] .= html_print_input_text_extended(
|
||||
'created_to',
|
||||
$created_to,
|
||||
'created_to',
|
||||
'',
|
||||
12,
|
||||
50,
|
||||
false,
|
||||
'',
|
||||
'style="margin-left:5px;" placeholder="'.__('Created to').'"',
|
||||
true
|
||||
);
|
||||
|
||||
// TODO: image of Integria IMS.
|
||||
$table->data[2][4] = 'Imagen:';
|
||||
$table->data[2][5] = 'IMAGEN';
|
||||
$table->data[2][4] = '';
|
||||
$table->data[2][5] = '';
|
||||
|
||||
|
||||
// Send filters to get_tickets_integriaims().
|
||||
$tickets_filters = [
|
||||
'incident_text' => $incident_text,
|
||||
'incident_status' => $incident_status,
|
||||
'incident_group' => $incident_group,
|
||||
'incident_owner' => $incident_owner,
|
||||
'incident_creator' => $incident_creator,
|
||||
'incident_priority' => $incident_priority,
|
||||
'incident_resolution' => $incident_resolution,
|
||||
'created_from' => $created_from,
|
||||
'created_to' => $created_to,
|
||||
];
|
||||
|
||||
// Data to export to csv file.
|
||||
$decode_csv = base64_encode(json_encode($tickets_filters));
|
||||
|
||||
|
||||
// ---- PRINT TABLE FILTERS ----
|
||||
$integria_incidents_form = '<form method="post" action="'.$url.'">';
|
||||
$integria_incidents_form .= html_print_table($table, true);
|
||||
$integria_incidents_form .= '<div style="width:100%; text-align:right;">';
|
||||
$integria_incidents_form .= '<div style="float:right; margin-left: 5px;">'.html_print_submit_button(__('Export to CSV'), 'csv_button', false, 'class="sub next"', true).'</div>';
|
||||
$integria_incidents_form .= '<div style="float:right; margin-left: 5px;">'.html_print_button(
|
||||
__('Export to CSV'),
|
||||
'csv_export',
|
||||
false,
|
||||
"location.href='operation/incidents/integriaims_export_csv.php?tickets_filters=$decode_csv'",
|
||||
'class="sub next"',
|
||||
true
|
||||
).'</div>';
|
||||
$integria_incidents_form .= '<div>'.html_print_submit_button(__('Filter'), 'filter_button', false, 'class="sub filter"', true).'</div>';
|
||||
$integria_incidents_form .= '</div>';
|
||||
$integria_incidents_form .= '</form>';
|
||||
|
@ -181,43 +230,6 @@ $integria_incidents_form .= '</form>';
|
|||
// ui_toggle($integria_incidents_form, __('Add Custom filter'));
|
||||
echo $integria_incidents_form;
|
||||
|
||||
// ---- LIST OF INCIDENTS ----
|
||||
$result_api_call_list = integria_api_call(
|
||||
$config['integria_hostname'],
|
||||
$config['integria_user'],
|
||||
$config['integria_pass'],
|
||||
$config['integria_api_pass'],
|
||||
'get_incidents',
|
||||
[
|
||||
$incident_text,
|
||||
$incident_status,
|
||||
$incident_group,
|
||||
$incident_priority,
|
||||
'0',
|
||||
$incident_owner,
|
||||
$incident_creator,
|
||||
]
|
||||
);
|
||||
// 'get_incidents', ['', '0', '1', '-1', '0', 'admin', 'admin']);
|
||||
// http://192.168.70.124/integria/include/api.php?user=admin&user_pass=integria&pass=1234&op=get_incidents¶ms=,0,1,-1
|
||||
$array_get_incidents = [];
|
||||
|
||||
// Return array of api call 'get_incidents'.
|
||||
get_array_from_csv_data_all($result_api_call_list, $array_get_incidents);
|
||||
|
||||
// Modify $array_get_incidents if filter for resolution exists.
|
||||
$filter_resolution = [];
|
||||
foreach ($array_get_incidents as $key => $value) {
|
||||
if ($incident_resolution !== '' && ($array_get_incidents[$key][12] == $incident_resolution)) {
|
||||
$filter_resolution[$key] = $array_get_incidents[$key];
|
||||
continue;
|
||||
}
|
||||
}
|
||||
|
||||
if ($incident_resolution !== '') {
|
||||
$array_get_incidents = $filter_resolution;
|
||||
}
|
||||
|
||||
/*
|
||||
* Order api call 'get_incidents'.
|
||||
*
|
||||
|
@ -232,6 +244,10 @@ if ($incident_resolution !== '') {
|
|||
*
|
||||
*/
|
||||
|
||||
// ---- LIST OF INCIDENTS ----
|
||||
// Get list of incidents.
|
||||
$array_get_incidents = get_tickets_integriaims($tickets_filters);
|
||||
|
||||
// Prepare pagination.
|
||||
$incidents_limit = $config['block_size'];
|
||||
$incidents_paginated = array_slice($array_get_incidents, $offset, $incidents_limit, true);
|
||||
|
@ -273,7 +289,7 @@ foreach ($incidents_paginated as $key => $value) {
|
|||
$table->data[$i][4] = ui_print_integria_incident_priority($array_get_incidents[$key][7], $priority_incident[$array_get_incidents[$key][7]]);
|
||||
$table->data[$i][5] = $array_get_incidents[$key][9];
|
||||
$table->data[$i][6] = $array_get_incidents[$key][10];
|
||||
$table->data[$i][7] = $array_get_incidents[$key][0];
|
||||
$table->data[$i][7] = $array_get_incidents[$key][5];
|
||||
$table->data[$i][8] = '';
|
||||
$table->cellclass[$i][8] = 'action_buttons';
|
||||
if (check_acl($config['id_user'], 0, 'IW')) {
|
||||
|
@ -301,7 +317,20 @@ ui_pagination(count($array_get_incidents), $url, $offset, 0, false, 'offset', tr
|
|||
if (check_acl($config['id_user'], 0, 'IR')) {
|
||||
echo '<form method="POST" action="'.ui_get_full_url('index.php?sec=incident&sec2=operation/incidents/configure_integriaims_incident').'">';
|
||||
echo '<div style="width: 100%; text-align:right;">';
|
||||
html_print_submit_button(__('Create'), 'create_new_incident', false, 'class="sub wand"');
|
||||
html_print_submit_button(__('Create'), 'create_new_incident', false, 'class="sub next"');
|
||||
echo '</div>';
|
||||
echo '</form>';
|
||||
}
|
||||
|
||||
// Datapicker library for show calendar.
|
||||
ui_require_jquery_file('ui.datepicker-'.get_user_language(), 'include/javascript/i18n/');
|
||||
?>
|
||||
|
||||
|
||||
<script language="javascript" type="text/javascript">
|
||||
$(document).ready( function() {
|
||||
$("#created_from, #created_to").datepicker({
|
||||
dateFormat: "<?php echo DATE_FORMAT_JS; ?>"
|
||||
});
|
||||
});
|
||||
</script>
|
Loading…
Reference in New Issue