--- misc/xenconsole/ajaxdata.php 2013/03/26 13:43:07 1958 +++ misc/xenconsole/ajaxdata.php 2013/07/23 19:00:14 2029 @@ -23,11 +23,44 @@ } } +function get_network_string($networks) { + global $hideipv6; + + $ret = ""; + foreach($networks as $net) { + if ($hideipv6 == true) { + if ( strpos($net, ":") !== false) + continue; + } + + if ($ret != "") + $ret .= ","; + + $ret .= $net; + } + return $ret; +} + include('xenapi.php'); /* Establish session with Xenserver */ $xenserver = new XenApi($url, $login, $password); +//Opbyg cache arrays +$consolemap = array(); +$consoles = $xenserver->console__get_all_records(); +foreach($consoles as $key => $val) { + $consolemap[$key] = $val; +} + +$guestmetricmap = array(); +$guestmetrics = $xenserver->VM_guest_metrics__get_all_records(); +foreach($guestmetrics as $key => $val) { + $guestmetricmap[$key] = $val; +} + +//find data + $hosts_array = $xenserver->host__get_all(); $host = $xenserver->host__get_record($hosts_array[0]); $host_metrics = $xenserver->host_metrics__get_record($host["metrics"]); @@ -75,10 +108,11 @@ $maxmem = 0; $guestversion = ""; - if ( $vm["power_state"] == "Running" ) { + if ( $vm["power_state"] == "Running" ) { if ($vm["guest_metrics"] != "OpaqueRef:NULL") {//guest tools installed - $guest_metrics = $xenserver->VM_guest_metrics__get_record( $vm["guest_metrics"] ); - $network = implode( ",", $guest_metrics["networks"]) ; + //$guest_metrics = $xenserver->VM_guest_metrics__get_record( $vm["guest_metrics"] ); + $guest_metrics = $guestmetricmap[ $vm["guest_metrics"] ]; + $network = get_network_string($guest_metrics["networks"]) ; $tmpos = explode('|', $guest_metrics["os_version"]["name"]); $os = $tmpos[0]; $guestversion = $guest_metrics["PV_drivers_version"]["major"] . "." . $guest_metrics["PV_drivers_version"]["minor"] . "." . $guest_metrics["PV_drivers_version"]["micro"]; @@ -86,7 +120,10 @@ $maxmem = round($xenserver->VM__query_data_source($vmref, "memory") / (1024*1024) ); $free = round( $xenserver->VM__query_data_source($vmref, "memory_internal_free") / 1024 ); $curmem = $maxmem - $free; + } else { + $maxmem = $vm["memory_static_max"] / (1024*1024); } + $cpusum = 0.0; for ($i=0; $i<$cpus; $i++) { $cpusum += $xenserver->VM__query_data_source($vmref, "cpu" . $i); @@ -94,7 +131,8 @@ $cpuavg = round ( ($cpusum/$cpus) * 100); foreach($vm["consoles"] as $conref) { - $con = $xenserver->console__get_record( $conref ); + //$con = $xenserver->console__get_record( $conref ); + $con = $consolemap[$conref]; if ($con["protocol"] == "rfb") { $url = urlencode( $con["location"] ); @@ -102,7 +140,7 @@ } } - } else { + } else { $maxmem = $vm["memory_static_max"] / (1024*1024); }