UNPKG

trm-core

Version:

TRM (Transport Request Manager) Core

179 lines (178 loc) 10.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()); }); }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.generateInstallTransport = void 0; const trm_commons_1 = require("trm-commons"); const commons_1 = require("../../commons"); const systemConnector_1 = require("../../systemConnector"); const transport_1 = require("../../transport"); const manifest_1 = require("../../manifest"); const chalk_1 = __importDefault(require("chalk")); const prompts_1 = require("../commons/prompts"); exports.generateInstallTransport = { name: 'generate-install-transport', filter: (context) => __awaiter(void 0, void 0, void 0, function* () { if (context.rawInput.installData.installTransport.create) { return true; } else { trm_commons_1.Logger.log(`Skipping install transport generation (user input)`, true); return false; } }), run: (context) => __awaiter(void 0, void 0, void 0, function* () { trm_commons_1.Logger.log('Generate install transport step', true); try { if ((0, commons_1.getPackageNamespace)(context.runtime.installData.namespace) === '$') { return; } trm_commons_1.Logger.loading(`Reading ${systemConnector_1.SystemConnector.getDest()} transport targets...`); const transportTarget = yield (0, prompts_1.setTransportTarget)(context.rawInput.contextData.noInquirer, yield systemConnector_1.SystemConnector.getTransportTargets(), context.rawInput.installData.installTransport.targetSystem, "Install transport target"); trm_commons_1.Logger.loading(`Generating install transports...`); context.runtime.installData.transports.push({ type: transport_1.TrmTransportIdentifier.TADIR, transport: yield transport_1.Transport.createWb({ text: `TRM generated transport`, target: transportTarget }) }); const noCustomizing = context.rawInput.installData.import.noCust || context.runtime.packageTransports.cust.length === 0; if (!noCustomizing) { context.runtime.installData.transports.push({ type: transport_1.TrmTransportIdentifier.CUST, transport: yield transport_1.Transport.createCust({ text: `TRM generated transport`, target: transportTarget }) }); } var tadirObjects = context.runtime.packageTransportsData.tadir; if (context.rawInput.installData.installDevclass.keepOriginal) { tadirObjects = tadirObjects.concat(context.runtime.packageTransportsData.tdevc.map(o => { return { pgmid: 'R3TR', object: 'DEVC', objName: o.devclass, devclass: o.devclass }; })); } else { tadirObjects = tadirObjects.concat(context.runtime.generatedData.devclass.map(devclass => { return { pgmid: 'R3TR', object: 'DEVC', objName: devclass, devclass: devclass }; })); } try { trm_commons_1.Logger.log(`Adding ${tadirObjects.length} workbench objects with lock in bulk`, true); yield (context.runtime.installData.transports.find(o => o.type == transport_1.TrmTransportIdentifier.TADIR)).transport.addObjects(tadirObjects, true); } catch (_a) { trm_commons_1.Logger.log(`Failed adding in bulk, adding one by one`, true); for (const tadir of tadirObjects) { try { try { trm_commons_1.Logger.log(`Adding object ${tadir.pgmid} ${tadir.object} ${tadir.objName} with lock`, true); yield (context.runtime.installData.transports.find(o => o.type == transport_1.TrmTransportIdentifier.TADIR)).transport.addObjects([tadir], true); } catch (e) { trm_commons_1.Logger.log(`Failed ${e.toString()}, adding without lock`, true); yield (context.runtime.installData.transports.find(o => o.type == transport_1.TrmTransportIdentifier.TADIR)).transport.addObjects([tadir], false); } } catch (e) { trm_commons_1.Logger.warning(`Failed adding ${tadir.pgmid}${tadir.object}${tadir.objName} to transport ${(context.runtime.installData.transports.find(o => o.type == transport_1.TrmTransportIdentifier.TADIR)).transport.trkorr}`); trm_commons_1.Logger.error(e.toString(), true); } } } if (context.runtime.packageTransports.lang.instance) { try { trm_commons_1.Logger.log(`Including language transport ${context.runtime.packageTransports.lang.instance.trkorr}`, true); yield (context.runtime.installData.transports.find(o => o.type == transport_1.TrmTransportIdentifier.TADIR)).transport.addObjectsFromTransport(context.runtime.packageTransports.lang.instance.trkorr); } catch (e) { trm_commons_1.Logger.warning(`Failed including language transport ${context.runtime.packageTransports.lang.instance.trkorr} in transport ${(context.runtime.installData.transports.find(o => o.type == transport_1.TrmTransportIdentifier.TADIR)).transport.trkorr}`); trm_commons_1.Logger.error(e.toString(), true); } } if (!noCustomizing) { for (const cust of context.runtime.packageTransports.cust) { try { trm_commons_1.Logger.log(`Including customizing transport ${cust.instance.trkorr}`, true); yield (context.runtime.installData.transports.find(o => o.type == transport_1.TrmTransportIdentifier.CUST)).transport.addObjectsFromTransport(cust.instance.trkorr); } catch (e) { trm_commons_1.Logger.warning(`Failed including customizing transport ${cust.instance.trkorr}`); trm_commons_1.Logger.error(e.toString(), true); } } } var transportsStatus = []; trm_commons_1.Logger.loading(`Releasing install transports...`); for (const transport of context.runtime.installData.transports) { var len; const index = (transportsStatus.push({ type: transport.type, trkorr: transport.transport.trkorr, len: 0, success: false }) - 1); try { yield transport.transport.removeComments(); len = (yield transport.transport.getE071()).length; transportsStatus[index].len = len; if (len === 0) { yield transport.transport.delete(); } else { yield transport.transport.addComment(`name=${context.runtime.remotePackageData.manifest.name}`); yield transport.transport.addComment(`version=${context.runtime.remotePackageData.manifest.version}`); yield transport.transport.setDocumentation(new manifest_1.Manifest(context.runtime.remotePackageData.manifest).getAbapXml()); yield transport.transport.rename(`@X1@TRM: ${context.runtime.remotePackageData.manifest.name} v${context.runtime.remotePackageData.manifest.version} ${transport.type === transport_1.TrmTransportIdentifier.CUST ? '(C)' : ''}`.trim()); yield transport.transport.release(true, true); } transportsStatus[index].success = true; } catch (e) { trm_commons_1.Logger.error(`Error on finalize step of transport ${transport.transport.trkorr}`, true); trm_commons_1.Logger.error(e.toString(), true); transportsStatus[index].success = false; } } transportsStatus.forEach(o => { if (o.success) { if (o.len > 0) { trm_commons_1.Logger.success(`Use ${o.type === transport_1.TrmTransportIdentifier.TADIR ? 'workbench' : 'customizing'} transport ${chalk_1.default.bold(o.trkorr)} in ${systemConnector_1.SystemConnector.getDest()} landscape transports.`); } } else { if (o.len > 0) { trm_commons_1.Logger.error(`Error on release of ${o.type === transport_1.TrmTransportIdentifier.TADIR ? 'workbench' : 'customizing'} transport ${chalk_1.default.bold(o.trkorr)}.`); context.runtime.installData.transports = context.runtime.installData.transports.filter(o => o.transport.trkorr !== o.transport.trkorr); } } }); } catch (e) { trm_commons_1.Logger.error(`An error occurred during install transport generation.`); trm_commons_1.Logger.error(`This error may be ignored.`); trm_commons_1.Logger.error(e.toString(), true); } }) };