2019-03-21 05:46:49 +00:00
|
|
|
import moment from 'moment';
|
2022-10-20 14:33:54 +00:00
|
|
|
|
2022-11-13 10:29:25 +00:00
|
|
|
import { concatLogsToString, NEW_LINE_BREAKER } from '@/docker/helpers/logHelper';
|
2019-03-21 05:46:49 +00:00
|
|
|
|
2020-04-10 21:54:53 +00:00
|
|
|
angular.module('portainer.docker').controller('LogViewerController', [
|
2022-07-11 23:26:23 +00:00
|
|
|
'$scope',
|
2020-04-10 21:54:53 +00:00
|
|
|
'clipboard',
|
2020-12-15 23:30:16 +00:00
|
|
|
'Blob',
|
|
|
|
'FileSaver',
|
2022-07-11 23:26:23 +00:00
|
|
|
function ($scope, clipboard, Blob, FileSaver) {
|
2020-04-10 21:54:53 +00:00
|
|
|
this.state = {
|
|
|
|
availableSinceDatetime: [
|
|
|
|
{ desc: 'Last day', value: moment().subtract(1, 'days').format() },
|
|
|
|
{ desc: 'Last 4 hours', value: moment().subtract(4, 'hours').format() },
|
|
|
|
{ desc: 'Last hour', value: moment().subtract(1, 'hours').format() },
|
|
|
|
{ desc: 'Last 10 minutes', value: moment().subtract(10, 'minutes').format() },
|
|
|
|
],
|
|
|
|
copySupported: clipboard.supported,
|
|
|
|
logCollection: true,
|
|
|
|
autoScroll: true,
|
|
|
|
wrapLines: true,
|
|
|
|
search: '',
|
|
|
|
filteredLogs: [],
|
|
|
|
selectedLines: [],
|
|
|
|
};
|
2018-02-28 06:19:28 +00:00
|
|
|
|
2022-07-11 23:26:23 +00:00
|
|
|
this.handleLogsCollectionChange = handleLogsCollectionChange.bind(this);
|
|
|
|
this.handleLogsWrapLinesChange = handleLogsWrapLinesChange.bind(this);
|
|
|
|
this.handleDisplayTimestampsChange = handleDisplayTimestampsChange.bind(this);
|
|
|
|
|
|
|
|
function handleLogsCollectionChange(enabled) {
|
|
|
|
$scope.$evalAsync(() => {
|
|
|
|
this.state.logCollection = enabled;
|
|
|
|
this.state.autoScroll = enabled;
|
|
|
|
this.logCollectionChange(enabled);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function handleLogsWrapLinesChange(enabled) {
|
|
|
|
$scope.$evalAsync(() => {
|
|
|
|
this.state.wrapLines = enabled;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function handleDisplayTimestampsChange(enabled) {
|
|
|
|
$scope.$evalAsync(() => {
|
|
|
|
this.displayTimestamps = enabled;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-04-10 21:54:53 +00:00
|
|
|
this.copy = function () {
|
2021-11-25 04:46:58 +00:00
|
|
|
clipboard.copyText(this.state.filteredLogs.map((log) => log.line).join(NEW_LINE_BREAKER));
|
2020-04-10 21:54:53 +00:00
|
|
|
$('#refreshRateChange').show();
|
|
|
|
$('#refreshRateChange').fadeOut(2000);
|
|
|
|
};
|
2018-02-28 06:19:28 +00:00
|
|
|
|
2020-04-10 21:54:53 +00:00
|
|
|
this.copySelection = function () {
|
2021-11-25 04:46:58 +00:00
|
|
|
clipboard.copyText(this.state.selectedLines.join(NEW_LINE_BREAKER));
|
2020-04-10 21:54:53 +00:00
|
|
|
$('#refreshRateChange').show();
|
|
|
|
$('#refreshRateChange').fadeOut(2000);
|
|
|
|
};
|
2018-02-28 06:19:28 +00:00
|
|
|
|
2020-04-10 21:54:53 +00:00
|
|
|
this.clearSelection = function () {
|
|
|
|
this.state.selectedLines = [];
|
|
|
|
};
|
2018-03-11 10:29:13 +00:00
|
|
|
|
2020-04-10 21:54:53 +00:00
|
|
|
this.selectLine = function (line) {
|
|
|
|
var idx = this.state.selectedLines.indexOf(line);
|
|
|
|
if (idx === -1) {
|
|
|
|
this.state.selectedLines.push(line);
|
|
|
|
} else {
|
|
|
|
this.state.selectedLines.splice(idx, 1);
|
|
|
|
}
|
|
|
|
};
|
2020-12-15 23:30:16 +00:00
|
|
|
|
|
|
|
this.downloadLogs = function () {
|
2022-10-20 14:33:54 +00:00
|
|
|
const logsAsString = concatLogsToString(this.state.filteredLogs);
|
|
|
|
const data = new Blob([logsAsString]);
|
2020-12-15 23:30:16 +00:00
|
|
|
FileSaver.saveAs(data, this.resourceName + '_logs.txt');
|
|
|
|
};
|
2020-04-10 21:54:53 +00:00
|
|
|
},
|
|
|
|
]);
|