cosmos-sdk/x/distribution/client/cli/tx.go

114 lines
3.1 KiB
Go
Raw Normal View History

2018-09-04 23:41:17 -07:00
// nolint
package cli
import (
2018-09-18 21:00:48 -07:00
"fmt"
2018-09-04 23:41:17 -07:00
"os"
"github.com/cosmos/cosmos-sdk/client/context"
"github.com/cosmos/cosmos-sdk/client/utils"
sdk "github.com/cosmos/cosmos-sdk/types"
2018-09-10 15:37:58 -07:00
distr "github.com/cosmos/cosmos-sdk/x/distribution"
2018-09-04 23:41:17 -07:00
"github.com/spf13/cobra"
"github.com/spf13/viper"
wire "github.com/tendermint/go-wire"
)
var (
flagOnlyFromValidator = "only-from-validator"
flagIsValidator = "is-validator"
)
2018-09-18 21:00:48 -07:00
// command to withdraw rewards
2018-09-04 23:41:17 -07:00
func GetCmdWithdrawDelegationRewardsAll(cdc *wire.Codec) *cobra.Command {
cmd := &cobra.Command{
2018-09-18 21:00:48 -07:00
Use: "withdraw-rewards",
Short: "withdraw rewards for either: all-delegations, a delegation, or a validator",
Args: cobra.NoArgs,
2018-09-04 23:41:17 -07:00
RunE: func(cmd *cobra.Command, args []string) error {
2018-09-18 21:00:48 -07:00
onlyFromVal := viper.GetString(flagOnlyFromValidator)
isVal := viper.GetBool(flagIsValidator)
if onlyFromVal != "" && isVal {
return fmt.Errorf("cannot use --%v, and --%v flags together",
flagOnlyFromValidator, flagIsValidator)
}
2018-09-04 23:41:17 -07:00
txCtx := authctx.NewTxContextFromCLI().WithCodec(cdc)
cliCtx := context.NewCLIContext().
WithCodec(cdc).
WithLogger(os.Stdout).
WithAccountDecoder(authcmd.GetAccountDecoder(cdc))
2018-09-18 21:00:48 -07:00
var msg sdk.Msg
switch {
case isVal:
addr, err := cliCtx.GetFromAddress()
if err != nil {
return err
}
valAddr := sdk.ValAddress{addr.Bytes()}
msg := distr.NewMsgWithdrawValidatorRewardsAll(valAddr)
case onlyFromVal != "":
delAddr, err := cliCtx.GetFromAddress()
if err != nil {
return err
}
valAddr, err := sdk.ValAddressFromBech32(onlyFromVal)
if err != nil {
return err
}
msg := distr.NewMsgWithdrawDelegationReward(delAddr, valAddr)
default:
delAddr, err := cliCtx.GetFromAddress()
if err != nil {
return err
}
msg := distr.NewMsgWithdrawDelegationRewardsAll(delAddr)
2018-09-04 23:41:17 -07:00
}
2018-09-18 21:00:48 -07:00
// build and sign the transaction, then broadcast to Tendermint
return utils.SendTx(txCtx, cliCtx, []sdk.Msg{msg})
},
}
cmd.Flags().String(flagOnlyFromValidator, "", "only withdraw from this validator address (in bech)")
cmd.Flags().Bool(flagIsValidator, false, "also withdraw validator's commission")
return cmd
}
// GetCmdDelegate implements the delegate command.
func GetCmdWithdrawDelegationRewardsAll(cdc *wire.Codec) *cobra.Command {
cmd := &cobra.Command{
Use: "set-withdraw-addr [withdraw-addr]",
Short: "change the default withdraw address for rewards associated with an address",
Args: cobra.ExactArgs(1),
RunE: func(cmd *cobra.Command, args []string) error {
txCtx := authctx.NewTxContextFromCLI().WithCodec(cdc)
cliCtx := context.NewCLIContext().
WithCodec(cdc).
WithLogger(os.Stdout).
WithAccountDecoder(authcmd.GetAccountDecoder(cdc))
2018-09-04 23:41:17 -07:00
delAddr, err := cliCtx.GetFromAddress()
if err != nil {
return err
}
2018-09-18 21:00:48 -07:00
withdrawAddr, err := sdk.AccAddressFromBech32(args[0])
2018-09-04 23:41:17 -07:00
if err != nil {
return err
}
2018-09-18 21:00:48 -07:00
msg := distr.NewMsgModifyWithdrawAddress(delAddr, withdrawAddr)
2018-09-04 23:41:17 -07:00
// build and sign the transaction, then broadcast to Tendermint
return utils.SendTx(txCtx, cliCtx, []sdk.Msg{msg})
},
}
return cmd
}