diff --git a/src/etc/inc/stats.inc b/src/etc/inc/stats.inc index bcec99fb6..f8cee4683 100644 --- a/src/etc/inc/stats.inc +++ b/src/etc/inc/stats.inc @@ -5,331 +5,353 @@ require_once("filter.inc"); require_once("pfsense-utils.inc"); require_once("interfaces.inc"); -function get_uptime_sec() { - $boottime = ""; - $matches = ""; - $boottime = get_single_sysctl("kern.boottime"); - preg_match("/sec = (\d+)/", $boottime, $matches); - $boottime = $matches[1]; - if(intval($boottime) == 0) - return 0; - - $uptime = time() - $boottime; - return $uptime; +function get_uptime_sec() +{ + $boottime = ""; + $matches = ""; + $boottime = get_single_sysctl("kern.boottime"); + preg_match("/sec = (\d+)/", $boottime, $matches); + $boottime = $matches[1]; + if (intval($boottime) == 0) { + return 0; + } + $uptime = time() - $boottime; + return $uptime; } -function get_stats() { - $stats['cpu'] = cpu_usage(); - $stats['mem'] = mem_usage(); - $stats['uptime'] = get_uptime(); - $stats['states'] = get_pfstate(); - $stats['temp'] = get_temp(); - $stats['datetime'] = update_date_time(); - $stats['interfacestatistics'] = get_interfacestats(); - $stats['interfacestatus'] = get_interfacestatus(); - $stats['gateways'] = get_gatewaystats(); - $stats['cpufreq'] = get_cpufreq(); - $stats['load_average'] = get_load_average(); - $stats['mbuf'] = get_mbuf(); - $stats['mbufpercent'] = get_mbuf(true); - $stats['statepercent'] = get_pfstate(true); - $stats = join("|", $stats); - return $stats; +function get_stats() +{ + $stats['cpu'] = cpu_usage(); + $stats['mem'] = mem_usage(); + $stats['uptime'] = get_uptime(); + $stats['states'] = get_pfstate(); + $stats['temp'] = get_temp(); + $stats['datetime'] = update_date_time(); + $stats['interfacestatistics'] = get_interfacestats(); + $stats['interfacestatus'] = get_interfacestatus(); + $stats['gateways'] = get_gatewaystats(); + $stats['cpufreq'] = get_cpufreq(); + $stats['load_average'] = get_load_average(); + $stats['mbuf'] = get_mbuf(); + $stats['mbufpercent'] = get_mbuf(true); + $stats['statepercent'] = get_pfstate(true); + $stats = join("|", $stats); + return $stats; } -function get_gatewaystats() { - $a_gateways = return_gateways_array(); - $gateways_status = array(); - $gateways_status = return_gateways_status(true); - $data = ""; - $isfirst = true; - foreach($a_gateways as $gname => $gw) { - if(!$isfirst) - $data .= ","; - $isfirst = false; - $data .= $gw['name'] . ","; - if ($gateways_status[$gname]) { - $data .= lookup_gateway_ip_by_name($gname) . ","; - $gws = $gateways_status[$gname]; - switch(strtolower($gws['status'])) { - case "none": - $online = "Online"; - $bgcolor = "#90EE90"; // lightgreen - break; - case "down": - $online = "Offline"; - $bgcolor = "#F08080"; // lightcoral - break; - case "delay": - $online = "Latency"; - $bgcolor = "#F0E68C"; // khaki - break; - case "loss": - $online = "Packetloss"; - $bgcolor = "#F0E68C"; // khaki - break; - default: - $online = "Pending"; - break; - } - } else { - $data .= "~,"; - $gws['delay'] = "~"; - $gws['loss'] = "~"; - $online = "Unknown"; - $bgcolor = "#ADD8E6"; // lightblue - } - $data .= ($online == "Pending") ? "{$online},{$online}," : "{$gws['delay']},{$gws['loss']},"; - $data .= "
 $online 
"; - } - return $data; +function get_gatewaystats() +{ + $a_gateways = return_gateways_array(); + $gateways_status = array(); + $gateways_status = return_gateways_status(true); + $data = ""; + $isfirst = true; + foreach($a_gateways as $gname => $gw) { + if (!$isfirst) { + $data .= ","; + } + $isfirst = false; + $data .= $gw['name'] . ","; + if ($gateways_status[$gname]) { + $data .= lookup_gateway_ip_by_name($gname) . ","; + $gws = $gateways_status[$gname]; + switch(strtolower($gws['status'])) { + case "none": + $online = "Online"; + $bgcolor = "#90EE90"; // lightgreen + break; + case "down": + $online = "Offline"; + $bgcolor = "#F08080"; // lightcoral + break; + case "delay": + $online = "Latency"; + $bgcolor = "#F0E68C"; // khaki + break; + case "loss": + $online = "Packetloss"; + $bgcolor = "#F0E68C"; // khaki + break; + default: + $online = "Pending"; + break; + } + } else { + $data .= "~,"; + $gws['delay'] = "~"; + $gws['loss'] = "~"; + $online = "Unknown"; + $bgcolor = "#ADD8E6"; // lightblue + } + $data .= ($online == "Pending") ? "{$online},{$online}," : "{$gws['delay']},{$gws['loss']},"; + $data .= "
 $online 
"; + } + return $data; } -function get_uptime() { - $uptime = get_uptime_sec(); +function get_uptime() +{ + $uptime = get_uptime_sec(); - if(intval($uptime) == 0) - return; + if (intval($uptime) == 0) { + return; + } - $updays = (int)($uptime / 86400); - $uptime %= 86400; - $uphours = (int)($uptime / 3600); - $uptime %= 3600; - $upmins = (int)($uptime / 60); - $uptime %= 60; - $upsecs = (int)($uptime); + $updays = (int)($uptime / 86400); + $uptime %= 86400; + $uphours = (int)($uptime / 3600); + $uptime %= 3600; + $upmins = (int)($uptime / 60); + $uptime %= 60; + $upsecs = (int)($uptime); - $uptimestr = ""; - if ($updays > 1) - $uptimestr .= "$updays Days "; - else if ($updays > 0) - $uptimestr .= "1 Day "; + $uptimestr = ""; + if ($updays > 1) { + $uptimestr .= "$updays Days "; + } elseif ($updays > 0) { + $uptimestr .= "1 Day "; + } - if ($uphours > 1) { - $hours = "s"; - } else { - $hours = ""; - } + if ($uphours > 1) { + $hours = "s"; + } else { + $hours = ""; + } - if ($upmins > 1) { - $minutes = "s"; - } else { - $minutes = "" ; - } + if ($upmins > 1) { + $minutes = "s"; + } else { + $minutes = "" ; + } - if ($upmins > 1) { - $seconds = "s"; - } else { - $seconds = ""; - } + if ($upmins > 1) { + $seconds = "s"; + } else { + $seconds = ""; + } - $uptimestr .= sprintf("%02d Hour$hours %02d Minute$minutes %02d Second$seconds", $uphours, $upmins, $upsecs); - return $uptimestr; + $uptimestr .= sprintf("%02d Hour$hours %02d Minute$minutes %02d Second$seconds", $uphours, $upmins, $upsecs); + return $uptimestr; } /* Calculates non-idle CPU time and returns as a percentage */ -function cpu_usage() { - $duration = 1; - $diff = array('user', 'nice', 'sys', 'intr', 'idle'); - $cpuTicks = array_combine($diff, explode(" ", get_single_sysctl('kern.cp_time'))); - sleep($duration); - $cpuTicks2 = array_combine($diff, explode(" ", get_single_sysctl('kern.cp_time'))); +function cpu_usage() +{ + $duration = 1; + $diff = array('user', 'nice', 'sys', 'intr', 'idle'); + $cpuTicks = array_combine($diff, explode(" ", get_single_sysctl('kern.cp_time'))); + sleep($duration); + $cpuTicks2 = array_combine($diff, explode(" ", get_single_sysctl('kern.cp_time'))); - $totalStart = array_sum($cpuTicks); - $totalEnd = array_sum($cpuTicks2); + $totalStart = array_sum($cpuTicks); + $totalEnd = array_sum($cpuTicks2); - // Something wrapped ?!?! - if ($totalEnd <= $totalStart) - return 0; + // Something wrapped ?!?! + if ($totalEnd <= $totalStart) { + return 0; + } - // Calculate total cycles used - $totalUsed = ($totalEnd - $totalStart) - ($cpuTicks2['idle'] - $cpuTicks['idle']); + // Calculate total cycles used + $totalUsed = ($totalEnd - $totalStart) - ($cpuTicks2['idle'] - $cpuTicks['idle']); - // Calculate the percentage used - $cpuUsage = floor(100 * ($totalUsed / ($totalEnd - $totalStart))); + // Calculate the percentage used + $cpuUsage = floor(100 * ($totalUsed / ($totalEnd - $totalStart))); - return $cpuUsage; + return $cpuUsage; } -function get_pfstate($percent=false) { - global $config; - $matches = ""; - if (isset($config['system']['maximumstates']) and $config['system']['maximumstates'] > 0) - $maxstates="{$config['system']['maximumstates']}"; - else - $maxstates=default_state_size(); - $curentries = `/sbin/pfctl -si |grep current`; - if (preg_match("/([0-9]+)/", $curentries, $matches)) { - $curentries = $matches[1]; - } - if (!is_numeric($curentries)) - $curentries = 0; - if ($percent) - if (intval($maxstates) > 0) - return round(($curentries / $maxstates) * 100, 0); - else - return "NA"; - else - return $curentries . "/" . $maxstates; +function get_pfstate($percent=false) +{ + global $config; + $matches = ""; + if (isset($config['system']['maximumstates']) and $config['system']['maximumstates'] > 0) { + $maxstates="{$config['system']['maximumstates']}"; + } else { + $maxstates=default_state_size(); + } + $curentries = `/sbin/pfctl -si |grep current`; + if (preg_match("/([0-9]+)/", $curentries, $matches)) { + $curentries = $matches[1]; + } + if (!is_numeric($curentries)) { + $curentries = 0; + } + if ($percent) { + if (intval($maxstates) > 0) { + return round(($curentries / $maxstates) * 100, 0); + } else { + return "NA"; + } + } else { + return $curentries . "/" . $maxstates; + } } -function get_mbuf($percent=false) { - $mbufs_output=trim(`/usr/bin/netstat -mb | /usr/bin/grep "mbuf clusters in use" | /usr/bin/awk '{ print $1 }'`); - list( $mbufs_current, $mbufs_cache, $mbufs_total, $mbufs_max ) = explode( "/", $mbufs_output); - if ($percent) - if ($mbufs_max > 0) - return round(($mbufs_total / $mbufs_max) * 100, 0); - else - return "NA"; - else - return "{$mbufs_total}/{$mbufs_max}"; +function get_mbuf($percent=false) +{ + $mbufs_output=trim(`/usr/bin/netstat -mb | /usr/bin/grep "mbuf clusters in use" | /usr/bin/awk '{ print $1 }'`); + list( $mbufs_current, $mbufs_cache, $mbufs_total, $mbufs_max ) = explode( "/", $mbufs_output); + if ($percent) { + if ($mbufs_max > 0) { + return round(($mbufs_total / $mbufs_max) * 100, 0); + } else { + return "NA"; + } + } else { + return "{$mbufs_total}/{$mbufs_max}"; + } } -function get_temp() { - $temp_out = get_single_sysctl("dev.cpu.0.temperature"); - if ($temp_out == "") - $temp_out = get_single_sysctl("hw.acpi.thermal.tz0.temperature"); - - // Remove 'C' from the end - return rtrim($temp_out, 'C'); +function get_temp() +{ + $temp_out = get_single_sysctl("dev.cpu.0.temperature"); + if ($temp_out == "") { + $temp_out = get_single_sysctl("hw.acpi.thermal.tz0.temperature"); + } + // Remove 'C' from the end + return rtrim($temp_out, 'C'); } /* Get mounted filesystems and usage. Do not display entries for virtual filesystems (e.g. devfs, nullfs, unionfs) */ -function get_mounted_filesystems() { - $mout = ""; - $filesystems = array(); - exec("/bin/df -Tht ufs,tmpfs,zfs,cd9660 | /usr/bin/awk '{print $1, $2, $3, $4, $6, $7;}'", $mout); +function get_mounted_filesystems() +{ + $mout = ""; + $filesystems = array(); + exec("/bin/df -Tht ufs,tmpfs,zfs,cd9660 | /usr/bin/awk '{print $1, $2, $3, $4, $6, $7;}'", $mout); - /* Get rid of the header */ - array_shift($mout); - foreach ($mout as $fs) { - $f = array(); - list($f['device'], $f['type'], $f['total_size'], $f['used_size'], $f['percent_used'], $f['mountpoint']) = explode(' ', $fs); - - /* We dont' want the trailing % sign. */ - $f['percent_used'] = trim($f['percent_used'], '%'); - - $filesystems[] = $f; - } - return $filesystems; + /* Get rid of the header */ + array_shift($mout); + foreach ($mout as $fs) { + $f = array(); + list($f['device'], $f['type'], $f['total_size'], $f['used_size'], $f['percent_used'], $f['mountpoint']) = explode(' ', $fs); + /* We dont' want the trailing % sign. */ + $f['percent_used'] = trim($f['percent_used'], '%'); + $filesystems[] = $f; + } + return $filesystems; } -function swap_usage() { - exec("/usr/sbin/swapinfo", $swap_info); - $swap_used = ""; - foreach ($swap_info as $line) - if (preg_match('/(\d+)%$/', $line, $matches)) { - $swap_used = $matches[1]; - break; - } - - return $swap_used; +function swap_usage() +{ + exec("/usr/sbin/swapinfo", $swap_info); + $swap_used = ""; + foreach ($swap_info as $line) { + if (preg_match('/(\d+)%$/', $line, $matches)) { + $swap_used = $matches[1]; + break; + } + } + return $swap_used; } -function mem_usage() { - $totalMem = get_single_sysctl("vm.stats.vm.v_page_count"); - if ($totalMem > 0) { - $inactiveMem = get_single_sysctl("vm.stats.vm.v_inactive_count"); - $cachedMem = get_single_sysctl("vm.stats.vm.v_cache_count"); - $freeMem = get_single_sysctl("vm.stats.vm.v_free_count"); - $usedMem = $totalMem - ($inactiveMem + $cachedMem + $freeMem); - $memUsage = round(($usedMem * 100) / $totalMem, 0); - } else - $memUsage = "NA"; - - return $memUsage; +function mem_usage() +{ + $totalMem = get_single_sysctl("vm.stats.vm.v_page_count"); + if ($totalMem > 0) { + $inactiveMem = get_single_sysctl("vm.stats.vm.v_inactive_count"); + $cachedMem = get_single_sysctl("vm.stats.vm.v_cache_count"); + $freeMem = get_single_sysctl("vm.stats.vm.v_free_count"); + $usedMem = $totalMem - ($inactiveMem + $cachedMem + $freeMem); + $memUsage = round(($usedMem * 100) / $totalMem, 0); + } else { + $memUsage = "NA"; + } + return $memUsage; } -function update_date_time() { - $datetime = date("D M j G:i:s T Y"); - return $datetime; +function update_date_time() +{ + $datetime = date("D M j G:i:s T Y"); + return $datetime; } -function get_cpufreq() { - $cpufreqs = ""; - $out = ""; - $cpufreqs = explode(" ", get_single_sysctl('dev.cpu.0.freq_levels')); - $maxfreq = explode("/", $cpufreqs[0]); - $maxfreq = $maxfreq[0]; - $curfreq = ""; - $curfreq = get_single_sysctl('dev.cpu.0.freq'); - if (($curfreq > 0) && ($curfreq != $maxfreq)) - $out = "Current: {$curfreq} MHz, Max: {$maxfreq} MHz"; - return $out; +function get_cpufreq() +{ + $cpufreqs = ""; + $out = ""; + $cpufreqs = explode(" ", get_single_sysctl('dev.cpu.0.freq_levels')); + $maxfreq = explode("/", $cpufreqs[0]); + $maxfreq = $maxfreq[0]; + $curfreq = ""; + $curfreq = get_single_sysctl('dev.cpu.0.freq'); + if (($curfreq > 0) && ($curfreq != $maxfreq)) { + $out = "Current: {$curfreq} MHz, Max: {$maxfreq} MHz"; + } + return $out; } -function get_cpu_count($show_detail = false) { - $cpucount = get_single_sysctl('kern.smp.cpus'); - - if ($show_detail) { - $cpudetail = ""; - exec("/usr/bin/grep 'SMP.*package.*core' /var/run/dmesg.boot | /usr/bin/cut -f2- -d' '", $cpudetail); - $cpucount = $cpudetail[0]; - } - return $cpucount; +function get_cpu_count($show_detail = false) +{ + $cpucount = get_single_sysctl('kern.smp.cpus'); + if ($show_detail) { + $cpudetail = ""; + exec("/usr/bin/grep 'SMP.*package.*core' /var/run/dmesg.boot | /usr/bin/cut -f2- -d' '", $cpudetail); + $cpucount = $cpudetail[0]; + } + return $cpucount; } -function get_load_average() { - $load_average = ""; - exec("/usr/bin/uptime | /usr/bin/sed 's/^.*: //'", $load_average); - return $load_average[0]; +function get_load_average() +{ + $load_average = ""; + exec("/usr/bin/uptime | /usr/bin/sed 's/^.*: //'", $load_average); + return $load_average[0]; } function get_interfacestats() { - $ifdescrs = get_configured_interface_list(); - $array_collisions = array(); - $new_data = ''; + $ifdescrs = get_configured_interface_list(); + $array_collisions = array(); + $new_data = ''; - foreach ($ifdescrs as $ifdescr => $ifname) { - $ifinfo = get_interface_info($ifdescr); - $new_data .= "{$ifinfo['inpkts']},"; - $new_data .= "{$ifinfo['outpkts']},"; - $new_data .= format_bytes($ifinfo['inbytes']) . ","; - $new_data .= format_bytes($ifinfo['outbytes']) . ","; - if (isset($ifinfo['inerrs'])){ - $new_data .= "{$ifinfo['inerrs']},"; - $new_data .= "{$ifinfo['outerrs']},"; - } else { - $new_data .= "0,"; - $new_data .= "0,"; - } - if (isset($ifinfo['collisions'])) { - $new_data .= htmlspecialchars($ifinfo['collisions']) . ","; - } else { - $new_data .= "0,"; - } - } - - return $new_data; + foreach ($ifdescrs as $ifdescr => $ifname) { + $ifinfo = get_interface_info($ifdescr); + $new_data .= "{$ifinfo['inpkts']},"; + $new_data .= "{$ifinfo['outpkts']},"; + $new_data .= format_bytes($ifinfo['inbytes']) . ","; + $new_data .= format_bytes($ifinfo['outbytes']) . ","; + if (isset($ifinfo['inerrs'])){ + $new_data .= "{$ifinfo['inerrs']},"; + $new_data .= "{$ifinfo['outerrs']},"; + } else { + $new_data .= "0,"; + $new_data .= "0,"; + } + if (isset($ifinfo['collisions'])) { + $new_data .= htmlspecialchars($ifinfo['collisions']) . ","; + } else { + $new_data .= "0,"; + } + } + return $new_data; } function get_interfacestatus() { - $ifdescrs = get_configured_interface_with_descr(); - $data = ''; + $ifdescrs = get_configured_interface_with_descr(); + $data = ''; - foreach ($ifdescrs as $ifdescr => $ifname) { - $ifinfo = get_interface_info($ifdescr); - $data .= $ifname . ","; - if ($ifinfo['status'] == "up" || $ifinfo['status'] == "associated") { - $data .= "up"; - } elseif ($ifinfo['status'] == "no carrier") { - $data .= "down"; - } elseif ($ifinfo['status'] == "down") { - $data .= "block"; - } - $data .= ","; - if ($ifinfo['ipaddr']) { - $data .= htmlspecialchars($ifinfo['ipaddr']); - } - $data .= ","; - if ($ifinfo['status'] != "down") { - $data .= htmlspecialchars($ifinfo['media']); - } - $data .= "~"; - } - return $data; + foreach ($ifdescrs as $ifdescr => $ifname) { + $ifinfo = get_interface_info($ifdescr); + $data .= $ifname . ","; + if ($ifinfo['status'] == "up" || $ifinfo['status'] == "associated") { + $data .= "up"; + } elseif ($ifinfo['status'] == "no carrier") { + $data .= "down"; + } elseif ($ifinfo['status'] == "down") { + $data .= "block"; + } + $data .= ","; + if ($ifinfo['ipaddr']) { + $data .= htmlspecialchars($ifinfo['ipaddr']); + } + $data .= ","; + if ($ifinfo['status'] != "down") { + $data .= htmlspecialchars($ifinfo['media']); + } + $data .= "~"; + } + return $data; }