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.

100 lines 5.39 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 }); const imperative_1 = require("@zowe/imperative"); const util_1 = require("util"); const rest_1 = require("../../../../../rest"); const ZosFiles_constants_1 = require("../../constants/ZosFiles.constants"); const ZosFiles_messages_1 = require("../../constants/ZosFiles.messages"); /** * This class holds helper functions that are used to mount file systems through the z/OS MF APIs */ class Mount { /** * Mount a Unix file system * * @param {AbstractSession} session - z/OS MF connection info * @param {string} fileSystemName - contains the file system name * @param {string} mountPoint - contains the mount point * @param {IListOptions} [options={}] - contains the options to be sent * * @returns {Promise<IZosFilesResponse>} A response indicating the outcome of the API * * @throws {ImperativeError} file system name must be set * @throws {Error} When the {@link ZosmfRestClient} throws an error * * @see https://www.ibm.com/support/knowledgecenter/SSLTBW_2.1.0/com.ibm.zos.v2r1.izua700/IZUHPINFO_API_MountUnixFile.htm */ static fs(session, fileSystemName, mountPoint, options) { return __awaiter(this, void 0, void 0, function* () { // We require the file system name and mount point imperative_1.ImperativeExpect.toBeDefinedAndNonBlank(fileSystemName, ZosFiles_messages_1.ZosFilesMessages.missingFileSystemName.message); imperative_1.ImperativeExpect.toBeDefinedAndNonBlank(mountPoint, ZosFiles_messages_1.ZosFilesMessages.missingMountPoint.message); // Removes undefined properties const tempOptions = !util_1.isNullOrUndefined(options) ? JSON.parse(JSON.stringify(options)) : {}; this.fsValidateOptions(tempOptions); tempOptions.action = "mount"; tempOptions["mount-point"] = mountPoint; const endpoint = ZosFiles_constants_1.ZosFilesConstants.RESOURCE + ZosFiles_constants_1.ZosFilesConstants.RES_MFS + "/" + fileSystemName; const jsonContent = JSON.stringify(tempOptions); const headers = [{ "Content-Length": jsonContent.length }]; const data = yield rest_1.ZosmfRestClient.putExpectString(session, endpoint, headers, jsonContent); return { success: true, commandResponse: ZosFiles_messages_1.ZosFilesMessages.fsMountedSuccessfully.message, apiResponse: data }; }); } /** * Validate the options for the command to mount a z/OS file system * @param options - options for the mounting of the file system */ static fsValidateOptions(options) { imperative_1.ImperativeExpect.toNotBeNullOrUndefined(options, ZosFiles_messages_1.ZosFilesMessages.missingFilesMountOptions.message); /* If our caller does not supply these options, we supply default values for them, * so they should exist at this point. */ imperative_1.ImperativeExpect.toBeDefinedAndNonBlank(options["fs-type"], ZosFiles_messages_1.ZosFilesMessages.missingFsOption.message + "fs-type"); imperative_1.ImperativeExpect.toBeDefinedAndNonBlank(options.mode, ZosFiles_messages_1.ZosFilesMessages.missingFsOption.message + "mode"); // validate specific options for (const option in options) { if (options.hasOwnProperty(option)) { switch (option) { case "mode": if ((options.mode !== "rdonly") && (options.mode !== "rdwr")) { throw new imperative_1.ImperativeError({ msg: ZosFiles_messages_1.ZosFilesMessages.invalidMountModeOption.message + options.mode }); } break; case "fs-type": // no validation at this time break; default: throw new imperative_1.ImperativeError({ msg: ZosFiles_messages_1.ZosFilesMessages.invalidFilesMountOption.message + option }); } // end switch } } // end for } } exports.Mount = Mount; //# sourceMappingURL=Mount.js.map