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 = []; $data = []; $agent_name = ui_print_agent_name($agent['id_agente'], true, 500, 'font-size: medium;font-weight:bold', true); $in_planned_downtime = db_get_sql( 'SELECT executed FROM tplanned_downtime INNER JOIN tplanned_downtime_agents ON tplanned_downtime.id = tplanned_downtime_agents.id_downtime WHERE tplanned_downtime_agents.id_agent = '.$agent['id_agente'].' AND tplanned_downtime.executed = 1' ); if ($agent['disabled']) { if ($in_planned_downtime) { $agent_name = ''.$agent_name.ui_print_help_tip(__('Disabled'), true); } else { $agent_name = ''.$agent_name.''.ui_print_help_tip(__('Disabled'), true); } } else if ($agent['quiet']) { if ($in_planned_downtime) { $agent_name = "".$agent_name.' '.html_print_image('images/dot_blue.png', true, ['border' => '0', 'title' => __('Quiet'), 'alt' => '']); } else { $agent_name = "".$agent_name.' '.html_print_image('images/dot_blue.png', true, ['border' => '0', 'title' => __('Quiet'), 'alt' => '']).''; } } else { $agent_name = $agent_name; } if ($in_planned_downtime && !$agent['disabled'] && !$agent['quiet']) { $agent_name .= ''.' '.ui_print_help_tip(__('Agent in planned downtime'), true, 'images/minireloj-16.png').''; } else if (($in_planned_downtime && !$agent['disabled']) || ($in_planned_downtime && !$agent['quiet'])) { $agent_name .= ' '.ui_print_help_tip(__('Agent in planned downtime'), true, 'images/minireloj-16.png').''; } 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 = []; // $data[0] = reporting_tiny_stats ($agent, true, 'agent', '
'); // $table_agent->rowspan[count($table_agent->data)][0] = 6; // Fixed width non interactive charts $status_chart_width = 150; $graph_width = 150; $data[0] = '
'; $data[0] .= '
'; $data[0] .= graph_agent_status($id_agente, $graph_width, 120, true); $data[0] .= '
'; $data[0] .= '
'.reporting_tiny_stats($agent, true); $data[0] .= ui_print_help_tip(__('Agent statuses are re-calculated by the server, they are not shown in real time.'), true); $data[0] .= '
'; $table_agent->rowspan[count($table_agent->data)][0] = 6; $table_agent->colspan[count($table_agent->data)][0] = 2; $table_agent->cellstyle[count($table_agent->data)][0] = 'width: 150px; text-align:center; padding: 0px; vertical-align: top;'; $data[2] = ui_print_os_icon($agent['id_os'], false, true, true, false, false, false, ['title' => __('OS').': '.get_os_name($agent['id_os'])]); $table_agent->cellstyle[count($table_agent->data)][2] = 'width: 16px; text-align: right; padding: 0px;'; $data[3] = empty($agent['os_version']) ? get_os_name((int) $agent['id_os']) : $agent['os_version']; $table_agent->colspan[count($table_agent->data)][3] = 2; $table_agent->data[] = $data; $table_agent->rowclass[] = ''; $addresses = agents_get_addresses($id_agente); $address = agents_get_address($id_agente); foreach ($addresses as $k => $add) { if ($add == $address) { unset($addresses[$k]); } } if (!empty($address)) { $data = []; $data[2] = html_print_image('images/world.png', true, ['title' => __('IP address')]); $table_agent->cellstyle[count($table_agent->data)][2] = 'width: 16px; text-align: right; padding: 0px;'; $data[3] = ''; $data[3] .= empty($address) ? ''.__('N/A').'' : $address; $data[3] .= ''; $table_agent->colspan[count($table_agent->data)][3] = 2; $table_agent->data[] = $data; $table_agent->rowclass[] = ''; } $data = []; $data[2] = html_print_image('images/version.png', true, ['title' => __('Agent Version')]); $table_agent->cellstyle[count($table_agent->data)][2] = 'width: 16px; text-align: right; padding: 0px;'; $data[3] = ''; $data[3] .= empty($agent['agent_version']) ? ''.__('N/A').'' : $agent['agent_version']; $data[3] .= ''; $table_agent->colspan[count($table_agent->data)][3] = 2; $table_agent->data[] = $data; $table_agent->rowclass[] = ''; $data = []; $data[2] = html_print_image( 'images/default_list.png', true, ['title' => __('Description')] ); $table_agent->cellstyle[count($table_agent->data)][2] = 'width: 16px; text-align: right; padding: 0px;'; $data[3] = ''; $data[3] .= empty($agent['comentarios']) ? ''.__('N/A').'' : $agent['comentarios']; $data[3] .= ''; $table_agent->colspan[count($table_agent->data)][3] = 2; $table_agent->data[] = $data; $table_agent->rowclass[] = ''; // END: TABLE AGENT BUILD // START: TABLE CONTACT BUILD $table_contact = new stdClass(); $table_contact->id = 'agent_contact_main'; $table_contact->width = '100%'; $table_contact->cellspacing = 0; $table_contact->cellpadding = 0; $table_contact->class = 'databox data'; $table_contact->style[0] = 'width: 30%;height:30px;'; $table_contact->style[1] = 'width: 70%;'; $table_contact->head[0] = ' '.__('Agent contact').''; $table_contact->head_colspan[0] = 2; $data = []; $data[0] = ''.__('Interval').''; $data[1] = human_time_description_raw($agent['intervalo']); $table_contact->data[] = $data; $data = []; $data[0] = ''.__('Last contact').' / '.__('Remote').''; $data[1] = ui_print_timestamp($agent['ultimo_contacto'], true); $data[1] .= ' / '; if ($agent['ultimo_contacto_remoto'] == '01-01-1970 00:00:00') { $data[1] .= __('Never'); } else { $data[1] .= date_w_fixed_tz($agent['ultimo_contacto_remoto']); } $table_contact->data[] = $data; $data[0] = ''.__('Next contact').''; $progress = agents_get_next_contact($id_agente); $data[1] = progress_bar($progress, 200, 20, '', 1, false, '#666666'); if ($progress > 100) { $data[1] .= clippy_context_help('agent_out_of_limits'); } $table_contact->data[] = $data; // END: TABLE CONTACT BUILD // START: TABLE DATA BUILD $table_data = new stdClass(); $table_data->id = 'agent_data_main'; $table_data->width = '100%'; $table_data->styleTable = 'height:180px'; $table_data->cellspacing = 0; $table_data->cellpadding = 0; $table_data->class = 'databox data'; $table_data->style[0] = 'width: 30%;'; $table_data->style[1] = 'width: 40%;'; $table_data->head[0] = ' '.__('Agent info').''; $table_data->head_colspan[0] = 3; $data = []; $data[0] = ''.__('Group').''; $data[1] = ''.groups_get_name($agent['id_grupo']).''; // ACCESS RATE GRAPH $access_agent = db_get_value_sql( 'SELECT COUNT(id_agent) FROM tagent_access WHERE id_agent = '.$id_agente ); if ($config['agentaccess'] && $access_agent > 0) { $data[2] = '
'.__('Agent access rate (24h)').''.graphic_agentaccess($id_agente, '95%', 100, SECONDS_1DAY, true).'
'; $table_data->style[0] = 'width: 20%;'; $table_data->style[1] = 'width: 30%;'; $table_data->style[2] = 'width: 50%;'; $table_data->rowspan[0][2] = 5; } $table_data->data[] = $data; if (!empty($addresses)) { $data = []; $data[0] = ''.__('Other IP addresses').''; $data[1] = '
'.implode('
', $addresses).'
'; $table_data->data[] = $data; } $data = []; $data[0] = ''.__('Parent').''; if ($agent['id_parent'] == 0) { $data[1] = ''.__('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', [$agent['id_agente']]); if (enterprise_installed()) { $data = []; $data[0] = ''.__('Remote configuration').''; if (!$has_remote_conf) { $data[1] = __('Disabled'); } else { $data[1] = __('Enabled'); } $table_data->data[] = $data; $data = []; $data[0] = ''.__('Secondary groups').''; $secondary_groups = enterprise_hook('agents_get_secondary_groups', [$id_agente]); if (!$secondary_groups) { $data[1] = ''.__('N/A').''; } else { $secondary_links = []; foreach ($secondary_groups['for_select'] as $id => $name) { $secondary_links[] = ''.$name.''; } $data[1] = implode(', ', $secondary_links); } $table_data->data[] = $data; } if ($config['activate_gis'] || $agent['url_address'] != '') { $data = []; // 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 = []; $data[0] = ''.__('Url address').''; $data[1] = ''.$agent['url_address'].''; $table_data->data[] = $data; } } // Timezone Offset if ($agent['timezone_offset'] != 0) { $data = []; $data[0] = ''.__('Timezone Offset').''; $data[1] = $agent['timezone_offset']; $table->data[] = $data; } // Custom fields $fields = db_get_all_rows_filter( 'tagent_custom_fields', ['display_on_front' => 1] ); if ($fields === false) { $fields = []; } foreach ($fields as $field) { $data = []; $data[0] = ''.$field['name'].ui_print_help_tip(__('Custom field'), true).''; $custom_value = db_get_all_rows_sql( 'select tagent_custom_data.description,tagent_custom_fields.is_password_type from tagent_custom_fields INNER JOIN tagent_custom_data ON tagent_custom_fields.id_field = tagent_custom_data.id_field where tagent_custom_fields.id_field = '.$field['id_field'].' and tagent_custom_data.id_agent = '.$id_agente ); if ($custom_value[0]['description'] === false || $custom_value[0]['description'] == '') { $custom_value[0]['description'] = '-'.__('empty').'-'; } else { $custom_value[0]['description'] = ui_bbcode_to_html($custom_value[0]['description']); } if ($custom_value[0]['is_password_type']) { $data[1] = '••••••••'; } else { $data[1] = $custom_value[0]['description']; } $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 = []; $data[0] = ''.__('Author').''; $data[1] = $last_incident['id_creator']; $table_incident->data[] = $data; $data = []; $data[0] = ''.__('Title').''; $data[1] = ''.$last_incident['titulo'].''; $table_incident->data[] = $data; $data = []; $data[0] = ''.__('Timestamp').''; $data[1] = $last_incident['inicio']; $table_incident->data[] = $data; $data = []; $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([$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_interface = new stdClass(); $table_interface->id = 'agent_interface_info'; $table_interface->class = 'databox data'; $table_interface->width = '98%'; $table_interface->style = []; $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 = []; $options = [ 'class' => 'closed', 'style' => 'vertical-align:righ; cursor:pointer;', ]; $table_interface->head[0] = html_print_image('images/graphmenu_arrow.png', true, $options).'  '; $table_interface->head[0] .= ''.__('Interface information').' (SNMP)'; $table_interface->head_colspan = []; $table_interface->head_colspan[0] = 8; $table_interface->data = []; $event_text_cont = 0; foreach ($network_interfaces as $interface_name => $interface) { if (!empty($interface['traffic'])) { $permission = check_acl_one_of_groups($config['id_user'], $all_groups, 'RR'); if ($permission) { $params = [ '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, ['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, [], true ); $id_modules_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 = ['color' => ['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 = []; $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 = []; $data[0][0] = html_print_table($table_agent, true); $data[0][0] .= '
'.''.'
'.__('Events (24h)').'

'.graph_graphic_agentevents($id_agente, 100, 45, SECONDS_1DAY, '', true, 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, ['border' => '0', 'title' => __('Refresh data'), 'alt' => '']).'
'; if (check_acl_one_of_groups($config['id_user'], $all_groups, 'AW')) { $data[0][2] .= ''.html_print_image('images/target.png', true, ['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);