0"); $data["avg_interval_remote_modules"] = get_db_sql ("SELECT AVG(module_interval) FROM tagente_modulo, tagente_estado where tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo AND disabled = 0 AND id_modulo != 1 AND module_interval > 0 AND utimestamp > 0"); if ($data["total_remote_modules"] == 0) $data["remote_modules_rate"] = 0; else $data["remote_modules_rate"] = $data["total_remote_modules"] / $data["avg_interval_remote_modules"]; // For local modules (ignoring local modules with custom invervals for simplicity). $data["total_local_modules"] = get_db_sql ("SELECT COUNT(tagente_modulo.id_agente_modulo) FROM tagente_modulo, tagente_estado WHERE tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo AND id_modulo = 1 AND disabled = 0 AND utimestamp > 0"); $data["avg_interval_local_modules"] = get_db_sql ("SELECT AVG(tagente.intervalo) FROM tagente WHERE disabled = 0 AND intervalo > 0"); $data["local_modules_rate"] = $data["total_local_modules"] / $data["avg_interval_local_modules"]; $data["total_modules"] = $data["total_local_modules"] + $data["total_remote_modules"]; return ($data); } /** * This function will get all the server information in an array or a specific server * * @param mixed An optional integer or array of integers to select specific servers * * @return mixed False in case the server doesn't exist or an array with info. */ function get_server_info ($id_server = -1) { if (is_array ($id_server)) { $select_id = " WHERE id_server IN (".implode (",", $id_server).")"; } elseif ($id_server > 0) { $select_id = " WHERE id_server IN (".(int) $id_server.")"; } else { $select_id = ""; } $modules_info = array (); $modules_total = array (); $result = get_db_all_rows_sql ("SELECT DISTINCT(tagente_estado.running_by), COUNT(tagente_estado.id_agente_modulo) AS modules, id_modulo FROM tagente_estado, tagente_modulo WHERE tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo AND tagente_modulo.disabled = 0 AND utimestamp > 0 GROUP BY running_by"); if (empty ($result)) { $result = array (); } foreach ($result as $row) { $modules_info[$row["running_by"]] = $row["modules"]; if (!isset ($modules_total[$row["id_modulo"]])) { $modules_total[$row["id_modulo"]] = $row["modules"]; } else { $modules_total[$row["id_modulo"]] += $row["modules"]; } } $recon_total = get_db_sql ("SELECT COUNT(*) FROM trecon_task"); $sql = "SELECT * FROM tserver".$select_id . " ORDER BY server_type"; $result = get_db_all_rows_sql ($sql); $time = get_system_time (); if (empty ($result)) { return false; } $return = array (); foreach ($result as $server) { switch ($server['server_type']) { case 0: $server["img"] = print_image ("images/data.png", true, array ("title" => __('Data server'))); $server["type"] = "data"; $id_modulo = 1; break; case 1: $server["img"] = print_image ("images/network.png", true, array ("title" => __('Network server'))); $server["type"] = "network"; $id_modulo = 2; break; case 2: $server["img"] = print_image ("images/snmp.png", true, array ("title" => __('SNMP server'))); $server["type"] = "snmp"; $id_modulo = 0; break; case 3: $server["img"] = print_image ("images/recon.png", true, array ("title" => __('Recon server'))); $server["type"] = "recon"; $id_modulo = 0; break; case 4: $server["img"] = print_image ("images/plugin.png", true, array ("title" => __('Plugin server'))); $server["type"] = "plugin"; $id_modulo = 4; break; case 5: $server["img"] = print_image ("images/chart_bar.png", true, array ("title" => __('Prediction server'))); $server["type"] = "prediction"; $id_modulo = 5; break; case 6: $server["img"] = print_image ("images/wmi.png", true, array ("title" => __('WMI server'))); $server["type"] = "wmi"; $id_modulo = 6; break; case 7: $server["img"] = print_image ("images/server_export.png", true, array ("title" => __('Export server'))); $server["type"] = "export"; $id_modulo = 0; break; case 8: $server["img"] = print_image ("images/page_white_text.png", true, array ("title" => __('Inventory server'))); $server["type"] = "inventory"; $id_modulo = 0; break; case 9: $server["img"] = print_image ("images/world.png", true, array ("title" => __('Web server'))); $server["type"] = "web"; $id_modulo = 0; break; default: $server["img"] = ''; $server["type"] = "unknown"; $id_modulo = 0; break; } if (empty ($modules_info[$server["id_server"]])) { $server["modules"] = 0; } else { $server["modules"] = $modules_info[$server["id_server"]]; } $server["module_lag"] = 0; $server["lag"] = 0; $server["load"] = 0; if (!isset ($modules_total[$id_modulo])) { $server["modules_total"] = 0; } else { $server["modules_total"] = $modules_total[$id_modulo]; } if ($id_modulo > 0 && $server["modules"] > 0) { //If the server doesn't have modules, it doesn't have lag so nothing to calculate. // If it's not a module server, don't go here either // Remote servers LAG Calculation: if ($id_modulo != 1){ $result = get_db_row_sql ("SELECT COUNT(tagente_modulo.id_agente_modulo) AS module_lag, AVG(UNIX_TIMESTAMP() - utimestamp - current_interval) AS lag FROM tagente_estado, tagente_modulo WHERE utimestamp > 0 AND tagente_modulo.disabled = 0 AND tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo AND current_interval > 0 AND running_by = ".$server["id_server"]." AND (UNIX_TIMESTAMP() - utimestamp) < ( current_interval * 10) AND (UNIX_TIMESTAMP() - utimestamp) > current_interval"); } else { // Local/Dataserver server LAG calculation: $result = get_db_row_sql ("SELECT COUNT(tagente_modulo.id_agente_modulo) AS module_lag, AVG(UNIX_TIMESTAMP() - utimestamp - current_interval) AS lag FROM tagente_estado, tagente_modulo WHERE utimestamp > 0 AND tagente_modulo.disabled = 0 AND tagente_modulo.id_tipo_modulo < 5 AND tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo AND current_interval > 0 AND (UNIX_TIMESTAMP() - utimestamp) < ( current_interval * 10) AND running_by = ".$server["id_server"]." AND (UNIX_TIMESTAMP() - utimestamp) > (current_interval * 1.1)"); } // Lag over current_interval * 2 is not lag, it's a timed out module // And we can't check current_interval = 0 (data modules) because they come as they want if (!empty ($result["lag"])) { $server["lag"] = $result["lag"]; } if (!empty ($result["module_lag"])) { $server["module_lag"] = $result["module_lag"]; } } else { switch ($server["type"]) { case "recon": $server["name"] = ''.$server["name"].''; //Get recon taks info $tasks = get_db_all_rows_sql ("SELECT status, utimestamp FROM trecon_task WHERE id_recon_server = ".$server["id_server"]); if (empty ($tasks)) { $tasks = array (); } //Total jobs running on this recon server $server["modules"] = count ($tasks); //Total recon jobs (all servers) $server["modules_total"] = $recon_total; //Lag (take average active time of all active tasks) $server["module_lag"] = 0; $lags = array (); foreach ($tasks as $task) { if ($task["status"] > 0 && $task["status"] <= 100) { $lags[] = $time - $task["utimestamp"]; //Module lag is actually the number of jobs that is currently running $server["module_lag"]++; } } if (count ($lags) > 0) { $server["lag"] = (int) array_sum ($lags) / count ($lags); } break; default: break; } } $server["lag_txt"] = ($server["lag"] == 0 ? '-' : human_time_description_raw ($server["lag"])) . " / ". $server["module_lag"]; if ($server["modules_total"] > 0) { $server["load"] = round ($server["modules"] / $server["modules_total"] * 100); } //Push the raw data on the return stack $return[$server["id_server"]] = $server; } return $return; } ?>