UNPKG

cli-stash

Version:

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

45 lines (44 loc) 1.82 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"); class Update 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 { await connector.admin.permissions().users().update(this.flags.name, this.flags.permission); response.status = 0; response.message = this.getRecordUpdatedText('User Permissions'); this.ux.log(response.message); } catch (error) { this.processError(response, error); } return response; } } exports.default = Update; Update.description = 'Promote or demote the global permission level of a user.'; Update.examples = [ `$ stash admin:permissions:users:update -a MyStashAlias --name Username --permission 'ADMIN' --json`, `$ stash admin:permissions:users:update -a MyStashAlias --name OtherUser --permission PROJECT_CREATE`, ]; Update.flags = { ...baseCommand_1.BaseCommand.flags, alias: baseCommand_1.BuildFlags.alias, name: core_1.Flags.string({ description: 'The name of the user', required: true, name: 'Name' }), permission: core_1.Flags.string({ description: 'The permission to grant', type: "option", options: ['LICENSED_USER', 'PROJECT_CREATE', 'ADMIN', 'SYS_ADMIN'], required: true, name: 'Permission' }), };