pandorafms/pandora_console/include/functions_treeview.php

910 lines
31 KiB
PHP
Raw Normal View History

<?php
// Pandora FMS - http://pandorafms.com
// ==================================================
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 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.
function treeview_printModuleTable($id_module, $server_data=false, $no_head=false)
{
global $config;
if (empty($server_data)) {
$server_name = '';
$server_id = '';
$url_hash = '';
2020-07-22 10:56:16 +02:00
$console_url = ui_get_full_url('/');
} else {
$server_name = $server_data['server_name'];
$server_id = $server_data['id'];
$console_url = $server_data['server_url'].'/';
$url_hash = metaconsole_get_servers_url_hash($server_data);
}
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%';
$table->class = 'databox data';
$table->style = [];
$table->style['title'] = 'font-weight: bold;';
if (!$no_head) {
$table->head = [];
$table->head[] = __('Module');
}
$table->head_colspan[] = 2;
$table->data = [];
// Module name
if ($module['disabled']) {
2021-08-18 13:57:47 +02:00
$cellName = '<em>'.ui_print_truncate_text($module['nombre'], GENERIC_SIZE_TEXT, true, true, true, '[&hellip;]', 'text-transform: uppercase;').ui_print_help_tip(__('Disabled'), true).'<em>';
} else {
2021-08-18 13:57:47 +02:00
$cellName = ui_print_truncate_text($module['nombre'], GENERIC_SIZE_TEXT, true, true, true, '[&hellip;]', 'text-transform: uppercase;');
}
$row = [];
$row['title'] = __('Name');
$row['data'] = '<b>'.$cellName.'</b>';
$table->data['name'] = $row;
// Interval
$row = [];
$row['title'] = __('Interval');
$row['data'] = human_time_description_raw(modules_get_interval($module['id_agente_modulo']), true);
$table->data['interval'] = $row;
// Warning Min/Max
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;
$table->data['warning_status'] = $row;
// Critical Min/Max
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;
// Module group
$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');
2020-04-02 14:30:02 +02:00
$row['data'] = ui_print_truncate_text(
2020-04-13 16:42:46 +02:00
$module['descripcion'],
2020-04-02 14:30:02 +02:00
'description',
true,
true,
true,
'[&hellip;]'
);
$table->data['description'] = $row;
// Tags
$tags = tags_get_module_tags($module['id_agente_modulo']);
if (empty($tags)) {
$tags = [];
}
$user_tags = tags_get_user_tags($config['id_user']);
foreach ($tags as $k => $v) {
if (!array_key_exists($v, $user_tags)) {
// only show user's tags.
unset($tags[$k]);
} else {
$tag_name = tags_get_name($v);
if (empty($tag_name)) {
unset($tags[$k]);
} else {
$tags[$k] = $tag_name;
}
}
}
if (empty($tags)) {
$tags = '<i>'.__('N/A').'</i>';
} else {
$tags = implode(', ', $tags);
}
$row = [];
$row['title'] = __('Tags');
$row['data'] = $tags;
$table->data['tags'] = $row;
// Data
$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) {
$data = "<span class='span_treeview'>".$config['render_proc_ok'].'</span>';
} else {
$data = "<span class='span_treeview'>".$config['render_proc_fail'].'</span>';
}
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') {
$data = "<span title='".$last_data['datos']."' class='nowrap'>".human_milliseconds_to_string($last_data['datos']).'</span>';
} else if (is_numeric($last_data['datos'])) {
$data = "<span class='span_treeview'>".remove_right_zeros(number_format($last_data['datos'], $config['graph_precision'])).'</span>';
} 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'])) {
$data = "<span class='span_treeview'>".remove_right_zeros(number_format($last_data['datos'], $config['graph_precision'])).'</span>';
} 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']);
if ($value == '.1.3.6.1.2.1.1.3.0' || $value == '.1.3.6.1.2.1.25.1.1.0') {
$data = "<span title='".human_milliseconds_to_string($last_data['datos'])."' class='nowrap'>".human_milliseconds_to_string($last_data['datos']).'</span>';
} else if (is_numeric($last_data['datos'])) {
$data = "<span class='span_treeview'>".remove_right_zeros(number_format($last_data['datos'], $config['graph_precision'])).'</span>';
} 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'])) {
$data = "<span class='span_treeview'>".remove_right_zeros(number_format($last_data['datos'], $config['graph_precision'])).'</span>';
} else {
$data = ui_print_truncate_text(
io_safe_output($last_data['datos']),
GENERIC_SIZE_TEXT,
true,
true,
true,
'...',
'white-space: nowrap;'
);
}
break;
}
}
if (!empty($last_data['utimestamp'])) {
$last_data_str = $data;
if ($module['unit'] != '') {
$data_macro = modules_get_unit_macro($last_data['datos'], $module['unit']);
if ($data_macro) {
if (is_numeric($data_macro)) {
$last_data_str = "<span class='span_treeview'>".remove_right_zeros(number_format($data_macro, $config['graph_precision'])).'</span>';
} 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 .= '&nbsp;';
$last_data_str .= '('.$module['unit'].')';
}
}
$last_data_str .= '&nbsp;';
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']);
$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).'&nbsp;&nbsp;';
}
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']);
}
$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');
$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;
// End of table
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']);
if ($user_access_node && check_acl($config['id_user'], $id_group, 'AW')) {
// Actions table
2021-03-18 18:05:50 +01:00
echo '<div class="actions_treeview" style="text-align: right">';
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'].$url_hash.'">';
html_print_submit_button(__('Go to module edition'), 'upd_button', false, 'class="sub config"');
echo '</a>';
echo '</div>';
}
// id_module and id_agent hidden
echo '<div id="ids" class="invisible">';
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;
}
function treeview_printAlertsTable($id_module, $server_data=[], $no_head=false)
{
global $config;
if (empty($server_data)) {
$server_name = '';
$server_id = '';
$url_hash = '';
$console_url = '';
} else {
$server_name = $server_data['server_name'];
$server_id = $server_data['id'];
$console_url = $server_data['server_url'].'/';
$url_hash = metaconsole_get_servers_url_hash($server_data);
}
$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')) {
// Actions table
2021-03-26 14:40:55 +01:00
echo '<div class="w100p right mw300px right_align">';
echo '<a target=_blank href="'.$console_url.'index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&tab=alert&search=1&module_name='.$module_name.'&id_agente='.$agent_id.$url_hash.'" target="_blank">';
html_print_submit_button(__('Go to alerts edition'), 'upd_button', false, 'class="sub search"');
echo '</a>';
echo '</div>';
}
if (!empty($server_data) && is_metaconsole()) {
metaconsole_restore_db();
}
return;
}
function treeview_printTable($id_agente, $server_data=[], $no_head=false)
{
global $config;
if (empty($server_data)) {
$server_name = '';
$server_id = '';
$url_hash = '';
2020-07-22 10:56:16 +02:00
$console_url = ui_get_full_url('/');
} else {
$server_name = $server_data['server_name'];
$server_id = $server_data['id'];
$console_url = $server_data['server_url'].'/';
$url_hash = metaconsole_get_servers_url_hash($server_data);
}
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.
$agent = db_get_row('tagente', 'id_agente', $id_agente);
if ($agent == false) {
return;
}
2020-11-25 15:52:31 +01:00
// Check all groups.
$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)
) {
db_pandora_audit(
'ACL Violation',
'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;
}
}
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%';
$table->class = 'databox data';
$table->style = [];
$table->style['title'] = 'font-weight: bold;';
$table->head = [];
$table->data = [];
2020-07-22 10:56:16 +02:00
// Agent name.
if ($agent['disabled']) {
$cellName = '<em>';
} else {
$cellName = '';
}
if (is_metaconsole()) {
$pwd = $server_data['auth_token'];
2020-07-22 10:56:16 +02:00
// Create HASH login info.
$user = $config['id_user'];
2020-07-22 10:56:16 +02:00
// Extract auth token from serialized field.
$pwd_deserialiced = json_decode($pwd, true);
$hashdata = $user.$pwd_deserialiced['auth_token'];
$hashdata = md5($hashdata);
$url = $server_data['server_url'].'/index.php?'.'sec=estado&'.'sec2=operation/agentes/ver_agente&'.'id_agente='.$agent['id_agente'].'&'.'loginhash=auto&'."loginhash_data=$hashdata&".'loginhash_user='.str_rot13($user);
2020-11-16 19:16:25 +01:00
if ($grants_on_node) {
$cellName .= '<a href="'.$url.'">'.'<b><span class="bolder pandora_upper" title="'.$agent['nombre'].'">'.$agent['alias'].'</span></b></a>';
2020-11-16 19:16:25 +01:00
} else {
$cellName .= '<b><span class="bolder pandora_upper" title="'.$agent['nombre'].'">'.$agent['alias'].'</span></b>';
2020-11-16 19:16:25 +01:00
}
} else {
2020-07-22 10:56:16 +02:00
$url = ui_get_full_url(
'index.php?sec=estado&amp;sec2=operation/agentes/ver_agente&amp;id_agente='.$agent['id_agente']
);
$cellName .= '<a href="'.$url.'">';
$cellName .= '<b><span class="bolder pandora_upper" title="'.$agent['nombre'].'">'.$agent['alias'].'</span></b></a>';
}
if ($agent['disabled']) {
$cellName .= ui_print_help_tip(__('Disabled'), true).'</em>';
}
$row = [];
$row['title'] = __('Agent name');
$row['data'] = $cellName;
$table->data['name'] = $row;
2020-07-22 10:56:16 +02:00
// Addresses.
$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
);
}
$row = [];
$row['title'] = __('IP Address');
$row['data'] = $address;
$table->data['address'] = $row;
2020-07-22 10:56:16 +02:00
// Agent Interval.
$row = [];
$row['title'] = __('Interval');
$row['data'] = human_time_description_raw($agent['intervalo']);
$table->data['interval'] = $row;
2020-07-22 10:56:16 +02:00
// Comments.
$row = [];
$row['title'] = __('Description');
$row['data'] = $agent['comentarios'];
$table->data['description'] = $row;
2020-07-22 10:56:16 +02:00
// Last contact.
$last_contact = ui_print_timestamp($agent['ultimo_contacto'], true);
if ($agent['ultimo_contacto_remoto'] == '01-01-1970 00:00: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']
);
}
$row = [];
$row['title'] = __('Last contact').' / '.__('Remote');
$row['data'] = "$last_contact / $last_remote_contact";
$table->data['contact'] = $row;
2020-07-22 10:56:16 +02:00
// Next contact (agent).
$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,
'100%',
'1.5',
2019-06-04 14:08:07 +02:00
'#82b92e',
2019-06-03 19:13:29 +02:00
true
);
$table->data['next_contact'] = $row;
2020-07-22 10:56:16 +02:00
// End of table.
$agent_table = html_print_table($table, true);
if ($user_access_node && check_acl($config['id_user'], $agent['id_grupo'], 'AW')) {
2021-03-18 18:05:50 +01:00
$go_to_agent = '<div style="text-align: right">';
2020-05-22 12:14:01 +02:00
if ($agent['id_os'] == CLUSTER_OS_ID) {
if (enterprise_installed()) {
$cluster = PandoraFMS\Enterprise\Cluster::loadFromAgentId(
$agent['id_agente']
);
$url = 'index.php?sec=reporting&sec2='.ENTERPRISE_DIR;
$url .= '/operation/cluster/cluster';
$url = ui_get_full_url(
$url.'&op=update&id='.$cluster->id()
);
$go_to_agent .= '<a target="_blank" href="'.$url.'">';
$go_to_agent .= html_print_submit_button(__('Edit cluster'), 'upd_button', false, 'class="sub config"', true);
}
} else {
$go_to_agent .= '<a target=_blank href="'.$console_url.'index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&id_agente='.$id_agente.$url_hash.'">';
$go_to_agent .= html_print_submit_button(__('Go to agent edition'), 'upd_button', false, 'class="sub config"', true);
}
$go_to_agent .= '</a>';
$go_to_agent .= '</div>';
$agent_table .= $go_to_agent;
}
$agent_table .= '<br>';
// print agent data toggle
2019-06-04 13:57:55 +02:00
ui_toggle($agent_table, __('Agent data'), '', '', false);
// Advanced data
$table = new StdClass();
$table->width = '100%';
$table->style = [];
$table->style['title'] = 'font-weight: bold;';
$table->head = [];
$table->data = [];
// Agent version
$row = [];
$row['title'] = __('Agent Version');
$row['data'] = $agent['agent_version'];
$table->data['agent_version'] = $row;
// Position Information
if ($config['activate_gis']) {
$dataPositionAgent = gis_get_data_last_position_agent($agent['id_agente']);
if ($dataPositionAgent !== false) {
$position = '<a href="'.$console_url.'index.php?sec=estado&amp;sec2=operation/agentes/ver_agente&amp;tab=gis&amp;id_agente='.$id_agente.'">';
if ($dataPositionAgent['description'] != '') {
$position .= $dataPositionAgent['description'];
} else {
$position .= $dataPositionAgent['stored_longitude'].', '.$dataPositionAgent['stored_latitude'];
}
$position .= '</a>';
$row = [];
$row['title'] = __('Position (Long, Lat)');
$row['data'] = $position;
$table->data['agent_position'] = $row;
}
}
// If the url description is setted
if ($agent['url_address'] != '') {
$row = [];
$row['title'] = __('Url address');
$row['data'] = '<a href='.$agent['url_address'].'>'.$agent['url_address'].'</a>';
$table->data['agent_address'] = $row;
}
// Timezone Offset
if ($agent['timezone_offset'] != 0) {
$row = [];
$row['title'] = __('Timezone Offset');
$row['data'] = $agent['timezone_offset'];
$table->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)) {
$row = [];
$row['title'] = $field['name'].ui_print_help_tip(__('Custom field'), true);
if ($field['is_password_type']) {
$row['data'] = '&bull;&bull;&bull;&bull;&bull;&bull;&bull;&bull;';
} else {
$row['data'] = ui_bbcode_to_html($custom_value);
}
$table->data['custom_field_'.$field['id_field']] = $row;
}
}
}
2020-04-13 16:42:46 +02:00
// End of table advanced.
$table_advanced = html_print_table($table, true);
$table_advanced .= '<br>';
ui_toggle($table_advanced, __('Advanced information'));
if ($config['agentaccess']) {
$access_graph = '<div class="w100p height_130px 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
);
$access_graph .= '</div>';
2020-04-13 16:42:46 +02:00
ui_toggle(
$access_graph,
__('Agent access rate (24h)')
);
}
$events_graph = '<div class="graphic_agents">';
2020-03-26 12:29:38 +01:00
$events_graph .= graph_graphic_agentevents(
$id_agente,
2020-10-28 12:50:15 +01:00
'340px;margin:0',
2021-08-12 14:24:16 +02:00
'130px',
2020-03-26 12:29:38 +01:00
SECONDS_1DAY,
'',
true,
false,
550,
1,
$server_id
);
$events_graph .= '</div><br>';
ui_toggle($events_graph, __('Events (24h)'));
// Table network interfaces
$network_interfaces_by_agents = agents_get_network_interfaces([$agent]);
$network_interfaces = [];
if (!empty($network_interfaces_by_agents) && !empty($network_interfaces_by_agents[$id_agente])) {
$network_interfaces = $network_interfaces_by_agents[$id_agente]['interfaces'];
}
if (!empty($network_interfaces)) {
$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) {
if (!empty($interface['traffic'])) {
$permission = check_acl($config['id_user'], $agent['id_grupo'], 'RR');
if ($permission) {
$params = [
'interface_name' => $interface_name,
'agent_id' => $id_agente,
'traffic_module_in' => $interface['traffic']['in'],
'traffic_module_out' => $interface['traffic']['out'],
];
if (defined('METACONSOLE') && !empty($server_id)) {
$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);
$graph_url = "$url?params=$params_encoded";
$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>';
} 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;
}
// End of table network interfaces
$table_interfaces = html_print_table($table, true);
$table_interfaces .= '<br>';
ui_toggle($table_interfaces, __('Interface information').' (SNMP)');
}
if (!empty($server_data) && is_metaconsole()) {
metaconsole_restore_db();
}
return;
}