UNPKG

@zowe/cli

Version:

Zowe CLI is a command line interface (CLI) that provides a simple and streamlined way to interact with IBM z/OS.

82 lines 3.97 kB
"use strict"; /* * This program and the accompanying materials are made available under the terms of the * Eclipse Public License v2.0 which accompanies this distribution, and is available at * https://www.eclipse.org/legal/epl-v20.html * * SPDX-License-Identifier: EPL-2.0 * * Copyright Contributors to the Zowe Project. * */ 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.ZosFilesBaseHandler = void 0; const imperative_1 = require("@zowe/imperative"); const zosmf_for_zowe_sdk_1 = require("@zowe/zosmf-for-zowe-sdk"); /** * This class is used by the various zosfiles handlers as the base class for their implementation. * All handlers within zosfiles should extend this class. * * This class should not be used outside of the zosfiles package. * * @private */ class ZosFilesBaseHandler { /** * This will grab the zosmf profile and create a session before calling the subclass * {@link ZosFilesBaseHandler#processWithSession} method. * * @param {IHandlerParameters} commandParameters Command parameters sent by imperative. * * @returns {Promise<void>} */ process(commandParameters) { return __awaiter(this, void 0, void 0, function* () { try { const sessCfg = zosmf_for_zowe_sdk_1.ZosmfSession.createSessCfgFromArgs(commandParameters.arguments); const sessCfgWithCreds = yield imperative_1.ConnectionPropsForSessCfg.addPropsOrPrompt(sessCfg, commandParameters.arguments, { parms: commandParameters }); const session = new imperative_1.Session(sessCfgWithCreds); const response = yield this.processWithSession(commandParameters, session); commandParameters.response.progress.endBar(); if (response.commandResponse) { commandParameters.response.console.log(response.commandResponse); } // Return as an object when using --response-format-json commandParameters.response.data.setObj(response); // Ensure error gets thrown if request was unsuccessful. // Sometimes it is useful to delay throwing an error until the end of the handler is // reached, for example the upload API needs to return an API response even when it fails. if (!response.success && response.commandResponse) { throw new imperative_1.ImperativeError({ msg: response.errorMessage || response.commandResponse }); } } catch (error) { if (commandParameters.arguments.ignoreNotFound && error.errorCode == '404') { commandParameters.response.data.setObj({ success: true }); } else { if (error instanceof imperative_1.ImperativeError) { throw error; } throw new imperative_1.ImperativeError({ msg: error.message, causeErrors: error }); } } }); } } exports.ZosFilesBaseHandler = ZosFilesBaseHandler; //# sourceMappingURL=ZosFilesBase.handler.js.map