cosmos-sdk/server/tm_cmds.go

108 lines
2.8 KiB
Go
Raw Normal View History

2018-04-05 03:31:33 -07:00
package server
import (
"fmt"
2018-04-21 22:32:47 -07:00
"github.com/cosmos/cosmos-sdk/wire"
2018-04-05 03:31:33 -07:00
"github.com/spf13/cobra"
"github.com/spf13/viper"
2018-04-05 03:31:33 -07:00
"github.com/cosmos/cosmos-sdk/client"
sdk "github.com/cosmos/cosmos-sdk/types"
2018-04-05 03:31:33 -07:00
tcmd "github.com/tendermint/tendermint/cmd/tendermint/commands"
"github.com/tendermint/tendermint/p2p"
2018-06-05 18:04:16 -07:00
pvm "github.com/tendermint/tendermint/privval"
2018-04-05 03:31:33 -07:00
)
// ShowNodeIDCmd - ported from Tendermint, dump node ID to stdout
func ShowNodeIDCmd(ctx *Context) *cobra.Command {
return &cobra.Command{
Use: "show-node-id",
2018-04-05 03:31:33 -07:00
Short: "Show this node's ID",
RunE: func(cmd *cobra.Command, args []string) error {
cfg := ctx.Config
nodeKey, err := p2p.LoadOrGenNodeKey(cfg.NodeKeyFile())
if err != nil {
return err
}
fmt.Println(nodeKey.ID())
return nil
},
2018-04-05 03:31:33 -07:00
}
}
// ShowValidator - ported from Tendermint, show this node's validator info
func ShowValidatorCmd(ctx *Context) *cobra.Command {
cmd := cobra.Command{
Use: "show-validator",
2018-04-25 21:27:40 -07:00
Short: "Show this node's tendermint validator info",
RunE: func(cmd *cobra.Command, args []string) error {
2018-04-05 03:31:33 -07:00
cfg := ctx.Config
privValidator := pvm.LoadOrGenFilePV(cfg.PrivValidatorFile())
valPubKey := privValidator.PubKey
2018-04-05 03:31:33 -07:00
if viper.GetBool(client.FlagJson) {
return printlnJSON(valPubKey)
}
pubkey, err := sdk.Bech32ifyConsPub(valPubKey)
if err != nil {
return err
}
2018-06-01 07:23:58 -07:00
fmt.Println(pubkey)
return nil
},
2018-04-05 03:31:33 -07:00
}
cmd.Flags().Bool(client.FlagJson, false, "get machine parseable output")
return &cmd
2018-04-05 03:31:33 -07:00
}
// ShowAddressCmd - show this node's validator address
func ShowAddressCmd(ctx *Context) *cobra.Command {
cmd := &cobra.Command{
Use: "show-address",
Short: "Shows this node's tendermint validator address",
RunE: func(cmd *cobra.Command, args []string) error {
cfg := ctx.Config
privValidator := pvm.LoadOrGenFilePV(cfg.PrivValidatorFile())
valAddr := (sdk.ValAddress)(privValidator.Address)
if viper.GetBool(client.FlagJson) {
return printlnJSON(valAddr)
}
fmt.Println(valAddr.String())
return nil
},
}
cmd.Flags().Bool(client.FlagJson, false, "get machine parseable output")
return cmd
}
func printlnJSON(v interface{}) error {
cdc := wire.NewCodec()
wire.RegisterCrypto(cdc)
marshalled, err := cdc.MarshalJSON(v)
if err != nil {
return err
}
fmt.Println(string(marshalled))
return nil
}
2018-04-05 03:31:33 -07:00
// UnsafeResetAllCmd - extension of the tendermint command, resets initialization
func UnsafeResetAllCmd(ctx *Context) *cobra.Command {
return &cobra.Command{
Use: "unsafe-reset-all",
Short: "Resets the blockchain database, removes address book files, and resets priv_validator.json to the genesis state",
RunE: func(cmd *cobra.Command, args []string) error {
cfg := ctx.Config
2018-06-29 14:52:00 -07:00
tcmd.ResetAll(cfg.DBDir(), cfg.P2P.AddrBookFile(), cfg.PrivValidatorFile(), ctx.Logger)
return nil
},
2018-04-05 03:31:33 -07:00
}
}