Allow to follow app logs

This commit is contained in:
Johannes Zellner
2017-08-07 16:48:27 +02:00
parent e7db2ab137
commit bcf37d833f
5 changed files with 109 additions and 41 deletions

View File

@@ -4,22 +4,56 @@ angular.module('Application').controller('LogsController', ['$scope', '$location
$scope.config = Client.getConfig();
$scope.user = Client.getUserInfo();
$scope.logs = {
types: null,
selectedUrl: '' // index into types
};
$scope.logs = [];
$scope.selected = null;
function ab2str(buf) {
return String.fromCharCode.apply(null, new Uint16Array(buf));
}
$scope.populateLogTypes = function () {
$scope.logs.types = [
{ name: 'System (All)', url: Client.makeURL('/api/v1/cloudron/logs?units=all') },
{ name: 'Box', url: Client.makeURL('/api/v1/cloudron/logs?units=box') },
{ name: 'Mail', url: Client.makeURL('/api/v1/cloudron/logs?units=mail') }
];
$scope.logs.push({ name: 'System (All)', type: 'platform', units: 'all' });
$scope.logs.push({ name: 'Box', type: 'platform', units: 'box' });
$scope.logs.push({ name: 'Mail', type: 'platform', units: 'mail' });
Client.getInstalledApps().forEach(function (app) {
$scope.logs.types.push({ name: app.fqdn, url: Client.makeURL('/api/v1/apps/' + app.id + '/logs') });
$scope.logs.types.push({ name: app.fqdn, type: 'app', id: app.id });
});
};
$scope.$watch('selected', function (newVal) {
if (!newVal) return;
if (newVal.type === 'platform') {
Client.getPlatformLogs(newVal.units, true, function (error, result) {
if (error) return console.error(error);
var logViewer = $('.log-line-container');
logViewer.empty();
});
} else {
Client.getAppLogs(newVal.id, true, function (error, result) {
if (error) return console.error(error);
var logViewer = $('.log-line-container');
logViewer.empty();
result.onmessage = function (e) {
var data;
try {
data = JSON.parse(e.data);
} catch (e) {
return console.error(e);
}
var logLine = $('<div>');
logLine.html(window.ansiToHTML(ab2str(data.message)));
logViewer.append(logLine);
};
});
}
});
Client.onReady($scope.populateLogTypes);
}]);