id = 'agent_details_main';
$table_agent->width = '95%';
$table_agent->cellspacing = 0;
$table_agent->cellpadding = 0;
$table_agent->class = 'databox filters';
$table_agent->style[0] = 'width: 16px; text-align:center; padding: 0px;';
$table_agent->style[5] = 'width: 16px; text-align:center; padding: 0px;';
$table_agent->styleTable = 'padding:0px;';
$table_agent->data = array();
$data = array();
$agent_name = ui_print_agent_name($agent["id_agente"], true, 500, "font-size: medium;font-weight:bold", true);
if ($agent['disabled']) {
$agent_name = "" . $agent_name . "" . ui_print_help_tip(__('Disabled'), true);
}
else if ($agent['quiet']) {
$agent_name = "" . $agent_name . " " . html_print_image("images/dot_green.disabled.png", true, array("border" => '0', "title" => __('Quiet'), "alt" => "")) . "";
}
else {
$agent_name = $agent_name;
}
if (!$config["show_group_name"])
$data[0] = ui_print_group_icon ($agent["id_grupo"], true);
else
$data[0] = "";
$table_agent->cellstyle[count($table_agent->data)][0] =
'width: 16px; text-align:center; padding: 0px;';
$data[2] = $agent_name;
$table_agent->colspan[count($table_agent->data)][2] = 3;
$table_agent->cellstyle[count($table_agent->data)][2] =
'width: 100px; word-break: break-all;';
$status_img = agents_detail_view_status_img ($agent["critical_count"],
$agent["warning_count"], $agent["unknown_count"], $agent["total_count"],
$agent["notinit_count"]);
$data[2] .= " " .$status_img;
$table_agent->data[] = $data;
$table_agent->rowclass[] = '';
$data = array();
//$data[0] = reporting_tiny_stats ($agent, true, 'agent', '
' . __('N/A') . '';
}
else {
$data[1] = '
'.agents_get_alias($agent["id_parent"]).'';
}
$table_data->data[] = $data;
$has_remote_conf = enterprise_hook('config_agents_has_remote_configuration',array($agent["id_agente"]));
if (enterprise_installed()) {
$data = array();
$data[0] = '
' . __('Remote configuration') . '';
if (!$has_remote_conf) {
$data[1] = __('Disabled');
}
else {
$data[1] = __('Enabled');
}
$table_data->data[] = $data;
}
if ($config['activate_gis'] || $agent['url_address'] != '') {
$data = array();
// Position Information
if ($config['activate_gis']) {
$dataPositionAgent =
gis_get_data_last_position_agent($agent['id_agente']);
$data[0] = '
' . __('Position (Long, Lat)') . '';
if ($dataPositionAgent === false) {
$data[1] = __('There is no GIS data.');
}
else {
$data[1] = '
';
if ($dataPositionAgent['description'] != "")
$data[1] .= $dataPositionAgent['description'];
else
$data[1] .= $dataPositionAgent['stored_longitude'].', '.$dataPositionAgent['stored_latitude'];
$data[1] .= "";
}
$table_data->data[] = $data;
}
// If the url description is setted
if ($agent['url_address'] != '') {
$data = array();
$data[0] = '
' . __('Url address') . '';
$data[1] = '
' . $agent["url_address"] . '';
$table_data->data[] = $data;
}
}
// Timezone Offset
if ($agent['timezone_offset'] != 0) {
$data = array();
$data[0] = '
' . __('Timezone Offset') . '';
$data[1] = $agent["timezone_offset"];
$table->data[] = $data;
}
// Custom fields
$fields = db_get_all_rows_filter(
'tagent_custom_fields',
array('display_on_front' => 1));
if ($fields === false) {
$fields = array ();
}
foreach ($fields as $field) {
$data = array();
$data[0] = '
' . $field['name'] .
ui_print_help_tip (__('Custom field'), true) . '';
$custom_value = db_get_value_filter(
'description', 'tagent_custom_data',
array('id_field' => $field['id_field'], 'id_agent' => $id_agente));
if ($custom_value === false || $custom_value == '') {
$custom_value = '
'.__('N/A').'';
}
else {
$custom_value = ui_bbcode_to_html($custom_value);
}
$data[1] = $custom_value;
$table_data->data[] = $data;
}
// END: TABLE DATA BUILD
// START: TABLE INCIDENTS
$last_incident = db_get_row_sql("
SELECT * FROM tincidencia
WHERE estado IN (0,1)
AND id_agent = $id_agente
ORDER BY actualizacion DESC");
if ($last_incident != false) {
$table_incident->id = 'agent_incident_main';
$table_incident->width = '100%';
$table_incident->cellspacing = 0;
$table_incident->cellpadding = 0;
$table_incident->class = 'databox';
$table_incident->style[0] = 'width: 30%;';
$table_incident->style[1] = 'width: 70%;';
$table_incident->head[0] = '
' . '' .__('Active incident on this agent') .''. '';
$table_incident->head_colspan[0] = 2;
$data = array();
$data[0] = '
' . __('Author') . '';
$data[1] = $last_incident["id_creator"];
$table_incident->data[] = $data;
$data = array();
$data[0] = '
' . __('Title') . '';
$data[1] = '
' .$last_incident["titulo"].'';
$table_incident->data[] = $data;
$data = array();
$data[0] = '
' . __('Timestamp') . '';
$data[1] = $last_incident["inicio"];
$table_incident->data[] = $data;
$data = array();
$data[0] = '
' . __('Priority') . '';
$data[1] = incidents_print_priority_img ($last_incident["prioridad"], true);
$table_incident->data[] = $data;
}
// END: TABLE INCIDENTS
// START: TABLE INTERFACES
$network_interfaces_by_agents = agents_get_network_interfaces(array($agent));
$network_interfaces = array();
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_interface = new stdClass();
$table_interface->id = 'agent_interface_info';
$table_interface->class = 'databox data';
$table_interface->width = '98%';
$table_interface->style = array();
$table_interface->style['interface_status'] = 'width: 30px;padding-top:0px;padding-bottom:0px;';
$table_interface->style['interface_graph'] = 'width: 20px;padding-top:0px;padding-bottom:0px;';
$table_interface->style['interface_event_graph'] = 'width: 100%;padding-top:0px;padding-bottom:0px;';
$table_interface->align['interface_event_graph'] = 'right';
//$table_interface->style['interface_event_graph'] = 'width: 5%;padding-top:0px;padding-bottom:0px;';
$table_interface->align['interface_event_graph_text'] = 'left';
$table_interface->style['interface_name'] = 'width: 10%;padding-top:0px;padding-bottom:0px;';
$table_interface->align['interface_name'] = 'left';
$table_interface->align['interface_ip'] = 'left';
$table_interface->align['last_contact'] = 'left';
$table_interface->style['last_contact'] = 'width: 40%;padding-top:0px;padding-bottom:0px;';
$table_interface->style['interface_ip'] = 'width: 8%;padding-top:0px;padding-bottom:0px;';
$table_interface->style['interface_mac'] = 'width: 12%;padding-top:0px;padding-bottom:0px;';
$table_interface->head = array();
$options = array(
"class" => "closed",
"style" => "vertical-align:righ; cursor:pointer;");
$table_interface->head[0] = html_print_image("images/go.png", true, $options) . " ";
$table_interface->head[0] .= '
' . __('Interface information') .' (SNMP)';
$table_interface->head_colspan = array();
$table_interface->head_colspan[0] = 8;
$table_interface->data = array();
$event_text_cont = 0;
foreach ($network_interfaces as $interface_name => $interface) {
if (!empty($interface['traffic'])) {
$permission = false;
if ($strict_user) {
if (tags_check_acl_by_module($interface['traffic']['in'], $config['id_user'], 'RR') === true
&& tags_check_acl_by_module($interface['traffic']['out'], $config['id_user'], 'RR') === true)
$permission = true;
}
else {
$permission = check_acl($config['id_user'], $agent["id_grupo"], "RR");
}
if ($permission) {
$params = array(
'interface_name' => $interface_name,
'agent_id' => $id_agente,
'traffic_module_in' => $interface['traffic']['in'],
'traffic_module_out' => $interface['traffic']['out']
);
$params_json = json_encode($params);
$params_encoded = base64_encode($params_json);
$win_handle = dechex(crc32($interface['status_module_id'].$interface_name));
$graph_link = "
" .
html_print_image("images/chart_curve.png", true, array("title" => __('Interface traffic'))) . "";
}
else {
$graph_link = "";
}
}
else {
$graph_link = "";
}
$events_limit = 5000;
$user_groups = users_get_groups($config['id_user'], 'ER');
$user_groups_ids = array_keys($user_groups);
if (empty($user_groups)) {
$groups_condition = ' 1 = 0 ';
}
else {
$groups_condition = ' id_grupo IN (' . implode(',', $user_groups_ids) . ') ';
}
if (!check_acl ($config['id_user'], 0, "PM")) {
$groups_condition .= " AND id_grupo != 0";
}
$status_condition = ' AND (estado = 0 OR estado = 1) ';
$unixtime = get_system_time () - SECONDS_1DAY; //last hour
$time_condition = 'AND (utimestamp > '.$unixtime.')';
// Tags ACLS
if ($id_group > 0 && in_array (0, $user_groups_ids)) {
$group_array = (array) $id_group;
}
else {
$group_array = $user_groups_ids;
}
$acl_tags = tags_get_acl_tags($config['id_user'], $group_array, 'ER',
'event_condition', 'AND', '', true, array(), true);
$id_modules_array = array();
$id_modules_array[] = $interface['status_module_id'];
$unixtime = get_system_time () - SECONDS_1DAY; //last hour
$time_condition = 'WHERE (te.utimestamp > '.$unixtime.')';
$sqlEvents = sprintf('
SELECT *
FROM tevento te
INNER JOIN tagente_estado tae
ON te.id_agentmodule = tae.id_agente_modulo
AND tae.id_agente_modulo IN (%s)
%s
', implode(',', $id_modules_array), $time_condition);
$sqlLast_contact = sprintf ('
SELECT last_try
FROM tagente_estado
WHERE id_agente_modulo = ' . $interface['status_module_id']
);
$last_contact = db_get_all_rows_sql ($sqlLast_contact);
$last_contact = array_shift($last_contact);
$last_contact = array_shift($last_contact);
$events = db_get_all_rows_sql ($sqlEvents);
$text_event_header = __('Events info (24hr.)');
if (!$events) {
$no_events = array('color' => array('criticity' => 2));
$e_graph = reporting_get_event_histogram ($no_events, $text_event_header);
}
else {
$e_graph = reporting_get_event_histogram ($events, $text_event_header);
}
$data = array();
$data['interface_name'] = "
" . $interface_name . "";
$data['interface_status'] = $interface['status_image'];
$data['interface_graph'] = $graph_link;
$data['interface_ip'] = $interface['ip'];
$data['interface_mac'] = $interface['mac'];
$data['last_contact'] = __('Last contact: ') . $last_contact;
$data['interface_event_graph'] = $e_graph;
if ($event_text_cont == 0) {
$data['interface_event_graph_text'] = ui_print_help_tip('Module events graph', true);
$event_text_cont++;
}
else {
$data['interface_event_graph_text'] = "";
}
$table_interface->data[] = $data;
}
// This javascript piece of code is used to make expandible the body of the table
?>
id = 'agent_details';
$table->width = '100%';
$table->cellspacing = 0;
$table->cellpadding = 0;
$table->class = 'agents';
$table->style = array_fill(0, 3, 'vertical-align: top;');
$data = array();
$data[0][0] = html_print_table($table_agent, true);
$data[0][0] .=
'
' .
__('Events (24h)') .
' |
' .
' ' .
graph_graphic_agentevents ($id_agente, 450, 15, SECONDS_1DAY, '', true) .
'
|
' .
'
';
$table->style[0] = 'width:40%; vertical-align:top;';
$data[0][1] = html_print_table($table_contact, true);
$data[0][1] .= empty($table_data->data) ?
'' :
'
' . html_print_table($table_data, true);
$data[0][1] .= !isset($table_incident) ?
'' :
'
' . html_print_table($table_incident, true);
$table->rowspan[1][0] = 0;
$data[0][2] = '
';
$data[0][2] .= '
' . html_print_image("images/refresh.png", true, array("border" => '0', "title" => __('Refresh data'), "alt" => "")) . '';
if (check_acl ($config["id_user"], $agent["id_grupo"], "AW"))
$data[0][2] .= '
' . html_print_image("images/target.png", true, array("border" => '0', "title" => __('Force remote checks'), "alt" => "")) . '';
$data[0][2] .= '
';
$table->data = $data;
$table->rowclass[] = '';
$table->cellstyle[1][0] = 'text-align:center;';
html_print_table($table);
$data2[1][0] = !isset($table_interface) ?
'' :
html_print_table($table_interface, true);
$table->data = $data2;
$table->styleTable = '';
html_print_table($table);
unset($table);
?>