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) }