2020-06-25 03:25:51 +00:00
|
|
|
import _ from 'lodash-es';
|
2022-10-23 06:53:25 +00:00
|
|
|
import { getEnvironments } from '@/react/portainer/environments/environment.service';
|
2023-02-14 08:19:41 +00:00
|
|
|
import { confirmWebEditorDiscard } from '@@/modals/confirm';
|
2020-06-25 03:25:51 +00:00
|
|
|
|
2020-07-06 07:35:13 +00:00
|
|
|
export class EdgeJobController {
|
2020-08-10 21:51:21 +00:00
|
|
|
/* @ngInject */
|
2023-02-14 08:19:41 +00:00
|
|
|
constructor($async, $q, $state, $window, EdgeJobService, FileSaver, GroupService, HostBrowserService, Notifications, TagService) {
|
2020-06-25 03:25:51 +00:00
|
|
|
this.state = {
|
|
|
|
actionInProgress: false,
|
|
|
|
showEditorTab: false,
|
2021-03-20 21:13:27 +00:00
|
|
|
isEditorDirty: false,
|
2020-06-25 03:25:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
this.$async = $async;
|
|
|
|
this.$q = $q;
|
|
|
|
this.$state = $state;
|
2021-03-20 21:13:27 +00:00
|
|
|
this.$window = $window;
|
2020-06-25 03:25:51 +00:00
|
|
|
this.EdgeJobService = EdgeJobService;
|
|
|
|
this.FileSaver = FileSaver;
|
|
|
|
this.GroupService = GroupService;
|
|
|
|
this.HostBrowserService = HostBrowserService;
|
|
|
|
this.Notifications = Notifications;
|
|
|
|
this.TagService = TagService;
|
|
|
|
|
|
|
|
this.update = this.update.bind(this);
|
|
|
|
this.updateAsync = this.updateAsync.bind(this);
|
|
|
|
this.downloadLogs = this.downloadLogs.bind(this);
|
|
|
|
this.downloadLogsAsync = this.downloadLogsAsync.bind(this);
|
|
|
|
this.collectLogs = this.collectLogs.bind(this);
|
|
|
|
this.collectLogsAsync = this.collectLogsAsync.bind(this);
|
|
|
|
this.clearLogs = this.clearLogs.bind(this);
|
|
|
|
this.clearLogsAsync = this.clearLogsAsync.bind(this);
|
|
|
|
this.refresh = this.refresh.bind(this);
|
|
|
|
this.refreshAsync = this.refreshAsync.bind(this);
|
|
|
|
this.showEditor = this.showEditor.bind(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
update() {
|
|
|
|
return this.$async(this.updateAsync);
|
|
|
|
}
|
|
|
|
|
|
|
|
async updateAsync() {
|
|
|
|
const model = this.edgeJob;
|
|
|
|
this.state.actionInProgress = true;
|
|
|
|
|
|
|
|
try {
|
|
|
|
await this.EdgeJobService.updateEdgeJob(model);
|
2022-08-10 05:07:35 +00:00
|
|
|
this.Notifications.success('Success', 'Edge job successfully updated');
|
2021-03-20 21:13:27 +00:00
|
|
|
this.state.isEditorDirty = false;
|
2020-06-25 03:25:51 +00:00
|
|
|
this.$state.go('edge.jobs', {}, { reload: true });
|
|
|
|
} catch (err) {
|
|
|
|
this.Notifications.error('Failure', err, 'Unable to update Edge job');
|
|
|
|
}
|
|
|
|
|
|
|
|
this.state.actionInProgress = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
downloadLogs(endpointId) {
|
|
|
|
return this.$async(this.downloadLogsAsync, endpointId);
|
|
|
|
}
|
|
|
|
async downloadLogsAsync(endpointId) {
|
|
|
|
try {
|
|
|
|
const data = await this.EdgeJobService.logFile(this.edgeJob.Id, endpointId);
|
|
|
|
const downloadData = new Blob([data.FileContent], {
|
|
|
|
type: 'text/plain;charset=utf-8',
|
|
|
|
});
|
|
|
|
const logFileName = `job_${this.edgeJob.Id}_task_${endpointId}.log`;
|
|
|
|
this.FileSaver.saveAs(downloadData, logFileName);
|
|
|
|
} catch (err) {
|
|
|
|
this.Notifications.error('Failure', err, 'Unable to download file');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
associateEndpointsToResults(results, endpoints) {
|
|
|
|
return _.map(results, (result) => {
|
|
|
|
const endpoint = _.find(endpoints, (endpoint) => endpoint.Id === result.EndpointId);
|
|
|
|
result.Endpoint = endpoint;
|
|
|
|
return result;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
collectLogs(endpointId) {
|
|
|
|
return this.$async(this.collectLogsAsync, endpointId);
|
|
|
|
}
|
|
|
|
|
|
|
|
async collectLogsAsync(endpointId) {
|
|
|
|
try {
|
|
|
|
await this.EdgeJobService.collectLogs(this.edgeJob.Id, endpointId);
|
|
|
|
const result = _.find(this.results, (result) => result.EndpointId === endpointId);
|
|
|
|
result.LogsStatus = 2;
|
|
|
|
} catch (err) {
|
|
|
|
this.Notifications.error('Failure', err, 'Unable to collect logs');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
clearLogs(endpointId) {
|
|
|
|
return this.$async(this.clearLogsAsync, endpointId);
|
|
|
|
}
|
|
|
|
async clearLogsAsync(endpointId) {
|
|
|
|
try {
|
|
|
|
await this.EdgeJobService.clearLogs(this.edgeJob.Id, endpointId);
|
|
|
|
const result = _.find(this.results, (result) => result.EndpointId === endpointId);
|
|
|
|
result.LogsStatus = 1;
|
|
|
|
} catch (err) {
|
|
|
|
this.Notifications.error('Failure', err, 'Unable to clear logs');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
refresh() {
|
|
|
|
return this.$async(this.refreshAsync);
|
|
|
|
}
|
|
|
|
async refreshAsync() {
|
|
|
|
const { id } = this.$state.params;
|
|
|
|
const results = await this.EdgeJobService.jobResults(id);
|
|
|
|
if (results.length > 0) {
|
|
|
|
const endpointIds = _.map(results, (result) => result.EndpointId);
|
2022-07-19 16:00:45 +00:00
|
|
|
const endpoints = await getEnvironments({ query: { endpointIds } });
|
2020-06-25 03:25:51 +00:00
|
|
|
this.results = this.associateEndpointsToResults(results, endpoints.value);
|
|
|
|
} else {
|
|
|
|
this.results = results;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
showEditor() {
|
|
|
|
this.state.showEditorTab = true;
|
|
|
|
}
|
|
|
|
|
2021-03-20 21:13:27 +00:00
|
|
|
async uiCanExit() {
|
2022-03-28 15:02:09 +00:00
|
|
|
if (this.edgeJob && this.edgeJob.FileContent !== this.oldFileContent && this.state.isEditorDirty) {
|
2023-02-14 08:19:41 +00:00
|
|
|
return confirmWebEditorDiscard();
|
2021-03-20 21:13:27 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-25 03:25:51 +00:00
|
|
|
async $onInit() {
|
|
|
|
const { id, tab } = this.$state.params;
|
|
|
|
this.state.activeTab = tab;
|
|
|
|
if (!tab || tab === 0) {
|
|
|
|
this.state.showEditorTab = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
const [edgeJob, file, results, groups, tags] = await Promise.all([
|
|
|
|
this.EdgeJobService.edgeJob(id),
|
|
|
|
this.EdgeJobService.getScriptFile(id),
|
|
|
|
this.EdgeJobService.jobResults(id),
|
|
|
|
this.GroupService.groups(),
|
|
|
|
this.TagService.tags(),
|
|
|
|
]);
|
|
|
|
|
|
|
|
edgeJob.FileContent = file.FileContent;
|
2021-03-20 21:13:27 +00:00
|
|
|
this.oldFileContent = edgeJob.FileContent;
|
2020-06-25 03:25:51 +00:00
|
|
|
this.edgeJob = edgeJob;
|
|
|
|
this.groups = groups;
|
|
|
|
this.tags = tags;
|
|
|
|
|
2022-12-19 21:54:51 +00:00
|
|
|
this.edgeJob.EdgeGroups = this.edgeJob.EdgeGroups ? this.edgeJob.EdgeGroups : [];
|
2023-01-27 09:08:13 +00:00
|
|
|
this.edgeJob.Endpoints = this.edgeJob.Endpoints ? this.edgeJob.Endpoints : [];
|
2022-12-19 21:54:51 +00:00
|
|
|
|
2020-06-25 03:25:51 +00:00
|
|
|
if (results.length > 0) {
|
|
|
|
const endpointIds = _.map(results, (result) => result.EndpointId);
|
2022-07-19 16:00:45 +00:00
|
|
|
const endpoints = await getEnvironments({ query: { endpointIds } });
|
2020-06-25 03:25:51 +00:00
|
|
|
this.results = this.associateEndpointsToResults(results, endpoints.value);
|
|
|
|
} else {
|
|
|
|
this.results = results;
|
|
|
|
}
|
|
|
|
} catch (err) {
|
2021-09-08 08:42:17 +00:00
|
|
|
this.Notifications.error('Failure', err, 'Unable to retrieve environment list');
|
2020-06-25 03:25:51 +00:00
|
|
|
}
|
2021-03-20 21:13:27 +00:00
|
|
|
|
|
|
|
this.$window.onbeforeunload = () => {
|
2022-03-28 15:02:09 +00:00
|
|
|
if (this.edgeJob && this.edgeJob.FileContent !== this.oldFileContent && this.state.isEditorDirty) {
|
2021-03-20 21:13:27 +00:00
|
|
|
return '';
|
|
|
|
}
|
|
|
|
};
|
2020-06-25 03:25:51 +00:00
|
|
|
}
|
2021-08-10 04:44:33 +00:00
|
|
|
|
|
|
|
$onDestroy() {
|
|
|
|
this.state.isEditorDirty = false;
|
|
|
|
}
|
2020-06-25 03:25:51 +00:00
|
|
|
}
|