'; echo $text; echo ''; echo ''; } function visual_map_print_user_line_handles($layoutData) { $id = $layoutData['id']; $start_x = $layoutData['pos_x']; $start_y = $layoutData['pos_y']; $end_x = $layoutData['width']; $end_y = $layoutData['height']; $z_index = 2; $sizeStyle = ""; $radious_handle = 12 / 2; //Handle of start echo '
'; html_print_image("images/dot_red.png"); echo "
"; //Handle of end echo '
'; html_print_image("images/dot_green.png"); echo "
"; } function visual_map_print_item($mode = "read", $layoutData, $proportion = 1, $show_links = true) { global $config; require_once ($config["homedir"] . '/include/functions_graph.php'); require_once ($config["homedir"] . '/include/functions_custom_graphs.php'); $width = $layoutData['width']; $height = $max_percentile = $layoutData['height']; $top = $layoutData['pos_y']; $left = $layoutData['pos_x']; $id = $layoutData['id']; $label = io_safe_output($layoutData['label']); $id_module = $layoutData['id_agente_modulo']; $type = $layoutData['type']; $period = $layoutData['period']; $border_width = $layoutData['border_width']; $border_color = $layoutData['border_color']; $fill_color = $layoutData['fill_color']; $sizeStyle = ''; $borderStyle = ''; $imageSize = ''; $text = '' . $label . ''; if (!isset($layoutData['status_calculated'])) { $layoutData['status_calculated'] = visual_map_get_status_element($layoutData); } $status = $layoutData['status_calculated']; 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; } $element_enterprise = array(); if (enterprise_installed()) { $element_enterprise = enterprise_visual_map_print_item( $mode, $layoutData, $proportion, $show_links); } $link = false; $url = "#"; if ($show_links && ($mode == 'read')) { switch ($type) { case STATIC_GRAPH: case GROUP_ITEM: if ($layoutData['enable_link'] && can_user_access_node()) { $link = true; } break; case LABEL: if ($layoutData['id_layout_linked'] != 0) { $link = true; } break; case ICON: if ($layoutData['id_layout_linked'] > 0) { $link = true; } elseif (preg_match('//', $layoutData['label'], $matches)) { // Link to an URL if ($layoutData['enable_link']) { $link = true; } } elseif (preg_match('/^.*(http:\/\/)((.)+).*$/i', $layoutData['label'])) { // Link to an URL if ($layoutData['enable_link']) { $link = true; } } break; case SIMPLE_VALUE: case SIMPLE_VALUE_MAX: case SIMPLE_VALUE_MIN: case SIMPLE_VALUE_AVG: //Extract id service if it is a prediction module. $id_service = db_get_value_filter('custom_integer_1', 'tagente_modulo', array('id_agente_modulo' => $layoutData['id_agente_modulo'], 'prediction_module' => 1)); if (!empty($id_service) && can_user_access_node()) { if ($layoutData['enable_link']) { $link = true; } } elseif ($layoutData['id_layout_linked'] > 0) { $link = true; } elseif ($layoutData['enable_link'] && can_user_access_node()) { $link = true; } break; case PERCENTILE_BAR: case PERCENTILE_BUBBLE: if (!empty($layoutData['id_agent']) && empty($layoutData['id_layout_linked'])) { if ($layoutData['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' => $layoutData['id_agente_modulo'], 'prediction_module' => 1)); if (!empty($id_service)) { //Link to an service page $link = true; } else if ($layoutData['id_agente_modulo'] != 0) { // Link to an module $link = true; } else { // Link to an agent $link = true; } } } elseif ($layoutData['id_layout_linked'] > 0) { // Link to a map $link = true; } break; case MODULE_GRAPH: if (( ($layoutData['id_layout_linked'] == "") || ($layoutData['id_layout_linked'] == 0)) && can_user_access_node()) { if ($layoutData['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' => $layoutData['id_agente_modulo'], 'prediction_module' => 1)); if ($id_service === false) { $id_service = 0; } if ($id_service != 0) { //Link to an service page if (!empty($layoutData['id_metaconsole'])) { $link = true; } else { $link = true; } } else { $link = true; } } } else { // Link to a map $link = true; } break; default: if (!empty($element_enterprise)) { $link = $element_enterprise['link']; } break; } } if ($link) { switch ($type) { case STATIC_GRAPH: $is_a_service = false; $is_a_link_to_other_visualconsole = false; if (enterprise_installed()) { $id_service = services_service_from_module ($layoutData['id_agente_modulo']); if (!empty($id_service)) $is_a_service = true; } if ($layoutData['id_layout_linked'] != 0) { $is_a_link_to_other_visualconsole = true; } if ($is_a_service) { if (empty($layoutData['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', $layoutData['id_metaconsole']); $url = $server["server_url"] . "/" . 'index.php?sec=services&sec2=enterprise/operation/services/services&id_service=' . $id_service . '&offset=0'; } } else if ($is_a_link_to_other_visualconsole) { if (empty($layout_data['id_metaconsole'])) { $url = $config['homeurl'] . "index.php?sec=reporting&sec2=operation/visual_console/render_view&pure=" . $config["pure"] . "&id=" . $layoutData["id_layout_linked"]; } else { $url = "index.php?sec=screen&sec2=screens/screens&action=visualmap&pure=0&id_visualmap=" . $layoutData["id_layout_linked"] . "&refr=0"; } } else { if ($layoutData['id_agente_modulo'] != 0) { // Link to an module if (empty($layoutData['id_metaconsole'])) { $url = $config['homeurl'] . 'index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo']; } else { $url = ui_meta_get_url_console_child( $layoutData['id_metaconsole'], "estado", "operation/agentes/ver_agente&id_agente=" . $layoutData['id_agent']); } } else { // Link to an agent if (empty($layoutData['id_metaconsole'])) { $url = $config['homeurl'] . 'index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=' . $layoutData['id_agent']; } else { $url = ui_meta_get_url_console_child( $layoutData['id_metaconsole'], "estado", "operation/agentes/ver_agente&id_agente=" . $layoutData['id_agent']); } } } break; case GROUP_ITEM: $is_a_link_to_other_visualconsole = false; if ($layoutData['id_layout_linked'] != 0) { $is_a_link_to_other_visualconsole = true; } if ($is_a_link_to_other_visualconsole) { if (empty($layout_data['id_metaconsole'])) { $url = $config['homeurl'] . "index.php?sec=reporting&sec2=operation/visual_console/render_view&pure=" . $config["pure"] . "&id=" . $layoutData["id_layout_linked"]; } else { $url = "index.php?sec=screen&sec2=screens/screens&action=visualmap&pure=1&id_visualmap=" . $layoutData["id_layout_linked"] . "&refr=0"; } } else { $url = $config['homeurl'] . 'index.php?sec=estado&sec2=operation/agentes/estado_agente&group_id=' . $layoutData['id_group']; } break; case LABEL: if ($layoutData['id_layout_linked'] != 0) { // Link to a map $url = $config['homeurl'] . 'index.php?sec=reporting&sec2=operation/visual_console/render_view&pure='.$config["pure"].'&id='.$layoutData["id_layout_linked"]; } break; case ICON: $url_icon = ""; if ($layoutData['id_layout_linked'] != 0) { // Link to a map if (empty($layoutData['id_metaconsole'])) { $url = 'index.php?sec=reporting&sec2=operation/visual_console/render_view&pure='.$config["pure"].'&id='.$layoutData["id_layout_linked"]; } else { $pure = get_parameter('pure', 0); $url = 'index.php?sec=screen&sec2=screens/screens&action=visualmap&pure=' . $pure . '&id_visualmap=' . $layoutData["id_layout_linked"] . '&refr=0'; } } elseif (preg_match('//', $layoutData['label'], $matches)) { // Link to an URL if ($layoutData['enable_link']) { $url = strip_tags($matches[1]); } } elseif (preg_match('/^.*(http:\/\/)((.)+).*$/i', $layoutData['label'])) { // Link to an URL if ($layoutData['enable_link']) { $url = strip_tags($layoutData['label']); } } break; case SIMPLE_VALUE: case SIMPLE_VALUE_MAX: case SIMPLE_VALUE_MIN: case SIMPLE_VALUE_AVG: //Extract id service if it is a prediction module. $id_service = db_get_value_filter('custom_integer_1', 'tagente_modulo', array('id_agente_modulo' => $layoutData['id_agente_modulo'], 'prediction_module' => 1)); if (!empty($id_service) && can_user_access_node()) { //Link to an service page if (!empty($layoutData['id_metaconsole'])) { $server = db_get_row('tmetaconsole_setup', 'id', $layoutData['id_metaconsole']); $url = $server["server_url"] . "/" . 'index.php?sec=services&sec2=enterprise/operation/services/services&id_service=' . $id_service . '&offset=0'; } else { $url = 'index.php?sec=services&sec2=enterprise/operation/services/services&id_service=' . $id_service . '&offset=0'; } } elseif ($layoutData['id_layout_linked'] > 0) { // Link to a map if (empty($layoutData['id_metaconsole'])) { $url = 'index.php?sec=reporting&sec2=operation/visual_console/render_view&pure='.$config["pure"].'&id='.$layoutData["id_layout_linked"]; } else { $pure = get_parameter('pure', 0); $url = 'index.php?sec=screen&sec2=screens/screens&action=visualmap&pure=' . $pure . '&id_visualmap=' . $layoutData["id_layout_linked"] . '&refr=0'; } } elseif ($layoutData['id_agente_modulo'] != 0) { // Link to an module if (empty($layoutData['id_metaconsole'])) { $url = $config['homeurl'] . 'index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo']; } else { $url = ui_meta_get_url_console_child( $layoutData['id_metaconsole'], "estado", "operation/agentes/ver_agente&id_agente=" . $layoutData['id_agent']); } } break; case PERCENTILE_BAR: case PERCENTILE_BUBBLE: if (!empty($layoutData['id_agent'])) { //Extract id service if it is a prediction module. $id_service = db_get_value_filter('custom_integer_1', 'tagente_modulo', array( 'id_agente_modulo' => $layoutData['id_agente_modulo'], 'prediction_module' => 1)); if (!empty($id_service)) { //Link to an service page if (!empty($layoutData['id_metaconsole'])) { $server = db_get_row('tmetaconsole_setup', 'id', $layoutData['id_metaconsole']); $url = $server["server_url"] . "/" . 'index.php?sec=services&sec2=enterprise/operation/services/services&id_service=' . $id_service . '&offset=0'; } else { $url = 'index.php?sec=services&sec2=enterprise/operation/services/services&id_service=' . $id_service . '&offset=0'; } } else if ($layoutData['id_agente_modulo'] != 0) { // Link to an module if (!empty($layoutData['id_metaconsole'])) { $server = db_get_row('tmetaconsole_setup', 'id', $layoutData['id_metaconsole']); $url = $server["server_url"] . '/index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo']; } else { $url = $config['homeurl'].'/index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo']; } } else { // Link to an agent if (empty($layoutData['id_metaconsole'])) { $url = $config['homeurl'] . 'index.php?' . 'sec=estado&' . 'sec2=operation/agentes/ver_agente&id_agente='.$layoutData['id_agent']; } else { $url = ui_meta_get_url_console_child( $layoutData['id_metaconsole'], "estado", 'operation/agentes/ver_agente&id_agente='.$layoutData['id_agent']); } } } elseif ($layoutData['id_layout_linked'] > 0) { // Link to a map if (empty($layoutData['id_metaconsole'])) { $url = 'index.php?sec=reporting&sec2=operation/visual_console/render_view&pure='.$config["pure"].'&id='.$layoutData["id_layout_linked"]; } else { $pure = get_parameter('pure', 0); $url = 'index.php?sec=screen&sec2=screens/screens&action=visualmap&pure=' . $pure . '&id_visualmap=' . $layoutData["id_layout_linked"] . '&refr=0'; } } break; case MODULE_GRAPH: if (( ($layoutData['id_layout_linked'] == "") || ($layoutData['id_layout_linked'] == 0)) && can_user_access_node()) { if ($layoutData['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' => $layoutData['id_agente_modulo'], 'prediction_module' => 1)); if (!empty($id_service)) { //Link to an service page if (!empty($layoutData['id_metaconsole'])) { $server = db_get_row('tmetaconsole_setup', 'id', $layoutData['id_metaconsole']); $url = $server["server_url"] . '/index.php?sec=services&sec2=enterprise/operation/services/services&id_service=' . $id_service . '&offset=0'; } else { $url = $config['homeurl'] . '/index.php?sec=services&sec2=enterprise/operation/services/services&id_service=' . $id_service . '&offset=0'; } } else { if (empty($layoutData['id_metaconsole'])) { $url = $config['homeurl'] . '/index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo']; } else { $url = ui_meta_get_url_console_child( $layoutData['id_metaconsole'], "estado", 'operation/agentes/ver_agente&id_agente='.$layoutData["id_agent"].'&tab=data'); } } } } else { // Link to a map if (empty($layoutData['id_metaconsole'])) { $url = $config['homeurl'] . '/index.php?sec=reporting&sec2=operation/visual_console/render_view&pure='.$config["pure"].'&id='.$layoutData["id_layout_linked"]; } else { $pure = get_parameter('pure', 0); $url = $config['homeurl'] . '/index.php?sec=screen&sec2=screens/screens&action=visualmap&pure=' . $pure . '&id_visualmap=' . $layoutData["id_layout_linked"] . '&refr=0'; } } break; default: if (!empty($element_enterprise)) { $url = $element_enterprise['url']; } break; } } // + 1 for to avoid the box and lines items are on the top of // others $z_index = 1 + 1; switch ($type) { case STATIC_GRAPH: case GROUP_ITEM: if ($layoutData['image'] != null) { $img = visual_map_get_image_status_element($layoutData, $layoutData['status_calculated']); if (substr($img,0,1) == '4') { $borderStyle ='border: 2px solid ' . COL_ALERTFIRED . ';'; $img = substr_replace($img, '', 0,1); } } if (($width != 0) && ($height != 0)) { $sizeStyle = 'width: ' . $width . 'px; height: ' . $height . 'px;'; $imageSize = 'width="' . $width . '" height="' . $height . '"'; } if ($status == VISUAL_MAP_STATUS_CRITICAL_BAD) $z_index = 3 + 1; elseif ($status == VISUAL_MAP_STATUS_WARNING) $z_index = 2 + 1; elseif ($status == VISUAL_MAP_STATUS_CRITICAL_ALERT) $z_index = 4 + 1; else $z_index = 1 + 1; break; case ICON: if ($layoutData['image'] != null) { $img = visual_map_get_image_status_element($layoutData, $layoutData['status_calculated']); } if (($width != 0) && ($height != 0)) { $sizeStyle = 'width: ' . $width . 'px; height: ' . $height . 'px;'; $imageSize = 'width="' . $width . '" height="' . $height . '"'; } $z_index = 4 + 1; 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; break; case MODULE_GRAPH: $width = ((integer)($proportion * $width)); $height = ((integer)($proportion * $height)); //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; } } if ($layoutData['id_custom_graph'] != 0) { $img = custom_graphs_print( $layoutData['id_custom_graph'], $height, $width, $period, null, true, 0, true, $layoutData['image']); } else { $img = grafico_modulo_sparse($id_module, $period, 0, $width, $height, '', null, false, 1, false, 0, '', 0, 0, true, true, '', 1, false, '', false, false, true, $layoutData['image']); } //Restore db connection if ($layoutData['id_metaconsole'] != 0) { metaconsole_restore_db(); } $img = str_replace('>', 'class="image" id="image_' . $id . '" />', $img); break; case LABEL: $z_index = 4 + 1; break; case BOX_ITEM: $z_index = 1; break; } $class = "item "; switch ($type) { case STATIC_GRAPH: $class .= "static_graph"; break; case GROUP_ITEM: $class .= "group_item"; break; case PERCENTILE_BAR: case PERCENTILE_BUBBLE: $class .= "percentile_item"; break; case MODULE_GRAPH: $class .= "module_graph"; break; case SIMPLE_VALUE: case SIMPLE_VALUE_MAX: case SIMPLE_VALUE_MIN: case SIMPLE_VALUE_AVG: $class .= "simple_value"; break; case LABEL: $class .= "label"; break; case ICON: $class .= "icon"; break; case BOX_ITEM: $class .= "box_item"; break; default: if (!empty($element_enterprise)) { $class .= $element_enterprise['class']; } break; } $top = (int)($proportion * $top); $left = (int)($proportion * $left); echo '
'; if ($link) { echo ""; } switch ($type) { case BOX_ITEM: $style = ""; $style .= "width: " . ($width * $proportion) . "px; "; $style .= "height: " . ($height * $proportion) . "px; "; $style .= "border-style: solid; "; $style .= "border-width: " . $border_width . "px; "; $style .= "border-color: " . $border_color . "; "; $style .= "background-color: " . $fill_color . "; "; echo "
"; break; case STATIC_GRAPH: case GROUP_ITEM: echo "
"; if ($layoutData['image'] != null) { $img_style_title = strip_tags($label); if ($layoutData['type'] == STATIC_GRAPH) { if ($layoutData['id_agente_modulo'] != 0) { $unit_text = trim(io_safe_output( modules_get_unit($layoutData['id_agente_modulo']))); $value = modules_get_last_value( $layoutData['id_agente_modulo']); if (!is_string($value)) { $value = format_for_graph($value, 2); } if (!empty($unit_text)) $value .= " " . $unit_text; $img_style_title .= "
" . __("Last value: ") . $value; } } if ($proportion != 1) { if (is_file($config['homedir'] . '/' . $img)) $infoImage = getimagesize($config['homedir'] . '/' . $img); if ($width != 0) { $width = (integer)($proportion * $width); } else { $width = (integer)($proportion * $infoImage[0]); } if ($height != 0) { $height = (integer)($proportion * $height); } else { $height = (integer)($proportion * $infoImage[1]); } } if (($width != 0) && ($height != 0)) echo html_print_image($img, true, array("class" => "image", "id" => "image_" . $id, "width" => "$width", "height" => "$height", "title" => $img_style_title, "style" => $borderStyle)); else echo html_print_image($img, true, array("class" => "image", "id" => "image_" . $id, "title" => $img_style_title, "style" => $borderStyle)); echo '
'; } echo io_safe_output($text); echo "
"; break; case PERCENTILE_BAR: case PERCENTILE_BUBBLE: 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; break; case MODULE_GRAPH: echo io_safe_output($text) . '
'; echo $img; 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 $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(); } break; case LABEL: echo io_safe_output($text); break; case ICON: if ($layoutData['image'] != null) { // If match with protocol://direction if (preg_match('/^(http:\/\/)((.)+)$/i', $text)) { echo '
' . '' . '
'; } if ($proportion != 1) { if (is_file($config['homedir'] . '/' . $img)) $infoImage = getimagesize($config['homedir'] . '/' . $img); if ($width != 0) { $width = (integer)($proportion * $width); } else { $width = (integer)($proportion * $infoImage[0]); } if ($height != 0) { $height = (integer)($proportion * $height); } else { $height = (integer)($proportion * $infoImage[1]); } } 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 '
'; } break; default: if (!empty($element_enterprise)) { echo $element_enterprise['item']; } break; } if ($link) { echo ""; } echo "
"; //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); 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, $kind_relationship = VISUAL_MAP_WIZARD_PARENTS_NONE, $item_in_the_map = 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; } $parent_item = 0; switch ($kind_relationship) { case VISUAL_MAP_WIZARD_PARENTS_ITEM_MAP: $parent_item = $item_in_the_map; 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, 'enable_link' => $enable_link, 'id_metaconsole' => $id_server, 'parent_item' => $parent_item); 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, $kind_relationship = VISUAL_MAP_WIZARD_PARENTS_NONE, $item_in_the_map = 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; $relationship = true; $relationships_agents = array(); //Check if the set a none relationship if (($kind_relationship == VISUAL_MAP_WIZARD_PARENTS_NONE) || ($kind_relationship == VISUAL_MAP_WIZARD_PARENTS_AGENT_RELANTIONSHIP && $item_in_the_map = 0)) { $relationship = false; } 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(); } $parent_item = 0; if ($relationship) { switch ($kind_relationship) { case VISUAL_MAP_WIZARD_PARENTS_ITEM_MAP: $parent_item = $item_in_the_map; 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' => 0, 'width' => $value_width, 'period' => $period, 'height' => $value_height, 'enable_link' => $enable_link, 'id_metaconsole' => $id_server, 'parent_item' => $parent_item); $id_item = db_process_sql_insert ('tlayout_data', $values); if ($relationship) { switch ($kind_relationship) { case VISUAL_MAP_WIZARD_PARENTS_AGENT_RELANTIONSHIP: if (!isset($relationships_agents[$id_agent])) { $relationships_agents[$id_agent]['id_layout_data_parent'] = $id_item; $relationships_agents[$id_agent]['id_layout_data_children'] = array(); } else { $relationships_agents[$id_agent]['id_layout_data_parent'] = $id_item; } $agent_id_parent = db_get_value('id_parent', 'tagente', 'id_agente', $id_agent); //Check in the group of new items is the father if (array_search($agent_id_parent, $id_agents) !== false) { if (isset($relationships_agents[$agent_id_parent])) { $relationships_agents[$agent_id_parent]['id_layout_data_children'][] = $id_item; } else { $relationships_agents[$agent_id_parent] = array(); $relationships_agents[$agent_id_parent]['id_layout_data_parent'] = null; $relationships_agents[$agent_id_parent]['id_layout_data_children'] = array(); $relationships_agents[$agent_id_parent]['id_layout_data_children'][] = $id_item; } } break; } } $pos_x = $pos_x + $range; } foreach ($relationships_agents as $relationship_item) { foreach ($relationship_item['id_layout_data_children'] as $children) { db_process_sql_update('tlayout_data', array('parent_item' => $relationship_item['id_layout_data_parent']), array('id' => $children)); } } $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, $status = false) { $img = "images/console/icons/" . $layoutData["image"]; if ($layoutData['type'] == 5) { //ICON ELEMENT $img .= ".png"; } else { if ($status === false) { $status = visual_map_get_status_element($layoutData); } switch ($status) { 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: case PERCENTILE_BAR: case PERCENTILE_BUBBLE: 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) { //-------------------------------------------------- // ADDED NO CHECK ACL FOR AVOID CHECK TAGS THAT // MAKE VERY SLOW THE VISUALMAPS WITH ACL TAGS //-------------------------------------------------- $status = agents_get_status ($layoutData["id_agent"], true); 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; case GROUP_ITEM: $group_status = groups_get_status($layoutData['id_group']); switch ($group_status) { case AGENT_STATUS_ALERT_FIRED: return VISUAL_MAP_STATUS_CRITICAL_ALERT; break; case AGENT_STATUS_CRITICAL: return VISUAL_MAP_STATUS_CRITICAL_BAD; break; case AGENT_STATUS_WARNING: return VISUAL_MAP_STATUS_WARNING; break; case AGENT_STATUS_UNKNOWN: return VISUAL_MAP_STATUS_UNKNOWN; break; case AGENT_STATUS_NORMAL: default: return VISUAL_MAP_STATUS_NORMAL; break; } 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; } function visual_map_print_user_lines($mode = "read", $layout_data, $proportion = 1) { $line = array(); $line["id"] = $layout_data['id']; $line["start_x"] = $layout_data['pos_x'] * $proportion; $line["start_y"] = $layout_data['pos_y'] * $proportion; $line["end_x"] = $layout_data['width'] * $proportion; $line["end_y"] = $layout_data['height'] * $proportion; $line["line_width"] = $layout_data['border_width'] * $proportion; $line["line_color"] = $layout_data['border_color']; echo ''; } /** * 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'); global $config; $metaconsole_hack = '/'; if (defined('METACONSOLE')) { $metaconsole_hack = '../../'; } enterprise_include_once("meta/include/functions_ui_meta.php"); require_once ($config["homedir"] . '/include/functions_custom_graphs.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; } switch ($layout_data['type']) { case LINE_ITEM: visual_map_print_user_lines("read", $layout_data, $proportion); break; default: visual_map_print_item("read", $layout_data, $proportion, $show_links); break; } } // End main div echo "
"; if (defined('METACONSOLE')) { echo "
"; } ?> 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', 'id_group', 'parent_item', 'id_layout_linked', 'id_agent', 'type')); if ($result === false) return VISUAL_MAP_STATUS_NORMAL; foreach ($result as $data) { switch ($data['type']) { case GROUP_ITEM: if ($data["id_layout_linked"] == 0) { $group_status = groups_get_status($data['id_group']); switch ($group_status) { case AGENT_STATUS_ALERT_FIRED: $status = VISUAL_MAP_STATUS_CRITICAL_ALERT; break; case AGENT_STATUS_CRITICAL: $status = VISUAL_MAP_STATUS_CRITICAL_BAD; break; case AGENT_STATUS_WARNING: $status = VISUAL_MAP_STATUS_WARNING; break; case AGENT_STATUS_UNKNOWN: $status = VISUAL_MAP_STATUS_UNKNOWN; break; case AGENT_STATUS_NORMAL: default: $status = VISUAL_MAP_STATUS_NORMAL; break; } } else { $status = visual_map_get_layout_status( $data["id_layout_linked"], $depth); } break; default: 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 { //-------------------------------------------------- // ADDED NO CHECK ACL FOR AVOID CHECK TAGS THAT // MAKE VERY SLOW THE VISUALMAPS WITH ACL TAGS //-------------------------------------------------- $status = agents_get_status($data["id_agent"], true); } break; } 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 'box_item': case BOX_ITEM: $text = __('Box'); break; 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 GROUP_ITEM: case 'group_item': $text = __('Group') . " - "; 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_sql(sprintf("SELECT * FROM tlayout_data where id_layout = %s order by label",$idVisual)); //$items = db_get_all_fields_in_table('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); } function visual_map_type_in_js($type) { switch ($type) { case STATIC_GRAPH: return 'static_graph'; break; case PERCENTILE_BAR: return 'percentile_item'; break; case MODULE_GRAPH: return 'module_graph'; break; case SIMPLE_VALUE: return 'simple_value'; break; case LABEL: return 'label'; break; case ICON: return 'icon'; break; case SIMPLE_VALUE_MAX: return 'simple_value'; break; case SIMPLE_VALUE_MIN: return 'simple_value'; break; case SIMPLE_VALUE_AVG: return 'simple_value'; break; case PERCENTILE_BUBBLE: return 'percentile_item'; break; case SERVICE: return 'service'; break; case GROUP_ITEM: return 'group_item'; break; case BOX_ITEM: return 'box_item'; break; case LINE_ITEM: return 'line_item'; break; } } ?>