-
{{ disk.filesystem }} mounted at {{ disk.mountpoint }} {{ disk.size }} GB
+
{{ disk.filesystem }} mounted at {{ disk.mountpoint }} {{ disk.size | prettyDiskSize }}
-
- {{ disk.occupied }} GB used
-
+
This {{ disk.type }} disk contains:
-
- {{ content.label }} {{ content.usage }}
- {{ content.app.manifest.title }} installed at {{ content.app.fqdn }} {{ content.usage }}
+ {{ content.label }} {{ content.usage | prettyDiskSize }}
+ {{ content.app.manifest.title }} installed at {{ content.app.fqdn }} {{ content.usage | prettyDiskSize }}
diff --git a/src/views/graphs.js b/src/views/graphs.js
index 41fa4c5dd..9f78e10b5 100644
--- a/src/views/graphs.js
+++ b/src/views/graphs.js
@@ -140,26 +140,42 @@ angular.module('Application').controller('GraphsController', ['$scope', '$locati
], '-1min', {}, function (error, data) {
if (error) return console.error(error);
- disk.size = bytesToGigaBytes(data[2].datapoints[0][0] + data[1].datapoints[0][0] + data[0].datapoints[0][0]);
- disk.free = bytesToGigaBytes(data[0].datapoints[0][0]);
- disk.occupied = bytesToGigaBytes(data[2].datapoints[0][0] + data[1].datapoints[0][0]);
+ disk.size = data[2].datapoints[0][0] + data[1].datapoints[0][0] + data[0].datapoints[0][0];
+ disk.free = data[0].datapoints[0][0];
+ disk.occupied = data[2].datapoints[0][0] + data[1].datapoints[0][0];
+
+ disk.contains.forEach(function (content) {
+ content.color = getRandomColor();
+ });
// get disk usage data
const graphiteQueries = disk.contains.map(function (content) {
return 'absolute(collectd.localhost.du-' + content.id + '.capacity-usage)';
});
- Client.graphs(graphiteQueries, '-2days', { noNullPoints: true }, function (error, data) {
+ Client.graphs(graphiteQueries, '-1day', { noNullPoints: true }, function (error, data) {
if (error) return console.error(error);
+ var usageOther = disk.occupied;
+
data.forEach(function (d) {
var content = disk.contains.find(function (content) { return d.target.indexOf(content.id) !== -1; });
- if (!content) {
- content.usage = 'no data available yet';
- } else {
- var tmp = d.datapoints[d.datapoints.length-1][0];
- content.usage = tmp < 1000000 ? (bytesToMegaBytes(tmp) + ' MB') : (bytesToGigaBytes(tmp) + ' GB');
- }
+ if (!content) return; // didn't match any content
+
+ var tmp = d.datapoints[d.datapoints.length-1][0];
+ content.usage = tmp;
+
+ // deduct from overal disk usage to track other
+ usageOther -= tmp;
+ });
+
+
+ // add content container for other non tracked data
+ disk.contains.push({
+ label: 'Other',
+ id: 'other',
+ color: '#27CE65',
+ usage: usageOther
});
});
});