UNPKG

cli-stash

Version:

CLI application to manage and work with Atlassian Stash. Work with your Stash project and repositories from Command lines.

54 lines (53 loc) 2.15 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const core_1 = require("@oclif/core"); const stash_connector_1 = require("stash-connector"); const baseCommand_1 = require("../../../libs/core/baseCommand"); const stashResponse_1 = require("../../../libs/core/stashResponse"); const utils_1 = require("../../../libs/utils/utils"); class Get extends baseCommand_1.BaseCommand { async run() { const response = new stashResponse_1.StashCLIResponse(); const connector = new stash_connector_1.StashConnector(this.localConfig.getConnectorOptions(this.flags.alias)); try { const settings = await connector.users.settings(this.flags.slug).get(); response.result = settings; response.status = 0; response.message = this.getRecordRetrievedText('User Settings'); this.ux.log(response.message); const columns = {}; if (utils_1.Utils.hasKeys(settings)) { for (const key of Object.keys(settings)) { columns[key] = { header: key, }; } } this.ux.table([settings], columns, { csv: this.flags.csv, extended: this.flags.extended || this.flags.csv }); } catch (error) { this.processError(response, error); } return response; } } exports.default = Get; Get.description = 'Rest resource for retrieving, and updating user settings key/values.'; Get.examples = [ `$ stash users:settings:get -a MyStashAlias --slug "userslug" --json`, `$ stash users:settings:get -a MyStashAlias --slug "userslug" --csv`, `$ stash users:settings:get -a MyStashAlias --slug "userslug"`, ]; Get.flags = { ...baseCommand_1.BaseCommand.flags, csv: baseCommand_1.BuildFlags.csv, alias: baseCommand_1.BuildFlags.alias, slug: core_1.Flags.string({ description: 'The user slug to retrieve settings', required: true, name: 'User Slug' }), };