Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

!Feat/client v2 #19738

Closed
wants to merge 19 commits into from
Closed
Show file tree
Hide file tree
Changes from 7 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions client/cmd.go
Original file line number Diff line number Diff line change
Expand Up @@ -318,6 +318,14 @@ func readTxCommandFlags(clientCtx Context, flagSet *pflag.FlagSet) (Context, err
}
}

if clientCtx.Viper == nil {
clientCtx = clientCtx.WithViper("")
}

if err = clientCtx.Viper.BindPFlags(flagSet); err != nil {
return clientCtx, fmt.Errorf("failed to bind flags to viper: %w", err)
}

return clientCtx, nil
}

Expand Down
19 changes: 19 additions & 0 deletions client/flags/flags.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package flags

import (
"fmt"
"github.com/cosmos/cosmos-sdk/types/tx/signing"
"strconv"

"github.com/spf13/cobra"
Expand Down Expand Up @@ -201,3 +202,21 @@ func ParseGasSetting(gasStr string) (GasSetting, error) {
return GasSetting{false, gas}, nil
}
}

func ParseSignMode(signModeStr string) signing.SignMode {
signMode := signing.SignMode_SIGN_MODE_UNSPECIFIED
switch signModeStr {
case SignModeDirect:
signMode = signing.SignMode_SIGN_MODE_DIRECT
case SignModeLegacyAminoJSON:
signMode = signing.SignMode_SIGN_MODE_LEGACY_AMINO_JSON
case SignModeDirectAux:
signMode = signing.SignMode_SIGN_MODE_DIRECT_AUX
case SignModeTextual:
signMode = signing.SignMode_SIGN_MODE_TEXTUAL
case SignModeEIP191:
signMode = signing.SignMode_SIGN_MODE_EIP_191
}

return signMode
}
19 changes: 18 additions & 1 deletion client/v2/autocli/keyring/interface.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,19 @@ package keyring

import (
signingv1beta1 "cosmossdk.io/api/cosmos/tx/signing/v1beta1"

cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
)

// Options are used to configure a keyring.
type Options struct{}

type Option func(*Options)

// KeyType reflects a human-readable type for key listing.
type KeyType uint

type Record struct{}

// Keyring is an interface used for signing transactions.
// It aims to be simplistic and easy to use.
type Keyring interface {
Expand All @@ -18,6 +27,14 @@ type Keyring interface {
// GetPubKey returns the public key of the key with the given name.
GetPubKey(name string) (cryptotypes.PubKey, error)

// Key and KeyByAddress return keys by uid and address respectively.
Key(uid string) (*Record, error)
KeyByAddress(address []byte) (*Record, error)

GetRecordAddress(record *Record) ([]byte, error)
GetRecordName(record *Record) string
GetRecordType(record *Record) KeyType

// Sign signs the given bytes with the key with the given name.
Sign(name string, msg []byte, signMode signingv1beta1.SignMode) ([]byte, error)
}
20 changes: 20 additions & 0 deletions client/v2/autocli/keyring/no_keyring.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,26 @@ var errNoKeyring = errors.New("no keyring configured")

type NoKeyring struct{}

func (k NoKeyring) Key(uid string) (*Record, error) {
return nil, errNoKeyring
}

func (k NoKeyring) KeyByAddress(address []byte) (*Record, error) {
return nil, errNoKeyring
}

func (k NoKeyring) GetRecordAddress(record *Record) ([]byte, error) {
return nil, errNoKeyring
}

func (k NoKeyring) GetRecordName(record *Record) string {
return ""
}

func (k NoKeyring) GetRecordType(record *Record) KeyType {
return 0
}

func (k NoKeyring) List() ([]string, error) {
return nil, errNoKeyring
}
Expand Down
24 changes: 24 additions & 0 deletions client/v2/tx/account_retriever.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
package tx

import (
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
sdk "github.com/cosmos/cosmos-sdk/types"
)

// Account defines a read-only version of the auth module's AccountI.
type Account interface {
GetAddress() sdk.AccAddress
GetPubKey() cryptotypes.PubKey // can return nil.
GetAccountNumber() uint64
GetSequence() uint64
}

// AccountRetriever defines the interfaces required by transactions to
// ensure an account exists and to be able to query for account fields necessary
// for signing.
type AccountRetriever interface {
GetAccount(clientCtx txContext, addr sdk.AccAddress) (Account, error)
GetAccountWithHeight(clientCtx txContext, addr sdk.AccAddress) (Account, int64, error)
EnsureExists(clientCtx txContext, addr sdk.AccAddress) error
GetAccountNumberSequence(clientCtx txContext, addr sdk.AccAddress) (accNum, accSeq uint64, err error)
}
Loading
Loading