UNPKG

@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
"use strict"; 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