Fix the platform log streaming
This commit is contained in:
@@ -5,54 +5,56 @@ angular.module('Application').controller('LogsController', ['$scope', '$location
|
||||
$scope.user = Client.getUserInfo();
|
||||
|
||||
$scope.logs = [];
|
||||
$scope.selected = null;
|
||||
$scope.selected = '';
|
||||
$scope.activeEventSource = null;
|
||||
|
||||
function ab2str(buf) {
|
||||
return String.fromCharCode.apply(null, new Uint16Array(buf));
|
||||
}
|
||||
|
||||
$scope.populateLogTypes = function () {
|
||||
$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' });
|
||||
$scope.logs.push({ name: 'System (All)', type: 'platform', value: 'all' });
|
||||
$scope.logs.push({ name: 'Box', type: 'platform', value: 'box' });
|
||||
$scope.logs.push({ name: 'Mail', type: 'platform', value: 'mail' });
|
||||
|
||||
Client.getInstalledApps().forEach(function (app) {
|
||||
$scope.logs.types.push({ name: app.fqdn, type: 'app', id: app.id });
|
||||
$scope.logs.push({ name: app.fqdn, type: 'app', value: app.id });
|
||||
});
|
||||
|
||||
$scope.selected = $scope.logs[0];
|
||||
};
|
||||
|
||||
$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);
|
||||
};
|
||||
});
|
||||
// close the old event source so we wont receive any new logs
|
||||
if ($scope.activeEventSource) {
|
||||
$scope.activeEventSource.close();
|
||||
$scope.activeEventSource = null;
|
||||
}
|
||||
|
||||
var func = newVal.type === 'platform' ? Client.getPlatformLogs : Client.getAppLogs;
|
||||
func(newVal.value, true, function handleLogs(error, result) {
|
||||
if (error) return console.error(error);
|
||||
|
||||
var logViewer = $('.log-line-container');
|
||||
logViewer.empty();
|
||||
|
||||
$scope.activeEventSource = result;
|
||||
result.onmessage = function handleMessage(message) {
|
||||
var data;
|
||||
|
||||
try {
|
||||
data = JSON.parse(message.data);
|
||||
} catch (e) {
|
||||
return console.error(e);
|
||||
}
|
||||
|
||||
var logLine = $('<div>');
|
||||
logLine.html(window.ansiToHTML(ab2str(data.message)));
|
||||
logViewer.append(logLine);
|
||||
};
|
||||
});
|
||||
});
|
||||
|
||||
Client.onReady($scope.populateLogTypes);
|
||||
|
||||
Reference in New Issue
Block a user