UNPKG

@broadcom/endevor-bridge-for-git-for-zowe-cli

Version:

Endevor Bridge for Git plug-in for Zowe CLI

91 lines 5.45 kB
"use strict"; /* * 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"); class ProcessorGroupUpdateHandler extends BaseHandler_1.BaseHandler { processWithSession() { return __awaiter(this, void 0, void 0, function* () { const workDir = this.getOption(EBGOptions_1.EBGOptions.WORK_DIRECTORY); let element = this.getOption(ProcessorGroupOptions_1.ProcessorGroupOptions.ELEMENT, true); 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; // if element is passed with a its file extension remove it const fileExt = bridgeMetadata.fileExtension.trim(); if ((0, object_1.isNotNil)(fileExt) && fileExt !== "" && element.includes(".")) { element = element.substr(0, element.lastIndexOf(".")); } if (definedProcGroups.filter(pg => pg.name === newProcGroup).length < 1) { throw new imperative_1.ImperativeError({ msg: `Processor Group '${newProcGroup}' is not a valid processor group` }); } const elements = bridgeMetadata.elements; if (!elements.hasOwnProperty(element)) { elements[element] = { processorGroup: newProcGroup }; } else { elements[element].processorGroup = newProcGroup; } BridgeMetadataUtils_1.BridgeMetadataUtils.updateBridgeMetadataFile(workDir, system, subsystem, type, bridgeMetadata); this.console.log("Processor Group of element " + element + " was updated"); }); } } exports.default = ProcessorGroupUpdateHandler; //# sourceMappingURL=ProcessorGroupUpdate.handler.js.map