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.9 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 tables_1 = require("../../../libs/core/tables"); const ux_1 = require("../../../libs/core/ux"); class Delete 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 group = await connector.admin.groups().delete(this.flags.name); response.result = group; response.status = 0; response.message = this.getRecordDeletedText('Group'); this.ux.log(response.message); this.ux.table([group], tables_1.GroupColumns, { csv: this.flags.csv }); } catch (error) { this.processError(response, error); } return response; } } exports.default = Delete; Delete.description = 'Deletes the specified group, removing them from the system. This also removes any permissions that may have been granted to the group. ' + ux_1.UX.processDocumentation('<doc:Group>'); Delete.examples = [ `$ stash admin:groups:delete -a MyStashAlias --name MyGroup --json`, `$ stash admin:groups:delete -a MyStashAlias --name AnotherGroup --csv`, ]; Delete.flags = { ...baseCommand_1.BaseCommand.flags, csv: baseCommand_1.BuildFlags.csv, alias: baseCommand_1.BuildFlags.alias, name: core_1.Flags.string({ description: 'Name of the group to delete', required: true, name: 'Name' }), };