trm-core
Version:
TRM (Transport Request Manager) Core
179 lines (178 loc) • 10.6 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());
});
};
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);
}
})
};