pandorafms/pandora_console/operation/events/events.php

2749 lines
78 KiB
PHP
Raw Normal View History

<?php
/**
2019-06-20 11:46:01 +02:00
* Event list.
*
* @category Events
* @package Pandora FMS
* @subpackage Community
* @version 1.0.0
* @license See below
*
* ______ ___ _______ _______ ________
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
*
* ============================================================================
2020-11-27 13:52:35 +01:00
* Copyright (c) 2005-2021 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 $config['homedir'].'/include/functions_events.php';
// Event processing functions.
require_once $config['homedir'].'/include/functions_alerts.php';
// Alerts processing functions.
require_once $config['homedir'].'/include/functions_agents.php';
// Agents functions.
require_once $config['homedir'].'/include/functions_users.php';
// Users functions.
require_once $config['homedir'].'/include/functions_graph.php';
require_once $config['homedir'].'/include/functions_ui.php';
2019-06-06 17:50:47 +02:00
// Check access.
check_login();
2021-05-24 17:35:15 +02:00
enterprise_include_once('/include/class/CommandCenter.class.php');
2019-06-20 19:23:13 +02:00
$event_a = check_acl($config['id_user'], 0, 'ER');
$event_w = check_acl($config['id_user'], 0, 'EW');
$event_m = check_acl($config['id_user'], 0, 'EM');
if (! $event_a
&& ! $event_w
&& ! $event_m
) {
db_pandora_audit(
2022-01-20 10:55:23 +01:00
AUDIT_LOG_ACL_VIOLATION,
'Trying to access event viewer'
);
2019-06-13 12:30:09 +02:00
if (is_ajax()) {
return ['error' => 'noaccess'];
}
include 'general/noaccess.php';
return;
}
2019-06-06 17:50:47 +02:00
$access = ($event_a == true) ? 'ER' : (($event_w == true) ? 'EW' : (($event_m == true) ? 'EM' : 'ER'));
2019-06-13 19:41:21 +02:00
$readonly = false;
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === false
2019-06-13 19:41:21 +02:00
&& isset($config['event_replication'])
&& $config['event_replication'] == 1
&& $config['show_events_in_local'] == 1
) {
$readonly = true;
}
2019-06-06 17:50:47 +02:00
// Load specific stylesheet.
ui_require_css_file('events');
2019-06-18 19:17:21 +02:00
ui_require_css_file('tables');
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === true) {
2019-06-19 08:43:37 +02:00
ui_require_css_file('tables_meta', ENTERPRISE_DIR.'/include/styles/');
}
2019-06-06 17:50:47 +02:00
2019-06-10 15:18:35 +02:00
// Load extra javascript.
ui_require_javascript_file('pandora_events');
2019-06-06 17:50:47 +02:00
// Get requests.
2019-06-20 14:18:49 +02:00
$default_filter = [
'status' => EVENT_NO_VALIDATED,
'event_view_hr' => $config['event_view_hr'],
'group_rep' => 1,
'tag_with' => [],
'tag_without' => [],
'history' => false,
];
$fb64 = get_parameter('fb64', null);
if (isset($fb64)) {
$filter = json_decode(base64_decode($fb64), true);
$filter['tag_with'] = [];
$filter['tag_without'] = [];
2019-06-20 14:18:49 +02:00
} else {
$filter = get_parameter(
'filter',
$default_filter
);
}
$id_group = get_parameter(
'filter[id_group]',
$filter['id_group']
);
$event_type = get_parameter(
'filter[event_type]',
$filter['event_type']
);
$severity = get_parameter(
'filter[severity]',
$filter['severity']
);
$status = get_parameter(
'filter[status]',
$filter['status']
);
$search = get_parameter(
'filter[search]',
$filter['search']
);
$text_agent = get_parameter(
'filter[text_agent]',
$filter['text_agent']
);
$id_agent = get_parameter(
'filter[id_agent]',
$filter['id_agent']
);
$text_module = get_parameter(
'filter[module_search]',
$filter['module_search']
);
2019-06-20 14:18:49 +02:00
$id_agent_module = get_parameter(
2020-12-09 18:15:01 +01:00
'id_agent_module',
get_parameter(
'filter[id_agent_module]',
$filter['id_agent_module']
)
2019-06-20 14:18:49 +02:00
);
$pagination = get_parameter(
'filter[pagination]',
$filter['pagination']
);
$event_view_hr = get_parameter(
'filter[event_view_hr]',
$filter['event_view_hr']
);
$id_user_ack = get_parameter(
'filter[id_user_ack]',
$filter['id_user_ack']
);
$group_rep = get_parameter(
'filter[group_rep]',
$filter['group_rep']
);
$tag_with = get_parameter(
'filter[tag_with]',
$filter['tag_with']
);
$tag_without = get_parameter(
'filter[tag_without]',
$filter['tag_without']
);
$filter_only_alert = get_parameter(
'filter[filter_only_alert]',
$filter['filter_only_alert']
);
$id_group_filter = get_parameter(
'filter[id_group_filter]',
$filter['id_group_filter']
);
$date_from = get_parameter(
'filter[date_from]',
$filter['date_from']
);
$date_to = get_parameter(
'filter[date_to]',
$filter['date_to']
);
$time_from = get_parameter(
'filter[time_from]',
$filter['time_from']
);
$time_to = get_parameter(
'filter[time_to]',
$filter['time_to']
);
2019-06-20 14:18:49 +02:00
$source = get_parameter(
'filter[source]',
$filter['source']
);
$id_extra = get_parameter(
'filter[id_extra]',
$filter['id_extra']
);
$user_comment = get_parameter(
'filter[user_comment]',
$filter['user_comment']
);
$history = get_parameter(
'history',
$filter['history']
);
2019-06-19 12:56:16 +02:00
$section = get_parameter('section', false);
2019-06-06 17:50:47 +02:00
2019-11-22 13:38:08 +01:00
$id_source_event = get_parameter(
'filter[id_source_event]',
2021-07-05 17:42:45 +02:00
($filter['id_source_event'] ?? '')
2019-11-22 13:38:08 +01:00
);
$server_id = get_parameter(
'filter[server_id]',
$filter['id_server_meta']
);
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === true) {
// Connect to node database.
$id_node = $server_id;
if ($id_node != 0) {
if (metaconsole_connect(null, $id_node) != NOERR) {
return false;
}
}
}
2021-07-05 17:42:45 +02:00
if (empty($text_agent) && empty($id_agent) === false) {
$text_agent = agents_get_alias($id_agent);
}
2021-07-05 17:42:45 +02:00
if (empty($text_module) && empty($id_agent_module) === false) {
$text_module = modules_get_agentmodule_name($id_agent_module);
$text_agent = agents_get_alias(modules_get_agentmodule_agent($id_agent_module));
}
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === true) {
// Return to metaconsole database.
if ($id_node != 0) {
metaconsole_restore_db();
}
}
2019-06-07 22:44:02 +02:00
// Ajax responses.
2021-07-05 17:42:45 +02:00
if (is_ajax() === true) {
2019-06-07 22:44:02 +02:00
$get_events = get_parameter('get_events', 0);
// Datatables offset, limit.
$start = get_parameter('start', 0);
$length = get_parameter('length', $config['block_size']);
if ($get_events) {
2019-06-17 18:33:39 +02:00
try {
ob_start();
2019-06-24 19:23:41 +02:00
2019-06-18 19:17:21 +02:00
$fields = [
'te.id_evento',
'te.id_agente',
'te.id_usuario',
'te.id_grupo',
'te.estado',
'te.timestamp',
'te.evento',
'te.utimestamp',
'te.event_type',
'te.id_alert_am',
'te.criticity',
'te.user_comment',
'te.tags',
'te.source',
'te.id_extra',
'te.critical_instructions',
'te.warning_instructions',
'te.unknown_instructions',
'te.owner_user',
'if(te.ack_utimestamp > 0, from_unixtime(te.ack_utimestamp),"") as ack_utimestamp',
'te.custom_data',
'te.data',
'te.module_status',
'ta.alias as agent_name',
'tg.nombre as group_name',
2021-07-07 16:07:08 +02:00
'ta.direccion',
2019-06-18 19:17:21 +02:00
];
2021-07-05 17:42:45 +02:00
$order = get_datatable_order(true);
if (is_array($order) === true && $order['field'] === 'mini_severity') {
$order['field'] = 'te.criticity';
}
// Find the order field and set the table and field name.
foreach ($fields as $field) {
if (str_contains($field, $order['field']) === true) {
$order['field'] = $field;
break;
}
}
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === false) {
2019-06-20 21:11:56 +02:00
$fields[] = 'am.nombre as module_name';
$fields[] = 'am.id_agente_modulo as id_agentmodule';
$fields[] = 'am.custom_id as module_custom_id';
2019-06-20 19:23:13 +02:00
$fields[] = 'ta.server_name as server_name';
} else {
$fields[] = 'ts.server_name as server_name';
2019-08-22 14:27:45 +02:00
$fields[] = 'te.id_agentmodule';
$fields[] = 'te.server_id';
2019-06-18 19:17:21 +02:00
}
2019-06-17 18:33:39 +02:00
$events = events_get_all(
2019-06-19 12:56:16 +02:00
// Fields.
2019-06-18 19:17:21 +02:00
$fields,
2019-06-19 12:56:16 +02:00
// Filter.
2019-06-17 18:33:39 +02:00
$filter,
// Offset.
$start,
// Limit.
$length,
// Order.
$order['direction'],
// Sort field.
2019-06-19 12:56:16 +02:00
$order['field'],
// History.
$history
2019-06-17 18:33:39 +02:00
);
$count = events_get_all(
'count',
$filter,
null,
null,
null,
null,
$history
2019-06-17 18:33:39 +02:00
);
2019-06-07 22:44:02 +02:00
2019-06-17 18:33:39 +02:00
if ($count !== false) {
$count = $count['0']['nitems'];
}
2019-06-07 22:44:02 +02:00
2019-06-17 18:33:39 +02:00
if ($events) {
$data = array_reduce(
$events,
function ($carry, $item) {
2020-03-13 14:03:50 +01:00
global $config;
2019-06-17 18:33:39 +02:00
$tmp = (object) $item;
$tmp->meta = is_metaconsole();
// phpcs:disable Squiz.NamingConventions.ValidVariableName.MemberNotCamelCaps
if ($tmp->meta === true) {
if ($tmp->server_name !== null) {
$tmp->data_server = metaconsole_get_servers($tmp->server_id);
$tmp->server_url_hash = metaconsole_get_servers_url_hash($tmp->data_server);
}
}
$tmp->evento = str_replace('"', '', io_safe_output($tmp->evento));
if (strlen($tmp->evento) >= 255) {
$tmp->evento = ui_print_truncate_text($tmp->evento, 255, $tmp->evento, true, false);
}
2019-06-20 21:11:56 +02:00
if ($tmp->module_name) {
$tmp->module_name = io_safe_output($tmp->module_name);
}
2019-10-01 16:24:02 +02:00
if ($tmp->comments) {
$tmp->comments = ui_print_comments($tmp->comments);
}
// Show last event.
if (isset($tmp->max_id_evento) && $tmp->max_id_evento !== $tmp->id_evento) {
$max_event = db_get_row_sql(
sprintf(
'SELECT criticity, timestamp FROM %s
WHERE id_evento = %s',
($tmp->meta === true) ? 'tmetaconsole_event' : 'tevento',
$tmp->max_id_evento
)
);
$tmp->timestamp = $max_event['timestamp'];
$tmp->criticity = $max_event['criticity'];
}
2019-06-20 21:11:56 +02:00
$tmp->agent_name = io_safe_output($tmp->agent_name);
2021-02-04 14:54:11 +01:00
$tmp->ack_utimestamp_raw = strtotime($tmp->ack_utimestamp);
2019-06-18 17:40:31 +02:00
$tmp->ack_utimestamp = ui_print_timestamp(
$tmp->ack_utimestamp,
true
);
$tmp->timestamp = ui_print_timestamp(
$tmp->timestamp,
true
);
if (is_numeric($tmp->data) === true) {
$tmp->data = format_numeric(
$tmp->data,
$config['graph_precision']
);
2021-06-08 16:48:01 +02:00
} else {
$tmp->data = ui_print_truncate_text($tmp->data, 10);
}
$tmp->instructions = events_get_instructions($item);
$tmp->b64 = base64_encode(json_encode($tmp));
2019-06-17 18:33:39 +02:00
$carry[] = $tmp;
return $carry;
}
);
}
// RecordsTotal && recordsfiltered resultados totales.
echo json_encode(
[
'data' => $data,
'recordsTotal' => $count,
'recordsFiltered' => $count,
]
);
$response = ob_get_clean();
// Clean output buffer.
while (ob_get_level() !== 0) {
ob_end_clean();
}
2019-06-17 18:33:39 +02:00
} catch (Exception $e) {
echo json_encode(
['error' => $e->getMessage()]
2019-06-07 22:44:02 +02:00
);
}
2019-06-17 18:33:39 +02:00
// If not valid it will throw an exception.
json_decode($response);
if (json_last_error() == JSON_ERROR_NONE) {
// If valid dump.
echo $response;
} else {
echo json_encode(
['error' => $response]
);
}
2019-06-07 22:44:02 +02:00
}
// AJAX section ends.
exit;
}
2019-07-09 17:54:23 +02:00
/*
* Load user default form.
*/
2021-04-21 13:05:18 +02:00
$load_filter_id = (int) get_parameter('filter_id', 0);
if ($load_filter_id === 0) {
// Load user filter.
$loaded_filter = db_get_row_sql(
sprintf(
'SELECT f.id_filter, f.id_name
FROM tevent_filter f
INNER JOIN tusuario u
ON u.default_event_filter=f.id_filter
WHERE u.id_user = "%s" ',
$config['id_user']
)
);
} else {
// Load filter selected by user.
$loaded_filter['id_filter'] = $load_filter_id;
$loaded_filter['id_name'] = db_get_value(
'id_name',
'tevent_filter',
'id_filter',
$load_filter_id
);
}
2020-10-29 15:06:01 +01:00
// Do not load the user filter if we come from the 24h event graph.
$from_event_graph = get_parameter('filter[from_event_graph]', $filter['from_event_graph']);
2021-11-19 11:38:11 +01:00
if ($loaded_filter !== false && $from_event_graph != 1 && !isset($fb64)) {
2021-04-21 13:05:18 +02:00
$filter = events_get_event_filter($loaded_filter['id_filter']);
2019-07-09 17:54:23 +02:00
if ($filter !== false) {
$id_group = $filter['id_group'];
$event_type = $filter['event_type'];
$severity = $filter['severity'];
$status = $filter['status'];
$search = $filter['search'];
$text_agent = $filter['text_agent'];
$id_agent = $filter['id_agent'];
$id_agent_module = $filter['id_agent_module'];
2020-10-29 15:06:01 +01:00
$text_module = io_safe_output(
db_get_value_filter(
'nombre',
'tagente_modulo',
['id_agente_modulo' => $filter['id_agent_module']]
)
);
2019-07-09 17:54:23 +02:00
$pagination = $filter['pagination'];
$event_view_hr = $filter['event_view_hr'];
$id_user_ack = $filter['id_user_ack'];
$group_rep = $filter['group_rep'];
$tag_with = json_decode(io_safe_output($filter['tag_with']));
$tag_without = json_decode(io_safe_output($filter['tag_without']));
$tag_with_base64 = base64_encode(json_encode($tag_with));
$tag_without_base64 = base64_encode(json_encode($tag_without));
$filter_only_alert = $filter['filter_only_alert'];
$id_group_filter = $filter['id_group_filter'];
$date_from = $filter['date_from'];
2021-07-05 17:42:45 +02:00
$time_from = $filter['time_from'];
2019-07-09 17:54:23 +02:00
$date_to = $filter['date_to'];
2021-07-05 17:42:45 +02:00
$time_to = $filter['time_to'];
2019-07-09 17:54:23 +02:00
$source = $filter['source'];
$id_extra = $filter['id_extra'];
$user_comment = $filter['user_comment'];
2021-07-05 17:42:45 +02:00
$id_source_event = ($filter['id_source_event'] ?? '');
$server_id = $filter['server_id'];
2019-07-09 17:54:23 +02:00
}
}
2019-06-07 17:35:13 +02:00
// TAGS.
2019-06-07 21:22:07 +02:00
// Get the tags where the user have permissions in Events reading tasks.
$tags = tags_get_user_tags($config['id_user'], $access);
2019-06-07 17:35:13 +02:00
$tags_select_with = [];
$tags_select_without = [];
$tag_with_temp = [];
$tag_without_temp = [];
2020-09-18 11:47:50 +02:00
if (is_array($tag_with) === false) {
$tag_with = json_decode(base64_decode($tag_with), true);
}
if (is_array($tag_without) === false) {
$tag_without = json_decode(base64_decode($tag_without), true);
}
foreach ((array) $tags as $id_tag => $tag) {
2020-09-07 14:38:43 +02:00
if (is_array($tag_with) === true
&& ((array_search($id_tag, $tag_with) === false) || (array_search($id_tag, $tag_with) === null))
2019-06-07 17:35:13 +02:00
) {
$tags_select_with[$id_tag] = ui_print_truncate_text($tag, 50, true);
} else {
$tag_with_temp[$id_tag] = ui_print_truncate_text($tag, 50, true);
}
2020-09-07 14:38:43 +02:00
if (is_array($tag_without) === true
&& ((array_search($id_tag, $tag_without) === false) || (array_search($id_tag, $tag_without) === null))
2019-06-07 17:35:13 +02:00
) {
$tags_select_without[$id_tag] = ui_print_truncate_text($tag, 50, true);
} else {
$tag_without_temp[$id_tag] = ui_print_truncate_text($tag, 50, true);
}
}
$add_with_tag_disabled = empty($tags_select_with);
$remove_with_tag_disabled = empty($tag_with_temp);
$add_without_tag_disabled = empty($tags_select_without);
$remove_without_tag_disabled = empty($tag_without_temp);
$tabletags_with = html_get_predefined_table('transparent', 2);
$tabletags_with->id = 'filter_events_tags_with';
$tabletags_with->width = '100%';
$tabletags_with->cellspacing = 4;
$tabletags_with->cellpadding = 4;
$tabletags_with->class = 'noshadow';
$tabletags_with->styleTable = 'border: 0px;';
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === true) {
2019-06-07 17:35:13 +02:00
$tabletags_with->class = 'nobady';
$tabletags_with->cellspacing = 0;
$tabletags_with->cellpadding = 0;
}
$data = [];
$data[0] = html_print_select(
$tags_select_with,
'select_with',
'',
'',
'',
0,
true,
true,
true,
'',
false,
'width: 200px;'
);
$data[1] = html_print_image(
'images/darrowright.png',
true,
[
'id' => 'button-add_with',
'style' => 'cursor: pointer;',
'title' => __('Add'),
'class' => 'invert_filter',
2019-06-07 17:35:13 +02:00
]
);
$data[1] .= html_print_input_hidden(
'tag_with',
$tag_with_base64,
true
);
$data[1] .= '<br><br>'.html_print_image(
'images/darrowleft.png',
true,
[
'id' => 'button-remove_with',
'style' => 'cursor: pointer;',
'title' => __('Remove'),
'class' => 'invert_filter',
2019-06-07 17:35:13 +02:00
]
);
$data[2] = html_print_select(
$tag_with_temp,
'tag_with_temp',
[],
'',
'',
0,
true,
true,
true,
'',
false,
'width: 200px;'
);
$tabletags_with->data[] = $data;
$tabletags_with->rowclass[] = '';
$tabletags_without = html_get_predefined_table('transparent', 2);
$tabletags_without->id = 'filter_events_tags_without';
$tabletags_without->width = '100%';
$tabletags_without->cellspacing = 4;
$tabletags_without->cellpadding = 4;
$tabletags_without->class = 'noshadow';
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === true) {
2019-06-07 17:35:13 +02:00
$tabletags_without->class = 'nobady';
$tabletags_without->cellspacing = 0;
$tabletags_without->cellpadding = 0;
}
$tabletags_without->styleTable = 'border: 0px;';
$data = [];
$data[0] = html_print_select(
$tags_select_without,
'select_without',
'',
'',
'',
0,
true,
true,
true,
'',
false,
'width: 200px;'
);
$data[1] = html_print_image(
'images/darrowright.png',
true,
[
'id' => 'button-add_without',
'style' => 'cursor: pointer;',
'title' => __('Add'),
'class' => 'invert_filter',
2019-06-07 17:35:13 +02:00
]
);
$data[1] .= html_print_input_hidden(
'tag_without',
$tag_without_base64,
true
);
$data[1] .= '<br><br>'.html_print_image(
'images/darrowleft.png',
true,
[
'id' => 'button-remove_without',
'style' => 'cursor: pointer;',
'title' => __('Remove'),
'class' => 'invert_filter',
2019-06-07 17:35:13 +02:00
]
);
$data[2] = html_print_select(
$tag_without_temp,
'tag_without_temp',
[],
'',
'',
0,
true,
true,
true,
'',
false,
'width: 200px;'
);
$tabletags_without->data[] = $data;
$tabletags_without->rowclass[] = '';
2019-06-06 17:50:47 +02:00
if (io_safe_output($tag_with) == '["0"]') {
$tag_with = '[]';
}
2019-06-06 17:50:47 +02:00
if (io_safe_output($tag_without) == '["0"]') {
$tag_without = '[]';
}
2019-06-07 21:22:07 +02:00
/*
* END OF TAGS.
*/
2019-06-06 17:50:47 +02:00
// View.
$pure = get_parameter('pure', 0);
$url = ui_get_full_url('index.php?sec=eventos&sec2=operation/events/events');
2019-06-06 17:50:47 +02:00
// Concatenate parameters.
$url .= '';
2019-06-18 19:17:21 +02:00
if ($pure) {
2019-06-06 17:50:47 +02:00
// Fullscreen.
// Floating menu - Start.
echo '<div id="vc-controls" class="zindex999"">';
2019-06-06 17:50:47 +02:00
echo '<div id="menu_tab">';
echo '<ul class="mn">';
2019-06-06 17:50:47 +02:00
// Quit fullscreen.
echo '<li class="nomn">';
echo '<a target="_top" href="'.$url.'&amp;pure=0">';
echo html_print_image(
'images/normal_screen.png',
true,
[
'title' => __('Back to normal mode'),
'class' => 'invert_filter',
]
);
2019-06-06 17:50:47 +02:00
echo '</a>';
echo '</li>';
2019-06-06 17:50:47 +02:00
// Countdown.
echo '<li class="nomn">';
echo '<div class="events-refr">';
echo '<div class="events-countdown"><span id="refrcounter"></span></div>';
echo '<div id="events-refr-form">';
2019-06-06 17:50:47 +02:00
echo __('Refresh').':';
echo html_print_select(
get_refresh_time_array(),
'refresh',
$refr,
'',
'',
0,
true,
false,
false
);
2019-06-06 17:50:47 +02:00
echo '</div>';
echo '</div>';
echo '</li>';
2019-06-06 17:50:47 +02:00
// Console name.
echo '<li class="nomn">';
echo '<div class="vc-title">'.__('Event viewer').'</div>';
echo '</li>';
2019-06-06 17:50:47 +02:00
echo '</ul>';
echo '</div>';
2019-06-06 17:50:47 +02:00
echo '</div>';
// Floating menu - End.
ui_require_jquery_file('countdown');
} else {
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === true) {
2019-06-18 19:17:21 +02:00
// Load metaconsole frame.
enterprise_hook('open_meta_frame');
}
2019-06-06 17:50:47 +02:00
// Header.
$pss = get_user_info($config['id_user']);
$hashup = md5($config['id_user'].$pss['password']);
// Fullscreen.
$fullscreen['active'] = false;
$fullscreen['text'] = '<a class="events_link" href="'.$url.'&amp;pure=1&">'.html_print_image(
'images/full_screen.png',
true,
[
'title' => __('Full screen'),
'class' => 'invert_filter',
]
).'</a>';
// Event list.
$list['active'] = false;
$list['text'] = '<a class="events_link" href="index.php?sec=eventos&sec2=operation/events/events&amp;pure='.$config['pure'].'&">'.html_print_image(
'images/events_list.png',
true,
[
'title' => __('Event list'),
'class' => 'invert_filter',
]
).'</a>';
// History event list.
$history_list['active'] = false;
$history_list['text'] = '<a class="events_link" href="index.php?sec=eventos&sec2=operation/events/events&amp;pure='.$config['pure'].'&amp;section=history&amp;history=1&">'.html_print_image(
'images/books.png',
true,
[
'title' => __('History event list'),
'class' => 'invert_filter',
]
).'</a>';
// RSS.
$rss['active'] = false;
$rss['text'] = '<a class="events_link" href="operation/events/events_rss.php?user='.$config['id_user'].'&hashup='.$hashup.'&">'.html_print_image(
'images/rss.png',
true,
[
'title' => __('RSS Events'),
'class' => 'invert_filter',
]
).'</a>';
// CSV.
$csv['active'] = false;
$csv['text'] = '<a class="events_link" href="'.ui_get_full_url(false, false, false, false).'operation/events/export_csv.php?'.$filter_b64.'">'.html_print_image(
'images/csv.png',
true,
[
'title' => __('Export to CSV file'),
'class' => 'invert_filter',
]
).'</a>';
// Sound events.
$sound_event['active'] = false;
$sound_event['text'] = '<a href="javascript: openSoundEventWindow();">'.html_print_image(
'images/sound.png',
true,
[
'title' => __('Sound events'),
'class' => 'invert_filter',
]
).'</a>';
// If the user has administrator permission display manage tab.
2019-06-20 19:23:13 +02:00
if ($event_w || $event_m) {
// Manage events.
$manage_events['active'] = false;
$manage_events['text'] = '<a href="index.php?sec=eventos&sec2=godmode/events/events&amp;section=filter&amp;pure='.$config['pure'].'">'.html_print_image(
'images/setup.png',
true,
[
'title' => __('Manage events'),
'class' => 'invert_filter',
]
).'</a>';
$manage_events['godmode'] = true;
$onheader = [
'manage_events' => $manage_events,
'fullscreen' => $fullscreen,
'list' => $list,
'history' => $history_list,
'rss' => $rss,
'csv' => $csv,
'sound_event' => $sound_event,
];
} else {
$onheader = [
'fullscreen' => $fullscreen,
'list' => $list,
'history' => $history_list,
'rss' => $rss,
'csv' => $csv,
'sound_event' => $sound_event,
];
}
2019-06-06 17:50:47 +02:00
// If the history event is not enabled, dont show the history tab.
2021-07-05 17:42:45 +02:00
if (isset($config['metaconsole_events_history']) === false || $config['metaconsole_events_history'] != 1) {
unset($onheader['history']);
}
switch ($section) {
case 'sound_event':
$onheader['sound_event']['active'] = true;
$section_string = __('Sound events');
break;
case 'history':
$onheader['history']['active'] = true;
$section_string = __('History');
break;
default:
$onheader['list']['active'] = true;
$section_string = __('List');
break;
}
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === false) {
unset($onheader['history']);
ui_print_page_header(
__('Events'),
'images/lightning_go.png',
false,
'eventview',
false,
$onheader,
true,
'eventsmodal'
);
} else {
unset($onheader['rss']);
unset($onheader['sound_event']);
unset($onheader['fullscreen']);
ui_meta_print_header(__('Events'), $section_string, $onheader);
}
?>
<script type="text/javascript">
function openSoundEventWindow() {
url = "<?php echo ui_get_full_url('operation/events/sound_events.php'); ?>";
window.open(
url,
'<?php __('Sound Alerts'); ?>',
'width=600, height=450, toolbar=no, location=no, directories=no, status=no, menubar=no, resizable=no'
);
}
</script>
<?php
2008-07-25 Sancho Lerena <slerena@gmail.com> * pandoradb.sql: Added new tables for planned downtimes. * godmode/menu.php: Added entry for manage downtimes. * group_list.php: Stetic changes in table. * modificar_server.php: Fixed timestamp render for start/update timestamp of each server. * functions.php: Minimal estetic changes in help function. * functions_db.php: Change header (Flexible <- Free) * functions_html.php: Now select admits multiselect option. Default class for table render is now databox not databox_color. * AUTHORS: Update list of authors and make a reference to contributors. * function_reporting.php: Header change, updated datetime string format. * language_en.php, language_es_es.php: Changed FREE for Flexible. * pandora.css: Minimal changes. Update color of Monitor count in tactical. * menu.php: Added some new event options: CSV Export, RSS and new marquee event visualizer. * estado_ultimopaquete.php: Header update. * tactical.php: Added link to data module alerts. * ver_agente.php: Fixed a problem in ajax code that was rending bad count of down monitors. Using boolean comparation on result of function get_db_sql(). This kind problem could be in more lines of code. * events.php: New quicklinks to RSS, CSV and Marquee in event viewer. * export_csv.php, events_rss.php: Fixed duped call to function includes. * graph_viewer.php: I hope this fix FINALLY the annoying bug of graph type selector. * visual_console/index.php: Updated header. git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@973 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2008-07-25 20:37:32 +02:00
}
2021-05-28 14:32:41 +02:00
if (enterprise_installed() === true) {
if (isset($config['merge_process_events']) === true
&& empty($config['merge_process_events']) === false
) {
ui_require_css_file('command_center', ENTERPRISE_DIR.'/include/styles/');
ui_require_javascript_file(
'pandora_command_center',
ENTERPRISE_DIR.'/include/javascript/'
);
2021-07-07 16:11:20 +02:00
$commandCenter = 'CommandCenterController';
if (class_exists($commandCenter) === true) {
$events_merge_state = $commandCenter::displayEventsProgress();
if (empty($events_merge_state) === false) {
echo '<div class="view_events_merge_process_events">';
echo $events_merge_state;
echo '</div>';
}
}
2021-05-28 14:32:41 +02:00
$tittle_error = __('Errors');
echo '<div id="dialog-error-node-'.$config['metaconsole_node_id'].'" title="'.$tittle_error.'"></div>';
}
2021-05-24 17:35:15 +02:00
}
// Error div for ajax messages.
2021-07-05 17:42:45 +02:00
html_print_div(
[
'id' => 'show_message_error',
'content' => '',
]
);
2019-06-06 17:50:47 +02:00
// Controls.
if (is_metaconsole() !== true) {
2021-07-05 17:42:45 +02:00
if (isset($config['event_replication']) === true
2019-06-06 17:50:47 +02:00
&& $config['event_replication'] == 1
) {
if ($config['show_events_in_local'] == 0) {
db_pandora_audit(
2022-01-20 10:55:23 +01:00
AUDIT_LOG_ACL_VIOLATION,
2019-06-06 17:50:47 +02:00
'Trying to access event viewer. View disabled due event replication.'
);
2019-06-06 17:50:47 +02:00
ui_print_info_message(
[
'message' => __(
'Event viewer is disabled due event replication. For more information, please contact with the administrator'
),
'no_close' => true,
]
);
2019-06-06 17:50:47 +02:00
return;
} else {
$readonly = true;
}
}
}
2021-08-13 15:57:01 +02:00
if (enterprise_hook(
'enterprise_acl',
[
$config['id_user'],
'eventos',
'execute_event_responses',
]
) === false
) {
$readonly = true;
}
2019-06-07 17:35:13 +02:00
/*
* Load filter form.
*/
2019-06-06 17:50:47 +02:00
// Group.
if ($id_group_filter === null) {
$id_group_filter = 0;
}
2020-09-11 14:34:41 +02:00
$data = html_print_input(
[
'name' => 'id_group_filter',
2020-09-11 15:30:18 +02:00
'returnAllGroup' => true,
2020-09-11 14:34:41 +02:00
'privilege' => 'AR',
'type' => 'select_groups',
'selected' => $id_group_filter,
2020-09-11 15:30:18 +02:00
'nothing' => false,
2020-09-11 14:34:41 +02:00
'return' => true,
'size' => '80%',
]
2019-06-06 17:50:47 +02:00
);
$in = '<div class="filter_input"><label>'.__('Group').'</label>';
$in .= $data.'</div>';
$inputs[] = $in;
// Event type.
$types = get_event_types();
$types['not_normal'] = __('Not normal');
$data = html_print_select(
$types,
'event_type',
$event_type,
'',
__('All'),
'',
true
);
$in = '<div class="filter_input"><label>'.__('Event type').'</label>';
$in .= $data.'</div>';
$inputs[] = $in;
// Event status.
$data = html_print_select(
events_get_all_status(),
'status',
$status,
'',
'',
'',
true
);
$in = '<div class="filter_input"><label>'.__('Event status').'</label>';
$in .= $data.'</div>';
$inputs[] = $in;
2019-06-06 17:50:47 +02:00
// Max hours old.
$data = html_print_input_text(
'event_view_hr',
$event_view_hr,
'',
5,
255,
true
);
$in = '<div class="filter_input"><label>'.__('Max. hours old').'</label>';
$in .= $data.'</div>';
$inputs[] = $in;
// Duplicates group { events | agents }.
$data = html_print_select(
[
2019-06-07 21:22:07 +02:00
0 => __('All events'),
1 => __('Group events'),
2 => __('Group agents'),
2019-06-06 17:50:47 +02:00
],
'group_rep',
$group_rep,
'',
'',
0,
true
);
$in = '<div class="filter_input"><label>'.__('Repeated').'</label>';
$in .= $data.'</div>';
$inputs[] = $in;
2019-06-18 17:40:31 +02:00
// Free search.
$data = html_print_input_text('search', $search, '', '', 255, true);
$in = '<div class="filter_input"><label>'.__('Free search').'</label>';
2019-06-06 17:50:47 +02:00
$in .= $data.'</div>';
$inputs[] = $in;
2021-07-05 17:42:45 +02:00
if (empty($severity) === true && $severity !== '0') {
$severity = -1;
}
// Criticity - severity.
$data = html_print_select(
get_priorities(),
'severity',
2021-04-21 13:05:18 +02:00
explode(',', $severity),
'',
__('All'),
-1,
true,
true,
true,
'',
false
);
$in = '<div class="filter_input"><label>'.__('Severity').'</label>';
$in .= $data.'</div>';
$inputs[] = $in;
2019-06-11 12:58:18 +02:00
$buttons = [];
$buttons[] = [
'id' => 'load-filter',
'class' => 'float-left margin-right-2 sub config',
'text' => __('Load filter'),
'onclick' => '',
];
2019-06-20 19:23:13 +02:00
if ($event_w || $event_m) {
$buttons[] = [
'id' => 'save-filter',
'class' => 'float-left margin-right-2 sub wand',
'text' => __('Save filter'),
'onclick' => '',
];
}
2019-06-06 17:50:47 +02:00
2019-06-07 17:35:13 +02:00
/*
* Advanced filter.
*/
$adv_inputs = [];
2019-06-18 17:40:31 +02:00
// Source.
$data = html_print_input_text('source', $source, '', '', 255, true);
$in = '<div class="filter_input"><label>'.__('Source').'</label>';
$in .= $data.'</div>';
$adv_inputs[] = $in;
// Extra ID.
$data = html_print_input_text('id_extra', $id_extra, '', 11, 255, true);
$in = '<div class="filter_input"><label>'.__('Extra ID').'</label>';
$in .= $data.'</div>';
$adv_inputs[] = $in;
// Comment.
$data = html_print_input_text(
'user_comment',
$user_comment,
'',
'',
255,
true
);
$in = '<div class="filter_input"><label>'.__('Comment').'</label>';
2019-06-07 17:35:13 +02:00
$in .= $data.'</div>';
$adv_inputs[] = $in;
// Agent search.
$params = [];
$params['show_helptip'] = true;
$params['input_name'] = 'text_agent';
$params['value'] = $text_agent;
$params['return'] = true;
if ($meta) {
$params['javascript_page'] = 'enterprise/meta/include/ajax/events.ajax';
}
$params['print_hidden_input_idagent'] = true;
$params['hidden_input_idagent_name'] = 'id_agent';
$params['hidden_input_idagent_value'] = $id_agent;
$params['size'] = '';
2021-04-21 13:05:18 +02:00
if ($id_agent !== null) {
if (is_metaconsole()) {
$metaconsole_agent = db_get_row_sql(
sprintf(
'SELECT alias, server_name
FROM tmetaconsole_agent
WHERE id_tagente = "%d" ',
$id_agent
)
);
$params['value'] = $metaconsole_agent['alias'].' ('.$metaconsole_agent['server_name'].')';
} else {
$params['value'] = agents_get_alias($id_agent);
}
}
2019-06-07 17:35:13 +02:00
$data = ui_print_agent_autocomplete_input($params);
$in = '<div class="filter_input"><label>'.__('Agent search').'</label>';
$in .= $data.'</div>';
$adv_inputs[] = $in;
// Mixed. Metaconsole => server, Console => module.
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === true) {
2019-06-07 17:35:13 +02:00
$title = __('Server');
$data = html_print_select_from_sql(
'SELECT id, server_name FROM tmetaconsole_setup',
'server_id',
$server_id,
2019-08-27 15:46:22 +02:00
'',
2019-06-07 17:35:13 +02:00
__('All'),
'0',
true
);
} else {
$title = __('Module search');
$data = html_print_autocomplete_modules(
'module_search',
$text_module,
false,
true,
'',
[],
true,
$id_agent_module,
''
);
}
$in = '<div class="filter_input"><label>'.$title.'</label>';
$in .= $data.'</div>';
$adv_inputs[] = $in;
// User ack.
$user_users = users_get_user_users(
$config['id_user'],
$access,
true
2019-06-07 17:35:13 +02:00
);
$data = html_print_select(
$user_users,
'id_user_ack',
$id_user_ack,
'',
__('Any'),
0,
true
);
$in = '<div class="filter_input"><label>'.__('User ack.').'</label>';
$in .= $data.'</div>';
$adv_inputs[] = $in;
// Only alert events.
$data = html_print_select(
[
'0' => __('Filter alert events'),
'1' => __('Only alert events'),
2019-06-07 17:35:13 +02:00
],
'filter_only_alert',
$filter_only_alert,
'',
__('All'),
-1,
2019-06-07 17:35:13 +02:00
true
);
2021-07-05 17:42:45 +02:00
$adv_inputs[] = html_print_div(
[
'class' => 'filter_input',
'content' => sprintf(
'<label>%s</label>%s',
__('Alert events'),
$data
),
],
true
);
2021-04-21 13:05:18 +02:00
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === true) {
2019-11-22 13:38:08 +01:00
$data = html_print_input_text(
'id_source_event',
$id_source_event,
'',
5,
255,
true
);
2021-07-05 17:42:45 +02:00
$adv_inputs[] = html_print_div(
[
'class' => 'filter_input',
'content' => sprintf(
'<label>%s</label>%s',
__('Id source event'),
$data
),
],
true
);
2021-04-21 13:05:18 +02:00
}
2019-06-07 17:35:13 +02:00
// Date from.
2021-07-05 17:42:45 +02:00
$inputDateFrom = html_print_input_text(
2019-06-07 17:35:13 +02:00
'date_from',
2021-07-05 17:42:45 +02:00
($date_from === '0000-00-00') ? '' : $date_from,
2019-06-07 17:35:13 +02:00
'',
false,
10,
true,
// Disabled.
false,
// Required.
false,
// Function.
'',
// Class.
'',
// OnChange.
'',
// Autocomplete.
'off'
);
2021-07-05 17:42:45 +02:00
// Time from.
$inputTimeFrom = html_print_input_text(
'time_from',
$time_from,
'',
false,
10,
true,
// Disabled.
false,
// Required.
false,
// Function.
'',
// Class.
'',
// OnChange.
'',
// Autocomplete.
'off'
);
2019-06-07 17:35:13 +02:00
2021-07-05 17:42:45 +02:00
// Date and Time From.
$adv_inputs[] = html_print_div(
[
'class' => 'filter_input',
'content' => sprintf(
'<label>%s</label>%s<span>:</span>%s',
__('From (date:time)'),
$inputDateFrom,
$inputTimeFrom
),
],
true
);
// Time to.
$inputTimeTo = html_print_input_text(
'time_to',
$time_to,
'',
false,
10,
true,
// Disabled.
false,
// Required.
false,
// Function.
'',
// Class.
'',
// OnChange.
'',
// Autocomplete.
'off'
);
2021-04-21 13:05:18 +02:00
2019-06-07 17:35:13 +02:00
// Date to.
2021-07-05 17:42:45 +02:00
$inputDateTo = html_print_input_text(
2019-06-07 17:35:13 +02:00
'date_to',
2021-07-05 17:42:45 +02:00
($date_to === '0000-00-00') ? '' : $date_to,
2019-06-07 17:35:13 +02:00
'',
false,
10,
true,
// Disabled.
false,
// Required.
false,
// Function.
'',
// Class.
'',
// OnChange.
'',
// Autocomplete.
'off'
);
2021-07-05 17:42:45 +02:00
// Date and Time To.
$adv_inputs[] = html_print_div(
[
'class' => 'filter_input',
'content' => sprintf(
'<label>%s</label>%s<span>:</span>%s',
__('To (date:time)'),
$inputDateTo,
$inputTimeTo
),
],
true
);
2019-06-07 17:35:13 +02:00
// Tags.
2021-07-05 17:42:45 +02:00
if (is_metaconsole() === true) {
$data = '<fieldset><legend class="pdd_0px">'.__('Events with following tags').'</legend>'.html_print_table($tabletags_with, true).'</fieldset>';
$data .= '<fieldset><legend class="pdd_0px">'.__('Events without following tags').'</legend>'.html_print_table($tabletags_without, true).'</fieldset>';
2019-06-07 17:35:13 +02:00
} else {
$data = '<fieldset><legend>'.__('Events with following tags').'</legend>'.html_print_table($tabletags_with, true).'</fieldset>';
$data .= '<fieldset><legend>'.__('Events without following tags').'</legend>'.html_print_table($tabletags_without, true).'</fieldset>';
}
$in = '<div class="filter_input large">';
$in .= $data.'</div>';
$adv_inputs[] = $in;
2019-06-06 17:50:47 +02:00
// Load view.
2019-06-07 17:35:13 +02:00
$adv_filter = join('', $adv_inputs);
2019-06-06 17:50:47 +02:00
$filter = join('', $inputs);
$filter .= ui_toggle(
$adv_filter,
__('Advanced options'),
'',
'',
true,
true,
'white_box white_box_opened',
2019-06-07 17:35:13 +02:00
'no-border flex-row'
2019-06-06 17:50:47 +02:00
);
2019-06-06 17:50:47 +02:00
try {
2019-06-18 10:32:04 +02:00
$checkbox_all = html_print_checkbox(
'all_validate_box',
1,
false,
true
);
2019-06-10 15:18:35 +02:00
$default_fields = [
2019-06-18 17:40:31 +02:00
[
'text' => 'evento',
'class' => 'mw120px',
],
2019-06-24 19:23:41 +02:00
[
'text' => 'mini_severity',
'class' => 'no-padding',
],
2019-06-07 17:35:13 +02:00
'id_evento',
// 'id_agente',
// 'id_usuario',
// 'id_grupo',
// 'estado',
'agent_name',
'timestamp',
// 'utimestamp',
// 'event_type',
// 'id_agentmodule',
// 'id_alert_am',
'event_type',
// 'user_comment',
// 'tags',
// 'source',
// 'id_extra',
// 'critical_instructions',
// 'warning_instructions',
// 'unknown_instructions',
// 'owner_user',
// 'ack_utimestamp',
// 'custom_data',
// 'data',
// 'module_status',
// 'similar_ids',
// 'event_rep',
// 'timestamp_rep',
// 'timestamp_rep_min',
// 'module_name',
2019-06-12 18:19:39 +02:00
[
'text' => 'options',
2019-06-13 19:41:21 +02:00
'class' => 'action_buttons w120px',
],
[
2019-06-13 19:41:21 +02:00
'text' => 'm',
2019-06-18 10:32:04 +02:00
'extra' => $checkbox_all,
2019-06-18 17:40:31 +02:00
'class' => 'mw120px',
2019-06-12 18:19:39 +02:00
],
2019-06-07 17:35:13 +02:00
];
2019-06-10 15:18:35 +02:00
$fields = explode(',', $config['event_fields']);
// Always check something is shown.
if (empty($fields)) {
$fields = $default_fields;
}
2019-06-24 19:23:41 +02:00
if (in_array('mini_severity', $fields) > 0) {
$fields[array_search('mini_severity', $fields)] = [
'text' => 'mini_severity',
'class' => 'no-padding-imp',
];
}
2019-06-18 17:40:31 +02:00
// Identifies column instructions to make it unsortable.
if (in_array('instructions', $fields) > 0) {
$fields[array_search('instructions', $fields)] = [
'text' => 'instructions',
'class' => 'column-instructions',
];
}
2019-06-18 17:40:31 +02:00
$evento_id = array_search('evento', $fields);
if ($evento_id !== false) {
$fields[$evento_id] = [
'text' => 'evento',
'class' => 'mw250px',
];
}
2019-06-10 15:18:35 +02:00
// Always add options column.
2019-06-12 18:19:39 +02:00
$fields = array_merge(
$fields,
2019-06-13 19:41:21 +02:00
[
[
'text' => 'options',
2019-06-18 17:40:31 +02:00
'class' => 'action_buttons mw120px',
],
[
2019-06-13 19:41:21 +02:00
'text' => 'm',
2019-06-18 10:32:04 +02:00
'extra' => $checkbox_all,
2019-06-13 19:41:21 +02:00
'class' => 'w20px no-text-imp',
],
2019-06-12 18:19:39 +02:00
]
);
2019-06-10 15:18:35 +02:00
// Get column names.
$column_names = events_get_column_names($fields, true);
2019-06-10 15:18:35 +02:00
2019-08-05 16:23:37 +02:00
foreach ($column_names as $key => $column) {
if (is_array($column) && $column['text'] == 'S') {
$column_names[$key]['style'] = 'padding-left: 1em !important;';
}
}
2019-08-02 10:04:10 +02:00
2019-06-10 15:18:35 +02:00
// Open current filter quick reference.
$active_filters_div = '<div class="filter_summary">';
2019-06-17 17:02:33 +02:00
// Current filter.
$active_filters_div .= '<div>';
$active_filters_div .= '<div class="label box-shadow">'.__('Current filter').'</div>';
$active_filters_div .= '<div id="current_filter" class="content">';
2021-04-21 13:05:18 +02:00
if ($loaded_filter !== false) {
2021-06-04 13:36:32 +02:00
$active_filters_div .= htmlentities(io_safe_output($loaded_filter['id_name']));
2019-06-17 17:02:33 +02:00
} else {
$active_filters_div .= __('Not set.');
}
$active_filters_div .= '</div>';
$active_filters_div .= '</div>';
2019-06-10 15:18:35 +02:00
// Event status.
$active_filters_div .= '<div>';
$active_filters_div .= '<div class="label box-shadow">'.__('Event status').'</div>';
$active_filters_div .= '<div id="summary_status" class="content">';
switch ($status) {
case EVENT_ALL:
default:
$active_filters_div .= __('Any status.');
break;
case EVENT_NEW:
$active_filters_div .= __('New events.');
break;
case EVENT_VALIDATE:
$active_filters_div .= __('Validated.');
break;
case EVENT_PROCESS:
$active_filters_div .= __('In proccess.');
break;
case EVENT_NO_VALIDATED:
$active_filters_div .= __('Not validated.');
break;
}
$active_filters_div .= '</div>';
$active_filters_div .= '</div>';
// Max. hours old.
$active_filters_div .= '<div>';
$active_filters_div .= '<div class="label box-shadow">'.__('Max. hours old').'</div>';
$active_filters_div .= '<div id="summary_hours" class="content">';
if ($event_view_hr == 0) {
$active_filters_div .= __('Any time.');
} else if ($event_view_hr == 1) {
$active_filters_div .= __('Last hour.');
2019-06-11 12:58:18 +02:00
} else if ($event_view_hr > 1) {
2019-06-10 15:18:35 +02:00
$active_filters_div .= __('Last %d hours.', $event_view_hr);
}
$active_filters_div .= '</div>';
$active_filters_div .= '</div>';
// Duplicates.
$active_filters_div .= '<div>';
$active_filters_div .= '<div class="label box-shadow">'.__('Duplicated').'</div>';
$active_filters_div .= '<div id="summary_duplicates" class="content">';
if ($group_rep == 0) {
$active_filters_div .= __('All events.');
} else if ($group_rep == 1) {
$active_filters_div .= __('Group events');
} else if ($group_rep == 2) {
$active_filters_div .= __('Group agents.');
}
$active_filters_div .= '</div>';
$active_filters_div .= '</div>';
// Close.
$active_filters_div .= '</div>';
2019-06-13 12:30:09 +02:00
$table_id = 'events';
2019-06-20 11:46:01 +02:00
$form_id = 'events_form';
2019-06-10 15:18:35 +02:00
// Print datatable.
2019-06-06 17:50:47 +02:00
ui_print_datatable(
[
2019-06-13 12:30:09 +02:00
'id' => $table_id,
2019-06-11 12:58:18 +02:00
'class' => 'info_table events',
'style' => 'width: 100%;',
'ajax_url' => 'operation/events/events',
2019-06-19 12:56:16 +02:00
'ajax_data' => [
'get_events' => 1,
'history' => (int) $history,
],
2019-06-11 12:58:18 +02:00
'form' => [
2019-06-20 11:46:01 +02:00
'id' => $form_id,
2019-06-11 12:58:18 +02:00
'class' => 'flex-row',
'html' => $filter,
'inputs' => [],
'extra_buttons' => $buttons,
2019-06-10 15:18:35 +02:00
],
2019-06-11 12:58:18 +02:00
'extra_html' => $active_filters_div,
'pagination_options' => [
2019-06-06 17:50:47 +02:00
[
$config['block_size'],
10,
25,
100,
200,
500,
1000,
-1,
],
[
$config['block_size'],
10,
25,
100,
200,
500,
1000,
'All',
],
],
2019-06-11 12:58:18 +02:00
'order' => [
2019-06-07 17:35:13 +02:00
'field' => 'timestamp',
'direction' => 'desc',
2019-06-06 17:50:47 +02:00
],
2019-06-11 12:58:18 +02:00
'column_names' => $column_names,
'columns' => $fields,
2019-06-13 19:41:21 +02:00
'no_sortable_columns' => [
-1,
-2,
'column-instructions',
2019-06-13 19:41:21 +02:00
],
2019-06-11 12:58:18 +02:00
'ajax_postprocess' => 'process_datatables_item(item)',
2019-06-12 18:19:39 +02:00
'drawCallback' => 'process_datatables_callback(this, settings)',
2019-06-06 17:50:47 +02:00
]
);
2019-06-06 17:50:47 +02:00
} catch (Exception $e) {
ui_print_error_message($e->getMessage());
}
2019-06-13 19:41:21 +02:00
// Event responses.
2021-03-11 16:11:06 +01:00
if (is_user_admin($config['id_user'])) {
$sql_event_resp = "SELECT id, name FROM tevent_response WHERE type LIKE 'command'";
$event_responses = db_get_all_rows_sql($sql_event_resp);
} else {
$id_groups = array_keys(users_get_groups(false, 'EW'));
$event_responses = db_get_all_rows_filter(
'tevent_response',
[
'id_group' => $id_groups,
'type' => 'command',
]
);
}
2019-06-13 19:41:21 +02:00
2019-06-19 12:56:16 +02:00
if ($config['event_replication'] != 1) {
2019-06-20 19:23:13 +02:00
if ($event_w && !$readonly) {
2019-06-19 12:56:16 +02:00
$array_events_actions['in_progress_selected'] = __('In progress selected');
$array_events_actions['validate_selected'] = __('Validate selected');
}
2019-06-13 19:41:21 +02:00
2019-06-20 19:23:13 +02:00
if ($event_m == 1 && !$readonly) {
2019-06-19 12:56:16 +02:00
$array_events_actions['delete_selected'] = __('Delete selected');
}
2019-06-13 19:41:21 +02:00
}
foreach ($event_responses as $val) {
$array_events_actions[$val['id']] = $val['name'];
}
if (check_acl(
$config['id_user'],
0,
'EW'
)
) {
echo '<div class="multi-response-buttons">';
echo '<form method="post" id="form_event_response">';
echo '<input type="hidden" id="max_execution_event_response" value="'.$config['max_execution_event_response'].'" />';
html_print_select(
$array_events_actions,
'response_id',
'',
'',
'',
0,
false,
false,
false
);
echo '&nbsp&nbsp';
html_print_button(
__('Execute event response'),
'submit_event_response',
false,
'execute_event_response(true);',
'class="sub next"'
);
echo "<span id='response_loading_dialog' class='invisible'>".html_print_image(
'images/spinner.gif',
true
).'</span>';
echo '</form>';
2021-03-18 18:05:50 +01:00
echo '<span id="max_custom_event_resp_msg" style="display: none; color: #e63c52; line-height: 200%;">';
echo __(
'A maximum of %s event custom responses can be selected',
$config['max_execution_event_response']
).'</span>';
2021-03-18 18:05:50 +01:00
echo '<span id="max_custom_selected" style="display: none; color: #e63c52; line-height: 200%;">';
echo __(
'Please, select an event'
).'</span>';
echo '</div>';
}
2019-06-13 19:41:21 +02:00
2019-06-06 17:50:47 +02:00
// Close viewer.
enterprise_hook('close_meta_frame');
2019-06-07 17:35:13 +02:00
// Datepicker requirements.
ui_require_css_file('datepicker');
ui_include_time_picker();
ui_require_jquery_file(
'ui.datepicker-'.get_user_language(),
'include/javascript/i18n/'
);
2019-06-07 21:22:07 +02:00
// End. Load required JS.
2019-06-10 15:18:35 +02:00
html_print_input_hidden('meta', (int) is_metaconsole());
html_print_input_hidden('history', (int) $history);
html_print_input_hidden('filterid', $is_filter);
html_print_input_hidden(
'ajax_file',
ui_get_full_url('ajax.php', false, false, false)
);
// AJAX call options responses.
echo "<div id='event_details_window'></div>";
echo "<div id='event_response_window'></div>";
echo "<div id='event_response_command_window' title='".__('Parameters')."'></div>";
2019-06-11 12:58:18 +02:00
// Load filter div for dialog.
2021-03-29 09:23:03 +02:00
echo '<div id="load-modal-filter" style="display:none"></div>';
echo '<div id="save-modal-filter" style="display:none"></div>';
if ($_GET['refr'] || $do_refresh === true) {
$autorefresh_draw = true;
}
2019-06-07 17:35:13 +02:00
?>
<script type="text/javascript">
2019-06-11 12:58:18 +02:00
var loading = 0;
2019-06-07 21:22:07 +02:00
var select_with_tag_empty = <?php echo (int) $remove_with_tag_disabled; ?>;
var select_without_tag_empty = <?php echo (int) $remove_without_tag_disabled; ?>;
var origin_select_with_tag_empty = <?php echo (int) $add_with_tag_disabled; ?>;
var origin_select_without_tag_empty = <?php echo (int) $add_without_tag_disabled; ?>;
var val_none = 0;
var text_none = "<?php echo __('None'); ?>";
var group_agents_id = false;
2019-06-12 18:19:39 +02:00
var test;
2019-06-11 12:58:18 +02:00
/* Datatables auxiliary functions starts */
2019-06-12 18:19:39 +02:00
function process_datatables_callback(table, settings) {
var api = table.api();
var rows = api.rows( {page:'current'} ).nodes();
var last=null;
var last_count=0;
var events_per_group = [];
var j=0;
// Only while grouping by agents.
if($('#group_rep').val() == '2') {
test = api;
target = -1;
for (var i =0 ; i < api.columns()['0'].length; i++) {
var label = $(api.table().column(i).header()).text();
if(label == '<?php echo __('Agent ID'); ?>') {
// Agent id.
target = i;
}
2019-10-30 13:01:59 +01:00
if(label == '<?php echo addslashes(__('Agent name')); ?>') {
2019-06-12 18:19:39 +02:00
// Agent id.
target = i;
break;
}
}
// Cannot group without agent_id or agent_name.
if (target < 0) {
return;
}
api.column(target, {page:'current'} )
.data()
.each( function ( group, i ) {
$(rows).eq( i ).show();
if ( last !== group ) {
$(rows).eq( i ).before(
'<tr class="group"><td colspan="100%">'
+'<?php echo __('Agent').' '; ?>'
2019-06-13 12:30:09 +02:00
+group+' <?php echo __('has at least').' '; ?>'
2019-06-12 18:19:39 +02:00
+'<span style="cursor: pointer" id="s'+j+'">'+'</span>'
+'<?php echo ' '.__('events'); ?>'
+'</td></tr>'
);
2019-06-13 12:30:09 +02:00
events_per_group.push(i - last_count);
2019-06-12 18:19:39 +02:00
last_count = i;
last = group;
j += 1;
}
});
events_per_group.push(rows.length - last_count);
for( j=0; j<events_per_group.length; j++ ) {
$('#s'+j).text(events_per_group[j+1]);
}
/* Grouped by agent toggle view. */
$("tr.group td span").on('click', function(e){
var id = this.id.substring(1)*1;
var from = events_per_group[id];
var to = events_per_group[id+1] + from;
for (var i = from; i < to; i++) {
$(rows).eq(i).toggle();
}
})
}
var autorefresh_draw = '<?php echo $autorefresh_draw; ?>';
if (autorefresh_draw == true){
$("#refrcounter").countdown('change', {
until: countdown_repeat()
});
function countdown_repeat() {
var until_time = new Date();
until_time.setTime (until_time.getTime () + parseInt(<?php echo ($config['refr'] * 1000); ?>));
return until_time;
}
}
// Uncheck checkbox to select all.
if ($('#checkbox-all_validate_box').length) {
$('#checkbox-all_validate_box').uncheck();
}
2019-06-12 18:19:39 +02:00
}
2019-06-11 12:58:18 +02:00
function process_datatables_item(item) {
2019-06-12 18:19:39 +02:00
// Url to go to node from meta.
var server_url = '';
var hashdata = '';
if(item.meta === true){
if(typeof item.data_server !== 'undefined' && typeof item.server_url_hash !== 'undefined'){
server_url = item.data_server.server_url;
hashdata = item.server_url_hash;
}
}
2019-10-01 16:24:02 +02:00
// Show comments events.
item.user_comment = item.comments
2019-10-30 13:01:59 +01:00
if(typeof item.comments !== 'undefined' && item.comments.length > 80) {
item.user_comment += '&nbsp;&nbsp;<a id="show_comments" href="javascript:" onclick="show_event_dialog(\'';
item.user_comment += item.b64+"','comments'," + $("#group_rep").val()+');">';
item.user_comment += '<?php echo html_print_image('images/operation.png', true, ['title' => __('Show more'), 'class' => 'invert_filter']); ?></a>';
2019-10-01 16:24:02 +02:00
}
2019-10-30 13:01:59 +01:00
2019-06-12 18:19:39 +02:00
// Grouped events.
if(item.max_id_evento) {
item.id_evento = item.max_id_evento
}
2019-06-11 12:58:18 +02:00
/* Event severity prepared */
var color = "<?php echo COL_UNKNOWN; ?>";
var text = "<?php echo __('UNKNOWN'); ?>";
switch (item.criticity) {
case "<?php echo EVENT_CRIT_CRITICAL; ?>":
text = "<?php echo __('CRITICAL'); ?>";
color = "<?php echo COL_CRITICAL; ?>";
break;
2019-06-10 15:18:35 +02:00
2019-06-11 12:58:18 +02:00
case "<?php echo EVENT_CRIT_MAINTENANCE; ?>":
text = "<?php echo __('MAINTENANCE'); ?>";
color = "<?php echo COL_MAINTENANCE; ?>";
break;
2019-06-10 15:18:35 +02:00
2019-06-11 12:58:18 +02:00
case "<?php echo EVENT_CRIT_INFORMATIONAL; ?>":
text = "<?php echo __('INFORMATIONAL'); ?>";
color = "<?php echo COL_INFORMATIONAL; ?>";
break;
2019-06-10 15:18:35 +02:00
2019-06-11 12:58:18 +02:00
case "<?php echo EVENT_CRIT_MAJOR; ?>":
text = "<?php echo __('MAJOR'); ?>";
color = "<?php echo COL_MAJOR; ?>";
break;
2019-06-10 15:18:35 +02:00
2019-06-11 12:58:18 +02:00
case "<?php echo EVENT_CRIT_MINOR; ?>":
text = "<?php echo __('MINOR'); ?>";
color = "<?php echo COL_MINOR; ?>";
break;
2019-06-07 21:22:07 +02:00
2019-06-11 12:58:18 +02:00
case "<?php echo EVENT_CRIT_NORMAL; ?>":
text = "<?php echo __('NORMAL'); ?>";
color = "<?php echo COL_NORMAL; ?>";
break;
2019-06-07 21:22:07 +02:00
2019-06-11 12:58:18 +02:00
case "<?php echo EVENT_CRIT_WARNING; ?>":
text = "<?php echo __('WARNING'); ?>";
color = "<?php echo COL_WARNING; ?>";
break;
2019-06-07 21:22:07 +02:00
}
2019-06-11 12:58:18 +02:00
output = '<div data-title="';
output += text;
output += '" data-use_title_for_force_title="1" ';
output += 'class="forced_title mini-criticity h100p" ';
output += 'style="background: ' + color + '">';
output += '</div>';
// Add event severity to end of text.
2019-06-24 19:23:41 +02:00
evn = '<a href="javascript:" onclick="show_event_dialog(\'';
evn += item.b64+'\','+$("#group_rep").val()+');">';
2019-06-12 18:19:39 +02:00
// Grouped events.
2019-06-17 18:33:39 +02:00
if(item.event_rep && item.event_rep > 1) {
2019-06-12 13:17:18 +02:00
evn += '('+item.event_rep+') ';
}
2019-06-24 19:23:41 +02:00
evn += item.evento+'</a>';
if(item.meta === true) {
evn += '<input id="hidden-server_id_'+item.id_evento+'" type="hidden" value="'+item.server_id+'">';
}
2019-06-24 19:23:41 +02:00
item.mini_severity = '<div class="event flex-row h100p nowrap">';
item.mini_severity += output;
item.mini_severity += '</div>';
2019-06-11 12:58:18 +02:00
criticity = '<div class="criticity" style="background: ';
criticity += color + '">' + text + "</div>";
2019-06-11 12:58:18 +02:00
2019-06-12 18:19:39 +02:00
// Grouped events.
if(item.max_timestamp) {
item.timestamp = item.max_timestamp;
}
2019-06-11 12:58:18 +02:00
/* Event type prepared. */
switch (item.event_type) {
case "<?php echo EVENTS_ALERT_FIRED; ?>":
case "<?php echo EVENTS_ALERT_RECOVERED; ?>":
case "<?php echo EVENTS_ALERT_CEASED; ?>":
case "<?php echo EVENTS_ALERT_MANUAL_VALIDATION; ?>":
text = "<?php echo __('ALERT'); ?>";
color = "<?php echo COL_ALERTFIRED; ?>";
break;
case "<?php echo EVENTS_RECON_HOST_DETECTED; ?>":
case "<?php echo EVENTS_SYSTEM; ?>":
case "<?php echo EVENTS_ERROR; ?>":
case "<?php echo EVENTS_NEW_AGENT; ?>":
case "<?php echo EVENTS_CONFIGURATION_CHANGE; ?>":
text = "<?php echo __('SYSTEM'); ?>";
color = "<?php echo COL_MAINTENANCE; ?>";
break;
case "<?php echo EVENTS_GOING_UP_WARNING; ?>":
case "<?php echo EVENTS_GOING_DOWN_WARNING; ?>":
2019-06-20 11:46:01 +02:00
text = "<?php echo __('WARNING'); ?>";
2019-06-11 12:58:18 +02:00
color = "<?php echo COL_WARNING; ?>";
break;
case "<?php echo EVENTS_GOING_DOWN_NORMAL; ?>":
case "<?php echo EVENTS_GOING_UP_NORMAL; ?>":
text = "<?php echo __('NORMAL'); ?>";
color = "<?php echo COL_NORMAL; ?>";
break;
case "<?php echo EVENTS_GOING_DOWN_CRITICAL; ?>":
case "<?php echo EVENTS_GOING_UP_CRITICAL; ?>":
text = "<?php echo __('CRITICAL'); ?>";
color = "<?php echo COL_CRITICAL; ?>";
break;
case "<?php echo EVENTS_UNKNOWN; ?>":
case "<?php echo EVENTS_GOING_UNKNOWN; ?>":
default:
text = "<?php echo __('UNKNOWN'); ?>";
color = "<?php echo COL_UNKNOWN; ?>";
break;
2019-06-07 21:22:07 +02:00
}
event_type = '<div class="criticity" style="background: ';
event_type += color + '">' + text + "</div>";
2019-06-11 12:58:18 +02:00
2019-06-18 16:07:53 +02:00
/* Module status */
/* Event severity prepared */
var color = "<?php echo COL_UNKNOWN; ?>";
var text = "<?php echo __('UNKNOWN'); ?>";
switch (item.module_status) {
case "<?php echo AGENT_MODULE_STATUS_NORMAL; ?>":
text = "<?php echo __('NORMAL'); ?>";
color = "<?php echo COL_NORMAL; ?>";
break;
case "<?php echo AGENT_MODULE_STATUS_CRITICAL_BAD; ?>":
text = "<?php echo __('CRITICAL'); ?>";
color = "<?php echo COL_CRITICAL; ?>";
break;
case "<?php echo AGENT_MODULE_STATUS_NO_DATA; ?>":
text = "<?php echo __('NOT INIT'); ?>";
color = "<?php echo COL_NOTINIT; ?>";
break;
case "<?php echo AGENT_MODULE_STATUS_CRITICAL_ALERT; ?>":
case "<?php echo AGENT_MODULE_STATUS_NORMAL_ALERT; ?>":
case "<?php echo AGENT_MODULE_STATUS_WARNING_ALERT; ?>":
text = "<?php echo __('ALERT'); ?>";
color = "<?php echo COL_ALERTFIRED; ?>";
break;
case "<?php echo AGENT_MODULE_STATUS_WARNING; ?>":
text = "<?php echo __('WARNING'); ?>";
color = "<?php echo COL_WARNING; ?>";
break;
}
module_status = '<div class="criticity" style="background: ';
module_status += color + '">' + text + "</div>";
2019-06-18 16:07:53 +02:00
2019-06-11 12:58:18 +02:00
/* Options */
// Show more.
2019-06-18 15:03:49 +02:00
item.options = '<a href="javascript:" onclick="show_event_dialog(\'';
item.options += item.b64+'\','+$("#group_rep").val();
item.options += ')" ><?php echo html_print_image('images/operation.png', true, ['title' => __('Show more'), 'class' => 'invert_filter']); ?></a>';
2019-06-11 12:58:18 +02:00
2019-06-13 19:41:21 +02:00
<?php
2019-06-14 13:20:34 +02:00
if (!$readonly) {
2019-06-13 19:41:21 +02:00
?>
2019-06-14 13:20:34 +02:00
if (item.user_can_write == '1') {
if (item.estado != '1') {
// Validate.
item.options += '<a href="javascript:" onclick="validate_event(dt_<?php echo $table_id; ?>,';
if (item.max_id_evento) {
item.options += item.max_id_evento+', '+ item.event_rep +', this)" id="val-'+item.max_id_evento+'">';
item.options += '<?php echo html_print_image('images/tick.png', true, ['title' => __('Validate events'), 'class' => 'invert_filter']); ?></a>';
2019-06-14 13:20:34 +02:00
} else {
item.options += item.id_evento+', 0, this)" id="val-'+item.id_evento+'">';
item.options += '<?php echo html_print_image('images/tick.png', true, ['title' => __('Validate event'), 'class' => 'invert_filter']); ?></a>';
2019-06-14 13:20:34 +02:00
}
}
if (item.estado != '2') {
// In process.
item.options += '<a href="javascript:" onclick="in_process_event(dt_<?php echo $table_id; ?>,';
if (item.max_id_evento) {
item.options += item.max_id_evento+', '+ item.event_rep +', this)" id="proc-'+item.max_id_evento+'">';
2019-06-14 13:20:34 +02:00
} else {
item.options += item.id_evento+', 0, this)" id="proc-'+item.id_evento+'">';
2019-06-14 13:20:34 +02:00
}
item.options += '<?php echo html_print_image('images/hourglass.png', true, ['title' => __('Change to in progress status'), 'class' => 'invert_filter']); ?></a>';
2019-06-13 19:41:21 +02:00
}
2019-06-12 18:19:39 +02:00
}
2019-06-14 13:20:34 +02:00
if (item.user_can_manage == '1') {
// Delete.
item.options += '<a href="javascript:" onclick="delete_event(dt_<?php echo $table_id; ?>,';
2019-06-13 19:41:21 +02:00
if (item.max_id_evento) {
item.options += item.max_id_evento+', '+ item.event_rep +', this)" id="del-'+item.max_id_evento+'">';
item.options += '<?php echo html_print_image('images/cross.png', true, ['title' => __('Delete events'), 'class' => 'invert_filter']); ?></a>';
2019-06-13 19:41:21 +02:00
} else {
item.options += item.id_evento+', 0, this)" id="del-'+item.id_evento+'">';
item.options += '<?php echo html_print_image('images/cross.png', true, ['title' => __('Delete event'), 'class' => 'invert_filter']); ?></a>';
2019-06-13 19:41:21 +02:00
}
2019-06-12 18:19:39 +02:00
}
2019-06-19 12:56:16 +02:00
<?php
}
?>
2019-06-13 19:41:21 +02:00
// Multi select.
item.m = '<input name="checkbox-multi[]" type="checkbox" value="';
item.m += item.id_evento+'" id="checkbox-multi-'+item.id_evento+'" ';
if (item.max_id_evento) {
item.m += ' event_rep="' + item.event_rep +'" ';
} else {
item.m += ' event_rep="0" ';
}
2019-06-13 19:41:21 +02:00
item.m += 'class="candeleted chk_val">';
/* Status */
img = '<?php echo html_print_image('images/star.png', true, ['title' => __('Unknown'), 'class' => 'forced-title']); ?>';
2020-10-21 16:18:07 +02:00
state = '0';
2019-06-13 19:41:21 +02:00
switch (item.estado) {
2019-06-20 11:46:01 +02:00
case "<?php echo EVENT_STATUS_NEW; ?>":
2019-06-13 19:41:21 +02:00
img = '<?php echo html_print_image('images/star.png', true, ['title' => __('New event'), 'class' => 'forced-title']); ?>';
break;
2019-06-20 11:46:01 +02:00
case "<?php echo EVENT_STATUS_VALIDATED; ?>":
2020-10-21 16:18:07 +02:00
state = '1';
img = '<?php echo html_print_image('images/tick.png', true, [ 'title' => __('Event validated'), 'class' => 'forced-title invert_filter']); ?>';
2019-06-13 19:41:21 +02:00
break;
2019-06-20 11:46:01 +02:00
case "<?php echo EVENT_STATUS_INPROCESS; ?>":
2020-10-21 16:18:07 +02:00
state = '2';
img = '<?php echo html_print_image('images/hourglass.png', true, [ 'title' => __('Event in process'), 'class' => 'forced-title invert_filter']); ?>';
2019-06-13 19:41:21 +02:00
break;
}
/* Update column content now to avoid json poisoning. */
2019-06-19 16:52:14 +02:00
// Url to agent view.
var url_link = '<?php echo ui_get_full_url('index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente='); ?>';
var url_link_hash = '';
if(item.meta === true){
url_link = server_url+'/index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=';
url_link_hash = hashdata;
}
2019-06-19 16:52:14 +02:00
/* Agent name link */
if (item.id_agente > 0) {
item.agent_name = '<a href="'+url_link+item.id_agente+url_link_hash+'">' + item.agent_name + '</a>';
2019-06-19 16:52:14 +02:00
} else {
item.agent_name = '';
}
/* Agent ID link */
if (item.id_agente > 0) {
item.id_agente = '<a href="'+url_link+item.id_agente+url_link_hash+'">' + item.id_agente + '</a>';
2019-06-19 16:52:14 +02:00
} else {
item.id_agente = '';
}
2019-06-13 19:41:21 +02:00
item.estado = '<div>';
item.estado += '<span class="invisible">';
2020-10-21 16:18:07 +02:00
item.estado += state;
item.estado += '</span>';
2019-06-13 19:41:21 +02:00
item.estado += img;
item.estado += '</div>';
2019-06-11 12:58:18 +02:00
item.criticity = criticity;
item.event_type = event_type;
item.module_status = module_status;
2019-06-11 12:58:18 +02:00
/* Event ID dash */
item.id_evento = "#"+item.id_evento;
2019-06-07 21:22:07 +02:00
2019-06-17 19:12:45 +02:00
/* Owner */
if (item.owner_user == "0") {
item.owner_user = '<?php echo __('System'); ?>';
}
2019-06-18 15:03:49 +02:00
// Add event severity format to itself.
item.evento = evn;
2019-06-19 16:52:14 +02:00
/* Group name */
if (item.id_grupo == "0") {
item.id_grupo = "<?php echo __('All'); ?>";
} else {
item.id_grupo = item.group_name;
}
2019-06-20 21:11:56 +02:00
/* Module name */
item.id_agentmodule = item.module_name;
2019-06-11 12:58:18 +02:00
}
/* Datatables auxiliary functions ends */
/* Tag management starts */
2019-06-07 21:22:07 +02:00
function click_button_remove_tag(what_button) {
if (what_button == "with") {
id_select_origin = "#select_with";
id_select_destiny = "#tag_with_temp";
id_button_remove = "#button-remove_with";
id_button_add = "#button-add_with";
select_origin_empty = origin_select_with_tag_empty;
}
else { //without
id_select_origin = "#select_without";
id_select_destiny = "#tag_without_temp";
id_button_remove = "#button-remove_without";
id_button_add = "#button-add_without";
select_origin_empty = origin_select_without_tag_empty;
}
if ($(id_select_destiny + " option:selected").length == 0) {
return; //Do nothing
}
if (select_origin_empty) {
$(id_select_origin + " option").remove();
if (what_button == "with") {
origin_select_with_tag_empty = false;
}
else { //without
origin_select_without_tag_empty = false;
}
$(id_button_add).removeAttr('disabled');
}
//Foreach because maybe the user select several items in
//the select.
jQuery.each($(id_select_destiny + " option:selected"), function(key, element) {
val = $(element).val();
text = $(element).text();
$(id_select_origin).append($("<option value='" + val + "'>" + text + "</option>"));
});
$(id_select_destiny + " option:selected").remove();
if ($(id_select_destiny + " option").length == 0) {
$(id_select_destiny).append($("<option value='" + val_none + "'>" + text_none + "</option>"));
$(id_button_remove).attr('disabled', 'true');
if (what_button == 'with') {
select_with_tag_empty = true;
}
else { //without
select_without_tag_empty = true;
}
}
replace_hidden_tags(what_button);
}
function click_button_add_tag(what_button) {
if (what_button == 'with') {
id_select_origin = "#select_with";
id_select_destiny = "#tag_with_temp";
id_button_remove = "#button-remove_with";
id_button_add = "#button-add_with";
}
else { //without
id_select_origin = "#select_without";
id_select_destiny = "#tag_without_temp";
id_button_remove = "#button-remove_without";
id_button_add = "#button-add_without";
}
2019-06-07 21:22:07 +02:00
$(id_select_origin + " option:selected").each(function() {
if (what_button == 'with') {
select_destiny_empty = select_with_tag_empty;
}
else { //without
select_destiny_empty = select_without_tag_empty;
}
2019-06-07 21:22:07 +02:00
without_val = $(this).val();
if(without_val == null) {
next;
}
without_text = $(this).text();
2019-06-07 21:22:07 +02:00
if (select_destiny_empty) {
$(id_select_destiny).empty();
2019-06-07 21:22:07 +02:00
if (what_button == 'with') {
select_with_tag_empty = false;
}
else { //without
select_without_tag_empty = false;
}
}
2019-06-07 21:22:07 +02:00
$(id_select_destiny).append($("<option value='" + without_val + "'>" + without_text + "</option>"));
$(id_select_origin + " option:selected").remove();
$(id_button_remove).removeAttr('disabled');
2019-06-07 21:22:07 +02:00
if ($(id_select_origin + " option").length == 0) {
$(id_select_origin).append($("<option value='" + val_none + "'>" + text_none + "</option>"));
$(id_button_add).attr('disabled', 'true');
2019-06-07 21:22:07 +02:00
if (what_button == 'with') {
origin_select_with_tag_empty = true;
}
else { //without
origin_select_without_tag_empty = true;
}
}
2019-06-07 21:22:07 +02:00
replace_hidden_tags(what_button);
});
2019-06-07 21:22:07 +02:00
}
function replace_hidden_tags(what_button) {
if (what_button == 'with') {
id_select_destiny = "#tag_with_temp";
id_hidden = "#hidden-tag_with";
}
else { //without
id_select_destiny = "#tag_without_temp";
id_hidden = "#hidden-tag_without";
}
2019-06-07 21:22:07 +02:00
value_store = [];
2019-06-07 21:22:07 +02:00
jQuery.each($(id_select_destiny + " option"), function(key, element) {
val = $(element).val();
2019-06-07 21:22:07 +02:00
value_store.push(val);
});
2019-06-07 21:22:07 +02:00
$(id_hidden).val(Base64.encode(JSON.stringify(value_store)));
}
function clear_tags_inputs() {
$("#hidden-tag_with").val(Base64.encode(JSON.stringify([])));
$("#hidden-tag_without").val(Base64.encode(JSON.stringify([])));
reorder_tags_inputs();
}
function reorder_tags_inputs() {
$('#select_with option[value="' + val_none + '"]').remove();
jQuery.each($("#tag_with_temp option"), function(key, element) {
val = $(element).val();
text = $(element).text();
2019-06-07 21:22:07 +02:00
if (val == val_none)
return;
2019-06-07 21:22:07 +02:00
$("#select_with").append($("<option value='" + val + "'>" + text + "</option>"));
});
$("#tag_with_temp option").remove();
2019-06-07 21:22:07 +02:00
$('#select_without option[value="' + val_none + '"]').remove();
jQuery.each($("#tag_without_temp option"), function(key, element) {
val = $(element).val();
text = $(element).text();
2019-06-07 21:22:07 +02:00
if (val == val_none)
return;
2019-06-07 21:22:07 +02:00
$("#select_without").append($("<option value='" + val + "'>" + text + "</option>"));
});
$("#tag_without_temp option").remove();
2019-06-07 21:22:07 +02:00
tags_base64 = $("#hidden-tag_with").val();
2019-06-11 12:58:18 +02:00
if (tags_base64.length > 0) {
tags = jQuery.parseJSON(Base64.decode(tags_base64));
} else {
tags = [];
}
2019-06-07 21:22:07 +02:00
jQuery.each(tags, function(key, element) {
if ($("#select_with option[value='" + element + "']").length == 1) {
text = $("#select_with option[value='" + element + "']").text();
val = $("#select_with option[value='" + element + "']").val();
$("#tag_with_temp").append($("<option value='" + val + "'>" + text + "</option>"));
$("#select_with option[value='" + element + "']").remove();
}
});
if ($("#select_with option").length == 0) {
origin_select_with_tag_empty = true;
$("#button-add_with").attr('disabled', 'true');
$("#select_with").append($("<option value='" + val_none + "'>" + text_none + "</option>"));
}
else {
origin_select_with_tag_empty = false;
$("#button-add_with").removeAttr('disabled');
}
if ($("#tag_with_temp option").length == 0) {
select_with_tag_empty = true;
$("#button-remove_with").attr('disabled', 'true');
$("#tag_with_temp").append($("<option value='" + val_none + "'>" + text_none + "</option>"));
}
else {
select_with_tag_empty = false;
$("#button-remove_with").removeAttr('disabled');
}
2019-06-07 21:22:07 +02:00
tags_base64 = $("#hidden-tag_without").val();
2019-06-11 12:58:18 +02:00
if (tags_base64.length > 0) {
tags = jQuery.parseJSON(Base64.decode(tags_base64));
} else {
tags = [];
}
2019-06-07 21:22:07 +02:00
jQuery.each(tags, function(key, element) {
if ($("#select_without option[value='" + element + "']").length == 1) {
text = $("#select_without option[value='" + element + "']").text();
val = $("#select_without option[value='" + element + "']").val();
$("#tag_without_temp").append($("<option value='" + val + "'>" + text + "</option>"));
$("#select_without option[value='" + element + "']").remove();
}
});
if ($("#select_without option").length == 0) {
origin_select_without_tag_empty = true;
$("#button-add_without").attr('disabled', 'true');
$("#select_without").append($("<option value='" + val_none + "'>" + text_none + "</option>"));
}
else {
origin_select_without_tag_empty = false;
$("#button-add_without").removeAttr('disabled');
}
if ($("#tag_without_temp option").length == 0) {
select_without_tag_empty = true;
$("#button-remove_without").attr('disabled', 'true');
$("#tag_without_temp").append($("<option value='" + val_none + "'>" + text_none + "</option>"));
}
else {
select_without_tag_empty = false;
$("#button-remove_without").removeAttr('disabled');
}
}
2019-06-12 13:17:18 +02:00
/* Tag management ends */
2019-06-11 12:58:18 +02:00
$(document).ready( function() {
let refresco = <?php echo get_parameter('refr', 0); ?>;
$('#refresh option[value='+refresco+']').attr('selected', 'selected');
2019-06-19 17:30:32 +02:00
/* Filter to a href */
$('.events_link').on('click', function(e) {
e.preventDefault();
2019-06-20 11:46:01 +02:00
inputs = $("#<?php echo $form_id; ?> :input");
values = {};
inputs.each(function() {
values[this.name] = $(this).val();
})
2019-06-19 17:30:32 +02:00
2019-06-20 11:46:01 +02:00
values['history'] = "<?php echo (int) $history; ?>";
2019-06-19 17:30:32 +02:00
2019-06-20 11:46:01 +02:00
var url = e.currentTarget.href;
url += 'fb64=' + btoa(JSON.stringify(values));
url += '&refr=' + '<?php echo $config['refr']; ?>';
2019-06-20 11:46:01 +02:00
document.location = url;
2019-06-19 17:30:32 +02:00
});
2019-06-13 19:41:21 +02:00
/* Multi select handler */
$('#checkbox-all_validate_box').on('change', function() {
if($('#checkbox-all_validate_box').is(":checked")) {
$('.chk_val').check();
} else {
$('.chk_val').uncheck();
}
});
2019-06-11 12:58:18 +02:00
/* Update summary */
$("#status").on("change",function(){
$('#summary_status').html($("#status option:selected").text());
});
$("#text-event_view_hr").on("keyup",function(){
hours = $('#text-event_view_hr').val();
if (hours == '' || hours == 0 ) {
$('#summary_hours').html('<?php echo __('Any'); ?>');
} else if (hours == 1) {
$('#summary_hours').html('<?php echo __('Last hour.'); ?>');
} else {
$('#summary_hours').html(hours + '<?php echo ' '.__('hours.'); ?>');
}
});
$('#group_rep').on("change", function(){
$('#summary_duplicates').html($("#group_rep option:selected").text());
});
/* Summary updates end. */
/* Filter management */
$('#load-filter').click(function (){
if($('#load-filter-select').length) {
$('#load-filter-select').dialog();
} else {
if (loading == 0) {
loading = 1
$.ajax({
method: 'POST',
url: '<?php echo ui_get_full_url('ajax.php'); ?>',
data: {
page: 'include/ajax/events',
load_filter_modal: 1
},
2019-06-11 12:58:18 +02:00
success: function (data){
$('#load-modal-filter')
.empty()
.html(data);
loading = 0;
}
});
}
}
});
$('#save-filter').click(function (){
if($('#save-filter-select').length) {
$('#save-filter-select').dialog();
} else {
if (loading == 0) {
loading = 1
$.ajax({
method: 'POST',
url: '<?php echo ui_get_full_url('ajax.php'); ?>',
data: {
page: 'include/ajax/events',
save_filter_modal: 1,
current_filter: $('#latest_filter_id').val()
},
success: function (data){
$('#save-modal-filter')
.empty()
.html(data);
loading = 0;
}
});
}
}
});
/* Filter management ends */
/* Tag management */
id_select_destiny = "#tag_with_temp";
id_hidden = "#hidden-tag_with";
value_store = [];
jQuery.each($(id_select_destiny + " option"), function(key, element) {
val = $(element).val();
value_store.push(val);
});
$(id_hidden).val(Base64.encode(JSON.stringify(value_store)));
id_select_destiny2 = "#tag_without_temp";
id_hidden2 = "#hidden-tag_without";
value_store2 = [];
jQuery.each($(id_select_destiny2 + " option"), function(key, element) {
val = $(element).val();
value_store2.push(val);
});
$(id_hidden2).val(Base64.encode(JSON.stringify(value_store2)));
$("#text-date_from, #text-date_to").datepicker(
{dateFormat: "<?php echo DATE_FORMAT_JS; ?>"});
$("#button-add_with").click(function() {
click_button_add_tag("with");
});
$("#button-add_without").click(function() {
click_button_add_tag("without");
});
$("#button-remove_with").click(function() {
click_button_remove_tag("with");
});
$("#button-remove_without").click(function() {
click_button_remove_tag("without");
});
//Autorefresh in fullscreen
var pure = '<?php echo $pure; ?>';
if(pure == 1){
var refresh_interval = parseInt('<?php echo ($config['refr'] * 1000); ?>');
var until_time='';
// If autorefresh is disabled, don't show the countdown
var refresh_time = '<?php echo $_GET['refr']; ?>';
if(refresh_time == '' || refresh_time == 0){
$('#refrcounter').toggle();
}
function events_refresh() {
until_time = new Date();
until_time.setTime (until_time.getTime () + parseInt(<?php echo ($config['refr'] * 1000); ?>));
$("#refrcounter").countdown ({
until: until_time,
layout: '(%M%nn%M:%S%nn%S <?php echo __('Until next'); ?>)',
labels: ['', '', '', '', '', '', ''],
onExpiry: function () {
dt_events.draw(false);
}
});
}
// Start the countdown when page is loaded (first time).
events_refresh();
// Repeat countdown according to refresh_interval.
setInterval(events_refresh, refresh_interval);
$("select#refresh").change (function () {
var href = window.location.href;
inputs = $("#events_form :input");
values = {};
inputs.each(function() {
values[this.name] = $(this).val();
})
var newValue = btoa(JSON.stringify(values));
var fb64 = '<?php echo $fb64; ?>';
// Check if the filters have changed.
if(fb64 !== newValue){
href = href.replace(fb64, newValue);
}
href = href.replace('refr='+refresh_time, 'refr='+this.value);
$(document).attr("location", href);
});
}
2019-06-11 12:58:18 +02:00
});
2019-06-07 21:22:07 +02:00
2019-06-07 17:35:13 +02:00
function datetime_picker_callback() {
$("#text-time_from, #text-time_to").timepicker({
showSecond: true,
timeFormat: '<?php echo TIME_FORMAT_JS; ?>',
timeOnlyTitle: '<?php echo __('Choose time'); ?>',
timeText: '<?php echo __('Time'); ?>',
hourText: '<?php echo __('Hour'); ?>',
minuteText: '<?php echo __('Minute'); ?>',
secondText: '<?php echo __('Second'); ?>',
currentText: '<?php echo __('Now'); ?>',
closeText: '<?php echo __('Close'); ?>'});
$("#text-date_from, #text-date_to").datepicker({dateFormat: "<?php echo DATE_FORMAT_JS; ?>"});
$.datepicker.setDefaults($.datepicker.regional[ "<?php echo get_user_language(); ?>"]);
};
datetime_picker_callback();
function show_instructions(id){
title = "<?php echo __('Instructions'); ?>";
$('#hidden_event_instructions_' + id).dialog({
title: title,
width: 600
});
}
2019-06-07 17:35:13 +02:00
</script>