'; $layout_datas = get_db_all_rows_field_filter ('tlayout_data', 'id_layout', $id_layout); $lines = array (); if ($layout_datas !== false) { foreach ($layout_datas as $layout_data) { // Linked to other layout ?? - Only if not module defined if ($layout_data['id_layout_linked'] != 0) { $status = get_layout_status ($layout_data['id_layout_linked']); $status_parent = 3; } else { // Status for a simple module if ($layout_data['id_agente_modulo'] != 0) { $id_agent = get_db_value ("id_agente", "tagente_estado", "id_agente_modulo", $layout_data['id_agente_modulo']); $id_agent_module_parent = get_db_value ("id_agente_modulo", "tlayout_data", "id", $layout_data["parent_item"]); // Item value $status = get_agentmodule_status ($layout_data['id_agente_modulo']); if ($layout_data['no_link_color'] == 1) $status_parent = 3; else $status_parent = get_agentmodule_status ($id_agent_module_parent); // Status for a whole agent } elseif ($layout_data['id_agent'] != 0) { $id_agent = $layout_data['id_agent']; $agent_interval = get_agent_interval ($id_agent); $sql = sprintf ('SELECT MAX(estado) FROM tagente_estado, tagente_modulo WHERE tagente_estado.id_agente_modulo = tagente_modulo.id_agente_modulo AND tagente_modulo.disabled = 0 AND tagente_modulo.id_agente = %d AND ((module_interval > 0 AND utimestamp >= UNIX_TIMESTAMP() - module_interval * 2) OR (module_interval = 0 AND utimestamp >= UNIX_TIMESTAMP() - %d))', $id_agent, $agent_interval * 2); $status = get_db_sql ($sql); $status_parent = $status; } else { $status = 3; $status_parent = 3; $id_agent = 0; } } // STATIC IMAGE (type = 0) if ($layout_data['type'] == 0) { // Link image //index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=1 if ($status == 0) // Bad monitor $z_index = 3; elseif ($status == 2) // Warning $z_index = 2; elseif ($status == 4) // Alert $z_index = 4; else $z_index = 1; // Print BAD over good // Draw image echo '
'; if (!isset($id_agent)) $id_agent = 0; if ($show_links) { // Link to an agent if (($id_agent > 0) && ($layout_data['id_layout_linked'] == "" || $layout_data['id_layout_linked'] == 0)) { echo ''; // Link to a map } elseif ($layout_data['id_layout_linked']>0){ echo ''; // A void object } else { echo ''; } } $img_style = array (); $img_style["title"] = $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 1: case 4: //Critical (BAD or ALERT) $img .= "_bad.png"; break; case 0: //Normal (OK) $img .= "_ok.png"; break; case 2: //Warning $img .= "_warning.png"; break; default: $img .= ".png"; // Default is Grey (Other) } print_image ($img, false, $img_style); echo ""; // Print label if valid label_color (only testing for starting with #) otherwise print nothing if ($layout_data['label_color'][0] == '#') { echo "
"; echo $layout_data['label']; } echo "
"; } // SIMPLE DATA VALIE (type = 2) if ($layout_data['type'] == 2){ echo '
'; echo ''.$layout_data['label']. ' '; echo get_db_sql ('SELECT datos FROM tagente_estado WHERE id_agente_modulo = '.$layout_data['id_agente_modulo']); echo '
'; } // Percentile bar (type = 3) if ($layout_data['type'] == 3){ echo '
'; $valor = get_db_sql ('SELECT datos FROM tagente_estado WHERE id_agente_modulo = '.$layout_data['id_agente_modulo']); $width = $layout_data['width']; if ( $layout_data['height'] > 0) $percentile = $valor / $layout_data['height'] * 100; else $percentile = 100; echo $layout_data['label']; echo "
"; echo ""; echo '
'; } // SINGLE GRAPH (type = 1) if ($layout_data['type'] == 1) { // single graph // Draw image echo '
'; if ($show_links) { if (($layout_data['id_layout_linked'] == "") || ($layout_data['id_layout_linked'] == 0)) { echo ''; } else { echo ''; } } print_image ("reporting/fgraph.php?tipo=sparse&id=".$layout_data['id_agente_modulo']."&label=".safe_input ($layout_data['label'])."&height=".$layout_data['height']."&width=".$layout_data['width']."&period=".$layout_data['period'], false, array ("title" => $layout_data['label'], "border" => 0)); echo ""; echo "
"; // Line, not implemented in editor } elseif ($layout_data['type'] == 2) { $line['id'] = $layout_data['id']; $line['x'] = $layout_data['pos_x']; $line['y'] = $layout_data['pos_y']; $line['width'] = $layout_data['width']; $line['height'] = $layout_data['height']; $line['color'] = $layout_data['label_color']; array_push ($lines, $line); } // Get parent relationship - Create line data if ($layout_data["parent_item"] != "" && $layout_data["parent_item"] != 0) { $line['id'] = $layout_data['id']; $line['node_begin'] = 'layout-data-'.$layout_data["parent_item"]; $line['node_end'] = 'layout-data-'.$layout_data["id"]; $line['color'] = $status_parent ? '#00dd00' : '#dd0000'; array_push ($lines, $line); } } } 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 ""; } /** * @return array Layout data types */ function get_layout_data_types () { $types = array (); $types[0] = __('Static graph'); $types[1] = __('Module graph'); $types[2] = __('Simple value'); $types[3] = __('Percentile bar'); return $types; } /** * 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 * print_select() directly) * @param array Additional filters to filter the layouts. * * @return array A list of layouts the user can see. */ function get_user_layouts ($id_user = 0, $only_names = false, $filter = false) { if (! is_array ($filter)) $filter = array (); $where = format_array_to_where_clause_sql ($filter); if ($where != '') { $where .= ' AND '; } $groups = get_user_groups ($id_user); $where .= sprintf ('id_group IN (%s)', implode (",", array_keys ($groups))); $layouts = get_db_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 * * @return bool The status of the given layout. True if it's OK, false if not. */ function get_layout_status ($id_layout = 0) { $temp_status = 0; $temp_total = 0; $sql = sprintf ('SELECT id_agente_modulo, parent_item, id_layout_linked, id_agent FROM `tlayout_data` WHERE `id_layout` = %d', $id_layout); $result = get_db_all_rows_filter ('tlayout_data', array ('id' => $id_layout), array ('id_agente_modulo', 'parent_item', 'id_layout_linked', 'id_agent')); if ($result === false) return 0; foreach ($result as $rownum => $data) { // Other Layout (Recursive!) if (($data["id_layout_linked"] != 0) && ($data["id_agente_modulo"] == 0)) { $temp_status = get_layout_status ($data["id_layout_linked"]); if ($temp_status > $temp_total) { $temp_total = $temp_status; } // Module } elseif ($data["id_agente_modulo"] != 0) { $temp_status = get_agentmodule_status ($data["id_agente_modulo"]); if ($temp_status > $temp_total) $temp_total = $temp_status; // Agent } else { $temp_status = get_agentmodule_status ($data["id_agent"]); if ($temp_status > $temp_total) $temp_total = $temp_status; } } return $temp_total; } ?>