trm-core
Version:
TRM (Transport Request Manager) Core
130 lines (129 loc) • 7.46 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 });
exports.generateInstallTransport = void 0;
const logger_1 = require("../../logger");
const commons_1 = require("../../commons");
const systemConnector_1 = require("../../systemConnector");
const transport_1 = require("../../transport");
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 {
logger_1.Logger.log(`Skipping install transport generation (user input)`, true);
return false;
}
}),
run: (context) => __awaiter(void 0, void 0, void 0, function* () {
logger_1.Logger.log('Generate install transport step', true);
try {
if ((0, commons_1.getPackageNamespace)(context.runtime.installData.namespace) === '$') {
logger_1.Logger.warning(`Install transport was not generated because the package contains non-transportable objects.`);
return;
}
logger_1.Logger.loading(`Generating install transport...`);
context.runtime.installData.transport = yield systemConnector_1.SystemConnector.getPackageWorkbenchTransport(context.runtime.remotePackageData.trmPackage);
if (context.runtime.installData.transport) {
logger_1.Logger.log(`Install transport (${context.runtime.installData.transport.trkorr}) already exists, won't create a new one.`, true);
}
else {
context.runtime.installData.transport = yield transport_1.Transport.createWb({
text: `TRM generated transport`,
target: context.rawInput.installData.installTransport.targetSystem || ''
});
logger_1.Logger.log(`Generated transport ${context.runtime.installData.transport.trkorr}`, true);
}
yield context.runtime.installData.transport.addComment(`name=${context.runtime.remotePackageData.trmManifest.name}`);
yield context.runtime.installData.transport.addComment(`version=${context.runtime.remotePackageData.trmManifest.version}`);
yield context.runtime.installData.transport.setDocumentation(context.runtime.remotePackageData.manifest.getAbapXml());
yield context.runtime.installData.transport.rename(`@X1@TRM: ${context.runtime.remotePackageData.trmManifest.name} v${context.runtime.remotePackageData.trmManifest.version}`);
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
};
}));
}
for (const tadir of tadirObjects) {
try {
try {
logger_1.Logger.log(`Adding object ${tadir.pgmid} ${tadir.object} ${tadir.objName} with lock`, true);
yield context.runtime.installData.transport.addObjects([tadir], true);
}
catch (e) {
logger_1.Logger.log(`Failed, adding object ${tadir.pgmid} ${tadir.object} ${tadir.objName} without lock`, true);
yield context.runtime.installData.transport.addObjects([tadir], false);
}
}
catch (e) {
logger_1.Logger.error(`Failed adding object ${tadir.pgmid} ${tadir.object} ${tadir.objName}`, true);
logger_1.Logger.error(e.toString(), true);
}
}
if (context.runtime.packageTransports.lang.instance) {
try {
logger_1.Logger.log(`Including language transport ${context.runtime.packageTransports.lang.instance.trkorr}`, true);
yield context.runtime.installData.transport.addObjectsFromTransport(context.runtime.packageTransports.lang.instance.trkorr);
}
catch (e) {
logger_1.Logger.error(`Failed including language transport ${context.runtime.packageTransports.lang.instance.trkorr}`, true);
logger_1.Logger.error(e.toString(), true);
}
}
if (context.runtime.packageTransports.cust.instance) {
try {
logger_1.Logger.log(`Including customizing transport ${context.runtime.packageTransports.cust.instance.trkorr}`, true);
yield context.runtime.installData.transport.addObjectsFromTransport(context.runtime.packageTransports.cust.instance.trkorr);
}
catch (e) {
logger_1.Logger.error(`Failed including customizing transport ${context.runtime.packageTransports.cust.instance.trkorr}`, true);
logger_1.Logger.error(e.toString(), true);
}
}
if (context.runtime.installData.namespace[0] === '/') {
logger_1.Logger.log(`Adding namespace ${context.runtime.installData.namespace} without lock`, true);
try {
yield context.runtime.installData.transport.addObjects([{
pgmid: 'R3TR',
object: 'NSPC',
objName: context.runtime.installData.namespace
}], false);
}
catch (e) {
logger_1.Logger.error(`Failed adding namespace ${context.runtime.installData.namespace}`, true);
logger_1.Logger.error(e.toString(), true);
}
}
logger_1.Logger.success(`Use ${context.runtime.installData.transport.trkorr} for transports in your landscape.`);
}
catch (e) {
logger_1.Logger.error(`An error occurred during install transport generation.`);
logger_1.Logger.error(e.toString(), true);
}
})
};