@mindconnect/mindconnect-nodejs
Version:
NodeJS Library for Siemens Insights Hub Connectivity - TypeScript SDK for Insights Hub and Industrial IoT - Command Line Interface - Insights Hub Development Proxy (Siemens Insights Hub was formerly known as MindSphere)
184 lines • 9.43 kB
JavaScript
;
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
const console_1 = require("console");
const fs = require("fs");
const __1 = require("../..");
const utils_1 = require("../../api/utils");
const command_utils_1 = require("./command-utils");
const path = require("path");
let color = (0, command_utils_1.getColor)("blue");
exports.default = (program) => {
program
.command("jobs")
.alias("jb")
.option("-m, --mode [list|create|stop|template|info]", "list | create | stop | template | info", "list")
.option("-f, --file <file>", ".mdsp.json file with job definition", "jobmanager.job.mdsp.json")
.option("-i, --jobid <jobid>", "the job id")
.option("-e, --message <message>", "the message filter (contains) for list command")
.option("-s, --status <status>", "the status filter (equals, e.g. STOPPED, FAILED...) for list command")
.option("-d, --modelid <modelid>", "the modelid filter (equals) for list command")
.option("-o, --overwrite", "overwrite template file if it already exists")
.option("-k, --passkey <passkey>", "passkey")
.option("-y, --retry <number>", "retry attempts before giving up", "3")
.option("-v, --verbose", "verbose output")
.description(color("list, create or stop jobs *"))
.action((options) => {
(() => __awaiter(void 0, void 0, void 0, function* () {
try {
checkRequiredParamaters(options);
const sdk = (0, command_utils_1.getSdk)(options);
color = (0, command_utils_1.adjustColor)(color, options, true);
(0, command_utils_1.homeDirLog)(options.verbose, color);
(0, command_utils_1.proxyLog)(options.verbose, color);
switch (options.mode) {
case "list":
yield listJobs(sdk, options);
break;
case "template":
createTemplate(options);
console.log("Edit the file before submitting it to MindSphere.");
break;
case "stop":
yield stopJob(options, sdk);
break;
case "create":
yield createJob(options, sdk);
break;
case "info":
yield jobInfo(options, sdk);
break;
default:
throw Error(`no such option: ${options.mode}`);
}
}
catch (err) {
(0, command_utils_1.errorLog)(err, options.verbose);
}
}))();
})
.on("--help", () => {
(0, console_1.log)("\n Examples:\n");
(0, console_1.log)(` mdsp jobs --mode list \t\t\t\t\t list all jobs`);
(0, console_1.log)(` mdsp jobs --mode list --status FAILED --message import \t list all jobs which failed on import`);
(0, console_1.log)(` mdsp jobs --mode list --modelid <modelid> \t\t\t list all jobs for specified model`);
(0, console_1.log)(` mdsp jobs --mode list --modelid <modelid> \t\t\t list all jobs for specified model`);
(0, console_1.log)(` mdsp jobs --mode list --modelid <modelid> \t\t\t list all jobs for specified model`);
(0, console_1.log)(` mdsp jobs --mode template \t\t\t\t\t create template file for job creation`);
(0, console_1.log)(` mdsp jobs --mode create --file <templatefile> \t\t create job`);
(0, console_1.log)(` mdsp jobs --mode info --jobid <jobid> \t\t\t get infos about the job`);
(0, console_1.log)(` mdsp jobs --mode stop --jobid <jobid> \t\t\t stop job with job id`);
(0, command_utils_1.serviceCredentialLog)();
});
};
function createJob(options, sdk) {
return __awaiter(this, void 0, void 0, function* () {
const filePath = path.resolve(options.file);
const file = fs.readFileSync(filePath);
const job = JSON.parse(file.toString());
const result = yield sdk.GetJobManagerClient().PostJob(job);
console.log(`created job ${color(result.id)} with status ${color(result.status)} and message \n ${result.message}`);
});
}
function createTemplate(options) {
const templateType = {
modelId: "<modelId>:guid",
configurationId: "<configurationId:guid>",
inputFolderId: "<inputFolderIdFromDataExchange:guid>",
outputFolderId: "<outputFolderIdFromDataExchange:id",
maximumExecutionTimeInSeconds: "60",
};
(0, command_utils_1.verboseLog)(JSON.stringify(templateType, null, 2), options.verbose);
writejobToFile(options, templateType);
}
function writejobToFile(options, job) {
const fileName = options.file || `job.jobmanager.mdsp.json`;
const filePath = path.resolve(fileName);
fs.existsSync(filePath) &&
!options.overwrite &&
(0, utils_1.throwError)(`The ${filePath} already exists. (use --overwrite to overwrite) `);
fs.writeFileSync(filePath, JSON.stringify(job, null, 2));
console.log(`The data was written into ${color(fileName)} run \n\n\tmdsp jobs --mode create --file ${fileName} \n\nto create the job`);
}
function stopJob(options, sdk) {
return __awaiter(this, void 0, void 0, function* () {
const id = options.jobid;
const result = yield sdk.GetJobManagerClient().StopJob(id);
console.log(`sent stop signal to job with id ${color(id)}. Job status: ${color(result.status)}`);
});
}
function listJobs(sdk, options) {
return __awaiter(this, void 0, void 0, function* () {
const jobManagerClient = sdk.GetJobManagerClient();
let page = 0;
let jobs;
const filter = buildFilter(options);
(0, command_utils_1.verboseLog)(JSON.stringify(filter, null, 2), options.verbose);
console.log(`id ${color("status")} message createdBy modelId`);
let jobCount = 0;
do {
jobs = (yield (0, __1.retry)(options.retry, () => jobManagerClient.GetJobs({
pageNumber: page,
pageSize: 100,
filter: Object.keys(filter).length === 0 ? undefined : JSON.stringify(filter),
})));
jobs.jobs = jobs.jobs || [];
jobs.page = jobs.page || { totalPages: 0 };
for (const job of jobs.jobs || []) {
jobCount++;
console.log(`${job.id} ${color(job.status)} ${(job.message || "").substr(0, 20)} ${job.createdBy}\t${job.modelId}`);
(0, command_utils_1.verboseLog)(JSON.stringify(job, null, 2), options.verbose);
}
} while (page++ < (jobs.page.totalPages || 0));
console.log(`${color(jobCount)} jobs listed.\n`);
});
}
function buildFilter(options) {
const filter = {};
if (options.message) {
filter.message = { contains: `${options.message}` };
}
if (options.status) {
filter.status = { eq: `${options.status}` };
}
if (options.modelid) {
filter.modelId = { eq: `${options.modelid}` };
}
return filter;
}
function jobInfo(options, sdk) {
return __awaiter(this, void 0, void 0, function* () {
const id = options.jobid;
const job = yield sdk.GetJobManagerClient().GetJob(id);
console.log(`Id: ${color(job.id)}`);
console.log(`Status: ${color(job.status)}`);
console.log(`Configuration Id: ${color(job.configurationId)}`);
console.log(`Environment Id: ${job.environmentId}`);
console.log(`InputFolder Id: ${job.inputFolderId}`);
console.log(`OutputFolder Id: ${job.inputFolderId}`);
console.log(`Model Id: ${color(job.modelId)}`);
console.log(`Created by: ${color(job.createdBy)} on date ${job.creationDate}`);
console.log(`Message:\n${job.message}`);
(0, command_utils_1.verboseLog)(JSON.stringify(job, null, 2), options.verbose);
});
}
function checkRequiredParamaters(options) {
options.mode === "create" &&
!options.file &&
(0, command_utils_1.errorLog)("you have to provide a file with job parameters to create an job (see mdsp jobs --help for more details)", true);
options.mode === "stop" &&
!options.jobid &&
(0, command_utils_1.errorLog)("you have to provide the jobid of the job you want to stop (see mdsp jobs --help for more details)", true);
options.mode === "info" &&
!options.jobid &&
(0, command_utils_1.errorLog)("you have to provide the jobid to get infos about the job (see mdsp jobs --help for more details)", true);
}
//# sourceMappingURL=jobmanager-jobs.js.map