2016-12-17 18:01:18 +00:00

345 lines
12 KiB
PHP

<?php
error_reporting(0);
// Config
$server = array(
'base' => '',
'cups' => '',
'scan' => ''
);
$values = array();
// Getting System Values.
$uname = split(" ", exec("uname -a"), 4);
$values['system'] = array();
$values['system']['current_time'] = exec("date +'%d %b %Y %T %Z'");
$values['system']['frequency'] = exec("cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq") / 1000;
$values['system']['processor'] = str_replace("-compatible processor", "", explode(": ", exec("cat /proc/cpuinfo | grep Processor"))[1]);
$values['system']['cpu_temperature'] = round(exec("cat /sys/class/thermal/thermal_zone0/temp ") / 1000, 1);
$values['system']['system'] = $uname[0];
$values['system']['kernel'] = $uname[2];
$values['system']['host'] = exec('hostname -f');
// Load averages
$loadavg = explode(" ", exec("cat /proc/loadavg"));
$values['system']['load'] = $loadavg[2];
//Uptime
$uptime_array = explode(" ", exec("cat /proc/uptime"));
$seconds = round($uptime_array[0], 0);
$minutes = $seconds / 60;
$hours = $minutes / 60;
$days = floor($hours / 24);
$hours = sprintf('%02d', floor($hours - ($days * 24)));
$minutes = sprintf('%02d', floor($minutes - ($days * 24 * 60) - ($hours * 60)));
if ($days == 0) {
$values['system']['uptime'] = $hours . ":" . $minutes . " (hh:mm)";
} elseif($days == 1) {
$values['system']['uptime'] = $days . " day, " . $hours . ":" . $minutes . " (hh:mm)";
} else {
$values['system']['uptime'] = $days . " days, " . $hours . ":" . $minutes . " (hh:mm)";
}
//Memory Utilisation
$values['memory'] = array();
$meminfo = file("/proc/meminfo");
for ($i = 0; $i < count($meminfo); $i++) {
list($item, $data) = split(":", $meminfo[$i], 2);
$item = trim(chop($item));
$data = intval(preg_replace("/[^0-9]/", "", trim(chop($data)))); //Remove non numeric characters
switch($item) {
case "MemTotal": $values['memory']['total'] = $data; break;
case "MemFree": $values['memory']['free'] = $data; break;
case "SwapTotal": $values['memory']['total_swap'] = $data; break;
case "SwapFree": $values['memory']['free_swap'] = $data; break;
case "Buffers": $values['memory']['buffer'] = $data; break;
case "Cached": $values['memory']['cache'] = $data; break;
default: break;
}
}
//Disk space check, with sizes reported in kB.
$values['hdd'] = array();
exec("df -T -l -BKB -x tmpfs -x devtmpfs -x rootfs", $diskfree);
for ($count = 1; $count < sizeof($diskfree); $count ++) {
$diskinfo = split(" +", $diskfree[$count]);
$values['hdd'][] = array(
'drive' => $diskinfo[0],
'type' => $diskinfo[1],
'size' => $diskinfo[2],
'used' => $diskinfo[3],
'avail' => $diskinfo[4],
'percent' => $diskinfo[5],
'mount' => $diskinfo[6]
);
}
//Read in RGB file
$file = file_get_contents('/home/pi/hugh/rgb', FILE_USE_INCLUDE_PATH);
if ($file == "0, 0, 0") {
$rgb = "Off";
} elseif ($file == "255, 0, 0") {
$rgb = "Red";
} elseif ($file == "0, 255, 0") {
$rgb = "Green";
} elseif ($file == "0, 0, 255") {
$rgb = "Blue";
} elseif ($file == "255, 255, 0") {
$rgb = "Yellow";
} elseif ($file == "255, 102, 255") {
$rgb = "Pink";
} elseif ($file == "75, 0, 130") {
$rgb = "Purple";
}
// Rendering Page.
?><!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>DeskPi Information</title>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="description" content="Raspberry Pi Print Server Information">
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0">
<title>Raspberry Pi Server Info</title>
<link rel="stylesheet" href="//fonts.googleapis.com/css?family=Roboto:regular,bold,italic,thin,light,bolditalic,black,medium&amp;lang=en">
<link rel="stylesheet" href="//fonts.googleapis.com/icon?family=Material+Icons">
<link rel="stylesheet" href="/css/css.css">
<link rel="stylesheet" href="/styles.css">
<style>
#view-source {
position: fixed;
display: block;
right: 0;
bottom: 0;
margin-right: 40px;
margin-bottom: 40px;
z-index: 900;
}
</style>
<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
</head>
<body>
<div class="mdl-layout mdl-js-layout mdl-layout--fixed-drawer mdl-layout--fixed-header">
<header class="mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600">
<div class="mdl-layout__header-row">
<span class="mdl-layout-title">DeskPi</span>
<div class="mdl-layout-spacer"></div>
<button class="mdl-button mdl-js-button mdl-js-ripple-effect mdl-button--icon" id="hdrbtn">
<i class="material-icons">more_vert</i>
</button>
<ul class="mdl-menu mdl-js-menu mdl-js-ripple-effect mdl-menu--bottom-right" for="hdrbtn">
<li class="mdl-menu__item">
<a href="http://kithub.ml:1337/Karl/Alexa-DeskControl">About</a>
</li>
<li class="mdl-menu__item">
<a href="#">Contact</a>
</li>
</ul>
</div>
</header>
<div class="mdl-grid">
<div class="mdl-color--white mdl-shadow--2dp mdl-cell mdl-cell--12-col mdl-grid" id="gauges">
</div>
<div class="mdl-color--white mdl-shadow--2dp mdl-cell mdl-cell--6-col mdl-grid">
<h3>System Properties</h3>
<table class="mdl-data-table mdl-js-data-table" style="width:100%;">
<tbody>
<tr>
<td class="mdl-data-table__cell--non-numeric">Hostname</td>
<td id="host"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric">System Time</td>
<td id="current_time"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric">Base</td>
<td id="system"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric">Kernel</td>
<td id="kernel"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric">CPU</td>
<td id="processor"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric">CPU Frequency</td>
<td id="frequency"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric">CPU Temprature</td>
<td id="cpu_temperature"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric">Uptime</td>
<td id="uptime"></td>
</tr>
</tbody>
</table>
</div>
<div class="mdl-color--white mdl-shadow--2dp mdl-cell mdl-cell--6-col mdl-grid">
<h3>Desk Colour - <?php echo $rgb;?></h3>
<table class="mdl-data-table mdl-js-data-table" style="width:100%;">
<tbody>
<tr>
<td class="mdl-data-table__cell--non-numeric" onclick="location.href='/off.php'">Off</td>
<td id="host"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric" onclick="location.href='/red.php'">Red</td>
<td id="current_time"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric" onclick="location.href='/blue.php'">Blue</td>
<td id="system"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric" onclick="location.href='/green.php'">Green</td>
<td id="kernel"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric" onclick="location.href='/yellow.php'">Yellow</td>
<td id="processor"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric" onclick="location.href='/pink.php'">Pink</td>
<td id="frequency"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric" onclick="location.href='/purple.php'">Purple</td>
<td id="cpu_temperature"></td>
</tr>
<tr>
<td class="mdl-data-table__cell--non-numeric"></td>
<td id="uptime"></td>
</tr>
</tbody>
</table>
</div>
</div>
</main>
</div>
<script src="https://code.getmdl.io/1.1.3/material.min.js"></script>
<script type="text/javascript">
// App Namespace.
var RPiServerApp = {};
// Place holder for info from server.
RPiServerApp.info = JSON.parse('<?php echo json_encode($values); ?>');
// Updates system values.
RPiServerApp.updateValues = function() {
for (var i in this.info.system) {
this.updateText(i, this.info.system[i]);
}
};
// Draw chart callback.
RPiServerApp.drawChart = function () {
var gaugeData = google.visualization.arrayToDataTable([
['Label', 'Value'],
['Memory', this.convertToPercent(
this.info.memory.total - this.info.memory.free,
this.info.memory.total)],
['CPU Load', this.convertToPercent(this.info.system.load, 1)],
['Swap', this.convertToPercent(
this.info.memory.total_swap - this.info.memory.free_swap,
this.info.memory.total_swap)],
['Cache', this.convertToPercent(
this.info.memory.total - this.info.memory.cache,
this.info.memory.total)],
['Buffer', this.convertToPercent(
this.info.memory.total - this.info.memory.buffer,
this.info.memory.total)],
]);
var gaugeOptions = {
height: 250,
redFrom: 85, redTo: 100,
yellowFrom:70, yellowTo: 85,
minorTicks: 5
};
var gauges = new google.visualization.Gauge(
document.getElementById('gauges'));
gauges.draw(gaugeData, gaugeOptions);
};
// Convert values to GB from KB.
RPiServerApp.convertToGB = function(size) {
var inGB = (parseFloat(size.replace('/[^\d]/g', '')))/(1024*1024)
return Math.round(inGB) + 'GB';
};
// Generates drive info snippet.
RPiServerApp.generateDriveInfoSnippet = function(drive) {
return 'Type: ' + drive.type + ' | ' +
'Size: ' + this.convertToGB(drive.size) + ' | ' +
'Used: ' + drive.percent;
};
// Adds drive info.
RPiServerApp.addDriveInfo = function() {
for (var i in this.info.hdd) {
var newDrive = liElemTemplate.replace(
'#drive#', this.info.hdd[i].drive).replace(
'#info#', this.generateDriveInfoSnippet(
this.info.hdd[i]));
drivesContainer.innerHTML += newDrive;
}
};
// Inits.
RPiServerApp.init = function() {
google.charts.load('current', {'packages':['gauge', 'corechart']});
google.charts.setOnLoadCallback(
RPiServerApp.drawChart.bind(this));
this.updateValues();
this.addDriveInfo();
};
/**
* Updates text.
* @param {string} objectId
* @param {string} text
*/
RPiServerApp.updateText = function (objectId, text) {
try {
document.getElementById(objectId).textContent = text;
} catch (e) {
console.log(e);
console.log(objectId);
console.log(text);
}
};
/**
* Convert to percent
* @param {string} some_value
* @param {string} percent_of
* @return {float} percent.
*/
RPiServerApp.convertToPercent = function(some_value, percent_of) {
return Math.round(
((parseFloat(some_value)*100)/parseFloat(percent_of)));
};
// Running App.
RPiServerApp.init();
</script>
</body>
</html>