'; echo $text; echo ''; echo ''; } function visual_map_print_item($layoutData) { global $config; require_once ($config["homedir"] . '/include/functions_graph.php'); $width = $layoutData['width']; $height = $max_percentile = $layoutData['height']; $top = $layoutData['pos_y']; $left = $layoutData['pos_x']; $id = $layoutData['id']; $color = $layoutData['label_color']; $label = $layoutData['label']; $id_module = $layoutData['id_agente_modulo']; $type = $layoutData['type']; $period = $layoutData['period']; $sizeStyle = ''; $borderStyle = ''; $imageSize = ''; $text = '' . $label . ''; $status = visual_map_get_status_element($layoutData); switch ($status) { case VISUAL_MAP_STATUS_CRITICAL_BAD: //Critical (BAD) $colorStatus = COL_CRITICAL; break; case VISUAL_MAP_STATUS_CRITICAL_ALERT: //Critical (ALERT) $colorStatus = COL_ALERTFIRED; break; case VISUAL_MAP_STATUS_NORMAL: //Normal (OK) $colorStatus = COL_NORMAL; break; case VISUAL_MAP_STATUS_WARNING: //Warning $colorStatus = COL_WARNING; break; case VISUAL_MAP_STATUS_UNKNOWN: default: //Unknown // Default is Blue (Other) $colorStatus = COL_UNKNOWN; break; } switch ($type) { case STATIC_GRAPH: if ($layoutData['image'] != null) { $img = visual_map_get_image_status_element($layoutData); if (substr($img,0,1) == '4') { $borderStyle ='border: 2px solid #ffa300;'; $img = substr_replace($img, '', 0,1); } } if (($width != 0) && ($height != 0)) { $sizeStyle = 'width: ' . $width . 'px; height: ' . $height . 'px;'; $imageSize = 'width="' . $width . '" height="' . $height . '"'; } echo '
'; if ($layoutData['image'] != null) { if (($width != 0) && ($height != 0)) echo html_print_image($img, true, array("class" => "image", "id" => "image_" . $id, "width" => "$width", "height" => "$height", "style" => $borderStyle)); else echo html_print_image($img, true, array("class" => "image", "id" => "image_" . $id, "style" => $borderStyle)); echo '
'; } echo io_safe_output($text); echo "
"; break; case PERCENTILE_BAR: case PERCENTILE_BUBBLE: //Metaconsole db connection if ($layoutData['id_metaconsole'] != 0) { $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layoutData['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } $module_value = db_get_sql ('SELECT datos FROM tagente_estado WHERE id_agente_modulo = ' . $id_module); $value_text = false; if ($layoutData['image'] == 'percent') { $value_text = false; } elseif ($layoutData['image'] == 'value') { $unit_text = db_get_sql ('SELECT unit FROM tagente_modulo WHERE id_agente_modulo = ' . $id_module); $unit_text = trim(io_safe_output($unit_text)); $value_text = format_for_graph($module_value, 2); if (!empty($unit_text)) $value_text .= " " . $unit_text; } //Restore db connection if ($layoutData['id_metaconsole'] != 0) { metaconsole_restore_db(); } if ( $max_percentile > 0) $percentile = format_numeric($module_value / $max_percentile * 100, 0); else $percentile = 100; echo '
'; echo io_safe_output($text) . '
'; ob_start(); if ($type == PERCENTILE_BUBBLE) { echo progress_bubble($percentile, $width, $width, '', 1, $value_text, $colorStatus); } else { echo progress_bar($percentile, $width, 15, '', 1, $value_text, $colorStatus); } $img = ob_get_clean(); $img = str_replace('>', 'class="image" id="image_' . $id . '" />', $img); echo $img; echo '
'; break; case MODULE_GRAPH: //Metaconsole db connection if ($layoutData['id_metaconsole'] != 0) { $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layoutData['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } $img = grafico_modulo_sparse($id_module, $period, 0, $width, $height, '', null, false, 1, false, 0, '', 0, 0, true, true); //Restore db connection if ($layoutData['id_metaconsole'] != 0) { metaconsole_restore_db(); } $img = str_replace('>', 'class="image" id="image_' . $id . '" />', $img); echo '
'; echo io_safe_output($text) . '
'; echo $img; echo '
'; break; case SIMPLE_VALUE: case SIMPLE_VALUE_MAX: case SIMPLE_VALUE_MIN: case SIMPLE_VALUE_AVG: $io_safe_output_text = io_safe_output($text); echo '
'; echo $io_safe_output_text; //Metaconsole db connection if ($layoutData['id_metaconsole'] != 0) { $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layoutData['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } $unit_text = db_get_sql ('SELECT unit FROM tagente_modulo WHERE id_agente_modulo = ' . $layoutData['id_agente_modulo']); $unit_text = trim(io_safe_output($unit_text)); $value = db_get_value ('datos', 'tagente_estado', 'id_agente_modulo', $layoutData['id_agente_modulo']); // If the value is a string, dont format it if (!is_string($value)) { $value = format_for_graph($value, 2); } if (!empty($unit_text)) $value .= " " . $unit_text; if (strstr($io_safe_output_text, "(_VALUE_)") === false) { echo ' ' . $value . ''; } //Restore db connection if ($layoutData['id_metaconsole'] != 0) { metaconsole_restore_db(); } echo '
'; break; case LABEL: echo '
'; echo io_safe_output($text); echo "
"; break; case ICON: if ($layoutData['image'] != null) { $img = visual_map_get_image_status_element($layoutData); } if (($width != 0) && ($height != 0)) { $sizeStyle = 'width: ' . $width . 'px; height: ' . $height . 'px;'; $imageSize = 'width="' . $width . '" height="' . $height . '"'; } echo '
'; if ($layoutData['image'] != null) { // If match with protocol://direction if (preg_match('/^(http:\/\/)((.)+)$/i', $text)) { echo '' . '' . '
'; } if (($width != 0) && ($height != 0)) echo html_print_image($img, true, array("class" => "image", "id" => "image_" . $id, "width" => "$width", "height" => "$height")); else echo html_print_image($img, true, array("class" => "image", "id" => "image_" . $id)); echo '
'; } echo "
"; break; default: enterprise_hook("enterprise_visual_map_print_item", array($layoutData, $status, $colorStatus)); break; } //Add the line between elements. if ($layoutData['parent_item'] != 0) { $parent = db_get_row_filter('tlayout_data', array('id' => $layoutData['parent_item'])); echo ''; } } /** * The function to get simple value type from the value of process type in the form * * @param int process simple value from form * * @return int type among the constants: * SIMPLE_VALUE, SIMPLE_VALUE_MAX, SIMPLE_VALUE_MIN, SIMPLE_VALUE_AVG */ function visual_map_get_simple_value_type($process_simple_value) { switch ($process_simple_value) { case PROCESS_VALUE_NONE: return SIMPLE_VALUE; break; case PROCESS_VALUE_MIN: return SIMPLE_VALUE_MIN; break; case PROCESS_VALUE_MAX: return SIMPLE_VALUE_MAX; break; case PROCESS_VALUE_AVG: return SIMPLE_VALUE_AVG; break; } } /** * The function to get the simple value of a module * * @param int type of the retrieving choosed among the constants: * SIMPLE_VALUE, SIMPLE_VALUE_MAX, SIMPLE_VALUE_MIN, SIMPLE_VALUE_AVG * @param int id agent module * @param int period The period in seconds for calculate the avg or min or max value. * * @return string value retrieved with units */ function visual_map_get_simple_value($type, $id_module, $period = SECONDS_1DAY) { $unit_text = db_get_sql ('SELECT unit FROM tagente_modulo WHERE id_agente_modulo = ' . $id_module); $unit_text = trim(io_safe_output($unit_text)); switch ($type) { case SIMPLE_VALUE: $value = db_get_value ('datos', 'tagente_estado', 'id_agente_modulo', $id_module); $value = format_for_graph($value, 2); if (!empty($unit_text)) $value .= " " . $unit_text; return $value; break; case SIMPLE_VALUE_MAX: $value = reporting_get_agentmodule_data_max ($id_module, $period, 0); if ($value === false) { $value = __('Unknown'); } else { $value = format_for_graph($value, 2); if (!empty($unit_text)) $value .= " " . $unit_text; } return $value; break; case SIMPLE_VALUE_MIN: $value = reporting_get_agentmodule_data_min ($id_module, $period, 0); if ($value === false) { $value = __('Unknown'); } else { $value = format_for_graph($value, 2); if (!empty($unit_text)) $value .= " " . $unit_text; } return $value; break; case SIMPLE_VALUE_AVG: $value = reporting_get_agentmodule_data_average ($id_module, $period, 0); if ($value === false) { $value = __('Unknown'); } else { $value = format_for_graph($value, 2); if (!empty($unit_text)) $value .= " " . $unit_text; } return $value; break; } } /** * The function to save the new elements of agents make as wizard. * * @param array $id_agents The list of id of agents. * @param string $image The image to set the elements. * @param integer $id_layout The id of visual console to insert the elements. * @param integer $range The distance between elements. * @param integer $width Width of image. * @param integer $height Height of image. * * @return string Return the message status to insert DB. */ function visual_map_process_wizard_add ($id_agents, $image, $id_layout, $range, $width = 0, $height = 0, $period, $process_value, $percentileitem_width, $max_value, $type_percentile, $value_show, $type) { if (empty ($id_agents)) { print_error_message (__('No agents selected')); return false; } $id_agents = (array) $id_agents; $error = false; $pos_y = 10; $pos_x = 10; foreach ($id_agents as $id_agent) { if ($pos_x > 600) { $pos_x = 10; $pos_y = $pos_y + $range; } $value_height = $height; $value_image = $image; $value_type = $type; switch ($type) { case PERCENTILE_BAR: case PERCENTILE_BUBBLE: $value_height = $max_value; $value_image = $value_show; if ($type_percentile == 'percentile') { $value_type = PERCENTILE_BAR; } else { $value_type = PERCENTILE_BUBBLE; } break; case SIMPLE_VALUE: $value_type = $process_value; break; } $values = array ('type' => $value_type, 'id_layout' => $id_layout, 'pos_x' => $pos_x, 'pos_y' => $pos_y, 'label' => agents_get_name ($id_agent), 'image' => $value_image, 'id_agent' => $id_agent, 'width' => $width, 'period' => $period, 'height' => $value_height, 'label_color' => '#000000'); db_process_sql_insert ('tlayout_data', $values); $pos_x = $pos_x + $range; } $return = ui_print_success_message (__('Agent successfully added to layout'), '', true); return $return; } /** * The function to save the new elements of modules make as wizard. * * @param array $id_modules The list of id of modules. * @param string $image The image to set the elements. * @param integer $id_layout The id of visual console to insert the elements. * @param integer $range The distance between elements. * @param integer $width Width of image. * @param integer $height Height of image. * * @return string Return the message status to insert DB. */ function visual_map_process_wizard_add_modules ($id_modules, $image, $id_layout, $range, $width = 0, $height = 0, $period, $process_value, $percentileitem_width, $max_value, $type_percentile, $value_show, $label_type, $type, $enable_link = true, $id_server = 0) { if (empty ($id_modules)) { $return = ui_print_error_message (__('No modules selected'), '', true); return $return; } $id_modules = (array) $id_modules; $error = false; $pos_y = 10; $pos_x = 10; foreach ($id_modules as $id_module) { if ($pos_x > 600) { $pos_x = 10; $pos_y = $pos_y + $range; } if ($id_server != 0) { $connection = db_get_row_filter('tmetaconsole_setup', array('id' => $id_server)); if (metaconsole_load_external_db($connection) != NOERR) { $return = ui_print_error_message( "Error connecting to " . $server_name, '', true); return $return; } } $id_agent = modules_get_agentmodule_agent ($id_module); switch ($label_type) { case 'agent_module': default: $agent_label = ui_print_truncate_text(agents_get_name ($id_agent), 'agent_small', false, true, false, '…', false); $module_label = ui_print_truncate_text(modules_get_agentmodule_name($id_module), 'module_small', false, true, false, '…', false); $label = $agent_label . " - " . $module_label; break; case 'module': $module_label = ui_print_truncate_text(modules_get_agentmodule_name($id_module), 'module_small', false, true, false, '…', false); $label = $module_label; break; case 'agent': $agent_label = ui_print_truncate_text(agents_get_name ($id_agent), 'agent_small', false, true, false, '…', false); $label = $agent_label; break; case 'none': $label = ''; break; } $label = io_safe_input($label); //Restore db connection if ($id_server != 0) { metaconsole_restore_db(); } $value_height = $height; $value_image = $image; $value_type = $type; $value_width = $width; switch ($type) { case PERCENTILE_BAR: case PERCENTILE_BUBBLE: $value_height = $max_value; $value_width = $percentileitem_width; $value_image = $value_show; if ($type_percentile == 'percentile') { $value_type = PERCENTILE_BAR; } else { $value_type = PERCENTILE_BUBBLE; } break; case SIMPLE_VALUE: $value_image = ''; switch ($process_value) { case PROCESS_VALUE_NONE: $value_type = SIMPLE_VALUE; break; case PROCESS_VALUE_MIN: $value_type = SIMPLE_VALUE_MIN; break; case PROCESS_VALUE_MAX: $value_type = SIMPLE_VALUE_MAX; break; case PROCESS_VALUE_AVG: $value_type = SIMPLE_VALUE_AVG; break; } break; } $values = array ('type' => $value_type, 'id_layout' => $id_layout, 'pos_x' => $pos_x, 'pos_y' => $pos_y, 'label' => $label, 'image' => $value_image, 'id_agent' => $id_agent, 'id_agente_modulo' => $id_module, 'width' => $value_width, 'period' => $period, 'height' => $value_height, 'label_color' => '#000000', 'enable_link' => $enable_link, 'id_metaconsole' => $id_server); db_process_sql_insert ('tlayout_data', $values); $pos_x = $pos_x + $range; } $return = ui_print_success_message (__('Modules successfully added to layout'), '', true); return $return; } /** * The function to save the new elements of agents make as wizard. * * @param array $id_agents The list of id of agents. * @param string $image The image to set the elements. * @param integer $id_layout The id of visual console to insert the elements. * @param integer $range The distance between elements. * @param integer $width Width of image. * @param integer $height Height of image. * * @return string Return the message status to insert DB. */ function visual_map_process_wizard_add_agents ($id_agents, $image, $id_layout, $range, $width = 0, $height = 0, $period, $process_value, $percentileitem_width, $max_value, $type_percentile, $value_show, $label_type, $type, $enable_link = 1, $id_server = 0) { global $config; if (empty ($id_agents)) { $return = ui_print_error_message (__('No agents selected'), '', true); return $return; } $id_agents = (array) $id_agents; $error = false; $pos_y = 10; $pos_x = 10; foreach ($id_agents as $id_agent) { if ($pos_x > 600) { $pos_x = 10; $pos_y = $pos_y + $range; } $value_height = $height; $value_image = $image; $value_type = $type; $value_width = $width; switch ($type) { case PERCENTILE_BAR: case PERCENTILE_BUBBLE: $value_height = $max_value; $value_width = $percentileitem_width; $value_image = $value_show; if ($type_percentile == 'percentile') { $value_type = PERCENTILE_BAR; } else { $value_type = PERCENTILE_BUBBLE; } break; case SIMPLE_VALUE: $value_image = ''; switch ($process_value) { case PROCESS_VALUE_NONE: $value_type = SIMPLE_VALUE; break; case PROCESS_VALUE_MIN: $value_type = SIMPLE_VALUE_MIN; break; case PROCESS_VALUE_MAX: $value_type = SIMPLE_VALUE_MAX; break; case PROCESS_VALUE_AVG: $value_type = SIMPLE_VALUE_AVG; break; } break; } if ($id_server != 0) { $connection = db_get_row_filter('tmetaconsole_setup', array('id' => $id_server)); if (metaconsole_load_external_db($connection) != NOERR) { $return = ui_print_error_message( "Error connecting to " . $server_name, '', true); return $return; } } switch ($label_type) { case 'agent': $agent_label = ui_print_truncate_text( agents_get_name($id_agent), 'agent_small', false, true, false, '…', false); $label = $agent_label; break; case 'none': $label = ''; break; } $label = io_safe_input($label); //Restore db connection if ($id_server != 0) { metaconsole_restore_db(); } $values = array ('type' => $value_type, 'id_layout' => $id_layout, 'pos_x' => $pos_x, 'pos_y' => $pos_y, 'label' => $label, 'image' => $value_image, 'id_agent' => $id_agent, 'id_agente_modulo' => 0, 'width' => $value_width, 'period' => $period, 'height' => $value_height, 'label_color' => '#000000', 'enable_link' => $enable_link, 'id_metaconsole' => $id_server); db_process_sql_insert ('tlayout_data', $values); $pos_x = $pos_x + $range; } $return = ui_print_success_message (__('Agents successfully added to layout'), '', true); return $return; } /** * Get the color of line between elements in the visual map. * * @param array $layoutData The row of element in DB. * * @return string The color as hexadecimal color in html. */ function visual_map_get_color_line_status($layoutData) { if (($layoutData['type'] == 5) || ($layoutData['type'] == 4)) { //ICON ELEMENT OR LABEL ELEMENT $color = "#cccccc"; } else { switch (visual_map_get_status_element($layoutData)) { case 3: $color = "#cccccc"; // Gray break; case 2: $color = "#20f6f6"; // Yellow break; case 0: $color = "#00ff00"; // Green break; case 4: case 1: $color = "#ff0000"; // Red break; } } return $color; } /** * Get image of element in the visual console with status. * * @param array $layoutData The row of element in DB. * * @return string The image with the relative path to pandora console directory. */ function visual_map_get_image_status_element($layoutData) { $img = "images/console/icons/" . $layoutData["image"]; if ($layoutData['type'] == 5) { //ICON ELEMENT $img .= ".png"; } else { switch (visual_map_get_status_element($layoutData)) { case 1: //Critical (BAD) $img .= "_bad.png"; break; case 4: //Critical (ALERT) $img = "4" . $img . "_bad.png"; break; case 0: //Normal (OK) $img .= "_ok.png"; break; case 2: //Warning $img .= "_warning.png"; break; case 10: //Warning (ALERT) $img = "4" . $img . "_warning.png"; break; case 3: //Unknown default: $img .= ".png"; // Default is Grey (Other) } } return $img; } /** * Get the status of element in visual console. Check the agent state or * module or layout linked. * * @param array $layoutData The row of element in DB. * * @return integer */ function visual_map_get_status_element($layoutData) { enterprise_include_once('include/functions_visual_map.php'); if (enterprise_installed()) { $status = enterprise_visual_map_get_status_element($layoutData); //The function return value. if ($status !== false) { //Return this value as call of open function. return $status; } } //Linked to other layout ?? - Only if not module defined if ($layoutData['id_layout_linked'] != 0) { $status = visual_map_get_layout_status ($layoutData['id_layout_linked']); } else { switch ($layoutData["type"]) { case STATIC_GRAPH: if ($layoutData['id_metaconsole'] != 0) { //Metaconsole db connection $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layoutData['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } //Status for a simple module if ($layoutData['id_agente_modulo'] != 0) { $status = modules_get_agentmodule_status ($layoutData['id_agente_modulo']); //We need to get the diference between warning and critical alerts!!! $real_status = db_get_row ("tagente_estado", "id_agente_modulo", $layoutData["id_agente_modulo"]); //Status for a whole agent, if agente_modulo was == 0 } else if ($layoutData['id_agent'] != 0) { $status = agents_get_status ($layoutData["id_agent"]); if ($status == -1) // agents_get_status return -1 for unknown! $status = VISUAL_MAP_STATUS_UNKNOWN; } else { $status = VISUAL_MAP_STATUS_UNKNOWN; $id_agent = 0; } if ($layoutData['id_metaconsole'] != 0) { //Restore db connection metaconsole_restore_db(); } break; default: //If it's a graph, a progress bar or a data tag, ALWAYS report status OK //(=0) to avoid confussions here. $status = VISUAL_MAP_STATUS_NORMAL; break; } } switch ($status) { case AGENT_MODULE_STATUS_CRITICAL_ALERT: $status = VISUAL_MAP_STATUS_CRITICAL_ALERT; break; case AGENT_MODULE_STATUS_WARNING_ALERT: $status = VISUAL_MAP_STATUS_WARNING_ALERT; break; } return $status; } /** * Prints visual map * * @param int $id_layout Layout id * @param bool $show_links * @param bool $draw_lines */ function visual_map_print_visual_map ($id_layout, $show_links = true, $draw_lines = true, $width = null, $height = null, $home_url = '') { enterprise_include_once('include/functions_visual_map.php'); //TODO: USE THE SAME CODE THAT THE VISUAL MAP EDITOR global $config; $metaconsole_hack = '/'; if (defined('METACONSOLE')) { $metaconsole_hack = '../../'; } enterprise_include_once("meta/include/functions_ui_meta.php"); $layout = db_get_row ('tlayout', 'id', $id_layout); if (empty($layout)) { ui_print_error_message(__('Cannot load the visualmap')); return; } $resizedMap = false; $proportion = 1; if (!is_null($width)) { $resizedMap = true; if (!is_null($height)) { $mapWidth = $width; $mapHeight = $height; } else { $mapWidth = $width; $proportion = $width / $layout["width"]; $mapHeight = $proportion * $layout["height"]; } if (defined('METACONSOLE')) { $backgroundImage = '/include/Image/image_functions.php?getFile=1&thumb=1&thumb_size=' . $mapWidth . 'x' . $mapHeight . '&file=' . $config['homeurl'] . 'images/console/background/' . io_safe_input ($layout["background"]); } else { $backgroundImage = '/include/Image/image_functions.php?getFile=1&thumb=1&thumb_size=' . $mapWidth . 'x' . $mapHeight . '&file=' . $config['homedir'] . '/images/console/background/' . io_safe_input ($layout["background"]); } } else { $mapWidth = $layout["width"]; $mapHeight = $layout["height"]; $backgroundImage = $metaconsole_hack . 'images/console/background/' . io_safe_input ($layout["background"]); } if (defined('METACONSOLE')) { echo "
"; } echo '
'; echo ""; $layout_datas = db_get_all_rows_field_filter('tlayout_data', 'id_layout', $id_layout); if (empty($layout_datas)) $layout_datas = array(); $lines = array (); foreach ($layout_datas as $layout_data) { if ($resizedMap) { //Hack to resize the text $layout_data["label"] = str_replace( 'visual_font_size', 'resize_visual_font_size', $layout_data["label"]); } //Check the items are from disabled or pending delete modules if ($layout_data['id_agente_modulo'] != 0 && (($layout_data['type'] != LABEL) || ($layout_data['type'] != ICON) || ($layout_data['type'] != SERVICE))) { $delete_pending_module = db_get_value ("delete_pending", "tagente_modulo", "id_agente_modulo", $layout_data["id_agente_modulo"]); $disabled_module = db_get_value ("disabled", "tagente_modulo", "id_agente_modulo", $layout_data["id_agente_modulo"]); if ($delete_pending_module == 1 || $disabled_module == 1) continue; } $layout_data['label'] = io_safe_output($layout_data['label']); // ************************************************************* // Get parent status (Could be an agent, module, map, // others doesnt have parent info) // ************************************************************* if ($layout_data["parent_item"] != 0) { $layout_data_parent = db_get_row_filter('tlayout_data', array('id' => $layout_data["parent_item"])); $status_parent = visual_map_get_status_element($layout_data_parent); $line['id'] = $layout_data['id']; $line['node_begin'] = 'layout-data-' . $layout_data["parent_item"]; $line['node_end'] = 'layout-data-' . $layout_data["id"]; switch ($status_parent) { default: case VISUAL_MAP_STATUS_UNKNOWN: $line["color"] = COL_UNKNOWN; // Gray break; case VISUAL_MAP_STATUS_WARNING: $line["color"] = COL_WARNING; // Yellow break; case VISUAL_MAP_STATUS_NORMAL: $line["color"] = COL_NORMAL; // Green break; case VISUAL_MAP_STATUS_CRITICAL_ALERT: case VISUAL_MAP_STATUS_CRITICAL_BAD: $line["color"] = COL_CRITICAL; // Red break; } array_push ($lines, $line); } // ************************************************************* // Get STATUS of current object // ************************************************************* $status = visual_map_get_status_element($layout_data); switch ($status) { case VISUAL_MAP_STATUS_CRITICAL_BAD: //Critical (BAD) $colorStatus = COL_CRITICAL; break; case VISUAL_MAP_STATUS_CRITICAL_ALERT: //Critical (ALERT) $colorStatus = COL_ALERTFIRED; break; case VISUAL_MAP_STATUS_NORMAL: //Normal (OK) $colorStatus = COL_NORMAL; break; case VISUAL_MAP_STATUS_WARNING: //Warning $colorStatus = COL_WARNING; break; case VISUAL_MAP_STATUS_UNKNOWN: default: //Unknown $colorStatus = COL_UNKNOWN; // Default is Grey (Other) break; } switch ($layout_data['type']) { case STATIC_GRAPH: if ($status == VISUAL_MAP_STATUS_CRITICAL_BAD) $z_index = 3; elseif ($status == VISUAL_MAP_STATUS_WARNING) $z_index = 2; elseif ($status == VISUAL_MAP_STATUS_CRITICAL_ALERT) $z_index = 4; else $z_index = 1; // Draw image if ($resizedMap) echo '
'; else echo '
'; if ($show_links) { if (!empty($layout_data['id_agent']) && empty($layout_data['id_layout_linked'])) { if ($layout_data['enable_link'] && can_user_access_node()) { $id_service = false; if (!defined('METACONSOLE')) { //Extract id service if it is a prediction module. $id_service = db_get_value_filter( 'custom_integer_1', 'tagente_modulo', array('id_agente_modulo' => $layout_data['id_agente_modulo'], 'prediction_module' => 1)); } if (!empty($id_service)) { //Link to an service page if (empty($layout_data['id_metaconsole'])) { $url = $config['homeurl'] . 'index.php?sec=services&sec2=enterprise/operation/services/services&id_service=' . $id_service . '&offset=0'; } else { $server = db_get_row('tmetaconsole_setup', 'id', $layout_data['id_metaconsole']); $url = $server["server_url"] . "/" . 'index.php?sec=services&sec2=enterprise/operation/services/services&id_service=' . $id_service . '&offset=0'; } } else if ($layout_data['id_agente_modulo'] != 0) { // Link to an module if (empty($layout_data['id_metaconsole'])) { $url = $config['homeurl'] . 'index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layout_data['id_agente_modulo']; } else { $url = ui_meta_get_url_console_child( $layout_data['id_metaconsole'], "estado", "operation/agentes/ver_agente&id_agente=" . $layout_data['id_agent']); } } else { // Link to an agent if (empty($layout_data['id_metaconsole'])) { $url = $config['homeurl'] . 'index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $layout_data['id_agent']; } else { $url = ui_meta_get_url_console_child( $layout_data['id_metaconsole'], "estado", "operation/agentes/ver_agente&id_agente=" . $layout_data['id_agent']); } } echo ''; } } elseif ($layout_data['id_layout_linked'] > 0) { // Link to a map if (empty($layout_data['id_metaconsole'])) { echo ''; } else { $pure = get_parameter('pure', 0); echo ''; } } else { // A void object echo ''; } } $img_style = array (); $img_style["title"] = strip_tags($layout_data["label"]); if (!empty ($layout_data["width"])) { $img_style["width"] = $layout_data["width"]; } if (!empty ($layout_data["height"])) { $img_style["height"] = $layout_data["height"]; } $img = "images/console/icons/" . $layout_data["image"]; switch ($status) { case VISUAL_MAP_STATUS_CRITICAL_BAD: $img .= "_bad.png"; break; case VISUAL_MAP_STATUS_CRITICAL_ALERT: $img = "4" . $img . "_bad.png"; break; case VISUAL_MAP_STATUS_WARNING_ALERT: $img = "4" . $img . "_warning.png"; break; case VISUAL_MAP_STATUS_NORMAL: $img .= "_ok.png"; break; case VISUAL_MAP_STATUS_WARNING: $img .= "_warning.png"; break; case VISUAL_MAP_STATUS_UNKNOWN: default: // Default is Grey (Other) $img .= ".png"; break; } $borderStyle = ''; if (substr($img,0,1) == '4') { $img_style['border'] = '2px solid #ffa300;'; $img = substr_replace($img, '', 0,1); } if (is_file($config['homedir'] . '/' . $img)) $infoImage = getimagesize($config['homedir'] . '/' . $img); if (!empty ($layout_data["width"])) { if ($resizedMap) $img_style["width"] = (integer)($proportion * $layout_data["width"]); else $img_style["width"] = $layout_data["width"]; } else $img_style["width"] = (integer)($proportion * $infoImage[0]); if (!empty ($layout_data["height"])) { if ($resizedMap) $img_style["height"] = (integer)($proportion * $img_style["height"]); else $img_style["height"] = $layout_data["height"]; } else $img_style["height"] = (integer)($proportion * $infoImage[1]); html_print_image ($metaconsole_hack . $img, false, $img_style); // Print label if valid label_color (only testing for starting with #) otherwise print nothing if ($layout_data['label_color'][0] == '#') { echo "
"; echo io_safe_output($layout_data['label']); } echo "
"; echo ""; break; case LABEL: $z_index = 4; if ($resizedMap) echo '
'; else echo '
'; $endTagA = false; if ($show_links) { if ($layout_data['id_layout_linked'] > 0) { // Link to a map echo ''; $endTagA = true; } } if ($layout_data['label_color'][0] == '#') { echo "
"; echo io_safe_output($layout_data['label']); } if ($endTagA) echo "
"; echo "
"; break; case ICON: $z_index = 4; if ($resizedMap) echo '
'; else echo '
'; $endTagA = false; if ($show_links) { $url_icon = ""; if ($layout_data['id_layout_linked'] > 0) { // Link to a map if (empty($layout_data['id_metaconsole'])) { echo ''; } else { $pure = get_parameter('pure', 0); echo ''; } $endTagA = true; } elseif (preg_match('//', $layout_data['label'], $matches)) { // Link to an URL if ($layout_data['enable_link']) { $url_icon = strip_tags($matches[1]); echo ''; $endTagA = true; } } elseif (preg_match('/^.*(http:\/\/)((.)+).*$/i', $layout_data['label'])) { // Link to an URL if ($layout_data['enable_link']) { $url_icon = strip_tags($layout_data['label']); echo ''; $endTagA = true; } } } $img_style = array (); $img_style["title"] = strip_tags($layout_data["label"]); if (!empty ($layout_data["width"])) { $img_style["width"] = $layout_data["width"]; } if (!empty ($layout_data["height"])) { $img_style["height"] = $layout_data["height"]; } $img = "images/console/icons/".$layout_data["image"] . ".png"; if (is_file($config['homedir'] . '/' . $img)) $infoImage = getimagesize($config['homedir'] . '/' . $img); if (!empty ($layout_data["width"])) { if ($resizedMap) $img_style["width"] = (integer)($proportion * $layout_data["width"]); else $img_style["width"] = $layout_data["width"]; } else $img_style["width"] = (integer)($proportion * $infoImage[0]); if (!empty ($layout_data["height"])) { if ($resizedMap) $img_style["height"] = (integer)($proportion * $img_style["height"]); else $img_style["height"] = $layout_data["height"]; } else $img_style["height"] = (integer)($proportion * $infoImage[1]); html_print_image ($metaconsole_hack . $img, false, $img_style); if ($endTagA) echo ""; echo "
"; break; case SIMPLE_VALUE: case SIMPLE_VALUE_MAX: case SIMPLE_VALUE_MIN: case SIMPLE_VALUE_AVG: //Metaconsole db connection if ($layout_data['id_metaconsole'] != 0) { $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layout_data['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } $unit_text = db_get_sql ('SELECT unit FROM tagente_modulo WHERE id_agente_modulo = ' . $layout_data['id_agente_modulo']); //Restore db connection if ($layout_data['id_metaconsole'] != 0) { metaconsole_restore_db(); } $unit_text = trim(io_safe_output($unit_text)); if ($resizedMap) echo '
'; else echo '
'; $endTagA = false; if ($show_links) { //Extract id service if it is a prediction module. $id_service = db_get_value_filter('custom_integer_1', 'tagente_modulo', array('id_agente_modulo' => $layout_data['id_agente_modulo'], 'prediction_module' => 1)); if (!empty($id_service) && can_user_access_node()) { if ($layout_data['enable_link']) { //Link to an service page if (!empty($layout_data['id_metaconsole'])) { $server = db_get_row('tmetaconsole_setup', 'id', $layout_data['id_metaconsole']); echo ''; } else { echo ''; } $endTagA = true; } } elseif ($layout_data['id_layout_linked'] > 0) { // Link to a map if (empty($layout_data['id_metaconsole'])) { echo ''; } else { $pure = get_parameter('pure', 0); echo ''; } $endTagA = true; } } $label_simple_value = io_safe_output($layout_data['label']); if (strstr($label_simple_value, '(_VALUE_)') === false) { //OLD MODE $label_simple_value = '' . $label_simple_value . ' '; } else { //NEW MODE WITH MACRO (_VALUE_) } //TODO: change interface to add a period parameter, now is set to 1 day switch ($layout_data['type']) { case SIMPLE_VALUE: //Metaconsole db connection if ($layout_data['id_metaconsole'] != 0) { $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layout_data['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } $value = db_get_value ('datos', 'tagente_estado', 'id_agente_modulo', $layout_data['id_agente_modulo']); //Restore db connection if ($layout_data['id_metaconsole'] != 0) { metaconsole_restore_db(); } // If the value is a string, dont format it if (!is_string($value)) { $value = format_for_graph($value, 2); } if (!empty($unit_text)) $value .= " " . $unit_text; break; case SIMPLE_VALUE_MAX: //Metaconsole db connection if ($layout_data['id_metaconsole'] != 0) { $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layout_data['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } $value = reporting_get_agentmodule_data_max( $layout_data['id_agente_modulo'], $layout_data['period'], 0); //Restore db connection if ($layout_data['id_metaconsole'] != 0) { metaconsole_restore_db(); } if ($value === false) { $value = __('Unknown'); } else { $value = format_for_graph($value, 2); if (!empty($unit_text)) $value .= " " . $unit_text; } break; case SIMPLE_VALUE_MIN: //Metaconsole db connection if ($layout_data['id_metaconsole'] != 0) { $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layout_data['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } $value = reporting_get_agentmodule_data_min( $layout_data['id_agente_modulo'], $layout_data['period'], 0); //Restore db connection if ($layout_data['id_metaconsole'] != 0) { metaconsole_restore_db(); } if ($value === false) { $value = __('Unknown'); } else { $value = format_for_graph($value, 2); if (!empty($unit_text)) $value .= " " . $unit_text; } break; case SIMPLE_VALUE_AVG: //Metaconsole db connection if ($layout_data['id_metaconsole'] != 0) { $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layout_data['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } $value = reporting_get_agentmodule_data_average( $layout_data['id_agente_modulo'], $layout_data['period'], 0); //Restore db connection if ($layout_data['id_metaconsole'] != 0) { metaconsole_restore_db(); } if ($value === false) { $value = __('Unknown'); } else { $value = format_for_graph($value, 2); if (!empty($unit_text)) $value .= " " . $unit_text; } break; } if (strstr($label_simple_value, '(_VALUE_)') === false) { //OLD MODE $label_simple_value .= $value . ''; } else { //NEW MODE WITH MACRO (_VALUE_) $label_simple_value = str_replace('(_VALUE_)', $value, $label_simple_value); } echo $label_simple_value; if ($endTagA) echo ''; echo '
'; break; case PERCENTILE_BAR: case PERCENTILE_BUBBLE: if ($resizedMap) echo '
'; else echo '
'; //Metaconsole db connection if ($layout_data['id_metaconsole'] != 0) { $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layout_data['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } $valor = db_get_sql ('SELECT datos FROM tagente_estado WHERE id_agente_modulo = '.$layout_data['id_agente_modulo']); $unit_text = db_get_sql ('SELECT unit FROM tagente_modulo WHERE id_agente_modulo = ' . $layout_data['id_agente_modulo']); //Restore db connection if ($layout_data['id_metaconsole'] != 0) { metaconsole_restore_db(); } $width = $layout_data['width']; if ( $layout_data['height'] > 0) $percentile = $valor / $layout_data['height'] * 100; else $percentile = 100; $percentile = round($percentile); $endTagA = false; echo io_safe_output($layout_data['label']); echo "
"; if ($show_links) { if (!empty($layout_data['id_agent']) && empty($layout_data['id_layout_linked'])) { if ($layout_data['enable_link'] && can_user_access_node()) { //Extract id service if it is a prediction module. $id_service = db_get_value_filter('custom_integer_1', 'tagente_modulo', array( 'id_agente_modulo' => $layout_data['id_agente_modulo'], 'prediction_module' => 1)); if ($id_service === false) { $id_service = 0; } if ($id_service != 0) { //Link to an service page if (!empty($layout_data['id_metaconsole'])) { $server = db_get_row('tmetaconsole_setup', 'id', $layout_data['id_metaconsole']); echo ''; } else { echo ''; } $endTagA = true; } else if ($layout_data['id_agente_modulo'] != 0) { // Link to an module if (!empty($layout_data['id_metaconsole'])) { $server = db_get_row('tmetaconsole_setup', 'id', $layout_data['id_metaconsole']); echo ''; } else { echo ''; } $endTagA = true; } else { // Link to an agent if (empty($layout_data['id_metaconsole'])) { $url = $config['homeurl'] . 'index.php?' . 'sec=estado&' . 'sec2=operation/agentes/ver_agente&id_agente='.$layout_data['id_agent']; } else { $url = ui_meta_get_url_console_child( $layout_data['id_metaconsole'], "estado", 'operation/agentes/ver_agente&id_agente='.$layout_data['id_agent']); } echo ''; $endTagA = true; } } } elseif ($layout_data['id_layout_linked'] > 0) { // Link to a map if (empty($layout_data['id_metaconsole'])) { echo ''; } else { $pure = get_parameter('pure', 0); echo ''; } $endTagA = true; } else { // A void object echo ''; $endTagA = true; } } $value_text = false; if ($layout_data['image'] == 'percent') { $value_text = false; } elseif ($layout_data['image'] == 'value') { $unit_text = trim(io_safe_output($unit_text)); $value_text = format_for_graph($valor, 2); if (!empty($unit_text)) $value_text .= " " . $unit_text; } if ($layout_data['type'] == 9) { if ($resizedMap) echo progress_bubble($percentile, ((integer)($proportion * $width)), $width, '', 1, $value_text, $colorStatus); else echo progress_bubble($percentile, $width, $width, '', 1, $value_text, $colorStatus); } else { if ($resizedMap) echo progress_bar($percentile, ((integer)($proportion * $width)), 15, '', 1, $value_text, $colorStatus); else echo progress_bar($percentile, $width, 15, '', 1, $value_text, $colorStatus); } if ($endTagA) echo ''; echo '
'; break; case MODULE_GRAPH: if ($resizedMap) { $layout_data['width'] = ((integer)($proportion * $layout_data['width'])); $layout_data['height'] = ((integer)($proportion * $layout_data['height'])); $layout_data['pos_x'] = ((integer)($proportion * $layout_data['pos_x'])); $layout_data['pos_y'] = ((integer)($proportion * $layout_data['pos_y'])); } echo '
'; echo io_safe_output($layout_data['label']); echo "
"; $endTagA = false; if ($show_links) { if (( ($layout_data['id_layout_linked'] == "") || ($layout_data['id_layout_linked'] == 0)) && can_user_access_node()) { if ($layout_data['enable_link']) { //Extract id service if it is a prediction module. $id_service = db_get_value_filter('custom_integer_1', 'tagente_modulo', array('id_agente_modulo' => $layout_data['id_agente_modulo'], 'prediction_module' => 1)); if ($id_service === false) { $id_service = 0; } if ($id_service != 0) { //Link to an service page if (!empty($layout_data['id_metaconsole'])) { $server = db_get_row('tmetaconsole_setup', 'id', $layout_data['id_metaconsole']); echo ''; } else { echo ''; } } else { if (empty($layout_data['id_metaconsole'])) { echo ''; } else { $url = ui_meta_get_url_console_child( $layout_data['id_metaconsole'], "estado", 'operation/agentes/ver_agente&id_agente='.$layout_data["id_agent"].'&tab=data'); } echo ''; } } } else { // Link to a map if (empty($layout_data['id_metaconsole'])) { echo ''; } else { $pure = get_parameter('pure', 0); echo ''; } } } //Metaconsole db connection if ($layout_data['id_metaconsole'] != 0) { $connection = db_get_row_filter ('tmetaconsole_setup', array('id' => $layout_data['id_metaconsole'])); if (metaconsole_load_external_db($connection) != NOERR) { //ui_print_error_message ("Error connecting to ".$server_name); continue; } } // ATTENTION: DO NOT USE & here because is bad-translated and doesnt work // resulting fault image links :( echo grafico_modulo_sparse ($layout_data['id_agente_modulo'], $layout_data['period'], false, $layout_data['width'], $layout_data['height'], '', null, false, 1, false, 0, '', 0, 0, true, true, $home_url, 1); //Restore db connection if ($layout_data['id_metaconsole'] != 0) { metaconsole_restore_db(); } echo ""; echo "
"; break; default: enterprise_hook("enterprise_visual_map_print_item", array($layout_data, $status, $colorStatus, 'operation')); break; } } if ($draw_lines) { /* If you want lines in the map, call using Javascript: draw_lines (lines, id_div); on body load, where id_div is the id of the div which holds the map */ echo ''; } // End main div echo "
"; if (defined('METACONSOLE')) { echo "
"; } } //End function //Start function /** * Get a list with the layouts for a user. * * @param int User id. * @param bool Wheter to return all the fields or only the name (to use in * html_print_select() directly) * @param array Additional filters to filter the layouts. * @param bool Whether to return All group or not. * * @return array A list of layouts the user can see. */ function visual_map_get_user_layouts ($id_user = 0, $only_names = false, $filter = false, $returnAllGroup = true) { if (! is_array ($filter)) $filter = array (); $where = db_format_array_where_clause_sql ($filter); if ($returnAllGroup) $groups = users_get_groups ($id_user, 'RR'); else $groups = users_get_groups ($id_user, 'RR', false); if (!empty($groups)) { if ($where != '') { $where .= ' AND '; } $where .= sprintf ('id_group IN (%s)', implode (",", array_keys ($groups))); } if ($where == '') { $where = array(); } $layouts = db_get_all_rows_filter ('tlayout', $where); if ($layouts == false) return array (); $retval = array (); foreach ($layouts as $layout) { if ($only_names) $retval[$layout['id']] = $layout['name']; else $retval[$layout['id']] = $layout; } return $retval; } /** * Get the status of a layout. * * It gets all the data of the contained elements (including nested * layouts), and makes an AND operation to be sure that all the items * are OK. If any of them is down, then result is down (0) * * @param int Id of the layout * @param int Depth (for recursion control) * * @return bool The status of the given layout. True if it's OK, false if not. */ function visual_map_get_layout_status ($id_layout = 0, $depth = 0) { $temp_status = VISUAL_MAP_STATUS_NORMAL; $temp_total = VISUAL_MAP_STATUS_NORMAL; $depth++; // For recursion depth checking // TODO: Implement this limit as a configurable item in setup if ($depth > 10) { return VISUAL_MAP_STATUS_UNKNOWN; // No status data if we need to exit by a excesive recursion } $id_layout = (int) $id_layout; $result = db_get_all_rows_filter ('tlayout_data', array ('id_layout' => $id_layout), array ('id_agente_modulo', 'parent_item', 'id_layout_linked', 'id_agent', 'type')); if ($result === false) return VISUAL_MAP_STATUS_NORMAL; foreach ($result as $rownum => $data) { if (($data["id_layout_linked"] == 0 && $data["id_agente_modulo"] == 0 && $data["id_agent"] == 0) || $data['type'] != 0) continue; // Other Layout (Recursive!) if (($data["id_layout_linked"] != 0) && ($data["id_agente_modulo"] == 0)) { $status = visual_map_get_layout_status ($data["id_layout_linked"], $depth); } // Module elseif ($data["id_agente_modulo"] != 0) { $status = modules_get_agentmodule_status ($data["id_agente_modulo"]); } // Agent else { $status = agents_get_status ($data["id_agent"]); } if ($status == VISUAL_MAP_STATUS_CRITICAL_BAD) return VISUAL_MAP_STATUS_CRITICAL_BAD; if ($status > $temp_total) $temp_total = $status; } return $temp_total; } /** * Make a text for the parent select, when the label is not empty put this for * the return text. Instead for the empty labels make the text with next form * () - ( - ) () * * @param string $label The label of item in visual map. * @param string $type The label of type in visual map. * @param string $image The image of item in visual map. * @param string $agent The agent name of item in visual map. * @param string $id_module The module name of item in visual map. * @param int $idData The id of item in visual map. * * @return string The text for the parent. */ function visual_map_create_internal_name_item($label = null, $type, $image, $agent = null, $id_module, $idData) { $text = ''; if (empty($label)) { switch ($type) { case 'module_graph': case MODULE_GRAPH: $text = __('Module graph'); break; case 'percentile_bar': case PERCENTILE_BAR: $text = __('Percentile bar'); break; case 'static_graph': case STATIC_GRAPH: $text = __('Static graph') . " - " . $image; break; case 'simple_value': case SIMPLE_VALUE: $text = __('Simple Value'); break; case 'label': case LABEL: $text = __('Label'); break; case 'icon': case ICON: $text = __('Icon') . " - " . $image; break; } if (!empty($agent)) { $text .= " (" . ui_print_truncate_text($agent, 'agent_small', false); $moduleName = io_safe_output(db_get_value('nombre', 'tagente_modulo', 'id_agente_modulo', $id_module)); if (!empty($moduleName)) { $text .= " - " . ui_print_truncate_text($moduleName, 'module_small', false); } $text .= ")"; } $text .= ' (' . $idData . ')'; } else { $text = $label; } return io_safe_output($text); } function visual_map_get_items_parents($idVisual) { $items = db_get_all_rows_filter('tlayout_data',array('id_layout' => $idVisual)); if ($items == false) { $items = array(); } $return = array(); foreach ($items as $item) { $agent = null; if ($item['id_agent'] != 0) { $agent = io_safe_output(agents_get_name($item['id_agent'])); } $return[$item['id']] = visual_map_create_internal_name_item($item['label'], $item['type'], $item['image'], $agent, $item['id_agente_modulo'], $item['id']); } return $return; } /** * Get the X axis coordinate of a layout item * * @param int Id of the layout to get. * * @return int The X axis coordinate value. */ function visual_map_get_layoutdata_x ($id_layoutdata) { return (float) db_get_value ('pos_x', 'tlayout_data', 'id', (int) $id_layoutdata); } /** * Get the Y axis coordinate of a layout item * * @param int Id of the layout to get. * * @return int The Y axis coordinate value. */ function visual_map_get_layoutdata_y ($id_layoutdata){ return (float) db_get_value ('pos_y', 'tlayout_data', 'id', (int) $id_layoutdata); } ?>