2012-08-22 16:09:05 +02:00
|
|
|
<?php
|
|
|
|
|
2023-06-08 13:19:01 +02:00
|
|
|
// Pandora FMS - https://pandorafms.com
|
2012-08-22 16:09:05 +02:00
|
|
|
// ==================================================
|
2023-06-08 11:53:13 +02:00
|
|
|
// Copyright (c) 2005-2023 Pandora FMS
|
2023-06-08 13:19:01 +02:00
|
|
|
// Please see https://pandorafms.com/community/ for full contribution list
|
2012-08-22 16:09:05 +02:00
|
|
|
// This program is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU Lesser General Public License
|
|
|
|
// as published by the Free Software Foundation; 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.
|
2019-01-30 16:18:44 +01:00
|
|
|
function treeview_printModuleTable($id_module, $server_data=false, $no_head=false)
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
if (empty($server_data)) {
|
|
|
|
$server_name = '';
|
|
|
|
$server_id = '';
|
2020-07-22 10:56:16 +02:00
|
|
|
$console_url = ui_get_full_url('/');
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
$server_name = $server_data['server_name'];
|
|
|
|
$server_id = $server_data['id'];
|
|
|
|
$console_url = $server_data['server_url'].'/';
|
|
|
|
}
|
|
|
|
|
|
|
|
include_once $config['homedir'].'/include/functions_agents.php';
|
|
|
|
include_once $config['homedir'].'/include/functions_graph.php';
|
|
|
|
include_graphs_dependencies($config['homedir'].'/');
|
|
|
|
include_once $config['homedir'].'/include/functions_groups.php';
|
|
|
|
include_once $config['homedir'].'/include/functions_servers.php';
|
|
|
|
enterprise_include_once('meta/include/functions_modules_meta.php');
|
|
|
|
enterprise_include_once('meta/include/functions_ui_meta.php');
|
|
|
|
enterprise_include_once('meta/include/functions_metaconsole.php');
|
|
|
|
|
|
|
|
$user_access_node = can_user_access_node();
|
|
|
|
|
|
|
|
if (is_metaconsole()) {
|
|
|
|
if (metaconsole_connect($server_data) != NOERR) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$filter['id_agente_modulo'] = $id_module;
|
|
|
|
|
|
|
|
$module = db_get_row_filter('tagente_modulo', $filter);
|
|
|
|
|
|
|
|
if ($module === false) {
|
|
|
|
ui_print_error_message(__('There was a problem loading module'));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$table = new StdClass();
|
|
|
|
$table->width = '100%';
|
2023-01-30 13:39:27 +01:00
|
|
|
$table->class = 'floating_form';
|
2023-01-19 23:26:26 +01:00
|
|
|
$table->id = 'tree_view_module_data';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->style = [];
|
2023-01-26 13:25:24 +01:00
|
|
|
$table->style['title'] = 'height: 32px; width: 30%; padding-right: 5px; text-align: end;';
|
2023-02-23 14:30:31 +01:00
|
|
|
$table->style['data'] = 'height: 32px; width: 70%; padding-left: 5px;font-weight: lighter;';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->data = [];
|
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
// Module name.
|
2023-01-26 13:25:24 +01:00
|
|
|
$cellName = ((bool) $module['disabled'] === true) ? '<em>'.$module['nombre'].'</em>'.ui_print_help_tip(__('Disabled'), true) : $module['nombre'];
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Name');
|
2023-02-01 15:14:32 +01:00
|
|
|
$row['data'] = html_print_anchor(
|
2023-01-30 13:39:27 +01:00
|
|
|
[
|
2024-04-10 10:50:11 +02:00
|
|
|
'href' => '#',
|
2023-02-01 15:14:32 +01:00
|
|
|
'title' => __('Click here for view this module'),
|
|
|
|
'class' => 'font_11',
|
|
|
|
'content' => $cellName,
|
2024-04-10 10:50:11 +02:00
|
|
|
'onClick' => 'redirectNode(\''.$console_url.'index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&id_agente='.$module['id_agente'].'&tab=module&edit_module=1&id_agent_module='.$module['id_agente_modulo'].'\');',
|
2023-01-30 13:39:27 +01:00
|
|
|
],
|
|
|
|
true
|
|
|
|
);
|
2023-02-01 15:14:32 +01:00
|
|
|
$table->data['name'] = $row;
|
2023-01-30 13:39:27 +01:00
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
// Interval.
|
2019-01-30 16:18:44 +01:00
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Interval');
|
|
|
|
$row['data'] = human_time_description_raw(modules_get_interval($module['id_agente_modulo']), true);
|
|
|
|
$table->data['interval'] = $row;
|
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
// Warning Min/Max.
|
2019-01-30 16:18:44 +01:00
|
|
|
if (modules_is_string_type($module['id_tipo_modulo'])) {
|
|
|
|
$warning_status_str = __('Str.').': '.$module['str_warning'];
|
|
|
|
} else {
|
|
|
|
$warning_status_str = __('Min.').': '.(float) $module['min_warning'].'<br>'.__('Max.').': '.(float) $module['max_warning'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Warning status');
|
|
|
|
$row['data'] = $warning_status_str;
|
2020-02-10 11:16:57 +01:00
|
|
|
$table->data['warning_status'] = $row;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
// Critical Min/Max.
|
2019-01-30 16:18:44 +01:00
|
|
|
if (modules_is_string_type($module['id_tipo_modulo'])) {
|
|
|
|
$critical_status_str = __('Str.').': '.$module['str_warning'];
|
|
|
|
} else {
|
|
|
|
$critical_status_str = __('Min.').': '.(float) $module['min_critical'].'<br>'.__('Max.').': '.(float) $module['max_critical'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Critical status');
|
|
|
|
$row['data'] = $critical_status_str;
|
|
|
|
$table->data['critical_status'] = $row;
|
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
// Module group.
|
2019-01-30 16:18:44 +01:00
|
|
|
$module_group = modules_get_modulegroup_name($module['id_module_group']);
|
|
|
|
|
|
|
|
if ($module_group === false) {
|
|
|
|
$module_group = __('Not assigned');
|
|
|
|
} else {
|
|
|
|
$module_group = __("$module_group");
|
|
|
|
}
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Module group');
|
|
|
|
$row['data'] = $module_group;
|
|
|
|
$table->data['module_group'] = $row;
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Description');
|
2023-01-26 13:25:24 +01:00
|
|
|
$row['data'] = $module['descripcion'];
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->data['description'] = $row;
|
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
// Tags.
|
2019-01-30 16:18:44 +01:00
|
|
|
$tags = tags_get_module_tags($module['id_agente_modulo']);
|
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
if (empty($tags) === false) {
|
|
|
|
$user_tags = tags_get_user_tags($config['id_user']);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
foreach ($tags as $k => $v) {
|
|
|
|
if (!array_key_exists($v, $user_tags)) {
|
|
|
|
// Only show user's tags.
|
2019-01-30 16:18:44 +01:00
|
|
|
unset($tags[$k]);
|
|
|
|
} else {
|
2023-01-19 23:26:26 +01:00
|
|
|
$tag_name = tags_get_name($v);
|
|
|
|
if (empty($tag_name) === true) {
|
|
|
|
unset($tags[$k]);
|
|
|
|
} else {
|
|
|
|
$tags[$k] = $tag_name;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Tags');
|
2023-01-19 23:26:26 +01:00
|
|
|
$row['data'] = (empty($tags) === true) ? '<i>'.__('N/A').'</i>' : implode(', ', $tags);
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->data['tags'] = $row;
|
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
// Data.
|
2019-01-30 16:18:44 +01:00
|
|
|
$last_data = db_get_row_filter('tagente_estado', ['id_agente_modulo' => $module['id_agente_modulo'], 'order' => ['field' => 'id_agente_estado', 'order' => 'DESC']]);
|
|
|
|
if ($config['render_proc']) {
|
|
|
|
switch ($module['id_tipo_modulo']) {
|
|
|
|
case 2:
|
|
|
|
case 6:
|
|
|
|
case 9:
|
|
|
|
case 18:
|
|
|
|
case 21:
|
|
|
|
case 31:
|
|
|
|
if (is_numeric($last_data['datos']) && $last_data['datos'] >= 1) {
|
2021-03-11 15:40:23 +01:00
|
|
|
$data = "<span class='span_treeview'>".$config['render_proc_ok'].'</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
2021-03-11 15:40:23 +01:00
|
|
|
$data = "<span class='span_treeview'>".$config['render_proc_fail'].'</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
switch ($module['id_tipo_modulo']) {
|
|
|
|
case 15:
|
|
|
|
$value = db_get_value('snmp_oid', 'tagente_modulo', 'id_agente_modulo', $module['id_agente_modulo']);
|
|
|
|
if ($value == '.1.3.6.1.2.1.1.3.0' || $value == '.1.3.6.1.2.1.25.1.1.0') {
|
2021-03-11 15:40:23 +01:00
|
|
|
$data = "<span title='".$last_data['datos']."' class='nowrap'>".human_milliseconds_to_string($last_data['datos']).'</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else if (is_numeric($last_data['datos'])) {
|
2022-10-26 18:25:16 +02:00
|
|
|
$data = "<span class='span_treeview'>".remove_right_zeros(number_format($last_data['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])).'</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
$data = ui_print_truncate_text(
|
|
|
|
io_safe_output($last_data['datos']),
|
|
|
|
GENERIC_SIZE_TEXT,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
'...',
|
|
|
|
'white-space: nowrap;'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
if (is_numeric($last_data['datos'])) {
|
2022-10-26 18:25:16 +02:00
|
|
|
$data = "<span class='span_treeview'>".remove_right_zeros(number_format($last_data['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])).'</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
$data = ui_print_truncate_text(
|
|
|
|
io_safe_output($last_data['datos']),
|
|
|
|
GENERIC_SIZE_TEXT,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
'...',
|
|
|
|
'white-space: nowrap;'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
switch ($module['id_tipo_modulo']) {
|
|
|
|
case 15:
|
|
|
|
$value = db_get_value('snmp_oid', 'tagente_modulo', 'id_agente_modulo', $module['id_agente_modulo']);
|
2023-01-19 23:26:26 +01:00
|
|
|
if ($value === '.1.3.6.1.2.1.1.3.0' || $value === '.1.3.6.1.2.1.25.1.1.0') {
|
2021-03-11 15:40:23 +01:00
|
|
|
$data = "<span title='".human_milliseconds_to_string($last_data['datos'])."' class='nowrap'>".human_milliseconds_to_string($last_data['datos']).'</span>';
|
2023-01-19 23:26:26 +01:00
|
|
|
} else if (is_numeric($last_data['datos']) === true) {
|
2022-10-26 18:25:16 +02:00
|
|
|
$data = "<span class='span_treeview'>".remove_right_zeros(number_format($last_data['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])).'</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
$data = ui_print_truncate_text(
|
|
|
|
io_safe_output($last_data['datos']),
|
|
|
|
GENERIC_SIZE_TEXT,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
'...',
|
|
|
|
'white-space: nowrap;'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
if (is_numeric($last_data['datos'])) {
|
2022-10-26 18:25:16 +02:00
|
|
|
$data = "<span class='span_treeview'>".remove_right_zeros(number_format($last_data['datos'], $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])).'</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
$data = ui_print_truncate_text(
|
|
|
|
io_safe_output($last_data['datos']),
|
|
|
|
GENERIC_SIZE_TEXT,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
'...',
|
|
|
|
'white-space: nowrap;'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
if (empty($last_data['utimestamp']) === false) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$last_data_str = $data;
|
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
if (empty($module['unit']) === false) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$data_macro = modules_get_unit_macro($last_data['datos'], $module['unit']);
|
2023-01-19 23:26:26 +01:00
|
|
|
if ($data_macro !== false) {
|
|
|
|
if (is_numeric($data_macro) === true) {
|
2022-10-26 18:25:16 +02:00
|
|
|
$last_data_str = "<span class='span_treeview'>".remove_right_zeros(number_format($data_macro, $config['graph_precision'], $config['decimal_separator'], $config['thousand_separator'])).'</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
$last_data_str = ui_print_truncate_text(
|
|
|
|
io_safe_output($data_macro),
|
|
|
|
GENERIC_SIZE_TEXT,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
'...',
|
|
|
|
'white-space: nowrap;'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$last_data_str .= ' ';
|
2023-01-19 23:26:26 +01:00
|
|
|
$last_data_str .= '<span class="span_treeview">('.$module['unit'].')</span>';
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$last_data_str .= ' ';
|
2023-01-19 23:26:26 +01:00
|
|
|
$last_data_str .= html_print_image('images/clock.svg', true, ['title' => $last_data['timestamp'], 'style' => 'margin-top: 3px; width: 20px', 'class' => 'invert_filter']);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
$is_snapshot = is_snapshot_data($last_data['datos']);
|
|
|
|
$is_large_image = is_text_to_black_string($last_data['datos']);
|
|
|
|
if (($config['command_snapshot']) && ($is_snapshot || $is_large_image)) {
|
|
|
|
$link = ui_get_snapshot_link(
|
|
|
|
[
|
|
|
|
'id_module' => $module['id_agente_modulo'],
|
|
|
|
'interval' => $module['current_interval'],
|
|
|
|
'module_name' => $module['module_name'],
|
|
|
|
'id_node' => empty($server_id) ? 0 : $server_id,
|
|
|
|
]
|
|
|
|
);
|
|
|
|
$salida = ui_get_snapshot_image($link, $is_snapshot).' ';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($salida !== null) {
|
2021-04-14 15:09:19 +02:00
|
|
|
$last_data_str = html_print_image('images/clock2.png', true, ['title' => $last_data['timestamp'], 'width' => '18px', 'class' => 'invert_filter']);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$last_data_str .= $salida;
|
|
|
|
} else {
|
|
|
|
$last_data_str = '<i>'.__('No data').'</i>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Last data');
|
|
|
|
$row['data'] = $last_data_str;
|
|
|
|
$table->data['last_data'] = $row;
|
|
|
|
|
2020-03-23 12:47:58 +01:00
|
|
|
// Last status change.
|
|
|
|
$last_status_change = db_get_value('last_status_change', 'tagente_estado', 'id_agente_modulo', $module['id_agente_modulo']);
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Last status change');
|
2020-03-25 17:40:05 +01:00
|
|
|
$time_elapsed = ($last_status_change > 0) ? human_time_comparation($last_status_change) : __('N/A');
|
|
|
|
$row['data'] = $time_elapsed;
|
2020-03-23 12:47:58 +01:00
|
|
|
$table->data['tags'] = $row;
|
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
// Title.
|
2023-01-30 13:39:27 +01:00
|
|
|
echo '<span id="fixedBottomHeadTitle" style="display:none">'.__('Module information').'</span>';
|
2023-01-19 23:26:26 +01:00
|
|
|
// End of table.
|
2019-01-30 16:18:44 +01:00
|
|
|
html_print_table($table);
|
|
|
|
|
|
|
|
$id_group = agents_get_agent_group($module['id_agente']);
|
|
|
|
$group_name = db_get_value('nombre', 'tgrupo', 'id_grupo', $id_group);
|
|
|
|
$agent_name = db_get_value('nombre', 'tagente', 'id_agente', $module['id_agente']);
|
|
|
|
|
2023-04-04 15:43:02 +02:00
|
|
|
if ($user_access_node && check_acl($config['id_user'], $id_group, 'AW')) {
|
|
|
|
echo '<div class="actions_treeview flex flex-evenly">';
|
2023-05-05 13:04:02 +02:00
|
|
|
|
|
|
|
if (is_metaconsole() === true) {
|
2024-04-10 10:50:11 +02:00
|
|
|
echo '<a target=_blank onclick="redirectNode(\''.$console_url.'index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&tab=module&edit_module=1&id_agente='.$module['id_agente'].'&id_agent_module='.$module['id_agente_modulo'].'\')" href="#">';
|
2023-05-05 13:04:02 +02:00
|
|
|
} else {
|
2024-04-10 10:50:11 +02:00
|
|
|
echo '<a target=_blank href="'.$console_url.'index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&id_agente='.$module['id_agente'].'&tab=module&edit_module=1&id_agent_module='.$module['id_agente_modulo'].'">';
|
2023-05-05 13:04:02 +02:00
|
|
|
}
|
|
|
|
|
2023-04-04 15:43:02 +02:00
|
|
|
html_print_submit_button(
|
|
|
|
__('Go to module edition'),
|
|
|
|
'upd_button',
|
|
|
|
false,
|
|
|
|
['class' => 'secondary mini']
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
echo '</a>';
|
|
|
|
|
|
|
|
echo '</div>';
|
2023-04-04 15:43:02 +02:00
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
// id_module and id_agent hidden
|
2021-03-11 15:40:23 +01:00
|
|
|
echo '<div id="ids" class="invisible">';
|
2019-01-30 16:18:44 +01:00
|
|
|
html_print_input_text('id_module', $id_module);
|
|
|
|
html_print_input_text('id_agent', $module['id_agente']);
|
|
|
|
html_print_input_text('server_name', $server_name);
|
|
|
|
echo '</div>';
|
|
|
|
|
|
|
|
if (!empty($server_data) && is_metaconsole()) {
|
|
|
|
metaconsole_restore_db();
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
2013-01-29 11:22:59 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
function treeview_printAlertsTable($id_module, $server_data=[], $no_head=false)
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
if (empty($server_data)) {
|
|
|
|
$server_name = '';
|
|
|
|
$server_id = '';
|
|
|
|
$console_url = '';
|
|
|
|
} else {
|
|
|
|
$server_name = $server_data['server_name'];
|
|
|
|
$server_id = $server_data['id'];
|
|
|
|
$console_url = $server_data['server_url'].'/';
|
|
|
|
}
|
|
|
|
|
|
|
|
$user_access_node = can_user_access_node();
|
|
|
|
|
|
|
|
if (is_metaconsole()) {
|
|
|
|
if (metaconsole_connect($server_data) != NOERR) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$module_alerts = alerts_get_alerts_agent_module($id_module);
|
|
|
|
$module_name = db_get_value('nombre', 'tagente_modulo', 'id_agente_modulo', $id_module);
|
|
|
|
$agent_id = db_get_value('id_agente', 'tagente_modulo', 'id_agente_modulo', $id_module);
|
|
|
|
$id_group = agents_get_agent_group($agent_id);
|
|
|
|
|
|
|
|
if ($module_alerts === false) {
|
|
|
|
ui_print_error_message(__('There was a problem loading alerts'));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$table = new StdClass();
|
|
|
|
$table->width = '100%';
|
|
|
|
$table->class = 'databox data';
|
|
|
|
$table->rowstyle = [];
|
|
|
|
$table->rowstyle['titles'] = 'font-weight: bold;';
|
|
|
|
|
|
|
|
if (!$no_head) {
|
|
|
|
$table->head = [];
|
|
|
|
$table->head[] = __('Alerts').': '.$module_name;
|
|
|
|
}
|
|
|
|
|
|
|
|
$table->head_colspan[] = 2;
|
|
|
|
$table->data = [];
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['template'] = __('Template');
|
|
|
|
$row['actions'] = __('Actions');
|
|
|
|
$table->data['titles'] = $row;
|
|
|
|
|
|
|
|
foreach ($module_alerts as $module_alert) {
|
|
|
|
// Template name
|
|
|
|
$template_name = db_get_value('name', 'talert_templates', 'id', $module_alert['id_alert_template']);
|
|
|
|
|
|
|
|
$actions = alerts_get_alert_agent_module_actions($module_alert['id']);
|
|
|
|
|
|
|
|
if (empty($actions)) {
|
|
|
|
$actions_list = '<i>'.__('N/A').'</i>';
|
|
|
|
} else {
|
|
|
|
$actions_list = '<ul>';
|
|
|
|
foreach ($actions as $act) {
|
|
|
|
$actions_list .= '<li>';
|
|
|
|
$actions_list .= $act['name'];
|
|
|
|
$actions_list .= '</li>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$actions_list .= '</ul>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['template'] = $template_name;
|
|
|
|
$row['actions'] = $actions_list;
|
|
|
|
$table->data['last_data'] = $row;
|
|
|
|
}
|
|
|
|
|
|
|
|
html_print_table($table);
|
|
|
|
|
|
|
|
$table2 = new StdClass();
|
|
|
|
$table2->width = '100%';
|
|
|
|
$table2->class = 'databox data';
|
|
|
|
$table2->rowstyle = [];
|
|
|
|
$table2->rowstyle['titles'] = 'font-weight: bold;';
|
|
|
|
|
|
|
|
$table2->head_colspan[] = 3;
|
|
|
|
$table2->data = [];
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['template'] = __('Template');
|
|
|
|
$row['times_fired'] = __('Times fired');
|
|
|
|
$row['last_fired'] = __('Last fired');
|
|
|
|
$table2->data['titles'] = $row;
|
|
|
|
|
|
|
|
foreach ($module_alerts as $module_alert) {
|
|
|
|
$template_name = db_get_value('name', 'talert_templates', 'id', $module_alert['id_alert_template']);
|
|
|
|
|
|
|
|
$times_fired = $module_alert['times_fired'];
|
|
|
|
|
|
|
|
$last_fired = date($config['date_format'], $module_alert['last_fired']);
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['template'] = $template_name;
|
|
|
|
$row['times_fired'] = $times_fired;
|
|
|
|
$row['last_fired'] = $last_fired;
|
|
|
|
$table2->data['last_data'] = $row;
|
|
|
|
}
|
|
|
|
|
|
|
|
html_print_table($table2);
|
|
|
|
|
|
|
|
if ($user_access_node && check_acl($config['id_user'], $id_group, 'LW')) {
|
2023-02-24 13:49:15 +01:00
|
|
|
// Actions button.
|
|
|
|
html_print_div(
|
|
|
|
[
|
|
|
|
'class' => 'action-buttons',
|
|
|
|
'content' => html_print_button(
|
|
|
|
__('Go to alerts edition'),
|
|
|
|
'upd_button',
|
|
|
|
false,
|
2024-04-10 10:50:11 +02:00
|
|
|
'redirectNode("'.$console_url.'index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&tab=alert&search=1&module_name='.$module_name.'&id_agente='.$agent_id.'")',
|
2023-02-24 13:49:15 +01:00
|
|
|
['icon' => 'alert'],
|
|
|
|
true
|
|
|
|
),
|
|
|
|
]
|
2023-02-24 13:43:10 +01:00
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2023-02-24 13:43:10 +01:00
|
|
|
if (empty($server_data) === false && is_metaconsole() === true) {
|
2019-01-30 16:18:44 +01:00
|
|
|
metaconsole_restore_db();
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
2013-01-09 10:25:07 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
function treeview_printTable($id_agente, $server_data=[], $no_head=false)
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
if (empty($server_data)) {
|
|
|
|
$server_id = '';
|
2020-07-22 10:56:16 +02:00
|
|
|
$console_url = ui_get_full_url('/');
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
$server_id = $server_data['id'];
|
|
|
|
$console_url = $server_data['server_url'].'/';
|
|
|
|
}
|
|
|
|
|
|
|
|
include_once $config['homedir'].'/include/functions_agents.php';
|
|
|
|
include_once $config['homedir'].'/include/functions_graph.php';
|
|
|
|
include_once $config['homedir'].'/include/functions_groups.php';
|
|
|
|
include_once $config['homedir'].'/include/functions_gis.php';
|
|
|
|
enterprise_include_once('meta/include/functions_ui_meta.php');
|
|
|
|
include_graphs_dependencies();
|
|
|
|
|
|
|
|
$user_access_node = can_user_access_node();
|
|
|
|
|
|
|
|
if (is_metaconsole()) {
|
|
|
|
if (metaconsole_connect($server_data) != NOERR) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-25 15:52:31 +01:00
|
|
|
// Get the agent info.
|
2019-01-30 16:18:44 +01:00
|
|
|
$agent = db_get_row('tagente', 'id_agente', $id_agente);
|
|
|
|
if ($agent == false) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-11-25 15:52:31 +01:00
|
|
|
// Check all groups.
|
2019-01-30 16:18:44 +01:00
|
|
|
$groups = agents_get_all_groups_agent($id_agente, $agent['id_grupo']);
|
2020-11-16 19:16:25 +01:00
|
|
|
|
2020-11-25 15:52:31 +01:00
|
|
|
if (is_metaconsole() === true) {
|
2020-11-16 19:16:25 +01:00
|
|
|
if (! check_acl_one_of_groups($config['id_user'], $groups, 'AR', false)
|
|
|
|
&& ! check_acl_one_of_groups($config['id_user'], $groups, 'AW', false)
|
|
|
|
) {
|
|
|
|
$grants_on_node = false;
|
|
|
|
} else {
|
|
|
|
$grants_on_node = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-25 15:52:31 +01:00
|
|
|
if (is_metaconsole() === true) {
|
2020-11-16 19:16:25 +01:00
|
|
|
metaconsole_restore_db();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! check_acl_one_of_groups($config['id_user'], $groups, 'AR', false)
|
|
|
|
&& ! check_acl_one_of_groups($config['id_user'], $groups, 'AW', false)
|
|
|
|
) {
|
2019-01-30 16:18:44 +01:00
|
|
|
db_pandora_audit(
|
2022-01-20 10:55:23 +01:00
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
2019-01-30 16:18:44 +01:00
|
|
|
'Trying to access Agent General Information'
|
|
|
|
);
|
|
|
|
include_once 'general/noaccess.php';
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-11-25 15:52:31 +01:00
|
|
|
if (is_metaconsole()) {
|
|
|
|
if (metaconsole_connect($server_data) != NOERR) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
if ($agent === false) {
|
|
|
|
ui_print_error_message(__('There was a problem loading agent'));
|
|
|
|
if (!empty($server_data) && is_metaconsole()) {
|
|
|
|
metaconsole_restore_db();
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$table = new StdClass();
|
|
|
|
$table->width = '100%';
|
2023-01-30 13:39:27 +01:00
|
|
|
$table->class = 'floating_form border-bottom-gray';
|
2023-01-19 23:26:26 +01:00
|
|
|
$table->id = 'tree_view_agent_detail';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->style = [];
|
2023-01-26 13:25:24 +01:00
|
|
|
$table->style['title'] = 'height: 32px; width: 30%; padding-right: 5px; text-align: end;';
|
2023-02-23 14:30:31 +01:00
|
|
|
$table->style['data'] = 'height: 32px; width: 70%; padding-left: 5px;font-weight: lighter;';
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->head = [];
|
|
|
|
$table->data = [];
|
|
|
|
|
2020-07-22 10:56:16 +02:00
|
|
|
// Agent name.
|
2023-01-26 13:25:24 +01:00
|
|
|
$cellName = ((bool) $agent['disabled'] === true) ? '<em>' : '';
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-01-26 13:25:24 +01:00
|
|
|
if (is_metaconsole() === true) {
|
|
|
|
if ((bool) $grants_on_node === true && (bool) $user_access_node !== false) {
|
2023-03-08 15:45:18 +01:00
|
|
|
$urlAgent = $server_data['server_url'].'/index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente='.$agent['id_agente'];
|
2020-11-16 19:16:25 +01:00
|
|
|
} else {
|
2023-01-26 13:25:24 +01:00
|
|
|
$urlAgent = '';
|
2020-11-16 19:16:25 +01:00
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
2023-02-24 13:37:47 +01:00
|
|
|
$urlAgent = 'index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente='.$agent['id_agente'];
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2023-01-26 13:25:24 +01:00
|
|
|
$cellName = $agent['alias'];
|
|
|
|
|
|
|
|
if ((bool) $agent['disabled'] === true) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$cellName .= ui_print_help_tip(__('Disabled'), true).'</em>';
|
|
|
|
}
|
|
|
|
|
2023-02-01 15:14:32 +01:00
|
|
|
// Agent name.
|
2019-01-30 16:18:44 +01:00
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Agent name');
|
2023-07-12 13:54:06 +02:00
|
|
|
if (is_metaconsole() === true) {
|
|
|
|
$row['data'] = html_print_anchor(
|
|
|
|
[
|
|
|
|
'href' => 'javascript:void(0)',
|
|
|
|
'title' => __('Click here for view this agent'),
|
|
|
|
'class' => 'font_11',
|
|
|
|
'content' => $cellName,
|
2024-04-10 10:50:11 +02:00
|
|
|
'onClick' => "redirectNode('".$urlAgent."')",
|
2023-07-12 13:54:06 +02:00
|
|
|
],
|
|
|
|
true
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$row['data'] = html_print_anchor(
|
|
|
|
[
|
|
|
|
'href' => $urlAgent,
|
|
|
|
'title' => __('Click here for view this agent'),
|
|
|
|
'class' => 'font_11',
|
|
|
|
'content' => $cellName,
|
|
|
|
],
|
|
|
|
true
|
|
|
|
);
|
|
|
|
}
|
2023-02-01 15:14:32 +01:00
|
|
|
|
|
|
|
$table->data['name'] = $row;
|
2023-01-30 13:39:27 +01:00
|
|
|
|
2020-07-22 10:56:16 +02:00
|
|
|
// Addresses.
|
2019-01-30 16:18:44 +01:00
|
|
|
$ips = [];
|
|
|
|
$addresses = agents_get_addresses($id_agente);
|
|
|
|
$address = agents_get_address($id_agente);
|
|
|
|
|
|
|
|
foreach ($addresses as $k => $add) {
|
|
|
|
if ($add == $address) {
|
|
|
|
unset($addresses[$k]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-22 10:56:16 +02:00
|
|
|
if (empty($addresses) === false) {
|
|
|
|
$address .= ui_print_help_tip(
|
|
|
|
__('Other IP addresses').': <br>'.implode('<br>', $addresses),
|
|
|
|
true
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2023-01-26 13:25:24 +01:00
|
|
|
if (empty($address) === true) {
|
|
|
|
$address = __('N/A');
|
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('IP Address');
|
|
|
|
$row['data'] = $address;
|
|
|
|
$table->data['address'] = $row;
|
|
|
|
|
2020-07-22 10:56:16 +02:00
|
|
|
// Agent Interval.
|
2019-01-30 16:18:44 +01:00
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Interval');
|
|
|
|
$row['data'] = human_time_description_raw($agent['intervalo']);
|
|
|
|
$table->data['interval'] = $row;
|
|
|
|
|
2023-09-20 13:51:56 +02:00
|
|
|
if (isset($agent['quiet']) && $agent['quiet']) {
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Quiet mode enabled');
|
|
|
|
$row['data'] = ui_print_help_tip(__('This agent would not raise events or alerts'), true);
|
|
|
|
$table->data['quiet'] = $row;
|
|
|
|
}
|
|
|
|
|
2020-07-22 10:56:16 +02:00
|
|
|
// Comments.
|
2019-01-30 16:18:44 +01:00
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Description');
|
|
|
|
$row['data'] = $agent['comentarios'];
|
|
|
|
$table->data['description'] = $row;
|
|
|
|
|
2020-07-22 10:56:16 +02:00
|
|
|
// Last contact.
|
2023-03-21 18:12:02 +01:00
|
|
|
$last_contact = ui_print_timestamp($agent['ultimo_contacto'], true, ['style' => 'font-size: 13px;']);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-01-26 13:25:24 +01:00
|
|
|
if ($agent['ultimo_contacto_remoto'] === '01-01-1970 00:00:00') {
|
2019-01-30 16:18:44 +01:00
|
|
|
$last_remote_contact = __('Never');
|
|
|
|
} else {
|
2020-07-22 10:56:16 +02:00
|
|
|
$last_remote_contact = date_w_fixed_tz(
|
|
|
|
$agent['ultimo_contacto_remoto']
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$row = [];
|
2023-01-26 13:25:24 +01:00
|
|
|
$row['title'] = __('Last contact');
|
|
|
|
$row['data'] = $last_contact;
|
|
|
|
$table->data['last_contact'] = $row;
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Remote contact');
|
|
|
|
$row['data'] = $last_remote_contact;
|
|
|
|
$table->data['remote_contact'] = $row;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2020-07-22 10:56:16 +02:00
|
|
|
// Next contact (agent).
|
2019-01-30 16:18:44 +01:00
|
|
|
$progress = agents_get_next_contact($id_agente);
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Next agent contact');
|
2019-06-03 19:13:29 +02:00
|
|
|
$row['data'] = ui_progress(
|
|
|
|
$progress,
|
2023-01-30 13:39:27 +01:00
|
|
|
'80%',
|
2023-01-26 13:25:24 +01:00
|
|
|
'1.2',
|
|
|
|
'#ececec',
|
|
|
|
true,
|
|
|
|
'',
|
2023-03-21 18:12:02 +01:00
|
|
|
false
|
2019-06-03 19:13:29 +02:00
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
$table->data['next_contact'] = $row;
|
|
|
|
|
2023-01-30 13:39:27 +01:00
|
|
|
// Title.
|
|
|
|
echo '<span id="fixedBottomHeadTitle" style="display:none">'.__('Agent information').'</span>';
|
2023-01-19 23:26:26 +01:00
|
|
|
// Print agent data toggle.
|
2023-02-01 15:14:32 +01:00
|
|
|
html_print_table($table);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-02-01 15:14:32 +01:00
|
|
|
// Events graph toggle.
|
|
|
|
$eventsGraph = html_print_div(
|
|
|
|
[
|
2023-03-06 13:32:21 +01:00
|
|
|
'style' => 'height: 150px;',
|
2023-03-22 11:23:07 +01:00
|
|
|
'class' => 'max-graph-tree-view',
|
2023-02-01 15:14:32 +01:00
|
|
|
'content' => graph_graphic_agentevents(
|
|
|
|
$id_agente,
|
|
|
|
'500px;',
|
|
|
|
'100px',
|
|
|
|
SECONDS_1DAY,
|
|
|
|
'',
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
550,
|
|
|
|
1,
|
|
|
|
$server_id
|
|
|
|
),
|
|
|
|
],
|
|
|
|
true
|
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-01-19 23:26:26 +01:00
|
|
|
ui_toggle(
|
2023-02-01 15:14:32 +01:00
|
|
|
$eventsGraph,
|
2023-02-24 13:37:47 +01:00
|
|
|
'<span class="subsection_header_title secondary">'.__('Events (24h)').'</span>',
|
2023-01-19 23:26:26 +01:00
|
|
|
'',
|
|
|
|
'',
|
2023-02-01 15:14:32 +01:00
|
|
|
false,
|
2023-01-19 23:26:26 +01:00
|
|
|
false,
|
|
|
|
'',
|
2023-09-01 10:28:02 +02:00
|
|
|
'white-box-content-no-height mrgn_top_0 mrgn_btn_0px',
|
2023-03-13 09:35:12 +01:00
|
|
|
'white_table_flex'
|
2023-01-19 23:26:26 +01:00
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
if ($config['agentaccess']) {
|
2023-03-06 13:32:21 +01:00
|
|
|
$access_graph = '<div style="height: 150px;" class="w100p center">';
|
2020-03-26 12:29:38 +01:00
|
|
|
$access_graph .= graphic_agentaccess(
|
|
|
|
$id_agente,
|
|
|
|
SECONDS_1DAY,
|
2020-04-13 16:42:46 +02:00
|
|
|
false
|
2020-03-26 12:29:38 +01:00
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
$access_graph .= '</div>';
|
2020-04-13 16:42:46 +02:00
|
|
|
ui_toggle(
|
|
|
|
$access_graph,
|
2023-02-24 13:37:47 +01:00
|
|
|
'<span class="subsection_header_title secondary">'.__('Agent access rate (24h)').'</span>',
|
2023-01-19 23:26:26 +01:00
|
|
|
'',
|
|
|
|
'',
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
'',
|
2023-09-01 10:28:02 +02:00
|
|
|
'white-box-content-no-height mrgn_top_0 mrgn_btn_0px border-bottom-gray',
|
2023-03-13 09:35:12 +01:00
|
|
|
'white_table_flex'
|
2020-04-13 16:42:46 +02:00
|
|
|
);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2023-01-30 13:39:27 +01:00
|
|
|
// Table network interfaces.
|
2019-01-30 16:18:44 +01:00
|
|
|
$network_interfaces_by_agents = agents_get_network_interfaces([$agent]);
|
|
|
|
|
|
|
|
$network_interfaces = [];
|
2023-01-30 13:39:27 +01:00
|
|
|
if (empty($network_interfaces_by_agents) === false && empty($network_interfaces_by_agents[$id_agente]) === false) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$network_interfaces = $network_interfaces_by_agents[$id_agente]['interfaces'];
|
|
|
|
}
|
|
|
|
|
2023-01-30 13:39:27 +01:00
|
|
|
if (empty($network_interfaces) === false) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$table = new stdClass();
|
|
|
|
$table->id = 'agent_interface_info';
|
|
|
|
$table->class = 'databox';
|
|
|
|
$table->width = '100%';
|
|
|
|
$table->style = [];
|
|
|
|
$table->style['interface_status'] = 'width: 30px;';
|
|
|
|
$table->style['interface_graph'] = 'width: 20px;';
|
|
|
|
$table->head = [];
|
|
|
|
$table->data = [];
|
|
|
|
|
|
|
|
foreach ($network_interfaces as $interface_name => $interface) {
|
2023-01-30 13:39:27 +01:00
|
|
|
if (empty($interface['traffic']) === false) {
|
|
|
|
$permission = (bool) check_acl($config['id_user'], $agent['id_grupo'], 'RR');
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2023-01-30 13:39:27 +01:00
|
|
|
if ($permission === true) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$params = [
|
|
|
|
'interface_name' => $interface_name,
|
|
|
|
'agent_id' => $id_agente,
|
|
|
|
'traffic_module_in' => $interface['traffic']['in'],
|
|
|
|
'traffic_module_out' => $interface['traffic']['out'],
|
|
|
|
];
|
|
|
|
|
2023-01-30 13:39:27 +01:00
|
|
|
if (is_metaconsole() === true && empty($server_id) === false) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$params['server'] = $server_id;
|
|
|
|
}
|
|
|
|
|
|
|
|
$params_json = json_encode($params);
|
|
|
|
$params_encoded = base64_encode($params_json);
|
|
|
|
$url = ui_get_full_url('operation/agentes/interface_traffic_graph_win.php', false, false, false);
|
2023-01-30 13:39:27 +01:00
|
|
|
$graph_url = $url.'?params='.$params_encoded;
|
2019-01-30 16:18:44 +01:00
|
|
|
$win_handle = dechex(crc32($interface['status_module_id'].$interface_name));
|
|
|
|
|
2020-10-01 15:29:54 +02:00
|
|
|
$graph_link = "<a href=\"javascript:winopeng_var('".$graph_url."','".$win_handle."', 800, 480)\">";
|
|
|
|
$graph_link .= html_print_image(
|
|
|
|
'images/chart_curve.png',
|
|
|
|
true,
|
|
|
|
['title' => __('Interface traffic')]
|
|
|
|
);
|
|
|
|
$graph_link .= '</a>';
|
2019-01-30 16:18:44 +01:00
|
|
|
} else {
|
|
|
|
$graph_link = '';
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$graph_link = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data = [];
|
|
|
|
$data['interface_name'] = '<strong>'.$interface_name.'</strong>';
|
|
|
|
$data['interface_status'] = $interface['status_image'];
|
|
|
|
$data['interface_graph'] = $graph_link;
|
|
|
|
$data['interface_ip'] = $interface['ip'];
|
|
|
|
$data['interface_mac'] = $interface['mac'];
|
|
|
|
$table->data[] = $data;
|
|
|
|
}
|
|
|
|
|
2023-01-30 13:39:27 +01:00
|
|
|
// End of table network interfaces.
|
2019-01-30 16:18:44 +01:00
|
|
|
$table_interfaces = html_print_table($table, true);
|
|
|
|
$table_interfaces .= '<br>';
|
|
|
|
|
2023-02-24 13:37:47 +01:00
|
|
|
ui_toggle($table_interfaces, '<span class="subsection_header_title secondary">'.__('Interface information').' (SNMP)</span>');
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2023-02-01 15:14:32 +01:00
|
|
|
// Advanced data.
|
|
|
|
$table_advanced = new StdClass();
|
|
|
|
$table_advanced->width = '100%';
|
|
|
|
$table_advanced->class = 'floating_form';
|
|
|
|
$table_advanced->id = 'tree_view_agent_advanced';
|
|
|
|
$table_advanced->style = [];
|
|
|
|
$table_advanced->style['title'] = 'height: 32px; width: 30%; padding-right: 5px; text-align: end;';
|
2023-02-23 14:30:31 +01:00
|
|
|
$table_advanced->style['data'] = 'height: 32px; width: 70%; padding-left: 5px;font-weight: lighter;';
|
2023-02-01 15:14:32 +01:00
|
|
|
$table_advanced->head = [];
|
|
|
|
$table_advanced->data = [];
|
|
|
|
|
2023-07-24 14:54:38 +02:00
|
|
|
$row = [];
|
|
|
|
// Agent version.
|
|
|
|
if (!empty($agent['agent_version'])) {
|
2023-02-01 15:14:32 +01:00
|
|
|
$row['title'] = __('Agent Version');
|
|
|
|
$row['data'] = $agent['agent_version'];
|
|
|
|
$table_advanced->data['agent_version'] = $row;
|
2023-07-24 14:54:38 +02:00
|
|
|
}
|
2023-02-01 15:14:32 +01:00
|
|
|
|
|
|
|
// Position Information.
|
|
|
|
if ($config['activate_gis']) {
|
|
|
|
$dataPositionAgent = gis_get_data_last_position_agent($agent['id_agente']);
|
|
|
|
|
|
|
|
if ($dataPositionAgent !== false) {
|
|
|
|
if (empty($dataPositionAgent['description']) === false) {
|
|
|
|
$positionContent .= $dataPositionAgent['description'];
|
|
|
|
} else {
|
|
|
|
$positionContent .= $dataPositionAgent['stored_longitude'].', '.$dataPositionAgent['stored_latitude'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$position = html_print_anchor(
|
|
|
|
[
|
|
|
|
'href' => $console_url.'index.php?sec=estado&sec2=operation/agentes/ver_agente&tab=gis&id_agente='.$id_agente,
|
|
|
|
'content' => $positionContent,
|
|
|
|
],
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Position (Long, Lat)');
|
|
|
|
$row['data'] = $position;
|
|
|
|
$table_advanced->data['agent_position'] = $row;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// If the url description is setted.
|
|
|
|
if (empty($agent['url_address']) === false) {
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Url address');
|
|
|
|
$row['data'] = html_print_anchor(
|
|
|
|
[
|
|
|
|
'href' => $agent['url_address'],
|
|
|
|
'content' => $agent['url_address'],
|
|
|
|
],
|
|
|
|
true
|
|
|
|
);
|
|
|
|
$table_advanced->data['agent_address'] = $row;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Timezone Offset.
|
|
|
|
if ($agent['timezone_offset'] != 0) {
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = __('Timezone Offset');
|
|
|
|
$row['data'] = $agent['timezone_offset'];
|
|
|
|
$table_advanced->data['agent_timezone_offset'] = $row;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Custom fields.
|
|
|
|
$fields = db_get_all_rows_filter('tagent_custom_fields', ['display_on_front' => 1]);
|
|
|
|
if ($fields === false) {
|
|
|
|
$fields = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($fields) {
|
|
|
|
foreach ($fields as $field) {
|
|
|
|
$custom_value = db_get_value_filter('description', 'tagent_custom_data', ['id_field' => $field['id_field'], 'id_agent' => $id_agente]);
|
|
|
|
if (empty($custom_value) === false) {
|
|
|
|
$row = [];
|
|
|
|
$row['title'] = $field['name'].ui_print_help_tip(__('Custom field'), true);
|
|
|
|
if ($field['is_password_type']) {
|
|
|
|
$row['data'] = '••••••••';
|
|
|
|
} else {
|
|
|
|
$row['data'] = ui_bbcode_to_html($custom_value);
|
|
|
|
}
|
|
|
|
|
|
|
|
$table_advanced->data['custom_field_'.$field['id_field']] = $row;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// End of table advanced.
|
|
|
|
ui_toggle(
|
|
|
|
html_print_table($table_advanced, true),
|
2023-02-24 13:37:47 +01:00
|
|
|
'<span class="subsection_header_title secondary">'.__('Advanced information').'</span>',
|
2023-02-01 15:14:32 +01:00
|
|
|
'',
|
|
|
|
'',
|
|
|
|
true,
|
2023-07-24 14:54:38 +02:00
|
|
|
empty($table_advanced->data),
|
2023-02-01 15:14:32 +01:00
|
|
|
'',
|
2023-09-01 10:28:02 +02:00
|
|
|
'white-box-content-no-height mrgn_top_0 mrgn_btn_0px border-bottom-gray',
|
2023-04-04 15:43:02 +02:00
|
|
|
'white_table_flex'
|
2023-02-01 15:14:32 +01:00
|
|
|
);
|
|
|
|
|
2023-04-04 15:43:02 +02:00
|
|
|
if ($user_access_node && check_acl($config['id_user'], $agent['id_grupo'], 'AW')) {
|
|
|
|
$buttons_act = '<div style="text-align: right" class="margin-bottom-20 margin-top-20 flex flex-evenly">';
|
|
|
|
|
|
|
|
if ($agent['id_os'] == CLUSTER_OS_ID) {
|
|
|
|
$cluster = PandoraFMS\Cluster::loadFromAgentId(
|
|
|
|
$agent['id_agente']
|
|
|
|
);
|
2024-04-10 10:50:11 +02:00
|
|
|
$buttons_act .= '<a target=_blank href="#" onclick="redirectNode(\''.$console_url.'index.php?sec=reporting&sec2=operation/cluster/cluster&op=update&id='.$cluster->id().'\')">';
|
2023-04-04 15:43:02 +02:00
|
|
|
$buttons_act .= html_print_submit_button(
|
|
|
|
__('Go to cluster edition'),
|
|
|
|
'upd_button',
|
|
|
|
false,
|
|
|
|
['class' => 'secondary mini'],
|
|
|
|
true
|
|
|
|
);
|
|
|
|
} else {
|
2024-04-10 10:50:11 +02:00
|
|
|
$buttons_act .= '<a target=_blank href="#" onclick="redirectNode(\''.$console_url.'index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&id_agente='.$id_agente.'&tab=module&show_dialog_create=1\')">';
|
2023-04-04 15:43:02 +02:00
|
|
|
$buttons_act .= html_print_submit_button(
|
|
|
|
__('Go to module creation'),
|
|
|
|
'upd_button',
|
|
|
|
false,
|
2023-04-11 14:57:53 +02:00
|
|
|
['class' => 'secondary mini no_decoration'],
|
2023-04-04 15:43:02 +02:00
|
|
|
true
|
|
|
|
);
|
|
|
|
|
2024-04-10 10:50:11 +02:00
|
|
|
$buttons_act .= '<a target=_blank href="#" onclick="redirectNode(\''.$console_url.'index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&id_agente='.$id_agente.'\')">';
|
2023-04-04 15:43:02 +02:00
|
|
|
$buttons_act .= html_print_submit_button(
|
|
|
|
__('Go to agent edition'),
|
|
|
|
'upd_button',
|
|
|
|
false,
|
2023-04-11 14:57:53 +02:00
|
|
|
['class' => 'secondary mini no_decoration'],
|
2023-04-04 15:43:02 +02:00
|
|
|
true
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$buttons_act .= '</a>';
|
|
|
|
$buttons_act .= '</div>';
|
|
|
|
}
|
|
|
|
|
|
|
|
echo $buttons_act;
|
|
|
|
|
2023-02-01 15:14:32 +01:00
|
|
|
if (empty($server_data) === false && is_metaconsole() === true) {
|
2019-01-30 16:18:44 +01:00
|
|
|
metaconsole_restore_db();
|
|
|
|
}
|
|
|
|
|
2022-10-27 12:35:31 +02:00
|
|
|
echo "
|
|
|
|
<script>
|
2023-03-22 11:23:07 +01:00
|
|
|
$('.max-graph-tree-view').ready(function() {
|
|
|
|
widthGraph();
|
|
|
|
});
|
|
|
|
|
|
|
|
$(window).resize(function() {
|
|
|
|
widthGraph();
|
|
|
|
});
|
|
|
|
|
|
|
|
function widthGraph () {
|
|
|
|
var parentWidth = $('.max-graph-tree-view').parent().width();
|
|
|
|
$('.max-graph-tree-view').children().width(parentWidth + 5);
|
2023-03-22 20:00:42 +01:00
|
|
|
|
|
|
|
$('<input>').attr({
|
|
|
|
type: 'hidden',
|
|
|
|
id: 'graph-counter',
|
|
|
|
value: 1
|
2023-03-28 17:07:06 +02:00
|
|
|
}).appendTo('body');
|
2023-03-22 20:00:42 +01:00
|
|
|
|
|
|
|
|
|
|
|
if ($('#graph-counter').val() == 1) {
|
|
|
|
$('.max-graph-tree-view div.flot-x-axis').css('inset', '-25px').css('margin-top', '10px').css('margin-left', '10px');
|
|
|
|
$('.max-graph-tree-view canvas.flot-base').css('height', '85px');
|
|
|
|
$('#graph-counter').val(2);
|
|
|
|
}
|
|
|
|
|
2023-03-22 11:23:07 +01:00
|
|
|
}
|
|
|
|
|
2022-10-27 12:35:31 +02:00
|
|
|
</script>";
|
2012-08-22 16:09:05 +02:00
|
|
|
}
|