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