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
JavaScript
;
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'
}),
};