summaryrefslogtreecommitdiffstats
path: root/usr
diff options
context:
space:
mode:
Diffstat (limited to 'usr')
-rwxr-xr-xusr/local/www/index.php306
1 files changed, 298 insertions, 8 deletions
diff --git a/usr/local/www/index.php b/usr/local/www/index.php
index 5eb4864..d43f27e 100755
--- a/usr/local/www/index.php
+++ b/usr/local/www/index.php
@@ -92,6 +92,63 @@ if ($fd) {
fclose($fd);
}
+function get_uptime() {
+ exec("/sbin/sysctl -n kern.boottime", $boottime);
+ preg_match("/sec = (\d+)/", $boottime[0], $matches);
+ $boottime = $matches[1];
+ $uptime = time() - $boottime;
+
+ if ($uptime > 60)
+ $uptime += 30;
+ $updays = (int)($uptime / 86400);
+ $uptime %= 86400;
+ $uphours = (int)($uptime / 3600);
+ $uptime %= 3600;
+ $upmins = (int)($uptime / 60);
+
+ $uptimestr = "";
+ if ($updays > 1)
+ $uptimestr .= "$updays days, ";
+ else if ($updays > 0)
+ $uptimestr .= "1 day, ";
+ $uptimestr .= sprintf("%02d:%02d", $uphours, $upmins);
+ return $uptimestr;
+}
+
+function get_cputicks() {
+ $cputicks = explode(" ", `/sbin/sysctl -n kern.cp_time`);
+ return $cputicks;
+}
+
+function get_cpuusage($cpuTicks, $cpuTicks2) {
+
+$diff = array();
+$diff['user'] = ($cpuTicks2[0] - $cpuTicks[0])+1;
+$diff['nice'] = ($cpuTicks2[1] - $cpuTicks[1])+1;
+$diff['sys'] = ($cpuTicks2[2] - $cpuTicks[2])+1;
+$diff['intr'] = ($cpuTicks2[3] - $cpuTicks[3])+1;
+$diff['idle'] = ($cpuTicks2[4] - $cpuTicks[4])+1;
+
+//echo "<!-- user: {$diff['user']} nice {$diff['nice']} sys {$diff['sys']} intr {$diff['intr']} idle {$diff['idle']} -->";
+
+$totalDiff = $diff['user'] + $diff['nice'] + $diff['sys'] + $diff['intr'] + $diff['idle'];
+$cpuUsage = round(100 * (1 - $diff['idle'] / $totalDiff), 0);
+
+return $cpuUsage;
+}
+
+function get_pfstate() {
+ global $config;
+ if (isset($config['system']['maximumstates']) and $config['system']['maximumstates'] > 0)
+ $maxstates="/{$config['system']['maximumstates']}";
+ else
+ $maxstates="/10000";
+ $curentries = `/sbin/pfctl -si |grep current`;
+ if (preg_match("/([0-9]+)/", $curentries, $matches)) {
+ $curentries = $matches[1];
+ }
+ return $curentries . $maxstates;
+}
$pgtitle = "pfSense webGUI";
/* include header and other code */
@@ -102,19 +159,176 @@ include("head.inc");
<body link="#0000CC" vlink="#0000CC" alink="#0000CC">
<form>
<?php
+
include("fbegin.inc");
-?>
-<p class="pgtitle">System Overview</p>
-<?
if(!file_exists("/usr/local/www/themes/{$g['theme']}/no_big_logo"))
echo "<center><img src=\"./themes/".$g['theme']."/images/logobig.jpg\"></center><br>";
?>
+<p class="pgtitle">System Overview</p>
+
+ <div id="niftyOutter" width="650">
+ <table bgcolor="#990000" width="100%" border="0" cellspacing="0" cellpadding="0">
+ <tr>
+ <td colspan="2" class="listtopic">System information</td>
+ </tr>
+ <tr>
+ <td width="25%" class="vncellt">Name</td>
+ <td width="75%" class="listr">
+ <?php echo $config['system']['hostname'] . "." . $config['system']['domain']; ?>
+ </td>
+ </tr>
+ <tr>
+ <td width="25%" valign="top" class="vncellt">Version</td>
+ <td width="75%" class="listr"> <strong>
+ <?php readfile("/etc/version"); ?>
+ </strong><br>
+ built on
+ <?php readfile("/etc/version.buildtime"); ?>
+ </td>
+ </tr>
+ <tr>
+ <td width="25%" class="vncellt">Platform</td>
+ <td width="75%" class="listr">
+ <?=htmlspecialchars($g['platform']);?>
+ </td>
+ </tr><?php if ($hwcrypto): ?>
+ <tr>
+ <td width="25%" class="vncellt">Hardware crypto</td>
+ <td width="75%" class="listr">
+ <?=htmlspecialchars($hwcrypto);?>
+ </td>
+ </tr><?php endif; ?>
+ <tr>
+ <td width="25%" class="vncellt">Uptime</td>
+ <td width="75%" class="listr">
+ <?php
+ echo "<input style='border: 0px solid white;' size='30' name='uptime' id='uptime' value='" .htmlspecialchars(get_uptime()) . "'>";
+ ?>
+ </td>
+ </tr><?php if ($config['lastchange']): ?>
+ <tr>
+ <td width="25%" class="vncellt">Last config change</td>
+ <td width="75%" class="listr">
+ <?=htmlspecialchars(date("D M j G:i:s T Y", $config['revision']['time']));?>
+ </td>
+ </tr><?php endif; ?>
+ <tr>
+ <td width="25%" class="vncellt">State table size</td>
+ <td width="75%" class="listr">
+ <?php
+ echo "<input style='border: 0px solid white;' size='30' name='pfstate' id='pfstate' value='" .htmlspecialchars(get_pfstate()) . "'>";
+ ?>
+ <br>
+ <a href="diag_dump_states.php">Show states</a>
+ </td>
+ </tr>
+ <tr>
+ <td width="25%" class="vncellt">CPU usage</td>
+ <td width="75%" class="listr">
+<?php
+if (preg_match("/MSIE/i", $_SERVER['HTTP_USER_AGENT'])) {
+ $seconds = "30";
+} else {
+ $seconds = "3";
+}
+
+$cpuUsage = get_cpuusage(get_cputicks(), get_cputicks());
+
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_left.gif' height='15' width='4' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_blue.gif' height='15' name='cpuwidtha' id='cpuwidtha' width='" . $cpuUsage . "' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_gray.gif' height='15' name='cpuwidthb' id='cpuwidthb' width='" . (100 - $cpuUsage) . "' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_right.gif' height='15' width='5' border='0' align='absmiddle'> ";
+echo "<input style='border: 0px solid white;' size='30' name='cpumeter' id='cpumeter' value='{$cpuUsage}% (Updating in $seconds seconds)'>";
+//echo $cpuUsage . "%";
+?>
+ </td>
+ </tr>
+ <tr>
+ <td width="25%" class="vncellt">Memory usage</td>
+ <td width="75%" class="listr">
+<?php
-<div id="niftyOutter" width="650">
- <iframe src="index_sub.php" height="350px" width="770px"></iframe>
-</div>
+exec("/sbin/sysctl -n vm.stats.vm.v_active_count vm.stats.vm.v_inactive_count " .
+ "vm.stats.vm.v_wire_count vm.stats.vm.v_cache_count vm.stats.vm.v_free_count", $memory);
-<?php include("fend.inc"); ?>
+$totalMem = $memory[0] + $memory[1] + $memory[2] + $memory[3] + $memory[4];
+$freeMem = $memory[4];
+$usedMem = $totalMem - $freeMem;
+$memUsage = round(($usedMem * 100) / $totalMem, 0);
+
+echo " <img src='./themes/".$g['theme']."/images/misc/bar_left.gif' height='15' width='4' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_blue.gif' height='15' name='memwidtha' id='memwidtha' width='" . $memUsage . "' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_gray.gif' height='15' name='memwidthb' id='memwidthb' width='" . (100 - $memUsage) . "' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_right.gif' height='15' width='5' border='0' align='absmiddle'> ";
+echo "<input style='border: 0px solid white;' size='30' name='memusagemeter' id='memusagemeter' value='{$memUsage}%'>";
+//echo $memUsage . "%";
+?>
+ </td>
+ </tr>
+
+<?php if($showswap == true): ?>
+ <tr>
+ <td width="25%" class="vncellt">SWAP usage</td>
+ <td width="75%" class="listr">
+
+<?php
+
+$swapUsage = `/usr/sbin/swapinfo | cut -c45-55 | grep "%"`;
+$swapUsage = ereg_replace('%', "", $swapUsage);
+$swapUsage = ereg_replace(' ', "", $swapUsage);
+$swapUsage = rtrim($swapUsage);
+
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_left.gif' height='15' width='4' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_blue.gif' height='15' width='" . $swapUsage . "' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_gray.gif' height='15' width='" . (100 - $swapUsage) . "' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_right.gif' height='15' width='5' border='0' align='absmiddle'> ";
+echo "<input style='border: 0px solid white;' size='30' name='swapusagemeter' id='swapusagemeter' value='{$swapUsage}%'>";
+//echo $swapUsage . "%";
+
+?>
+ </td>
+ </tr>
+<?php endif; ?>
+
+<?php
+ /* XXX - Stub in the HW monitor for net4801 - needs to use platform var's once we start using them */
+ $is4801 = `/sbin/dmesg -a | grep NET4801`;
+ if($is4801 <> "") {
+echo " <tr>";
+echo " <td width='25%' class='vncellt'>Temperature </td>";
+echo " <td width='75%' class='listr'>";
+// Initialize hw monitor
+exec("/usr/local/sbin/env4801 -i");
+$Temp = rtrim(`/usr/local/sbin/env4801 | grep Temp |cut -c24-25`);
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_left.gif' height='15' width='4' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_blue.gif' height='15' name='Tempwidtha' id='tempwidtha' width='" . $Temp . "' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_gray.gif' height='15' name='Tempwidthb' id='tempwidthb' width='" . (100 - $Temp) . "' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_right.gif' height='15' width='5' border='0' align='absmiddle'> ";
+echo "<input style='border: 0px solid white;' size='30' name='Tempmeter' id='Tempmeter' value='{$Temp}C'>";
+echo " </td>";
+echo " </tr>";
+ }
+?>
+ <tr>
+ <td width="25%" class="vncellt">Disk usage</td>
+ <td width="75%" class="listr">
+<?php
+exec("df -h | grep -w '/' | awk '{ print $5 }' | cut -d '%' -f 1", $dfout);
+$diskusage = trim($dfout[0]);
+
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_left.gif' height='15' width='4' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_blue.gif' height='15' width='" . $diskusage . "' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_gray.gif' height='15' width='" . (100 - $diskusage) . "' border='0' align='absmiddle'>";
+echo "<img src='./themes/".$g['theme']."/images/misc/bar_right.gif' height='15' width='5' border='0' align='absmiddle'> ";
+echo $diskusage . "%";
+?>
+ </td>
+ </tr>
+
+
+ </table>
+ </div>
+ <?php include("fend.inc"); ?>
<script type="text/javascript">
NiftyCheck();
@@ -123,4 +337,80 @@ Rounded("div#nifty","top","#FFF","#EEEEEE","smooth");
</form>
</body>
-</html> \ No newline at end of file
+</html>
+<?php
+if (preg_match("/MSIE/i", $_SERVER['HTTP_USER_AGENT'])) {
+ echo "<meta http-equiv=\"refresh\" content=\"30;url=index.php\">";
+ exit;
+}
+
+$counter = 0;
+
+While(!Connection_Aborted()) {
+
+ /* Update CPU meter */
+ sleep(1);
+ $cpuTicks = get_cputicks();
+ sleep(2);
+ $cpuTicks2 = get_cputicks();
+ $cpuUsage = get_cpuusage($cpuTicks, $cpuTicks2);
+
+ /* Update memory usage */
+ exec("/sbin/sysctl -n vm.stats.vm.v_active_count vm.stats.vm.v_inactive_count " .
+ "vm.stats.vm.v_wire_count vm.stats.vm.v_cache_count vm.stats.vm.v_free_count", $memory);
+
+ $totalMem = $memory[0] + $memory[1] + $memory[2] + $memory[3] + $memory[4];
+ $freeMem = $memory[4];
+ $usedMem = $totalMem - $freeMem;
+ $memUsage = round(($usedMem * 100) / $totalMem, 0);
+
+ echo "<script language='javascript'>\n";
+ echo "document.forms[0].uptime.value = '" . get_uptime() . "';\n";
+ echo "document.forms[0].pfstate.value = '" . get_pfstate() . "';\n";
+
+ echo "document.cpuwidtha.style.width='" . $cpuUsage . "px';\n";
+ echo "document.cpuwidthb.style.width='" . (100 - $cpuUsage) . "px';\n";
+ echo "document.forms[0].cpumeter.value = '" . $cpuUsage . "%';\n";
+
+ echo "document.memwidtha.style.width='" . $memUsage . "px';\n";
+ echo "document.memwidthb.style.width='" . (100 - $memUsage) . "px';\n";
+ echo "document.forms[0].memusagemeter.value = '" . $memUsage . "%';\n";
+
+ if (file_exists("/etc/48xx")) {
+ /* Update temp. meter */
+ $Temp = rtrim(`/usr/local/sbin/env4801 | grep Temp |cut -c24-25`);
+ echo "document.Tempwidtha.style.width='" . $Temp . "px';\n";
+ echo "document.Tempwidthb.style.width='" . (100 - $Temp) . "px';\n";
+ echo "document.forms[0].Tempmeter.value = '" . $Temp . "C';\n";
+ }
+
+/*
+ exec("df -h | grep -w '/' | awk '{ print $5 }' | cut -d '%' -f 1", $dfout);
+ $diskusage = trim($dfout[0]);
+
+ echo "document.Diskwidtha.style.width='" . $diskusage . "px';\n";
+ echo "document.Diskwidthb.style.width='" . (100 - $diskusage) . "px';\n";
+ echo "document.forms[0].Diskmeter.value = '" . $diskusage . "%';\n";
+*/
+
+ echo "</script>\n";
+
+ if(are_notices_pending() == true and $found_notices == false) {
+ /* found a notice, lets redirect so they can see the notice */
+ $counter = 500;
+ }
+
+ /*
+ * prevent user from running out of ram.
+ * firefox and ie can be a bear on ram usage!
+ */
+ $counter++;
+ if($counter > 120) {
+ echo "Redirecting to <a href=\"index.php\">Main Status</a>.<p>";
+ echo "<meta http-equiv=\"refresh\" content=\"1;url=index.php\">";
+ exit;
+ }
+
+}
+
+?>
OpenPOWER on IntegriCloud