@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
JavaScript
;
/*
* 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