UNPKG

@iotize/tap-scripts

Version:

IoTize Tap scripts

312 lines 19.6 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 }); exports.ScriptRunner = exports.DisplayToLogFunction = exports.OutputToLogFunction = exports.TestRunnerContext = void 0; const byte_converter_1 = require("@iotize/common/byte-converter"); const rxjs_1 = require("rxjs"); const errors_1 = require("./errors"); const instructions_1 = require("./instructions"); const logger_1 = require("./logger"); /** * */ class TestRunnerContext { constructor(device, instructions, io) { this.device = device; this.instructions = instructions; this.io = io; this._labels = {}; this.current = -1; this.resultCode = null; this._data = {}; this._running = false; this.nextChanged = false; this.errorHandler = (error) => { throw error; }; this.instructions.forEach((instruction, index) => { if (instruction instanceof instructions_1.LabelInstruction) { this.mapLabel(instruction.name, index); } }); } store(key, value) { if (arguments.length === 2) { this._data[key] = value; } else { return this._data[key]; } } get labels() { return this._labels; } set lastLwm2mGetResponse(r) { this._lastLwm2mGetResponse = r; this.lastLwm2mResponse = r; } get lastLwm2mGetResponse() { if (!this._lastLwm2mGetResponse) { throw new Error(`No last LWM2M get response available yet`); } return this._lastLwm2mGetResponse; } // asObservable() { // return this._observer!.asObservable(); // TODO fix // } /** * Resume script execution */ continue() { return __awaiter(this, void 0, void 0, function* () { this._running = true; while (this._running && !this.isEnded()) { if (!this.nextChanged) { this.current++; } this.nextChanged = false; yield this.safeRunOne(this.current); } this._running = false; }); } runAll() { return new rxjs_1.Observable((observer) => { this._observer = observer; this.resultCode = null; this.current = -1; this.continue() .then(() => [this._observer, undefined]) .catch((err) => [this._observer, err]) .then(([observer, err]) => { this._observer = undefined; if (!err) { observer === null || observer === void 0 ? void 0 : observer.complete(); } else { observer === null || observer === void 0 ? void 0 : observer.error(err); } }); return () => { this._observer = undefined; this.stop(); }; }); } isRunning() { return this._running; } /** * Pause script execution */ stop() { this._running = false; } /** * Return true script execution is finished */ isEnded() { return (this.resultCode !== null || this.current >= this.instructions.length); } getCurrentIndex() { return this.current; } setNextIndex(index) { (0, logger_1.debug)(`TestRunnerContext`, `Jumping to index: ${index}`); this.current = index; this.nextChanged = true; } runCurrent() { return this.safeRunOne(this.current); } /** * Run instruction at given index * @param index */ runOne(index) { var _a; return __awaiter(this, void 0, void 0, function* () { this.current = index; // debug(`next on instruction ${index}/${this.instructions.length}`); if (index < this.instructions.length) { const instruction = this.instructions[index]; if (!instruction) { throw errors_1.ScriptError.internalError(`Instruction should not be null at index ${index}`); } (0, logger_1.debug)(`Running instruction ${index + 1}/${this.instructions.length}: ${instruction.constructor.name} (${instruction.toString()})`); const progressInfo = { loaded: index, total: this.instructions.length }; (_a = this._observer) === null || _a === void 0 ? void 0 : _a.next({ type: 'before', instruction: instruction, progress: progressInfo }); const result = instruction.run(this); let promise; if (result instanceof Promise) { promise = result; } else { promise = Promise.resolve(result); } return promise.then(res => { var _a; (_a = this._observer) === null || _a === void 0 ? void 0 : _a.next({ type: 'after', instruction: instruction, progress: progressInfo, result: result }); return res; }); } else { this.end(); return Promise.resolve(); } }); } next() { return __awaiter(this, void 0, void 0, function* () { const result = yield this.safeRunOne(this.current + 1); this.next(); }); } /** * TODO use result code */ end(resultCode = 0) { var _a; if (typeof resultCode !== 'number') { throw errors_1.ScriptError.internalError(`result code should be a number. Given: "${resultCode}" (type=${typeof resultCode})`); } this.resultCode = resultCode; (0, logger_1.debug)(`Ending script with result code ${resultCode}`); (_a = this._observer) === null || _a === void 0 ? void 0 : _a.next({ type: 'end', resultCode: resultCode, progress: { total: this.instructions.length, loaded: this.instructions.length } }); } onError(err) { var _a, _b; return __awaiter(this, void 0, void 0, function* () { // debug('ScriptRunner', `An error occured`, err); try { if (!this.errorHandler) { this._running = false; (_a = this._observer) === null || _a === void 0 ? void 0 : _a.error(err); } else { yield this.errorHandler(err); } } catch (error) { this._running = false; (_b = this._observer) === null || _b === void 0 ? void 0 : _b.error(err); } }); } mapLabel(name, value) { // debug(`Adding label "${name}" to index ${value}`) this._labels[name] = value; } getLabel(name) { if (name in this._labels) { return this._labels[name]; } else { return undefined; } } safeRunOne(index) { return __awaiter(this, void 0, void 0, function* () { try { return yield this.runOne(index); } catch (err) { yield this.onError(err); } }); } } exports.TestRunnerContext = TestRunnerContext; function OutputToLogFunction(response) { let message; if (response) { message = (0, byte_converter_1.bufferToHexString)(response.toBytes()); } else { message = 'NO OUTPUT YET'; } (0, logger_1.debug)(message + '\r\n'); } exports.OutputToLogFunction = OutputToLogFunction; function DisplayToLogFunction(logLevel, message) { const map = { error: 'error', verbose: 'debug', message: 'info' }; console[map[logLevel]](message); } exports.DisplayToLogFunction = DisplayToLogFunction; /** * Script runner * */ class ScriptRunner { constructor(io = { output: OutputToLogFunction, display: DisplayToLogFunction }) { this.io = io; } /** * Configure error handler */ set errorHandler(handler) { this._errorHandler = handler; } get errorHandler() { return this._errorHandler; } isRunning() { var _a; return !!((_a = this.context) === null || _a === void 0 ? void 0 : _a.isRunning()); } /** * Run script instructions * @param instructions * @param device */ run(instructions, device) { if (this.context) { // should we throw an error when script is already running ? } this.context = new TestRunnerContext(device, instructions, this.io); if (this.context.errorHandler) { this.context.errorHandler = this._errorHandler; } return this.context.runAll(); } stop() { var _a; (_a = this.context) === null || _a === void 0 ? void 0 : _a.stop(); } } exports.ScriptRunner = ScriptRunner; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"script-runner.js","sourceRoot":"","sources":["../../../src/lib/script-runner.ts"],"names":[],"mappings":"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"}