UNPKG

balena-cli

Version:

The official balena Command Line Interface

76 lines (71 loc) 2.77 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const core_1 = require("@oclif/core"); const cf = require("../../utils/common-flags"); const lazy_1 = require("../../utils/lazy"); const messages_1 = require("../../utils/messages"); class TagRmCmd extends core_1.Command { async run() { const { args: params, flags: options } = await this.parse(TagRmCmd); const balena = (0, lazy_1.getBalenaSdk)(); if (!options.fleet && !options.device && !options.release) { const { ExpectedError } = await Promise.resolve().then(() => require('../../errors')); throw new ExpectedError(TagRmCmd.missingResourceMessage); } if (options.fleet) { const { getFleetSlug } = await Promise.resolve().then(() => require('../../utils/sdk')); return balena.models.application.tags.remove(await getFleetSlug(balena, options.fleet), params.tagKey); } if (options.device) { return balena.models.device.tags.remove(options.device, params.tagKey); } if (options.release) { const { disambiguateReleaseParam } = await Promise.resolve().then(() => require('../../utils/normalization')); const releaseParam = await disambiguateReleaseParam(balena, options.release); return balena.models.release.tags.remove(releaseParam, params.tagKey); } } } TagRmCmd.description = (0, lazy_1.stripIndent) ` Remove a tag from a fleet, device or release. Remove a tag from a fleet, device or release. ${messages_1.applicationIdInfo.split('\n').join('\n\t\t')} `; TagRmCmd.examples = [ '$ balena tag rm myTagKey --fleet MyFleet', '$ balena tag rm myTagKey -f myorg/myfleet', '$ balena tag rm myTagKey --device 7cf02a6', '$ balena tag rm myTagKey --release 1234', '$ balena tag rm myTagKey --release b376b0e544e9429483b656490e5b9443b4349bd6', ]; TagRmCmd.args = { tagKey: core_1.Args.string({ description: 'the key string of the tag', required: true, }), }; TagRmCmd.flags = { fleet: { ...cf.fleet, exclusive: ['device', 'release'], }, device: { ...cf.device, exclusive: ['fleet', 'release'], }, release: { ...cf.release, exclusive: ['fleet', 'device'], }, }; TagRmCmd.authenticated = true; TagRmCmd.missingResourceMessage = (0, lazy_1.stripIndent) ` To remove a resource tag, you must provide exactly one of: * A fleet, with --fleet <fleetNameOrSlug> * A device, with --device <UUID> * A release, with --release <ID or commit> See the help page for examples: $ balena help tag rm `; exports.default = TagRmCmd; //# sourceMappingURL=rm.js.map