Small non-breaking UX changes to keys {list,delete} commands (#5366)
Add --list-names flag to keys command for short listing. Make keys delete accept multiple key names at once. Usage example: gaiacli keys list -n | xargs gaiacli keys delete
This commit is contained in:
parent
722a633f54
commit
0300a6f6d7
|
@ -106,6 +106,9 @@ upgrade via: `sudo rm -rf /Library/Developer/CommandLineTools; xcode-select --in
|
||||||
correct version via: `pkgutil --pkg-info=com.apple.pkg.CLTools_Executables`.
|
correct version via: `pkgutil --pkg-info=com.apple.pkg.CLTools_Executables`.
|
||||||
* (keys) [\#5097](https://github.com/cosmos/cosmos-sdk/pull/5097) New `keys migrate` command to assist users migrate their keys
|
* (keys) [\#5097](https://github.com/cosmos/cosmos-sdk/pull/5097) New `keys migrate` command to assist users migrate their keys
|
||||||
to the new keyring.
|
to the new keyring.
|
||||||
|
* (keys) [\#5366](https://github.com/cosmos/cosmos-sdk/pull/5366) `keys list` now accepts a `--list-names` option to list key names only, whilst the `keys delete`
|
||||||
|
command can delete multiple keys by passing their names as arguments. The aforementioned commands can then be piped together, e.g.
|
||||||
|
`appcli keys list -n | xargs appcli keys delete`
|
||||||
* (modules) [\#4233](https://github.com/cosmos/cosmos-sdk/pull/4233) Add upgrade module that coordinates software upgrades of live chains.
|
* (modules) [\#4233](https://github.com/cosmos/cosmos-sdk/pull/4233) Add upgrade module that coordinates software upgrades of live chains.
|
||||||
* [\#4486](https://github.com/cosmos/cosmos-sdk/issues/4486) Introduce new `PeriodicVestingAccount` vesting account type
|
* [\#4486](https://github.com/cosmos/cosmos-sdk/issues/4486) Introduce new `PeriodicVestingAccount` vesting account type
|
||||||
that allows for arbitrary vesting periods.
|
that allows for arbitrary vesting periods.
|
||||||
|
|
|
@ -18,27 +18,26 @@ const (
|
||||||
|
|
||||||
func deleteKeyCommand() *cobra.Command {
|
func deleteKeyCommand() *cobra.Command {
|
||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "delete <name>",
|
Use: "delete <name>...",
|
||||||
Short: "Delete the given key",
|
Short: "Delete the given keys",
|
||||||
Long: `Delete a key from the store.
|
Long: `Delete keys from the Keybase backend.
|
||||||
|
|
||||||
Note that removing offline or ledger keys will remove
|
Note that removing offline or ledger keys will remove
|
||||||
only the public key references stored locally, i.e.
|
only the public key references stored locally, i.e.
|
||||||
private keys stored in a ledger device cannot be deleted with the CLI.
|
private keys stored in a ledger device cannot be deleted with the CLI.
|
||||||
`,
|
`,
|
||||||
RunE: runDeleteCmd,
|
RunE: runDeleteCmd,
|
||||||
Args: cobra.ExactArgs(1),
|
Args: cobra.MinimumNArgs(1),
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd.Flags().BoolP(flagYes, "y", false,
|
cmd.Flags().BoolP(flagYes, "y", false,
|
||||||
"Skip confirmation prompt when deleting offline or ledger key references")
|
"Skip confirmation prompt when deleting offline or ledger key references")
|
||||||
cmd.Flags().BoolP(flagForce, "f", false,
|
cmd.Flags().BoolP(flagForce, "f", false,
|
||||||
"Remove the key unconditionally without asking for the passphrase")
|
"Remove the key unconditionally without asking for the passphrase. Deprecated.")
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
func runDeleteCmd(cmd *cobra.Command, args []string) error {
|
func runDeleteCmd(cmd *cobra.Command, args []string) error {
|
||||||
name := args[0]
|
|
||||||
buf := bufio.NewReader(cmd.InOrStdin())
|
buf := bufio.NewReader(cmd.InOrStdin())
|
||||||
|
|
||||||
kb, err := NewKeyringFromHomeFlag(buf)
|
kb, err := NewKeyringFromHomeFlag(buf)
|
||||||
|
@ -46,31 +45,34 @@ func runDeleteCmd(cmd *cobra.Command, args []string) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
info, err := kb.Get(name)
|
for _, name := range args {
|
||||||
if err != nil {
|
info, err := kb.Get(name)
|
||||||
return err
|
if err != nil {
|
||||||
}
|
return err
|
||||||
|
|
||||||
if info.GetType() == keys.TypeLedger || info.GetType() == keys.TypeOffline {
|
|
||||||
// confirm deletion, unless -y is passed
|
|
||||||
if !viper.GetBool(flagYes) {
|
|
||||||
if err := confirmDeletion(buf); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if info.GetType() == keys.TypeLedger || info.GetType() == keys.TypeOffline {
|
||||||
|
// confirm deletion, unless -y is passed
|
||||||
|
if !viper.GetBool(flagYes) {
|
||||||
|
if err := confirmDeletion(buf); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := kb.Delete(name, "", true); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
cmd.PrintErrln("Public key reference deleted")
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// old password and skip flag arguments are ignored
|
||||||
if err := kb.Delete(name, "", true); err != nil {
|
if err := kb.Delete(name, "", true); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
cmd.PrintErrln("Public key reference deleted")
|
cmd.PrintErrln("Key deleted forever (uh oh!)")
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// old password and skip flag arguments are ignored
|
|
||||||
if err := kb.Delete(name, "", true); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
cmd.PrintErrln("Key deleted forever (uh oh!)")
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,10 +2,13 @@ package keys
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
|
"github.com/spf13/viper"
|
||||||
|
|
||||||
"github.com/cosmos/cosmos-sdk/client/flags"
|
"github.com/cosmos/cosmos-sdk/client/flags"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const flagListNames = "list-names"
|
||||||
|
|
||||||
func listKeysCmd() *cobra.Command {
|
func listKeysCmd() *cobra.Command {
|
||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "list",
|
Use: "list",
|
||||||
|
@ -15,18 +18,30 @@ along with their associated name and address.`,
|
||||||
RunE: runListCmd,
|
RunE: runListCmd,
|
||||||
}
|
}
|
||||||
cmd.Flags().Bool(flags.FlagIndentResponse, false, "Add indent to JSON response")
|
cmd.Flags().Bool(flags.FlagIndentResponse, false, "Add indent to JSON response")
|
||||||
|
cmd.Flags().BoolP(flagListNames, "n", false, "List names only")
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
func runListCmd(cmd *cobra.Command, args []string) error {
|
func runListCmd(cmd *cobra.Command, _ []string) error {
|
||||||
kb, err := NewKeyringFromHomeFlag(cmd.InOrStdin())
|
kb, err := NewKeyringFromHomeFlag(cmd.InOrStdin())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
infos, err := kb.List()
|
infos, err := kb.List()
|
||||||
if err == nil {
|
if err != nil {
|
||||||
printInfos(infos)
|
return err
|
||||||
}
|
}
|
||||||
return err
|
|
||||||
|
if !viper.GetBool(flagListNames) {
|
||||||
|
printInfos(infos)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd.SetOut(cmd.OutOrStdout())
|
||||||
|
for _, info := range infos {
|
||||||
|
cmd.Println(info.GetName())
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,10 +57,19 @@ func Test_runListCmd(t *testing.T) {
|
||||||
if runningUnattended {
|
if runningUnattended {
|
||||||
mockIn.Reset("testpass1\ntestpass1\n")
|
mockIn.Reset("testpass1\ntestpass1\n")
|
||||||
}
|
}
|
||||||
|
viper.Set(flagListNames, false)
|
||||||
viper.Set(flags.FlagHome, tt.kbDir)
|
viper.Set(flags.FlagHome, tt.kbDir)
|
||||||
if err := runListCmd(tt.args.cmd, tt.args.args); (err != nil) != tt.wantErr {
|
if err := runListCmd(tt.args.cmd, tt.args.args); (err != nil) != tt.wantErr {
|
||||||
t.Errorf("runListCmd() error = %v, wantErr %v", err, tt.wantErr)
|
t.Errorf("runListCmd() error = %v, wantErr %v", err, tt.wantErr)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if runningUnattended {
|
||||||
|
mockIn.Reset("testpass1\ntestpass1\n")
|
||||||
|
}
|
||||||
|
viper.Set(flagListNames, true)
|
||||||
|
if err := runListCmd(tt.args.cmd, tt.args.args); (err != nil) != tt.wantErr {
|
||||||
|
t.Errorf("runListCmd() error = %v, wantErr %v", err, tt.wantErr)
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue