* Refactor CliContext as Context
* Fix lint issues
* Fix goimports
* Fix gov tests
* Resolved ci-lint issues
* Add changelog
* Rename cliCtx to clientCtx
* Fix mocks and routes
* Add changelog
* Update changelog
* Apply suggestions from code review
Co-authored-by: Alessio Treglia <alessio@tendermint.com>
* merge client/rpc/ro{ot,utes}.go
* Update docs
* client/rpc: remove redundant client/rpc.RegisterRPCRoutes
* regenerate mocks
* Update ADRs
Co-authored-by: Alessio Treglia <alessio@tendermint.com>
Co-authored-by: Federico Kunze <31522760+fedekunze@users.noreply.github.com>
Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
175 lines
5.0 KiB
Go
175 lines
5.0 KiB
Go
package cli
|
|
|
|
import (
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/cosmos/cosmos-sdk/client/tx"
|
|
gov "github.com/cosmos/cosmos-sdk/x/gov/types"
|
|
|
|
"github.com/cosmos/cosmos-sdk/x/gov/client/cli"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
"github.com/cosmos/cosmos-sdk/client"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
"github.com/cosmos/cosmos-sdk/x/upgrade/types"
|
|
)
|
|
|
|
const (
|
|
// TimeFormat specifies ISO UTC format for submitting the time for a new upgrade proposal
|
|
TimeFormat = "2006-01-02T15:04:05Z"
|
|
|
|
FlagUpgradeHeight = "upgrade-height"
|
|
FlagUpgradeTime = "time"
|
|
FlagUpgradeInfo = "info"
|
|
)
|
|
|
|
// NewCmdSubmitUpgradeProposal implements a command handler for submitting a software upgrade proposal transaction.
|
|
func NewCmdSubmitUpgradeProposal(clientCtx client.Context) *cobra.Command {
|
|
|
|
cmd := &cobra.Command{
|
|
Use: "software-upgrade [name] (--upgrade-height [height] | --upgrade-time [time]) (--upgrade-info [info]) [flags]",
|
|
Args: cobra.ExactArgs(1),
|
|
Short: "Submit a software upgrade proposal",
|
|
Long: "Submit a software upgrade along with an initial deposit.\n" +
|
|
"Please specify a unique name and height OR time for the upgrade to take effect.\n" +
|
|
"You may include info to reference a binary download link, in a format compatible with: https://github.com/regen-network/cosmosd",
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
name := args[0]
|
|
content, err := parseArgsToContent(cmd, name)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
clientCtx := clientCtx.InitWithInput(cmd.InOrStdin())
|
|
from := clientCtx.GetFromAddress()
|
|
|
|
depositStr, err := cmd.Flags().GetString(cli.FlagDeposit)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
deposit, err := sdk.ParseCoins(depositStr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
msg, err := gov.NewMsgSubmitProposal(content, deposit, from)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if err = msg.ValidateBasic(); err != nil {
|
|
return err
|
|
}
|
|
|
|
return tx.GenerateOrBroadcastTx(clientCtx, msg)
|
|
},
|
|
}
|
|
|
|
cmd.Flags().String(cli.FlagTitle, "", "title of proposal")
|
|
cmd.Flags().String(cli.FlagDescription, "", "description of proposal")
|
|
cmd.Flags().String(cli.FlagDeposit, "", "deposit of proposal")
|
|
cmd.Flags().Int64(FlagUpgradeHeight, 0, "The height at which the upgrade must happen (not to be used together with --upgrade-time)")
|
|
cmd.Flags().String(FlagUpgradeTime, "", fmt.Sprintf("The time at which the upgrade must happen (ex. %s) (not to be used together with --upgrade-height)", TimeFormat))
|
|
cmd.Flags().String(FlagUpgradeInfo, "", "Optional info for the planned upgrade such as commit hash, etc.")
|
|
|
|
return cmd
|
|
}
|
|
|
|
// NewCmdSubmitCancelUpgradeProposal implements a command handler for submitting a software upgrade cancel proposal transaction.
|
|
func NewCmdSubmitCancelUpgradeProposal(clientCtx client.Context) *cobra.Command {
|
|
cmd := &cobra.Command{
|
|
Use: "cancel-software-upgrade [flags]",
|
|
Args: cobra.ExactArgs(0),
|
|
Short: "Submit a software upgrade proposal",
|
|
Long: "Cancel a software upgrade along with an initial deposit.",
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
clientCtx := clientCtx.InitWithInput(cmd.InOrStdin())
|
|
from := clientCtx.GetFromAddress()
|
|
|
|
depositStr, err := cmd.Flags().GetString(cli.FlagDeposit)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
deposit, err := sdk.ParseCoins(depositStr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
title, err := cmd.Flags().GetString(cli.FlagTitle)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
description, err := cmd.Flags().GetString(cli.FlagDescription)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
content := types.NewCancelSoftwareUpgradeProposal(title, description)
|
|
|
|
msg, err := gov.NewMsgSubmitProposal(content, deposit, from)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if err = msg.ValidateBasic(); err != nil {
|
|
return err
|
|
}
|
|
|
|
return tx.GenerateOrBroadcastTx(clientCtx, msg)
|
|
},
|
|
}
|
|
|
|
cmd.Flags().String(cli.FlagTitle, "", "title of proposal")
|
|
cmd.Flags().String(cli.FlagDescription, "", "description of proposal")
|
|
cmd.Flags().String(cli.FlagDeposit, "", "deposit of proposal")
|
|
|
|
return cmd
|
|
}
|
|
|
|
func parseArgsToContent(cmd *cobra.Command, name string) (gov.Content, error) {
|
|
title, err := cmd.Flags().GetString(cli.FlagTitle)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
description, err := cmd.Flags().GetString(cli.FlagDescription)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
height, err := cmd.Flags().GetInt64(FlagUpgradeHeight)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
timeStr, err := cmd.Flags().GetString(FlagUpgradeTime)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if height != 0 && len(timeStr) != 0 {
|
|
return nil, fmt.Errorf("only one of --upgrade-time or --upgrade-height should be specified")
|
|
}
|
|
|
|
var upgradeTime time.Time
|
|
if len(timeStr) != 0 {
|
|
upgradeTime, err = time.Parse(TimeFormat, timeStr)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
|
|
info, err := cmd.Flags().GetString(FlagUpgradeInfo)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
plan := types.Plan{Name: name, Time: upgradeTime, Height: height, Info: info}
|
|
content := types.NewSoftwareUpgradeProposal(title, description, plan)
|
|
return content, nil
|
|
}
|