mirror of https://github.com/portainer/portainer
84 lines
2.3 KiB
JavaScript
84 lines
2.3 KiB
JavaScript
angular.module('serviceLogs', [])
|
|
.controller('ServiceLogsController', ['$scope', '$stateParams', '$anchorScroll', 'ServiceLogs', 'Service',
|
|
function ($scope, $stateParams, $anchorScroll, ServiceLogs, Service) {
|
|
$scope.state = {};
|
|
$scope.state.displayTimestampsOut = false;
|
|
$scope.state.displayTimestampsErr = false;
|
|
$scope.stdout = '';
|
|
$scope.stderr = '';
|
|
$scope.tailLines = 2000;
|
|
|
|
function getLogs() {
|
|
$('#loadingViewSpinner').show();
|
|
getLogsStdout();
|
|
getLogsStderr();
|
|
$('#loadingViewSpinner').hide();
|
|
}
|
|
|
|
function getLogsStderr() {
|
|
ServiceLogs.get($stateParams.id, {
|
|
stdout: 0,
|
|
stderr: 1,
|
|
timestamps: $scope.state.displayTimestampsErr,
|
|
tail: $scope.tailLines
|
|
}, function (data, status, headers, config) {
|
|
// Replace carriage returns with newlines to clean up output
|
|
data = data.replace(/[\r]/g, '\n');
|
|
// Strip 8 byte header from each line of output
|
|
data = data.substring(8);
|
|
data = data.replace(/\n(.{8})/g, '\n');
|
|
$scope.stderr = data;
|
|
});
|
|
}
|
|
|
|
function getLogsStdout() {
|
|
ServiceLogs.get($stateParams.id, {
|
|
stdout: 1,
|
|
stderr: 0,
|
|
timestamps: $scope.state.displayTimestampsOut,
|
|
tail: $scope.tailLines
|
|
}, function (data, status, headers, config) {
|
|
// Replace carriage returns with newlines to clean up output
|
|
data = data.replace(/[\r]/g, '\n');
|
|
// Strip 8 byte header from each line of output
|
|
data = data.substring(8);
|
|
data = data.replace(/\n(.{8})/g, '\n');
|
|
$scope.stdout = data;
|
|
});
|
|
}
|
|
|
|
function getService() {
|
|
$('#loadingViewSpinner').show();
|
|
Service.get({id: $stateParams.id}, function (d) {
|
|
$scope.service = d;
|
|
$('#loadingViewSpinner').hide();
|
|
}, function (e) {
|
|
Notifications.error('Failure', e, 'Unable to retrieve service info');
|
|
$('#loadingViewSpinner').hide();
|
|
});
|
|
}
|
|
|
|
function initView() {
|
|
getService();
|
|
getLogs();
|
|
|
|
var logIntervalId = window.setInterval(getLogs, 5000);
|
|
|
|
$scope.$on('$destroy', function () {
|
|
// clearing interval when view changes
|
|
clearInterval(logIntervalId);
|
|
});
|
|
|
|
$scope.toggleTimestampsOut = function () {
|
|
getLogsStdout();
|
|
};
|
|
|
|
$scope.toggleTimestampsErr = function () {
|
|
getLogsStderr();
|
|
};
|
|
}
|
|
|
|
initView();
|
|
|
|
}]);
|