9d47c4b779
* wip * Transit byok cli * It works! * changelog * document return codes * Update command/transit_import_key.go Co-authored-by: Steven Clark <steven.clark@hashicorp.com> * make fmt --------- Co-authored-by: Steven Clark <steven.clark@hashicorp.com>
53 lines
1.5 KiB
Go
53 lines
1.5 KiB
Go
package command
|
|
|
|
import (
|
|
"strings"
|
|
|
|
"github.com/mitchellh/cli"
|
|
"github.com/posener/complete"
|
|
)
|
|
|
|
var (
|
|
_ cli.Command = (*TransitImportVersionCommand)(nil)
|
|
_ cli.CommandAutocomplete = (*TransitImportVersionCommand)(nil)
|
|
)
|
|
|
|
type TransitImportVersionCommand struct {
|
|
*BaseCommand
|
|
}
|
|
|
|
func (c *TransitImportVersionCommand) Synopsis() string {
|
|
return "Import key material into a new key version in the Transit or Transform secrets engines."
|
|
}
|
|
|
|
func (c *TransitImportVersionCommand) Help() string {
|
|
helpText := `
|
|
Usage: vault transit import-version PATH KEY
|
|
|
|
Using the Transit or Transform key wrapping system, imports key material from
|
|
the base64 encoded KEY, into a new key whose API path is PATH. To import a new transit/transform key,
|
|
use import. The remaining options after KEY (key=value style) are passed on to the transit/transform create key
|
|
endpoint.
|
|
If your system or device natively supports the RSA AES key wrap mechanism, you should use it directly
|
|
rather than this command.
|
|
` + c.Flags().Help()
|
|
|
|
return strings.TrimSpace(helpText)
|
|
}
|
|
|
|
func (c *TransitImportVersionCommand) Flags() *FlagSets {
|
|
return c.flagSet(FlagSetHTTP | FlagSetOutputField | FlagSetOutputFormat)
|
|
}
|
|
|
|
func (c *TransitImportVersionCommand) AutocompleteArgs() complete.Predictor {
|
|
return nil
|
|
}
|
|
|
|
func (c *TransitImportVersionCommand) AutocompleteFlags() complete.Flags {
|
|
return c.Flags().Completions()
|
|
}
|
|
|
|
func (c *TransitImportVersionCommand) Run(args []string) int {
|
|
return importKey(c.BaseCommand, "import_version", args)
|
|
}
|