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); $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, array("border" => '0', "title" => __('Quiet'), "alt" => "")); } else { $agent_name = "" . $agent_name . " " . html_print_image("images/dot_blue.png", true, array("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 = array(); //$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 = $config["flash_charts"] == false ? 100 : 150; $graph_width = $config["flash_charts"] == false ? 200 : 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, array('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 = array(); $data[2] = html_print_image('images/world.png', true, array('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 = array(); $data[2] = html_print_image('images/version.png', true, array('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 = array(); $data[2] = html_print_image('images/default_list.png', true, array('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 = array(); $data[0] = '' . __('Interval') . ''; $data[1] = human_time_description_raw ($agent["intervalo"]); $table_contact->data[] = $data; $data = array(); $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 = array(); $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 = array(); $data[0] = '' . __('Other IP addresses') . ''; $data[1] = '
' . implode('
',$addresses) . '
'; $table_data->data[] = $data; } $data = array(); $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',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; $data = array(); $data[0] = '' . __('Secondary groups') . ''; $secondary_groups = enterprise_hook('agents_get_secondary_groups', array($id_agente)); if (!$secondary_groups) { $data[1] = '' . __('N/A') . ''; } else { $secondary_links = array(); 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 = 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_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 = 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/graphmenu_arrow.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 = check_acl_one_of_groups($config['id_user'], $all_groups, "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, 40, 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, array("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, 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); ?>