mirror of
https://github.com/portainer/portainer.git
synced 2025-07-19 13:29:41 +02:00
* Adding latest build to dist. * Adding latest build to dist. * Bump other app version. * Build latest changes. * Bump version to 0.7.0. * Version bump to 0.9.0-beta and remote API 1.20. * Whoah there, back down to 0.8.0-beta. * Merge branch 'crosbymichael-master' into crosbymichael-dist * Add volume options in volume creation form * display swarm cluster information in Swarm tab * update LICENSE * update repository URL in status bar * remove console logs * do not display Swarm containers anywhere in the UI * update position for add/remove option on Volumes page * compliant with swarm == 1.2.0 API support * update nginx-basic-auth examples with latest nginx and swarm example * Updated .gitignore * update .gitignore * reverted entry for dist/uifordocker in .gitignore * WIP * fix linter issues * added logo * update repository URL * update .gitignore (ignore dist/*) * add lodash * add containers actions binding (start, stop...) * replace image icon * bind remove image action * bind network remove action * bind volume remove action * update logo * wip on container details * update logo scaling, favicon and page title * wip container view * add containers actions in container view * add image view * add network view * remove useless data in tables * add pull image, create network modals * add create volume modal * update style for createVolume options * add start container modal * create volume modal now use a select to display drivers * add container stats * add containerTop view in stats view * fix trimcontainername filter * add container logs view * updated .gitignore * remove useless files/modules * remove useless chart in image view * replace $location usage with $state.go * remove useless swarm example
79 lines
2.2 KiB
JavaScript
79 lines
2.2 KiB
JavaScript
angular.module('containerLogs', [])
|
|
.controller('ContainerLogsController', ['$scope', '$stateParams', '$anchorScroll', 'ContainerLogs', 'Container', 'ViewSpinner',
|
|
function ($scope, $stateParams, $anchorScroll, ContainerLogs, Container, ViewSpinner) {
|
|
$scope.state = {};
|
|
$scope.state.displayTimestampsOut = false;
|
|
$scope.state.displayTimestampsErr = false;
|
|
$scope.stdout = '';
|
|
$scope.stderr = '';
|
|
$scope.tailLines = 2000;
|
|
|
|
ViewSpinner.spin();
|
|
Container.get({id: $stateParams.id}, function (d) {
|
|
$scope.container = d;
|
|
ViewSpinner.stop();
|
|
}, function (e) {
|
|
if (e.status === 404) {
|
|
Messages.error("Not found", "Container not found.");
|
|
} else {
|
|
Messages.error("Failure", e.data);
|
|
}
|
|
ViewSpinner.stop();
|
|
});
|
|
|
|
function getLogs() {
|
|
ViewSpinner.spin();
|
|
getLogsStdout();
|
|
getLogsStderr();
|
|
ViewSpinner.stop();
|
|
}
|
|
|
|
function getLogsStderr() {
|
|
ContainerLogs.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() {
|
|
ContainerLogs.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;
|
|
});
|
|
}
|
|
|
|
// initial call
|
|
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();
|
|
};
|
|
}]);
|