@broadcom/endevor-bridge-for-git-for-zowe-cli
Version:
Endevor Bridge for Git plug-in for Zowe CLI
146 lines • 8.67 kB
JavaScript
;
/*
* Copyright (c) 2019 Broadcom. All Rights Reserved. The term
* "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
*
* This software and all information contained therein is
* confidential and proprietary and shall not be duplicated,
* used, disclosed, or disseminated in any way except as
* authorized by the applicable license agreement, without the
* express written permission of Broadcom. All authorized
* reproductions must be marked with this language.
*
* EXCEPT AS SET FORTH IN THE APPLICABLE LICENSE AGREEMENT, TO
* THE EXTENT PERMITTED BY APPLICABLE LAW, BROADCOM PROVIDES THIS
* SOFTWARE WITHOUT WARRANTY OF ANY KIND, INCLUDING WITHOUT
* LIMITATION, ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR
* FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT WILL BROADCOM
* BE LIABLE TO THE END USER OR ANY THIRD PARTY FOR ANY LOSS OR
* DAMAGE, DIRECT OR INDIRECT, FROM THE USE OF THIS SOFTWARE,
* INCLUDING WITHOUT LIMITATION, LOST PROFITS, BUSINESS
* INTERRUPTION, GOODWILL, OR LOST DATA, EVEN IF BROADCOM IS
* EXPRESSLY ADVISED OF SUCH LOSS OR DAMAGE.
*/
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 BaseHandler_1 = require("../../BaseHandler");
const api_1 = require("../../../api");
const imperative_1 = require("@zowe/imperative");
const object_1 = require("../../../utils/object");
const ProcessorGroupOptions_1 = require("../ProcessorGroupOptions");
const EBGOptions_1 = require("../../options/EBGOptions");
const BridgeMetadataUtils_1 = require("../../../api/utils/BridgeMetadataUtils");
const child_process_1 = require("child_process");
class ProcessorGroupUpdateAllHandler extends BaseHandler_1.BaseHandler {
processWithSession() {
return __awaiter(this, void 0, void 0, function* () {
const workDir = this.getOption(EBGOptions_1.EBGOptions.WORK_DIRECTORY);
const newProcGroup = this.getOption(ProcessorGroupOptions_1.ProcessorGroupOptions.PROCESSOR_GROUP, true);
let system = this.getOption(ProcessorGroupOptions_1.ProcessorGroupOptions.ENDEVOR_SYSTEM, false);
let subsystem = this.getOption(ProcessorGroupOptions_1.ProcessorGroupOptions.ENDEVOR_SUBSYSTEM, false);
const type = this.getOption(ProcessorGroupOptions_1.ProcessorGroupOptions.TYPE, true);
this.validateRequiredOptions();
const mappingMetadata = api_1.BuildUtils.readMappingMetadata(workDir);
const branchMetadata = api_1.MappingMetadata.getSynchronizedBranch(mappingMetadata);
if (api_1.MappingMetadata.isMultiSystem(branchMetadata) && ((0, object_1.isNil)(system) || (0, object_1.isNil)(subsystem))) {
throw new imperative_1.ImperativeError({
msg: `You must specify system/subsystem for multi system/subsystem mappings`,
});
}
if ((0, object_1.isNil)(system)) {
system = branchMetadata.systems[0];
system = (0, object_1.isNil)(system.alias) ? system.name : system.alias;
}
if ((0, object_1.isNil)(subsystem)) {
subsystem = branchMetadata.systems[0].subsystems[0];
subsystem = (0, object_1.isNil)(subsystem.alias) ? subsystem.name : subsystem.alias;
}
const bridgeMetadata = BridgeMetadataUtils_1.BridgeMetadataUtils.readBridgeMetadataFile(workDir, system, subsystem, type);
const definedProcGroups = bridgeMetadata.definedProcessorGroups;
const fileExt = bridgeMetadata.fileExtension.trim();
if (definedProcGroups.filter(pg => pg.name === newProcGroup).length < 1) {
throw new imperative_1.ImperativeError({
msg: `Processor Group '${newProcGroup}' is not a valid processor group`
});
}
let changed;
let untracked;
try {
changed = (((0, child_process_1.execSync)("git diff --name-status origin/" + branchMetadata.name, { cwd: workDir }).toString()).split(/\r?\n/)).filter(String);
untracked = (((0, child_process_1.execSync)("git ls-files --others --exclude-standard", { cwd: workDir }).toString()).split(/\r?\n/)).filter(String);
}
catch (err) {
throw new imperative_1.ImperativeError({
msg: `Error getting changed elements: ${err}`,
});
}
const modifiedElements = [];
const exemptions = [api_1.EBGConstants.GITKEEP_FILENAME, api_1.EBGConstants.GITIGNORE_FILENAME, api_1.EBGConstants.BRIDGE_METATDATA_FILENAME];
changed.filter(change => !exemptions.some(e => change.includes(e))).forEach(entry => {
// example changed:
// M ESCM180/XUEYU010/ISPM/LOCK2
// R100 ESCM180/XUEYU010/ISPM/TESTADD2 ESCM180/XUEYU010/ISPM/REN
// A ESCM180/XUEYU010/ISPM/test
const items = entry.split(/\s+/);
if (items.length <= 1) {
return;
}
let matchResult;
if ((items[0].startsWith("A") || items[0].startsWith("M")) && items.length === 2) {
matchResult = api_1.ChangeValidator.validateAndGetPathComponents(items[1], mappingMetadata);
}
// tslint:disable-next-line:no-magic-numbers
if (items[0].startsWith("R") && items.length === 3) {
matchResult = api_1.ChangeValidator.validateAndGetPathComponents(items[2], mappingMetadata);
}
if ((0, object_1.isNotNil)(matchResult) && matchResult[api_1.EBGConstants.TYPE_DIR_INDEX].toUpperCase() === type.toUpperCase()) {
let elementName = matchResult[api_1.EBGConstants.ELEMENT_NAME_INDEX];
// remove file extension
if ((0, object_1.isNotNil)(fileExt) && fileExt !== "") {
elementName = elementName.substr(0, elementName.lastIndexOf("."));
}
modifiedElements.push(elementName);
}
});
untracked.filter(v => !exemptions.some(e => v.includes(e))).forEach(entry => {
// example untracked:
// ESCM180/XUEYU010/ISPM/NEW
const matchResult = api_1.ChangeValidator.validateAndGetPathComponents(entry, mappingMetadata);
if ((0, object_1.isNotNil)(matchResult) && matchResult[api_1.EBGConstants.TYPE_DIR_INDEX].toUpperCase() === type.toUpperCase()) {
let elementName = matchResult[api_1.EBGConstants.ELEMENT_NAME_INDEX];
// remove file extension
if ((0, object_1.isNotNil)(fileExt) && fileExt !== "") {
elementName = elementName.substr(0, elementName.lastIndexOf("."));
}
modifiedElements.push(elementName);
}
});
if (modifiedElements.length < 1) {
throw new imperative_1.ImperativeError({
msg: `There are not any changed elements of type '${type}' `
});
}
const elements = bridgeMetadata.elements;
for (const ele of modifiedElements) {
if (elements.hasOwnProperty(ele)) {
elements[ele].processorGroup = newProcGroup;
}
else {
elements[ele] = { processorGroup: newProcGroup };
}
}
BridgeMetadataUtils_1.BridgeMetadataUtils.updateBridgeMetadataFile(workDir, system, subsystem, type, bridgeMetadata);
this.console.log("Processor Group of changed elements of type '" + type + "' was updated");
});
}
}
exports.default = ProcessorGroupUpdateAllHandler;
//# sourceMappingURL=ProcessorGroupUpdateAll.handler.js.map