From 36ad7b767910a001f6247f1372c182a7c11d2860 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 9 Jun 2020 21:44:24 -0400 Subject: [PATCH 01/43] Add TxWrapper, encoder, decoder and DirectModeHandler --- types/tx/tx_builder.go | 150 ++++++++ types/tx/tx_decoder.go | 43 +++ types/tx/tx_encoder.go | 25 ++ types/tx/types.go | 29 ++ types/tx/types.pb.go | 502 ++++++++++++++++++++------- types/tx/types.proto | 18 +- x/auth/signing/direct/direct.go | 42 +++ x/auth/signing/direct/direct_test.go | 7 + x/bank/types/query.pb.go | 16 +- 9 files changed, 702 insertions(+), 130 deletions(-) create mode 100644 types/tx/tx_builder.go create mode 100644 types/tx/tx_decoder.go create mode 100644 types/tx/tx_encoder.go create mode 100644 types/tx/types.go create mode 100644 x/auth/signing/direct/direct.go create mode 100644 x/auth/signing/direct/direct_test.go diff --git a/types/tx/tx_builder.go b/types/tx/tx_builder.go new file mode 100644 index 000000000000..c049846e2476 --- /dev/null +++ b/types/tx/tx_builder.go @@ -0,0 +1,150 @@ +package types + +import ( + "fmt" + + "github.com/cosmos/cosmos-sdk/codec" + "github.com/cosmos/cosmos-sdk/crypto/types" + sdk "github.com/cosmos/cosmos-sdk/types" + sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" + "github.com/tendermint/tendermint/crypto" +) + +type txWrapper struct { + tx *Tx + bodyBz []byte + authInfoBz []byte + pubKeys []crypto.PubKey + marshaler codec.Marshaler + pubkeyCodec types.PublicKeyCodec +} + +type TxWrapper interface { + sdk.Tx + ProtoTx + + WithTxBody(*TxBody) TxWrapper + WithAuthInfo(*AuthInfo) TxWrapper + WithSignatures([][]byte) TxWrapper +} + +func NewTxWrapper(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) TxWrapper { + return txWrapper{ + tx: &Tx{ + Body: &TxBody{}, + AuthInfo: &AuthInfo{}, + }, + marshaler: marshaler, + pubkeyCodec: pubkeyCodec, + } +} + +var ( + _ sdk.Tx = txWrapper{} + _ ProtoTx = txWrapper{} +) + +func (t txWrapper) GetMsgs() []sdk.Msg { + anys := t.tx.Body.Messages + res := make([]sdk.Msg, len(anys)) + for i, any := range anys { + msg := any.GetCachedValue().(sdk.Msg) + res[i] = msg + } + return res +} + +// MaxGasWanted defines the max gas allowed. +const MaxGasWanted = uint64((1 << 63) - 1) + +func (t txWrapper) ValidateBasic() error { + tx := t.tx + if tx == nil { + return fmt.Errorf("bad Tx") + } + + body := t.tx.Body + if body == nil { + return fmt.Errorf("missing TxBody") + } + + authInfo := t.tx.AuthInfo + if authInfo == nil { + return fmt.Errorf("missing AuthInfo") + } + + fee := authInfo.Fee + if fee == nil { + return fmt.Errorf("missing fee") + } + + if fee.GasLimit > MaxGasWanted { + return sdkerrors.Wrapf( + sdkerrors.ErrInvalidRequest, + "invalid gas supplied; %d > %d", fee.GasLimit, MaxGasWanted, + ) + } + + if fee.Amount.IsAnyNegative() { + return sdkerrors.Wrapf( + sdkerrors.ErrInsufficientFee, + "invalid fee provided: %s", fee.Amount, + ) + } + + sigs := tx.Signatures + + if len(sigs) == 0 { + return sdkerrors.ErrNoSignatures + } + + if len(sigs) != len(t.GetSigners()) { + return sdkerrors.Wrapf( + sdkerrors.ErrUnauthorized, + "wrong number of signers; expected %d, got %d", t.GetSigners(), len(sigs), + ) + } + + return nil +} + +func (t txWrapper) GetBodyBytes() []byte { + return t.bodyBz +} + +func (t txWrapper) GetAuthInfoBytes() []byte { + return t.authInfoBz +} + +func (t txWrapper) GetSigners() []sdk.AccAddress { + var signers []sdk.AccAddress + seen := map[string]bool{} + + for _, msg := range t.GetMsgs() { + for _, addr := range msg.GetSigners() { + if !seen[addr.String()] { + signers = append(signers, addr) + seen[addr.String()] = true + } + } + } + + return signers +} + +func (t txWrapper) WithTxBody(body *TxBody) TxWrapper { + t.tx.Body = body + t.bodyBz = t.marshaler.MustMarshalBinaryBare(body) + return t +} + +func (t txWrapper) WithAuthInfo(info *AuthInfo) TxWrapper { + t.tx.AuthInfo = info + t.authInfoBz = t.marshaler.MustMarshalBinaryBare(info) + return t +} + +func (t txWrapper) WithSignatures(sigs [][]byte) TxWrapper { + t.tx.Signatures = sigs + return t +} diff --git a/types/tx/tx_decoder.go b/types/tx/tx_decoder.go new file mode 100644 index 000000000000..630eea702d88 --- /dev/null +++ b/types/tx/tx_decoder.go @@ -0,0 +1,43 @@ +package types + +import ( + "github.com/cosmos/cosmos-sdk/codec" + cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types" + sdk "github.com/cosmos/cosmos-sdk/types" + "github.com/tendermint/tendermint/crypto" +) + +func DefaultTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCodec) sdk.TxDecoder { + return func(txBytes []byte) (sdk.Tx, error) { + var raw TxRaw + err := cdc.UnmarshalBinaryBare(txBytes, &raw) + if err != nil { + return nil, err + } + + var tx Tx + err = cdc.UnmarshalBinaryBare(txBytes, &tx) + if err != nil { + return nil, err + } + + signerInfos := tx.AuthInfo.SignerInfos + pks := make([]crypto.PubKey, len(signerInfos)) + for i, si := range signerInfos { + pk, err := keyCodec.Decode(si.PublicKey) + if err != nil { + return nil, err + } + pks[i] = pk + } + + return txWrapper{ + tx: &tx, + bodyBz: raw.BodyBytes, + authInfoBz: raw.AuthInfoBytes, + pubKeys: pks, + marshaler: cdc, + pubkeyCodec: keyCodec, + }, nil + } +} diff --git a/types/tx/tx_encoder.go b/types/tx/tx_encoder.go new file mode 100644 index 000000000000..9272e8f084cb --- /dev/null +++ b/types/tx/tx_encoder.go @@ -0,0 +1,25 @@ +package types + +import ( + "fmt" + + "github.com/cosmos/cosmos-sdk/codec" + "github.com/cosmos/cosmos-sdk/types" +) + +func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { + return func(tx types.Tx) ([]byte, error) { + wrapper, ok := tx.(txWrapper) + if !ok { + return nil, fmt.Errorf("expected %T, got %T", txWrapper{}, tx) + } + + raw := &TxRaw{ + BodyBytes: wrapper.bodyBz, + AuthInfoBytes: wrapper.authInfoBz, + Signatures: wrapper.tx.Signatures, + } + + return marshaler.MarshalBinaryBare(raw) + } +} diff --git a/types/tx/types.go b/types/tx/types.go new file mode 100644 index 000000000000..9ff0f2e04212 --- /dev/null +++ b/types/tx/types.go @@ -0,0 +1,29 @@ +package types + +import ( + codectypes "github.com/cosmos/cosmos-sdk/codec/types" + sdk "github.com/cosmos/cosmos-sdk/types" +) + +type ProtoTx interface { + GetBodyBytes() []byte + GetAuthInfoBytes() []byte +} + +func (m *Tx) UnpackInterfaces(unpacker codectypes.AnyUnpacker) error { + if m.Body != nil { + return m.Body.UnpackInterfaces(unpacker) + } + return nil +} + +func (m *TxBody) UnpackInterfaces(unpacker codectypes.AnyUnpacker) error { + for _, any := range m.Messages { + var msg sdk.Msg + err := unpacker.UnpackAny(any, &msg) + if err != nil { + return err + } + } + return nil +} diff --git a/types/tx/types.pb.go b/types/tx/types.pb.go index 16e2ac453b56..501387490c63 100644 --- a/types/tx/types.pb.go +++ b/types/tx/types.pb.go @@ -131,12 +131,70 @@ func (m *Tx) GetSignatures() [][]byte { return nil } -// SignDoc is the standard type used for signing transaction in SIGN_MODE_DIRECT +type TxRaw struct { + BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` + AuthInfoBytes []byte `protobuf:"bytes,2,opt,name=auth_info_bytes,json=authInfoBytes,proto3" json:"auth_info_bytes,omitempty"` + // signatures are the raw binary signatures of signers specified by body and auth_info + Signatures [][]byte `protobuf:"bytes,3,rep,name=signatures,proto3" json:"signatures,omitempty"` +} + +func (m *TxRaw) Reset() { *m = TxRaw{} } +func (m *TxRaw) String() string { return proto.CompactTextString(m) } +func (*TxRaw) ProtoMessage() {} +func (*TxRaw) Descriptor() ([]byte, []int) { + return fileDescriptor_1c6ac8fa65877134, []int{1} +} +func (m *TxRaw) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TxRaw) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_TxRaw.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *TxRaw) XXX_Merge(src proto.Message) { + xxx_messageInfo_TxRaw.Merge(m, src) +} +func (m *TxRaw) XXX_Size() int { + return m.Size() +} +func (m *TxRaw) XXX_DiscardUnknown() { + xxx_messageInfo_TxRaw.DiscardUnknown(m) +} + +var xxx_messageInfo_TxRaw proto.InternalMessageInfo + +func (m *TxRaw) GetBodyBytes() []byte { + if m != nil { + return m.BodyBytes + } + return nil +} + +func (m *TxRaw) GetAuthInfoBytes() []byte { + if m != nil { + return m.AuthInfoBytes + } + return nil +} + +func (m *TxRaw) GetSignatures() [][]byte { + if m != nil { + return m.Signatures + } + return nil +} + type SignDoc struct { - // body is the TxBody from Tx - Body *TxBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"` - // auth_info is the AuthInfo from Tx - AuthInfo *AuthInfo `protobuf:"bytes,2,opt,name=auth_info,json=authInfo,proto3" json:"auth_info,omitempty"` + BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` + AuthInfoBytes []byte `protobuf:"bytes,2,opt,name=auth_info_bytes,json=authInfoBytes,proto3" json:"auth_info_bytes,omitempty"` // chain_id is the unique identifier of the chain this transaction targets. // It prevents signed transactions from being used on another chain by an // attacker @@ -152,7 +210,7 @@ func (m *SignDoc) Reset() { *m = SignDoc{} } func (m *SignDoc) String() string { return proto.CompactTextString(m) } func (*SignDoc) ProtoMessage() {} func (*SignDoc) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{1} + return fileDescriptor_1c6ac8fa65877134, []int{2} } func (m *SignDoc) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -181,16 +239,16 @@ func (m *SignDoc) XXX_DiscardUnknown() { var xxx_messageInfo_SignDoc proto.InternalMessageInfo -func (m *SignDoc) GetBody() *TxBody { +func (m *SignDoc) GetBodyBytes() []byte { if m != nil { - return m.Body + return m.BodyBytes } return nil } -func (m *SignDoc) GetAuthInfo() *AuthInfo { +func (m *SignDoc) GetAuthInfoBytes() []byte { if m != nil { - return m.AuthInfo + return m.AuthInfoBytes } return nil } @@ -239,7 +297,7 @@ func (m *TxBody) Reset() { *m = TxBody{} } func (m *TxBody) String() string { return proto.CompactTextString(m) } func (*TxBody) ProtoMessage() {} func (*TxBody) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{2} + return fileDescriptor_1c6ac8fa65877134, []int{3} } func (m *TxBody) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -318,7 +376,7 @@ func (m *AuthInfo) Reset() { *m = AuthInfo{} } func (m *AuthInfo) String() string { return proto.CompactTextString(m) } func (*AuthInfo) ProtoMessage() {} func (*AuthInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{3} + return fileDescriptor_1c6ac8fa65877134, []int{4} } func (m *AuthInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -365,7 +423,7 @@ func (m *AuthInfo) GetFee() *Fee { type SignerInfo struct { // public_key is the public key of the signer. It is optional for accounts // that already exist in state - PublicKey *types.Any `protobuf:"bytes,1,opt,name=public_key,json=publicKey,proto3" json:"public_key,omitempty"` + PublicKey *types1.PublicKey `protobuf:"bytes,1,opt,name=public_key,json=publicKey,proto3" json:"public_key,omitempty"` // mode_info describes the signing mode of the signer and is a nested // structure to support nested multisig pubkey's ModeInfo *ModeInfo `protobuf:"bytes,2,opt,name=mode_info,json=modeInfo,proto3" json:"mode_info,omitempty"` @@ -375,7 +433,7 @@ func (m *SignerInfo) Reset() { *m = SignerInfo{} } func (m *SignerInfo) String() string { return proto.CompactTextString(m) } func (*SignerInfo) ProtoMessage() {} func (*SignerInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{4} + return fileDescriptor_1c6ac8fa65877134, []int{5} } func (m *SignerInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -404,7 +462,7 @@ func (m *SignerInfo) XXX_DiscardUnknown() { var xxx_messageInfo_SignerInfo proto.InternalMessageInfo -func (m *SignerInfo) GetPublicKey() *types.Any { +func (m *SignerInfo) GetPublicKey() *types1.PublicKey { if m != nil { return m.PublicKey } @@ -433,7 +491,7 @@ func (m *ModeInfo) Reset() { *m = ModeInfo{} } func (m *ModeInfo) String() string { return proto.CompactTextString(m) } func (*ModeInfo) ProtoMessage() {} func (*ModeInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{5} + return fileDescriptor_1c6ac8fa65877134, []int{6} } func (m *ModeInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -518,7 +576,7 @@ func (m *ModeInfo_Single) Reset() { *m = ModeInfo_Single{} } func (m *ModeInfo_Single) String() string { return proto.CompactTextString(m) } func (*ModeInfo_Single) ProtoMessage() {} func (*ModeInfo_Single) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{5, 0} + return fileDescriptor_1c6ac8fa65877134, []int{6, 0} } func (m *ModeInfo_Single) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -567,7 +625,7 @@ func (m *ModeInfo_Multi) Reset() { *m = ModeInfo_Multi{} } func (m *ModeInfo_Multi) String() string { return proto.CompactTextString(m) } func (*ModeInfo_Multi) ProtoMessage() {} func (*ModeInfo_Multi) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{5, 1} + return fileDescriptor_1c6ac8fa65877134, []int{6, 1} } func (m *ModeInfo_Multi) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -625,7 +683,7 @@ func (m *Fee) Reset() { *m = Fee{} } func (m *Fee) String() string { return proto.CompactTextString(m) } func (*Fee) ProtoMessage() {} func (*Fee) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{6} + return fileDescriptor_1c6ac8fa65877134, []int{7} } func (m *Fee) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -671,6 +729,7 @@ func (m *Fee) GetGasLimit() uint64 { func init() { proto.RegisterEnum("cosmos_sdk.tx.v1.SignMode", SignMode_name, SignMode_value) proto.RegisterType((*Tx)(nil), "cosmos_sdk.tx.v1.Tx") + proto.RegisterType((*TxRaw)(nil), "cosmos_sdk.tx.v1.TxRaw") proto.RegisterType((*SignDoc)(nil), "cosmos_sdk.tx.v1.SignDoc") proto.RegisterType((*TxBody)(nil), "cosmos_sdk.tx.v1.TxBody") proto.RegisterType((*AuthInfo)(nil), "cosmos_sdk.tx.v1.AuthInfo") @@ -684,60 +743,63 @@ func init() { func init() { proto.RegisterFile("types/tx/types.proto", fileDescriptor_1c6ac8fa65877134) } var fileDescriptor_1c6ac8fa65877134 = []byte{ - // 842 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x55, 0x4d, 0x6f, 0xe3, 0x44, - 0x18, 0x8e, 0x93, 0x34, 0x4d, 0xde, 0xee, 0x47, 0x3a, 0xb4, 0x92, 0x9b, 0xa2, 0x34, 0x44, 0x2a, - 0x04, 0x04, 0xce, 0xb2, 0x7b, 0x60, 0x11, 0x87, 0x55, 0x92, 0xa6, 0xdb, 0x40, 0x9b, 0xa2, 0x49, - 0x56, 0x82, 0x95, 0x90, 0xe5, 0xd8, 0x53, 0x67, 0xd4, 0x78, 0x26, 0x78, 0xc6, 0x28, 0xe1, 0x82, - 0x38, 0x70, 0xe2, 0xc2, 0x85, 0x3f, 0xc1, 0x2f, 0x59, 0x71, 0xda, 0x23, 0x17, 0x3e, 0xd4, 0xfe, - 0x10, 0x90, 0xc7, 0xe3, 0xa4, 0x6a, 0x4a, 0xb8, 0x71, 0xca, 0xeb, 0xc7, 0xcf, 0xf3, 0xcc, 0xfb, - 0x95, 0x31, 0xec, 0xc8, 0xf9, 0x94, 0x88, 0xa6, 0x9c, 0x35, 0x55, 0x60, 0x4d, 0x43, 0x2e, 0x39, - 0x2a, 0xbb, 0x5c, 0x04, 0x5c, 0xd8, 0xc2, 0xbb, 0xb4, 0xe4, 0xcc, 0xfa, 0xe6, 0xc3, 0xca, 0xdb, - 0x72, 0x4c, 0x43, 0xcf, 0x9e, 0x3a, 0xa1, 0x9c, 0x37, 0x15, 0xa9, 0xe9, 0x73, 0x9f, 0x2f, 0xa3, - 0x44, 0x59, 0x31, 0xdd, 0x70, 0x3e, 0x95, 0xbc, 0xa9, 0x6d, 0x97, 0x9e, 0x95, 0xed, 0x55, 0x68, - 0xcf, 0xe7, 0xdc, 0x9f, 0x90, 0xc4, 0x6f, 0x14, 0x5d, 0x34, 0x1d, 0x36, 0x4f, 0x5e, 0xd5, 0x7f, - 0x34, 0x20, 0x3b, 0x9c, 0xa1, 0xf7, 0x21, 0x3f, 0xe2, 0xde, 0xdc, 0x34, 0x6a, 0x46, 0x63, 0xeb, - 0xb1, 0x69, 0xdd, 0xce, 0xcb, 0x1a, 0xce, 0xda, 0xdc, 0x9b, 0x63, 0xc5, 0x42, 0x1f, 0x41, 0xc9, - 0x89, 0xe4, 0xd8, 0xa6, 0xec, 0x82, 0x9b, 0x59, 0x25, 0xa9, 0xac, 0x4a, 0x5a, 0x91, 0x1c, 0xf7, - 0xd8, 0x05, 0xc7, 0x45, 0x47, 0x47, 0xa8, 0x0a, 0x20, 0xa8, 0xcf, 0x1c, 0x19, 0x85, 0x44, 0x98, - 0xb9, 0x5a, 0xae, 0x71, 0x0f, 0xdf, 0x40, 0xea, 0xbf, 0x1b, 0xb0, 0x39, 0xa0, 0x3e, 0x3b, 0xe2, - 0xee, 0xff, 0x95, 0xd2, 0x1e, 0x14, 0xdd, 0xb1, 0x43, 0x99, 0x4d, 0x3d, 0x33, 0x57, 0x33, 0x1a, - 0x25, 0xbc, 0xa9, 0x9e, 0x7b, 0x1e, 0x3a, 0x84, 0x07, 0x8e, 0xeb, 0xf2, 0x88, 0x49, 0x9b, 0x45, - 0xc1, 0x88, 0x84, 0x66, 0xbe, 0x66, 0x34, 0xf2, 0xf8, 0xbe, 0x46, 0xfb, 0x0a, 0x44, 0xef, 0x42, - 0x39, 0xa5, 0x09, 0xf2, 0x75, 0x44, 0x98, 0x4b, 0xcc, 0x0d, 0x45, 0x7c, 0xa8, 0xf1, 0x81, 0x86, - 0xeb, 0x3f, 0x67, 0xa1, 0x90, 0xa4, 0x8d, 0x1e, 0x41, 0x31, 0x20, 0x42, 0x38, 0x3e, 0x11, 0xa6, - 0x51, 0xcb, 0x35, 0xb6, 0x1e, 0xef, 0x58, 0xc9, 0x98, 0xac, 0x74, 0x4c, 0x56, 0x8b, 0xcd, 0xf1, - 0x82, 0x85, 0x10, 0xe4, 0x03, 0x12, 0x24, 0xd5, 0x95, 0xb0, 0x8a, 0xe3, 0x14, 0x25, 0x0d, 0x08, - 0x8f, 0xa4, 0x3d, 0x26, 0xd4, 0x1f, 0x4b, 0x55, 0x43, 0x0e, 0xdf, 0xd7, 0xe8, 0x89, 0x02, 0x51, - 0x1b, 0xb6, 0xc9, 0x4c, 0x12, 0x26, 0x28, 0x67, 0x36, 0x9f, 0x4a, 0xca, 0x99, 0x30, 0xff, 0xde, - 0x5c, 0x73, 0x6c, 0x79, 0xc1, 0x3f, 0x4f, 0xe8, 0xe8, 0x25, 0x54, 0x19, 0x67, 0xb6, 0x1b, 0x52, - 0x49, 0x5d, 0x67, 0x62, 0xdf, 0x61, 0xf8, 0x70, 0x8d, 0xe1, 0x3e, 0xe3, 0xac, 0xa3, 0xb5, 0xdd, - 0x5b, 0xde, 0x75, 0x09, 0xc5, 0x74, 0x34, 0xe8, 0x19, 0xdc, 0x8b, 0x37, 0x82, 0x84, 0x6a, 0x96, - 0x69, 0x73, 0xde, 0x5c, 0x1d, 0xe6, 0x40, 0xb1, 0xd4, 0x38, 0xb7, 0xc4, 0x22, 0x16, 0xe8, 0x1d, - 0xc8, 0x5d, 0x10, 0xa2, 0x97, 0x60, 0x77, 0x55, 0x77, 0x4c, 0x08, 0x8e, 0x19, 0xf5, 0x6f, 0x01, - 0x96, 0x1e, 0xe8, 0x09, 0xc0, 0x34, 0x1a, 0x4d, 0xa8, 0x6b, 0x5f, 0x92, 0x74, 0xeb, 0xee, 0x2e, - 0xa5, 0x94, 0xf0, 0x3e, 0x23, 0x6a, 0xed, 0x02, 0xee, 0x91, 0xff, 0x58, 0xbb, 0x33, 0xee, 0x91, - 0x64, 0xed, 0x02, 0x1d, 0xd5, 0x7f, 0xcd, 0x42, 0x31, 0x85, 0xd1, 0x27, 0x50, 0x10, 0x94, 0xf9, - 0x13, 0xa2, 0x8f, 0x7d, 0xeb, 0xdf, 0x2d, 0xac, 0x81, 0x22, 0x9e, 0x64, 0xb0, 0x96, 0xa0, 0xa7, - 0xb0, 0x11, 0x44, 0x13, 0x49, 0xf5, 0xf1, 0xb5, 0x35, 0xda, 0xb3, 0x98, 0x77, 0x92, 0xc1, 0x89, - 0xa0, 0xf2, 0x14, 0x0a, 0x89, 0x1b, 0xb2, 0x20, 0x1f, 0x67, 0xa6, 0x8e, 0x7f, 0x70, 0x57, 0x05, - 0x71, 0x9f, 0x62, 0x1b, 0xac, 0x78, 0x95, 0x1f, 0x0c, 0xd8, 0x50, 0x66, 0xa8, 0x05, 0xc5, 0x11, - 0x95, 0x4e, 0x18, 0x3a, 0x69, 0xcf, 0x0e, 0x6f, 0xaa, 0x93, 0x5b, 0x2a, 0x76, 0xe8, 0xf0, 0x60, - 0xea, 0xb8, 0xb2, 0x4d, 0x65, 0x2b, 0x26, 0xe3, 0x85, 0x0c, 0x7d, 0x0c, 0xb0, 0xe8, 0xa1, 0x30, - 0xb3, 0x6a, 0xdc, 0xeb, 0x9a, 0x58, 0x4a, 0x9b, 0x28, 0xda, 0x1b, 0x90, 0x13, 0x51, 0x50, 0xff, - 0xde, 0x80, 0xdc, 0x31, 0x21, 0xe8, 0x2b, 0x28, 0x38, 0x41, 0xfc, 0x87, 0xd3, 0x4b, 0xf3, 0xc6, - 0x4d, 0x17, 0x95, 0x03, 0x65, 0xed, 0x47, 0xaf, 0xfe, 0x38, 0xc8, 0xfc, 0xf2, 0xe7, 0x41, 0xc3, - 0xa7, 0x72, 0x1c, 0x8d, 0x2c, 0x97, 0x07, 0xcd, 0x84, 0xa6, 0x7f, 0x3e, 0x10, 0xde, 0xa5, 0xbe, - 0x3e, 0x63, 0x81, 0xc0, 0xda, 0x14, 0xed, 0x43, 0xc9, 0x77, 0x84, 0x3d, 0xa1, 0x01, 0x95, 0xaa, - 0xdb, 0x79, 0x5c, 0xf4, 0x1d, 0x71, 0x1a, 0x3f, 0xbf, 0x27, 0xa0, 0x98, 0x36, 0x09, 0xed, 0xc1, - 0xee, 0xa0, 0xf7, 0xbc, 0x6f, 0x9f, 0x9d, 0x1f, 0x75, 0xed, 0x17, 0xfd, 0xc1, 0xe7, 0xdd, 0x4e, - 0xef, 0xb8, 0xd7, 0x3d, 0x2a, 0x67, 0xd0, 0x0e, 0x94, 0x97, 0xaf, 0x8e, 0x7a, 0xb8, 0xdb, 0x19, - 0x96, 0x0d, 0xb4, 0x0b, 0xdb, 0x4b, 0x74, 0xd8, 0xfd, 0x62, 0xf8, 0xa2, 0x75, 0x5a, 0xce, 0xa2, - 0x03, 0xd8, 0x5f, 0xc2, 0xa7, 0xdd, 0xe7, 0xad, 0xce, 0x97, 0x76, 0xeb, 0xac, 0xd7, 0x3f, 0xb7, - 0x3f, 0x1d, 0x9c, 0xf7, 0xcb, 0xdf, 0xb5, 0x9f, 0xbd, 0xba, 0xaa, 0x1a, 0xaf, 0xaf, 0xaa, 0xc6, - 0x5f, 0x57, 0x55, 0xe3, 0xa7, 0xeb, 0x6a, 0xe6, 0xf5, 0x75, 0x35, 0xf3, 0xdb, 0x75, 0x35, 0xf3, - 0xf2, 0x70, 0x7d, 0x75, 0xfa, 0x33, 0x34, 0x2a, 0xa8, 0xc5, 0x7e, 0xf2, 0x4f, 0x00, 0x00, 0x00, - 0xff, 0xff, 0x28, 0x03, 0x76, 0x89, 0x9f, 0x06, 0x00, 0x00, + // 889 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x55, 0xcf, 0x6f, 0xe3, 0x44, + 0x14, 0x8e, 0xf3, 0xab, 0xc9, 0x6b, 0xbb, 0x4d, 0x87, 0x56, 0x4a, 0x53, 0x48, 0x43, 0xa4, 0x2e, + 0x01, 0x81, 0xb3, 0x2c, 0x07, 0x16, 0x21, 0xb1, 0x4a, 0xd2, 0x74, 0x1b, 0x68, 0xd3, 0xd5, 0x24, + 0x2b, 0xc1, 0x4a, 0xc8, 0x72, 0x9c, 0xa9, 0x33, 0x6a, 0x3c, 0x13, 0x3c, 0x63, 0x88, 0x4f, 0x88, + 0xc3, 0x9e, 0xb8, 0x70, 0xe1, 0x9f, 0xe0, 0x7f, 0xe0, 0xbe, 0xe2, 0xb4, 0x47, 0x4e, 0x80, 0xda, + 0x3f, 0x04, 0xe4, 0xf1, 0x38, 0xa9, 0xb6, 0xa5, 0xbd, 0xec, 0x29, 0xcf, 0x9f, 0xbf, 0xef, 0x7b, + 0x6f, 0xde, 0x9b, 0x17, 0xc3, 0x96, 0x0c, 0x67, 0x44, 0x34, 0xe5, 0xbc, 0xa9, 0x02, 0x73, 0xe6, + 0x73, 0xc9, 0x51, 0xc9, 0xe1, 0xc2, 0xe3, 0xc2, 0x12, 0xe3, 0x73, 0x53, 0xce, 0xcd, 0xef, 0x3f, + 0xae, 0xdc, 0x97, 0x13, 0xea, 0x8f, 0xad, 0x99, 0xed, 0xcb, 0xb0, 0xa9, 0x48, 0x4d, 0x97, 0xbb, + 0x7c, 0x19, 0xc5, 0xca, 0x4a, 0xd9, 0xf1, 0xc3, 0x99, 0xe4, 0x4d, 0x6d, 0xbb, 0xf4, 0xac, 0x6c, + 0x5e, 0x87, 0x76, 0x5c, 0xce, 0xdd, 0x29, 0x89, 0xfd, 0x46, 0xc1, 0x59, 0xd3, 0x66, 0x61, 0xfc, + 0xaa, 0xfe, 0xb3, 0x01, 0xe9, 0xe1, 0x1c, 0x7d, 0x08, 0xd9, 0x11, 0x1f, 0x87, 0x65, 0xa3, 0x66, + 0x34, 0x56, 0x1f, 0x96, 0xcd, 0xd7, 0xeb, 0x32, 0x87, 0xf3, 0x36, 0x1f, 0x87, 0x58, 0xb1, 0xd0, + 0xa7, 0x50, 0xb4, 0x03, 0x39, 0xb1, 0x28, 0x3b, 0xe3, 0xe5, 0xb4, 0x92, 0x54, 0xae, 0x4b, 0x5a, + 0x81, 0x9c, 0xf4, 0xd8, 0x19, 0xc7, 0x05, 0x5b, 0x47, 0xa8, 0x0a, 0x20, 0xa8, 0xcb, 0x6c, 0x19, + 0xf8, 0x44, 0x94, 0x33, 0xb5, 0x4c, 0x63, 0x0d, 0x5f, 0x41, 0xea, 0x0c, 0x72, 0xc3, 0x39, 0xb6, + 0x7f, 0x40, 0xef, 0x00, 0x44, 0x99, 0xac, 0x51, 0x28, 0x89, 0x50, 0x55, 0xad, 0xe1, 0x62, 0x84, + 0xb4, 0x23, 0x00, 0xdd, 0x87, 0x8d, 0x45, 0x01, 0x9a, 0x93, 0x56, 0x9c, 0xf5, 0x24, 0x55, 0xcc, + 0xbb, 0x2b, 0xdf, 0xef, 0x06, 0xac, 0x0c, 0xa8, 0xcb, 0x0e, 0xb8, 0xf3, 0xa6, 0x52, 0xee, 0x40, + 0xc1, 0x99, 0xd8, 0x94, 0x59, 0x74, 0x5c, 0xce, 0xd4, 0x8c, 0x46, 0x11, 0xaf, 0xa8, 0xe7, 0xde, + 0x18, 0xed, 0xc3, 0x3d, 0xdb, 0x71, 0x78, 0xc0, 0xa4, 0xc5, 0x02, 0x6f, 0x44, 0xfc, 0x72, 0xb6, + 0x66, 0x34, 0xb2, 0x78, 0x5d, 0xa3, 0x7d, 0x05, 0xa2, 0xf7, 0xa1, 0x94, 0xd0, 0x04, 0xf9, 0x2e, + 0x20, 0xcc, 0x21, 0xe5, 0x9c, 0x22, 0x6e, 0x68, 0x7c, 0xa0, 0xe1, 0xfa, 0xaf, 0x69, 0xc8, 0xc7, + 0x93, 0x41, 0x0f, 0xa0, 0xe0, 0x11, 0x21, 0x6c, 0x57, 0x15, 0x9f, 0x69, 0xac, 0x3e, 0xdc, 0x32, + 0xe3, 0xb1, 0x9b, 0xc9, 0xd8, 0xcd, 0x16, 0x0b, 0xf1, 0x82, 0x85, 0x10, 0x64, 0x3d, 0xe2, 0xc5, + 0x03, 0x2c, 0x62, 0x15, 0x47, 0x25, 0x4a, 0xea, 0x11, 0x1e, 0x48, 0x6b, 0x42, 0xa8, 0x3b, 0x91, + 0xea, 0x0c, 0x19, 0xbc, 0xae, 0xd1, 0x23, 0x05, 0xa2, 0x36, 0x6c, 0x92, 0xb9, 0x24, 0x4c, 0x50, + 0xce, 0x2c, 0x3e, 0x93, 0x94, 0x33, 0x51, 0xfe, 0x77, 0xe5, 0x96, 0xb4, 0xa5, 0x05, 0xff, 0x34, + 0xa6, 0xa3, 0xe7, 0x50, 0x65, 0x9c, 0x59, 0x8e, 0x4f, 0x25, 0x75, 0xec, 0xa9, 0x75, 0x83, 0xe1, + 0xc6, 0x2d, 0x86, 0xbb, 0x8c, 0xb3, 0x8e, 0xd6, 0x76, 0x5f, 0xf3, 0xae, 0x4b, 0x28, 0x24, 0xb7, + 0x0f, 0x3d, 0x86, 0xb5, 0x68, 0xe2, 0xc4, 0x57, 0xa3, 0x4b, 0x9a, 0xf3, 0xf6, 0xf5, 0xfb, 0x3a, + 0x50, 0x2c, 0x75, 0x63, 0x57, 0xc5, 0x22, 0x16, 0xe8, 0x3d, 0xc8, 0x9c, 0x11, 0xa2, 0xef, 0xf9, + 0xf6, 0x75, 0xdd, 0x21, 0x21, 0x38, 0x62, 0xd4, 0x5f, 0x18, 0x00, 0x4b, 0x13, 0xf4, 0x05, 0xc0, + 0x2c, 0x18, 0x4d, 0xa9, 0x63, 0x9d, 0x93, 0x64, 0xb3, 0xf6, 0xae, 0xca, 0xe3, 0x15, 0x8e, 0x2c, + 0x9e, 0x2a, 0xde, 0x57, 0x24, 0xc4, 0xc5, 0x59, 0x12, 0x46, 0x5b, 0xe6, 0xf1, 0x31, 0xb9, 0x63, + 0xcb, 0x4e, 0xf8, 0x98, 0xc4, 0x5b, 0xe6, 0xe9, 0xa8, 0xfe, 0x47, 0x1a, 0x0a, 0x09, 0x8c, 0x3e, + 0x87, 0xbc, 0xa0, 0xcc, 0x9d, 0x12, 0x5d, 0xc1, 0xbb, 0xff, 0x6f, 0x61, 0x0e, 0x14, 0xf1, 0x28, + 0x85, 0xb5, 0x04, 0x3d, 0x82, 0x9c, 0x17, 0x4c, 0x25, 0xd5, 0xe9, 0x6b, 0xb7, 0x68, 0x4f, 0x22, + 0xde, 0x51, 0x0a, 0xc7, 0x82, 0xca, 0x23, 0xc8, 0xc7, 0x6e, 0xc8, 0x84, 0x6c, 0x54, 0x99, 0x4a, + 0x7f, 0xef, 0xa6, 0x13, 0x44, 0x2d, 0x8b, 0x6c, 0xb0, 0xe2, 0x55, 0x5e, 0x18, 0x90, 0x53, 0x66, + 0xa8, 0x05, 0x85, 0x11, 0x95, 0xb6, 0xef, 0xdb, 0x49, 0xfb, 0xf6, 0x6f, 0x6e, 0x5f, 0x87, 0x7b, + 0x33, 0xdb, 0x91, 0x6d, 0x2a, 0x5b, 0x11, 0x19, 0x2f, 0x64, 0xe8, 0x33, 0x80, 0x45, 0x0f, 0xa3, + 0x85, 0xcd, 0xdc, 0xd1, 0xc4, 0x62, 0xd2, 0x44, 0xd1, 0xce, 0x41, 0x46, 0x04, 0x5e, 0xfd, 0x27, + 0x03, 0x32, 0x87, 0x84, 0xa0, 0x6f, 0x21, 0x6f, 0x7b, 0xd1, 0xf2, 0xe9, 0x0b, 0xf4, 0xd6, 0x55, + 0x17, 0x55, 0x03, 0x65, 0xed, 0x07, 0x2f, 0xff, 0xda, 0x4b, 0xfd, 0xf6, 0xf7, 0x5e, 0xc3, 0xa5, + 0x72, 0x12, 0x8c, 0x4c, 0x87, 0x7b, 0xcd, 0x98, 0xa6, 0x7f, 0x3e, 0x12, 0xe3, 0x73, 0xfd, 0xd7, + 0x1c, 0x09, 0x04, 0xd6, 0xa6, 0x68, 0x17, 0x8a, 0xae, 0x2d, 0xac, 0x29, 0xf5, 0xa8, 0x54, 0xdd, + 0xce, 0xe2, 0x82, 0x6b, 0x8b, 0xe3, 0xe8, 0xf9, 0x03, 0x01, 0x85, 0xa4, 0x49, 0x68, 0x07, 0xb6, + 0x07, 0xbd, 0x27, 0x7d, 0xeb, 0xe4, 0xf4, 0xa0, 0x6b, 0x3d, 0xeb, 0x0f, 0x9e, 0x76, 0x3b, 0xbd, + 0xc3, 0x5e, 0xf7, 0xa0, 0x94, 0x42, 0x5b, 0x50, 0x5a, 0xbe, 0x3a, 0xe8, 0xe1, 0x6e, 0x67, 0x58, + 0x32, 0xd0, 0x36, 0x6c, 0x2e, 0xd1, 0x61, 0xf7, 0xeb, 0xe1, 0xb3, 0xd6, 0x71, 0x29, 0x8d, 0xf6, + 0x60, 0x77, 0x09, 0x1f, 0x77, 0x9f, 0xb4, 0x3a, 0xdf, 0x58, 0xad, 0x93, 0x5e, 0xff, 0xd4, 0xfa, + 0x72, 0x70, 0xda, 0x2f, 0xfd, 0xd8, 0x7e, 0xfc, 0xf2, 0xa2, 0x6a, 0xbc, 0xba, 0xa8, 0x1a, 0xff, + 0x5c, 0x54, 0x8d, 0x5f, 0x2e, 0xab, 0xa9, 0x57, 0x97, 0xd5, 0xd4, 0x9f, 0x97, 0xd5, 0xd4, 0xf3, + 0xfd, 0xdb, 0x4f, 0xa7, 0x3f, 0x71, 0xa3, 0xbc, 0xda, 0xd7, 0x4f, 0xfe, 0x0b, 0x00, 0x00, 0xff, + 0xff, 0x00, 0xca, 0xa5, 0x82, 0xfb, 0x06, 0x00, 0x00, } func (m *Tx) Marshal() (dAtA []byte, err error) { @@ -796,6 +858,52 @@ func (m *Tx) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } +func (m *TxRaw) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *TxRaw) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TxRaw) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Signatures) > 0 { + for iNdEx := len(m.Signatures) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Signatures[iNdEx]) + copy(dAtA[i:], m.Signatures[iNdEx]) + i = encodeVarintTypes(dAtA, i, uint64(len(m.Signatures[iNdEx]))) + i-- + dAtA[i] = 0x1a + } + } + if len(m.AuthInfoBytes) > 0 { + i -= len(m.AuthInfoBytes) + copy(dAtA[i:], m.AuthInfoBytes) + i = encodeVarintTypes(dAtA, i, uint64(len(m.AuthInfoBytes))) + i-- + dAtA[i] = 0x12 + } + if len(m.BodyBytes) > 0 { + i -= len(m.BodyBytes) + copy(dAtA[i:], m.BodyBytes) + i = encodeVarintTypes(dAtA, i, uint64(len(m.BodyBytes))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + func (m *SignDoc) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) @@ -833,27 +941,17 @@ func (m *SignDoc) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x1a } - if m.AuthInfo != nil { - { - size, err := m.AuthInfo.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTypes(dAtA, i, uint64(size)) - } + if len(m.AuthInfoBytes) > 0 { + i -= len(m.AuthInfoBytes) + copy(dAtA[i:], m.AuthInfoBytes) + i = encodeVarintTypes(dAtA, i, uint64(len(m.AuthInfoBytes))) i-- dAtA[i] = 0x12 } - if m.Body != nil { - { - size, err := m.Body.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTypes(dAtA, i, uint64(size)) - } + if len(m.BodyBytes) > 0 { + i -= len(m.BodyBytes) + copy(dAtA[i:], m.BodyBytes) + i = encodeVarintTypes(dAtA, i, uint64(len(m.BodyBytes))) i-- dAtA[i] = 0xa } @@ -1264,18 +1362,41 @@ func (m *Tx) Size() (n int) { return n } +func (m *TxRaw) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.BodyBytes) + if l > 0 { + n += 1 + l + sovTypes(uint64(l)) + } + l = len(m.AuthInfoBytes) + if l > 0 { + n += 1 + l + sovTypes(uint64(l)) + } + if len(m.Signatures) > 0 { + for _, b := range m.Signatures { + l = len(b) + n += 1 + l + sovTypes(uint64(l)) + } + } + return n +} + func (m *SignDoc) Size() (n int) { if m == nil { return 0 } var l int _ = l - if m.Body != nil { - l = m.Body.Size() + l = len(m.BodyBytes) + if l > 0 { n += 1 + l + sovTypes(uint64(l)) } - if m.AuthInfo != nil { - l = m.AuthInfo.Size() + l = len(m.AuthInfoBytes) + if l > 0 { n += 1 + l + sovTypes(uint64(l)) } l = len(m.ChainId) @@ -1609,6 +1730,159 @@ func (m *Tx) Unmarshal(dAtA []byte) error { } return nil } +func (m *TxRaw) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTypes + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: TxRaw: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: TxRaw: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field BodyBytes", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTypes + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthTypes + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthTypes + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.BodyBytes = append(m.BodyBytes[:0], dAtA[iNdEx:postIndex]...) + if m.BodyBytes == nil { + m.BodyBytes = []byte{} + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AuthInfoBytes", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTypes + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthTypes + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthTypes + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.AuthInfoBytes = append(m.AuthInfoBytes[:0], dAtA[iNdEx:postIndex]...) + if m.AuthInfoBytes == nil { + m.AuthInfoBytes = []byte{} + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Signatures", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTypes + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthTypes + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthTypes + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Signatures = append(m.Signatures, make([]byte, postIndex-iNdEx)) + copy(m.Signatures[len(m.Signatures)-1], dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipTypes(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthTypes + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthTypes + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func (m *SignDoc) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 @@ -1640,9 +1914,9 @@ func (m *SignDoc) Unmarshal(dAtA []byte) error { switch fieldNum { case 1: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field BodyBytes", wireType) } - var msglen int + var byteLen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTypes @@ -1652,33 +1926,31 @@ func (m *SignDoc) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + byteLen |= int(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + if byteLen < 0 { return ErrInvalidLengthTypes } - postIndex := iNdEx + msglen + postIndex := iNdEx + byteLen if postIndex < 0 { return ErrInvalidLengthTypes } if postIndex > l { return io.ErrUnexpectedEOF } - if m.Body == nil { - m.Body = &TxBody{} - } - if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + m.BodyBytes = append(m.BodyBytes[:0], dAtA[iNdEx:postIndex]...) + if m.BodyBytes == nil { + m.BodyBytes = []byte{} } iNdEx = postIndex case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AuthInfo", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field AuthInfoBytes", wireType) } - var msglen int + var byteLen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTypes @@ -1688,26 +1960,24 @@ func (m *SignDoc) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + byteLen |= int(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + if byteLen < 0 { return ErrInvalidLengthTypes } - postIndex := iNdEx + msglen + postIndex := iNdEx + byteLen if postIndex < 0 { return ErrInvalidLengthTypes } if postIndex > l { return io.ErrUnexpectedEOF } - if m.AuthInfo == nil { - m.AuthInfo = &AuthInfo{} - } - if err := m.AuthInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + m.AuthInfoBytes = append(m.AuthInfoBytes[:0], dAtA[iNdEx:postIndex]...) + if m.AuthInfoBytes == nil { + m.AuthInfoBytes = []byte{} } iNdEx = postIndex case 3: @@ -2192,7 +2462,7 @@ func (m *SignerInfo) Unmarshal(dAtA []byte) error { return io.ErrUnexpectedEOF } if m.PublicKey == nil { - m.PublicKey = &types.Any{} + m.PublicKey = &types1.PublicKey{} } if err := m.PublicKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err diff --git a/types/tx/types.proto b/types/tx/types.proto index 51ec4da84390..6f7fb14c3450 100644 --- a/types/tx/types.proto +++ b/types/tx/types.proto @@ -21,13 +21,19 @@ message Tx { repeated bytes signatures = 3; } -// SignDoc is the standard type used for signing transaction in SIGN_MODE_DIRECT +message TxRaw { + bytes body_bytes = 1; + + bytes auth_info_bytes = 2; + + // signatures are the raw binary signatures of signers specified by body and auth_info + repeated bytes signatures = 3; +} + message SignDoc { - // body is the TxBody from Tx - TxBody body = 1; + bytes body_bytes = 1; - // auth_info is the AuthInfo from Tx - AuthInfo auth_info = 2; + bytes auth_info_bytes = 2; // chain_id is the unique identifier of the chain this transaction targets. // It prevents signed transactions from being used on another chain by an @@ -81,7 +87,7 @@ message AuthInfo { message SignerInfo { // public_key is the public key of the signer. It is optional for accounts // that already exist in state - google.protobuf.Any public_key = 1; + cosmos_sdk.crypto.v1.PublicKey public_key = 1; // mode_info describes the signing mode of the signer and is a nested // structure to support nested multisig pubkey's diff --git a/x/auth/signing/direct/direct.go b/x/auth/signing/direct/direct.go new file mode 100644 index 000000000000..544727cce2f1 --- /dev/null +++ b/x/auth/signing/direct/direct.go @@ -0,0 +1,42 @@ +package direct + +import ( + "fmt" + + sdk "github.com/cosmos/cosmos-sdk/types" + types "github.com/cosmos/cosmos-sdk/types/tx" + "github.com/cosmos/cosmos-sdk/x/auth/signing" +) + +type DirectModeHandler struct{} + +func (h DirectModeHandler) DefaultMode() types.SignMode { + return types.SignMode_SIGN_MODE_DIRECT +} + +var _ signing.SignModeHandler = DirectModeHandler{} + +func (DirectModeHandler) Modes() []types.SignMode { + return []types.SignMode{types.SignMode_SIGN_MODE_DIRECT} +} + +func (DirectModeHandler) GetSignBytes(mode types.SignMode, data signing.SignerData, tx sdk.Tx) ([]byte, error) { + protoTx, ok := tx.(types.ProtoTx) + if !ok { + return nil, fmt.Errorf("can only get direct sign bytes for a ProtoTx, got %T", tx) + } + bodyBz := protoTx.GetBodyBytes() + authInfoBz := protoTx.GetAuthInfoBytes() + return DirectSignBytes(bodyBz, authInfoBz, data.ChainID, data.AccountNumber, data.AccountSequence) +} + +func DirectSignBytes(bodyBz, authInfoBz []byte, chainID string, accnum, sequence uint64) ([]byte, error) { + signDoc := types.SignDoc{ + BodyBytes: bodyBz, + AuthInfoBytes: authInfoBz, + ChainId: chainID, + AccountNumber: accnum, + AccountSequence: sequence, + } + return signDoc.Marshal() +} diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go new file mode 100644 index 000000000000..66bd8505d649 --- /dev/null +++ b/x/auth/signing/direct/direct_test.go @@ -0,0 +1,7 @@ +package direct + +import "testing" + +func TestDirectModeHandler(t *testing.T) { + +} diff --git a/x/bank/types/query.pb.go b/x/bank/types/query.pb.go index b9223cf7e00f..bd25ff3fb91a 100644 --- a/x/bank/types/query.pb.go +++ b/x/bank/types/query.pb.go @@ -30,7 +30,7 @@ var _ = math.Inf // proto package needs to be updated. const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package -// QueryBalanceRequest is the request type for the Query.Balance RPC method +// QueryBalanceRequest is the request type for the Query/Balance RPC method type QueryBalanceRequest struct { // address is the address to query balances for Address github_com_cosmos_cosmos_sdk_types.AccAddress `protobuf:"bytes,1,opt,name=address,proto3,casttype=github.com/cosmos/cosmos-sdk/types.AccAddress" json:"address,omitempty"` @@ -85,7 +85,7 @@ func (m *QueryBalanceRequest) GetDenom() string { return "" } -// QueryBalanceResponse is the response type for the Query.Balance RPC method +// QueryBalanceResponse is the response type for the Query/Balance RPC method type QueryBalanceResponse struct { // balance is the balance of the coin Balance *types.Coin `protobuf:"bytes,1,opt,name=balance,proto3" json:"balance,omitempty"` @@ -131,7 +131,7 @@ func (m *QueryBalanceResponse) GetBalance() *types.Coin { return nil } -// QueryBalanceRequest is the request type for the Query.AllBalances RPC method +// QueryBalanceRequest is the request type for the Query/AllBalances RPC method type QueryAllBalancesRequest struct { // address is the address to query balances for Address github_com_cosmos_cosmos_sdk_types.AccAddress `protobuf:"bytes,1,opt,name=address,proto3,casttype=github.com/cosmos/cosmos-sdk/types.AccAddress" json:"address,omitempty"` @@ -177,7 +177,7 @@ func (m *QueryAllBalancesRequest) GetAddress() github_com_cosmos_cosmos_sdk_type return nil } -// QueryAllBalancesResponse is the response type for the Query.AllBalances RPC method +// QueryAllBalancesResponse is the response type for the Query/AllBalances RPC method type QueryAllBalancesResponse struct { // balances is the balances of the coins Balances github_com_cosmos_cosmos_sdk_types.Coins `protobuf:"bytes,1,rep,name=balances,proto3,castrepeated=github.com/cosmos/cosmos-sdk/types.Coins" json:"balances"` @@ -223,7 +223,7 @@ func (m *QueryAllBalancesResponse) GetBalances() github_com_cosmos_cosmos_sdk_ty return nil } -// QueryTotalSupplyRequest is the request type for the Query.TotalSupply RPC method +// QueryTotalSupplyRequest is the request type for the Query/TotalSupply RPC method type QueryTotalSupplyRequest struct { } @@ -260,7 +260,7 @@ func (m *QueryTotalSupplyRequest) XXX_DiscardUnknown() { var xxx_messageInfo_QueryTotalSupplyRequest proto.InternalMessageInfo -// QueryTotalSupplyResponse is the response type for the Query.TotalSupply RPC method +// QueryTotalSupplyResponse is the response type for the Query/TotalSupply RPC method type QueryTotalSupplyResponse struct { // supply is the supply of the coins Supply github_com_cosmos_cosmos_sdk_types.Coins `protobuf:"bytes,1,rep,name=supply,proto3,castrepeated=github.com/cosmos/cosmos-sdk/types.Coins" json:"supply"` @@ -306,7 +306,7 @@ func (m *QueryTotalSupplyResponse) GetSupply() github_com_cosmos_cosmos_sdk_type return nil } -// QuerySupplyOfRequest is the request type for the Query.SupplyOf RPC method +// QuerySupplyOfRequest is the request type for the Query/SupplyOf RPC method type QuerySupplyOfRequest struct { Denom string `protobuf:"bytes,1,opt,name=denom,proto3" json:"denom,omitempty"` } @@ -351,7 +351,7 @@ func (m *QuerySupplyOfRequest) GetDenom() string { return "" } -// QuerySupplyOfResponse is the response type for the Query.SupplyOf RPC method +// QuerySupplyOfResponse is the response type for the Query/SupplyOf RPC method type QuerySupplyOfResponse struct { // amount is the supply of the coin Amount github_com_cosmos_cosmos_sdk_types.Int `protobuf:"bytes,1,opt,name=amount,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Int" json:"amount"` From e2f344aaffe45ee934ca124dfbd095e66e1c8fd4 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Wed, 10 Jun 2020 09:59:30 -0400 Subject: [PATCH 02/43] fix pkg name --- types/tx/tx_decoder.go | 5 +- types/tx/tx_encoder.go | 2 +- types/tx/{tx_builder.go => tx_wrapper.go} | 5 +- types/tx/types.go | 2 +- types/tx/types.pb.go | 112 +++++++++++----------- types/tx/types.proto | 2 +- 6 files changed, 65 insertions(+), 63 deletions(-) rename types/tx/{tx_builder.go => tx_wrapper.go} (99%) diff --git a/types/tx/tx_decoder.go b/types/tx/tx_decoder.go index 630eea702d88..d743ed56c852 100644 --- a/types/tx/tx_decoder.go +++ b/types/tx/tx_decoder.go @@ -1,10 +1,11 @@ -package types +package tx import ( + "github.com/tendermint/tendermint/crypto" + "github.com/cosmos/cosmos-sdk/codec" cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types" sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/tendermint/tendermint/crypto" ) func DefaultTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCodec) sdk.TxDecoder { diff --git a/types/tx/tx_encoder.go b/types/tx/tx_encoder.go index 9272e8f084cb..89533e98b628 100644 --- a/types/tx/tx_encoder.go +++ b/types/tx/tx_encoder.go @@ -1,4 +1,4 @@ -package types +package tx import ( "fmt" diff --git a/types/tx/tx_builder.go b/types/tx/tx_wrapper.go similarity index 99% rename from types/tx/tx_builder.go rename to types/tx/tx_wrapper.go index c049846e2476..4054485d7dbe 100644 --- a/types/tx/tx_builder.go +++ b/types/tx/tx_wrapper.go @@ -1,13 +1,14 @@ -package types +package tx import ( "fmt" + "github.com/tendermint/tendermint/crypto" + "github.com/cosmos/cosmos-sdk/codec" "github.com/cosmos/cosmos-sdk/crypto/types" sdk "github.com/cosmos/cosmos-sdk/types" sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/tendermint/tendermint/crypto" ) type txWrapper struct { diff --git a/types/tx/types.go b/types/tx/types.go index 9ff0f2e04212..6d779ea300e0 100644 --- a/types/tx/types.go +++ b/types/tx/types.go @@ -1,4 +1,4 @@ -package types +package tx import ( codectypes "github.com/cosmos/cosmos-sdk/codec/types" diff --git a/types/tx/types.pb.go b/types/tx/types.pb.go index 501387490c63..3c7d24fbced5 100644 --- a/types/tx/types.pb.go +++ b/types/tx/types.pb.go @@ -1,7 +1,7 @@ // Code generated by protoc-gen-gogo. DO NOT EDIT. // source: types/tx/types.proto -package types +package tx import ( fmt "fmt" @@ -743,63 +743,63 @@ func init() { func init() { proto.RegisterFile("types/tx/types.proto", fileDescriptor_1c6ac8fa65877134) } var fileDescriptor_1c6ac8fa65877134 = []byte{ - // 889 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x55, 0xcf, 0x6f, 0xe3, 0x44, - 0x14, 0x8e, 0xf3, 0xab, 0xc9, 0x6b, 0xbb, 0x4d, 0x87, 0x56, 0x4a, 0x53, 0x48, 0x43, 0xa4, 0x2e, + // 887 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x54, 0xcf, 0x6f, 0xe3, 0x44, + 0x14, 0x8e, 0xf3, 0xab, 0xc9, 0x6b, 0xbb, 0x4d, 0x87, 0x56, 0x72, 0x53, 0x48, 0x43, 0xa4, 0x2e, 0x01, 0x81, 0xb3, 0x2c, 0x07, 0x16, 0x21, 0xb1, 0x4a, 0xd2, 0x74, 0x1b, 0x68, 0xd3, 0xd5, 0x24, - 0x2b, 0xc1, 0x4a, 0xc8, 0x72, 0x9c, 0xa9, 0x33, 0x6a, 0x3c, 0x13, 0x3c, 0x63, 0x88, 0x4f, 0x88, + 0x2b, 0xc1, 0x4a, 0xc8, 0x72, 0xec, 0xa9, 0x33, 0x6a, 0x3c, 0x13, 0x3c, 0x63, 0x88, 0x4f, 0x88, 0xc3, 0x9e, 0xb8, 0x70, 0xe1, 0x9f, 0xe0, 0x7f, 0xe0, 0xbe, 0xe2, 0xb4, 0x47, 0x4e, 0x80, 0xda, - 0x3f, 0x04, 0xe4, 0xf1, 0x38, 0xa9, 0xb6, 0xa5, 0xbd, 0xec, 0x29, 0xcf, 0x9f, 0xbf, 0xef, 0x7b, - 0x6f, 0xde, 0x9b, 0x17, 0xc3, 0x96, 0x0c, 0x67, 0x44, 0x34, 0xe5, 0xbc, 0xa9, 0x02, 0x73, 0xe6, - 0x73, 0xc9, 0x51, 0xc9, 0xe1, 0xc2, 0xe3, 0xc2, 0x12, 0xe3, 0x73, 0x53, 0xce, 0xcd, 0xef, 0x3f, - 0xae, 0xdc, 0x97, 0x13, 0xea, 0x8f, 0xad, 0x99, 0xed, 0xcb, 0xb0, 0xa9, 0x48, 0x4d, 0x97, 0xbb, - 0x7c, 0x19, 0xc5, 0xca, 0x4a, 0xd9, 0xf1, 0xc3, 0x99, 0xe4, 0x4d, 0x6d, 0xbb, 0xf4, 0xac, 0x6c, - 0x5e, 0x87, 0x76, 0x5c, 0xce, 0xdd, 0x29, 0x89, 0xfd, 0x46, 0xc1, 0x59, 0xd3, 0x66, 0x61, 0xfc, - 0xaa, 0xfe, 0xb3, 0x01, 0xe9, 0xe1, 0x1c, 0x7d, 0x08, 0xd9, 0x11, 0x1f, 0x87, 0x65, 0xa3, 0x66, - 0x34, 0x56, 0x1f, 0x96, 0xcd, 0xd7, 0xeb, 0x32, 0x87, 0xf3, 0x36, 0x1f, 0x87, 0x58, 0xb1, 0xd0, - 0xa7, 0x50, 0xb4, 0x03, 0x39, 0xb1, 0x28, 0x3b, 0xe3, 0xe5, 0xb4, 0x92, 0x54, 0xae, 0x4b, 0x5a, - 0x81, 0x9c, 0xf4, 0xd8, 0x19, 0xc7, 0x05, 0x5b, 0x47, 0xa8, 0x0a, 0x20, 0xa8, 0xcb, 0x6c, 0x19, - 0xf8, 0x44, 0x94, 0x33, 0xb5, 0x4c, 0x63, 0x0d, 0x5f, 0x41, 0xea, 0x0c, 0x72, 0xc3, 0x39, 0xb6, - 0x7f, 0x40, 0xef, 0x00, 0x44, 0x99, 0xac, 0x51, 0x28, 0x89, 0x50, 0x55, 0xad, 0xe1, 0x62, 0x84, - 0xb4, 0x23, 0x00, 0xdd, 0x87, 0x8d, 0x45, 0x01, 0x9a, 0x93, 0x56, 0x9c, 0xf5, 0x24, 0x55, 0xcc, - 0xbb, 0x2b, 0xdf, 0xef, 0x06, 0xac, 0x0c, 0xa8, 0xcb, 0x0e, 0xb8, 0xf3, 0xa6, 0x52, 0xee, 0x40, - 0xc1, 0x99, 0xd8, 0x94, 0x59, 0x74, 0x5c, 0xce, 0xd4, 0x8c, 0x46, 0x11, 0xaf, 0xa8, 0xe7, 0xde, - 0x18, 0xed, 0xc3, 0x3d, 0xdb, 0x71, 0x78, 0xc0, 0xa4, 0xc5, 0x02, 0x6f, 0x44, 0xfc, 0x72, 0xb6, - 0x66, 0x34, 0xb2, 0x78, 0x5d, 0xa3, 0x7d, 0x05, 0xa2, 0xf7, 0xa1, 0x94, 0xd0, 0x04, 0xf9, 0x2e, - 0x20, 0xcc, 0x21, 0xe5, 0x9c, 0x22, 0x6e, 0x68, 0x7c, 0xa0, 0xe1, 0xfa, 0xaf, 0x69, 0xc8, 0xc7, - 0x93, 0x41, 0x0f, 0xa0, 0xe0, 0x11, 0x21, 0x6c, 0x57, 0x15, 0x9f, 0x69, 0xac, 0x3e, 0xdc, 0x32, - 0xe3, 0xb1, 0x9b, 0xc9, 0xd8, 0xcd, 0x16, 0x0b, 0xf1, 0x82, 0x85, 0x10, 0x64, 0x3d, 0xe2, 0xc5, - 0x03, 0x2c, 0x62, 0x15, 0x47, 0x25, 0x4a, 0xea, 0x11, 0x1e, 0x48, 0x6b, 0x42, 0xa8, 0x3b, 0x91, - 0xea, 0x0c, 0x19, 0xbc, 0xae, 0xd1, 0x23, 0x05, 0xa2, 0x36, 0x6c, 0x92, 0xb9, 0x24, 0x4c, 0x50, - 0xce, 0x2c, 0x3e, 0x93, 0x94, 0x33, 0x51, 0xfe, 0x77, 0xe5, 0x96, 0xb4, 0xa5, 0x05, 0xff, 0x34, - 0xa6, 0xa3, 0xe7, 0x50, 0x65, 0x9c, 0x59, 0x8e, 0x4f, 0x25, 0x75, 0xec, 0xa9, 0x75, 0x83, 0xe1, - 0xc6, 0x2d, 0x86, 0xbb, 0x8c, 0xb3, 0x8e, 0xd6, 0x76, 0x5f, 0xf3, 0xae, 0x4b, 0x28, 0x24, 0xb7, - 0x0f, 0x3d, 0x86, 0xb5, 0x68, 0xe2, 0xc4, 0x57, 0xa3, 0x4b, 0x9a, 0xf3, 0xf6, 0xf5, 0xfb, 0x3a, - 0x50, 0x2c, 0x75, 0x63, 0x57, 0xc5, 0x22, 0x16, 0xe8, 0x3d, 0xc8, 0x9c, 0x11, 0xa2, 0xef, 0xf9, - 0xf6, 0x75, 0xdd, 0x21, 0x21, 0x38, 0x62, 0xd4, 0x5f, 0x18, 0x00, 0x4b, 0x13, 0xf4, 0x05, 0xc0, - 0x2c, 0x18, 0x4d, 0xa9, 0x63, 0x9d, 0x93, 0x64, 0xb3, 0xf6, 0xae, 0xca, 0xe3, 0x15, 0x8e, 0x2c, - 0x9e, 0x2a, 0xde, 0x57, 0x24, 0xc4, 0xc5, 0x59, 0x12, 0x46, 0x5b, 0xe6, 0xf1, 0x31, 0xb9, 0x63, - 0xcb, 0x4e, 0xf8, 0x98, 0xc4, 0x5b, 0xe6, 0xe9, 0xa8, 0xfe, 0x47, 0x1a, 0x0a, 0x09, 0x8c, 0x3e, - 0x87, 0xbc, 0xa0, 0xcc, 0x9d, 0x12, 0x5d, 0xc1, 0xbb, 0xff, 0x6f, 0x61, 0x0e, 0x14, 0xf1, 0x28, - 0x85, 0xb5, 0x04, 0x3d, 0x82, 0x9c, 0x17, 0x4c, 0x25, 0xd5, 0xe9, 0x6b, 0xb7, 0x68, 0x4f, 0x22, - 0xde, 0x51, 0x0a, 0xc7, 0x82, 0xca, 0x23, 0xc8, 0xc7, 0x6e, 0xc8, 0x84, 0x6c, 0x54, 0x99, 0x4a, - 0x7f, 0xef, 0xa6, 0x13, 0x44, 0x2d, 0x8b, 0x6c, 0xb0, 0xe2, 0x55, 0x5e, 0x18, 0x90, 0x53, 0x66, - 0xa8, 0x05, 0x85, 0x11, 0x95, 0xb6, 0xef, 0xdb, 0x49, 0xfb, 0xf6, 0x6f, 0x6e, 0x5f, 0x87, 0x7b, - 0x33, 0xdb, 0x91, 0x6d, 0x2a, 0x5b, 0x11, 0x19, 0x2f, 0x64, 0xe8, 0x33, 0x80, 0x45, 0x0f, 0xa3, - 0x85, 0xcd, 0xdc, 0xd1, 0xc4, 0x62, 0xd2, 0x44, 0xd1, 0xce, 0x41, 0x46, 0x04, 0x5e, 0xfd, 0x27, - 0x03, 0x32, 0x87, 0x84, 0xa0, 0x6f, 0x21, 0x6f, 0x7b, 0xd1, 0xf2, 0xe9, 0x0b, 0xf4, 0xd6, 0x55, - 0x17, 0x55, 0x03, 0x65, 0xed, 0x07, 0x2f, 0xff, 0xda, 0x4b, 0xfd, 0xf6, 0xf7, 0x5e, 0xc3, 0xa5, - 0x72, 0x12, 0x8c, 0x4c, 0x87, 0x7b, 0xcd, 0x98, 0xa6, 0x7f, 0x3e, 0x12, 0xe3, 0x73, 0xfd, 0xd7, - 0x1c, 0x09, 0x04, 0xd6, 0xa6, 0x68, 0x17, 0x8a, 0xae, 0x2d, 0xac, 0x29, 0xf5, 0xa8, 0x54, 0xdd, - 0xce, 0xe2, 0x82, 0x6b, 0x8b, 0xe3, 0xe8, 0xf9, 0x03, 0x01, 0x85, 0xa4, 0x49, 0x68, 0x07, 0xb6, - 0x07, 0xbd, 0x27, 0x7d, 0xeb, 0xe4, 0xf4, 0xa0, 0x6b, 0x3d, 0xeb, 0x0f, 0x9e, 0x76, 0x3b, 0xbd, - 0xc3, 0x5e, 0xf7, 0xa0, 0x94, 0x42, 0x5b, 0x50, 0x5a, 0xbe, 0x3a, 0xe8, 0xe1, 0x6e, 0x67, 0x58, - 0x32, 0xd0, 0x36, 0x6c, 0x2e, 0xd1, 0x61, 0xf7, 0xeb, 0xe1, 0xb3, 0xd6, 0x71, 0x29, 0x8d, 0xf6, - 0x60, 0x77, 0x09, 0x1f, 0x77, 0x9f, 0xb4, 0x3a, 0xdf, 0x58, 0xad, 0x93, 0x5e, 0xff, 0xd4, 0xfa, - 0x72, 0x70, 0xda, 0x2f, 0xfd, 0xd8, 0x7e, 0xfc, 0xf2, 0xa2, 0x6a, 0xbc, 0xba, 0xa8, 0x1a, 0xff, - 0x5c, 0x54, 0x8d, 0x5f, 0x2e, 0xab, 0xa9, 0x57, 0x97, 0xd5, 0xd4, 0x9f, 0x97, 0xd5, 0xd4, 0xf3, - 0xfd, 0xdb, 0x4f, 0xa7, 0x3f, 0x71, 0xa3, 0xbc, 0xda, 0xd7, 0x4f, 0xfe, 0x0b, 0x00, 0x00, 0xff, - 0xff, 0x00, 0xca, 0xa5, 0x82, 0xfb, 0x06, 0x00, 0x00, + 0x3f, 0x04, 0xe4, 0xb1, 0x9d, 0x54, 0xdb, 0xd2, 0x5e, 0xf6, 0x94, 0xe7, 0xcf, 0xdf, 0xf7, 0xbd, + 0xe7, 0xf7, 0x23, 0xb0, 0x25, 0xc3, 0x19, 0x11, 0x2d, 0x39, 0x6f, 0xa9, 0xc0, 0x98, 0xf9, 0x5c, + 0x72, 0x54, 0xb1, 0xb9, 0xf0, 0xb8, 0x30, 0x85, 0x73, 0x6e, 0xc8, 0xb9, 0xf1, 0xfd, 0xc7, 0xd5, + 0xfb, 0x72, 0x42, 0x7d, 0xc7, 0x9c, 0x59, 0xbe, 0x0c, 0x5b, 0x8a, 0xd4, 0x72, 0xb9, 0xcb, 0x97, + 0x51, 0xac, 0xac, 0xea, 0xb6, 0x1f, 0xce, 0x24, 0x6f, 0x25, 0xb6, 0x4b, 0xcf, 0xea, 0xe6, 0x75, + 0x68, 0xc7, 0xe5, 0xdc, 0x9d, 0x92, 0xd8, 0x6f, 0x1c, 0x9c, 0xb5, 0x2c, 0x16, 0xc6, 0xaf, 0x1a, + 0x3f, 0x6b, 0x90, 0x1d, 0xcd, 0xd1, 0x87, 0x90, 0x1f, 0x73, 0x27, 0xd4, 0xb5, 0xba, 0xd6, 0x5c, + 0x7d, 0xa8, 0x1b, 0xaf, 0xd7, 0x65, 0x8c, 0xe6, 0x1d, 0xee, 0x84, 0x58, 0xb1, 0xd0, 0xa7, 0x50, + 0xb6, 0x02, 0x39, 0x31, 0x29, 0x3b, 0xe3, 0x7a, 0x56, 0x49, 0xaa, 0xd7, 0x25, 0xed, 0x40, 0x4e, + 0xfa, 0xec, 0x8c, 0xe3, 0x92, 0x95, 0x44, 0xa8, 0x06, 0x20, 0xa8, 0xcb, 0x2c, 0x19, 0xf8, 0x44, + 0xe8, 0xb9, 0x7a, 0xae, 0xb9, 0x86, 0xaf, 0x20, 0x0d, 0x06, 0x85, 0xd1, 0x1c, 0x5b, 0x3f, 0xa0, + 0x77, 0x00, 0xa2, 0x4c, 0xe6, 0x38, 0x94, 0x44, 0xa8, 0xaa, 0xd6, 0x70, 0x39, 0x42, 0x3a, 0x11, + 0x80, 0xee, 0xc3, 0xc6, 0xa2, 0x80, 0x84, 0x93, 0x55, 0x9c, 0xf5, 0x34, 0x55, 0xcc, 0xbb, 0x2b, + 0xdf, 0xef, 0x1a, 0xac, 0x0c, 0xa9, 0xcb, 0x0e, 0xb8, 0xfd, 0xa6, 0x52, 0xee, 0x40, 0xc9, 0x9e, + 0x58, 0x94, 0x99, 0xd4, 0xd1, 0x73, 0x75, 0xad, 0x59, 0xc6, 0x2b, 0xea, 0xb9, 0xef, 0xa0, 0x7d, + 0xb8, 0x67, 0xd9, 0x36, 0x0f, 0x98, 0x34, 0x59, 0xe0, 0x8d, 0x89, 0xaf, 0xe7, 0xeb, 0x5a, 0x33, + 0x8f, 0xd7, 0x13, 0x74, 0xa0, 0x40, 0xf4, 0x3e, 0x54, 0x52, 0x9a, 0x20, 0xdf, 0x05, 0x84, 0xd9, + 0x44, 0x2f, 0x28, 0xe2, 0x46, 0x82, 0x0f, 0x13, 0xb8, 0xf1, 0x6b, 0x16, 0x8a, 0xf1, 0x64, 0xd0, + 0x03, 0x28, 0x79, 0x44, 0x08, 0xcb, 0x55, 0xc5, 0xe7, 0x9a, 0xab, 0x0f, 0xb7, 0x8c, 0x78, 0xec, + 0x46, 0x3a, 0x76, 0xa3, 0xcd, 0x42, 0xbc, 0x60, 0x21, 0x04, 0x79, 0x8f, 0x78, 0xf1, 0x00, 0xcb, + 0x58, 0xc5, 0x51, 0x89, 0x92, 0x7a, 0x84, 0x07, 0xd2, 0x9c, 0x10, 0xea, 0x4e, 0xa4, 0xfa, 0x86, + 0x1c, 0x5e, 0x4f, 0xd0, 0x23, 0x05, 0xa2, 0x0e, 0x6c, 0x92, 0xb9, 0x24, 0x4c, 0x50, 0xce, 0x4c, + 0x3e, 0x93, 0x94, 0x33, 0xa1, 0xff, 0xbb, 0x72, 0x4b, 0xda, 0xca, 0x82, 0x7f, 0x1a, 0xd3, 0xd1, + 0x73, 0xa8, 0x31, 0xce, 0x4c, 0xdb, 0xa7, 0x92, 0xda, 0xd6, 0xd4, 0xbc, 0xc1, 0x70, 0xe3, 0x16, + 0xc3, 0x5d, 0xc6, 0x59, 0x37, 0xd1, 0xf6, 0x5e, 0xf3, 0x6e, 0x48, 0x28, 0xa5, 0xdb, 0x87, 0x1e, + 0xc3, 0x5a, 0x34, 0x71, 0xe2, 0xab, 0xd1, 0xa5, 0xcd, 0x79, 0xfb, 0xfa, 0xbe, 0x0e, 0x15, 0x4b, + 0x6d, 0xec, 0xaa, 0x58, 0xc4, 0x02, 0xbd, 0x07, 0xb9, 0x33, 0x42, 0x92, 0x3d, 0xdf, 0xbe, 0xae, + 0x3b, 0x24, 0x04, 0x47, 0x8c, 0xc6, 0x0b, 0x0d, 0x60, 0x69, 0x82, 0xbe, 0x00, 0x98, 0x05, 0xe3, + 0x29, 0xb5, 0xcd, 0x73, 0x92, 0x5e, 0xd6, 0xde, 0x55, 0x79, 0x7c, 0xc2, 0x91, 0xc5, 0x53, 0xc5, + 0xfb, 0x8a, 0x84, 0xb8, 0x3c, 0x4b, 0xc3, 0xe8, 0xca, 0x3c, 0xee, 0x90, 0x3b, 0xae, 0xec, 0x84, + 0x3b, 0x24, 0xbe, 0x32, 0x2f, 0x89, 0x1a, 0x7f, 0x64, 0xa1, 0x94, 0xc2, 0xe8, 0x73, 0x28, 0x0a, + 0xca, 0xdc, 0x29, 0x49, 0x2a, 0x78, 0xf7, 0xff, 0x2d, 0x8c, 0xa1, 0x22, 0x1e, 0x65, 0x70, 0x22, + 0x41, 0x8f, 0xa0, 0xe0, 0x05, 0x53, 0x49, 0x93, 0xf4, 0xf5, 0x5b, 0xb4, 0x27, 0x11, 0xef, 0x28, + 0x83, 0x63, 0x41, 0xf5, 0x11, 0x14, 0x63, 0x37, 0x64, 0x40, 0x3e, 0xaa, 0x4c, 0xa5, 0xbf, 0x77, + 0xd3, 0x17, 0x44, 0x2d, 0x8b, 0x6c, 0xb0, 0xe2, 0x55, 0x5f, 0x68, 0x50, 0x50, 0x66, 0xa8, 0x0d, + 0xa5, 0x31, 0x95, 0x96, 0xef, 0x5b, 0x69, 0xfb, 0xf6, 0x6f, 0x6e, 0x5f, 0x97, 0x7b, 0x33, 0xcb, + 0x96, 0x1d, 0x2a, 0xdb, 0x11, 0x19, 0x2f, 0x64, 0xe8, 0x33, 0x80, 0x45, 0x0f, 0xa3, 0x83, 0xcd, + 0xdd, 0xd1, 0xc4, 0x72, 0xda, 0x44, 0xd1, 0x29, 0x40, 0x4e, 0x04, 0x5e, 0xe3, 0x27, 0x0d, 0x72, + 0x87, 0x84, 0xa0, 0x6f, 0xa1, 0x68, 0x79, 0xd1, 0xf1, 0x25, 0x0b, 0xf4, 0xd6, 0x55, 0x17, 0x55, + 0x03, 0x65, 0x9d, 0x07, 0x2f, 0xff, 0xda, 0xcb, 0xfc, 0xf6, 0xf7, 0x5e, 0xd3, 0xa5, 0x72, 0x12, + 0x8c, 0x0d, 0x9b, 0x7b, 0xad, 0x98, 0x96, 0xfc, 0x7c, 0x24, 0x9c, 0xf3, 0xe4, 0xaf, 0x39, 0x12, + 0x08, 0x9c, 0x98, 0xa2, 0x5d, 0x28, 0xbb, 0x96, 0x30, 0xa7, 0xd4, 0xa3, 0x52, 0x75, 0x3b, 0x8f, + 0x4b, 0xae, 0x25, 0x8e, 0xa3, 0xe7, 0x0f, 0x04, 0x94, 0xd2, 0x26, 0xa1, 0x1d, 0xd8, 0x1e, 0xf6, + 0x9f, 0x0c, 0xcc, 0x93, 0xd3, 0x83, 0x9e, 0xf9, 0x6c, 0x30, 0x7c, 0xda, 0xeb, 0xf6, 0x0f, 0xfb, + 0xbd, 0x83, 0x4a, 0x06, 0x6d, 0x41, 0x65, 0xf9, 0xea, 0xa0, 0x8f, 0x7b, 0xdd, 0x51, 0x45, 0x43, + 0xdb, 0xb0, 0xb9, 0x44, 0x47, 0xbd, 0xaf, 0x47, 0xcf, 0xda, 0xc7, 0x95, 0x2c, 0xda, 0x83, 0xdd, + 0x25, 0x7c, 0xdc, 0x7b, 0xd2, 0xee, 0x7e, 0x63, 0xb6, 0x4f, 0xfa, 0x83, 0x53, 0xf3, 0xcb, 0xe1, + 0xe9, 0xa0, 0xf2, 0x63, 0xe7, 0xf1, 0xcb, 0x8b, 0x9a, 0xf6, 0xea, 0xa2, 0xa6, 0xfd, 0x73, 0x51, + 0xd3, 0x7e, 0xb9, 0xac, 0x65, 0x5e, 0x5d, 0xd6, 0x32, 0x7f, 0x5e, 0xd6, 0x32, 0xcf, 0xf7, 0xef, + 0xfe, 0xba, 0x96, 0x9c, 0x8f, 0x8b, 0xea, 0x5e, 0x3f, 0xf9, 0x2f, 0x00, 0x00, 0xff, 0xff, 0x54, + 0xa4, 0x18, 0x68, 0xfb, 0x06, 0x00, 0x00, } func (m *Tx) Marshal() (dAtA []byte, err error) { diff --git a/types/tx/types.proto b/types/tx/types.proto index 6f7fb14c3450..bffe22bcc687 100644 --- a/types/tx/types.proto +++ b/types/tx/types.proto @@ -6,7 +6,7 @@ import "crypto/types/types.proto"; import "types/types.proto"; import "google/protobuf/any.proto"; -option go_package = "github.com/cosmos/cosmos-sdk/tx/types"; +option go_package = "github.com/cosmos/cosmos-sdk/types/tx"; // Tx is the standard type used for broadcasting transactions message Tx { From 50b632169a9fb3bad519ceef2d4031f337471129 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Wed, 10 Jun 2020 16:41:52 -0400 Subject: [PATCH 03/43] Update API and leave test TODO's --- types/tx/tx_wrapper.go | 107 ++++++++++++++++++++------- types/tx/tx_wrapper_test.go | 13 ++++ x/auth/signing/direct/direct.go | 6 ++ x/auth/signing/direct/direct_test.go | 4 +- 4 files changed, 102 insertions(+), 28 deletions(-) create mode 100644 types/tx/tx_wrapper_test.go diff --git a/types/tx/tx_wrapper.go b/types/tx/tx_wrapper.go index 4054485d7dbe..6db09f51b9a2 100644 --- a/types/tx/tx_wrapper.go +++ b/types/tx/tx_wrapper.go @@ -11,26 +11,24 @@ import ( sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" ) -type txWrapper struct { - tx *Tx - bodyBz []byte - authInfoBz []byte - pubKeys []crypto.PubKey - marshaler codec.Marshaler - pubkeyCodec types.PublicKeyCodec -} - +// TxWrapper defines a type that is to be used for building, signing and verifying +// protobuf transactions. The protobuf Tx type is not used directly because a) protobuf +// SIGN_MODE_DIRECT signing uses raw body and auth_info bytes and b) Tx does does not retain +// crypto.PubKey instances. type TxWrapper interface { sdk.Tx + ProtoTx - WithTxBody(*TxBody) TxWrapper - WithAuthInfo(*AuthInfo) TxWrapper - WithSignatures([][]byte) TxWrapper + GetPubKeys() []crypto.PubKey // If signer already has pubkey in context, this list will have nil in its place + + SetBody(*TxBody) + SetAuthInfo(*AuthInfo) + SetSignatures([][]byte) } func NewTxWrapper(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) TxWrapper { - return txWrapper{ + return &txWrapper{ tx: &Tx{ Body: &TxBody{}, AuthInfo: &AuthInfo{}, @@ -40,10 +38,26 @@ func NewTxWrapper(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) T } } -var ( - _ sdk.Tx = txWrapper{} - _ ProtoTx = txWrapper{} -) +type txWrapper struct { + tx *Tx + + // bodyBz represents the protobuf encoding of TxBody. This should be encoding + // from the client using TxRaw if the tx was decoded from the wire + bodyBz []byte + + // authInfoBz represents the protobuf encoding of TxBody. This should be encoding + // from the client using TxRaw if the tx was decoded from the wire + authInfoBz []byte + + // pubKeys represents the cached crypto.PubKey's that were set either from tx decoding + // or decoded from AuthInfo when GetPubKey's was called + pubKeys []crypto.PubKey + + marshaler codec.Marshaler + pubkeyCodec types.PublicKeyCodec +} + +var _ TxWrapper = &txWrapper{} func (t txWrapper) GetMsgs() []sdk.Msg { anys := t.tx.Body.Messages @@ -109,11 +123,27 @@ func (t txWrapper) ValidateBasic() error { return nil } -func (t txWrapper) GetBodyBytes() []byte { +func (t *txWrapper) GetBodyBytes() []byte { + if len(t.bodyBz) == 0 { + // if bodyBz is empty, then marshal the body. bodyBz will generally + // be set to nil whenever SetBody is called so the result of calling + // this method should always return the correct bytes. Note that after + // decoding bodyBz is derived from TxRaw so that it matches what was + // transmitted over the wire + t.bodyBz = t.marshaler.MustMarshalBinaryBare(t.tx.Body) + } return t.bodyBz } -func (t txWrapper) GetAuthInfoBytes() []byte { +func (t *txWrapper) GetAuthInfoBytes() []byte { + if len(t.authInfoBz) == 0 { + // if authInfoBz is empty, then marshal the body. authInfoBz will generally + // be set to nil whenever SetAuthInfo is called so the result of calling + // this method should always return the correct bytes. Note that after + // decoding authInfoBz is derived from TxRaw so that it matches what was + // transmitted over the wire + t.authInfoBz = t.marshaler.MustMarshalBinaryBare(t.tx.AuthInfo) + } return t.authInfoBz } @@ -133,19 +163,42 @@ func (t txWrapper) GetSigners() []sdk.AccAddress { return signers } -func (t txWrapper) WithTxBody(body *TxBody) TxWrapper { +func (t txWrapper) GetPubKeys() []crypto.PubKey { + if t.pubKeys == nil { + signerInfos := t.tx.AuthInfo.SignerInfos + pubKeys := make([]crypto.PubKey, len(signerInfos)) + + for i, si := range signerInfos { + var err error + pk := si.PublicKey + if pk != nil { + pubKeys[i], err = t.pubkeyCodec.Decode(si.PublicKey) + if err != nil { + panic(err) + } + } + } + + t.pubKeys = pubKeys + } + + return t.pubKeys +} + +func (t *txWrapper) SetBody(body *TxBody) { t.tx.Body = body - t.bodyBz = t.marshaler.MustMarshalBinaryBare(body) - return t + // set bodyBz to nil because the cached bodyBz no longer matches tx.Body + t.bodyBz = nil } -func (t txWrapper) WithAuthInfo(info *AuthInfo) TxWrapper { +func (t *txWrapper) SetAuthInfo(info *AuthInfo) { t.tx.AuthInfo = info - t.authInfoBz = t.marshaler.MustMarshalBinaryBare(info) - return t + // set authInfoBz to nil because the cached authInfoBz no longer matches tx.AuthInfo + t.authInfoBz = nil + // set cached pubKeys to nil because they no longer match tx.AuthInfo + t.pubKeys = nil } -func (t txWrapper) WithSignatures(sigs [][]byte) TxWrapper { +func (t *txWrapper) SetSignatures(sigs [][]byte) { t.tx.Signatures = sigs - return t } diff --git a/types/tx/tx_wrapper_test.go b/types/tx/tx_wrapper_test.go new file mode 100644 index 000000000000..1184522bf7e3 --- /dev/null +++ b/types/tx/tx_wrapper_test.go @@ -0,0 +1,13 @@ +package tx + +import "testing" + +func TestTxWrapper(t *testing.T) { + // TODO: + // - verify that body and authInfo bytes encoded with DefaultTxEncoder and decoded with DefaultTxDecoder can be + // retrieved from GetBodyBytes and GetAuthInfoBytes + // - create a TxWrapper using NewTxWrapper and: + // - verify that calling the SetBody results in the correct GetBodyBytes + // - verify that calling the SetAuthInfo results in the correct GetAuthInfoBytes and GetPubKeys + // - verify no nil panics +} diff --git a/x/auth/signing/direct/direct.go b/x/auth/signing/direct/direct.go index 544727cce2f1..b14878c3a5b8 100644 --- a/x/auth/signing/direct/direct.go +++ b/x/auth/signing/direct/direct.go @@ -21,12 +21,18 @@ func (DirectModeHandler) Modes() []types.SignMode { } func (DirectModeHandler) GetSignBytes(mode types.SignMode, data signing.SignerData, tx sdk.Tx) ([]byte, error) { + if mode != types.SignMode_SIGN_MODE_DIRECT { + return nil, fmt.Errorf("expected %s, got %s", types.SignMode_SIGN_MODE_DIRECT, mode) + } + protoTx, ok := tx.(types.ProtoTx) if !ok { return nil, fmt.Errorf("can only get direct sign bytes for a ProtoTx, got %T", tx) } + bodyBz := protoTx.GetBodyBytes() authInfoBz := protoTx.GetAuthInfoBytes() + return DirectSignBytes(bodyBz, authInfoBz, data.ChainID, data.AccountNumber, data.AccountSequence) } diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index 66bd8505d649..f70f0824ea05 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -3,5 +3,7 @@ package direct import "testing" func TestDirectModeHandler(t *testing.T) { - + // TODO: + // - verify DefaultMode and Modes + // - verify GetSignBytes using a test transaction vs manually generating sign bytes by marshaling SignDoc } From 488742db73930f883b4f8d69dc65b17a83fd40b8 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Thu, 11 Jun 2020 11:23:01 -0400 Subject: [PATCH 04/43] Update TxWrapper API --- types/tx/tx_wrapper.go | 42 ++++++++++++++++++++++++++++++++++++------ 1 file changed, 36 insertions(+), 6 deletions(-) diff --git a/types/tx/tx_wrapper.go b/types/tx/tx_wrapper.go index 6db09f51b9a2..9f0e76f74071 100644 --- a/types/tx/tx_wrapper.go +++ b/types/tx/tx_wrapper.go @@ -3,6 +3,8 @@ package tx import ( "fmt" + codectypes "github.com/cosmos/cosmos-sdk/codec/types" + "github.com/tendermint/tendermint/crypto" "github.com/cosmos/cosmos-sdk/codec" @@ -22,8 +24,11 @@ type TxWrapper interface { GetPubKeys() []crypto.PubKey // If signer already has pubkey in context, this list will have nil in its place - SetBody(*TxBody) - SetAuthInfo(*AuthInfo) + SetMsgs([]sdk.Msg) + SetGas(uint64) + SetFee(sdk.Coins) + // TODO: replace SetSignerInfos with SetSignaturesV2 once SignatureV2 from #6373 is merged in + SetSignerInfos([]*SignerInfo) SetSignatures([][]byte) } @@ -185,14 +190,39 @@ func (t txWrapper) GetPubKeys() []crypto.PubKey { return t.pubKeys } -func (t *txWrapper) SetBody(body *TxBody) { - t.tx.Body = body +func (t *txWrapper) SetMsgs(msgs []sdk.Msg) { + anys := make([]*codectypes.Any, len(msgs)) + + for i, msg := range msgs { + var err error + anys[i], err = codectypes.NewAnyWithValue(msg) + if err != nil { + panic(err) + } + } + + t.tx.Body.Messages = anys + // set bodyBz to nil because the cached bodyBz no longer matches tx.Body t.bodyBz = nil } -func (t *txWrapper) SetAuthInfo(info *AuthInfo) { - t.tx.AuthInfo = info +func (t *txWrapper) SetGas(limit uint64) { + t.tx.AuthInfo.Fee.GasLimit = limit + + // set authInfoBz to nil because the cached authInfoBz no longer matches tx.AuthInfo + t.authInfoBz = nil +} + +func (t *txWrapper) SetFee(coins sdk.Coins) { + t.tx.AuthInfo.Fee.Amount = coins + + // set authInfoBz to nil because the cached authInfoBz no longer matches tx.AuthInfo + t.authInfoBz = nil +} + +func (t *txWrapper) SetSignerInfos(infos []*SignerInfo) { + t.tx.AuthInfo.SignerInfos = infos // set authInfoBz to nil because the cached authInfoBz no longer matches tx.AuthInfo t.authInfoBz = nil // set cached pubKeys to nil because they no longer match tx.AuthInfo From e67eaf8334476607a03ccf55ab1555a951105083 Mon Sep 17 00:00:00 2001 From: atheeshp <59333759+atheeshp@users.noreply.github.com> Date: Fri, 12 Jun 2020 20:48:34 +0530 Subject: [PATCH 05/43] tests for tx wrapper (#6410) * WIP: added test for direct mode handler * updated code * Add msg * Update TxWrapper API * Fix pubkey declaration * Add pubkey for tests * Fix SetFee * Remove logs * Avoid global var declaration for tests * Add test for GetPubKeys * Fix direct signing tests * Add more test cases for GetSignBytes * Revert SetFee API * Remove logs * Refactor tests Co-authored-by: anilCSE Co-authored-by: sahith-narahari --- types/tx/tx_wrapper.go | 12 +++ types/tx/tx_wrapper_test.go | 97 ++++++++++++++++++++++-- x/auth/signing/direct/direct_test.go | 107 ++++++++++++++++++++++++++- 3 files changed, 204 insertions(+), 12 deletions(-) diff --git a/types/tx/tx_wrapper.go b/types/tx/tx_wrapper.go index 9f0e76f74071..82244fb6e0fe 100644 --- a/types/tx/tx_wrapper.go +++ b/types/tx/tx_wrapper.go @@ -25,6 +25,7 @@ type TxWrapper interface { GetPubKeys() []crypto.PubKey // If signer already has pubkey in context, this list will have nil in its place SetMsgs([]sdk.Msg) + SetMemo(string) SetGas(uint64) SetFee(sdk.Coins) // TODO: replace SetSignerInfos with SetSignaturesV2 once SignatureV2 from #6373 is merged in @@ -207,6 +208,13 @@ func (t *txWrapper) SetMsgs(msgs []sdk.Msg) { t.bodyBz = nil } +func (t *txWrapper) SetMemo(memo string) { + t.tx.Body.Memo = memo + + // set bodyBz to nil because the cached bodyBz no longer matches tx.Body + t.bodyBz = nil +} + func (t *txWrapper) SetGas(limit uint64) { t.tx.AuthInfo.Fee.GasLimit = limit @@ -215,6 +223,10 @@ func (t *txWrapper) SetGas(limit uint64) { } func (t *txWrapper) SetFee(coins sdk.Coins) { + if t.tx.AuthInfo.Fee == nil { + t.tx.AuthInfo.Fee = &Fee{} + } + t.tx.AuthInfo.Fee.Amount = coins // set authInfoBz to nil because the cached authInfoBz no longer matches tx.AuthInfo diff --git a/types/tx/tx_wrapper_test.go b/types/tx/tx_wrapper_test.go index 1184522bf7e3..e051b19d24aa 100644 --- a/types/tx/tx_wrapper_test.go +++ b/types/tx/tx_wrapper_test.go @@ -1,13 +1,94 @@ package tx -import "testing" +import ( + authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" + "github.com/stretchr/testify/require" + "testing" + + "github.com/cosmos/cosmos-sdk/codec" + codectypes "github.com/cosmos/cosmos-sdk/codec/types" + "github.com/cosmos/cosmos-sdk/std" + "github.com/cosmos/cosmos-sdk/types" + sdk "github.com/cosmos/cosmos-sdk/types" +) func TestTxWrapper(t *testing.T) { - // TODO: - // - verify that body and authInfo bytes encoded with DefaultTxEncoder and decoded with DefaultTxDecoder can be - // retrieved from GetBodyBytes and GetAuthInfoBytes - // - create a TxWrapper using NewTxWrapper and: - // - verify that calling the SetBody results in the correct GetBodyBytes - // - verify that calling the SetAuthInfo results in the correct GetAuthInfoBytes and GetPubKeys - // - verify no nil panics + _, pubkey, addr := authtypes.KeyTestPubAddr() + + appCodec := std.NewAppCodec(codec.New(), codectypes.NewInterfaceRegistry()) + tx := NewTxWrapper(appCodec.Marshaler, std.DefaultPublicKeyCodec{}) + + cdc := std.DefaultPublicKeyCodec{} + + memo := "sometestmemo" + msgs := []sdk.Msg{types.NewTestMsg(addr)} + + pk, err := cdc.Encode(pubkey) + require.NoError(t, err) + + var signerInfo []*SignerInfo + signerInfo = append(signerInfo, &SignerInfo{ + PublicKey: pk, + ModeInfo: &ModeInfo{ + Sum: &ModeInfo_Single_{ + Single: &ModeInfo_Single{ + Mode: SignMode_SIGN_MODE_DIRECT, + }, + }, + }, + }) + + fee := Fee{Amount: sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), GasLimit: 20000} + + t.Log("verify that authInfo bytes encoded with DefaultTxEncoder and decoded with DefaultTxDecoder can be retrieved from GetAuthInfoBytes") + authInfo := &AuthInfo{ + Fee: &fee, + SignerInfos: signerInfo, + } + + authInfoBytes := appCodec.Marshaler.MustMarshalBinaryBare(authInfo) + + require.NotEmpty(t, authInfoBytes) + require.Empty(t, tx.GetAuthInfoBytes()) + + t.Log("verify that body bytes encoded with DefaultTxEncoder and decoded with DefaultTxDecoder can be retrieved from GetBodyBytes") + anys := make([]*codectypes.Any, len(msgs)) + + for i, msg := range msgs { + var err error + anys[i], err = codectypes.NewAnyWithValue(msg) + if err != nil { + panic(err) + } + } + + txBody := &TxBody{ + Memo: memo, + Messages: anys, + } + bodyBytes := appCodec.Marshaler.MustMarshalBinaryBare(txBody) + require.NotEmpty(t, bodyBytes) + require.Empty(t, tx.GetBodyBytes()) + + t.Log("verify that calling the SetMsgs, SetMemo results in the correct GetBodyBytes") + require.NotEqual(t, bodyBytes, tx.GetBodyBytes()) + tx.SetMsgs(msgs) + require.NotEqual(t, bodyBytes, tx.GetBodyBytes()) + tx.SetMemo(memo) + require.Equal(t, bodyBytes, tx.GetBodyBytes()) + require.Equal(t, len(msgs), len(tx.GetMsgs())) + require.Equal(t, 0, len(tx.GetPubKeys())) + + t.Log("verify that calling the SetAuthInfo results in the correct GetAuthInfoBytes and GetPubKeys") + require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) + tx.SetFee(fee.Amount) + require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) + tx.SetGas(fee.GasLimit) + require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) + tx.SetSignerInfos(signerInfo) + require.Equal(t, authInfoBytes, tx.GetAuthInfoBytes()) + + require.Equal(t, len(msgs), len(tx.GetMsgs())) + require.Equal(t, 1, len(tx.GetPubKeys())) + require.Equal(t, pubkey.Bytes(), tx.GetPubKeys()[0].Bytes()) } diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index f70f0824ea05..97676d60d59d 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -1,9 +1,108 @@ package direct -import "testing" +import ( + codectypes "github.com/cosmos/cosmos-sdk/codec/types" + "testing" + + "github.com/cosmos/cosmos-sdk/simapp" + "github.com/cosmos/cosmos-sdk/std" + sdk "github.com/cosmos/cosmos-sdk/types" + types "github.com/cosmos/cosmos-sdk/types/tx" + "github.com/cosmos/cosmos-sdk/x/auth/signing" + authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" + "github.com/stretchr/testify/require" +) func TestDirectModeHandler(t *testing.T) { - // TODO: - // - verify DefaultMode and Modes - // - verify GetSignBytes using a test transaction vs manually generating sign bytes by marshaling SignDoc + app := simapp.Setup(false) + //ctx := app.BaseApp.NewContext(false, abci.Header{}) + + _, pubkey, addr := authtypes.KeyTestPubAddr() + cdc := std.DefaultPublicKeyCodec{} + + tx := types.NewTxWrapper(app.AppCodec().Marshaler, std.DefaultPublicKeyCodec{}) + memo := "sometestmemo" + msgs := []sdk.Msg{authtypes.NewTestMsg(addr)} + + pk, err := cdc.Encode(pubkey) + require.NoError(t, err) + + var signerInfo []*types.SignerInfo + signerInfo = append(signerInfo, &types.SignerInfo{ + PublicKey: pk, + ModeInfo: &types.ModeInfo{ + Sum: &types.ModeInfo_Single_{ + Single: &types.ModeInfo_Single{ + Mode: types.SignMode_SIGN_MODE_DIRECT, + }, + }, + }, + }) + + fee := types.Fee{Amount: sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), GasLimit: 20000} + + tx.SetMsgs(msgs) + tx.SetMemo(memo) + tx.SetFee(fee.Amount) + tx.SetGas(fee.GasLimit) + + tx.SetSignerInfos(signerInfo) + + t.Log("verify modes and default-mode") + var directModeHandler DirectModeHandler + require.Equal(t, directModeHandler.DefaultMode(), types.SignMode_SIGN_MODE_DIRECT) + require.Len(t, directModeHandler.Modes(), 1) + + signingData := signing.SignerData{ + ChainID: "test-chain", + AccountNumber: 1, + AccountSequence: 1, + } + + signBytes, err := directModeHandler.GetSignBytes(types.SignMode_SIGN_MODE_DIRECT, signingData, tx) + + require.NoError(t, err) + require.NotNil(t, signBytes) + + authInfo := &types.AuthInfo{ + Fee: &fee, + SignerInfos: signerInfo, + } + + authInfoBytes := app.AppCodec().Marshaler.MustMarshalBinaryBare(authInfo) + + anys := make([]*codectypes.Any, len(msgs)) + + for i, msg := range msgs { + var err error + anys[i], err = codectypes.NewAnyWithValue(msg) + if err != nil { + panic(err) + } + } + + txBody := &types.TxBody{ + Memo: memo, + Messages: anys, + } + bodyBytes := app.AppCodec().Marshaler.MustMarshalBinaryBare(txBody) + + t.Log("verify GetSignBytes with generating sign bytes by marshaling SignDoc") + signDoc := types.SignDoc{ + AccountNumber: 1, + AccountSequence: 1, + AuthInfoBytes: authInfoBytes, + BodyBytes: bodyBytes, + ChainId: "test-chain", + } + + signDocBytes, err := signDoc.Marshal() + require.NoError(t, err) + require.Equal(t, signDocBytes, signBytes) + + t.Log("verify GetSignBytes with false txBody data") + signDoc.BodyBytes = []byte("dfafdasfds") + signDocBytes, err = signDoc.Marshal() + require.NoError(t, err) + require.NotEqual(t, signDocBytes, signBytes) } From f136f7e10e97664aa8dab8da3ee310444d86c7f0 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Fri, 12 Jun 2020 14:07:51 -0400 Subject: [PATCH 06/43] Refactoring --- types/tx/tx_decoder.go | 2 +- types/tx/tx_encoder.go | 4 +-- types/tx/tx_wrapper.go | 46 ++++++++++++++++------------ types/tx/tx_wrapper_test.go | 18 ++++++----- x/auth/signing/direct/direct_test.go | 42 ++++++++++++------------- 5 files changed, 60 insertions(+), 52 deletions(-) diff --git a/types/tx/tx_decoder.go b/types/tx/tx_decoder.go index d743ed56c852..a05fe9145226 100644 --- a/types/tx/tx_decoder.go +++ b/types/tx/tx_decoder.go @@ -32,7 +32,7 @@ func DefaultTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCodec) pks[i] = pk } - return txWrapper{ + return builder{ tx: &tx, bodyBz: raw.BodyBytes, authInfoBz: raw.AuthInfoBytes, diff --git a/types/tx/tx_encoder.go b/types/tx/tx_encoder.go index 89533e98b628..277b7ed2bd4c 100644 --- a/types/tx/tx_encoder.go +++ b/types/tx/tx_encoder.go @@ -9,9 +9,9 @@ import ( func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { return func(tx types.Tx) ([]byte, error) { - wrapper, ok := tx.(txWrapper) + wrapper, ok := tx.(builder) if !ok { - return nil, fmt.Errorf("expected %T, got %T", txWrapper{}, tx) + return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) } raw := &TxRaw{ diff --git a/types/tx/tx_wrapper.go b/types/tx/tx_wrapper.go index 82244fb6e0fe..993851193eca 100644 --- a/types/tx/tx_wrapper.go +++ b/types/tx/tx_wrapper.go @@ -13,11 +13,11 @@ import ( sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" ) -// TxWrapper defines a type that is to be used for building, signing and verifying +// Builder defines a type that is to be used for building, signing and verifying // protobuf transactions. The protobuf Tx type is not used directly because a) protobuf // SIGN_MODE_DIRECT signing uses raw body and auth_info bytes and b) Tx does does not retain // crypto.PubKey instances. -type TxWrapper interface { +type Builder interface { sdk.Tx ProtoTx @@ -33,18 +33,20 @@ type TxWrapper interface { SetSignatures([][]byte) } -func NewTxWrapper(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) TxWrapper { - return &txWrapper{ +func NewBuilder(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) Builder { + return &builder{ tx: &Tx{ - Body: &TxBody{}, - AuthInfo: &AuthInfo{}, + Body: &TxBody{}, + AuthInfo: &AuthInfo{ + Fee: &Fee{}, + }, }, marshaler: marshaler, pubkeyCodec: pubkeyCodec, } } -type txWrapper struct { +type builder struct { tx *Tx // bodyBz represents the protobuf encoding of TxBody. This should be encoding @@ -63,9 +65,9 @@ type txWrapper struct { pubkeyCodec types.PublicKeyCodec } -var _ TxWrapper = &txWrapper{} +var _ Builder = &builder{} -func (t txWrapper) GetMsgs() []sdk.Msg { +func (t builder) GetMsgs() []sdk.Msg { anys := t.tx.Body.Messages res := make([]sdk.Msg, len(anys)) for i, any := range anys { @@ -78,7 +80,7 @@ func (t txWrapper) GetMsgs() []sdk.Msg { // MaxGasWanted defines the max gas allowed. const MaxGasWanted = uint64((1 << 63) - 1) -func (t txWrapper) ValidateBasic() error { +func (t builder) ValidateBasic() error { tx := t.tx if tx == nil { return fmt.Errorf("bad Tx") @@ -129,7 +131,7 @@ func (t txWrapper) ValidateBasic() error { return nil } -func (t *txWrapper) GetBodyBytes() []byte { +func (t *builder) GetBodyBytes() []byte { if len(t.bodyBz) == 0 { // if bodyBz is empty, then marshal the body. bodyBz will generally // be set to nil whenever SetBody is called so the result of calling @@ -141,7 +143,7 @@ func (t *txWrapper) GetBodyBytes() []byte { return t.bodyBz } -func (t *txWrapper) GetAuthInfoBytes() []byte { +func (t *builder) GetAuthInfoBytes() []byte { if len(t.authInfoBz) == 0 { // if authInfoBz is empty, then marshal the body. authInfoBz will generally // be set to nil whenever SetAuthInfo is called so the result of calling @@ -153,7 +155,7 @@ func (t *txWrapper) GetAuthInfoBytes() []byte { return t.authInfoBz } -func (t txWrapper) GetSigners() []sdk.AccAddress { +func (t builder) GetSigners() []sdk.AccAddress { var signers []sdk.AccAddress seen := map[string]bool{} @@ -169,7 +171,7 @@ func (t txWrapper) GetSigners() []sdk.AccAddress { return signers } -func (t txWrapper) GetPubKeys() []crypto.PubKey { +func (t builder) GetPubKeys() []crypto.PubKey { if t.pubKeys == nil { signerInfos := t.tx.AuthInfo.SignerInfos pubKeys := make([]crypto.PubKey, len(signerInfos)) @@ -191,7 +193,7 @@ func (t txWrapper) GetPubKeys() []crypto.PubKey { return t.pubKeys } -func (t *txWrapper) SetMsgs(msgs []sdk.Msg) { +func (t *builder) SetMsgs(msgs []sdk.Msg) { anys := make([]*codectypes.Any, len(msgs)) for i, msg := range msgs { @@ -208,21 +210,25 @@ func (t *txWrapper) SetMsgs(msgs []sdk.Msg) { t.bodyBz = nil } -func (t *txWrapper) SetMemo(memo string) { +func (t *builder) SetMemo(memo string) { t.tx.Body.Memo = memo // set bodyBz to nil because the cached bodyBz no longer matches tx.Body t.bodyBz = nil } -func (t *txWrapper) SetGas(limit uint64) { +func (t *builder) SetGas(limit uint64) { + if t.tx.AuthInfo.Fee == nil { + t.tx.AuthInfo.Fee = &Fee{} + } + t.tx.AuthInfo.Fee.GasLimit = limit // set authInfoBz to nil because the cached authInfoBz no longer matches tx.AuthInfo t.authInfoBz = nil } -func (t *txWrapper) SetFee(coins sdk.Coins) { +func (t *builder) SetFee(coins sdk.Coins) { if t.tx.AuthInfo.Fee == nil { t.tx.AuthInfo.Fee = &Fee{} } @@ -233,7 +239,7 @@ func (t *txWrapper) SetFee(coins sdk.Coins) { t.authInfoBz = nil } -func (t *txWrapper) SetSignerInfos(infos []*SignerInfo) { +func (t *builder) SetSignerInfos(infos []*SignerInfo) { t.tx.AuthInfo.SignerInfos = infos // set authInfoBz to nil because the cached authInfoBz no longer matches tx.AuthInfo t.authInfoBz = nil @@ -241,6 +247,6 @@ func (t *txWrapper) SetSignerInfos(infos []*SignerInfo) { t.pubKeys = nil } -func (t *txWrapper) SetSignatures(sigs [][]byte) { +func (t *builder) SetSignatures(sigs [][]byte) { t.tx.Signatures = sigs } diff --git a/types/tx/tx_wrapper_test.go b/types/tx/tx_wrapper_test.go index e051b19d24aa..eba0668af595 100644 --- a/types/tx/tx_wrapper_test.go +++ b/types/tx/tx_wrapper_test.go @@ -1,9 +1,10 @@ package tx import ( + "testing" + authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" "github.com/stretchr/testify/require" - "testing" "github.com/cosmos/cosmos-sdk/codec" codectypes "github.com/cosmos/cosmos-sdk/codec/types" @@ -15,8 +16,8 @@ import ( func TestTxWrapper(t *testing.T) { _, pubkey, addr := authtypes.KeyTestPubAddr() - appCodec := std.NewAppCodec(codec.New(), codectypes.NewInterfaceRegistry()) - tx := NewTxWrapper(appCodec.Marshaler, std.DefaultPublicKeyCodec{}) + marshaler := codec.NewHybridCodec(codec.New(), codectypes.NewInterfaceRegistry()) + tx := NewBuilder(marshaler, std.DefaultPublicKeyCodec{}) cdc := std.DefaultPublicKeyCodec{} @@ -42,11 +43,11 @@ func TestTxWrapper(t *testing.T) { t.Log("verify that authInfo bytes encoded with DefaultTxEncoder and decoded with DefaultTxDecoder can be retrieved from GetAuthInfoBytes") authInfo := &AuthInfo{ - Fee: &fee, + Fee: &fee, SignerInfos: signerInfo, } - authInfoBytes := appCodec.Marshaler.MustMarshalBinaryBare(authInfo) + authInfoBytes := marshaler.MustMarshalBinaryBare(authInfo) require.NotEmpty(t, authInfoBytes) require.Empty(t, tx.GetAuthInfoBytes()) @@ -63,10 +64,10 @@ func TestTxWrapper(t *testing.T) { } txBody := &TxBody{ - Memo: memo, + Memo: memo, Messages: anys, } - bodyBytes := appCodec.Marshaler.MustMarshalBinaryBare(txBody) + bodyBytes := marshaler.MustMarshalBinaryBare(txBody) require.NotEmpty(t, bodyBytes) require.Empty(t, tx.GetBodyBytes()) @@ -79,13 +80,14 @@ func TestTxWrapper(t *testing.T) { require.Equal(t, len(msgs), len(tx.GetMsgs())) require.Equal(t, 0, len(tx.GetPubKeys())) - t.Log("verify that calling the SetAuthInfo results in the correct GetAuthInfoBytes and GetPubKeys") + t.Log("verify that updated AuthInfo results in the correct GetAuthInfoBytes and GetPubKeys") require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) tx.SetFee(fee.Amount) require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) tx.SetGas(fee.GasLimit) require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) tx.SetSignerInfos(signerInfo) + // once fee, gas and signerInfos are all set, AuthInfo bytes should match require.Equal(t, authInfoBytes, tx.GetAuthInfoBytes()) require.Equal(t, len(msgs), len(tx.GetMsgs())) diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index 97676d60d59d..91bebff5c4d0 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -1,13 +1,13 @@ package direct import ( - codectypes "github.com/cosmos/cosmos-sdk/codec/types" "testing" + codectypes "github.com/cosmos/cosmos-sdk/codec/types" "github.com/cosmos/cosmos-sdk/simapp" "github.com/cosmos/cosmos-sdk/std" sdk "github.com/cosmos/cosmos-sdk/types" - types "github.com/cosmos/cosmos-sdk/types/tx" + txtypes "github.com/cosmos/cosmos-sdk/types/tx" "github.com/cosmos/cosmos-sdk/x/auth/signing" authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" "github.com/stretchr/testify/require" @@ -20,26 +20,26 @@ func TestDirectModeHandler(t *testing.T) { _, pubkey, addr := authtypes.KeyTestPubAddr() cdc := std.DefaultPublicKeyCodec{} - tx := types.NewTxWrapper(app.AppCodec().Marshaler, std.DefaultPublicKeyCodec{}) + tx := txtypes.NewBuilder(app.AppCodec().Marshaler, std.DefaultPublicKeyCodec{}) memo := "sometestmemo" msgs := []sdk.Msg{authtypes.NewTestMsg(addr)} pk, err := cdc.Encode(pubkey) require.NoError(t, err) - var signerInfo []*types.SignerInfo - signerInfo = append(signerInfo, &types.SignerInfo{ + var signerInfo []*txtypes.SignerInfo + signerInfo = append(signerInfo, &txtypes.SignerInfo{ PublicKey: pk, - ModeInfo: &types.ModeInfo{ - Sum: &types.ModeInfo_Single_{ - Single: &types.ModeInfo_Single{ - Mode: types.SignMode_SIGN_MODE_DIRECT, + ModeInfo: &txtypes.ModeInfo{ + Sum: &txtypes.ModeInfo_Single_{ + Single: &txtypes.ModeInfo_Single{ + Mode: txtypes.SignMode_SIGN_MODE_DIRECT, }, }, }, }) - fee := types.Fee{Amount: sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), GasLimit: 20000} + fee := txtypes.Fee{Amount: sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), GasLimit: 20000} tx.SetMsgs(msgs) tx.SetMemo(memo) @@ -50,7 +50,7 @@ func TestDirectModeHandler(t *testing.T) { t.Log("verify modes and default-mode") var directModeHandler DirectModeHandler - require.Equal(t, directModeHandler.DefaultMode(), types.SignMode_SIGN_MODE_DIRECT) + require.Equal(t, directModeHandler.DefaultMode(), txtypes.SignMode_SIGN_MODE_DIRECT) require.Len(t, directModeHandler.Modes(), 1) signingData := signing.SignerData{ @@ -59,13 +59,13 @@ func TestDirectModeHandler(t *testing.T) { AccountSequence: 1, } - signBytes, err := directModeHandler.GetSignBytes(types.SignMode_SIGN_MODE_DIRECT, signingData, tx) + signBytes, err := directModeHandler.GetSignBytes(txtypes.SignMode_SIGN_MODE_DIRECT, signingData, tx) require.NoError(t, err) require.NotNil(t, signBytes) - authInfo := &types.AuthInfo{ - Fee: &fee, + authInfo := &txtypes.AuthInfo{ + Fee: &fee, SignerInfos: signerInfo, } @@ -81,19 +81,19 @@ func TestDirectModeHandler(t *testing.T) { } } - txBody := &types.TxBody{ - Memo: memo, + txBody := &txtypes.TxBody{ + Memo: memo, Messages: anys, } bodyBytes := app.AppCodec().Marshaler.MustMarshalBinaryBare(txBody) t.Log("verify GetSignBytes with generating sign bytes by marshaling SignDoc") - signDoc := types.SignDoc{ - AccountNumber: 1, + signDoc := txtypes.SignDoc{ + AccountNumber: 1, AccountSequence: 1, - AuthInfoBytes: authInfoBytes, - BodyBytes: bodyBytes, - ChainId: "test-chain", + AuthInfoBytes: authInfoBytes, + BodyBytes: bodyBytes, + ChainId: "test-chain", } signDocBytes, err := signDoc.Marshal() From 3ba70b0bd708c8507afae9e52f1aac0dae546a7d Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Fri, 12 Jun 2020 14:32:24 -0400 Subject: [PATCH 07/43] Refactoring --- types/tx/tx_wrapper_test.go | 5 +- types/tx/types.pb.go | 496 +++++++++++++++++++++------ x/auth/signing/direct/direct.go | 16 +- x/auth/signing/direct/direct_test.go | 8 +- 4 files changed, 400 insertions(+), 125 deletions(-) diff --git a/types/tx/tx_wrapper_test.go b/types/tx/tx_wrapper_test.go index eba0668af595..a583ef777e83 100644 --- a/types/tx/tx_wrapper_test.go +++ b/types/tx/tx_wrapper_test.go @@ -3,6 +3,8 @@ package tx import ( "testing" + "github.com/cosmos/cosmos-sdk/types/tx/signing" + authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" "github.com/stretchr/testify/require" @@ -33,7 +35,7 @@ func TestTxWrapper(t *testing.T) { ModeInfo: &ModeInfo{ Sum: &ModeInfo_Single_{ Single: &ModeInfo_Single{ - Mode: SignMode_SIGN_MODE_DIRECT, + Mode: signing.SignMode_SIGN_MODE_DIRECT, }, }, }, @@ -50,7 +52,6 @@ func TestTxWrapper(t *testing.T) { authInfoBytes := marshaler.MustMarshalBinaryBare(authInfo) require.NotEmpty(t, authInfoBytes) - require.Empty(t, tx.GetAuthInfoBytes()) t.Log("verify that body bytes encoded with DefaultTxEncoder and decoded with DefaultTxDecoder can be retrieved from GetBodyBytes") anys := make([]*codectypes.Any, len(msgs)) diff --git a/types/tx/types.pb.go b/types/tx/types.pb.go index 770cc3610778..c4a784d31c9a 100644 --- a/types/tx/types.pb.go +++ b/types/tx/types.pb.go @@ -1,7 +1,7 @@ // Code generated by protoc-gen-gogo. DO NOT EDIT. // source: types/tx/types.proto -package types +package tx import ( fmt "fmt" @@ -93,12 +93,70 @@ func (m *Tx) GetSignatures() [][]byte { return nil } -// SignDoc is the standard type used for signing transaction in SIGN_MODE_DIRECT +type TxRaw struct { + BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` + AuthInfoBytes []byte `protobuf:"bytes,2,opt,name=auth_info_bytes,json=authInfoBytes,proto3" json:"auth_info_bytes,omitempty"` + // signatures are the raw binary signatures of signers specified by body and auth_info + Signatures [][]byte `protobuf:"bytes,3,rep,name=signatures,proto3" json:"signatures,omitempty"` +} + +func (m *TxRaw) Reset() { *m = TxRaw{} } +func (m *TxRaw) String() string { return proto.CompactTextString(m) } +func (*TxRaw) ProtoMessage() {} +func (*TxRaw) Descriptor() ([]byte, []int) { + return fileDescriptor_1c6ac8fa65877134, []int{1} +} +func (m *TxRaw) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TxRaw) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_TxRaw.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *TxRaw) XXX_Merge(src proto.Message) { + xxx_messageInfo_TxRaw.Merge(m, src) +} +func (m *TxRaw) XXX_Size() int { + return m.Size() +} +func (m *TxRaw) XXX_DiscardUnknown() { + xxx_messageInfo_TxRaw.DiscardUnknown(m) +} + +var xxx_messageInfo_TxRaw proto.InternalMessageInfo + +func (m *TxRaw) GetBodyBytes() []byte { + if m != nil { + return m.BodyBytes + } + return nil +} + +func (m *TxRaw) GetAuthInfoBytes() []byte { + if m != nil { + return m.AuthInfoBytes + } + return nil +} + +func (m *TxRaw) GetSignatures() [][]byte { + if m != nil { + return m.Signatures + } + return nil +} + type SignDoc struct { - // body is the TxBody from Tx - Body *TxBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"` - // auth_info is the AuthInfo from Tx - AuthInfo *AuthInfo `protobuf:"bytes,2,opt,name=auth_info,json=authInfo,proto3" json:"auth_info,omitempty"` + BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` + AuthInfoBytes []byte `protobuf:"bytes,2,opt,name=auth_info_bytes,json=authInfoBytes,proto3" json:"auth_info_bytes,omitempty"` // chain_id is the unique identifier of the chain this transaction targets. // It prevents signed transactions from being used on another chain by an // attacker @@ -114,7 +172,7 @@ func (m *SignDoc) Reset() { *m = SignDoc{} } func (m *SignDoc) String() string { return proto.CompactTextString(m) } func (*SignDoc) ProtoMessage() {} func (*SignDoc) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{1} + return fileDescriptor_1c6ac8fa65877134, []int{2} } func (m *SignDoc) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -143,16 +201,16 @@ func (m *SignDoc) XXX_DiscardUnknown() { var xxx_messageInfo_SignDoc proto.InternalMessageInfo -func (m *SignDoc) GetBody() *TxBody { +func (m *SignDoc) GetBodyBytes() []byte { if m != nil { - return m.Body + return m.BodyBytes } return nil } -func (m *SignDoc) GetAuthInfo() *AuthInfo { +func (m *SignDoc) GetAuthInfoBytes() []byte { if m != nil { - return m.AuthInfo + return m.AuthInfoBytes } return nil } @@ -201,7 +259,7 @@ func (m *TxBody) Reset() { *m = TxBody{} } func (m *TxBody) String() string { return proto.CompactTextString(m) } func (*TxBody) ProtoMessage() {} func (*TxBody) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{2} + return fileDescriptor_1c6ac8fa65877134, []int{3} } func (m *TxBody) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -280,7 +338,7 @@ func (m *AuthInfo) Reset() { *m = AuthInfo{} } func (m *AuthInfo) String() string { return proto.CompactTextString(m) } func (*AuthInfo) ProtoMessage() {} func (*AuthInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{3} + return fileDescriptor_1c6ac8fa65877134, []int{4} } func (m *AuthInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -327,7 +385,7 @@ func (m *AuthInfo) GetFee() *Fee { type SignerInfo struct { // public_key is the public key of the signer. It is optional for accounts // that already exist in state - PublicKey *types.Any `protobuf:"bytes,1,opt,name=public_key,json=publicKey,proto3" json:"public_key,omitempty"` + PublicKey *types1.PublicKey `protobuf:"bytes,1,opt,name=public_key,json=publicKey,proto3" json:"public_key,omitempty"` // mode_info describes the signing mode of the signer and is a nested // structure to support nested multisig pubkey's ModeInfo *ModeInfo `protobuf:"bytes,2,opt,name=mode_info,json=modeInfo,proto3" json:"mode_info,omitempty"` @@ -337,7 +395,7 @@ func (m *SignerInfo) Reset() { *m = SignerInfo{} } func (m *SignerInfo) String() string { return proto.CompactTextString(m) } func (*SignerInfo) ProtoMessage() {} func (*SignerInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{4} + return fileDescriptor_1c6ac8fa65877134, []int{5} } func (m *SignerInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -366,7 +424,7 @@ func (m *SignerInfo) XXX_DiscardUnknown() { var xxx_messageInfo_SignerInfo proto.InternalMessageInfo -func (m *SignerInfo) GetPublicKey() *types.Any { +func (m *SignerInfo) GetPublicKey() *types1.PublicKey { if m != nil { return m.PublicKey } @@ -395,7 +453,7 @@ func (m *ModeInfo) Reset() { *m = ModeInfo{} } func (m *ModeInfo) String() string { return proto.CompactTextString(m) } func (*ModeInfo) ProtoMessage() {} func (*ModeInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{5} + return fileDescriptor_1c6ac8fa65877134, []int{6} } func (m *ModeInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -480,7 +538,7 @@ func (m *ModeInfo_Single) Reset() { *m = ModeInfo_Single{} } func (m *ModeInfo_Single) String() string { return proto.CompactTextString(m) } func (*ModeInfo_Single) ProtoMessage() {} func (*ModeInfo_Single) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{5, 0} + return fileDescriptor_1c6ac8fa65877134, []int{6, 0} } func (m *ModeInfo_Single) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -529,7 +587,7 @@ func (m *ModeInfo_Multi) Reset() { *m = ModeInfo_Multi{} } func (m *ModeInfo_Multi) String() string { return proto.CompactTextString(m) } func (*ModeInfo_Multi) ProtoMessage() {} func (*ModeInfo_Multi) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{5, 1} + return fileDescriptor_1c6ac8fa65877134, []int{6, 1} } func (m *ModeInfo_Multi) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -587,7 +645,7 @@ func (m *Fee) Reset() { *m = Fee{} } func (m *Fee) String() string { return proto.CompactTextString(m) } func (*Fee) ProtoMessage() {} func (*Fee) Descriptor() ([]byte, []int) { - return fileDescriptor_1c6ac8fa65877134, []int{6} + return fileDescriptor_1c6ac8fa65877134, []int{7} } func (m *Fee) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -632,6 +690,7 @@ func (m *Fee) GetGasLimit() uint64 { func init() { proto.RegisterType((*Tx)(nil), "cosmos_sdk.tx.v1.Tx") + proto.RegisterType((*TxRaw)(nil), "cosmos_sdk.tx.v1.TxRaw") proto.RegisterType((*SignDoc)(nil), "cosmos_sdk.tx.v1.SignDoc") proto.RegisterType((*TxBody)(nil), "cosmos_sdk.tx.v1.TxBody") proto.RegisterType((*AuthInfo)(nil), "cosmos_sdk.tx.v1.AuthInfo") @@ -645,56 +704,59 @@ func init() { func init() { proto.RegisterFile("types/tx/types.proto", fileDescriptor_1c6ac8fa65877134) } var fileDescriptor_1c6ac8fa65877134 = []byte{ - // 774 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x55, 0x3d, 0x6f, 0xe3, 0x46, - 0x10, 0x15, 0x45, 0x49, 0x96, 0xc6, 0xdf, 0x1b, 0x07, 0xa0, 0x65, 0x83, 0x56, 0x08, 0x38, 0x51, - 0x80, 0x84, 0x72, 0x6c, 0x20, 0x1f, 0x48, 0xe1, 0x48, 0x4e, 0x0c, 0x1b, 0x89, 0x13, 0x80, 0x72, - 0x65, 0x20, 0x20, 0x28, 0x72, 0x45, 0x2d, 0x2c, 0xee, 0x2a, 0xdc, 0x65, 0x20, 0xa5, 0x4b, 0x91, - 0x2a, 0x4d, 0x9a, 0xfc, 0x89, 0xfb, 0x25, 0x2e, 0x8d, 0xab, 0xae, 0xb9, 0x0f, 0xd8, 0x3f, 0xe4, - 0x0e, 0x5c, 0x2e, 0x65, 0x9f, 0xe5, 0xd3, 0x75, 0x57, 0x69, 0xf8, 0xf8, 0xde, 0x9b, 0xd9, 0x99, - 0xd1, 0x12, 0x36, 0xc4, 0x64, 0x84, 0x79, 0x4b, 0x8c, 0x5b, 0x32, 0xb0, 0x47, 0x31, 0x13, 0x0c, - 0xad, 0xf9, 0x8c, 0x47, 0x8c, 0xbb, 0x3c, 0xb8, 0xb4, 0xc5, 0xd8, 0xfe, 0xf3, 0xab, 0xfa, 0xa7, - 0x62, 0x40, 0xe2, 0xc0, 0x1d, 0x79, 0xb1, 0x98, 0xb4, 0x24, 0xa9, 0x15, 0xb2, 0x90, 0xdd, 0x45, - 0x99, 0xb2, 0x6e, 0xf8, 0xf1, 0x64, 0x24, 0x58, 0x4b, 0xd9, 0xde, 0x79, 0xd6, 0xd7, 0x67, 0xa1, - 0xed, 0x69, 0x72, 0x4e, 0x42, 0x4a, 0x68, 0xf8, 0xd6, 0xdb, 0xcd, 0x90, 0xb1, 0x70, 0x88, 0xb3, - 0x6c, 0xbd, 0xa4, 0xdf, 0xf2, 0xe8, 0x24, 0x7b, 0x65, 0xfd, 0xab, 0x41, 0xf1, 0x7c, 0x8c, 0xbe, - 0x80, 0x52, 0x8f, 0x05, 0x13, 0x43, 0x6b, 0x68, 0xcd, 0xc5, 0x7d, 0xc3, 0x7e, 0x58, 0xb5, 0x7d, - 0x3e, 0xee, 0xb0, 0x60, 0xe2, 0x48, 0x16, 0xfa, 0x06, 0x6a, 0x5e, 0x22, 0x06, 0x2e, 0xa1, 0x7d, - 0x66, 0x14, 0xa5, 0xa4, 0x3e, 0x2b, 0x69, 0x27, 0x62, 0x70, 0x4a, 0xfb, 0xcc, 0xa9, 0x7a, 0x2a, - 0x42, 0x26, 0x40, 0x5a, 0x9f, 0x27, 0x92, 0x18, 0x73, 0x43, 0x6f, 0xe8, 0xcd, 0x25, 0xe7, 0x1e, - 0x62, 0x3d, 0xd7, 0x60, 0xa1, 0x4b, 0x42, 0xfa, 0x23, 0xf3, 0x3f, 0x54, 0x49, 0x9b, 0x50, 0xf5, - 0x07, 0x1e, 0xa1, 0x2e, 0x09, 0x0c, 0xbd, 0xa1, 0x35, 0x6b, 0xce, 0x82, 0x7c, 0x3e, 0x0d, 0xd0, - 0x2e, 0xac, 0x78, 0xbe, 0xcf, 0x12, 0x2a, 0x5c, 0x9a, 0x44, 0x3d, 0x1c, 0x1b, 0xa5, 0x86, 0xd6, - 0x2c, 0x39, 0xcb, 0x0a, 0xfd, 0x55, 0x82, 0xe8, 0x73, 0x58, 0xcb, 0x69, 0x1c, 0xff, 0x91, 0x60, - 0xea, 0x63, 0xa3, 0x2c, 0x89, 0xab, 0x0a, 0xef, 0x2a, 0xd8, 0xfa, 0xbf, 0x08, 0x95, 0xac, 0x6c, - 0xb4, 0x07, 0xd5, 0x08, 0x73, 0xee, 0x85, 0x98, 0x1b, 0x5a, 0x43, 0x6f, 0x2e, 0xee, 0x6f, 0xd8, - 0xd9, 0x98, 0xec, 0x7c, 0x4c, 0x76, 0x9b, 0x4e, 0x9c, 0x29, 0x0b, 0x21, 0x28, 0x45, 0x38, 0xca, - 0x4e, 0x57, 0x73, 0x64, 0x9c, 0x96, 0x28, 0x48, 0x84, 0x59, 0x22, 0xdc, 0x01, 0x26, 0xe1, 0x40, - 0xc8, 0x33, 0xe8, 0xce, 0xb2, 0x42, 0x4f, 0x24, 0x88, 0x3a, 0xb0, 0x8e, 0xc7, 0x02, 0x53, 0x4e, - 0x18, 0x75, 0xd9, 0x48, 0x10, 0x46, 0xb9, 0xf1, 0x7a, 0x61, 0x4e, 0xda, 0xb5, 0x29, 0xff, 0xb7, - 0x8c, 0x8e, 0x2e, 0xc0, 0xa4, 0x8c, 0xba, 0x7e, 0x4c, 0x04, 0xf1, 0xbd, 0xa1, 0xfb, 0x88, 0xe1, - 0xea, 0x1c, 0xc3, 0x2d, 0xca, 0xe8, 0x91, 0xd2, 0xfe, 0xf4, 0xc0, 0xdb, 0x12, 0x50, 0xcd, 0x47, - 0x83, 0x0e, 0x61, 0x29, 0xdd, 0x08, 0x1c, 0xcb, 0x59, 0xe6, 0xcd, 0xd9, 0x9e, 0x1d, 0x66, 0x57, - 0xb2, 0xe4, 0x38, 0x17, 0xf9, 0x34, 0xe6, 0xe8, 0x33, 0xd0, 0xfb, 0x18, 0xab, 0x25, 0xf8, 0x78, - 0x56, 0x77, 0x8c, 0xb1, 0x93, 0x32, 0xac, 0xbf, 0x00, 0xee, 0x3c, 0xd0, 0x01, 0xc0, 0x28, 0xe9, - 0x0d, 0x89, 0xef, 0x5e, 0xe2, 0x7c, 0xeb, 0x1e, 0x3f, 0x4a, 0x2d, 0xe3, 0xfd, 0x8c, 0xe5, 0xda, - 0x45, 0x2c, 0xc0, 0xef, 0x59, 0xbb, 0x33, 0x16, 0xe0, 0x6c, 0xed, 0x22, 0x15, 0x59, 0x4f, 0x8b, - 0x50, 0xcd, 0x61, 0xf4, 0x3d, 0x54, 0x38, 0xa1, 0xe1, 0x10, 0xab, 0xb4, 0x9f, 0xbc, 0xdb, 0xc2, - 0xee, 0x4a, 0xe2, 0x49, 0xc1, 0x51, 0x12, 0xf4, 0x2d, 0x94, 0xa3, 0x64, 0x28, 0x88, 0x4a, 0xdf, - 0x98, 0xa3, 0x3d, 0x4b, 0x79, 0x27, 0x05, 0x27, 0x13, 0xd4, 0x7f, 0x80, 0x4a, 0xe6, 0x86, 0xbe, - 0x86, 0x52, 0x5a, 0x99, 0x4c, 0xbf, 0xb2, 0x6f, 0x3d, 0xb0, 0x50, 0x57, 0x4a, 0xde, 0xf3, 0xd4, - 0xce, 0x91, 0xfc, 0xfa, 0x3f, 0x1a, 0x94, 0xa5, 0x29, 0x6a, 0x43, 0xb5, 0x47, 0x84, 0x17, 0xc7, - 0x5e, 0xde, 0xbb, 0xdd, 0xfb, 0x2e, 0xd9, 0x5d, 0x96, 0x3a, 0x1c, 0xb1, 0x68, 0xe4, 0xf9, 0xa2, - 0x43, 0x44, 0x3b, 0x25, 0x3b, 0x53, 0x19, 0xfa, 0x0e, 0x60, 0xda, 0x4b, 0x6e, 0x14, 0xe5, 0xd8, - 0xe7, 0x35, 0xb3, 0x96, 0x37, 0x93, 0x77, 0xca, 0xa0, 0xf3, 0x24, 0xb2, 0xfe, 0xd6, 0x40, 0x3f, - 0xc6, 0x18, 0xfd, 0x0e, 0x15, 0x2f, 0x4a, 0xff, 0x78, 0x6a, 0x79, 0x3e, 0xba, 0xef, 0x22, 0x6b, - 0x20, 0xb4, 0xb3, 0x77, 0xf5, 0x62, 0xa7, 0xf0, 0xe4, 0xe5, 0x4e, 0x33, 0x24, 0x62, 0x90, 0xf4, - 0x6c, 0x9f, 0x45, 0xad, 0x8c, 0xa6, 0x7e, 0xbe, 0xe4, 0xc1, 0xa5, 0xba, 0x46, 0x53, 0x01, 0x77, - 0x94, 0x29, 0xda, 0x82, 0x5a, 0xe8, 0x71, 0x77, 0x48, 0x22, 0x22, 0x64, 0xd7, 0x4b, 0x4e, 0x35, - 0xf4, 0xf8, 0x2f, 0xe9, 0x73, 0xe7, 0xf0, 0xea, 0xc6, 0xd4, 0xae, 0x6f, 0x4c, 0xed, 0xd5, 0x8d, - 0xa9, 0xfd, 0x77, 0x6b, 0x16, 0xae, 0x6f, 0xcd, 0xc2, 0xb3, 0x5b, 0xb3, 0x70, 0xb1, 0x3b, 0x3f, - 0x91, 0xfa, 0x6e, 0xf4, 0x2a, 0x72, 0xd7, 0x0e, 0xde, 0x04, 0x00, 0x00, 0xff, 0xff, 0x03, 0x5c, - 0xe0, 0x71, 0x50, 0x06, 0x00, 0x00, + // 819 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x54, 0xcf, 0x6f, 0xe3, 0x44, + 0x14, 0x8e, 0xe3, 0x24, 0x4d, 0x5e, 0xdb, 0x6d, 0x77, 0x58, 0x24, 0x6f, 0x76, 0x49, 0x43, 0xa4, + 0x2e, 0x41, 0x02, 0x67, 0x29, 0x12, 0x3f, 0x84, 0xc4, 0xd2, 0x2c, 0xac, 0xba, 0x82, 0x05, 0x34, + 0xed, 0x69, 0x25, 0x64, 0x8d, 0xed, 0xa9, 0x33, 0x6a, 0x3c, 0x63, 0x3c, 0x63, 0x88, 0x8f, 0x1c, + 0xf6, 0xc4, 0x85, 0x0b, 0xff, 0x04, 0xff, 0x03, 0xf7, 0x3d, 0xae, 0x38, 0x71, 0x02, 0xd4, 0xfe, + 0x21, 0xa0, 0x19, 0x8f, 0xd3, 0xd2, 0x2e, 0xcd, 0x85, 0x53, 0x9e, 0x3f, 0x7f, 0xdf, 0xf7, 0x5e, + 0xde, 0x0f, 0xc3, 0x2d, 0x55, 0x66, 0x54, 0x4e, 0xd4, 0x62, 0x62, 0x02, 0x3f, 0xcb, 0x85, 0x12, + 0x68, 0x3b, 0x12, 0x32, 0x15, 0x32, 0x90, 0xf1, 0x89, 0xaf, 0x16, 0xfe, 0x77, 0xef, 0xf4, 0xef, + 0xa9, 0x19, 0xcb, 0xe3, 0x20, 0x23, 0xb9, 0x2a, 0x27, 0x86, 0x34, 0x49, 0x44, 0x22, 0xce, 0xa3, + 0x4a, 0xd9, 0xf7, 0xa2, 0xbc, 0xcc, 0x94, 0x98, 0x58, 0xdb, 0x73, 0xcf, 0xfe, 0xcd, 0xab, 0xd0, + 0xdd, 0x65, 0x72, 0xc9, 0x12, 0xce, 0x78, 0xf2, 0xaf, 0xb7, 0xb7, 0x13, 0x21, 0x92, 0x39, 0xad, + 0xb2, 0x85, 0xc5, 0xf1, 0x84, 0xf0, 0xb2, 0x7a, 0x35, 0xfa, 0xd1, 0x81, 0xe6, 0xd1, 0x02, 0xbd, + 0x05, 0xad, 0x50, 0xc4, 0xa5, 0xe7, 0x0c, 0x9d, 0xf1, 0xfa, 0x9e, 0xe7, 0x5f, 0xae, 0xda, 0x3f, + 0x5a, 0x4c, 0x45, 0x5c, 0x62, 0xc3, 0x42, 0xef, 0x43, 0x8f, 0x14, 0x6a, 0x16, 0x30, 0x7e, 0x2c, + 0xbc, 0xa6, 0x91, 0xf4, 0xaf, 0x4a, 0xf6, 0x0b, 0x35, 0x7b, 0xcc, 0x8f, 0x05, 0xee, 0x12, 0x1b, + 0xa1, 0x01, 0x80, 0xae, 0x8f, 0xa8, 0x22, 0xa7, 0xd2, 0x73, 0x87, 0xee, 0x78, 0x03, 0x5f, 0x40, + 0x46, 0x1c, 0xda, 0x47, 0x0b, 0x4c, 0xbe, 0x47, 0xaf, 0x01, 0xe8, 0x4c, 0x41, 0x58, 0x2a, 0x2a, + 0x4d, 0x55, 0x1b, 0xb8, 0xa7, 0x91, 0xa9, 0x06, 0xd0, 0x3d, 0xd8, 0x5a, 0x16, 0x60, 0x39, 0x4d, + 0xc3, 0xd9, 0xac, 0x53, 0x55, 0xbc, 0x55, 0xf9, 0x7e, 0x75, 0x60, 0xed, 0x90, 0x25, 0xfc, 0x53, + 0x11, 0xfd, 0x5f, 0x29, 0x6f, 0x43, 0x37, 0x9a, 0x11, 0xc6, 0x03, 0x16, 0x7b, 0xee, 0xd0, 0x19, + 0xf7, 0xf0, 0x9a, 0x79, 0x7e, 0x1c, 0xa3, 0x5d, 0xb8, 0x41, 0xa2, 0x48, 0x14, 0x5c, 0x05, 0xbc, + 0x48, 0x43, 0x9a, 0x7b, 0xad, 0xa1, 0x33, 0x6e, 0xe1, 0x4d, 0x8b, 0x7e, 0x69, 0x40, 0xf4, 0x26, + 0x6c, 0xd7, 0x34, 0x49, 0xbf, 0x2d, 0x28, 0x8f, 0xa8, 0xd7, 0x36, 0xc4, 0x2d, 0x8b, 0x1f, 0x5a, + 0x78, 0xf4, 0x73, 0x13, 0x3a, 0xd5, 0x64, 0xd0, 0x7d, 0xe8, 0xa6, 0x54, 0x4a, 0x92, 0x98, 0xe2, + 0xdd, 0xf1, 0xfa, 0xde, 0x2d, 0xbf, 0x1a, 0xbb, 0x5f, 0x8f, 0xdd, 0xdf, 0xe7, 0x25, 0x5e, 0xb2, + 0x10, 0x82, 0x56, 0x4a, 0xd3, 0x6a, 0x80, 0x3d, 0x6c, 0x62, 0x5d, 0xa2, 0x62, 0x29, 0x15, 0x85, + 0x0a, 0x66, 0x94, 0x25, 0x33, 0x65, 0xfe, 0x83, 0x8b, 0x37, 0x2d, 0x7a, 0x60, 0x40, 0x34, 0x85, + 0x9b, 0x74, 0xa1, 0x28, 0x97, 0x4c, 0xf0, 0x40, 0x64, 0x8a, 0x09, 0x2e, 0xbd, 0xbf, 0xd7, 0xae, + 0x49, 0xbb, 0xbd, 0xe4, 0x7f, 0x55, 0xd1, 0xd1, 0x53, 0x18, 0x70, 0xc1, 0x83, 0x28, 0x67, 0x8a, + 0x45, 0x64, 0x1e, 0xbc, 0xc4, 0x70, 0xeb, 0x1a, 0xc3, 0x3b, 0x5c, 0xf0, 0x87, 0x56, 0xfb, 0xd9, + 0x25, 0xef, 0x91, 0x82, 0x6e, 0xbd, 0x7d, 0xe8, 0x01, 0x6c, 0xe8, 0x89, 0xd3, 0xdc, 0x8c, 0xae, + 0x6e, 0xce, 0xdd, 0xab, 0xfb, 0x7a, 0x68, 0x58, 0x66, 0x63, 0xd7, 0xe5, 0x32, 0x96, 0xe8, 0x0d, + 0x70, 0x8f, 0x29, 0xb5, 0x7b, 0xfe, 0xea, 0x55, 0xdd, 0x23, 0x4a, 0xb1, 0x66, 0x8c, 0x9e, 0x39, + 0x00, 0xe7, 0x26, 0xe8, 0x63, 0x80, 0xac, 0x08, 0xe7, 0x2c, 0x0a, 0x4e, 0x68, 0x7d, 0x59, 0x3b, + 0x17, 0xe5, 0xd5, 0x81, 0x6b, 0x8b, 0xaf, 0x0d, 0xef, 0x73, 0x5a, 0xe2, 0x5e, 0x56, 0x87, 0xfa, + 0xca, 0x52, 0x11, 0xd3, 0x15, 0x57, 0xf6, 0x44, 0xc4, 0xb4, 0xba, 0xb2, 0xd4, 0x46, 0xa3, 0xdf, + 0x9a, 0xd0, 0xad, 0x61, 0xf4, 0x11, 0x74, 0x24, 0xe3, 0xc9, 0x9c, 0xda, 0x0a, 0x5e, 0xff, 0x6f, + 0x0b, 0xff, 0xd0, 0x10, 0x0f, 0x1a, 0xd8, 0x4a, 0xd0, 0x07, 0xd0, 0x4e, 0x8b, 0xb9, 0x62, 0x36, + 0xfd, 0xf0, 0x1a, 0xed, 0x13, 0xcd, 0x3b, 0x68, 0xe0, 0x4a, 0xd0, 0xff, 0x04, 0x3a, 0x95, 0x1b, + 0x7a, 0x0f, 0x5a, 0xba, 0x32, 0x93, 0xfe, 0xc6, 0xde, 0xe8, 0x92, 0x85, 0xfd, 0x5c, 0xd5, 0xfd, + 0xd7, 0x76, 0xd8, 0xf0, 0xfb, 0xcf, 0x1c, 0x68, 0x1b, 0x53, 0xb4, 0x0f, 0xdd, 0x90, 0x29, 0x92, + 0xe7, 0xa4, 0x6e, 0xe3, 0xee, 0xcb, 0xdb, 0xf8, 0x50, 0xa4, 0x19, 0x89, 0xd4, 0x94, 0xa9, 0x7d, + 0x4d, 0xc6, 0x4b, 0x19, 0xfa, 0x10, 0x60, 0xd9, 0x4b, 0x7d, 0xb8, 0xee, 0x8a, 0x66, 0xf6, 0xea, + 0x66, 0xca, 0x69, 0x1b, 0x5c, 0x59, 0xa4, 0xa3, 0x1f, 0x1c, 0x70, 0x1f, 0x51, 0x8a, 0xbe, 0x81, + 0x0e, 0x49, 0xf5, 0x11, 0xda, 0x45, 0x7a, 0xe5, 0xa2, 0x8b, 0xa9, 0x81, 0xf1, 0xe9, 0xfd, 0xe7, + 0x7f, 0xec, 0x34, 0x7e, 0xf9, 0x73, 0x67, 0x9c, 0x30, 0x35, 0x2b, 0x42, 0x3f, 0x12, 0xe9, 0xa4, + 0xa2, 0xd9, 0x9f, 0xb7, 0x65, 0x7c, 0x62, 0x3f, 0xd1, 0x5a, 0x20, 0xb1, 0x35, 0x45, 0x77, 0xa0, + 0x97, 0x10, 0x19, 0xcc, 0x59, 0xca, 0x94, 0xe9, 0x7a, 0x0b, 0x77, 0x13, 0x22, 0xbf, 0xd0, 0xcf, + 0xd3, 0x07, 0xcf, 0x4f, 0x07, 0xce, 0x8b, 0xd3, 0x81, 0xf3, 0xd7, 0xe9, 0xc0, 0xf9, 0xe9, 0x6c, + 0xd0, 0x78, 0x71, 0x36, 0x68, 0xfc, 0x7e, 0x36, 0x68, 0x3c, 0xdd, 0x5d, 0x9d, 0x68, 0xa2, 0x16, + 0x61, 0xc7, 0x9c, 0xd0, 0xbb, 0xff, 0x04, 0x00, 0x00, 0xff, 0xff, 0xb9, 0xa9, 0x76, 0x33, 0xac, + 0x06, 0x00, 0x00, } func (m *Tx) Marshal() (dAtA []byte, err error) { @@ -753,6 +815,52 @@ func (m *Tx) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } +func (m *TxRaw) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *TxRaw) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TxRaw) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Signatures) > 0 { + for iNdEx := len(m.Signatures) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Signatures[iNdEx]) + copy(dAtA[i:], m.Signatures[iNdEx]) + i = encodeVarintTypes(dAtA, i, uint64(len(m.Signatures[iNdEx]))) + i-- + dAtA[i] = 0x1a + } + } + if len(m.AuthInfoBytes) > 0 { + i -= len(m.AuthInfoBytes) + copy(dAtA[i:], m.AuthInfoBytes) + i = encodeVarintTypes(dAtA, i, uint64(len(m.AuthInfoBytes))) + i-- + dAtA[i] = 0x12 + } + if len(m.BodyBytes) > 0 { + i -= len(m.BodyBytes) + copy(dAtA[i:], m.BodyBytes) + i = encodeVarintTypes(dAtA, i, uint64(len(m.BodyBytes))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + func (m *SignDoc) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) @@ -790,27 +898,17 @@ func (m *SignDoc) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x1a } - if m.AuthInfo != nil { - { - size, err := m.AuthInfo.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTypes(dAtA, i, uint64(size)) - } + if len(m.AuthInfoBytes) > 0 { + i -= len(m.AuthInfoBytes) + copy(dAtA[i:], m.AuthInfoBytes) + i = encodeVarintTypes(dAtA, i, uint64(len(m.AuthInfoBytes))) i-- dAtA[i] = 0x12 } - if m.Body != nil { - { - size, err := m.Body.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTypes(dAtA, i, uint64(size)) - } + if len(m.BodyBytes) > 0 { + i -= len(m.BodyBytes) + copy(dAtA[i:], m.BodyBytes) + i = encodeVarintTypes(dAtA, i, uint64(len(m.BodyBytes))) i-- dAtA[i] = 0xa } @@ -1221,18 +1319,41 @@ func (m *Tx) Size() (n int) { return n } +func (m *TxRaw) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.BodyBytes) + if l > 0 { + n += 1 + l + sovTypes(uint64(l)) + } + l = len(m.AuthInfoBytes) + if l > 0 { + n += 1 + l + sovTypes(uint64(l)) + } + if len(m.Signatures) > 0 { + for _, b := range m.Signatures { + l = len(b) + n += 1 + l + sovTypes(uint64(l)) + } + } + return n +} + func (m *SignDoc) Size() (n int) { if m == nil { return 0 } var l int _ = l - if m.Body != nil { - l = m.Body.Size() + l = len(m.BodyBytes) + if l > 0 { n += 1 + l + sovTypes(uint64(l)) } - if m.AuthInfo != nil { - l = m.AuthInfo.Size() + l = len(m.AuthInfoBytes) + if l > 0 { n += 1 + l + sovTypes(uint64(l)) } l = len(m.ChainId) @@ -1566,6 +1687,159 @@ func (m *Tx) Unmarshal(dAtA []byte) error { } return nil } +func (m *TxRaw) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTypes + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: TxRaw: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: TxRaw: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field BodyBytes", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTypes + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthTypes + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthTypes + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.BodyBytes = append(m.BodyBytes[:0], dAtA[iNdEx:postIndex]...) + if m.BodyBytes == nil { + m.BodyBytes = []byte{} + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AuthInfoBytes", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTypes + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthTypes + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthTypes + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.AuthInfoBytes = append(m.AuthInfoBytes[:0], dAtA[iNdEx:postIndex]...) + if m.AuthInfoBytes == nil { + m.AuthInfoBytes = []byte{} + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Signatures", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTypes + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthTypes + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthTypes + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Signatures = append(m.Signatures, make([]byte, postIndex-iNdEx)) + copy(m.Signatures[len(m.Signatures)-1], dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipTypes(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthTypes + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthTypes + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func (m *SignDoc) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 @@ -1597,9 +1871,9 @@ func (m *SignDoc) Unmarshal(dAtA []byte) error { switch fieldNum { case 1: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field BodyBytes", wireType) } - var msglen int + var byteLen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTypes @@ -1609,33 +1883,31 @@ func (m *SignDoc) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + byteLen |= int(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + if byteLen < 0 { return ErrInvalidLengthTypes } - postIndex := iNdEx + msglen + postIndex := iNdEx + byteLen if postIndex < 0 { return ErrInvalidLengthTypes } if postIndex > l { return io.ErrUnexpectedEOF } - if m.Body == nil { - m.Body = &TxBody{} - } - if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + m.BodyBytes = append(m.BodyBytes[:0], dAtA[iNdEx:postIndex]...) + if m.BodyBytes == nil { + m.BodyBytes = []byte{} } iNdEx = postIndex case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AuthInfo", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field AuthInfoBytes", wireType) } - var msglen int + var byteLen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTypes @@ -1645,26 +1917,24 @@ func (m *SignDoc) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + byteLen |= int(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + if byteLen < 0 { return ErrInvalidLengthTypes } - postIndex := iNdEx + msglen + postIndex := iNdEx + byteLen if postIndex < 0 { return ErrInvalidLengthTypes } if postIndex > l { return io.ErrUnexpectedEOF } - if m.AuthInfo == nil { - m.AuthInfo = &AuthInfo{} - } - if err := m.AuthInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + m.AuthInfoBytes = append(m.AuthInfoBytes[:0], dAtA[iNdEx:postIndex]...) + if m.AuthInfoBytes == nil { + m.AuthInfoBytes = []byte{} } iNdEx = postIndex case 3: @@ -2149,7 +2419,7 @@ func (m *SignerInfo) Unmarshal(dAtA []byte) error { return io.ErrUnexpectedEOF } if m.PublicKey == nil { - m.PublicKey = &types.Any{} + m.PublicKey = &types1.PublicKey{} } if err := m.PublicKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err diff --git a/x/auth/signing/direct/direct.go b/x/auth/signing/direct/direct.go index b14878c3a5b8..1d2587f91638 100644 --- a/x/auth/signing/direct/direct.go +++ b/x/auth/signing/direct/direct.go @@ -3,6 +3,8 @@ package direct import ( "fmt" + signingtypes "github.com/cosmos/cosmos-sdk/types/tx/signing" + sdk "github.com/cosmos/cosmos-sdk/types" types "github.com/cosmos/cosmos-sdk/types/tx" "github.com/cosmos/cosmos-sdk/x/auth/signing" @@ -10,19 +12,19 @@ import ( type DirectModeHandler struct{} -func (h DirectModeHandler) DefaultMode() types.SignMode { - return types.SignMode_SIGN_MODE_DIRECT +func (h DirectModeHandler) DefaultMode() signingtypes.SignMode { + return signingtypes.SignMode_SIGN_MODE_DIRECT } var _ signing.SignModeHandler = DirectModeHandler{} -func (DirectModeHandler) Modes() []types.SignMode { - return []types.SignMode{types.SignMode_SIGN_MODE_DIRECT} +func (DirectModeHandler) Modes() []signingtypes.SignMode { + return []signingtypes.SignMode{signingtypes.SignMode_SIGN_MODE_DIRECT} } -func (DirectModeHandler) GetSignBytes(mode types.SignMode, data signing.SignerData, tx sdk.Tx) ([]byte, error) { - if mode != types.SignMode_SIGN_MODE_DIRECT { - return nil, fmt.Errorf("expected %s, got %s", types.SignMode_SIGN_MODE_DIRECT, mode) +func (DirectModeHandler) GetSignBytes(mode signingtypes.SignMode, data signing.SignerData, tx sdk.Tx) ([]byte, error) { + if mode != signingtypes.SignMode_SIGN_MODE_DIRECT { + return nil, fmt.Errorf("expected %s, got %s", signingtypes.SignMode_SIGN_MODE_DIRECT, mode) } protoTx, ok := tx.(types.ProtoTx) diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index 91bebff5c4d0..cac44af712ac 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -3,6 +3,8 @@ package direct import ( "testing" + signingtypes "github.com/cosmos/cosmos-sdk/types/tx/signing" + codectypes "github.com/cosmos/cosmos-sdk/codec/types" "github.com/cosmos/cosmos-sdk/simapp" "github.com/cosmos/cosmos-sdk/std" @@ -33,7 +35,7 @@ func TestDirectModeHandler(t *testing.T) { ModeInfo: &txtypes.ModeInfo{ Sum: &txtypes.ModeInfo_Single_{ Single: &txtypes.ModeInfo_Single{ - Mode: txtypes.SignMode_SIGN_MODE_DIRECT, + Mode: signingtypes.SignMode_SIGN_MODE_DIRECT, }, }, }, @@ -50,7 +52,7 @@ func TestDirectModeHandler(t *testing.T) { t.Log("verify modes and default-mode") var directModeHandler DirectModeHandler - require.Equal(t, directModeHandler.DefaultMode(), txtypes.SignMode_SIGN_MODE_DIRECT) + require.Equal(t, directModeHandler.DefaultMode(), signingtypes.SignMode_SIGN_MODE_DIRECT) require.Len(t, directModeHandler.Modes(), 1) signingData := signing.SignerData{ @@ -59,7 +61,7 @@ func TestDirectModeHandler(t *testing.T) { AccountSequence: 1, } - signBytes, err := directModeHandler.GetSignBytes(txtypes.SignMode_SIGN_MODE_DIRECT, signingData, tx) + signBytes, err := directModeHandler.GetSignBytes(signingtypes.SignMode_SIGN_MODE_DIRECT, signingData, tx) require.NoError(t, err) require.NotNil(t, signBytes) From e00d0074e64f211e17045059031a2ced48cff512 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Fri, 12 Jun 2020 16:04:46 -0400 Subject: [PATCH 08/43] Integrate SignatureV2 API --- types/tx/tx_wrapper.go | 73 +++++++++++++++++++++++++++++++++++++++--- 1 file changed, 68 insertions(+), 5 deletions(-) diff --git a/types/tx/tx_wrapper.go b/types/tx/tx_wrapper.go index 993851193eca..df61b6dabf68 100644 --- a/types/tx/tx_wrapper.go +++ b/types/tx/tx_wrapper.go @@ -3,6 +3,8 @@ package tx import ( "fmt" + "github.com/cosmos/cosmos-sdk/types/tx/signing" + codectypes "github.com/cosmos/cosmos-sdk/codec/types" "github.com/tendermint/tendermint/crypto" @@ -28,9 +30,7 @@ type Builder interface { SetMemo(string) SetGas(uint64) SetFee(sdk.Coins) - // TODO: replace SetSignerInfos with SetSignaturesV2 once SignatureV2 from #6373 is merged in - SetSignerInfos([]*SignerInfo) - SetSignatures([][]byte) + SetSignaturesV2(...signing.SignatureV2) error } func NewBuilder(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) Builder { @@ -239,7 +239,28 @@ func (t *builder) SetFee(coins sdk.Coins) { t.authInfoBz = nil } -func (t *builder) SetSignerInfos(infos []*SignerInfo) { +func (t builder) SetSignaturesV2(signatures ...signing.SignatureV2) error { + n := len(signatures) + signerInfos := make([]*SignerInfo, n) + rawSigs := make([][]byte, n) + + for i, sig := range signatures { + var modeInfo *ModeInfo + modeInfo, rawSigs[i] = SignatureDataToModeInfoAndSig(sig.Data) + pk, err := t.pubkeyCodec.Encode(sig.PubKey) + if err != nil { + return err + } + signerInfos[i] = &SignerInfo{ + PublicKey: pk, + ModeInfo: modeInfo, + } + } + + return nil +} + +func (t *builder) setSignerInfos(infos []*SignerInfo) { t.tx.AuthInfo.SignerInfos = infos // set authInfoBz to nil because the cached authInfoBz no longer matches tx.AuthInfo t.authInfoBz = nil @@ -247,6 +268,48 @@ func (t *builder) SetSignerInfos(infos []*SignerInfo) { t.pubKeys = nil } -func (t *builder) SetSignatures(sigs [][]byte) { +func (t *builder) setSignatures(sigs [][]byte) { t.tx.Signatures = sigs } + +func SignatureDataToModeInfoAndSig(data signing.SignatureData) (*ModeInfo, []byte) { + if data == nil { + return nil, nil + } + + switch data := data.(type) { + case *signing.SingleSignatureData: + return &ModeInfo{ + Sum: &ModeInfo_Single_{ + Single: &ModeInfo_Single{Mode: data.SignMode}, + }, + }, data.Signature + case *signing.MultiSignatureData: + n := len(data.Signatures) + modeInfos := make([]*ModeInfo, n) + sigs := make([][]byte, n) + + for i, d := range data.Signatures { + modeInfos[i], sigs[i] = SignatureDataToModeInfoAndSig(d) + } + + multisig := types.MultiSignature{ + Signatures: sigs, + } + sig, err := multisig.Marshal() + if err != nil { + panic(err) + } + + return &ModeInfo{ + Sum: &ModeInfo_Multi_{ + Multi: &ModeInfo_Multi{ + Bitarray: data.BitArray, + ModeInfos: modeInfos, + }, + }, + }, sig + default: + panic("unexpected case") + } +} From 5aea3eec036836bda80cdbf9d1a5f141d887cf3a Mon Sep 17 00:00:00 2001 From: anilCSE Date: Wed, 17 Jun 2020 00:42:26 +0530 Subject: [PATCH 09/43] Fix wrapper tests --- types/tx/signing/signature_data.go | 2 +- types/tx/tx_wrapper.go | 4 +++- types/tx/tx_wrapper_test.go | 12 +++++++++++- 3 files changed, 15 insertions(+), 3 deletions(-) diff --git a/types/tx/signing/signature_data.go b/types/tx/signing/signature_data.go index 174902ac106e..0dd61fe63459 100644 --- a/types/tx/signing/signature_data.go +++ b/types/tx/signing/signature_data.go @@ -5,7 +5,7 @@ import ( ) // SignatureData represents either a *SingleSignatureData or *MultiSignatureData. -// It is a convenience type that is easier to use in buiness logic than the encoded +// It is a convenience type that is easier to use in business logic than the encoded // protobuf ModeInfo's and raw signatures. type SignatureData interface { isSignatureData() diff --git a/types/tx/tx_wrapper.go b/types/tx/tx_wrapper.go index df61b6dabf68..8abcdd5ee044 100644 --- a/types/tx/tx_wrapper.go +++ b/types/tx/tx_wrapper.go @@ -239,7 +239,7 @@ func (t *builder) SetFee(coins sdk.Coins) { t.authInfoBz = nil } -func (t builder) SetSignaturesV2(signatures ...signing.SignatureV2) error { +func (t *builder) SetSignaturesV2(signatures ...signing.SignatureV2) error { n := len(signatures) signerInfos := make([]*SignerInfo, n) rawSigs := make([][]byte, n) @@ -257,6 +257,8 @@ func (t builder) SetSignaturesV2(signatures ...signing.SignatureV2) error { } } + t.setSignerInfos(signerInfos) + return nil } diff --git a/types/tx/tx_wrapper_test.go b/types/tx/tx_wrapper_test.go index a583ef777e83..d48ef0b4646d 100644 --- a/types/tx/tx_wrapper_test.go +++ b/types/tx/tx_wrapper_test.go @@ -41,6 +41,15 @@ func TestTxWrapper(t *testing.T) { }, }) + var sig signing.SignatureV2 + sig = signing.SignatureV2{ + PubKey: pubkey, + Data: &signing.SingleSignatureData{ + SignMode: signing.SignMode_SIGN_MODE_DIRECT, + Signature: pubkey.Bytes(), + }, + } + fee := Fee{Amount: sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), GasLimit: 20000} t.Log("verify that authInfo bytes encoded with DefaultTxEncoder and decoded with DefaultTxDecoder can be retrieved from GetAuthInfoBytes") @@ -87,7 +96,8 @@ func TestTxWrapper(t *testing.T) { require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) tx.SetGas(fee.GasLimit) require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) - tx.SetSignerInfos(signerInfo) + tx.SetSignaturesV2(sig) + // once fee, gas and signerInfos are all set, AuthInfo bytes should match require.Equal(t, authInfoBytes, tx.GetAuthInfoBytes()) From 1c8f96dd193bff86aa94906ea3a9cda6ce167659 Mon Sep 17 00:00:00 2001 From: anilCSE Date: Wed, 17 Jun 2020 01:11:38 +0530 Subject: [PATCH 10/43] Fix tests --- x/auth/signing/direct/direct_test.go | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index cac44af712ac..2849657b0309 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -41,6 +41,15 @@ func TestDirectModeHandler(t *testing.T) { }, }) + var sig signingtypes.SignatureV2 + sig = signingtypes.SignatureV2{ + PubKey: pubkey, + Data: &signingtypes.SingleSignatureData{ + SignMode: signingtypes.SignMode_SIGN_MODE_DIRECT, + Signature: pubkey.Bytes(), + }, + } + fee := txtypes.Fee{Amount: sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), GasLimit: 20000} tx.SetMsgs(msgs) @@ -48,7 +57,7 @@ func TestDirectModeHandler(t *testing.T) { tx.SetFee(fee.Amount) tx.SetGas(fee.GasLimit) - tx.SetSignerInfos(signerInfo) + tx.SetSignaturesV2(sig) t.Log("verify modes and default-mode") var directModeHandler DirectModeHandler From f2dae4378f68b9111db393350bacd652dc2eba6a Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 16 Jun 2020 15:46:57 -0400 Subject: [PATCH 11/43] Linting and API tweaks --- types/tx/{tx_wrapper.go => builder.go} | 9 +++++---- types/tx/{tx_wrapper_test.go => builder_test.go} | 9 +++++---- types/tx/{tx_decoder.go => decoder.go} | 0 types/tx/{tx_encoder.go => encoder.go} | 0 x/auth/signing/direct/direct.go | 14 +++++++------- x/auth/signing/direct/direct_test.go | 14 +++++++------- 6 files changed, 24 insertions(+), 22 deletions(-) rename types/tx/{tx_wrapper.go => builder.go} (97%) rename types/tx/{tx_wrapper_test.go => builder_test.go} (94%) rename types/tx/{tx_decoder.go => decoder.go} (100%) rename types/tx/{tx_encoder.go => encoder.go} (100%) diff --git a/types/tx/tx_wrapper.go b/types/tx/builder.go similarity index 97% rename from types/tx/tx_wrapper.go rename to types/tx/builder.go index 8abcdd5ee044..d12edb2714d2 100644 --- a/types/tx/tx_wrapper.go +++ b/types/tx/builder.go @@ -28,8 +28,8 @@ type Builder interface { SetMsgs([]sdk.Msg) SetMemo(string) - SetGas(uint64) - SetFee(sdk.Coins) + SetGasLimit(uint64) + SetFeeAmount(sdk.Coins) SetSignaturesV2(...signing.SignatureV2) error } @@ -217,7 +217,7 @@ func (t *builder) SetMemo(memo string) { t.bodyBz = nil } -func (t *builder) SetGas(limit uint64) { +func (t *builder) SetGasLimit(limit uint64) { if t.tx.AuthInfo.Fee == nil { t.tx.AuthInfo.Fee = &Fee{} } @@ -228,7 +228,7 @@ func (t *builder) SetGas(limit uint64) { t.authInfoBz = nil } -func (t *builder) SetFee(coins sdk.Coins) { +func (t *builder) SetFeeAmount(coins sdk.Coins) { if t.tx.AuthInfo.Fee == nil { t.tx.AuthInfo.Fee = &Fee{} } @@ -258,6 +258,7 @@ func (t *builder) SetSignaturesV2(signatures ...signing.SignatureV2) error { } t.setSignerInfos(signerInfos) + t.setSignatures(rawSigs) return nil } diff --git a/types/tx/tx_wrapper_test.go b/types/tx/builder_test.go similarity index 94% rename from types/tx/tx_wrapper_test.go rename to types/tx/builder_test.go index d48ef0b4646d..9959d465db62 100644 --- a/types/tx/tx_wrapper_test.go +++ b/types/tx/builder_test.go @@ -45,7 +45,7 @@ func TestTxWrapper(t *testing.T) { sig = signing.SignatureV2{ PubKey: pubkey, Data: &signing.SingleSignatureData{ - SignMode: signing.SignMode_SIGN_MODE_DIRECT, + SignMode: signing.SignMode_SIGN_MODE_DIRECT, Signature: pubkey.Bytes(), }, } @@ -92,11 +92,12 @@ func TestTxWrapper(t *testing.T) { t.Log("verify that updated AuthInfo results in the correct GetAuthInfoBytes and GetPubKeys") require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) - tx.SetFee(fee.Amount) + tx.SetFeeAmount(fee.Amount) require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) - tx.SetGas(fee.GasLimit) + tx.SetGasLimit(fee.GasLimit) require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) - tx.SetSignaturesV2(sig) + err = tx.SetSignaturesV2(sig) + require.NoError(t, err) // once fee, gas and signerInfos are all set, AuthInfo bytes should match require.Equal(t, authInfoBytes, tx.GetAuthInfoBytes()) diff --git a/types/tx/tx_decoder.go b/types/tx/decoder.go similarity index 100% rename from types/tx/tx_decoder.go rename to types/tx/decoder.go diff --git a/types/tx/tx_encoder.go b/types/tx/encoder.go similarity index 100% rename from types/tx/tx_encoder.go rename to types/tx/encoder.go diff --git a/x/auth/signing/direct/direct.go b/x/auth/signing/direct/direct.go index 1d2587f91638..bcf993aac869 100644 --- a/x/auth/signing/direct/direct.go +++ b/x/auth/signing/direct/direct.go @@ -10,19 +10,19 @@ import ( "github.com/cosmos/cosmos-sdk/x/auth/signing" ) -type DirectModeHandler struct{} +type ModeHandler struct{} -func (h DirectModeHandler) DefaultMode() signingtypes.SignMode { +func (h ModeHandler) DefaultMode() signingtypes.SignMode { return signingtypes.SignMode_SIGN_MODE_DIRECT } -var _ signing.SignModeHandler = DirectModeHandler{} +var _ signing.SignModeHandler = ModeHandler{} -func (DirectModeHandler) Modes() []signingtypes.SignMode { +func (ModeHandler) Modes() []signingtypes.SignMode { return []signingtypes.SignMode{signingtypes.SignMode_SIGN_MODE_DIRECT} } -func (DirectModeHandler) GetSignBytes(mode signingtypes.SignMode, data signing.SignerData, tx sdk.Tx) ([]byte, error) { +func (ModeHandler) GetSignBytes(mode signingtypes.SignMode, data signing.SignerData, tx sdk.Tx) ([]byte, error) { if mode != signingtypes.SignMode_SIGN_MODE_DIRECT { return nil, fmt.Errorf("expected %s, got %s", signingtypes.SignMode_SIGN_MODE_DIRECT, mode) } @@ -35,10 +35,10 @@ func (DirectModeHandler) GetSignBytes(mode signingtypes.SignMode, data signing.S bodyBz := protoTx.GetBodyBytes() authInfoBz := protoTx.GetAuthInfoBytes() - return DirectSignBytes(bodyBz, authInfoBz, data.ChainID, data.AccountNumber, data.AccountSequence) + return SignBytes(bodyBz, authInfoBz, data.ChainID, data.AccountNumber, data.AccountSequence) } -func DirectSignBytes(bodyBz, authInfoBz []byte, chainID string, accnum, sequence uint64) ([]byte, error) { +func SignBytes(bodyBz, authInfoBz []byte, chainID string, accnum, sequence uint64) ([]byte, error) { signDoc := types.SignDoc{ BodyBytes: bodyBz, AuthInfoBytes: authInfoBz, diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index 2849657b0309..0382d06194e1 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -41,11 +41,10 @@ func TestDirectModeHandler(t *testing.T) { }, }) - var sig signingtypes.SignatureV2 - sig = signingtypes.SignatureV2{ + sig := signingtypes.SignatureV2{ PubKey: pubkey, Data: &signingtypes.SingleSignatureData{ - SignMode: signingtypes.SignMode_SIGN_MODE_DIRECT, + SignMode: signingtypes.SignMode_SIGN_MODE_DIRECT, Signature: pubkey.Bytes(), }, } @@ -54,13 +53,14 @@ func TestDirectModeHandler(t *testing.T) { tx.SetMsgs(msgs) tx.SetMemo(memo) - tx.SetFee(fee.Amount) - tx.SetGas(fee.GasLimit) + tx.SetFeeAmount(fee.Amount) + tx.SetGasLimit(fee.GasLimit) - tx.SetSignaturesV2(sig) + err = tx.SetSignaturesV2(sig) + require.NoError(t, err) t.Log("verify modes and default-mode") - var directModeHandler DirectModeHandler + var directModeHandler ModeHandler require.Equal(t, directModeHandler.DefaultMode(), signingtypes.SignMode_SIGN_MODE_DIRECT) require.Len(t, directModeHandler.Modes(), 1) From afb288ddc3d664c7943f7fa75ba9117a48ed259e Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Thu, 18 Jun 2020 17:02:57 -0400 Subject: [PATCH 12/43] Update API --- proto/cosmos/tx/tx.proto | 2 +- types/tx/builder.go | 20 +- types/tx/builder_test.go | 8 +- types/tx/tx.pb.go | 490 +++++++++++++++++++++------ x/auth/signing/direct/direct_test.go | 14 +- 5 files changed, 406 insertions(+), 128 deletions(-) diff --git a/proto/cosmos/tx/tx.proto b/proto/cosmos/tx/tx.proto index 0d3b5b7bdbaf..a62bc7342764 100644 --- a/proto/cosmos/tx/tx.proto +++ b/proto/cosmos/tx/tx.proto @@ -88,7 +88,7 @@ message AuthInfo { message SignerInfo { // public_key is the public key of the signer. It is optional for accounts // that already exist in state - cosmos_sdk.crypto.v1.PublicKey public_key = 1; + cosmos.crypto.PublicKey public_key = 1; // mode_info describes the signing mode of the signer and is a nested // structure to support nested multisig pubkey's diff --git a/types/tx/builder.go b/types/tx/builder.go index d12edb2714d2..4b3d1df217eb 100644 --- a/types/tx/builder.go +++ b/types/tx/builder.go @@ -3,6 +3,8 @@ package tx import ( "fmt" + "github.com/cosmos/cosmos-sdk/client" + "github.com/cosmos/cosmos-sdk/types/tx/signing" codectypes "github.com/cosmos/cosmos-sdk/codec/types" @@ -26,11 +28,7 @@ type Builder interface { GetPubKeys() []crypto.PubKey // If signer already has pubkey in context, this list will have nil in its place - SetMsgs([]sdk.Msg) - SetMemo(string) - SetGasLimit(uint64) - SetFeeAmount(sdk.Coins) - SetSignaturesV2(...signing.SignatureV2) error + client.TxBuilder } func NewBuilder(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) Builder { @@ -193,14 +191,14 @@ func (t builder) GetPubKeys() []crypto.PubKey { return t.pubKeys } -func (t *builder) SetMsgs(msgs []sdk.Msg) { +func (t *builder) SetMsgs(msgs ...sdk.Msg) error { anys := make([]*codectypes.Any, len(msgs)) for i, msg := range msgs { var err error anys[i], err = codectypes.NewAnyWithValue(msg) if err != nil { - panic(err) + return err } } @@ -208,6 +206,8 @@ func (t *builder) SetMsgs(msgs []sdk.Msg) { // set bodyBz to nil because the cached bodyBz no longer matches tx.Body t.bodyBz = nil + + return nil } func (t *builder) SetMemo(memo string) { @@ -239,7 +239,7 @@ func (t *builder) SetFeeAmount(coins sdk.Coins) { t.authInfoBz = nil } -func (t *builder) SetSignaturesV2(signatures ...signing.SignatureV2) error { +func (t *builder) SetSignatures(signatures ...signing.SignatureV2) error { n := len(signatures) signerInfos := make([]*SignerInfo, n) rawSigs := make([][]byte, n) @@ -316,3 +316,7 @@ func SignatureDataToModeInfoAndSig(data signing.SignatureData) (*ModeInfo, []byt panic("unexpected case") } } + +func (t builder) GetTx() sdk.Tx { + return t +} diff --git a/types/tx/builder_test.go b/types/tx/builder_test.go index 9959d465db62..a68a63244b26 100644 --- a/types/tx/builder_test.go +++ b/types/tx/builder_test.go @@ -5,9 +5,10 @@ import ( "github.com/cosmos/cosmos-sdk/types/tx/signing" - authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" "github.com/stretchr/testify/require" + authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" + "github.com/cosmos/cosmos-sdk/codec" codectypes "github.com/cosmos/cosmos-sdk/codec/types" "github.com/cosmos/cosmos-sdk/std" @@ -83,7 +84,8 @@ func TestTxWrapper(t *testing.T) { t.Log("verify that calling the SetMsgs, SetMemo results in the correct GetBodyBytes") require.NotEqual(t, bodyBytes, tx.GetBodyBytes()) - tx.SetMsgs(msgs) + err = tx.SetMsgs(msgs...) + require.NoError(t, err) require.NotEqual(t, bodyBytes, tx.GetBodyBytes()) tx.SetMemo(memo) require.Equal(t, bodyBytes, tx.GetBodyBytes()) @@ -96,7 +98,7 @@ func TestTxWrapper(t *testing.T) { require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) tx.SetGasLimit(fee.GasLimit) require.NotEqual(t, authInfoBytes, tx.GetAuthInfoBytes()) - err = tx.SetSignaturesV2(sig) + err = tx.SetSignatures(sig) require.NoError(t, err) // once fee, gas and signerInfos are all set, AuthInfo bytes should match diff --git a/types/tx/tx.pb.go b/types/tx/tx.pb.go index 9fb635b818d3..6d663cdbd117 100644 --- a/types/tx/tx.pb.go +++ b/types/tx/tx.pb.go @@ -93,12 +93,70 @@ func (m *Tx) GetSignatures() [][]byte { return nil } -// SignDoc is the standard type used for signing transaction in SIGN_MODE_DIRECT +type TxRaw struct { + BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` + AuthInfoBytes []byte `protobuf:"bytes,2,opt,name=auth_info_bytes,json=authInfoBytes,proto3" json:"auth_info_bytes,omitempty"` + // signatures are the raw binary signatures of signers specified by body and auth_info + Signatures [][]byte `protobuf:"bytes,3,rep,name=signatures,proto3" json:"signatures,omitempty"` +} + +func (m *TxRaw) Reset() { *m = TxRaw{} } +func (m *TxRaw) String() string { return proto.CompactTextString(m) } +func (*TxRaw) ProtoMessage() {} +func (*TxRaw) Descriptor() ([]byte, []int) { + return fileDescriptor_9b35c9d5d6b7bce8, []int{1} +} +func (m *TxRaw) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TxRaw) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_TxRaw.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *TxRaw) XXX_Merge(src proto.Message) { + xxx_messageInfo_TxRaw.Merge(m, src) +} +func (m *TxRaw) XXX_Size() int { + return m.Size() +} +func (m *TxRaw) XXX_DiscardUnknown() { + xxx_messageInfo_TxRaw.DiscardUnknown(m) +} + +var xxx_messageInfo_TxRaw proto.InternalMessageInfo + +func (m *TxRaw) GetBodyBytes() []byte { + if m != nil { + return m.BodyBytes + } + return nil +} + +func (m *TxRaw) GetAuthInfoBytes() []byte { + if m != nil { + return m.AuthInfoBytes + } + return nil +} + +func (m *TxRaw) GetSignatures() [][]byte { + if m != nil { + return m.Signatures + } + return nil +} + type SignDoc struct { - // body is the TxBody from Tx - Body *TxBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"` - // auth_info is the AuthInfo from Tx - AuthInfo *AuthInfo `protobuf:"bytes,2,opt,name=auth_info,json=authInfo,proto3" json:"auth_info,omitempty"` + BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` + AuthInfoBytes []byte `protobuf:"bytes,2,opt,name=auth_info_bytes,json=authInfoBytes,proto3" json:"auth_info_bytes,omitempty"` // chain_id is the unique identifier of the chain this transaction targets. // It prevents signed transactions from being used on another chain by an // attacker @@ -114,7 +172,7 @@ func (m *SignDoc) Reset() { *m = SignDoc{} } func (m *SignDoc) String() string { return proto.CompactTextString(m) } func (*SignDoc) ProtoMessage() {} func (*SignDoc) Descriptor() ([]byte, []int) { - return fileDescriptor_9b35c9d5d6b7bce8, []int{1} + return fileDescriptor_9b35c9d5d6b7bce8, []int{2} } func (m *SignDoc) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -143,16 +201,16 @@ func (m *SignDoc) XXX_DiscardUnknown() { var xxx_messageInfo_SignDoc proto.InternalMessageInfo -func (m *SignDoc) GetBody() *TxBody { +func (m *SignDoc) GetBodyBytes() []byte { if m != nil { - return m.Body + return m.BodyBytes } return nil } -func (m *SignDoc) GetAuthInfo() *AuthInfo { +func (m *SignDoc) GetAuthInfoBytes() []byte { if m != nil { - return m.AuthInfo + return m.AuthInfoBytes } return nil } @@ -201,7 +259,7 @@ func (m *TxBody) Reset() { *m = TxBody{} } func (m *TxBody) String() string { return proto.CompactTextString(m) } func (*TxBody) ProtoMessage() {} func (*TxBody) Descriptor() ([]byte, []int) { - return fileDescriptor_9b35c9d5d6b7bce8, []int{2} + return fileDescriptor_9b35c9d5d6b7bce8, []int{3} } func (m *TxBody) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -280,7 +338,7 @@ func (m *AuthInfo) Reset() { *m = AuthInfo{} } func (m *AuthInfo) String() string { return proto.CompactTextString(m) } func (*AuthInfo) ProtoMessage() {} func (*AuthInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_9b35c9d5d6b7bce8, []int{3} + return fileDescriptor_9b35c9d5d6b7bce8, []int{4} } func (m *AuthInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -327,7 +385,7 @@ func (m *AuthInfo) GetFee() *Fee { type SignerInfo struct { // public_key is the public key of the signer. It is optional for accounts // that already exist in state - PublicKey *types.Any `protobuf:"bytes,1,opt,name=public_key,json=publicKey,proto3" json:"public_key,omitempty"` + PublicKey *types1.PublicKey `protobuf:"bytes,1,opt,name=public_key,json=publicKey,proto3" json:"public_key,omitempty"` // mode_info describes the signing mode of the signer and is a nested // structure to support nested multisig pubkey's ModeInfo *ModeInfo `protobuf:"bytes,2,opt,name=mode_info,json=modeInfo,proto3" json:"mode_info,omitempty"` @@ -337,7 +395,7 @@ func (m *SignerInfo) Reset() { *m = SignerInfo{} } func (m *SignerInfo) String() string { return proto.CompactTextString(m) } func (*SignerInfo) ProtoMessage() {} func (*SignerInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_9b35c9d5d6b7bce8, []int{4} + return fileDescriptor_9b35c9d5d6b7bce8, []int{5} } func (m *SignerInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -366,7 +424,7 @@ func (m *SignerInfo) XXX_DiscardUnknown() { var xxx_messageInfo_SignerInfo proto.InternalMessageInfo -func (m *SignerInfo) GetPublicKey() *types.Any { +func (m *SignerInfo) GetPublicKey() *types1.PublicKey { if m != nil { return m.PublicKey } @@ -395,7 +453,7 @@ func (m *ModeInfo) Reset() { *m = ModeInfo{} } func (m *ModeInfo) String() string { return proto.CompactTextString(m) } func (*ModeInfo) ProtoMessage() {} func (*ModeInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_9b35c9d5d6b7bce8, []int{5} + return fileDescriptor_9b35c9d5d6b7bce8, []int{6} } func (m *ModeInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -480,7 +538,7 @@ func (m *ModeInfo_Single) Reset() { *m = ModeInfo_Single{} } func (m *ModeInfo_Single) String() string { return proto.CompactTextString(m) } func (*ModeInfo_Single) ProtoMessage() {} func (*ModeInfo_Single) Descriptor() ([]byte, []int) { - return fileDescriptor_9b35c9d5d6b7bce8, []int{5, 0} + return fileDescriptor_9b35c9d5d6b7bce8, []int{6, 0} } func (m *ModeInfo_Single) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -529,7 +587,7 @@ func (m *ModeInfo_Multi) Reset() { *m = ModeInfo_Multi{} } func (m *ModeInfo_Multi) String() string { return proto.CompactTextString(m) } func (*ModeInfo_Multi) ProtoMessage() {} func (*ModeInfo_Multi) Descriptor() ([]byte, []int) { - return fileDescriptor_9b35c9d5d6b7bce8, []int{5, 1} + return fileDescriptor_9b35c9d5d6b7bce8, []int{6, 1} } func (m *ModeInfo_Multi) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -587,7 +645,7 @@ func (m *Fee) Reset() { *m = Fee{} } func (m *Fee) String() string { return proto.CompactTextString(m) } func (*Fee) ProtoMessage() {} func (*Fee) Descriptor() ([]byte, []int) { - return fileDescriptor_9b35c9d5d6b7bce8, []int{6} + return fileDescriptor_9b35c9d5d6b7bce8, []int{7} } func (m *Fee) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -632,6 +690,7 @@ func (m *Fee) GetGasLimit() uint64 { func init() { proto.RegisterType((*Tx)(nil), "cosmos.tx.Tx") + proto.RegisterType((*TxRaw)(nil), "cosmos.tx.TxRaw") proto.RegisterType((*SignDoc)(nil), "cosmos.tx.SignDoc") proto.RegisterType((*TxBody)(nil), "cosmos.tx.TxBody") proto.RegisterType((*AuthInfo)(nil), "cosmos.tx.AuthInfo") @@ -645,54 +704,57 @@ func init() { func init() { proto.RegisterFile("cosmos/tx/tx.proto", fileDescriptor_9b35c9d5d6b7bce8) } var fileDescriptor_9b35c9d5d6b7bce8 = []byte{ - // 749 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x54, 0xcd, 0x6e, 0xdb, 0x38, - 0x10, 0xb6, 0x2c, 0xdb, 0xb1, 0x27, 0xff, 0x4c, 0x16, 0x50, 0x1c, 0x40, 0x31, 0x0c, 0x04, 0xf0, - 0x1e, 0x56, 0xca, 0x3a, 0x7b, 0xd8, 0xdd, 0xcb, 0x22, 0xce, 0x6e, 0x90, 0x60, 0x9b, 0x16, 0xa0, - 0x83, 0x1e, 0x72, 0x11, 0x64, 0x99, 0x96, 0x89, 0x58, 0xa4, 0x2b, 0x52, 0xa8, 0x5d, 0xa0, 0xef, - 0xd0, 0x4b, 0x5f, 0xa2, 0x87, 0x3e, 0x47, 0x6e, 0xcd, 0xb1, 0xa7, 0xb6, 0x48, 0x1e, 0xa4, 0x85, - 0x28, 0xca, 0x71, 0x0b, 0x37, 0x3d, 0xf5, 0xa4, 0xe1, 0x37, 0xdf, 0x37, 0x33, 0x9c, 0x19, 0x11, - 0x50, 0xc0, 0x45, 0xc4, 0x85, 0x2b, 0x27, 0xae, 0x9c, 0x38, 0xe3, 0x98, 0x4b, 0x8e, 0x6a, 0x19, - 0xe6, 0xc8, 0x49, 0x7d, 0x3b, 0xe4, 0x21, 0x57, 0xa8, 0x9b, 0x5a, 0x19, 0xa1, 0x5e, 0xd7, 0xa2, - 0x20, 0x9e, 0x8e, 0x25, 0xd7, 0x1f, 0xed, 0xdb, 0xca, 0x7d, 0x59, 0x8c, 0x0c, 0xdc, 0xbb, 0xcf, - 0x22, 0x68, 0xc8, 0x28, 0x0b, 0xf3, 0xaf, 0x26, 0xec, 0x84, 0x9c, 0x87, 0x23, 0xe2, 0xaa, 0x53, - 0x2f, 0x19, 0xb8, 0x3e, 0x9b, 0x66, 0xae, 0xe6, 0x4b, 0x28, 0x5e, 0x4c, 0xd0, 0x3e, 0x94, 0x7a, - 0xbc, 0x3f, 0xb5, 0x8c, 0x86, 0xd1, 0x5a, 0x6e, 0x6f, 0x3a, 0xb3, 0x12, 0x9d, 0x8b, 0x49, 0x87, - 0xf7, 0xa7, 0x58, 0xb9, 0xd1, 0x01, 0xd4, 0xfc, 0x44, 0x0e, 0x3d, 0xca, 0x06, 0xdc, 0x2a, 0x2a, - 0xee, 0xd6, 0x1c, 0xf7, 0x28, 0x91, 0xc3, 0x33, 0x36, 0xe0, 0xb8, 0xea, 0x6b, 0x0b, 0xd9, 0x00, - 0x69, 0x29, 0xbe, 0x4c, 0x62, 0x22, 0x2c, 0xb3, 0x61, 0xb6, 0x56, 0xf0, 0x1c, 0xd2, 0x7c, 0x67, - 0xc0, 0x52, 0x97, 0x86, 0xec, 0x5f, 0x1e, 0xfc, 0xbc, 0x22, 0x76, 0xa0, 0x1a, 0x0c, 0x7d, 0xca, - 0x3c, 0xda, 0xb7, 0xcc, 0x86, 0xd1, 0xaa, 0xe1, 0x25, 0x75, 0x3e, 0xeb, 0xa3, 0x7d, 0x58, 0xf3, - 0x83, 0x80, 0x27, 0x4c, 0x7a, 0x2c, 0x89, 0x7a, 0x24, 0xb6, 0x4a, 0x0d, 0xa3, 0x55, 0xc2, 0xab, - 0x1a, 0x7d, 0xac, 0x40, 0xf4, 0x2b, 0x6c, 0xe4, 0x34, 0x41, 0x9e, 0x25, 0x84, 0x05, 0xc4, 0x2a, - 0x2b, 0xe2, 0xba, 0xc6, 0xbb, 0x1a, 0x6e, 0xbe, 0x2e, 0x42, 0x25, 0xab, 0x17, 0x1d, 0x40, 0x35, - 0x22, 0x42, 0xf8, 0x21, 0x11, 0x96, 0xd1, 0x30, 0x5b, 0xcb, 0xed, 0x6d, 0x27, 0x9b, 0x84, 0x93, - 0x4f, 0xc2, 0x39, 0x62, 0x53, 0x3c, 0x63, 0x21, 0x04, 0xa5, 0x88, 0x44, 0xd9, 0xb5, 0x6a, 0x58, - 0xd9, 0x69, 0x89, 0x92, 0x46, 0x84, 0x27, 0xd2, 0x1b, 0x12, 0x1a, 0x0e, 0xa5, 0xba, 0x83, 0x89, - 0x57, 0x35, 0x7a, 0xaa, 0x40, 0xd4, 0x81, 0x4d, 0x32, 0x91, 0x84, 0x09, 0xca, 0x99, 0xc7, 0xc7, - 0x92, 0x72, 0x26, 0xac, 0xcf, 0x4b, 0x0f, 0xa4, 0xdd, 0x98, 0xf1, 0x9f, 0x64, 0x74, 0x74, 0x09, - 0x36, 0xe3, 0xcc, 0x0b, 0x62, 0x2a, 0x69, 0xe0, 0x8f, 0xbc, 0x05, 0x01, 0xd7, 0x1f, 0x08, 0xb8, - 0xcb, 0x38, 0x3b, 0xd6, 0xda, 0xff, 0xbe, 0x89, 0xdd, 0x1c, 0x40, 0x35, 0x1f, 0x0d, 0xfa, 0x13, - 0x56, 0xd2, 0x1d, 0x20, 0xb1, 0x1a, 0x62, 0xde, 0x9c, 0x5f, 0xe6, 0xa6, 0xd8, 0x55, 0x6e, 0x35, - 0xc7, 0x65, 0x31, 0xb3, 0x05, 0x6a, 0x80, 0x39, 0x20, 0x44, 0x8f, 0x7d, 0x6d, 0x4e, 0x70, 0x42, - 0x08, 0x4e, 0x5d, 0x4d, 0x01, 0x70, 0x2f, 0x46, 0x87, 0x00, 0xe3, 0xa4, 0x37, 0xa2, 0x81, 0x77, - 0x45, 0xf2, 0xcd, 0x5a, 0x5c, 0x7c, 0x2d, 0xe3, 0xfd, 0x4f, 0xd4, 0x86, 0x45, 0xbc, 0x4f, 0xbe, - 0xb7, 0x61, 0xe7, 0xbc, 0x4f, 0xb2, 0x0d, 0x8b, 0xb4, 0xd5, 0x7c, 0x5b, 0x84, 0x6a, 0x0e, 0xa3, - 0x3f, 0xa0, 0x22, 0x28, 0x0b, 0x47, 0x44, 0xe7, 0xab, 0x2f, 0xd0, 0x3a, 0x5d, 0xc5, 0x38, 0x2d, - 0x60, 0xcd, 0x45, 0xbf, 0x43, 0x39, 0x4a, 0x46, 0x92, 0xea, 0x84, 0x3b, 0x8b, 0x44, 0xe7, 0x29, - 0xe1, 0xb4, 0x80, 0x33, 0x66, 0xfd, 0x2f, 0xa8, 0x64, 0x61, 0x90, 0x0b, 0xa5, 0xb4, 0x16, 0x95, - 0x70, 0xad, 0xbd, 0x3b, 0xa7, 0xcd, 0x1f, 0x82, 0xb4, 0x27, 0x69, 0x1c, 0xac, 0x88, 0xf5, 0xe7, - 0x50, 0x56, 0xc1, 0xd0, 0xdf, 0x50, 0xed, 0x51, 0xe9, 0xc7, 0xb1, 0x9f, 0xb7, 0xc7, 0xce, 0xd5, - 0xfa, 0xe1, 0x39, 0xe6, 0xd1, 0xd8, 0x0f, 0x64, 0x87, 0xca, 0xa3, 0x94, 0x85, 0x67, 0x7c, 0xd4, - 0x06, 0x98, 0xf5, 0x49, 0x58, 0x45, 0x35, 0xc4, 0x85, 0x8d, 0xaa, 0xe5, 0x8d, 0x12, 0x9d, 0x32, - 0x98, 0x22, 0x89, 0x9a, 0x2f, 0xc0, 0x3c, 0x21, 0x04, 0x3d, 0x85, 0x8a, 0x1f, 0xa5, 0xbf, 0x8f, - 0x5e, 0x81, 0x95, 0x5c, 0x7d, 0xcc, 0x29, 0xeb, 0x1c, 0x5c, 0x7f, 0xd8, 0x2b, 0xbc, 0xf9, 0xb8, - 0xd7, 0x0a, 0xa9, 0x1c, 0x26, 0x3d, 0x27, 0xe0, 0x91, 0xfb, 0xd5, 0xfb, 0xf7, 0x9b, 0xe8, 0x5f, - 0xb9, 0x72, 0x3a, 0x26, 0x99, 0x40, 0x60, 0x1d, 0x0d, 0xed, 0x42, 0x2d, 0xf4, 0x85, 0x37, 0xa2, - 0x11, 0x95, 0xaa, 0xa1, 0x25, 0x5c, 0x0d, 0x7d, 0xf1, 0x28, 0x3d, 0x77, 0xfe, 0xb9, 0xbe, 0xb5, - 0x8d, 0x9b, 0x5b, 0xdb, 0xf8, 0x74, 0x6b, 0x1b, 0xaf, 0xee, 0xec, 0xc2, 0xcd, 0x9d, 0x5d, 0x78, - 0x7f, 0x67, 0x17, 0x2e, 0xf7, 0x7f, 0x9c, 0xc8, 0x95, 0x93, 0x5e, 0x45, 0x2d, 0xce, 0xe1, 0x97, - 0x00, 0x00, 0x00, 0xff, 0xff, 0x14, 0xf8, 0x98, 0x8a, 0xde, 0x05, 0x00, 0x00, + // 795 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x54, 0x4f, 0x6f, 0xe3, 0x44, + 0x14, 0x8f, 0xe3, 0x24, 0x8d, 0x5f, 0xff, 0xed, 0xce, 0x2e, 0x92, 0x9b, 0x0a, 0x37, 0x8a, 0x54, + 0x14, 0x0e, 0xd8, 0xa5, 0x20, 0xf1, 0xe7, 0x82, 0x9a, 0xc2, 0xaa, 0x2b, 0x58, 0x40, 0x93, 0x8a, + 0xc3, 0x5e, 0x2c, 0xdb, 0x99, 0x38, 0xa3, 0x8d, 0x67, 0x82, 0x67, 0xac, 0xda, 0x48, 0x7c, 0x07, + 0x2e, 0x7c, 0x09, 0x0e, 0x7c, 0x03, 0xee, 0x7b, 0xdc, 0x23, 0x27, 0x40, 0xed, 0x07, 0x01, 0xcd, + 0x78, 0x9c, 0x0d, 0xab, 0xee, 0xf6, 0xb2, 0xa7, 0xbc, 0xf9, 0xbd, 0xdf, 0x7b, 0xbf, 0x97, 0xf7, + 0xc7, 0x80, 0x12, 0x2e, 0x32, 0x2e, 0x02, 0x59, 0x06, 0xb2, 0xf4, 0x57, 0x39, 0x97, 0x1c, 0x39, + 0x35, 0xe6, 0xcb, 0x72, 0xf0, 0x30, 0xe5, 0x29, 0xd7, 0x68, 0xa0, 0xac, 0x9a, 0x30, 0x18, 0x98, + 0xa0, 0x24, 0xaf, 0x56, 0x92, 0x9b, 0x1f, 0xe3, 0x7b, 0xd0, 0xf8, 0xea, 0x1c, 0x35, 0x78, 0xf4, + 0x52, 0x45, 0xd0, 0x94, 0x51, 0x96, 0x36, 0xbf, 0x86, 0x70, 0x90, 0x72, 0x9e, 0x2e, 0x49, 0xa0, + 0x5f, 0x71, 0x31, 0x0f, 0x22, 0x56, 0xd5, 0xae, 0xd1, 0xcf, 0xd0, 0xbe, 0x2c, 0xd1, 0x31, 0x74, + 0x62, 0x3e, 0xab, 0x5c, 0x6b, 0x68, 0x8d, 0xb7, 0x4f, 0xef, 0xfb, 0xeb, 0x12, 0xfd, 0xcb, 0x72, + 0xc2, 0x67, 0x15, 0xd6, 0x6e, 0x74, 0x02, 0x4e, 0x54, 0xc8, 0x45, 0x48, 0xd9, 0x9c, 0xbb, 0x6d, + 0xcd, 0x7d, 0xb0, 0xc1, 0x3d, 0x2b, 0xe4, 0xe2, 0x31, 0x9b, 0x73, 0xdc, 0x8f, 0x8c, 0x85, 0x3c, + 0x00, 0x55, 0x4a, 0x24, 0x8b, 0x9c, 0x08, 0xd7, 0x1e, 0xda, 0xe3, 0x1d, 0xbc, 0x81, 0x8c, 0x18, + 0x74, 0x2f, 0x4b, 0x1c, 0x5d, 0xa1, 0x77, 0x01, 0x94, 0x44, 0x18, 0x57, 0x92, 0x08, 0x5d, 0xc7, + 0x0e, 0x76, 0x14, 0x32, 0x51, 0x00, 0x7a, 0x0f, 0xf6, 0xd7, 0xca, 0x86, 0xd3, 0xd6, 0x9c, 0xdd, + 0x46, 0xaa, 0xe6, 0xdd, 0xa5, 0xf7, 0x87, 0x05, 0x5b, 0x53, 0x9a, 0xb2, 0x2f, 0x79, 0xf2, 0xb6, + 0x24, 0x0f, 0xa0, 0x9f, 0x2c, 0x22, 0xca, 0x42, 0x3a, 0x73, 0xed, 0xa1, 0x35, 0x76, 0xf0, 0x96, + 0x7e, 0x3f, 0x9e, 0xa1, 0x63, 0xd8, 0x8b, 0x92, 0x84, 0x17, 0x4c, 0x86, 0xac, 0xc8, 0x62, 0x92, + 0xbb, 0x9d, 0xa1, 0x35, 0xee, 0xe0, 0x5d, 0x83, 0x7e, 0xab, 0x41, 0xf4, 0x3e, 0xdc, 0x6b, 0x68, + 0x82, 0xfc, 0x58, 0x10, 0x96, 0x10, 0xb7, 0xab, 0x89, 0xfb, 0x06, 0x9f, 0x1a, 0x78, 0xf4, 0x6b, + 0x1b, 0x7a, 0xf5, 0x48, 0xd0, 0x09, 0xf4, 0x33, 0x22, 0x44, 0x94, 0xea, 0xe2, 0xed, 0xf1, 0xf6, + 0xe9, 0x43, 0xbf, 0x9e, 0xb3, 0xdf, 0xcc, 0xd9, 0x3f, 0x63, 0x15, 0x5e, 0xb3, 0x10, 0x82, 0x4e, + 0x46, 0xb2, 0x7a, 0x72, 0x0e, 0xd6, 0xb6, 0x2a, 0x51, 0xd2, 0x8c, 0xf0, 0x42, 0x86, 0x0b, 0x42, + 0xd3, 0x85, 0xd4, 0xff, 0xc1, 0xc6, 0xbb, 0x06, 0xbd, 0xd0, 0x20, 0x9a, 0xc0, 0x7d, 0x52, 0x4a, + 0xc2, 0x04, 0xe5, 0x2c, 0xe4, 0x2b, 0x49, 0x39, 0x13, 0xee, 0xbf, 0x5b, 0x6f, 0x90, 0xbd, 0xb7, + 0xe6, 0x7f, 0x57, 0xd3, 0xd1, 0x53, 0xf0, 0x18, 0x67, 0x61, 0x92, 0x53, 0x49, 0x93, 0x68, 0x19, + 0xde, 0x92, 0x70, 0xff, 0x0d, 0x09, 0x0f, 0x19, 0x67, 0xe7, 0x26, 0xf6, 0xab, 0x57, 0x72, 0x8f, + 0xe6, 0xd0, 0x6f, 0xb6, 0x0f, 0x7d, 0x0a, 0x3b, 0x6a, 0xe2, 0x24, 0xd7, 0xa3, 0x6b, 0x9a, 0xf3, + 0xce, 0xc6, 0xa2, 0x4e, 0xb5, 0x5b, 0xaf, 0xea, 0xb6, 0x58, 0xdb, 0x02, 0x0d, 0xc1, 0x9e, 0x13, + 0x62, 0x36, 0x7b, 0x6f, 0x23, 0xe0, 0x11, 0x21, 0x58, 0xb9, 0x46, 0x57, 0x00, 0x2f, 0x83, 0xd1, + 0x27, 0x00, 0xab, 0x22, 0x5e, 0xd2, 0x24, 0x7c, 0x46, 0x9a, 0xe3, 0x71, 0x9b, 0x30, 0x73, 0xb7, + 0xdf, 0x6b, 0xc2, 0xd7, 0xa4, 0xc2, 0xce, 0xaa, 0x31, 0xd5, 0x21, 0x65, 0x7c, 0x46, 0x5e, 0x77, + 0x48, 0x4f, 0xf8, 0x8c, 0xd4, 0x87, 0x94, 0x19, 0x6b, 0xf4, 0x7b, 0x1b, 0xfa, 0x0d, 0x8c, 0x3e, + 0x86, 0x9e, 0xa0, 0x2c, 0x5d, 0x12, 0xa3, 0x39, 0xb8, 0x25, 0xd6, 0x9f, 0x6a, 0xc6, 0x45, 0x0b, + 0x1b, 0x2e, 0xfa, 0x10, 0xba, 0x59, 0xb1, 0x94, 0xd4, 0x08, 0x1e, 0xdc, 0x16, 0xf4, 0x44, 0x11, + 0x2e, 0x5a, 0xb8, 0x66, 0x0e, 0x3e, 0x83, 0x5e, 0x9d, 0x06, 0x05, 0xd0, 0x51, 0xb5, 0x68, 0xc1, + 0xbd, 0xd3, 0xc3, 0x8d, 0xd8, 0xe6, 0x53, 0xa3, 0xfa, 0xa2, 0xf2, 0x60, 0x4d, 0x1c, 0x5c, 0x41, + 0x57, 0x27, 0x43, 0x9f, 0x43, 0x3f, 0xa6, 0x32, 0xca, 0xf3, 0xa8, 0x69, 0x91, 0xf7, 0x4a, 0x8b, + 0xce, 0x79, 0xb6, 0x8a, 0x12, 0x39, 0xa1, 0xf2, 0x4c, 0xb1, 0xf0, 0x9a, 0x8f, 0x4e, 0x01, 0xd6, + 0x7d, 0x52, 0xe7, 0x67, 0xbf, 0xae, 0x51, 0x4e, 0xd3, 0x28, 0x31, 0xe9, 0x82, 0x2d, 0x8a, 0x6c, + 0xf4, 0x13, 0xd8, 0x8f, 0x08, 0x41, 0x3f, 0x40, 0x2f, 0xca, 0xd4, 0x09, 0x99, 0x35, 0xd8, 0x69, + 0xa2, 0xcf, 0x39, 0x65, 0x93, 0x93, 0xe7, 0x7f, 0x1d, 0xb5, 0x7e, 0xfb, 0xfb, 0x68, 0x9c, 0x52, + 0xb9, 0x28, 0x62, 0x3f, 0xe1, 0x59, 0xf0, 0xbf, 0x2f, 0xec, 0x07, 0x62, 0xf6, 0x2c, 0x90, 0xd5, + 0x8a, 0xd4, 0x01, 0x02, 0x9b, 0x6c, 0xe8, 0x10, 0x9c, 0x34, 0x12, 0xe1, 0x92, 0x66, 0x54, 0xea, + 0x86, 0x76, 0x70, 0x3f, 0x8d, 0xc4, 0x37, 0xea, 0x3d, 0xf9, 0xe2, 0xf9, 0xb5, 0x67, 0xbd, 0xb8, + 0xf6, 0xac, 0x7f, 0xae, 0x3d, 0xeb, 0x97, 0x1b, 0xaf, 0xf5, 0xe2, 0xc6, 0x6b, 0xfd, 0x79, 0xe3, + 0xb5, 0x9e, 0x1e, 0xdf, 0x2d, 0x14, 0xc8, 0x32, 0xee, 0xe9, 0xcd, 0xff, 0xe8, 0xbf, 0x00, 0x00, + 0x00, 0xff, 0xff, 0x40, 0xba, 0x1f, 0xb6, 0x40, 0x06, 0x00, 0x00, } func (m *Tx) Marshal() (dAtA []byte, err error) { @@ -751,6 +813,52 @@ func (m *Tx) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } +func (m *TxRaw) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *TxRaw) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TxRaw) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Signatures) > 0 { + for iNdEx := len(m.Signatures) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Signatures[iNdEx]) + copy(dAtA[i:], m.Signatures[iNdEx]) + i = encodeVarintTx(dAtA, i, uint64(len(m.Signatures[iNdEx]))) + i-- + dAtA[i] = 0x1a + } + } + if len(m.AuthInfoBytes) > 0 { + i -= len(m.AuthInfoBytes) + copy(dAtA[i:], m.AuthInfoBytes) + i = encodeVarintTx(dAtA, i, uint64(len(m.AuthInfoBytes))) + i-- + dAtA[i] = 0x12 + } + if len(m.BodyBytes) > 0 { + i -= len(m.BodyBytes) + copy(dAtA[i:], m.BodyBytes) + i = encodeVarintTx(dAtA, i, uint64(len(m.BodyBytes))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + func (m *SignDoc) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) @@ -788,27 +896,17 @@ func (m *SignDoc) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x1a } - if m.AuthInfo != nil { - { - size, err := m.AuthInfo.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } + if len(m.AuthInfoBytes) > 0 { + i -= len(m.AuthInfoBytes) + copy(dAtA[i:], m.AuthInfoBytes) + i = encodeVarintTx(dAtA, i, uint64(len(m.AuthInfoBytes))) i-- dAtA[i] = 0x12 } - if m.Body != nil { - { - size, err := m.Body.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } + if len(m.BodyBytes) > 0 { + i -= len(m.BodyBytes) + copy(dAtA[i:], m.BodyBytes) + i = encodeVarintTx(dAtA, i, uint64(len(m.BodyBytes))) i-- dAtA[i] = 0xa } @@ -1219,18 +1317,41 @@ func (m *Tx) Size() (n int) { return n } +func (m *TxRaw) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.BodyBytes) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = len(m.AuthInfoBytes) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + if len(m.Signatures) > 0 { + for _, b := range m.Signatures { + l = len(b) + n += 1 + l + sovTx(uint64(l)) + } + } + return n +} + func (m *SignDoc) Size() (n int) { if m == nil { return 0 } var l int _ = l - if m.Body != nil { - l = m.Body.Size() + l = len(m.BodyBytes) + if l > 0 { n += 1 + l + sovTx(uint64(l)) } - if m.AuthInfo != nil { - l = m.AuthInfo.Size() + l = len(m.AuthInfoBytes) + if l > 0 { n += 1 + l + sovTx(uint64(l)) } l = len(m.ChainId) @@ -1564,6 +1685,159 @@ func (m *Tx) Unmarshal(dAtA []byte) error { } return nil } +func (m *TxRaw) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: TxRaw: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: TxRaw: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field BodyBytes", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.BodyBytes = append(m.BodyBytes[:0], dAtA[iNdEx:postIndex]...) + if m.BodyBytes == nil { + m.BodyBytes = []byte{} + } + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field AuthInfoBytes", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.AuthInfoBytes = append(m.AuthInfoBytes[:0], dAtA[iNdEx:postIndex]...) + if m.AuthInfoBytes == nil { + m.AuthInfoBytes = []byte{} + } + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Signatures", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Signatures = append(m.Signatures, make([]byte, postIndex-iNdEx)) + copy(m.Signatures[len(m.Signatures)-1], dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipTx(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthTx + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthTx + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func (m *SignDoc) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 @@ -1595,9 +1869,9 @@ func (m *SignDoc) Unmarshal(dAtA []byte) error { switch fieldNum { case 1: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field BodyBytes", wireType) } - var msglen int + var byteLen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -1607,33 +1881,31 @@ func (m *SignDoc) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + byteLen |= int(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + if byteLen < 0 { return ErrInvalidLengthTx } - postIndex := iNdEx + msglen + postIndex := iNdEx + byteLen if postIndex < 0 { return ErrInvalidLengthTx } if postIndex > l { return io.ErrUnexpectedEOF } - if m.Body == nil { - m.Body = &TxBody{} - } - if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + m.BodyBytes = append(m.BodyBytes[:0], dAtA[iNdEx:postIndex]...) + if m.BodyBytes == nil { + m.BodyBytes = []byte{} } iNdEx = postIndex case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AuthInfo", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field AuthInfoBytes", wireType) } - var msglen int + var byteLen int for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowTx @@ -1643,26 +1915,24 @@ func (m *SignDoc) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + byteLen |= int(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + if byteLen < 0 { return ErrInvalidLengthTx } - postIndex := iNdEx + msglen + postIndex := iNdEx + byteLen if postIndex < 0 { return ErrInvalidLengthTx } if postIndex > l { return io.ErrUnexpectedEOF } - if m.AuthInfo == nil { - m.AuthInfo = &AuthInfo{} - } - if err := m.AuthInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + m.AuthInfoBytes = append(m.AuthInfoBytes[:0], dAtA[iNdEx:postIndex]...) + if m.AuthInfoBytes == nil { + m.AuthInfoBytes = []byte{} } iNdEx = postIndex case 3: @@ -2147,7 +2417,7 @@ func (m *SignerInfo) Unmarshal(dAtA []byte) error { return io.ErrUnexpectedEOF } if m.PublicKey == nil { - m.PublicKey = &types.Any{} + m.PublicKey = &types1.PublicKey{} } if err := m.PublicKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index 0382d06194e1..eed73f7b58a6 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -5,6 +5,8 @@ import ( signingtypes "github.com/cosmos/cosmos-sdk/types/tx/signing" + "github.com/stretchr/testify/require" + codectypes "github.com/cosmos/cosmos-sdk/codec/types" "github.com/cosmos/cosmos-sdk/simapp" "github.com/cosmos/cosmos-sdk/std" @@ -12,7 +14,6 @@ import ( txtypes "github.com/cosmos/cosmos-sdk/types/tx" "github.com/cosmos/cosmos-sdk/x/auth/signing" authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - "github.com/stretchr/testify/require" ) func TestDirectModeHandler(t *testing.T) { @@ -22,7 +23,7 @@ func TestDirectModeHandler(t *testing.T) { _, pubkey, addr := authtypes.KeyTestPubAddr() cdc := std.DefaultPublicKeyCodec{} - tx := txtypes.NewBuilder(app.AppCodec().Marshaler, std.DefaultPublicKeyCodec{}) + tx := txtypes.NewBuilder(app.AppCodec(), std.DefaultPublicKeyCodec{}) memo := "sometestmemo" msgs := []sdk.Msg{authtypes.NewTestMsg(addr)} @@ -51,12 +52,13 @@ func TestDirectModeHandler(t *testing.T) { fee := txtypes.Fee{Amount: sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), GasLimit: 20000} - tx.SetMsgs(msgs) + err = tx.SetMsgs(msgs...) + require.NoError(t, err) tx.SetMemo(memo) tx.SetFeeAmount(fee.Amount) tx.SetGasLimit(fee.GasLimit) - err = tx.SetSignaturesV2(sig) + err = tx.SetSignatures(sig) require.NoError(t, err) t.Log("verify modes and default-mode") @@ -80,7 +82,7 @@ func TestDirectModeHandler(t *testing.T) { SignerInfos: signerInfo, } - authInfoBytes := app.AppCodec().Marshaler.MustMarshalBinaryBare(authInfo) + authInfoBytes := app.AppCodec().MustMarshalBinaryBare(authInfo) anys := make([]*codectypes.Any, len(msgs)) @@ -96,7 +98,7 @@ func TestDirectModeHandler(t *testing.T) { Memo: memo, Messages: anys, } - bodyBytes := app.AppCodec().Marshaler.MustMarshalBinaryBare(txBody) + bodyBytes := app.AppCodec().MustMarshalBinaryBare(txBody) t.Log("verify GetSignBytes with generating sign bytes by marshaling SignDoc") signDoc := txtypes.SignDoc{ From 24095cc985dff50417b350f3b4a3d4dec0561153 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Mon, 29 Jun 2020 13:16:56 -0400 Subject: [PATCH 13/43] WIP on updating API --- client/testutil/suite.go | 2 +- types/tx/decoder.go | 44 ------- types/tx/encoder.go | 25 ---- types/tx/{ => generator}/builder.go | 148 +++++++++++++++++++---- types/tx/{ => generator}/builder_test.go | 22 ++-- types/tx/generator/decoder.go | 79 ++++++++++++ types/tx/generator/encoder.go | 43 +++++++ types/tx/generator/generator.go | 68 +++++++++++ types/tx/generator/generator_test.go | 17 +++ x/auth/signing/direct/direct_test.go | 4 +- 10 files changed, 345 insertions(+), 107 deletions(-) delete mode 100644 types/tx/decoder.go delete mode 100644 types/tx/encoder.go rename types/tx/{ => generator}/builder.go (71%) rename types/tx/{ => generator}/builder_test.go (87%) create mode 100644 types/tx/generator/decoder.go create mode 100644 types/tx/generator/encoder.go create mode 100644 types/tx/generator/generator.go create mode 100644 types/tx/generator/generator_test.go diff --git a/client/testutil/suite.go b/client/testutil/suite.go index 8ec3c1de2232..cb3cc9d867e5 100644 --- a/client/testutil/suite.go +++ b/client/testutil/suite.go @@ -67,9 +67,9 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetMsgs() { } type HasSignaturesTx interface { - GetSignatures() [][]byte GetSigners() []sdk.AccAddress GetPubKeys() []crypto.PubKey // If signer already has pubkey in context, this list will have nil in its place + GetSignatures() [][]byte } func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { diff --git a/types/tx/decoder.go b/types/tx/decoder.go deleted file mode 100644 index a05fe9145226..000000000000 --- a/types/tx/decoder.go +++ /dev/null @@ -1,44 +0,0 @@ -package tx - -import ( - "github.com/tendermint/tendermint/crypto" - - "github.com/cosmos/cosmos-sdk/codec" - cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types" - sdk "github.com/cosmos/cosmos-sdk/types" -) - -func DefaultTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCodec) sdk.TxDecoder { - return func(txBytes []byte) (sdk.Tx, error) { - var raw TxRaw - err := cdc.UnmarshalBinaryBare(txBytes, &raw) - if err != nil { - return nil, err - } - - var tx Tx - err = cdc.UnmarshalBinaryBare(txBytes, &tx) - if err != nil { - return nil, err - } - - signerInfos := tx.AuthInfo.SignerInfos - pks := make([]crypto.PubKey, len(signerInfos)) - for i, si := range signerInfos { - pk, err := keyCodec.Decode(si.PublicKey) - if err != nil { - return nil, err - } - pks[i] = pk - } - - return builder{ - tx: &tx, - bodyBz: raw.BodyBytes, - authInfoBz: raw.AuthInfoBytes, - pubKeys: pks, - marshaler: cdc, - pubkeyCodec: keyCodec, - }, nil - } -} diff --git a/types/tx/encoder.go b/types/tx/encoder.go deleted file mode 100644 index 277b7ed2bd4c..000000000000 --- a/types/tx/encoder.go +++ /dev/null @@ -1,25 +0,0 @@ -package tx - -import ( - "fmt" - - "github.com/cosmos/cosmos-sdk/codec" - "github.com/cosmos/cosmos-sdk/types" -) - -func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { - return func(tx types.Tx) ([]byte, error) { - wrapper, ok := tx.(builder) - if !ok { - return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) - } - - raw := &TxRaw{ - BodyBytes: wrapper.bodyBz, - AuthInfoBytes: wrapper.authInfoBz, - Signatures: wrapper.tx.Signatures, - } - - return marshaler.MarshalBinaryBare(raw) - } -} diff --git a/types/tx/builder.go b/types/tx/generator/builder.go similarity index 71% rename from types/tx/builder.go rename to types/tx/generator/builder.go index 4b3d1df217eb..d627b2584439 100644 --- a/types/tx/builder.go +++ b/types/tx/generator/builder.go @@ -1,8 +1,12 @@ -package tx +package generator import ( "fmt" + "github.com/cosmos/cosmos-sdk/client/testutil" + + "github.com/cosmos/cosmos-sdk/types/tx" + "github.com/cosmos/cosmos-sdk/client" "github.com/cosmos/cosmos-sdk/types/tx/signing" @@ -23,8 +27,12 @@ import ( // crypto.PubKey instances. type Builder interface { sdk.Tx + sdk.FeeTx + sdk.TxWithMemo + testutil.HasSignaturesTx + GetSignaturesV2() ([]signing.SignatureV2, error) - ProtoTx + tx.ProtoTx GetPubKeys() []crypto.PubKey // If signer already has pubkey in context, this list will have nil in its place @@ -33,10 +41,10 @@ type Builder interface { func NewBuilder(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) Builder { return &builder{ - tx: &Tx{ - Body: &TxBody{}, - AuthInfo: &AuthInfo{ - Fee: &Fee{}, + tx: &tx.Tx{ + Body: &tx.TxBody{}, + AuthInfo: &tx.AuthInfo{ + Fee: &tx.Fee{}, }, }, marshaler: marshaler, @@ -45,7 +53,7 @@ func NewBuilder(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) Bui } type builder struct { - tx *Tx + tx *tx.Tx // bodyBz represents the protobuf encoding of TxBody. This should be encoding // from the client using TxRaw if the tx was decoded from the wire @@ -79,8 +87,8 @@ func (t builder) GetMsgs() []sdk.Msg { const MaxGasWanted = uint64((1 << 63) - 1) func (t builder) ValidateBasic() error { - tx := t.tx - if tx == nil { + theTx := t.tx + if theTx == nil { return fmt.Errorf("bad Tx") } @@ -113,7 +121,7 @@ func (t builder) ValidateBasic() error { ) } - sigs := tx.Signatures + sigs := theTx.Signatures if len(sigs) == 0 { return sdkerrors.ErrNoSignatures @@ -191,6 +199,48 @@ func (t builder) GetPubKeys() []crypto.PubKey { return t.pubKeys } +func (t builder) GetGas() uint64 { + return t.tx.AuthInfo.Fee.GasLimit +} + +func (t builder) GetFee() sdk.Coins { + return t.tx.AuthInfo.Fee.Amount +} + +func (t builder) FeePayer() sdk.AccAddress { + return t.GetSigners()[0] +} + +func (t builder) GetMemo() string { + return t.tx.Body.Memo +} + +func (t builder) GetSignatures() [][]byte { + return t.tx.Signatures +} + +func (t builder) GetSignaturesV2() ([]signing.SignatureV2, error) { + signerInfos := t.tx.AuthInfo.SignerInfos + sigs := t.tx.Signatures + pubKeys := t.GetPubKeys() + n := len(signerInfos) + res := make([]signing.SignatureV2, n) + + for i, si := range signerInfos { + var err error + sigData, err := ModeInfoToSignatureData(si.ModeInfo, sigs[i]) + if err != nil { + return nil, err + } + res[i] = signing.SignatureV2{ + PubKey: pubKeys[i], + Data: sigData, + } + } + + return res, nil +} + func (t *builder) SetMsgs(msgs ...sdk.Msg) error { anys := make([]*codectypes.Any, len(msgs)) @@ -219,7 +269,7 @@ func (t *builder) SetMemo(memo string) { func (t *builder) SetGasLimit(limit uint64) { if t.tx.AuthInfo.Fee == nil { - t.tx.AuthInfo.Fee = &Fee{} + t.tx.AuthInfo.Fee = &tx.Fee{} } t.tx.AuthInfo.Fee.GasLimit = limit @@ -230,7 +280,7 @@ func (t *builder) SetGasLimit(limit uint64) { func (t *builder) SetFeeAmount(coins sdk.Coins) { if t.tx.AuthInfo.Fee == nil { - t.tx.AuthInfo.Fee = &Fee{} + t.tx.AuthInfo.Fee = &tx.Fee{} } t.tx.AuthInfo.Fee.Amount = coins @@ -241,17 +291,17 @@ func (t *builder) SetFeeAmount(coins sdk.Coins) { func (t *builder) SetSignatures(signatures ...signing.SignatureV2) error { n := len(signatures) - signerInfos := make([]*SignerInfo, n) + signerInfos := make([]*tx.SignerInfo, n) rawSigs := make([][]byte, n) for i, sig := range signatures { - var modeInfo *ModeInfo + var modeInfo *tx.ModeInfo modeInfo, rawSigs[i] = SignatureDataToModeInfoAndSig(sig.Data) pk, err := t.pubkeyCodec.Encode(sig.PubKey) if err != nil { return err } - signerInfos[i] = &SignerInfo{ + signerInfos[i] = &tx.SignerInfo{ PublicKey: pk, ModeInfo: modeInfo, } @@ -263,7 +313,7 @@ func (t *builder) SetSignatures(signatures ...signing.SignatureV2) error { return nil } -func (t *builder) setSignerInfos(infos []*SignerInfo) { +func (t *builder) setSignerInfos(infos []*tx.SignerInfo) { t.tx.AuthInfo.SignerInfos = infos // set authInfoBz to nil because the cached authInfoBz no longer matches tx.AuthInfo t.authInfoBz = nil @@ -275,21 +325,25 @@ func (t *builder) setSignatures(sigs [][]byte) { t.tx.Signatures = sigs } -func SignatureDataToModeInfoAndSig(data signing.SignatureData) (*ModeInfo, []byte) { +func (t builder) GetTx() sdk.Tx { + return t +} + +func SignatureDataToModeInfoAndSig(data signing.SignatureData) (*tx.ModeInfo, []byte) { if data == nil { return nil, nil } switch data := data.(type) { case *signing.SingleSignatureData: - return &ModeInfo{ - Sum: &ModeInfo_Single_{ - Single: &ModeInfo_Single{Mode: data.SignMode}, + return &tx.ModeInfo{ + Sum: &tx.ModeInfo_Single_{ + Single: &tx.ModeInfo_Single{Mode: data.SignMode}, }, }, data.Signature case *signing.MultiSignatureData: n := len(data.Signatures) - modeInfos := make([]*ModeInfo, n) + modeInfos := make([]*tx.ModeInfo, n) sigs := make([][]byte, n) for i, d := range data.Signatures { @@ -304,9 +358,9 @@ func SignatureDataToModeInfoAndSig(data signing.SignatureData) (*ModeInfo, []byt panic(err) } - return &ModeInfo{ - Sum: &ModeInfo_Multi_{ - Multi: &ModeInfo_Multi{ + return &tx.ModeInfo{ + Sum: &tx.ModeInfo_Multi_{ + Multi: &tx.ModeInfo_Multi{ Bitarray: data.BitArray, ModeInfos: modeInfos, }, @@ -317,6 +371,48 @@ func SignatureDataToModeInfoAndSig(data signing.SignatureData) (*ModeInfo, []byt } } -func (t builder) GetTx() sdk.Tx { - return t +func ModeInfoToSignatureData(modeInfo *tx.ModeInfo, sig []byte) (signing.SignatureData, error) { + switch modeInfo := modeInfo.Sum.(type) { + case *tx.ModeInfo_Single_: + return &signing.SingleSignatureData{ + SignMode: modeInfo.Single.Mode, + Signature: sig, + }, nil + + case *tx.ModeInfo_Multi_: + multi := modeInfo.Multi + + sigs, err := DecodeMultisignatures(sig) + if err != nil { + return nil, err + } + + sigv2s := make([]signing.SignatureData, len(sigs)) + for i, mi := range multi.ModeInfos { + sigv2s[i], err = ModeInfoToSignatureData(mi, sigs[i]) + if err != nil { + return nil, err + } + } + + return &signing.MultiSignatureData{ + BitArray: multi.Bitarray, + Signatures: sigv2s, + }, nil + + default: + panic("unexpected case") + } +} + +func DecodeMultisignatures(bz []byte) ([][]byte, error) { + multisig := types.MultiSignature{} + err := multisig.Unmarshal(bz) + if err != nil { + return nil, err + } + if len(multisig.XXX_unrecognized) > 0 { + return nil, fmt.Errorf("rejecting unrecognized fields found in MultiSignature") + } + return multisig.Signatures, nil } diff --git a/types/tx/builder_test.go b/types/tx/generator/builder_test.go similarity index 87% rename from types/tx/builder_test.go rename to types/tx/generator/builder_test.go index a68a63244b26..191c37140668 100644 --- a/types/tx/builder_test.go +++ b/types/tx/generator/builder_test.go @@ -1,8 +1,10 @@ -package tx +package generator import ( "testing" + tx2 "github.com/cosmos/cosmos-sdk/types/tx" + "github.com/cosmos/cosmos-sdk/types/tx/signing" "github.com/stretchr/testify/require" @@ -16,7 +18,7 @@ import ( sdk "github.com/cosmos/cosmos-sdk/types" ) -func TestTxWrapper(t *testing.T) { +func TestTxBuilder(t *testing.T) { _, pubkey, addr := authtypes.KeyTestPubAddr() marshaler := codec.NewHybridCodec(codec.New(), codectypes.NewInterfaceRegistry()) @@ -30,12 +32,12 @@ func TestTxWrapper(t *testing.T) { pk, err := cdc.Encode(pubkey) require.NoError(t, err) - var signerInfo []*SignerInfo - signerInfo = append(signerInfo, &SignerInfo{ + var signerInfo []*tx2.SignerInfo + signerInfo = append(signerInfo, &tx2.SignerInfo{ PublicKey: pk, - ModeInfo: &ModeInfo{ - Sum: &ModeInfo_Single_{ - Single: &ModeInfo_Single{ + ModeInfo: &tx2.ModeInfo{ + Sum: &tx2.ModeInfo_Single_{ + Single: &tx2.ModeInfo_Single{ Mode: signing.SignMode_SIGN_MODE_DIRECT, }, }, @@ -51,10 +53,10 @@ func TestTxWrapper(t *testing.T) { }, } - fee := Fee{Amount: sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), GasLimit: 20000} + fee := tx2.Fee{Amount: sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), GasLimit: 20000} t.Log("verify that authInfo bytes encoded with DefaultTxEncoder and decoded with DefaultTxDecoder can be retrieved from GetAuthInfoBytes") - authInfo := &AuthInfo{ + authInfo := &tx2.AuthInfo{ Fee: &fee, SignerInfos: signerInfo, } @@ -74,7 +76,7 @@ func TestTxWrapper(t *testing.T) { } } - txBody := &TxBody{ + txBody := &tx2.TxBody{ Memo: memo, Messages: anys, } diff --git a/types/tx/generator/decoder.go b/types/tx/generator/decoder.go new file mode 100644 index 000000000000..b8567e8cdd32 --- /dev/null +++ b/types/tx/generator/decoder.go @@ -0,0 +1,79 @@ +package generator + +import ( + "github.com/cosmos/cosmos-sdk/types/tx" + "github.com/tendermint/tendermint/crypto" + + "github.com/cosmos/cosmos-sdk/codec" + cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types" + sdk "github.com/cosmos/cosmos-sdk/types" +) + +func DefaultTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCodec) sdk.TxDecoder { + return func(txBytes []byte) (sdk.Tx, error) { + var raw tx.TxRaw + err := cdc.UnmarshalBinaryBare(txBytes, &raw) + if err != nil { + return nil, err + } + + var theTx tx.Tx + err = cdc.UnmarshalBinaryBare(txBytes, &theTx) + if err != nil { + return nil, err + } + + pks, err := extractPubKeys(theTx, keyCodec) + if err != nil { + return nil, err + } + + return builder{ + tx: &theTx, + bodyBz: raw.BodyBytes, + authInfoBz: raw.AuthInfoBytes, + pubKeys: pks, + marshaler: cdc, + pubkeyCodec: keyCodec, + }, nil + } +} + +func DefaultJSONTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCodec) sdk.TxDecoder { + return func(txBytes []byte) (sdk.Tx, error) { + var theTx tx.Tx + err := cdc.UnmarshalJSON(txBytes, &theTx) + if err != nil { + return nil, err + } + + pks, err := extractPubKeys(theTx, keyCodec) + if err != nil { + return nil, err + } + + return builder{ + tx: &theTx, + pubKeys: pks, + marshaler: cdc, + pubkeyCodec: keyCodec, + }, nil + } +} + +func extractPubKeys(tx tx.Tx, keyCodec cryptotypes.PublicKeyCodec) ([]crypto.PubKey, error) { + if tx.AuthInfo == nil { + return []crypto.PubKey{}, nil + } + + signerInfos := tx.AuthInfo.SignerInfos + pks := make([]crypto.PubKey, len(signerInfos)) + for i, si := range signerInfos { + pk, err := keyCodec.Decode(si.PublicKey) + if err != nil { + return nil, err + } + pks[i] = pk + } + return pks, nil +} diff --git a/types/tx/generator/encoder.go b/types/tx/generator/encoder.go new file mode 100644 index 000000000000..fc13135d0ee6 --- /dev/null +++ b/types/tx/generator/encoder.go @@ -0,0 +1,43 @@ +package generator + +import ( + "fmt" + + "github.com/cosmos/cosmos-sdk/codec" + "github.com/cosmos/cosmos-sdk/types" + tx2 "github.com/cosmos/cosmos-sdk/types/tx" +) + +func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { + return func(tx types.Tx) ([]byte, error) { + wrapper, ok := tx.(builder) + if !ok { + return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) + } + + raw := &tx2.TxRaw{ + BodyBytes: wrapper.bodyBz, + AuthInfoBytes: wrapper.authInfoBz, + Signatures: wrapper.tx.Signatures, + } + + return marshaler.MarshalBinaryBare(raw) + } +} + +func DefaultJSONTxEncoder(marshaler codec.Marshaler) types.TxEncoder { + return func(tx types.Tx) ([]byte, error) { + wrapper, ok := tx.(builder) + if !ok { + return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) + } + + raw := &tx2.TxRaw{ + BodyBytes: wrapper.bodyBz, + AuthInfoBytes: wrapper.authInfoBz, + Signatures: wrapper.tx.Signatures, + } + + return marshaler.MarshalJSON(raw) + } +} diff --git a/types/tx/generator/generator.go b/types/tx/generator/generator.go new file mode 100644 index 000000000000..50da70f8bb11 --- /dev/null +++ b/types/tx/generator/generator.go @@ -0,0 +1,68 @@ +package generator + +import ( + "github.com/cosmos/cosmos-sdk/client" + "github.com/cosmos/cosmos-sdk/codec" + "github.com/cosmos/cosmos-sdk/crypto/types" + sdk "github.com/cosmos/cosmos-sdk/types" + signing2 "github.com/cosmos/cosmos-sdk/types/tx/signing" + "github.com/cosmos/cosmos-sdk/x/auth/signing" + "github.com/cosmos/cosmos-sdk/x/auth/signing/direct" + types2 "github.com/cosmos/cosmos-sdk/x/auth/types" +) + +type generator struct { + marshaler codec.Marshaler + pubkeyCodec types.PublicKeyCodec + handler signing.SignModeHandler + decoder sdk.TxDecoder + encoder sdk.TxEncoder + jsonDecoder sdk.TxDecoder + jsonEncoder sdk.TxEncoder +} + +func New(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) client.TxGenerator { + return &generator{ + marshaler: marshaler, + pubkeyCodec: pubkeyCodec, + handler: DefaultSignModeHandler(), + decoder: DefaultTxDecoder(marshaler, pubkeyCodec), + encoder: DefaultTxEncoder(marshaler), + jsonDecoder: DefaultJSONTxDecoder(marshaler, pubkeyCodec), + jsonEncoder: DefaultJSONTxEncoder(marshaler), + } +} + +func (g generator) NewTxBuilder() client.TxBuilder { + return NewBuilder(g.marshaler, g.pubkeyCodec) +} + +func (g generator) SignModeHandler() signing.SignModeHandler { + return g.handler +} + +func (g generator) TxEncoder() sdk.TxEncoder { + return g.encoder +} + +func (g generator) TxDecoder() sdk.TxDecoder { + return g.decoder +} + +func (g generator) TxJSONEncoder() sdk.TxEncoder { + return g.jsonEncoder +} + +func (g generator) TxJSONDecoder() sdk.TxDecoder { + return g.jsonDecoder +} + +func DefaultSignModeHandler() signing.SignModeHandler { + return signing.NewSignModeHandlerMap( + signing2.SignMode_SIGN_MODE_DIRECT, + []signing.SignModeHandler{ + types2.LegacyAminoJSONHandler{}, + direct.ModeHandler{}, + }, + ) +} diff --git a/types/tx/generator/generator_test.go b/types/tx/generator/generator_test.go new file mode 100644 index 000000000000..d6c9aa0b0949 --- /dev/null +++ b/types/tx/generator/generator_test.go @@ -0,0 +1,17 @@ +package generator + +import ( + "testing" + + "github.com/cosmos/cosmos-sdk/client/testutil" + "github.com/cosmos/cosmos-sdk/codec" + codectypes "github.com/cosmos/cosmos-sdk/codec/types" + "github.com/cosmos/cosmos-sdk/std" + "github.com/stretchr/testify/suite" +) + +func TestGenerator(t *testing.T) { + marshaler := codec.NewHybridCodec(codec.New(), codectypes.NewInterfaceRegistry()) + pubKeyCodec := std.DefaultPublicKeyCodec{} + suite.Run(t, testutil.NewTxGeneratorTestSuite(New(marshaler, pubKeyCodec))) +} diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index eed73f7b58a6..a9adb0682681 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -3,6 +3,8 @@ package direct import ( "testing" + "github.com/cosmos/cosmos-sdk/types/tx/generator" + signingtypes "github.com/cosmos/cosmos-sdk/types/tx/signing" "github.com/stretchr/testify/require" @@ -23,7 +25,7 @@ func TestDirectModeHandler(t *testing.T) { _, pubkey, addr := authtypes.KeyTestPubAddr() cdc := std.DefaultPublicKeyCodec{} - tx := txtypes.NewBuilder(app.AppCodec(), std.DefaultPublicKeyCodec{}) + tx := generator.NewBuilder(app.AppCodec(), std.DefaultPublicKeyCodec{}) memo := "sometestmemo" msgs := []sdk.Msg{authtypes.NewTestMsg(addr)} From 66684902f4de3a97cf3891b6b5c6773899563e93 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Mon, 29 Jun 2020 16:41:27 -0400 Subject: [PATCH 14/43] Fix tests --- client/testutil/suite.go | 111 +++++++---- codec/any_test.go | 18 +- codec/testdata/proto.pb.go | 272 ++++++++++++++++++++++----- codec/testdata/proto.proto | 6 + codec/testdata/test_msg.go | 26 +++ go.mod | 1 - scripts/protocgen.sh | 7 + types/tx/generator/builder.go | 31 ++- types/tx/generator/builder_test.go | 5 +- types/tx/generator/decoder.go | 7 +- types/tx/generator/encoder.go | 16 +- types/tx/generator/generator_test.go | 11 +- types/tx/types.go | 5 - types/tx_msg.go | 34 ---- types/tx_msg_test.go | 4 +- x/auth/client/tx_test.go | 6 +- x/auth/signing/direct/direct.go | 7 +- x/auth/signing/direct/direct_test.go | 66 ++++--- x/auth/types/client_tx_test.go | 4 +- x/auth/types/stdtx_test.go | 10 +- x/auth/types/test_utils.go | 6 +- x/auth/types/txbuilder_test.go | 4 +- x/auth/vesting/types/test_common.go | 6 +- x/bank/handler_test.go | 4 +- x/crisis/handler_test.go | 4 +- x/distribution/client/cli/tx_test.go | 12 +- x/gov/handler_test.go | 4 +- x/slashing/handler_test.go | 4 +- x/staking/handler_test.go | 4 +- 29 files changed, 487 insertions(+), 208 deletions(-) create mode 100644 codec/testdata/test_msg.go diff --git a/client/testutil/suite.go b/client/testutil/suite.go index cb3cc9d867e5..b2d30ed5d7b9 100644 --- a/client/testutil/suite.go +++ b/client/testutil/suite.go @@ -5,6 +5,8 @@ import ( "github.com/tendermint/tendermint/crypto" "github.com/tendermint/tendermint/crypto/secp256k1" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/cosmos/cosmos-sdk/client" signingtypes "github.com/cosmos/cosmos-sdk/types/tx/signing" @@ -25,45 +27,50 @@ func NewTxGeneratorTestSuite(txGenerator client.TxGenerator) *TxGeneratorTestSui } func (s *TxGeneratorTestSuite) TestTxBuilderGetTx() { - stdTxBuilder := s.TxGenerator.NewTxBuilder() - tx := stdTxBuilder.GetTx() + txBuilder := s.TxGenerator.NewTxBuilder() + tx := txBuilder.GetTx() s.Require().NotNil(tx) s.Require().Equal(len(tx.GetMsgs()), 0) } func (s *TxGeneratorTestSuite) TestTxBuilderSetFeeAmount() { - stdTxBuilder := s.TxGenerator.NewTxBuilder() + txBuilder := s.TxGenerator.NewTxBuilder() feeAmount := sdk.Coins{ sdk.NewInt64Coin("atom", 20000000), } - stdTxBuilder.SetFeeAmount(feeAmount) - feeTx := stdTxBuilder.GetTx().(sdk.FeeTx) + txBuilder.SetFeeAmount(feeAmount) + feeTx := txBuilder.GetTx().(sdk.FeeTx) s.Require().Equal(feeAmount, feeTx.GetFee()) } func (s *TxGeneratorTestSuite) TestTxBuilderSetGasLimit() { const newGas uint64 = 300000 - stdTxBuilder := s.TxGenerator.NewTxBuilder() - stdTxBuilder.SetGasLimit(newGas) - feeTx := stdTxBuilder.GetTx().(sdk.FeeTx) + txBuilder := s.TxGenerator.NewTxBuilder() + txBuilder.SetGasLimit(newGas) + feeTx := txBuilder.GetTx().(sdk.FeeTx) s.Require().Equal(newGas, feeTx.GetGas()) } func (s *TxGeneratorTestSuite) TestTxBuilderSetMemo() { const newMemo string = "newfoomemo" - stdTxBuilder := s.TxGenerator.NewTxBuilder() - stdTxBuilder.SetMemo(newMemo) - txWithMemo := stdTxBuilder.GetTx().(sdk.TxWithMemo) + txBuilder := s.TxGenerator.NewTxBuilder() + txBuilder.SetMemo(newMemo) + txWithMemo := txBuilder.GetTx().(sdk.TxWithMemo) s.Require().Equal(txWithMemo.GetMemo(), newMemo) } func (s *TxGeneratorTestSuite) TestTxBuilderSetMsgs() { - stdTxBuilder := s.TxGenerator.NewTxBuilder() - tx := stdTxBuilder.GetTx() - err := stdTxBuilder.SetMsgs(sdk.NewTestMsg(), sdk.NewTestMsg()) + addr1 := sdk.AccAddress(secp256k1.GenPrivKey().PubKey().Address()) + addr2 := sdk.AccAddress(secp256k1.GenPrivKey().PubKey().Address()) + msg1 := testdata.NewTestMsg(addr1) + msg2 := testdata.NewTestMsg(addr2) + msgs := []sdk.Msg{msg1, msg2} + + txBuilder := s.TxGenerator.NewTxBuilder() + + err := txBuilder.SetMsgs(msgs...) s.Require().NoError(err) - s.Require().NotEqual(tx, stdTxBuilder.GetTx()) - s.Require().Equal(len(stdTxBuilder.GetTx().GetMsgs()), 2) + s.Require().Equal(msgs, txBuilder.GetTx().GetMsgs()) } type HasSignaturesTx interface { @@ -74,37 +81,75 @@ type HasSignaturesTx interface { func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { priv := secp256k1.GenPrivKey() + dummySig := []byte("dummySig") - stdTxBuilder := s.TxGenerator.NewTxBuilder() - tx := stdTxBuilder.GetTx() - singleSignatureData := signingtypes.SingleSignatureData{ - Signature: priv.PubKey().Bytes(), - SignMode: signingtypes.SignMode_SIGN_MODE_LEGACY_AMINO_JSON, - } + txBuilder := s.TxGenerator.NewTxBuilder() - err := stdTxBuilder.SetSignatures(signingtypes.SignatureV2{ + sig := signingtypes.SignatureV2{ PubKey: priv.PubKey(), - Data: &singleSignatureData, - }) - sigTx := stdTxBuilder.GetTx().(HasSignaturesTx) + Data: &signingtypes.SingleSignatureData{ + SignMode: signingtypes.SignMode_SIGN_MODE_LEGACY_AMINO_JSON, + Signature: dummySig, + }, + } + err := txBuilder.SetSignatures(sig) s.Require().NoError(err) - s.Require().NotEqual(tx, stdTxBuilder.GetTx()) - s.Require().Equal(sigTx.GetSignatures()[0], priv.PubKey().Bytes()) + + sigTx := txBuilder.GetTx().(HasSignaturesTx) + s.Require().Equal(dummySig, sigTx.GetSignatures()[0]) } func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { + priv := secp256k1.GenPrivKey() + feeAmount := sdk.Coins{sdk.NewInt64Coin("atom", 150)} + gasLimit := uint64(50000) + memo := "foomemo" + msg := testdata.NewTestMsg(sdk.AccAddress(priv.PubKey().Address())) + dummySig := []byte("dummySig") + sig := signingtypes.SignatureV2{ + PubKey: priv.PubKey(), + Data: &signingtypes.SingleSignatureData{ + SignMode: signingtypes.SignMode_SIGN_MODE_LEGACY_AMINO_JSON, + Signature: dummySig, + }, + } + txBuilder := s.TxGenerator.NewTxBuilder() - txBuilder.SetFeeAmount(sdk.Coins{sdk.NewInt64Coin("atom", 150)}) - txBuilder.SetGasLimit(50000) - txBuilder.SetMemo("foomemo") + txBuilder.SetFeeAmount(feeAmount) + txBuilder.SetGasLimit(gasLimit) + txBuilder.SetMemo(memo) + err := txBuilder.SetMsgs(msg) + s.Require().NoError(err) + err = txBuilder.SetSignatures(sig) + s.Require().NoError(err) tx := txBuilder.GetTx() - // Encode transaction + // encode transaction txBytes, err := s.TxGenerator.TxEncoder()(tx) s.Require().NoError(err) s.Require().NotNil(txBytes) + // decode transaction tx2, err := s.TxGenerator.TxDecoder()(txBytes) s.Require().NoError(err) - s.Require().Equal(tx, tx2) + s.Require().Equal(feeAmount, tx2.(sdk.FeeTx).GetFee()) + s.Require().Equal(gasLimit, tx2.(sdk.FeeTx).GetGas()) + s.Require().Equal(memo, tx2.(sdk.TxWithMemo).GetMemo()) + s.Require().Equal(dummySig, tx2.(HasSignaturesTx).GetSignatures()[0]) + s.Require().Equal(priv.PubKey(), tx2.(HasSignaturesTx).GetPubKeys()[0]) + + // JSON encode transaction + jsonTxBytes, err := s.TxGenerator.TxEncoder()(tx) + s.Require().NoError(err) + s.Require().NotNil(jsonTxBytes) + + // JSON decode transaction + tx2, err = s.TxGenerator.TxDecoder()(txBytes) + s.Require().NoError(err) + s.Require().Equal(feeAmount, tx2.(sdk.FeeTx).GetFee()) + s.Require().Equal(gasLimit, tx2.(sdk.FeeTx).GetGas()) + s.Require().Equal(memo, tx2.(sdk.TxWithMemo).GetMemo()) + s.Require().Equal([]sdk.Msg{msg}, tx2.GetMsgs()) + s.Require().Equal(dummySig, tx2.(HasSignaturesTx).GetSignatures()[0]) + s.Require().Equal(priv.PubKey(), tx2.(HasSignaturesTx).GetPubKeys()[0]) } diff --git a/codec/any_test.go b/codec/any_test.go index dbca831008f8..a3914f888584 100644 --- a/codec/any_test.go +++ b/codec/any_test.go @@ -1,8 +1,10 @@ -package codec +package codec_test import ( "testing" + "github.com/cosmos/cosmos-sdk/codec" + "github.com/stretchr/testify/require" "github.com/cosmos/cosmos-sdk/codec/testdata" @@ -23,32 +25,32 @@ func NewTestInterfaceRegistry() types.InterfaceRegistry { func TestMarshalAny(t *testing.T) { registry := types.NewInterfaceRegistry() - cdc := NewProtoCodec(registry) + cdc := codec.NewProtoCodec(registry) kitty := &testdata.Cat{Moniker: "Kitty"} - bz, err := MarshalAny(cdc, kitty) + bz, err := codec.MarshalAny(cdc, kitty) require.NoError(t, err) var animal testdata.Animal // empty registry should fail - err = UnmarshalAny(cdc, &animal, bz) + err = codec.UnmarshalAny(cdc, &animal, bz) require.Error(t, err) // wrong type registration should fail registry.RegisterImplementations((*testdata.Animal)(nil), &testdata.Dog{}) - err = UnmarshalAny(cdc, &animal, bz) + err = codec.UnmarshalAny(cdc, &animal, bz) require.Error(t, err) // should pass registry = NewTestInterfaceRegistry() - cdc = NewProtoCodec(registry) - err = UnmarshalAny(cdc, &animal, bz) + cdc = codec.NewProtoCodec(registry) + err = codec.UnmarshalAny(cdc, &animal, bz) require.NoError(t, err) require.Equal(t, kitty, animal) // nil should fail registry = NewTestInterfaceRegistry() - err = UnmarshalAny(cdc, nil, bz) + err = codec.UnmarshalAny(cdc, nil, bz) require.Error(t, err) } diff --git a/codec/testdata/proto.pb.go b/codec/testdata/proto.pb.go index 458fc7987b62..8bc3fe380120 100644 --- a/codec/testdata/proto.pb.go +++ b/codec/testdata/proto.pb.go @@ -1,5 +1,5 @@ // Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: codec/testdata/proto.proto +// source: proto.proto package testdata @@ -7,6 +7,8 @@ import ( context "context" fmt "fmt" types "github.com/cosmos/cosmos-sdk/codec/types" + github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" + _ "github.com/gogo/protobuf/gogoproto" grpc1 "github.com/gogo/protobuf/grpc" proto "github.com/gogo/protobuf/proto" grpc "google.golang.org/grpc" @@ -37,7 +39,7 @@ func (m *Dog) Reset() { *m = Dog{} } func (m *Dog) String() string { return proto.CompactTextString(m) } func (*Dog) ProtoMessage() {} func (*Dog) Descriptor() ([]byte, []int) { - return fileDescriptor_ae1353846770e6e2, []int{0} + return fileDescriptor_2fcc84b9998d60d8, []int{0} } func (m *Dog) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -89,7 +91,7 @@ func (m *Cat) Reset() { *m = Cat{} } func (m *Cat) String() string { return proto.CompactTextString(m) } func (*Cat) ProtoMessage() {} func (*Cat) Descriptor() ([]byte, []int) { - return fileDescriptor_ae1353846770e6e2, []int{1} + return fileDescriptor_2fcc84b9998d60d8, []int{1} } func (m *Cat) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -141,7 +143,7 @@ func (m *HasAnimal) Reset() { *m = HasAnimal{} } func (m *HasAnimal) String() string { return proto.CompactTextString(m) } func (*HasAnimal) ProtoMessage() {} func (*HasAnimal) Descriptor() ([]byte, []int) { - return fileDescriptor_ae1353846770e6e2, []int{2} + return fileDescriptor_2fcc84b9998d60d8, []int{2} } func (m *HasAnimal) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -192,7 +194,7 @@ func (m *HasHasAnimal) Reset() { *m = HasHasAnimal{} } func (m *HasHasAnimal) String() string { return proto.CompactTextString(m) } func (*HasHasAnimal) ProtoMessage() {} func (*HasHasAnimal) Descriptor() ([]byte, []int) { - return fileDescriptor_ae1353846770e6e2, []int{3} + return fileDescriptor_2fcc84b9998d60d8, []int{3} } func (m *HasHasAnimal) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -236,7 +238,7 @@ func (m *HasHasHasAnimal) Reset() { *m = HasHasHasAnimal{} } func (m *HasHasHasAnimal) String() string { return proto.CompactTextString(m) } func (*HasHasHasAnimal) ProtoMessage() {} func (*HasHasHasAnimal) Descriptor() ([]byte, []int) { - return fileDescriptor_ae1353846770e6e2, []int{4} + return fileDescriptor_2fcc84b9998d60d8, []int{4} } func (m *HasHasHasAnimal) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -280,7 +282,7 @@ func (m *EchoRequest) Reset() { *m = EchoRequest{} } func (m *EchoRequest) String() string { return proto.CompactTextString(m) } func (*EchoRequest) ProtoMessage() {} func (*EchoRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_ae1353846770e6e2, []int{5} + return fileDescriptor_2fcc84b9998d60d8, []int{5} } func (m *EchoRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -324,7 +326,7 @@ func (m *EchoResponse) Reset() { *m = EchoResponse{} } func (m *EchoResponse) String() string { return proto.CompactTextString(m) } func (*EchoResponse) ProtoMessage() {} func (*EchoResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_ae1353846770e6e2, []int{6} + return fileDescriptor_2fcc84b9998d60d8, []int{6} } func (m *EchoResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -368,7 +370,7 @@ func (m *SayHelloRequest) Reset() { *m = SayHelloRequest{} } func (m *SayHelloRequest) String() string { return proto.CompactTextString(m) } func (*SayHelloRequest) ProtoMessage() {} func (*SayHelloRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_ae1353846770e6e2, []int{7} + return fileDescriptor_2fcc84b9998d60d8, []int{7} } func (m *SayHelloRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -412,7 +414,7 @@ func (m *SayHelloResponse) Reset() { *m = SayHelloResponse{} } func (m *SayHelloResponse) String() string { return proto.CompactTextString(m) } func (*SayHelloResponse) ProtoMessage() {} func (*SayHelloResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_ae1353846770e6e2, []int{8} + return fileDescriptor_2fcc84b9998d60d8, []int{8} } func (m *SayHelloResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -448,6 +450,51 @@ func (m *SayHelloResponse) GetGreeting() string { return "" } +// msg type for testing +type TestMsg struct { + Signers []github_com_cosmos_cosmos_sdk_types.AccAddress `protobuf:"bytes,1,rep,name=signers,proto3,casttype=github.com/cosmos/cosmos-sdk/types.AccAddress" json:"signers,omitempty"` +} + +func (m *TestMsg) Reset() { *m = TestMsg{} } +func (m *TestMsg) String() string { return proto.CompactTextString(m) } +func (*TestMsg) ProtoMessage() {} +func (*TestMsg) Descriptor() ([]byte, []int) { + return fileDescriptor_2fcc84b9998d60d8, []int{9} +} +func (m *TestMsg) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TestMsg) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_TestMsg.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *TestMsg) XXX_Merge(src proto.Message) { + xxx_messageInfo_TestMsg.Merge(m, src) +} +func (m *TestMsg) XXX_Size() int { + return m.Size() +} +func (m *TestMsg) XXX_DiscardUnknown() { + xxx_messageInfo_TestMsg.DiscardUnknown(m) +} + +var xxx_messageInfo_TestMsg proto.InternalMessageInfo + +func (m *TestMsg) GetSigners() []github_com_cosmos_cosmos_sdk_types.AccAddress { + if m != nil { + return m.Signers + } + return nil +} + func init() { proto.RegisterType((*Dog)(nil), "cosmos_sdk.codec.v1.Dog") proto.RegisterType((*Cat)(nil), "cosmos_sdk.codec.v1.Cat") @@ -458,39 +505,44 @@ func init() { proto.RegisterType((*EchoResponse)(nil), "cosmos_sdk.codec.v1.EchoResponse") proto.RegisterType((*SayHelloRequest)(nil), "cosmos_sdk.codec.v1.SayHelloRequest") proto.RegisterType((*SayHelloResponse)(nil), "cosmos_sdk.codec.v1.SayHelloResponse") -} - -func init() { proto.RegisterFile("codec/testdata/proto.proto", fileDescriptor_ae1353846770e6e2) } - -var fileDescriptor_ae1353846770e6e2 = []byte{ - // 429 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x93, 0xc1, 0x6e, 0xd3, 0x40, - 0x10, 0x40, 0xb3, 0xa4, 0x2d, 0xcd, 0xc4, 0xa2, 0x68, 0xe9, 0x21, 0xf8, 0x60, 0x15, 0x8b, 0x8a, - 0x4a, 0xd0, 0xb5, 0x68, 0xc5, 0x85, 0x5b, 0x29, 0x15, 0x91, 0x10, 0x17, 0x17, 0x09, 0x89, 0x4b, - 0xb5, 0xb1, 0x07, 0xdb, 0x8a, 0xed, 0x2d, 0x9e, 0x4d, 0xd4, 0xf0, 0x15, 0xfc, 0x0b, 0x3f, 0xc1, - 0xb1, 0x47, 0x8e, 0x28, 0xf9, 0x11, 0xe4, 0x5d, 0x3b, 0x09, 0xa8, 0x2a, 0xbd, 0xd8, 0x33, 0xab, - 0x37, 0xcf, 0xb3, 0x3b, 0x5e, 0x70, 0x23, 0x15, 0x63, 0x14, 0x68, 0x24, 0x1d, 0x4b, 0x2d, 0x83, - 0xcb, 0x4a, 0x69, 0x25, 0xcc, 0x93, 0x3f, 0x8a, 0x14, 0x15, 0x8a, 0x2e, 0x28, 0x1e, 0x0b, 0x83, - 0x89, 0xe9, 0x4b, 0xf7, 0x71, 0xa2, 0x54, 0x92, 0xa3, 0x05, 0x47, 0x93, 0x2f, 0x81, 0x2c, 0x67, - 0x96, 0xf7, 0x0f, 0xa1, 0xfb, 0x56, 0x25, 0x9c, 0xc3, 0x06, 0x65, 0xdf, 0x70, 0xc0, 0xf6, 0xd8, - 0x41, 0x2f, 0x34, 0x71, 0xbd, 0x56, 0xca, 0x02, 0x07, 0xf7, 0xec, 0x5a, 0x1d, 0xfb, 0xaf, 0xa0, - 0x7b, 0x2a, 0x35, 0x1f, 0xc0, 0xfd, 0x42, 0x95, 0xd9, 0x18, 0xab, 0xa6, 0xa2, 0x4d, 0xf9, 0x2e, - 0x6c, 0xe6, 0xd9, 0x14, 0xc9, 0x54, 0x6d, 0x86, 0x36, 0xf1, 0xdf, 0x41, 0x6f, 0x28, 0xe9, 0xa4, - 0xcc, 0x0a, 0x99, 0xf3, 0x17, 0xb0, 0x25, 0x4d, 0x64, 0x6a, 0xfb, 0x47, 0xbb, 0xc2, 0xb6, 0x27, - 0xda, 0xf6, 0xc4, 0x49, 0x39, 0x0b, 0x1b, 0x86, 0x3b, 0xc0, 0xae, 0x8c, 0xac, 0x1b, 0xb2, 0x2b, - 0xff, 0x14, 0x9c, 0xa1, 0xa4, 0x95, 0xeb, 0x18, 0x20, 0x95, 0x74, 0x71, 0x07, 0x5f, 0x2f, 0x6d, - 0x8b, 0xfc, 0x0f, 0xb0, 0x63, 0x25, 0x2b, 0xcf, 0x6b, 0x78, 0x50, 0x7b, 0xee, 0xe8, 0x72, 0xd2, - 0xb5, 0x5a, 0xff, 0x19, 0xf4, 0xcf, 0xa2, 0x54, 0x85, 0xf8, 0x75, 0x82, 0x64, 0xcf, 0x06, 0x89, - 0x64, 0x82, 0xcb, 0xb3, 0xb1, 0xa9, 0x7f, 0x00, 0x8e, 0x05, 0xe9, 0x52, 0x95, 0x84, 0xb7, 0x90, - 0xfb, 0xb0, 0x73, 0x2e, 0x67, 0x43, 0xcc, 0xf3, 0xa5, 0xb6, 0x9d, 0x06, 0x5b, 0x9b, 0x86, 0x80, - 0x87, 0x2b, 0xac, 0x91, 0xba, 0xb0, 0x9d, 0x54, 0x88, 0x3a, 0x2b, 0x93, 0x86, 0x5d, 0xe6, 0x47, - 0x3f, 0x18, 0xf4, 0x3f, 0x22, 0xe9, 0x73, 0xac, 0xa6, 0x59, 0x84, 0xfc, 0x3d, 0x6c, 0xd4, 0x0d, - 0xf1, 0x3d, 0x71, 0xc3, 0x5f, 0x23, 0xd6, 0x36, 0xe5, 0x3e, 0xb9, 0x85, 0x68, 0x3e, 0xfc, 0x09, - 0xb6, 0xdb, 0x66, 0xf8, 0xd3, 0x1b, 0xf1, 0x7f, 0xb6, 0xe4, 0xee, 0xff, 0x87, 0xb2, 0xe2, 0x37, - 0x67, 0x3f, 0xe7, 0x1e, 0xbb, 0x9e, 0x7b, 0xec, 0xf7, 0xdc, 0x63, 0xdf, 0x17, 0x5e, 0xe7, 0x7a, - 0xe1, 0x75, 0x7e, 0x2d, 0xbc, 0xce, 0xe7, 0xe7, 0x49, 0xa6, 0xd3, 0xc9, 0x48, 0x44, 0xaa, 0x08, - 0xac, 0xaa, 0x79, 0x1d, 0x52, 0x3c, 0x0e, 0xfe, 0xbe, 0x25, 0xa3, 0x2d, 0x33, 0xc2, 0xe3, 0x3f, - 0x01, 0x00, 0x00, 0xff, 0xff, 0xff, 0x4f, 0x91, 0x9b, 0x3e, 0x03, 0x00, 0x00, + proto.RegisterType((*TestMsg)(nil), "cosmos_sdk.codec.v1.TestMsg") +} + +func init() { proto.RegisterFile("proto.proto", fileDescriptor_2fcc84b9998d60d8) } + +var fileDescriptor_2fcc84b9998d60d8 = []byte{ + // 481 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0xc1, 0x6e, 0xd3, 0x40, + 0x10, 0x40, 0x63, 0xd2, 0x36, 0xcd, 0x24, 0xa2, 0x68, 0xc9, 0x21, 0xe4, 0x60, 0x82, 0x45, 0x45, + 0x24, 0xc8, 0x5a, 0x6d, 0xc5, 0x85, 0x5b, 0x5a, 0x2a, 0x22, 0x55, 0xbd, 0xb8, 0x08, 0x24, 0x2e, + 0xd5, 0xc6, 0x1e, 0x36, 0x56, 0x62, 0x6f, 0xf0, 0x38, 0x51, 0xc3, 0x57, 0xf0, 0x2f, 0xfc, 0x04, + 0xc7, 0x1e, 0x39, 0x21, 0x94, 0xfc, 0x05, 0x27, 0xe4, 0x5d, 0x3b, 0x89, 0x50, 0x15, 0x7a, 0xb1, + 0x67, 0x56, 0x6f, 0x9e, 0x76, 0x66, 0x07, 0x6a, 0x93, 0x44, 0xa5, 0x8a, 0xeb, 0x2f, 0x7b, 0xec, + 0x2b, 0x8a, 0x14, 0x5d, 0x53, 0x30, 0xe2, 0xbe, 0x0a, 0xd0, 0xe7, 0xb3, 0xa3, 0xd6, 0x13, 0xa9, + 0x94, 0x1c, 0xa3, 0xab, 0x91, 0xc1, 0xf4, 0xb3, 0x2b, 0xe2, 0xb9, 0xe1, 0x5b, 0x0d, 0xa9, 0xa4, + 0xd2, 0xa1, 0x9b, 0x45, 0xe6, 0xd4, 0xe9, 0x42, 0xf9, 0xad, 0x92, 0x8c, 0xc1, 0x0e, 0x85, 0x5f, + 0xb1, 0x69, 0xb5, 0xad, 0x4e, 0xd5, 0xd3, 0x71, 0x76, 0x16, 0x8b, 0x08, 0x9b, 0x0f, 0xcc, 0x59, + 0x16, 0x3b, 0xaf, 0xa1, 0x7c, 0x26, 0x52, 0xd6, 0x84, 0x4a, 0xa4, 0xe2, 0x70, 0x84, 0x49, 0x5e, + 0x51, 0xa4, 0xac, 0x01, 0xbb, 0xe3, 0x70, 0x86, 0xa4, 0xab, 0x76, 0x3d, 0x93, 0x38, 0xef, 0xa0, + 0xda, 0x17, 0xd4, 0x8b, 0xc3, 0x48, 0x8c, 0xd9, 0x2b, 0xd8, 0x13, 0x3a, 0xd2, 0xb5, 0xb5, 0xe3, + 0x06, 0x37, 0x97, 0xe6, 0xc5, 0xa5, 0x79, 0x2f, 0x9e, 0x7b, 0x39, 0xc3, 0xea, 0x60, 0xdd, 0x68, + 0x59, 0xd9, 0xb3, 0x6e, 0x9c, 0x33, 0xa8, 0xf7, 0x05, 0xad, 0x5d, 0x27, 0x00, 0x43, 0x41, 0xd7, + 0xf7, 0xf0, 0x55, 0x87, 0x45, 0x91, 0x73, 0x09, 0x07, 0x46, 0xb2, 0xf6, 0xbc, 0x81, 0x87, 0x99, + 0xe7, 0x9e, 0xae, 0xfa, 0x70, 0xa3, 0xd6, 0x79, 0x01, 0xb5, 0x73, 0x7f, 0xa8, 0x3c, 0xfc, 0x32, + 0x45, 0x32, 0xb3, 0x41, 0x22, 0x21, 0x71, 0x35, 0x1b, 0x93, 0x3a, 0x1d, 0xa8, 0x1b, 0x90, 0x26, + 0x2a, 0x26, 0xdc, 0x42, 0x1e, 0xc2, 0xc1, 0x95, 0x98, 0xf7, 0x71, 0x3c, 0x5e, 0x69, 0x8b, 0xd7, + 0xb0, 0x36, 0x5e, 0x83, 0xc3, 0xa3, 0x35, 0x96, 0x4b, 0x5b, 0xb0, 0x2f, 0x13, 0xc4, 0x34, 0x8c, + 0x65, 0xce, 0xae, 0x72, 0xe7, 0x03, 0x54, 0xde, 0x23, 0xa5, 0x97, 0x24, 0xd9, 0x05, 0x54, 0x28, + 0x94, 0x31, 0x26, 0xd4, 0xb4, 0xda, 0xe5, 0x4e, 0xfd, 0xf4, 0xe8, 0xcf, 0xaf, 0xa7, 0x5d, 0x19, + 0xa6, 0xc3, 0xe9, 0x80, 0xfb, 0x2a, 0x72, 0xcd, 0x76, 0xe5, 0xbf, 0x2e, 0x05, 0x23, 0x37, 0x9d, + 0x4f, 0x90, 0x78, 0xcf, 0xf7, 0x7b, 0x41, 0x90, 0x20, 0x91, 0x57, 0x18, 0x8e, 0xbf, 0x5b, 0x50, + 0xcb, 0xc4, 0x57, 0x98, 0xcc, 0x42, 0x1f, 0xd9, 0x05, 0xec, 0x64, 0x8d, 0xb2, 0x36, 0xbf, 0x63, + 0x47, 0xf9, 0xc6, 0xb0, 0x5a, 0xcf, 0xb6, 0x10, 0x79, 0x43, 0x1f, 0x61, 0xbf, 0x68, 0x92, 0x3d, + 0xbf, 0x13, 0xff, 0x67, 0x54, 0xad, 0xc3, 0xff, 0x50, 0x46, 0x7c, 0x7a, 0xfe, 0x63, 0x61, 0x5b, + 0xb7, 0x0b, 0xdb, 0xfa, 0xbd, 0xb0, 0xad, 0x6f, 0x4b, 0xbb, 0x74, 0xbb, 0xb4, 0x4b, 0x3f, 0x97, + 0x76, 0xe9, 0xd3, 0xcb, 0xad, 0x73, 0xd0, 0x46, 0x37, 0x45, 0x4a, 0x03, 0x91, 0x8a, 0xc1, 0x9e, + 0x5e, 0x8d, 0x93, 0xbf, 0x01, 0x00, 0x00, 0xff, 0xff, 0xe2, 0x42, 0x37, 0xaa, 0x9d, 0x03, 0x00, + 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -606,7 +658,7 @@ var _TestService_serviceDesc = grpc.ServiceDesc{ }, }, Streams: []grpc.StreamDesc{}, - Metadata: "codec/testdata/proto.proto", + Metadata: "proto.proto", } func (m *Dog) Marshal() (dAtA []byte, err error) { @@ -911,6 +963,38 @@ func (m *SayHelloResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } +func (m *TestMsg) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *TestMsg) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TestMsg) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Signers) > 0 { + for iNdEx := len(m.Signers) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Signers[iNdEx]) + copy(dAtA[i:], m.Signers[iNdEx]) + i = encodeVarintProto(dAtA, i, uint64(len(m.Signers[iNdEx]))) + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + func encodeVarintProto(dAtA []byte, offset int, v uint64) int { offset -= sovProto(v) base := offset @@ -1049,6 +1133,21 @@ func (m *SayHelloResponse) Size() (n int) { return n } +func (m *TestMsg) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Signers) > 0 { + for _, b := range m.Signers { + l = len(b) + n += 1 + l + sovProto(uint64(l)) + } + } + return n +} + func sovProto(x uint64) (n int) { return (math_bits.Len64(x|1) + 6) / 7 } @@ -1902,6 +2001,91 @@ func (m *SayHelloResponse) Unmarshal(dAtA []byte) error { } return nil } +func (m *TestMsg) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowProto + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: TestMsg: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: TestMsg: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Signers", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowProto + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthProto + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthProto + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Signers = append(m.Signers, make([]byte, postIndex-iNdEx)) + copy(m.Signers[len(m.Signers)-1], dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipProto(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthProto + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthProto + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func skipProto(dAtA []byte) (n int, err error) { l := len(dAtA) iNdEx := 0 diff --git a/codec/testdata/proto.proto b/codec/testdata/proto.proto index f0b5f60a0ed2..f724c90b1116 100644 --- a/codec/testdata/proto.proto +++ b/codec/testdata/proto.proto @@ -2,6 +2,7 @@ syntax = "proto3"; package cosmos_sdk.codec.v1; import "google/protobuf/any.proto"; +import "gogoproto/gogo.proto"; option go_package = "github.com/cosmos/cosmos-sdk/codec/testdata"; @@ -48,3 +49,8 @@ message SayHelloRequest { message SayHelloResponse { string greeting = 1; } + +// msg type for testing +message TestMsg { + repeated bytes signers = 1 [(gogoproto.casttype) = "github.com/cosmos/cosmos-sdk/types.AccAddress"]; +} diff --git a/codec/testdata/test_msg.go b/codec/testdata/test_msg.go new file mode 100644 index 000000000000..9ae3088e9b14 --- /dev/null +++ b/codec/testdata/test_msg.go @@ -0,0 +1,26 @@ +package testdata + +import ( + "encoding/json" + + sdk "github.com/cosmos/cosmos-sdk/types" +) + +func NewTestMsg(addrs ...sdk.AccAddress) *TestMsg { + return &TestMsg{ + Signers: addrs, + } +} + +var _ sdk.Msg = (*TestMsg)(nil) + +func (msg *TestMsg) Route() string { return "TestMsg" } +func (msg *TestMsg) Type() string { return "Test message" } +func (msg *TestMsg) GetSignBytes() []byte { + bz, err := json.Marshal(msg.Signers) + if err != nil { + panic(err) + } + return sdk.MustSortJSON(bz) +} +func (msg *TestMsg) ValidateBasic() error { return nil } diff --git a/go.mod b/go.mod index ee9584a3d148..11e264f4eb9f 100644 --- a/go.mod +++ b/go.mod @@ -39,7 +39,6 @@ require ( github.com/tendermint/iavl v0.14.0-rc1 github.com/tendermint/tendermint v0.33.5 github.com/tendermint/tm-db v0.5.1 - golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e google.golang.org/grpc v1.30.0 gopkg.in/yaml.v2 v2.3.0 ) diff --git a/scripts/protocgen.sh b/scripts/protocgen.sh index 2a5a76e00e6f..71d0b70a9e44 100755 --- a/scripts/protocgen.sh +++ b/scripts/protocgen.sh @@ -12,5 +12,12 @@ Mgoogle/protobuf/any.proto=github.com/cosmos/cosmos-sdk/codec/types:. \ $(find "${dir}" -maxdepth 1 -name '*.proto') done +# generate codec/testdata proto code +protoc -I "proto" -I "third_party/proto" -I "codec/testdata" --gocosmos_out=plugins=interfacetype+grpc,\ +Mgoogle/protobuf/any.proto=github.com/cosmos/cosmos-sdk/codec/types:. ./codec/testdata/proto.proto + +# move proto files to the right places cp -r github.com/cosmos/cosmos-sdk/* ./ rm -rf github.com + + diff --git a/types/tx/generator/builder.go b/types/tx/generator/builder.go index d627b2584439..5cbab608785f 100644 --- a/types/tx/generator/builder.go +++ b/types/tx/generator/builder.go @@ -3,6 +3,8 @@ package generator import ( "fmt" + "github.com/cosmos/cosmos-sdk/x/auth/signing/direct" + "github.com/cosmos/cosmos-sdk/client/testutil" "github.com/cosmos/cosmos-sdk/types/tx" @@ -30,13 +32,10 @@ type Builder interface { sdk.FeeTx sdk.TxWithMemo testutil.HasSignaturesTx + client.TxBuilder GetSignaturesV2() ([]signing.SignatureV2, error) - tx.ProtoTx - - GetPubKeys() []crypto.PubKey // If signer already has pubkey in context, this list will have nil in its place - - client.TxBuilder + direct.ProtoTx } func NewBuilder(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) Builder { @@ -73,7 +72,7 @@ type builder struct { var _ Builder = &builder{} -func (t builder) GetMsgs() []sdk.Msg { +func (t *builder) GetMsgs() []sdk.Msg { anys := t.tx.Body.Messages res := make([]sdk.Msg, len(anys)) for i, any := range anys { @@ -86,7 +85,7 @@ func (t builder) GetMsgs() []sdk.Msg { // MaxGasWanted defines the max gas allowed. const MaxGasWanted = uint64((1 << 63) - 1) -func (t builder) ValidateBasic() error { +func (t *builder) ValidateBasic() error { theTx := t.tx if theTx == nil { return fmt.Errorf("bad Tx") @@ -161,7 +160,7 @@ func (t *builder) GetAuthInfoBytes() []byte { return t.authInfoBz } -func (t builder) GetSigners() []sdk.AccAddress { +func (t *builder) GetSigners() []sdk.AccAddress { var signers []sdk.AccAddress seen := map[string]bool{} @@ -177,7 +176,7 @@ func (t builder) GetSigners() []sdk.AccAddress { return signers } -func (t builder) GetPubKeys() []crypto.PubKey { +func (t *builder) GetPubKeys() []crypto.PubKey { if t.pubKeys == nil { signerInfos := t.tx.AuthInfo.SignerInfos pubKeys := make([]crypto.PubKey, len(signerInfos)) @@ -199,27 +198,27 @@ func (t builder) GetPubKeys() []crypto.PubKey { return t.pubKeys } -func (t builder) GetGas() uint64 { +func (t *builder) GetGas() uint64 { return t.tx.AuthInfo.Fee.GasLimit } -func (t builder) GetFee() sdk.Coins { +func (t *builder) GetFee() sdk.Coins { return t.tx.AuthInfo.Fee.Amount } -func (t builder) FeePayer() sdk.AccAddress { +func (t *builder) FeePayer() sdk.AccAddress { return t.GetSigners()[0] } -func (t builder) GetMemo() string { +func (t *builder) GetMemo() string { return t.tx.Body.Memo } -func (t builder) GetSignatures() [][]byte { +func (t *builder) GetSignatures() [][]byte { return t.tx.Signatures } -func (t builder) GetSignaturesV2() ([]signing.SignatureV2, error) { +func (t *builder) GetSignaturesV2() ([]signing.SignatureV2, error) { signerInfos := t.tx.AuthInfo.SignerInfos sigs := t.tx.Signatures pubKeys := t.GetPubKeys() @@ -325,7 +324,7 @@ func (t *builder) setSignatures(sigs [][]byte) { t.tx.Signatures = sigs } -func (t builder) GetTx() sdk.Tx { +func (t *builder) GetTx() sdk.Tx { return t } diff --git a/types/tx/generator/builder_test.go b/types/tx/generator/builder_test.go index 191c37140668..d30229e2a89f 100644 --- a/types/tx/generator/builder_test.go +++ b/types/tx/generator/builder_test.go @@ -3,6 +3,8 @@ package generator import ( "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + tx2 "github.com/cosmos/cosmos-sdk/types/tx" "github.com/cosmos/cosmos-sdk/types/tx/signing" @@ -14,7 +16,6 @@ import ( "github.com/cosmos/cosmos-sdk/codec" codectypes "github.com/cosmos/cosmos-sdk/codec/types" "github.com/cosmos/cosmos-sdk/std" - "github.com/cosmos/cosmos-sdk/types" sdk "github.com/cosmos/cosmos-sdk/types" ) @@ -27,7 +28,7 @@ func TestTxBuilder(t *testing.T) { cdc := std.DefaultPublicKeyCodec{} memo := "sometestmemo" - msgs := []sdk.Msg{types.NewTestMsg(addr)} + msgs := []sdk.Msg{testdata.NewTestMsg(addr)} pk, err := cdc.Encode(pubkey) require.NoError(t, err) diff --git a/types/tx/generator/decoder.go b/types/tx/generator/decoder.go index b8567e8cdd32..284512561dd3 100644 --- a/types/tx/generator/decoder.go +++ b/types/tx/generator/decoder.go @@ -1,9 +1,10 @@ package generator import ( - "github.com/cosmos/cosmos-sdk/types/tx" "github.com/tendermint/tendermint/crypto" + "github.com/cosmos/cosmos-sdk/types/tx" + "github.com/cosmos/cosmos-sdk/codec" cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types" sdk "github.com/cosmos/cosmos-sdk/types" @@ -28,7 +29,7 @@ func DefaultTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCodec) return nil, err } - return builder{ + return &builder{ tx: &theTx, bodyBz: raw.BodyBytes, authInfoBz: raw.AuthInfoBytes, @@ -52,7 +53,7 @@ func DefaultJSONTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCod return nil, err } - return builder{ + return &builder{ tx: &theTx, pubKeys: pks, marshaler: cdc, diff --git a/types/tx/generator/encoder.go b/types/tx/generator/encoder.go index fc13135d0ee6..dca80fa9b04b 100644 --- a/types/tx/generator/encoder.go +++ b/types/tx/generator/encoder.go @@ -10,14 +10,14 @@ import ( func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { return func(tx types.Tx) ([]byte, error) { - wrapper, ok := tx.(builder) + wrapper, ok := tx.(*builder) if !ok { return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) } raw := &tx2.TxRaw{ - BodyBytes: wrapper.bodyBz, - AuthInfoBytes: wrapper.authInfoBz, + BodyBytes: wrapper.GetBodyBytes(), + AuthInfoBytes: wrapper.GetAuthInfoBytes(), Signatures: wrapper.tx.Signatures, } @@ -27,17 +27,11 @@ func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { func DefaultJSONTxEncoder(marshaler codec.Marshaler) types.TxEncoder { return func(tx types.Tx) ([]byte, error) { - wrapper, ok := tx.(builder) + wrapper, ok := tx.(*builder) if !ok { return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) } - raw := &tx2.TxRaw{ - BodyBytes: wrapper.bodyBz, - AuthInfoBytes: wrapper.authInfoBz, - Signatures: wrapper.tx.Signatures, - } - - return marshaler.MarshalJSON(raw) + return marshaler.MarshalJSON(wrapper.tx) } } diff --git a/types/tx/generator/generator_test.go b/types/tx/generator/generator_test.go index d6c9aa0b0949..af5500a31b23 100644 --- a/types/tx/generator/generator_test.go +++ b/types/tx/generator/generator_test.go @@ -3,15 +3,22 @@ package generator import ( "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + + sdk "github.com/cosmos/cosmos-sdk/types" + + "github.com/stretchr/testify/suite" + "github.com/cosmos/cosmos-sdk/client/testutil" "github.com/cosmos/cosmos-sdk/codec" codectypes "github.com/cosmos/cosmos-sdk/codec/types" "github.com/cosmos/cosmos-sdk/std" - "github.com/stretchr/testify/suite" ) func TestGenerator(t *testing.T) { - marshaler := codec.NewHybridCodec(codec.New(), codectypes.NewInterfaceRegistry()) + interfaceRegistry := codectypes.NewInterfaceRegistry() + interfaceRegistry.RegisterImplementations((*sdk.Msg)(nil), &testdata.TestMsg{}) + marshaler := codec.NewProtoCodec(interfaceRegistry) pubKeyCodec := std.DefaultPublicKeyCodec{} suite.Run(t, testutil.NewTxGeneratorTestSuite(New(marshaler, pubKeyCodec))) } diff --git a/types/tx/types.go b/types/tx/types.go index 6d779ea300e0..4499cd64ead2 100644 --- a/types/tx/types.go +++ b/types/tx/types.go @@ -5,11 +5,6 @@ import ( sdk "github.com/cosmos/cosmos-sdk/types" ) -type ProtoTx interface { - GetBodyBytes() []byte - GetAuthInfoBytes() []byte -} - func (m *Tx) UnpackInterfaces(unpacker codectypes.AnyUnpacker) error { if m.Body != nil { return m.Body.UnpackInterfaces(unpacker) diff --git a/types/tx_msg.go b/types/tx_msg.go index 3524d9e75fb7..45bf8bf8519f 100644 --- a/types/tx_msg.go +++ b/types/tx_msg.go @@ -1,8 +1,6 @@ package types import ( - "encoding/json" - "github.com/gogo/protobuf/proto" "github.com/tendermint/tendermint/crypto" @@ -80,35 +78,3 @@ type TxDecoder func(txBytes []byte) (Tx, error) type TxEncoder func(tx Tx) ([]byte, error) //__________________________________________________________ - -var _ Msg = (*TestMsg)(nil) - -// msg type for testing -type TestMsg struct { - signers []AccAddress -} - -// dummy implementation of proto.Message -func (msg *TestMsg) Reset() {} -func (msg *TestMsg) String() string { return "TODO" } -func (msg *TestMsg) ProtoMessage() {} - -func NewTestMsg(addrs ...AccAddress) *TestMsg { - return &TestMsg{ - signers: addrs, - } -} - -func (msg *TestMsg) Route() string { return "TestMsg" } -func (msg *TestMsg) Type() string { return "Test message" } -func (msg *TestMsg) GetSignBytes() []byte { - bz, err := json.Marshal(msg.signers) - if err != nil { - panic(err) - } - return MustSortJSON(bz) -} -func (msg *TestMsg) ValidateBasic() error { return nil } -func (msg *TestMsg) GetSigners() []AccAddress { - return msg.signers -} diff --git a/types/tx_msg_test.go b/types/tx_msg_test.go index 5023cbec575a..9f7d0a26deda 100644 --- a/types/tx_msg_test.go +++ b/types/tx_msg_test.go @@ -3,6 +3,8 @@ package types_test import ( "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" sdk "github.com/cosmos/cosmos-sdk/types" @@ -13,7 +15,7 @@ func TestTestMsg(t *testing.T) { addr := []byte{0, 1, 2, 3, 4, 5, 6, 7, 8, 9} accAddr := sdk.AccAddress(addr) - msg := sdk.NewTestMsg(accAddr) + msg := testdata.NewTestMsg(accAddr) require.NotNil(t, msg) require.Equal(t, "TestMsg", msg.Route()) require.Equal(t, "Test message", msg.Type()) diff --git a/x/auth/client/tx_test.go b/x/auth/client/tx_test.go index ed09f31580ba..0bc4f2fbb38a 100644 --- a/x/auth/client/tx_test.go +++ b/x/auth/client/tx_test.go @@ -8,6 +8,8 @@ import ( "strings" "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + simappparams "github.com/cosmos/cosmos-sdk/simapp/params" "github.com/cosmos/cosmos-sdk/client" @@ -195,7 +197,7 @@ malformed } func compareEncoders(t *testing.T, expected sdk.TxEncoder, actual sdk.TxEncoder) { - msgs := []sdk.Msg{sdk.NewTestMsg(addr)} + msgs := []sdk.Msg{testdata.NewTestMsg(addr)} tx := authtypes.NewStdTx(msgs, authtypes.StdFee{}, []authtypes.StdSignature{}, "") defaultEncoderBytes, err := expected(tx) @@ -262,6 +264,6 @@ func makeCodec() *codec.Codec { sdk.RegisterCodec(cdc) cryptocodec.RegisterCrypto(cdc) authtypes.RegisterCodec(cdc) - cdc.RegisterConcrete(sdk.TestMsg{}, "cosmos-sdk/Test", nil) + cdc.RegisterConcrete(testdata.TestMsg{}, "cosmos-sdk/Test", nil) return cdc } diff --git a/x/auth/signing/direct/direct.go b/x/auth/signing/direct/direct.go index bcf993aac869..3c3c1c922c08 100644 --- a/x/auth/signing/direct/direct.go +++ b/x/auth/signing/direct/direct.go @@ -10,6 +10,11 @@ import ( "github.com/cosmos/cosmos-sdk/x/auth/signing" ) +type ProtoTx interface { + GetBodyBytes() []byte + GetAuthInfoBytes() []byte +} + type ModeHandler struct{} func (h ModeHandler) DefaultMode() signingtypes.SignMode { @@ -27,7 +32,7 @@ func (ModeHandler) GetSignBytes(mode signingtypes.SignMode, data signing.SignerD return nil, fmt.Errorf("expected %s, got %s", signingtypes.SignMode_SIGN_MODE_DIRECT, mode) } - protoTx, ok := tx.(types.ProtoTx) + protoTx, ok := tx.(ProtoTx) if !ok { return nil, fmt.Errorf("can only get direct sign bytes for a ProtoTx, got %T", tx) } diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index a9adb0682681..489addbedac4 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -1,8 +1,14 @@ -package direct +package direct_test import ( "testing" + "github.com/cosmos/cosmos-sdk/x/auth/signing/direct" + + "github.com/cosmos/cosmos-sdk/codec/testdata" + + "github.com/cosmos/cosmos-sdk/codec" + "github.com/cosmos/cosmos-sdk/types/tx/generator" signingtypes "github.com/cosmos/cosmos-sdk/types/tx/signing" @@ -10,7 +16,6 @@ import ( "github.com/stretchr/testify/require" codectypes "github.com/cosmos/cosmos-sdk/codec/types" - "github.com/cosmos/cosmos-sdk/simapp" "github.com/cosmos/cosmos-sdk/std" sdk "github.com/cosmos/cosmos-sdk/types" txtypes "github.com/cosmos/cosmos-sdk/types/tx" @@ -19,17 +24,19 @@ import ( ) func TestDirectModeHandler(t *testing.T) { - app := simapp.Setup(false) - //ctx := app.BaseApp.NewContext(false, abci.Header{}) + privKey, pubkey, addr := authtypes.KeyTestPubAddr() + interfaceRegistry := codectypes.NewInterfaceRegistry() + interfaceRegistry.RegisterImplementations((*sdk.Msg)(nil), &testdata.TestMsg{}) + marshaler := codec.NewProtoCodec(interfaceRegistry) + pubKeyCdc := std.DefaultPublicKeyCodec{} - _, pubkey, addr := authtypes.KeyTestPubAddr() - cdc := std.DefaultPublicKeyCodec{} + txGen := generator.New(marshaler, pubKeyCdc) + txBuilder := txGen.NewTxBuilder() - tx := generator.NewBuilder(app.AppCodec(), std.DefaultPublicKeyCodec{}) memo := "sometestmemo" msgs := []sdk.Msg{authtypes.NewTestMsg(addr)} - pk, err := cdc.Encode(pubkey) + pk, err := pubKeyCdc.Encode(pubkey) require.NoError(t, err) var signerInfo []*txtypes.SignerInfo @@ -44,27 +51,27 @@ func TestDirectModeHandler(t *testing.T) { }, }) + sigData := &signingtypes.SingleSignatureData{ + SignMode: signingtypes.SignMode_SIGN_MODE_DIRECT, + } sig := signingtypes.SignatureV2{ PubKey: pubkey, - Data: &signingtypes.SingleSignatureData{ - SignMode: signingtypes.SignMode_SIGN_MODE_DIRECT, - Signature: pubkey.Bytes(), - }, + Data: sigData, } fee := txtypes.Fee{Amount: sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), GasLimit: 20000} - err = tx.SetMsgs(msgs...) + err = txBuilder.SetMsgs(msgs...) require.NoError(t, err) - tx.SetMemo(memo) - tx.SetFeeAmount(fee.Amount) - tx.SetGasLimit(fee.GasLimit) + txBuilder.SetMemo(memo) + txBuilder.SetFeeAmount(fee.Amount) + txBuilder.SetGasLimit(fee.GasLimit) - err = tx.SetSignatures(sig) + err = txBuilder.SetSignatures(sig) require.NoError(t, err) t.Log("verify modes and default-mode") - var directModeHandler ModeHandler + directModeHandler := direct.ModeHandler{} require.Equal(t, directModeHandler.DefaultMode(), signingtypes.SignMode_SIGN_MODE_DIRECT) require.Len(t, directModeHandler.Modes(), 1) @@ -74,7 +81,7 @@ func TestDirectModeHandler(t *testing.T) { AccountSequence: 1, } - signBytes, err := directModeHandler.GetSignBytes(signingtypes.SignMode_SIGN_MODE_DIRECT, signingData, tx) + signBytes, err := directModeHandler.GetSignBytes(signingtypes.SignMode_SIGN_MODE_DIRECT, signingData, txBuilder.GetTx()) require.NoError(t, err) require.NotNil(t, signBytes) @@ -84,7 +91,7 @@ func TestDirectModeHandler(t *testing.T) { SignerInfos: signerInfo, } - authInfoBytes := app.AppCodec().MustMarshalBinaryBare(authInfo) + authInfoBytes := marshaler.MustMarshalBinaryBare(authInfo) anys := make([]*codectypes.Any, len(msgs)) @@ -100,7 +107,7 @@ func TestDirectModeHandler(t *testing.T) { Memo: memo, Messages: anys, } - bodyBytes := app.AppCodec().MustMarshalBinaryBare(txBody) + bodyBytes := marshaler.MustMarshalBinaryBare(txBody) t.Log("verify GetSignBytes with generating sign bytes by marshaling SignDoc") signDoc := txtypes.SignDoc{ @@ -111,13 +118,22 @@ func TestDirectModeHandler(t *testing.T) { ChainId: "test-chain", } - signDocBytes, err := signDoc.Marshal() + expectedSignBytes, err := signDoc.Marshal() + require.NoError(t, err) + require.Equal(t, expectedSignBytes, signBytes) + + t.Log("verify that setting signature doesn't change sign bytes") + sigData.Signature, err = privKey.Sign(signBytes) + require.NoError(t, err) + err = txBuilder.SetSignatures(sig) + require.NoError(t, err) + signBytes, err = directModeHandler.GetSignBytes(signingtypes.SignMode_SIGN_MODE_DIRECT, signingData, txBuilder.GetTx()) require.NoError(t, err) - require.Equal(t, signDocBytes, signBytes) + require.Equal(t, expectedSignBytes, signBytes) t.Log("verify GetSignBytes with false txBody data") signDoc.BodyBytes = []byte("dfafdasfds") - signDocBytes, err = signDoc.Marshal() + expectedSignBytes, err = signDoc.Marshal() require.NoError(t, err) - require.NotEqual(t, signDocBytes, signBytes) + require.NotEqual(t, expectedSignBytes, signBytes) } diff --git a/x/auth/types/client_tx_test.go b/x/auth/types/client_tx_test.go index b1d7c93870e1..600a20af32e5 100644 --- a/x/auth/types/client_tx_test.go +++ b/x/auth/types/client_tx_test.go @@ -3,6 +3,8 @@ package types_test import ( "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/cosmos/cosmos-sdk/client/testutil" "github.com/stretchr/testify/suite" @@ -15,7 +17,7 @@ import ( func testCodec() *codec.Codec { cdc := codec.New() sdk.RegisterCodec(cdc) - cdc.RegisterConcrete(sdk.TestMsg{}, "cosmos-sdk/Test", nil) + cdc.RegisterConcrete(&testdata.TestMsg{}, "cosmos-sdk/Test", nil) return cdc } diff --git a/x/auth/types/stdtx_test.go b/x/auth/types/stdtx_test.go index df43ccda9268..867049d77ab3 100644 --- a/x/auth/types/stdtx_test.go +++ b/x/auth/types/stdtx_test.go @@ -4,6 +4,8 @@ import ( "fmt" "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/cosmos/cosmos-sdk/crypto/types" "github.com/cosmos/cosmos-sdk/crypto/types/multisig" @@ -27,7 +29,7 @@ var ( ) func TestStdTx(t *testing.T) { - msgs := []sdk.Msg{sdk.NewTestMsg(addr)} + msgs := []sdk.Msg{testdata.NewTestMsg(addr)} fee := NewTestStdFee() sigs := []StdSignature{} @@ -54,7 +56,7 @@ func TestStdSignBytes(t *testing.T) { want string }{ { - args{"1234", 3, 6, defaultFee, []sdk.Msg{sdk.NewTestMsg(addr)}, "memo"}, + args{"1234", 3, 6, defaultFee, []sdk.Msg{testdata.NewTestMsg(addr)}, "memo"}, fmt.Sprintf("{\"account_number\":\"3\",\"chain_id\":\"1234\",\"fee\":{\"amount\":[{\"amount\":\"150\",\"denom\":\"atom\"}],\"gas\":\"100000\"},\"memo\":\"memo\",\"msgs\":[[\"%s\"]],\"sequence\":\"6\"}", addr), }, } @@ -127,10 +129,10 @@ func TestDefaultTxEncoder(t *testing.T) { cdc := codec.New() sdk.RegisterCodec(cdc) RegisterCodec(cdc) - cdc.RegisterConcrete(sdk.TestMsg{}, "cosmos-sdk/Test", nil) + cdc.RegisterConcrete(testdata.TestMsg{}, "cosmos-sdk/Test", nil) encoder := DefaultTxEncoder(cdc) - msgs := []sdk.Msg{sdk.NewTestMsg(addr)} + msgs := []sdk.Msg{testdata.NewTestMsg(addr)} fee := NewTestStdFee() sigs := []StdSignature{} diff --git a/x/auth/types/test_utils.go b/x/auth/types/test_utils.go index 4c0d801af377..e221b4d48379 100644 --- a/x/auth/types/test_utils.go +++ b/x/auth/types/test_utils.go @@ -4,11 +4,13 @@ import ( "github.com/tendermint/tendermint/crypto" "github.com/tendermint/tendermint/crypto/secp256k1" + "github.com/cosmos/cosmos-sdk/codec/testdata" + sdk "github.com/cosmos/cosmos-sdk/types" ) -func NewTestMsg(addrs ...sdk.AccAddress) *sdk.TestMsg { - return sdk.NewTestMsg(addrs...) +func NewTestMsg(addrs ...sdk.AccAddress) *testdata.TestMsg { + return testdata.NewTestMsg(addrs...) } func NewTestStdFee() StdFee { diff --git a/x/auth/types/txbuilder_test.go b/x/auth/types/txbuilder_test.go index c0a0e337a9ab..19d4e101b2a9 100644 --- a/x/auth/types/txbuilder_test.go +++ b/x/auth/types/txbuilder_test.go @@ -4,6 +4,8 @@ import ( "reflect" "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" "github.com/cosmos/cosmos-sdk/codec" @@ -23,7 +25,7 @@ func TestTxBuilderBuild(t *testing.T) { Fees sdk.Coins GasPrices sdk.DecCoins } - defaultMsg := []sdk.Msg{sdk.NewTestMsg(addr)} + defaultMsg := []sdk.Msg{testdata.NewTestMsg(addr)} tests := []struct { name string fields fields diff --git a/x/auth/vesting/types/test_common.go b/x/auth/vesting/types/test_common.go index 0287bde80dd0..0ccb5e62f3de 100644 --- a/x/auth/vesting/types/test_common.go +++ b/x/auth/vesting/types/test_common.go @@ -4,12 +4,14 @@ import ( "github.com/tendermint/tendermint/crypto" "github.com/tendermint/tendermint/crypto/secp256k1" + "github.com/cosmos/cosmos-sdk/codec/testdata" + sdk "github.com/cosmos/cosmos-sdk/types" ) // NewTestMsg generates a test message -func NewTestMsg(addrs ...sdk.AccAddress) *sdk.TestMsg { - return sdk.NewTestMsg(addrs...) +func NewTestMsg(addrs ...sdk.AccAddress) *testdata.TestMsg { + return testdata.NewTestMsg(addrs...) } // NewTestCoins coins to more than cover the fee diff --git a/x/bank/handler_test.go b/x/bank/handler_test.go index f9d313385f0a..ab6338d1d49c 100644 --- a/x/bank/handler_test.go +++ b/x/bank/handler_test.go @@ -4,6 +4,8 @@ import ( "strings" "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" abci "github.com/tendermint/tendermint/abci/types" @@ -14,7 +16,7 @@ import ( func TestInvalidMsg(t *testing.T) { h := NewHandler(nil) - res, err := h(sdk.NewContext(nil, abci.Header{}, false, nil), sdk.NewTestMsg()) + res, err := h(sdk.NewContext(nil, abci.Header{}, false, nil), testdata.NewTestMsg()) require.Error(t, err) require.Nil(t, res) diff --git a/x/crisis/handler_test.go b/x/crisis/handler_test.go index 21e92512f89f..b4aa14e701d2 100644 --- a/x/crisis/handler_test.go +++ b/x/crisis/handler_test.go @@ -4,6 +4,8 @@ import ( "fmt" "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" abci "github.com/tendermint/tendermint/abci/types" "github.com/tendermint/tendermint/libs/log" @@ -60,7 +62,7 @@ func TestHandleMsgVerifyInvariant(t *testing.T) { {"bad invariant route", types.NewMsgVerifyInvariant(sender, testModuleName, "route-that-doesnt-exist"), "fail"}, {"invariant broken", types.NewMsgVerifyInvariant(sender, testModuleName, dummyRouteWhichFails.Route), "panic"}, {"invariant passing", types.NewMsgVerifyInvariant(sender, testModuleName, dummyRouteWhichPasses.Route), "pass"}, - {"invalid msg", sdk.NewTestMsg(), "fail"}, + {"invalid msg", testdata.NewTestMsg(), "fail"}, } for _, tc := range cases { diff --git a/x/distribution/client/cli/tx_test.go b/x/distribution/client/cli/tx_test.go index 2b5f27ca563d..7a00e9720afd 100644 --- a/x/distribution/client/cli/tx_test.go +++ b/x/distribution/client/cli/tx_test.go @@ -4,6 +4,8 @@ import ( "io/ioutil" "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" "github.com/stretchr/testify/assert" @@ -28,11 +30,11 @@ func Test_splitAndCall_Splitting(t *testing.T) { // Add five messages msgs := []sdk.Msg{ - sdk.NewTestMsg(addr), - sdk.NewTestMsg(addr), - sdk.NewTestMsg(addr), - sdk.NewTestMsg(addr), - sdk.NewTestMsg(addr), + testdata.NewTestMsg(addr), + testdata.NewTestMsg(addr), + testdata.NewTestMsg(addr), + testdata.NewTestMsg(addr), + testdata.NewTestMsg(addr), } // Keep track of number of calls diff --git a/x/gov/handler_test.go b/x/gov/handler_test.go index c8d0d3a9c756..96728accda79 100644 --- a/x/gov/handler_test.go +++ b/x/gov/handler_test.go @@ -4,6 +4,8 @@ import ( "strings" "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" abci "github.com/tendermint/tendermint/abci/types" @@ -16,7 +18,7 @@ func TestInvalidMsg(t *testing.T) { k := keeper.Keeper{} h := gov.NewHandler(k) - res, err := h(sdk.NewContext(nil, abci.Header{}, false, nil), sdk.NewTestMsg()) + res, err := h(sdk.NewContext(nil, abci.Header{}, false, nil), testdata.NewTestMsg()) require.Error(t, err) require.Nil(t, res) require.True(t, strings.Contains(err.Error(), "unrecognized gov message type")) diff --git a/x/slashing/handler_test.go b/x/slashing/handler_test.go index 23d6ba609369..38a3014afe0f 100644 --- a/x/slashing/handler_test.go +++ b/x/slashing/handler_test.go @@ -6,6 +6,8 @@ import ( "testing" "time" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" abci "github.com/tendermint/tendermint/abci/types" @@ -162,7 +164,7 @@ func TestInvalidMsg(t *testing.T) { k := keeper.Keeper{} h := slashing.NewHandler(k) - res, err := h(sdk.NewContext(nil, abci.Header{}, false, nil), sdk.NewTestMsg()) + res, err := h(sdk.NewContext(nil, abci.Header{}, false, nil), testdata.NewTestMsg()) require.Error(t, err) require.Nil(t, res) require.True(t, strings.Contains(err.Error(), "unrecognized slashing message type")) diff --git a/x/staking/handler_test.go b/x/staking/handler_test.go index 9c8404269848..462ee92be1ac 100644 --- a/x/staking/handler_test.go +++ b/x/staking/handler_test.go @@ -5,6 +5,8 @@ import ( "testing" "time" + "github.com/cosmos/cosmos-sdk/codec/testdata" + gogotypes "github.com/gogo/protobuf/types" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" @@ -1439,7 +1441,7 @@ func TestInvalidMsg(t *testing.T) { k := keeper.Keeper{} h := staking.NewHandler(k) - res, err := h(sdk.NewContext(nil, abci.Header{}, false, nil), sdk.NewTestMsg()) + res, err := h(sdk.NewContext(nil, abci.Header{}, false, nil), testdata.NewTestMsg()) require.Error(t, err) require.Nil(t, res) require.True(t, strings.Contains(err.Error(), "unrecognized staking message type")) From d9c02227d4f10234606a4d182cc8fce29a121c03 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 10:08:58 -0400 Subject: [PATCH 15/43] Update to new SigVerifiableTx --- client/testutil/suite.go | 43 ++++++++++++++--------------- client/tx/tx_test.go | 6 ++-- client/tx_generator.go | 2 +- types/tx/generator/builder.go | 13 ++++----- types/tx/generator/encoder.go | 4 +-- x/auth/ante/basic.go | 3 +- x/auth/ante/sigverify.go | 22 ++++----------- x/auth/signing/sig_verifiable_tx.go | 24 ++++++++++++++++ x/auth/signing/verify_test.go | 4 ++- x/auth/types/client_tx.go | 2 +- 10 files changed, 68 insertions(+), 55 deletions(-) create mode 100644 x/auth/signing/sig_verifiable_tx.go diff --git a/client/testutil/suite.go b/client/testutil/suite.go index b2d30ed5d7b9..33ec9bb860f0 100644 --- a/client/testutil/suite.go +++ b/client/testutil/suite.go @@ -1,8 +1,8 @@ package testutil import ( + "github.com/cosmos/cosmos-sdk/x/auth/signing" "github.com/stretchr/testify/suite" - "github.com/tendermint/tendermint/crypto" "github.com/tendermint/tendermint/crypto/secp256k1" "github.com/cosmos/cosmos-sdk/codec/testdata" @@ -39,7 +39,7 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetFeeAmount() { sdk.NewInt64Coin("atom", 20000000), } txBuilder.SetFeeAmount(feeAmount) - feeTx := txBuilder.GetTx().(sdk.FeeTx) + feeTx := txBuilder.GetTx() s.Require().Equal(feeAmount, feeTx.GetFee()) } @@ -47,7 +47,7 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetGasLimit() { const newGas uint64 = 300000 txBuilder := s.TxGenerator.NewTxBuilder() txBuilder.SetGasLimit(newGas) - feeTx := txBuilder.GetTx().(sdk.FeeTx) + feeTx := txBuilder.GetTx() s.Require().Equal(newGas, feeTx.GetGas()) } @@ -55,7 +55,7 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetMemo() { const newMemo string = "newfoomemo" txBuilder := s.TxGenerator.NewTxBuilder() txBuilder.SetMemo(newMemo) - txWithMemo := txBuilder.GetTx().(sdk.TxWithMemo) + txWithMemo := txBuilder.GetTx() s.Require().Equal(txWithMemo.GetMemo(), newMemo) } @@ -73,12 +73,6 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetMsgs() { s.Require().Equal(msgs, txBuilder.GetTx().GetMsgs()) } -type HasSignaturesTx interface { - GetSigners() []sdk.AccAddress - GetPubKeys() []crypto.PubKey // If signer already has pubkey in context, this list will have nil in its place - GetSignatures() [][]byte -} - func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { priv := secp256k1.GenPrivKey() dummySig := []byte("dummySig") @@ -95,7 +89,7 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { err := txBuilder.SetSignatures(sig) s.Require().NoError(err) - sigTx := txBuilder.GetTx().(HasSignaturesTx) + sigTx := txBuilder.GetTx().(signing.SigVerifiableTx) s.Require().Equal(dummySig, sigTx.GetSignatures()[0]) } @@ -132,11 +126,14 @@ func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { // decode transaction tx2, err := s.TxGenerator.TxDecoder()(txBytes) s.Require().NoError(err) - s.Require().Equal(feeAmount, tx2.(sdk.FeeTx).GetFee()) - s.Require().Equal(gasLimit, tx2.(sdk.FeeTx).GetGas()) - s.Require().Equal(memo, tx2.(sdk.TxWithMemo).GetMemo()) - s.Require().Equal(dummySig, tx2.(HasSignaturesTx).GetSignatures()[0]) - s.Require().Equal(priv.PubKey(), tx2.(HasSignaturesTx).GetPubKeys()[0]) + tx3, ok := tx2.(signing.Tx) + s.Require().True(ok) + s.Require().Equal([]sdk.Msg{msg}, tx3.GetMsgs()) + s.Require().Equal(feeAmount, tx3.GetFee()) + s.Require().Equal(gasLimit, tx3.GetGas()) + s.Require().Equal(memo, tx3.GetMemo()) + s.Require().Equal(dummySig, tx3.GetSignatures()[0]) + s.Require().Equal(priv.PubKey(), tx3.GetPubKeys()[0]) // JSON encode transaction jsonTxBytes, err := s.TxGenerator.TxEncoder()(tx) @@ -146,10 +143,12 @@ func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { // JSON decode transaction tx2, err = s.TxGenerator.TxDecoder()(txBytes) s.Require().NoError(err) - s.Require().Equal(feeAmount, tx2.(sdk.FeeTx).GetFee()) - s.Require().Equal(gasLimit, tx2.(sdk.FeeTx).GetGas()) - s.Require().Equal(memo, tx2.(sdk.TxWithMemo).GetMemo()) - s.Require().Equal([]sdk.Msg{msg}, tx2.GetMsgs()) - s.Require().Equal(dummySig, tx2.(HasSignaturesTx).GetSignatures()[0]) - s.Require().Equal(priv.PubKey(), tx2.(HasSignaturesTx).GetPubKeys()[0]) + tx3, ok = tx2.(signing.Tx) + s.Require().True(ok) + s.Require().Equal([]sdk.Msg{msg}, tx3.GetMsgs()) + s.Require().Equal(feeAmount, tx3.GetFee()) + s.Require().Equal(gasLimit, tx3.GetGas()) + s.Require().Equal(memo, tx3.GetMemo()) + s.Require().Equal(dummySig, tx3.GetSignatures()[0]) + s.Require().Equal(priv.PubKey(), tx3.GetPubKeys()[0]) } diff --git a/client/tx/tx_test.go b/client/tx/tx_test.go index daa0dea739a6..dd95e2df42a4 100644 --- a/client/tx/tx_test.go +++ b/client/tx/tx_test.go @@ -4,12 +4,12 @@ import ( "errors" "testing" + "github.com/cosmos/cosmos-sdk/x/auth/signing" + "github.com/cosmos/cosmos-sdk/crypto/hd" "github.com/cosmos/cosmos-sdk/crypto/keyring" "github.com/cosmos/cosmos-sdk/tests" - "github.com/cosmos/cosmos-sdk/x/auth/ante" - "github.com/stretchr/testify/require" "github.com/cosmos/cosmos-sdk/client" @@ -111,7 +111,7 @@ func TestBuildUnsignedTx(t *testing.T) { tx, err := tx.BuildUnsignedTx(txf, msg) require.NoError(t, err) require.NotNil(t, tx) - require.Empty(t, tx.GetTx().(ante.SigVerifiableTx).GetSignatures()) + require.Empty(t, tx.GetTx().(signing.SigVerifiableTx).GetSignatures()) } func TestSign(t *testing.T) { diff --git a/client/tx_generator.go b/client/tx_generator.go index 70b2d3368ce4..89348c824ad6 100644 --- a/client/tx_generator.go +++ b/client/tx_generator.go @@ -25,7 +25,7 @@ type ( // signatures, and provide canonical bytes to sign over. The transaction must // also know how to encode itself. TxBuilder interface { - GetTx() sdk.Tx + GetTx() signing.Tx SetMsgs(msgs ...sdk.Msg) error SetSignatures(signatures ...signingtypes.SignatureV2) error diff --git a/types/tx/generator/builder.go b/types/tx/generator/builder.go index 5cbab608785f..53e6354c43c0 100644 --- a/types/tx/generator/builder.go +++ b/types/tx/generator/builder.go @@ -3,9 +3,9 @@ package generator import ( "fmt" - "github.com/cosmos/cosmos-sdk/x/auth/signing/direct" + authsigning "github.com/cosmos/cosmos-sdk/x/auth/signing" - "github.com/cosmos/cosmos-sdk/client/testutil" + "github.com/cosmos/cosmos-sdk/x/auth/signing/direct" "github.com/cosmos/cosmos-sdk/types/tx" @@ -28,12 +28,9 @@ import ( // SIGN_MODE_DIRECT signing uses raw body and auth_info bytes and b) Tx does does not retain // crypto.PubKey instances. type Builder interface { - sdk.Tx - sdk.FeeTx - sdk.TxWithMemo - testutil.HasSignaturesTx + authsigning.Tx + client.TxBuilder - GetSignaturesV2() ([]signing.SignatureV2, error) direct.ProtoTx } @@ -324,7 +321,7 @@ func (t *builder) setSignatures(sigs [][]byte) { t.tx.Signatures = sigs } -func (t *builder) GetTx() sdk.Tx { +func (t *builder) GetTx() authsigning.Tx { return t } diff --git a/types/tx/generator/encoder.go b/types/tx/generator/encoder.go index dca80fa9b04b..296023b85028 100644 --- a/types/tx/generator/encoder.go +++ b/types/tx/generator/encoder.go @@ -5,7 +5,7 @@ import ( "github.com/cosmos/cosmos-sdk/codec" "github.com/cosmos/cosmos-sdk/types" - tx2 "github.com/cosmos/cosmos-sdk/types/tx" + txtypes "github.com/cosmos/cosmos-sdk/types/tx" ) func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { @@ -15,7 +15,7 @@ func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) } - raw := &tx2.TxRaw{ + raw := &txtypes.TxRaw{ BodyBytes: wrapper.GetBodyBytes(), AuthInfoBytes: wrapper.GetAuthInfoBytes(), Signatures: wrapper.tx.Signatures, diff --git a/x/auth/ante/basic.go b/x/auth/ante/basic.go index f7120e627f24..9fca3521d2ab 100644 --- a/x/auth/ante/basic.go +++ b/x/auth/ante/basic.go @@ -1,6 +1,7 @@ package ante import ( + "github.com/cosmos/cosmos-sdk/x/auth/signing" "github.com/tendermint/tendermint/crypto" "github.com/cosmos/cosmos-sdk/codec/legacy" @@ -89,7 +90,7 @@ func NewConsumeGasForTxSizeDecorator(ak AccountKeeper) ConsumeTxSizeGasDecorator } func (cgts ConsumeTxSizeGasDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (sdk.Context, error) { - sigTx, ok := tx.(SigVerifiableTx) + sigTx, ok := tx.(signing.SigVerifiableTx) if !ok { return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid tx type") } diff --git a/x/auth/ante/sigverify.go b/x/auth/ante/sigverify.go index b7d7d46dea31..52a6a3de6055 100644 --- a/x/auth/ante/sigverify.go +++ b/x/auth/ante/sigverify.go @@ -9,7 +9,6 @@ import ( "github.com/cosmos/cosmos-sdk/types/tx/signing" - "github.com/tendermint/tendermint/crypto" "github.com/tendermint/tendermint/crypto/ed25519" "github.com/tendermint/tendermint/crypto/secp256k1" @@ -24,7 +23,7 @@ var ( simSecp256k1Pubkey secp256k1.PubKeySecp256k1 simSecp256k1Sig [64]byte - _ SigVerifiableTx = (*types.StdTx)(nil) // assert StdTx implements SigVerifiableTx + _ authsigning.SigVerifiableTx = (*types.StdTx)(nil) // assert StdTx implements SigVerifiableTx ) func init() { @@ -38,15 +37,6 @@ func init() { // This is where apps can define their own PubKey type SignatureVerificationGasConsumer = func(meter sdk.GasMeter, sig signing.SignatureV2, params types.Params) error -// SigVerifiableTx defines a Tx interface for all signature verification decorators -type SigVerifiableTx interface { - sdk.Tx - GetSigners() []sdk.AccAddress - GetPubKeys() []crypto.PubKey // If signer already has pubkey in context, this list will have nil in its place - GetSignatures() [][]byte - GetSignaturesV2() ([]signing.SignatureV2, error) -} - // SetPubKeyDecorator sets PubKeys in context for any signer which does not already have pubkey set // PubKeys must be set in context for all signers before any other sigverify decorators run // CONTRACT: Tx must implement SigVerifiableTx interface @@ -61,7 +51,7 @@ func NewSetPubKeyDecorator(ak AccountKeeper) SetPubKeyDecorator { } func (spkd SetPubKeyDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (sdk.Context, error) { - sigTx, ok := tx.(SigVerifiableTx) + sigTx, ok := tx.(authsigning.SigVerifiableTx) if !ok { return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid tx type") } @@ -118,7 +108,7 @@ func NewSigGasConsumeDecorator(ak AccountKeeper, sigGasConsumer SignatureVerific } func (sgcd SigGasConsumeDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (newCtx sdk.Context, err error) { - sigTx, ok := tx.(SigVerifiableTx) + sigTx, ok := tx.(authsigning.SigVerifiableTx) if !ok { return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid transaction type") } @@ -186,7 +176,7 @@ func (svd SigVerificationDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simul if ctx.IsReCheckTx() { return next(ctx, tx, simulate) } - sigTx, ok := tx.(SigVerifiableTx) + sigTx, ok := tx.(authsigning.SigVerifiableTx) if !ok { return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid transaction type") } @@ -268,7 +258,7 @@ func NewIncrementSequenceDecorator(ak AccountKeeper) IncrementSequenceDecorator } func (isd IncrementSequenceDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (sdk.Context, error) { - sigTx, ok := tx.(SigVerifiableTx) + sigTx, ok := tx.(authsigning.SigVerifiableTx) if !ok { return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "invalid transaction type") } @@ -301,7 +291,7 @@ func NewValidateSigCountDecorator(ak AccountKeeper) ValidateSigCountDecorator { } func (vscd ValidateSigCountDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (sdk.Context, error) { - sigTx, ok := tx.(SigVerifiableTx) + sigTx, ok := tx.(authsigning.SigVerifiableTx) if !ok { return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "Tx must be a sigTx") } diff --git a/x/auth/signing/sig_verifiable_tx.go b/x/auth/signing/sig_verifiable_tx.go new file mode 100644 index 000000000000..ada863e5614b --- /dev/null +++ b/x/auth/signing/sig_verifiable_tx.go @@ -0,0 +1,24 @@ +package signing + +import ( + "github.com/cosmos/cosmos-sdk/types" + "github.com/cosmos/cosmos-sdk/types/tx/signing" + "github.com/tendermint/tendermint/crypto" +) + +// SigVerifiableTx defines a Tx interface for all signature verification decorators +type SigVerifiableTx interface { + types.Tx + GetSigners() []types.AccAddress + GetPubKeys() []crypto.PubKey // If signer already has pubkey in context, this list will have nil in its place + GetSignatures() [][]byte + GetSignaturesV2() ([]signing.SignatureV2, error) +} + +// Tx defines an interface for transactions that support all standard message, signature, +// fee and memo interfaces. +type Tx interface { + SigVerifiableTx + types.TxWithMemo + types.FeeTx +} diff --git a/x/auth/signing/verify_test.go b/x/auth/signing/verify_test.go index e93aae75f632..9b415a69e3f9 100644 --- a/x/auth/signing/verify_test.go +++ b/x/auth/signing/verify_test.go @@ -3,6 +3,8 @@ package signing_test import ( "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" abci "github.com/tendermint/tendermint/abci/types" "github.com/tendermint/tendermint/crypto" @@ -31,7 +33,7 @@ func TestVerifySignature(t *testing.T) { cdc := codec.New() sdk.RegisterCodec(cdc) types.RegisterCodec(cdc) - cdc.RegisterConcrete(sdk.TestMsg{}, "cosmos-sdk/Test", nil) + cdc.RegisterConcrete(testdata.TestMsg{}, "cosmos-sdk/Test", nil) acc1 := app.AccountKeeper.NewAccountWithAddress(ctx, addr) _ = app.AccountKeeper.NewAccountWithAddress(ctx, addr1) diff --git a/x/auth/types/client_tx.go b/x/auth/types/client_tx.go index dc42613d4db8..b60168944fcb 100644 --- a/x/auth/types/client_tx.go +++ b/x/auth/types/client_tx.go @@ -20,7 +20,7 @@ type StdTxBuilder struct { var _ client.TxBuilder = &StdTxBuilder{} // GetTx implements TxBuilder.GetTx -func (s *StdTxBuilder) GetTx() sdk.Tx { +func (s *StdTxBuilder) GetTx() authsigning.Tx { return s.StdTx } From b3b133b0354315f15e99325258c74594f2a6ca04 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 10:26:48 -0400 Subject: [PATCH 16/43] Rename --- client/testutil/suite.go | 4 ++-- client/tx_generator.go | 2 +- types/tx/generator/builder.go | 4 ++-- x/auth/signing/sig_verifiable_tx.go | 4 ++-- x/auth/types/client_tx.go | 2 +- 5 files changed, 8 insertions(+), 8 deletions(-) diff --git a/client/testutil/suite.go b/client/testutil/suite.go index 33ec9bb860f0..7e8684ca83ac 100644 --- a/client/testutil/suite.go +++ b/client/testutil/suite.go @@ -126,7 +126,7 @@ func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { // decode transaction tx2, err := s.TxGenerator.TxDecoder()(txBytes) s.Require().NoError(err) - tx3, ok := tx2.(signing.Tx) + tx3, ok := tx2.(signing.SigFeeMemoTx) s.Require().True(ok) s.Require().Equal([]sdk.Msg{msg}, tx3.GetMsgs()) s.Require().Equal(feeAmount, tx3.GetFee()) @@ -143,7 +143,7 @@ func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { // JSON decode transaction tx2, err = s.TxGenerator.TxDecoder()(txBytes) s.Require().NoError(err) - tx3, ok = tx2.(signing.Tx) + tx3, ok = tx2.(signing.SigFeeMemoTx) s.Require().True(ok) s.Require().Equal([]sdk.Msg{msg}, tx3.GetMsgs()) s.Require().Equal(feeAmount, tx3.GetFee()) diff --git a/client/tx_generator.go b/client/tx_generator.go index 89348c824ad6..6718a603defa 100644 --- a/client/tx_generator.go +++ b/client/tx_generator.go @@ -25,7 +25,7 @@ type ( // signatures, and provide canonical bytes to sign over. The transaction must // also know how to encode itself. TxBuilder interface { - GetTx() signing.Tx + GetTx() signing.SigFeeMemoTx SetMsgs(msgs ...sdk.Msg) error SetSignatures(signatures ...signingtypes.SignatureV2) error diff --git a/types/tx/generator/builder.go b/types/tx/generator/builder.go index 53e6354c43c0..f7f18871a85a 100644 --- a/types/tx/generator/builder.go +++ b/types/tx/generator/builder.go @@ -28,7 +28,7 @@ import ( // SIGN_MODE_DIRECT signing uses raw body and auth_info bytes and b) Tx does does not retain // crypto.PubKey instances. type Builder interface { - authsigning.Tx + authsigning.SigFeeMemoTx client.TxBuilder @@ -321,7 +321,7 @@ func (t *builder) setSignatures(sigs [][]byte) { t.tx.Signatures = sigs } -func (t *builder) GetTx() authsigning.Tx { +func (t *builder) GetTx() authsigning.SigFeeMemoTx { return t } diff --git a/x/auth/signing/sig_verifiable_tx.go b/x/auth/signing/sig_verifiable_tx.go index ada863e5614b..599a544ea32c 100644 --- a/x/auth/signing/sig_verifiable_tx.go +++ b/x/auth/signing/sig_verifiable_tx.go @@ -15,9 +15,9 @@ type SigVerifiableTx interface { GetSignaturesV2() ([]signing.SignatureV2, error) } -// Tx defines an interface for transactions that support all standard message, signature, +// SigFeeMemoTx defines an interface for transactions that support all standard message, signature, // fee and memo interfaces. -type Tx interface { +type SigFeeMemoTx interface { SigVerifiableTx types.TxWithMemo types.FeeTx diff --git a/x/auth/types/client_tx.go b/x/auth/types/client_tx.go index b60168944fcb..3175cc89cf53 100644 --- a/x/auth/types/client_tx.go +++ b/x/auth/types/client_tx.go @@ -20,7 +20,7 @@ type StdTxBuilder struct { var _ client.TxBuilder = &StdTxBuilder{} // GetTx implements TxBuilder.GetTx -func (s *StdTxBuilder) GetTx() authsigning.Tx { +func (s *StdTxBuilder) GetTx() authsigning.SigFeeMemoTx { return s.StdTx } From f84e510df60e8fd58c815132ff82449f058c0105 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 10:37:35 -0400 Subject: [PATCH 17/43] Update docs to reflect ADR 020 --- proto/cosmos/tx/tx.proto | 32 ++++++++++++++++++++++++-------- 1 file changed, 24 insertions(+), 8 deletions(-) diff --git a/proto/cosmos/tx/tx.proto b/proto/cosmos/tx/tx.proto index a62bc7342764..a2a58352c2b7 100644 --- a/proto/cosmos/tx/tx.proto +++ b/proto/cosmos/tx/tx.proto @@ -18,16 +18,24 @@ message Tx { // signers, signer modes and fee AuthInfo auth_info = 2; - // signatures are the raw binary signatures of signers specified by body and auth_info + // signatures is a list of signatures that matches the length and order of AuthInfo's signer_infos to + // allow connecting signature meta information like public key and signing mode by position. repeated bytes signatures = 3; } +// TxRaw is a variant of Tx that pins the signer's exact binary representation of body and +// auth_info. This is used for signing, broadcasting and verification. The binary +// `serialize(tx: TxRaw)` is stored in Tendermint and the hash `sha256(serialize(tx: TxRaw))` +// becomes the "txhash", commonly used as the transaction ID. message TxRaw { + // body_bytes is a protobuf serialization of a TxBody that matches the representation in SignDoc. bytes body_bytes = 1; + // auth_info_bytes is a protobuf serialization of an AuthInfo that matches the representation in SignDoc. bytes auth_info_bytes = 2; - // signatures are the raw binary signatures of signers specified by body and auth_info + // signatures is a list of signatures that matches the length and order of AuthInfo's signer_infos to + // allow connecting signature meta information like public key and signing mode by position. repeated bytes signatures = 3; } @@ -51,7 +59,12 @@ message SignDoc { // TxBody is the body of a transaction that all signers sign over message TxBody { - // messages are the processable content of the transaction + // messages is a list of messages to be executed. The required signers of those messages define + // the number and order of elements in AuthInfo's signer_infos and Tx's signatures. + // Each required signer address is added to the list only the first time it occurs. + // + // By convention, the first required signer (usually from the first message) is referred + // to as the primary signer and pays the fee for the whole transaction. repeated google.protobuf.Any messages = 1; // memo is any arbitrary memo to be added to the transaction @@ -74,20 +87,23 @@ message TxBody { // AuthInfo describes the fee and signer modes that are used to sign a transaction message AuthInfo { - // signer_infos is the list of signer infos which corresponds with - // Tx.signatures and expected signers derived from TxBody.messages. All signers - // are expected to occur in the same order in each of these locations + // signer_infos defines the signing modes for the required signers. The number + // and order of elements must match the required signers from TxBody's messages. + // The first element is the primary signer and the one which pays the fee. repeated SignerInfo signer_infos = 1; // Fee is the fee and gas limit for the transaction. The first signer is the - // primary signer and the one which pays the fee + // primary signer and the one which pays the fee. The fee can be calculated + // based on the cost of evaluating the body and doing signature verification + // of the signers. This can be estimated via simulation. Fee fee = 2; } // SignerInfo describes the public key and signing mode of a single top-level signer message SignerInfo { // public_key is the public key of the signer. It is optional for accounts - // that already exist in state + // that already exist in state. If unset, the verifier can use the required \ + // signer address for this position and lookup the public key. cosmos.crypto.PublicKey public_key = 1; // mode_info describes the signing mode of the signer and is a nested From dc1c88d3352e24f76bfbfe2adb38c12fd8e1c4ec Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 10:38:07 -0400 Subject: [PATCH 18/43] proto-gen --- types/tx/tx.pb.go | 34 +++++++++++++++++++++++++--------- 1 file changed, 25 insertions(+), 9 deletions(-) diff --git a/types/tx/tx.pb.go b/types/tx/tx.pb.go index 6d663cdbd117..25341ce0e1c5 100644 --- a/types/tx/tx.pb.go +++ b/types/tx/tx.pb.go @@ -35,7 +35,8 @@ type Tx struct { // auth_info is the authorization related content of the transaction, specifically // signers, signer modes and fee AuthInfo *AuthInfo `protobuf:"bytes,2,opt,name=auth_info,json=authInfo,proto3" json:"auth_info,omitempty"` - // signatures are the raw binary signatures of signers specified by body and auth_info + // signatures is a list of signatures that matches the length and order of AuthInfo's signer_infos to + // allow connecting signature meta information like public key and signing mode by position. Signatures [][]byte `protobuf:"bytes,3,rep,name=signatures,proto3" json:"signatures,omitempty"` } @@ -93,10 +94,17 @@ func (m *Tx) GetSignatures() [][]byte { return nil } +// TxRaw is a variant of Tx that pins the signer's exact binary representation of body and +// auth_info. This is used for signing, broadcasting and verification. The binary +// `serialize(tx: TxRaw)` is stored in Tendermint and the hash `sha256(serialize(tx: TxRaw))` +// becomes the "txhash", commonly used as the transaction ID. type TxRaw struct { - BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` + // body_bytes is a protobuf serialization of a TxBody that matches the representation in SignDoc. + BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` + // auth_info_bytes is a protobuf serialization of an AuthInfo that matches the representation in SignDoc. AuthInfoBytes []byte `protobuf:"bytes,2,opt,name=auth_info_bytes,json=authInfoBytes,proto3" json:"auth_info_bytes,omitempty"` - // signatures are the raw binary signatures of signers specified by body and auth_info + // signatures is a list of signatures that matches the length and order of AuthInfo's signer_infos to + // allow connecting signature meta information like public key and signing mode by position. Signatures [][]byte `protobuf:"bytes,3,rep,name=signatures,proto3" json:"signatures,omitempty"` } @@ -238,7 +246,12 @@ func (m *SignDoc) GetAccountSequence() uint64 { // TxBody is the body of a transaction that all signers sign over type TxBody struct { - // messages are the processable content of the transaction + // messages is a list of messages to be executed. The required signers of those messages define + // the number and order of elements in AuthInfo's signer_infos and Tx's signatures. + // Each required signer address is added to the list only the first time it occurs. + // + // By convention, the first required signer (usually from the first message) is referred + // to as the primary signer and pays the fee for the whole transaction. Messages []*types.Any `protobuf:"bytes,1,rep,name=messages,proto3" json:"messages,omitempty"` // memo is any arbitrary memo to be added to the transaction Memo string `protobuf:"bytes,2,opt,name=memo,proto3" json:"memo,omitempty"` @@ -325,12 +338,14 @@ func (m *TxBody) GetNonCriticalExtensionOptions() []*types.Any { // AuthInfo describes the fee and signer modes that are used to sign a transaction type AuthInfo struct { - // signer_infos is the list of signer infos which corresponds with - // Tx.signatures and expected signers derived from TxBody.messages. All signers - // are expected to occur in the same order in each of these locations + // signer_infos defines the signing modes for the required signers. The number + // and order of elements must match the required signers from TxBody's messages. + // The first element is the primary signer and the one which pays the fee. SignerInfos []*SignerInfo `protobuf:"bytes,1,rep,name=signer_infos,json=signerInfos,proto3" json:"signer_infos,omitempty"` // Fee is the fee and gas limit for the transaction. The first signer is the - // primary signer and the one which pays the fee + // primary signer and the one which pays the fee. The fee can be calculated + // based on the cost of evaluating the body and doing signature verification + // of the signers. This can be estimated via simulation. Fee *Fee `protobuf:"bytes,2,opt,name=fee,proto3" json:"fee,omitempty"` } @@ -384,7 +399,8 @@ func (m *AuthInfo) GetFee() *Fee { // SignerInfo describes the public key and signing mode of a single top-level signer type SignerInfo struct { // public_key is the public key of the signer. It is optional for accounts - // that already exist in state + // that already exist in state. If unset, the verifier can use the required \ + // signer address for this position and lookup the public key. PublicKey *types1.PublicKey `protobuf:"bytes,1,opt,name=public_key,json=publicKey,proto3" json:"public_key,omitempty"` // mode_info describes the signing mode of the signer and is a nested // structure to support nested multisig pubkey's From ab6071541706fd768c216c391d3e706b1aff5f42 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 10:41:37 -0400 Subject: [PATCH 19/43] proto docs --- proto/cosmos/tx/tx.proto | 2 ++ types/tx/tx.pb.go | 4 +++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/proto/cosmos/tx/tx.proto b/proto/cosmos/tx/tx.proto index a2a58352c2b7..6b537ea828de 100644 --- a/proto/cosmos/tx/tx.proto +++ b/proto/cosmos/tx/tx.proto @@ -40,8 +40,10 @@ message TxRaw { } message SignDoc { + // body_bytes is protobuf serialization of a TxBody that matches the representation in TxRaw. bytes body_bytes = 1; + // auth_info_bytes is a protobuf serialization of an AuthInfo that matches the representation in TxRaw. bytes auth_info_bytes = 2; // chain_id is the unique identifier of the chain this transaction targets. diff --git a/types/tx/tx.pb.go b/types/tx/tx.pb.go index 25341ce0e1c5..031697ff77ef 100644 --- a/types/tx/tx.pb.go +++ b/types/tx/tx.pb.go @@ -163,7 +163,9 @@ func (m *TxRaw) GetSignatures() [][]byte { } type SignDoc struct { - BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` + // body_bytes is protobuf serialization of a TxBody that matches the representation in TxRaw. + BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` + // auth_info_bytes is a protobuf serialization of an AuthInfo that matches the representation in TxRaw. AuthInfoBytes []byte `protobuf:"bytes,2,opt,name=auth_info_bytes,json=authInfoBytes,proto3" json:"auth_info_bytes,omitempty"` // chain_id is the unique identifier of the chain this transaction targets. // It prevents signed transactions from being used on another chain by an From 129a2227c269efd4ce9374884f215b47e9776fdf Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 10:48:20 -0400 Subject: [PATCH 20/43] cleanup --- types/tx/generator/builder.go | 91 +---------------------------- types/tx/generator/sigs.go | 104 ++++++++++++++++++++++++++++++++++ 2 files changed, 106 insertions(+), 89 deletions(-) create mode 100644 types/tx/generator/sigs.go diff --git a/types/tx/generator/builder.go b/types/tx/generator/builder.go index f7f18871a85a..f5c708eb700d 100644 --- a/types/tx/generator/builder.go +++ b/types/tx/generator/builder.go @@ -35,6 +35,7 @@ type Builder interface { direct.ProtoTx } +// NewBuilder returns a new Builder instance func NewBuilder(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) Builder { return &builder{ tx: &tx.Tx{ @@ -224,7 +225,7 @@ func (t *builder) GetSignaturesV2() ([]signing.SignatureV2, error) { for i, si := range signerInfos { var err error - sigData, err := ModeInfoToSignatureData(si.ModeInfo, sigs[i]) + sigData, err := ModeInfoAndSigToSignatureData(si.ModeInfo, sigs[i]) if err != nil { return nil, err } @@ -324,91 +325,3 @@ func (t *builder) setSignatures(sigs [][]byte) { func (t *builder) GetTx() authsigning.SigFeeMemoTx { return t } - -func SignatureDataToModeInfoAndSig(data signing.SignatureData) (*tx.ModeInfo, []byte) { - if data == nil { - return nil, nil - } - - switch data := data.(type) { - case *signing.SingleSignatureData: - return &tx.ModeInfo{ - Sum: &tx.ModeInfo_Single_{ - Single: &tx.ModeInfo_Single{Mode: data.SignMode}, - }, - }, data.Signature - case *signing.MultiSignatureData: - n := len(data.Signatures) - modeInfos := make([]*tx.ModeInfo, n) - sigs := make([][]byte, n) - - for i, d := range data.Signatures { - modeInfos[i], sigs[i] = SignatureDataToModeInfoAndSig(d) - } - - multisig := types.MultiSignature{ - Signatures: sigs, - } - sig, err := multisig.Marshal() - if err != nil { - panic(err) - } - - return &tx.ModeInfo{ - Sum: &tx.ModeInfo_Multi_{ - Multi: &tx.ModeInfo_Multi{ - Bitarray: data.BitArray, - ModeInfos: modeInfos, - }, - }, - }, sig - default: - panic("unexpected case") - } -} - -func ModeInfoToSignatureData(modeInfo *tx.ModeInfo, sig []byte) (signing.SignatureData, error) { - switch modeInfo := modeInfo.Sum.(type) { - case *tx.ModeInfo_Single_: - return &signing.SingleSignatureData{ - SignMode: modeInfo.Single.Mode, - Signature: sig, - }, nil - - case *tx.ModeInfo_Multi_: - multi := modeInfo.Multi - - sigs, err := DecodeMultisignatures(sig) - if err != nil { - return nil, err - } - - sigv2s := make([]signing.SignatureData, len(sigs)) - for i, mi := range multi.ModeInfos { - sigv2s[i], err = ModeInfoToSignatureData(mi, sigs[i]) - if err != nil { - return nil, err - } - } - - return &signing.MultiSignatureData{ - BitArray: multi.Bitarray, - Signatures: sigv2s, - }, nil - - default: - panic("unexpected case") - } -} - -func DecodeMultisignatures(bz []byte) ([][]byte, error) { - multisig := types.MultiSignature{} - err := multisig.Unmarshal(bz) - if err != nil { - return nil, err - } - if len(multisig.XXX_unrecognized) > 0 { - return nil, fmt.Errorf("rejecting unrecognized fields found in MultiSignature") - } - return multisig.Signatures, nil -} diff --git a/types/tx/generator/sigs.go b/types/tx/generator/sigs.go new file mode 100644 index 000000000000..d65a9670cf8b --- /dev/null +++ b/types/tx/generator/sigs.go @@ -0,0 +1,104 @@ +package generator + +import ( + "fmt" + + "github.com/cosmos/cosmos-sdk/crypto/types" + "github.com/cosmos/cosmos-sdk/types/tx" + "github.com/cosmos/cosmos-sdk/types/tx/signing" +) + +// SignatureDataToModeInfoAndSig converts a SignatureData to a ModeInfo and raw bytes signature +func SignatureDataToModeInfoAndSig(data signing.SignatureData) (*tx.ModeInfo, []byte) { + if data == nil { + return nil, nil + } + + switch data := data.(type) { + case *signing.SingleSignatureData: + return &tx.ModeInfo{ + Sum: &tx.ModeInfo_Single_{ + Single: &tx.ModeInfo_Single{Mode: data.SignMode}, + }, + }, data.Signature + case *signing.MultiSignatureData: + n := len(data.Signatures) + modeInfos := make([]*tx.ModeInfo, n) + sigs := make([][]byte, n) + + for i, d := range data.Signatures { + modeInfos[i], sigs[i] = SignatureDataToModeInfoAndSig(d) + } + + multisig := types.MultiSignature{ + Signatures: sigs, + } + sig, err := multisig.Marshal() + if err != nil { + panic(err) + } + + return &tx.ModeInfo{ + Sum: &tx.ModeInfo_Multi_{ + Multi: &tx.ModeInfo_Multi{ + Bitarray: data.BitArray, + ModeInfos: modeInfos, + }, + }, + }, sig + default: + panic("unexpected case") + } +} + +// ModeInfoAndSigToSignatureData converts a ModeInfo and raw bytes signature to a SignatureData or returns +// an error +func ModeInfoAndSigToSignatureData(modeInfo *tx.ModeInfo, sig []byte) (signing.SignatureData, error) { + switch modeInfo := modeInfo.Sum.(type) { + case *tx.ModeInfo_Single_: + return &signing.SingleSignatureData{ + SignMode: modeInfo.Single.Mode, + Signature: sig, + }, nil + + case *tx.ModeInfo_Multi_: + multi := modeInfo.Multi + + sigs, err := decodeMultisignatures(sig) + if err != nil { + return nil, err + } + + sigv2s := make([]signing.SignatureData, len(sigs)) + for i, mi := range multi.ModeInfos { + sigv2s[i], err = ModeInfoAndSigToSignatureData(mi, sigs[i]) + if err != nil { + return nil, err + } + } + + return &signing.MultiSignatureData{ + BitArray: multi.Bitarray, + Signatures: sigv2s, + }, nil + + default: + panic("unexpected case") + } +} + +// decodeMultisignatures safely decodes the the raw bytes as a MultiSignature protobuf message +func decodeMultisignatures(bz []byte) ([][]byte, error) { + multisig := types.MultiSignature{} + err := multisig.Unmarshal(bz) + if err != nil { + return nil, err + } + // NOTE: it is import to reject multi-signatures that contain unrecognized fields because this is an exploitable + // malleability in the protobuf message. Basically an attacker could bloat a MultiSignature message with unknown + // fields, thus bloating the transaction and causing it to fail. + if len(multisig.XXX_unrecognized) > 0 { + return nil, fmt.Errorf("rejecting unrecognized fields found in MultiSignature") + } + return multisig.Signatures, nil +} From b538e121912490346786db347579b204fc0eb8b0 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 10:50:10 -0400 Subject: [PATCH 21/43] cleanup --- types/tx/generator/decoder.go | 2 ++ types/tx/generator/encoder.go | 2 ++ 2 files changed, 4 insertions(+) diff --git a/types/tx/generator/decoder.go b/types/tx/generator/decoder.go index 284512561dd3..df31928ae1f6 100644 --- a/types/tx/generator/decoder.go +++ b/types/tx/generator/decoder.go @@ -10,6 +10,7 @@ import ( sdk "github.com/cosmos/cosmos-sdk/types" ) +// DefaultTxDecoder returns a default protobuf TxDecoder using the provided Marshaler and PublicKeyCodec func DefaultTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCodec) sdk.TxDecoder { return func(txBytes []byte) (sdk.Tx, error) { var raw tx.TxRaw @@ -40,6 +41,7 @@ func DefaultTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCodec) } } +// DefaultTxDecoder returns a default protobuf JSON TxDecoder using the provided Marshaler and PublicKeyCodec func DefaultJSONTxDecoder(cdc codec.Marshaler, keyCodec cryptotypes.PublicKeyCodec) sdk.TxDecoder { return func(txBytes []byte) (sdk.Tx, error) { var theTx tx.Tx diff --git a/types/tx/generator/encoder.go b/types/tx/generator/encoder.go index 296023b85028..5fea3692d403 100644 --- a/types/tx/generator/encoder.go +++ b/types/tx/generator/encoder.go @@ -8,6 +8,7 @@ import ( txtypes "github.com/cosmos/cosmos-sdk/types/tx" ) +// DefaultTxEncoder returns a default protobuf TxEncoder using the provided Marshaler func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { return func(tx types.Tx) ([]byte, error) { wrapper, ok := tx.(*builder) @@ -25,6 +26,7 @@ func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { } } +// DefaultTxEncoder returns a default protobuf JSON TxEncoder using the provided Marshaler func DefaultJSONTxEncoder(marshaler codec.Marshaler) types.TxEncoder { return func(tx types.Tx) ([]byte, error) { wrapper, ok := tx.(*builder) From f18ea60e0bc185fc25ef18637a14046b5d8b455d Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 10:53:52 -0400 Subject: [PATCH 22/43] cleanup --- types/tx/generator/generator.go | 18 +++--------------- types/tx/generator/generator_test.go | 3 ++- types/tx/generator/mode_handler.go | 20 ++++++++++++++++++++ 3 files changed, 25 insertions(+), 16 deletions(-) create mode 100644 types/tx/generator/mode_handler.go diff --git a/types/tx/generator/generator.go b/types/tx/generator/generator.go index 50da70f8bb11..a215a707786b 100644 --- a/types/tx/generator/generator.go +++ b/types/tx/generator/generator.go @@ -5,10 +5,7 @@ import ( "github.com/cosmos/cosmos-sdk/codec" "github.com/cosmos/cosmos-sdk/crypto/types" sdk "github.com/cosmos/cosmos-sdk/types" - signing2 "github.com/cosmos/cosmos-sdk/types/tx/signing" "github.com/cosmos/cosmos-sdk/x/auth/signing" - "github.com/cosmos/cosmos-sdk/x/auth/signing/direct" - types2 "github.com/cosmos/cosmos-sdk/x/auth/types" ) type generator struct { @@ -21,11 +18,12 @@ type generator struct { jsonEncoder sdk.TxEncoder } -func New(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) client.TxGenerator { +// New returns a new protobuf TxGenerator using the provided Marshaler, PublicKeyCodec and SignModeHandler. +func New(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec, signModeHandler signing.SignModeHandler) client.TxGenerator { return &generator{ marshaler: marshaler, pubkeyCodec: pubkeyCodec, - handler: DefaultSignModeHandler(), + handler: signModeHandler, decoder: DefaultTxDecoder(marshaler, pubkeyCodec), encoder: DefaultTxEncoder(marshaler), jsonDecoder: DefaultJSONTxDecoder(marshaler, pubkeyCodec), @@ -56,13 +54,3 @@ func (g generator) TxJSONEncoder() sdk.TxEncoder { func (g generator) TxJSONDecoder() sdk.TxDecoder { return g.jsonDecoder } - -func DefaultSignModeHandler() signing.SignModeHandler { - return signing.NewSignModeHandlerMap( - signing2.SignMode_SIGN_MODE_DIRECT, - []signing.SignModeHandler{ - types2.LegacyAminoJSONHandler{}, - direct.ModeHandler{}, - }, - ) -} diff --git a/types/tx/generator/generator_test.go b/types/tx/generator/generator_test.go index af5500a31b23..9c064c775c0b 100644 --- a/types/tx/generator/generator_test.go +++ b/types/tx/generator/generator_test.go @@ -20,5 +20,6 @@ func TestGenerator(t *testing.T) { interfaceRegistry.RegisterImplementations((*sdk.Msg)(nil), &testdata.TestMsg{}) marshaler := codec.NewProtoCodec(interfaceRegistry) pubKeyCodec := std.DefaultPublicKeyCodec{} - suite.Run(t, testutil.NewTxGeneratorTestSuite(New(marshaler, pubKeyCodec))) + signModeHandler := DefaultSignModeHandler() + suite.Run(t, testutil.NewTxGeneratorTestSuite(New(marshaler, pubKeyCodec, signModeHandler))) } diff --git a/types/tx/generator/mode_handler.go b/types/tx/generator/mode_handler.go new file mode 100644 index 000000000000..92f0e03c576b --- /dev/null +++ b/types/tx/generator/mode_handler.go @@ -0,0 +1,20 @@ +package generator + +import ( + signing2 "github.com/cosmos/cosmos-sdk/types/tx/signing" + "github.com/cosmos/cosmos-sdk/x/auth/signing" + "github.com/cosmos/cosmos-sdk/x/auth/signing/direct" + authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" +) + +// DefaultSignModeHandler returns the default protobuf SignModeHandler supporting +// SIGN_MODE_DIRECT and SIGN_MODE_LEGACY_AMINO_JSON. +func DefaultSignModeHandler() signing.SignModeHandler { + return signing.NewSignModeHandlerMap( + signing2.SignMode_SIGN_MODE_DIRECT, + []signing.SignModeHandler{ + authtypes.LegacyAminoJSONHandler{}, + direct.ModeHandler{}, + }, + ) +} From 13c3b5af767187f4d90cf2667579cb205af50d14 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 10:55:16 -0400 Subject: [PATCH 23/43] cleanup --- types/tx/types.go | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/types/tx/types.go b/types/tx/types.go index 4499cd64ead2..ed56de13e4bc 100644 --- a/types/tx/types.go +++ b/types/tx/types.go @@ -5,6 +5,9 @@ import ( sdk "github.com/cosmos/cosmos-sdk/types" ) +var _, _ codectypes.UnpackInterfacesMessage = &Tx{}, &TxBody{} + +// UnpackInterfaces implements the UnpackInterfaceMessages.UnpackInterfaces method func (m *Tx) UnpackInterfaces(unpacker codectypes.AnyUnpacker) error { if m.Body != nil { return m.Body.UnpackInterfaces(unpacker) @@ -12,6 +15,7 @@ func (m *Tx) UnpackInterfaces(unpacker codectypes.AnyUnpacker) error { return nil } +// UnpackInterfaces implements the UnpackInterfaceMessages.UnpackInterfaces method func (m *TxBody) UnpackInterfaces(unpacker codectypes.AnyUnpacker) error { for _, any := range m.Messages { var msg sdk.Msg From a74165bd03dde13da9e336a5198a0dcd9cfed7b9 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 10:59:55 -0400 Subject: [PATCH 24/43] cleanup --- x/auth/signing/direct/direct.go | 21 ++++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) diff --git a/x/auth/signing/direct/direct.go b/x/auth/signing/direct/direct.go index 3c3c1c922c08..a22ce6022a96 100644 --- a/x/auth/signing/direct/direct.go +++ b/x/auth/signing/direct/direct.go @@ -10,23 +10,32 @@ import ( "github.com/cosmos/cosmos-sdk/x/auth/signing" ) +// ProtoTx defines an interface which protobuf transactions must implement for +// signature verification via SignModeDirect type ProtoTx interface { + // GetBodyBytes returns the raw serialized bytes for TxBody GetBodyBytes() []byte + + // GetBodyBytes returns the raw serialized bytes for AuthInfo GetAuthInfoBytes() []byte } +// ModeHandler defines the SIGN_MODE_DIRECT SignModeHandler type ModeHandler struct{} +var _ signing.SignModeHandler = ModeHandler{} + +// DefaultMode implements SignModeHandler.DefaultMode func (h ModeHandler) DefaultMode() signingtypes.SignMode { return signingtypes.SignMode_SIGN_MODE_DIRECT } -var _ signing.SignModeHandler = ModeHandler{} - +// Modes implements SignModeHandler.Modes func (ModeHandler) Modes() []signingtypes.SignMode { return []signingtypes.SignMode{signingtypes.SignMode_SIGN_MODE_DIRECT} } +// GetSignBytes implements SignModeHandler.GetSignBytes func (ModeHandler) GetSignBytes(mode signingtypes.SignMode, data signing.SignerData, tx sdk.Tx) ([]byte, error) { if mode != signingtypes.SignMode_SIGN_MODE_DIRECT { return nil, fmt.Errorf("expected %s, got %s", signingtypes.SignMode_SIGN_MODE_DIRECT, mode) @@ -43,10 +52,12 @@ func (ModeHandler) GetSignBytes(mode signingtypes.SignMode, data signing.SignerD return SignBytes(bodyBz, authInfoBz, data.ChainID, data.AccountNumber, data.AccountSequence) } -func SignBytes(bodyBz, authInfoBz []byte, chainID string, accnum, sequence uint64) ([]byte, error) { +// SignBytes returns the SIGN_MODE_DIRECT sign bytes for the provided TxBody bytes, AuthInfo bytes, chain ID, +// account number and sequence. +func SignBytes(bodyBytes, authInfoBytes []byte, chainID string, accnum, sequence uint64) ([]byte, error) { signDoc := types.SignDoc{ - BodyBytes: bodyBz, - AuthInfoBytes: authInfoBz, + BodyBytes: bodyBytes, + AuthInfoBytes: authInfoBytes, ChainId: chainID, AccountNumber: accnum, AccountSequence: sequence, From eb22466bf3cf7f19781cbf4556037323acc8ed87 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 11:25:05 -0400 Subject: [PATCH 25/43] cleanup --- proto/cosmos/tx/tx.proto | 1 + 1 file changed, 1 insertion(+) diff --git a/proto/cosmos/tx/tx.proto b/proto/cosmos/tx/tx.proto index 6b537ea828de..91c92a70ca88 100644 --- a/proto/cosmos/tx/tx.proto +++ b/proto/cosmos/tx/tx.proto @@ -39,6 +39,7 @@ message TxRaw { repeated bytes signatures = 3; } +// SignDoc is the type used for generating sign bytes for SIGN_MODE_DIRECT message SignDoc { // body_bytes is protobuf serialization of a TxBody that matches the representation in TxRaw. bytes body_bytes = 1; From f25b3822e9fddb32c3ca772b117f07bcc242a94b Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 11:25:49 -0400 Subject: [PATCH 26/43] cleanup --- x/auth/signing/direct/direct_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index 489addbedac4..961b0b48892c 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -30,7 +30,7 @@ func TestDirectModeHandler(t *testing.T) { marshaler := codec.NewProtoCodec(interfaceRegistry) pubKeyCdc := std.DefaultPublicKeyCodec{} - txGen := generator.New(marshaler, pubKeyCdc) + txGen := generator.New(marshaler, pubKeyCdc, generator.DefaultSignModeHandler()) txBuilder := txGen.NewTxBuilder() memo := "sometestmemo" From dc9c6cbb4644a91101e3f08d391480af7e08d30b Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 13:14:24 -0400 Subject: [PATCH 27/43] Add tests --- client/testutil/suite.go | 52 ++++++++++++++++++++++++++++++---------- 1 file changed, 39 insertions(+), 13 deletions(-) diff --git a/client/testutil/suite.go b/client/testutil/suite.go index 7e8684ca83ac..6dc3508d9988 100644 --- a/client/testutil/suite.go +++ b/client/testutil/suite.go @@ -2,6 +2,7 @@ package testutil import ( "github.com/cosmos/cosmos-sdk/x/auth/signing" + authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" "github.com/stretchr/testify/suite" "github.com/tendermint/tendermint/crypto/secp256k1" @@ -74,23 +75,48 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetMsgs() { } func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { - priv := secp256k1.GenPrivKey() - dummySig := []byte("dummySig") + privKey, pubkey, addr := authtypes.KeyTestPubAddr() txBuilder := s.TxGenerator.NewTxBuilder() - sig := signingtypes.SignatureV2{ - PubKey: priv.PubKey(), - Data: &signingtypes.SingleSignatureData{ - SignMode: signingtypes.SignMode_SIGN_MODE_LEGACY_AMINO_JSON, - Signature: dummySig, - }, - } - err := txBuilder.SetSignatures(sig) + // set test msg + msg := testdata.NewTestMsg(addr) + err := txBuilder.SetMsgs(msg) s.Require().NoError(err) + // set SignatureV2 without actual signature bytes + signModeHandler := s.TxGenerator.SignModeHandler() + s.Require().Contains(signModeHandler.Modes(), signModeHandler.DefaultMode()) + sigData := &signingtypes.SingleSignatureData{SignMode: signModeHandler.DefaultMode()} + sig := signingtypes.SignatureV2{PubKey: pubkey, Data: sigData} + err = txBuilder.SetSignatures(sig) + s.Require().NoError(err) sigTx := txBuilder.GetTx().(signing.SigVerifiableTx) - s.Require().Equal(dummySig, sigTx.GetSignatures()[0]) + s.Require().Equal([][]byte{nil}, sigTx.GetSignatures()) + sigsV2, err := sigTx.GetSignaturesV2() + s.Require().NoError(err) + s.Require().Equal([]signingtypes.SignatureV2{sig}, sigsV2) + + // sign transaction + signBytes, err := signModeHandler.GetSignBytes(signModeHandler.DefaultMode(), signing.SignerData{ + ChainID: "test", + AccountNumber: 1, + AccountSequence: 2, + }, sigTx) + s.Require().NoError(err) + sigBz, err := privKey.Sign(signBytes) + s.Require().NoError(err) + + // set signature + sigData.Signature = sigBz + sig = signingtypes.SignatureV2{PubKey: pubkey, Data: sigData} + err = txBuilder.SetSignatures(sig) + s.Require().NoError(err) + sigTx = txBuilder.GetTx().(signing.SigVerifiableTx) + s.Require().Equal([][]byte{nil}, sigTx.GetSignatures()) + sigsV2, err = sigTx.GetSignaturesV2() + s.Require().NoError(err) + s.Require().Equal([]signingtypes.SignatureV2{sig}, sigsV2) } func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { @@ -136,12 +162,12 @@ func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { s.Require().Equal(priv.PubKey(), tx3.GetPubKeys()[0]) // JSON encode transaction - jsonTxBytes, err := s.TxGenerator.TxEncoder()(tx) + jsonTxBytes, err := s.TxGenerator.TxJSONEncoder()(tx) s.Require().NoError(err) s.Require().NotNil(jsonTxBytes) // JSON decode transaction - tx2, err = s.TxGenerator.TxDecoder()(txBytes) + tx2, err = s.TxGenerator.TxJSONDecoder()(txBytes) s.Require().NoError(err) tx3, ok = tx2.(signing.SigFeeMemoTx) s.Require().True(ok) From 864d5066019030221afbf699d419a67431d18863 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 14:21:55 -0400 Subject: [PATCH 28/43] Refactor and improving test coverage --- client/testutil/suite.go | 52 ++++++----- codec/proto_codec.go | 7 +- codec/testdata/proto.pb.go | 93 +++++++++---------- codec/testdata/proto.proto | 2 +- types/tx/tx.pb.go | 1 + x/auth/signing/direct/direct_test.go | 6 +- {types/tx/generator => x/auth/tx}/builder.go | 2 +- .../generator => x/auth/tx}/builder_test.go | 2 +- {types/tx/generator => x/auth/tx}/decoder.go | 2 +- {types/tx/generator => x/auth/tx}/encoder.go | 2 +- .../tx/generator => x/auth/tx}/generator.go | 2 +- .../generator => x/auth/tx}/generator_test.go | 2 +- .../generator => x/auth/tx}/mode_handler.go | 2 +- {types/tx/generator => x/auth/tx}/sigs.go | 2 +- 14 files changed, 96 insertions(+), 81 deletions(-) rename {types/tx/generator => x/auth/tx}/builder.go (99%) rename {types/tx/generator => x/auth/tx}/builder_test.go (99%) rename {types/tx/generator => x/auth/tx}/decoder.go (99%) rename {types/tx/generator => x/auth/tx}/encoder.go (98%) rename {types/tx/generator => x/auth/tx}/generator.go (98%) rename {types/tx/generator => x/auth/tx}/generator_test.go (97%) rename {types/tx/generator => x/auth/tx}/mode_handler.go (97%) rename {types/tx/generator => x/auth/tx}/sigs.go (99%) diff --git a/client/testutil/suite.go b/client/testutil/suite.go index 6dc3508d9988..560e45e35cb4 100644 --- a/client/testutil/suite.go +++ b/client/testutil/suite.go @@ -1,12 +1,11 @@ package testutil import ( + "github.com/cosmos/cosmos-sdk/codec/testdata" "github.com/cosmos/cosmos-sdk/x/auth/signing" authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" "github.com/stretchr/testify/suite" - "github.com/tendermint/tendermint/crypto/secp256k1" - - "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/tendermint/tendermint/crypto" "github.com/cosmos/cosmos-sdk/client" @@ -61,8 +60,8 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetMemo() { } func (s *TxGeneratorTestSuite) TestTxBuilderSetMsgs() { - addr1 := sdk.AccAddress(secp256k1.GenPrivKey().PubKey().Address()) - addr2 := sdk.AccAddress(secp256k1.GenPrivKey().PubKey().Address()) + _, _, addr1 := authtypes.KeyTestPubAddr() + _, _, addr2 := authtypes.KeyTestPubAddr() msg1 := testdata.NewTestMsg(addr1) msg2 := testdata.NewTestMsg(addr2) msgs := []sdk.Msg{msg1, msg2} @@ -71,7 +70,11 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetMsgs() { err := txBuilder.SetMsgs(msgs...) s.Require().NoError(err) - s.Require().Equal(msgs, txBuilder.GetTx().GetMsgs()) + tx := txBuilder.GetTx() + s.Require().Equal(msgs, tx.GetMsgs()) + s.Require().Equal([]sdk.AccAddress{addr1, addr2}, tx.GetSigners()) + s.Require().Equal(addr1, tx.FeePayer()) + s.Require().Error(tx.ValidateBasic()) // should fail because of no signatures } func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { @@ -84,6 +87,9 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { err := txBuilder.SetMsgs(msg) s.Require().NoError(err) + // check that validation fails + s.Require().Error(txBuilder.GetTx().ValidateBasic()) + // set SignatureV2 without actual signature bytes signModeHandler := s.TxGenerator.SignModeHandler() s.Require().Contains(signModeHandler.Modes(), signModeHandler.DefaultMode()) @@ -91,11 +97,13 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { sig := signingtypes.SignatureV2{PubKey: pubkey, Data: sigData} err = txBuilder.SetSignatures(sig) s.Require().NoError(err) - sigTx := txBuilder.GetTx().(signing.SigVerifiableTx) + sigTx := txBuilder.GetTx() s.Require().Equal([][]byte{nil}, sigTx.GetSignatures()) sigsV2, err := sigTx.GetSignaturesV2() s.Require().NoError(err) s.Require().Equal([]signingtypes.SignatureV2{sig}, sigsV2) + s.Require().Equal([]sdk.AccAddress{addr}, sigTx.GetSigners()) + s.Require().NoError(sigTx.ValidateBasic()) // sign transaction signBytes, err := signModeHandler.GetSignBytes(signModeHandler.DefaultMode(), signing.SignerData{ @@ -112,22 +120,24 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { sig = signingtypes.SignatureV2{PubKey: pubkey, Data: sigData} err = txBuilder.SetSignatures(sig) s.Require().NoError(err) - sigTx = txBuilder.GetTx().(signing.SigVerifiableTx) - s.Require().Equal([][]byte{nil}, sigTx.GetSignatures()) + sigTx = txBuilder.GetTx() + s.Require().Equal([][]byte{sigBz}, sigTx.GetSignatures()) sigsV2, err = sigTx.GetSignaturesV2() s.Require().NoError(err) s.Require().Equal([]signingtypes.SignatureV2{sig}, sigsV2) + s.Require().Equal([]sdk.AccAddress{addr}, sigTx.GetSigners()) + s.Require().NoError(sigTx.ValidateBasic()) } func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { - priv := secp256k1.GenPrivKey() + _, pubkey, addr := authtypes.KeyTestPubAddr() feeAmount := sdk.Coins{sdk.NewInt64Coin("atom", 150)} gasLimit := uint64(50000) memo := "foomemo" - msg := testdata.NewTestMsg(sdk.AccAddress(priv.PubKey().Address())) + msg := testdata.NewTestMsg(addr) dummySig := []byte("dummySig") sig := signingtypes.SignatureV2{ - PubKey: priv.PubKey(), + PubKey: pubkey, Data: &signingtypes.SingleSignatureData{ SignMode: signingtypes.SignMode_SIGN_MODE_LEGACY_AMINO_JSON, Signature: dummySig, @@ -144,12 +154,12 @@ func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { s.Require().NoError(err) tx := txBuilder.GetTx() - // encode transaction + s.T().Log("encode transaction") txBytes, err := s.TxGenerator.TxEncoder()(tx) s.Require().NoError(err) s.Require().NotNil(txBytes) - // decode transaction + s.T().Log("decode transaction") tx2, err := s.TxGenerator.TxDecoder()(txBytes) s.Require().NoError(err) tx3, ok := tx2.(signing.SigFeeMemoTx) @@ -158,16 +168,16 @@ func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { s.Require().Equal(feeAmount, tx3.GetFee()) s.Require().Equal(gasLimit, tx3.GetGas()) s.Require().Equal(memo, tx3.GetMemo()) - s.Require().Equal(dummySig, tx3.GetSignatures()[0]) - s.Require().Equal(priv.PubKey(), tx3.GetPubKeys()[0]) + s.Require().Equal([][]byte{dummySig}, tx3.GetSignatures()) + s.Require().Equal([]crypto.PubKey{pubkey}, tx3.GetPubKeys()) - // JSON encode transaction + s.T().Log("JSON encode transaction") jsonTxBytes, err := s.TxGenerator.TxJSONEncoder()(tx) s.Require().NoError(err) s.Require().NotNil(jsonTxBytes) - // JSON decode transaction - tx2, err = s.TxGenerator.TxJSONDecoder()(txBytes) + s.T().Log("JSON decode transaction") + tx2, err = s.TxGenerator.TxJSONDecoder()(jsonTxBytes) s.Require().NoError(err) tx3, ok = tx2.(signing.SigFeeMemoTx) s.Require().True(ok) @@ -175,6 +185,6 @@ func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { s.Require().Equal(feeAmount, tx3.GetFee()) s.Require().Equal(gasLimit, tx3.GetGas()) s.Require().Equal(memo, tx3.GetMemo()) - s.Require().Equal(dummySig, tx3.GetSignatures()[0]) - s.Require().Equal(priv.PubKey(), tx3.GetPubKeys()[0]) + s.Require().Equal([][]byte{dummySig}, tx3.GetSignatures()) + s.Require().Equal([]crypto.PubKey{pubkey}, tx3.GetPubKeys()) } diff --git a/codec/proto_codec.go b/codec/proto_codec.go index 2c9825db704b..2a2befc33261 100644 --- a/codec/proto_codec.go +++ b/codec/proto_codec.go @@ -125,7 +125,12 @@ func (pc *ProtoCodec) UnmarshalJSON(bz []byte, ptr interface{}) error { return fmt.Errorf("cannot protobuf JSON decode unsupported type: %T", ptr) } - return jsonpb.Unmarshal(strings.NewReader(string(bz)), m) + err := jsonpb.Unmarshal(strings.NewReader(string(bz)), m) + if err != nil { + return err + } + + return types.UnpackInterfaces(ptr, pc.anyUnpacker) } func (pc *ProtoCodec) MustUnmarshalJSON(bz []byte, ptr interface{}) { diff --git a/codec/testdata/proto.pb.go b/codec/testdata/proto.pb.go index 8bc3fe380120..e8baad718a13 100644 --- a/codec/testdata/proto.pb.go +++ b/codec/testdata/proto.pb.go @@ -496,53 +496,52 @@ func (m *TestMsg) GetSigners() []github_com_cosmos_cosmos_sdk_types.AccAddress { } func init() { - proto.RegisterType((*Dog)(nil), "cosmos_sdk.codec.v1.Dog") - proto.RegisterType((*Cat)(nil), "cosmos_sdk.codec.v1.Cat") - proto.RegisterType((*HasAnimal)(nil), "cosmos_sdk.codec.v1.HasAnimal") - proto.RegisterType((*HasHasAnimal)(nil), "cosmos_sdk.codec.v1.HasHasAnimal") - proto.RegisterType((*HasHasHasAnimal)(nil), "cosmos_sdk.codec.v1.HasHasHasAnimal") - proto.RegisterType((*EchoRequest)(nil), "cosmos_sdk.codec.v1.EchoRequest") - proto.RegisterType((*EchoResponse)(nil), "cosmos_sdk.codec.v1.EchoResponse") - proto.RegisterType((*SayHelloRequest)(nil), "cosmos_sdk.codec.v1.SayHelloRequest") - proto.RegisterType((*SayHelloResponse)(nil), "cosmos_sdk.codec.v1.SayHelloResponse") - proto.RegisterType((*TestMsg)(nil), "cosmos_sdk.codec.v1.TestMsg") + proto.RegisterType((*Dog)(nil), "testdata.Dog") + proto.RegisterType((*Cat)(nil), "testdata.Cat") + proto.RegisterType((*HasAnimal)(nil), "testdata.HasAnimal") + proto.RegisterType((*HasHasAnimal)(nil), "testdata.HasHasAnimal") + proto.RegisterType((*HasHasHasAnimal)(nil), "testdata.HasHasHasAnimal") + proto.RegisterType((*EchoRequest)(nil), "testdata.EchoRequest") + proto.RegisterType((*EchoResponse)(nil), "testdata.EchoResponse") + proto.RegisterType((*SayHelloRequest)(nil), "testdata.SayHelloRequest") + proto.RegisterType((*SayHelloResponse)(nil), "testdata.SayHelloResponse") + proto.RegisterType((*TestMsg)(nil), "testdata.TestMsg") } func init() { proto.RegisterFile("proto.proto", fileDescriptor_2fcc84b9998d60d8) } var fileDescriptor_2fcc84b9998d60d8 = []byte{ - // 481 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0xc1, 0x6e, 0xd3, 0x40, - 0x10, 0x40, 0x63, 0xd2, 0x36, 0xcd, 0x24, 0xa2, 0x68, 0xc9, 0x21, 0xe4, 0x60, 0x82, 0x45, 0x45, - 0x24, 0xc8, 0x5a, 0x6d, 0xc5, 0x85, 0x5b, 0x5a, 0x2a, 0x22, 0x55, 0xbd, 0xb8, 0x08, 0x24, 0x2e, - 0xd5, 0xc6, 0x1e, 0x36, 0x56, 0x62, 0x6f, 0xf0, 0x38, 0x51, 0xc3, 0x57, 0xf0, 0x2f, 0xfc, 0x04, - 0xc7, 0x1e, 0x39, 0x21, 0x94, 0xfc, 0x05, 0x27, 0xe4, 0x5d, 0x3b, 0x89, 0x50, 0x15, 0x7a, 0xb1, - 0x67, 0x56, 0x6f, 0x9e, 0x76, 0x66, 0x07, 0x6a, 0x93, 0x44, 0xa5, 0x8a, 0xeb, 0x2f, 0x7b, 0xec, - 0x2b, 0x8a, 0x14, 0x5d, 0x53, 0x30, 0xe2, 0xbe, 0x0a, 0xd0, 0xe7, 0xb3, 0xa3, 0xd6, 0x13, 0xa9, - 0x94, 0x1c, 0xa3, 0xab, 0x91, 0xc1, 0xf4, 0xb3, 0x2b, 0xe2, 0xb9, 0xe1, 0x5b, 0x0d, 0xa9, 0xa4, - 0xd2, 0xa1, 0x9b, 0x45, 0xe6, 0xd4, 0xe9, 0x42, 0xf9, 0xad, 0x92, 0x8c, 0xc1, 0x0e, 0x85, 0x5f, - 0xb1, 0x69, 0xb5, 0xad, 0x4e, 0xd5, 0xd3, 0x71, 0x76, 0x16, 0x8b, 0x08, 0x9b, 0x0f, 0xcc, 0x59, - 0x16, 0x3b, 0xaf, 0xa1, 0x7c, 0x26, 0x52, 0xd6, 0x84, 0x4a, 0xa4, 0xe2, 0x70, 0x84, 0x49, 0x5e, - 0x51, 0xa4, 0xac, 0x01, 0xbb, 0xe3, 0x70, 0x86, 0xa4, 0xab, 0x76, 0x3d, 0x93, 0x38, 0xef, 0xa0, - 0xda, 0x17, 0xd4, 0x8b, 0xc3, 0x48, 0x8c, 0xd9, 0x2b, 0xd8, 0x13, 0x3a, 0xd2, 0xb5, 0xb5, 0xe3, - 0x06, 0x37, 0x97, 0xe6, 0xc5, 0xa5, 0x79, 0x2f, 0x9e, 0x7b, 0x39, 0xc3, 0xea, 0x60, 0xdd, 0x68, - 0x59, 0xd9, 0xb3, 0x6e, 0x9c, 0x33, 0xa8, 0xf7, 0x05, 0xad, 0x5d, 0x27, 0x00, 0x43, 0x41, 0xd7, - 0xf7, 0xf0, 0x55, 0x87, 0x45, 0x91, 0x73, 0x09, 0x07, 0x46, 0xb2, 0xf6, 0xbc, 0x81, 0x87, 0x99, - 0xe7, 0x9e, 0xae, 0xfa, 0x70, 0xa3, 0xd6, 0x79, 0x01, 0xb5, 0x73, 0x7f, 0xa8, 0x3c, 0xfc, 0x32, - 0x45, 0x32, 0xb3, 0x41, 0x22, 0x21, 0x71, 0x35, 0x1b, 0x93, 0x3a, 0x1d, 0xa8, 0x1b, 0x90, 0x26, - 0x2a, 0x26, 0xdc, 0x42, 0x1e, 0xc2, 0xc1, 0x95, 0x98, 0xf7, 0x71, 0x3c, 0x5e, 0x69, 0x8b, 0xd7, - 0xb0, 0x36, 0x5e, 0x83, 0xc3, 0xa3, 0x35, 0x96, 0x4b, 0x5b, 0xb0, 0x2f, 0x13, 0xc4, 0x34, 0x8c, - 0x65, 0xce, 0xae, 0x72, 0xe7, 0x03, 0x54, 0xde, 0x23, 0xa5, 0x97, 0x24, 0xd9, 0x05, 0x54, 0x28, - 0x94, 0x31, 0x26, 0xd4, 0xb4, 0xda, 0xe5, 0x4e, 0xfd, 0xf4, 0xe8, 0xcf, 0xaf, 0xa7, 0x5d, 0x19, - 0xa6, 0xc3, 0xe9, 0x80, 0xfb, 0x2a, 0x72, 0xcd, 0x76, 0xe5, 0xbf, 0x2e, 0x05, 0x23, 0x37, 0x9d, - 0x4f, 0x90, 0x78, 0xcf, 0xf7, 0x7b, 0x41, 0x90, 0x20, 0x91, 0x57, 0x18, 0x8e, 0xbf, 0x5b, 0x50, - 0xcb, 0xc4, 0x57, 0x98, 0xcc, 0x42, 0x1f, 0xd9, 0x05, 0xec, 0x64, 0x8d, 0xb2, 0x36, 0xbf, 0x63, - 0x47, 0xf9, 0xc6, 0xb0, 0x5a, 0xcf, 0xb6, 0x10, 0x79, 0x43, 0x1f, 0x61, 0xbf, 0x68, 0x92, 0x3d, - 0xbf, 0x13, 0xff, 0x67, 0x54, 0xad, 0xc3, 0xff, 0x50, 0x46, 0x7c, 0x7a, 0xfe, 0x63, 0x61, 0x5b, - 0xb7, 0x0b, 0xdb, 0xfa, 0xbd, 0xb0, 0xad, 0x6f, 0x4b, 0xbb, 0x74, 0xbb, 0xb4, 0x4b, 0x3f, 0x97, - 0x76, 0xe9, 0xd3, 0xcb, 0xad, 0x73, 0xd0, 0x46, 0x37, 0x45, 0x4a, 0x03, 0x91, 0x8a, 0xc1, 0x9e, - 0x5e, 0x8d, 0x93, 0xbf, 0x01, 0x00, 0x00, 0xff, 0xff, 0xe2, 0x42, 0x37, 0xaa, 0x9d, 0x03, 0x00, - 0x00, + // 471 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0x4f, 0x6f, 0xd3, 0x4c, + 0x10, 0xc6, 0xb3, 0x6f, 0xda, 0x26, 0x99, 0x58, 0x6f, 0xd1, 0x2a, 0xa0, 0xd4, 0x07, 0x53, 0x59, + 0x42, 0x44, 0x82, 0xd8, 0xa2, 0x55, 0x2f, 0xdc, 0xdc, 0x52, 0x11, 0x09, 0xf5, 0xe2, 0x22, 0x0e, + 0x5c, 0xd0, 0xc6, 0x1e, 0xd6, 0x56, 0x6d, 0x6f, 0xf0, 0x38, 0x55, 0xc3, 0x17, 0xe0, 0xca, 0xc7, + 0xe2, 0xd8, 0x23, 0x27, 0x84, 0x92, 0x6f, 0xc1, 0x09, 0xd9, 0x6b, 0x27, 0x51, 0x85, 0xaa, 0x5e, + 0xec, 0x99, 0xf1, 0xf3, 0xfc, 0x34, 0x7f, 0x0c, 0xfd, 0x59, 0xae, 0x0a, 0xe5, 0x54, 0x4f, 0xde, + 0x2d, 0x90, 0x8a, 0x50, 0x14, 0xc2, 0x3c, 0x90, 0x4a, 0xc9, 0x04, 0xdd, 0xaa, 0x3e, 0x9d, 0x7f, + 0x76, 0x45, 0xb6, 0xd0, 0x22, 0x73, 0x20, 0x95, 0x54, 0x55, 0xe8, 0x96, 0x91, 0xae, 0xda, 0x63, + 0x68, 0xbf, 0x51, 0x92, 0x73, 0xd8, 0xa1, 0xf8, 0x2b, 0x0e, 0xd9, 0x21, 0x1b, 0xf5, 0xfc, 0x2a, + 0x2e, 0x6b, 0x99, 0x48, 0x71, 0xf8, 0x9f, 0xae, 0x95, 0xb1, 0x7d, 0x02, 0xed, 0x33, 0x51, 0xf0, + 0x21, 0x74, 0x52, 0x95, 0xc5, 0x57, 0x98, 0xd7, 0x8e, 0x26, 0xe5, 0x03, 0xd8, 0x4d, 0xe2, 0x6b, + 0xa4, 0xca, 0xb5, 0xeb, 0xeb, 0xc4, 0x7e, 0x0b, 0xbd, 0x89, 0x20, 0x2f, 0x8b, 0x53, 0x91, 0xf0, + 0x97, 0xb0, 0x27, 0xaa, 0xa8, 0xf2, 0xf6, 0x8f, 0x06, 0x8e, 0x6e, 0xda, 0x69, 0x9a, 0x76, 0xbc, + 0x6c, 0xe1, 0xd7, 0x1a, 0x6e, 0x00, 0xbb, 0xa9, 0x60, 0x6d, 0x9f, 0xdd, 0xd8, 0x67, 0x60, 0x4c, + 0x04, 0x6d, 0x58, 0xc7, 0x00, 0x91, 0xa0, 0x4f, 0x0f, 0xe0, 0xf5, 0xa2, 0xc6, 0x64, 0x5f, 0xc0, + 0xbe, 0x86, 0x6c, 0x38, 0xaf, 0xe1, 0xff, 0x92, 0xf3, 0x40, 0x96, 0x11, 0x6d, 0x79, 0xed, 0xe7, + 0xd0, 0x3f, 0x0f, 0x22, 0xe5, 0xe3, 0x97, 0x39, 0x92, 0xde, 0x0d, 0x12, 0x09, 0x89, 0xeb, 0xdd, + 0xe8, 0xd4, 0x1e, 0x81, 0xa1, 0x85, 0x34, 0x53, 0x19, 0xe1, 0x3d, 0xca, 0x67, 0xb0, 0x7f, 0x29, + 0x16, 0x13, 0x4c, 0x92, 0x35, 0xb6, 0xb9, 0x06, 0xdb, 0xba, 0x86, 0x03, 0x8f, 0x36, 0xb2, 0x1a, + 0x6a, 0x42, 0x57, 0xe6, 0x88, 0x45, 0x9c, 0xc9, 0x5a, 0xbb, 0xce, 0xed, 0x0f, 0xd0, 0x79, 0x8f, + 0x54, 0x5c, 0x90, 0xe4, 0xef, 0xa0, 0x43, 0xb1, 0xcc, 0x30, 0xa7, 0x21, 0x3b, 0x6c, 0x8f, 0x8c, + 0xd3, 0x57, 0x7f, 0x7e, 0x3d, 0x1d, 0xcb, 0xb8, 0x88, 0xe6, 0x53, 0x27, 0x50, 0xa9, 0x1b, 0x28, + 0x4a, 0x15, 0xd5, 0xaf, 0x31, 0x85, 0x57, 0x6e, 0xb1, 0x98, 0x21, 0x39, 0x5e, 0x10, 0x78, 0x61, + 0x98, 0x23, 0x91, 0xdf, 0x10, 0x8e, 0xbe, 0x31, 0xe8, 0x97, 0xe0, 0x4b, 0xcc, 0xaf, 0xe3, 0x00, + 0xf9, 0x09, 0xec, 0x94, 0x83, 0xf2, 0xc7, 0x4e, 0xf3, 0x63, 0x3a, 0x5b, 0x1b, 0x32, 0x9f, 0xdc, + 0x2d, 0xd7, 0xad, 0x7b, 0xd0, 0x6d, 0xc6, 0xe1, 0x07, 0x1b, 0xcd, 0x9d, 0x4d, 0x98, 0xe6, 0xbf, + 0x3e, 0x69, 0xc4, 0xe9, 0xf9, 0x8f, 0xa5, 0xc5, 0x6e, 0x97, 0x16, 0xfb, 0xbd, 0xb4, 0xd8, 0xf7, + 0x95, 0xd5, 0xba, 0x5d, 0x59, 0xad, 0x9f, 0x2b, 0xab, 0xf5, 0xf1, 0xc5, 0xbd, 0xb3, 0x05, 0x2a, + 0xc4, 0xc0, 0x6d, 0xb8, 0xd3, 0xbd, 0xea, 0xdc, 0xc7, 0x7f, 0x03, 0x00, 0x00, 0xff, 0xff, 0xc0, + 0x24, 0x11, 0x66, 0x66, 0x03, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -571,7 +570,7 @@ func NewTestServiceClient(cc grpc1.ClientConn) TestServiceClient { func (c *testServiceClient) Echo(ctx context.Context, in *EchoRequest, opts ...grpc.CallOption) (*EchoResponse, error) { out := new(EchoResponse) - err := c.cc.Invoke(ctx, "/cosmos_sdk.codec.v1.TestService/Echo", in, out, opts...) + err := c.cc.Invoke(ctx, "/testdata.TestService/Echo", in, out, opts...) if err != nil { return nil, err } @@ -580,7 +579,7 @@ func (c *testServiceClient) Echo(ctx context.Context, in *EchoRequest, opts ...g func (c *testServiceClient) SayHello(ctx context.Context, in *SayHelloRequest, opts ...grpc.CallOption) (*SayHelloResponse, error) { out := new(SayHelloResponse) - err := c.cc.Invoke(ctx, "/cosmos_sdk.codec.v1.TestService/SayHello", in, out, opts...) + err := c.cc.Invoke(ctx, "/testdata.TestService/SayHello", in, out, opts...) if err != nil { return nil, err } @@ -618,7 +617,7 @@ func _TestService_Echo_Handler(srv interface{}, ctx context.Context, dec func(in } info := &grpc.UnaryServerInfo{ Server: srv, - FullMethod: "/cosmos_sdk.codec.v1.TestService/Echo", + FullMethod: "/testdata.TestService/Echo", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(TestServiceServer).Echo(ctx, req.(*EchoRequest)) @@ -636,7 +635,7 @@ func _TestService_SayHello_Handler(srv interface{}, ctx context.Context, dec fun } info := &grpc.UnaryServerInfo{ Server: srv, - FullMethod: "/cosmos_sdk.codec.v1.TestService/SayHello", + FullMethod: "/testdata.TestService/SayHello", } handler := func(ctx context.Context, req interface{}) (interface{}, error) { return srv.(TestServiceServer).SayHello(ctx, req.(*SayHelloRequest)) @@ -645,7 +644,7 @@ func _TestService_SayHello_Handler(srv interface{}, ctx context.Context, dec fun } var _TestService_serviceDesc = grpc.ServiceDesc{ - ServiceName: "cosmos_sdk.codec.v1.TestService", + ServiceName: "testdata.TestService", HandlerType: (*TestServiceServer)(nil), Methods: []grpc.MethodDesc{ { diff --git a/codec/testdata/proto.proto b/codec/testdata/proto.proto index f724c90b1116..a437f151e3e7 100644 --- a/codec/testdata/proto.proto +++ b/codec/testdata/proto.proto @@ -1,5 +1,5 @@ syntax = "proto3"; -package cosmos_sdk.codec.v1; +package testdata; import "google/protobuf/any.proto"; import "gogoproto/gogo.proto"; diff --git a/types/tx/tx.pb.go b/types/tx/tx.pb.go index 031697ff77ef..35b8564c6d43 100644 --- a/types/tx/tx.pb.go +++ b/types/tx/tx.pb.go @@ -162,6 +162,7 @@ func (m *TxRaw) GetSignatures() [][]byte { return nil } +// SignDoc is the type used for generating sign bytes for SIGN_MODE_DIRECT type SignDoc struct { // body_bytes is protobuf serialization of a TxBody that matches the representation in TxRaw. BodyBytes []byte `protobuf:"bytes,1,opt,name=body_bytes,json=bodyBytes,proto3" json:"body_bytes,omitempty"` diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index 961b0b48892c..9975533b3105 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -3,14 +3,14 @@ package direct_test import ( "testing" + "github.com/cosmos/cosmos-sdk/x/auth/tx" + "github.com/cosmos/cosmos-sdk/x/auth/signing/direct" "github.com/cosmos/cosmos-sdk/codec/testdata" "github.com/cosmos/cosmos-sdk/codec" - "github.com/cosmos/cosmos-sdk/types/tx/generator" - signingtypes "github.com/cosmos/cosmos-sdk/types/tx/signing" "github.com/stretchr/testify/require" @@ -30,7 +30,7 @@ func TestDirectModeHandler(t *testing.T) { marshaler := codec.NewProtoCodec(interfaceRegistry) pubKeyCdc := std.DefaultPublicKeyCodec{} - txGen := generator.New(marshaler, pubKeyCdc, generator.DefaultSignModeHandler()) + txGen := tx.New(marshaler, pubKeyCdc, tx.DefaultSignModeHandler()) txBuilder := txGen.NewTxBuilder() memo := "sometestmemo" diff --git a/types/tx/generator/builder.go b/x/auth/tx/builder.go similarity index 99% rename from types/tx/generator/builder.go rename to x/auth/tx/builder.go index f5c708eb700d..538585c440f1 100644 --- a/types/tx/generator/builder.go +++ b/x/auth/tx/builder.go @@ -1,4 +1,4 @@ -package generator +package tx import ( "fmt" diff --git a/types/tx/generator/builder_test.go b/x/auth/tx/builder_test.go similarity index 99% rename from types/tx/generator/builder_test.go rename to x/auth/tx/builder_test.go index d30229e2a89f..6f47d9557282 100644 --- a/types/tx/generator/builder_test.go +++ b/x/auth/tx/builder_test.go @@ -1,4 +1,4 @@ -package generator +package tx import ( "testing" diff --git a/types/tx/generator/decoder.go b/x/auth/tx/decoder.go similarity index 99% rename from types/tx/generator/decoder.go rename to x/auth/tx/decoder.go index df31928ae1f6..8ce3b06fa66e 100644 --- a/types/tx/generator/decoder.go +++ b/x/auth/tx/decoder.go @@ -1,4 +1,4 @@ -package generator +package tx import ( "github.com/tendermint/tendermint/crypto" diff --git a/types/tx/generator/encoder.go b/x/auth/tx/encoder.go similarity index 98% rename from types/tx/generator/encoder.go rename to x/auth/tx/encoder.go index 5fea3692d403..d8419d98c0e4 100644 --- a/types/tx/generator/encoder.go +++ b/x/auth/tx/encoder.go @@ -1,4 +1,4 @@ -package generator +package tx import ( "fmt" diff --git a/types/tx/generator/generator.go b/x/auth/tx/generator.go similarity index 98% rename from types/tx/generator/generator.go rename to x/auth/tx/generator.go index a215a707786b..88465c8f037c 100644 --- a/types/tx/generator/generator.go +++ b/x/auth/tx/generator.go @@ -1,4 +1,4 @@ -package generator +package tx import ( "github.com/cosmos/cosmos-sdk/client" diff --git a/types/tx/generator/generator_test.go b/x/auth/tx/generator_test.go similarity index 97% rename from types/tx/generator/generator_test.go rename to x/auth/tx/generator_test.go index 9c064c775c0b..83bd113e2b09 100644 --- a/types/tx/generator/generator_test.go +++ b/x/auth/tx/generator_test.go @@ -1,4 +1,4 @@ -package generator +package tx import ( "testing" diff --git a/types/tx/generator/mode_handler.go b/x/auth/tx/mode_handler.go similarity index 97% rename from types/tx/generator/mode_handler.go rename to x/auth/tx/mode_handler.go index 92f0e03c576b..ef45d90dbfa0 100644 --- a/types/tx/generator/mode_handler.go +++ b/x/auth/tx/mode_handler.go @@ -1,4 +1,4 @@ -package generator +package tx import ( signing2 "github.com/cosmos/cosmos-sdk/types/tx/signing" diff --git a/types/tx/generator/sigs.go b/x/auth/tx/sigs.go similarity index 99% rename from types/tx/generator/sigs.go rename to x/auth/tx/sigs.go index d65a9670cf8b..852aca667116 100644 --- a/types/tx/generator/sigs.go +++ b/x/auth/tx/sigs.go @@ -1,4 +1,4 @@ -package generator +package tx import ( "fmt" From 28a35363f636aca0d878ed8ab7ff7cedd64dce66 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Tue, 30 Jun 2020 14:56:07 -0400 Subject: [PATCH 29/43] WIP on test coverage --- client/testutil/suite.go | 64 +++++++++++++++++++++++++++++++--------- 1 file changed, 50 insertions(+), 14 deletions(-) diff --git a/client/testutil/suite.go b/client/testutil/suite.go index 560e45e35cb4..989ca3f9ddd8 100644 --- a/client/testutil/suite.go +++ b/client/testutil/suite.go @@ -2,6 +2,7 @@ package testutil import ( "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/cosmos/cosmos-sdk/crypto/types/multisig" "github.com/cosmos/cosmos-sdk/x/auth/signing" authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" "github.com/stretchr/testify/suite" @@ -79,52 +80,87 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetMsgs() { func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { privKey, pubkey, addr := authtypes.KeyTestPubAddr() + privKey2, pubkey2, _ := authtypes.KeyTestPubAddr() + multisigPk := multisig.NewPubKeyMultisigThreshold(2, []crypto.PubKey{pubkey, pubkey2}) txBuilder := s.TxGenerator.NewTxBuilder() // set test msg msg := testdata.NewTestMsg(addr) - err := txBuilder.SetMsgs(msg) + msg2 := testdata.NewTestMsg(sdk.AccAddress(multisigPk.Address())) + err := txBuilder.SetMsgs(msg, msg2) s.Require().NoError(err) // check that validation fails s.Require().Error(txBuilder.GetTx().ValidateBasic()) - // set SignatureV2 without actual signature bytes signModeHandler := s.TxGenerator.SignModeHandler() s.Require().Contains(signModeHandler.Modes(), signModeHandler.DefaultMode()) - sigData := &signingtypes.SingleSignatureData{SignMode: signModeHandler.DefaultMode()} - sig := signingtypes.SignatureV2{PubKey: pubkey, Data: sigData} - err = txBuilder.SetSignatures(sig) + + // set SignatureV2 without actual signature bytes + sigData1 := &signingtypes.SingleSignatureData{SignMode: signModeHandler.DefaultMode()} + sig1 := signingtypes.SignatureV2{PubKey: pubkey, Data: sigData1} + + msigData := multisig.NewMultisig(2) + multisig.AddSignature(msigData, &signingtypes.SingleSignatureData{SignMode: signModeHandler.DefaultMode()}, 0) + multisig.AddSignature(msigData, &signingtypes.SingleSignatureData{SignMode: signModeHandler.DefaultMode()}, 1) + msig := signingtypes.SignatureV2{PubKey: multisigPk, Data: msigData} + + // fail validation without required signers + err = txBuilder.SetSignatures(sig1) s.Require().NoError(err) sigTx := txBuilder.GetTx() - s.Require().Equal([][]byte{nil}, sigTx.GetSignatures()) + s.Require().Error(sigTx.ValidateBasic()) + + err = txBuilder.SetSignatures(sig1, msig) + s.Require().NoError(err) + sigTx = txBuilder.GetTx() + s.Require().Len(sigTx.GetSignatures(), 2) sigsV2, err := sigTx.GetSignaturesV2() s.Require().NoError(err) - s.Require().Equal([]signingtypes.SignatureV2{sig}, sigsV2) + s.Require().Equal([]signingtypes.SignatureV2{sig1, msig}, sigsV2) s.Require().Equal([]sdk.AccAddress{addr}, sigTx.GetSigners()) s.Require().NoError(sigTx.ValidateBasic()) // sign transaction - signBytes, err := signModeHandler.GetSignBytes(signModeHandler.DefaultMode(), signing.SignerData{ + signerData := signing.SignerData{ ChainID: "test", AccountNumber: 1, AccountSequence: 2, - }, sigTx) + } + signBytes, err := signModeHandler.GetSignBytes(signModeHandler.DefaultMode(), signerData, sigTx) s.Require().NoError(err) sigBz, err := privKey.Sign(signBytes) s.Require().NoError(err) + signerData = signing.SignerData{ + ChainID: "test", + AccountNumber: 3, + AccountSequence: 4, + } + mSignBytes, err := signModeHandler.GetSignBytes(signModeHandler.DefaultMode(), signerData, sigTx) + s.Require().NoError(err) + mSigBz1, err := privKey.Sign(mSignBytes) + s.Require().NoError(err) + mSigBz2, err := privKey2.Sign(mSignBytes) + s.Require().NoError(err) + msigData = multisig.NewMultisig(2) + multisig.AddSignature(msigData, &signingtypes.SingleSignatureData{ + SignMode: signModeHandler.DefaultMode(), Signature: mSigBz1}, 0) + multisig.AddSignature(msigData, &signingtypes.SingleSignatureData{ + SignMode: signModeHandler.DefaultMode(), Signature: mSigBz2}, 0) + // set signature - sigData.Signature = sigBz - sig = signingtypes.SignatureV2{PubKey: pubkey, Data: sigData} - err = txBuilder.SetSignatures(sig) + sigData1.Signature = sigBz + sig1 = signingtypes.SignatureV2{PubKey: pubkey, Data: sigData1} + msig = signingtypes.SignatureV2{PubKey: multisigPk, Data: msigData} + err = txBuilder.SetSignatures(sig1, msig) s.Require().NoError(err) sigTx = txBuilder.GetTx() - s.Require().Equal([][]byte{sigBz}, sigTx.GetSignatures()) sigsV2, err = sigTx.GetSignaturesV2() s.Require().NoError(err) - s.Require().Equal([]signingtypes.SignatureV2{sig}, sigsV2) + s.Require().Len(sigTx.GetSignatures(), 2) + s.Require().Equal([]signingtypes.SignatureV2{sig1, msig}, sigsV2) s.Require().Equal([]sdk.AccAddress{addr}, sigTx.GetSigners()) s.Require().NoError(sigTx.ValidateBasic()) } From 81bc3d06806546bbc943cfac17819e5b7ce41070 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Wed, 1 Jul 2020 10:11:23 -0400 Subject: [PATCH 30/43] WIP on test coverage --- baseapp/baseapp_test.go | 2 +- client/context_test.go | 6 ++-- client/testutil/suite.go | 74 +++++++++++++++++++++++++++++++++++---- codec/types/types_test.go | 4 +-- 4 files changed, 74 insertions(+), 12 deletions(-) diff --git a/baseapp/baseapp_test.go b/baseapp/baseapp_test.go index 73307e69a0a7..056a51ddc997 100644 --- a/baseapp/baseapp_test.go +++ b/baseapp/baseapp_test.go @@ -1555,7 +1555,7 @@ func TestGRPCQuery(t *testing.T) { reqQuery := abci.RequestQuery{ Data: reqBz, - Path: "/cosmos_sdk.codec.v1.TestService/SayHello", + Path: "/testdata.TestService/SayHello", } resQuery := app.Query(reqQuery) diff --git a/client/context_test.go b/client/context_test.go index e5598cbcd80e..cbe7f5c8117f 100644 --- a/client/context_test.go +++ b/client/context_test.go @@ -110,7 +110,7 @@ func TestContext_PrintOutput(t *testing.T) { err = ctx.PrintOutput(hasAnimal) require.NoError(t, err) require.Equal(t, - `{"animal":{"@type":"/cosmos_sdk.codec.v1.Dog","size":"big","name":"Spot"},"x":"10"} + `{"animal":{"@type":"/testdata.Dog","size":"big","name":"Spot"},"x":"10"} `, string(buf.Bytes())) // json indent @@ -123,7 +123,7 @@ func TestContext_PrintOutput(t *testing.T) { require.Equal(t, `{ "animal": { - "@type": "/cosmos_sdk.codec.v1.Dog", + "@type": "/testdata.Dog", "name": "Spot", "size": "big" }, @@ -140,7 +140,7 @@ func TestContext_PrintOutput(t *testing.T) { require.NoError(t, err) require.Equal(t, `animal: - '@type': /cosmos_sdk.codec.v1.Dog + '@type': /testdata.Dog name: Spot size: big x: "10" diff --git a/client/testutil/suite.go b/client/testutil/suite.go index 989ca3f9ddd8..c85dcf51b346 100644 --- a/client/testutil/suite.go +++ b/client/testutil/suite.go @@ -1,6 +1,8 @@ package testutil import ( + "bytes" + "github.com/cosmos/cosmos-sdk/codec/testdata" "github.com/cosmos/cosmos-sdk/crypto/types/multisig" "github.com/cosmos/cosmos-sdk/x/auth/signing" @@ -87,7 +89,8 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { // set test msg msg := testdata.NewTestMsg(addr) - msg2 := testdata.NewTestMsg(sdk.AccAddress(multisigPk.Address())) + msigAddr := sdk.AccAddress(multisigPk.Address()) + msg2 := testdata.NewTestMsg(msigAddr) err := txBuilder.SetMsgs(msg, msg2) s.Require().NoError(err) @@ -118,8 +121,10 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { s.Require().Len(sigTx.GetSignatures(), 2) sigsV2, err := sigTx.GetSignaturesV2() s.Require().NoError(err) - s.Require().Equal([]signingtypes.SignatureV2{sig1, msig}, sigsV2) - s.Require().Equal([]sdk.AccAddress{addr}, sigTx.GetSigners()) + s.Require().Len(sigsV2, 2) + s.Require().True(sigEquals(sig1, sigsV2[0])) + s.Require().True(sigEquals(msig, sigsV2[1])) + s.Require().Equal([]sdk.AccAddress{addr, msigAddr}, sigTx.GetSigners()) s.Require().NoError(sigTx.ValidateBasic()) // sign transaction @@ -157,14 +162,71 @@ func (s *TxGeneratorTestSuite) TestTxBuilderSetSignatures() { err = txBuilder.SetSignatures(sig1, msig) s.Require().NoError(err) sigTx = txBuilder.GetTx() + s.Require().Len(sigTx.GetSignatures(), 2) sigsV2, err = sigTx.GetSignaturesV2() s.Require().NoError(err) - s.Require().Len(sigTx.GetSignatures(), 2) - s.Require().Equal([]signingtypes.SignatureV2{sig1, msig}, sigsV2) - s.Require().Equal([]sdk.AccAddress{addr}, sigTx.GetSigners()) + s.Require().Len(sigsV2, 2) + s.Require().True(sigEquals(sig1, sigsV2[0])) + s.Require().True(sigEquals(msig, sigsV2[1])) + s.Require().Equal([]sdk.AccAddress{addr, msigAddr}, sigTx.GetSigners()) s.Require().NoError(sigTx.ValidateBasic()) } +func sigEquals(sig1, sig2 signingtypes.SignatureV2) bool { + if !sig1.PubKey.Equals(sig2.PubKey) { + return false + } + + if sig1.Data == nil && sig2.Data == nil { + return true + } + + return sigDataEquals(sig1.Data, sig2.Data) +} + +func sigDataEquals(data1, data2 signingtypes.SignatureData) bool { + switch data1 := data1.(type) { + case *signingtypes.SingleSignatureData: + data2, ok := data2.(*signingtypes.SingleSignatureData) + if !ok { + return false + } + + if data1.SignMode != data2.SignMode { + return false + } + + return bytes.Equal(data1.Signature, data2.Signature) + case *signingtypes.MultiSignatureData: + data2, ok := data2.(*signingtypes.MultiSignatureData) + if !ok { + return false + } + + if data1.BitArray.ExtraBitsStored != data2.BitArray.ExtraBitsStored { + return false + } + + if !bytes.Equal(data1.BitArray.Elems, data2.BitArray.Elems) { + return false + } + + if len(data1.Signatures) != len(data2.Signatures) { + return false + } + + for i, s := range data1.Signatures { + if !sigDataEquals(s, data2.Signatures[i]) { + return false + } + } + + return true + default: + return false + } +} + func (s *TxGeneratorTestSuite) TestTxEncodeDecode() { _, pubkey, addr := authtypes.KeyTestPubAddr() feeAmount := sdk.Coins{sdk.NewInt64Coin("atom", 150)} diff --git a/codec/types/types_test.go b/codec/types/types_test.go index 2089fc4c54a8..e547ca7a00fd 100644 --- a/codec/types/types_test.go +++ b/codec/types/types_test.go @@ -124,7 +124,7 @@ func TestAny_ProtoJSON(t *testing.T) { jm := &jsonpb.Marshaler{} json, err := jm.MarshalToString(any) require.NoError(t, err) - require.Equal(t, "{\"@type\":\"/cosmos_sdk.codec.v1.Dog\",\"name\":\"Spot\"}", json) + require.Equal(t, "{\"@type\":\"/testdata.Dog\",\"name\":\"Spot\"}", json) registry := testdata.NewTestInterfaceRegistry() jum := &jsonpb.Unmarshaler{} @@ -143,7 +143,7 @@ func TestAny_ProtoJSON(t *testing.T) { require.NoError(t, err) json, err = jm.MarshalToString(ha) require.NoError(t, err) - require.Equal(t, "{\"animal\":{\"@type\":\"/cosmos_sdk.codec.v1.Dog\",\"name\":\"Spot\"}}", json) + require.Equal(t, "{\"animal\":{\"@type\":\"/testdata.Dog\",\"name\":\"Spot\"}}", json) require.NoError(t, err) var ha2 testdata.HasAnimal From 7817dc4ffc0a1bd66c292c2060526db60e746331 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Wed, 1 Jul 2020 14:40:55 -0400 Subject: [PATCH 31/43] proto-gen --- codec/testdata/proto.pb.go | 238 ++++++++++++++++++++++++++++++++----- 1 file changed, 211 insertions(+), 27 deletions(-) diff --git a/codec/testdata/proto.pb.go b/codec/testdata/proto.pb.go index b10536e732e2..e8baad718a13 100644 --- a/codec/testdata/proto.pb.go +++ b/codec/testdata/proto.pb.go @@ -7,6 +7,8 @@ import ( context "context" fmt "fmt" types "github.com/cosmos/cosmos-sdk/codec/types" + github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" + _ "github.com/gogo/protobuf/gogoproto" grpc1 "github.com/gogo/protobuf/grpc" proto "github.com/gogo/protobuf/proto" grpc "google.golang.org/grpc" @@ -448,6 +450,51 @@ func (m *SayHelloResponse) GetGreeting() string { return "" } +// msg type for testing +type TestMsg struct { + Signers []github_com_cosmos_cosmos_sdk_types.AccAddress `protobuf:"bytes,1,rep,name=signers,proto3,casttype=github.com/cosmos/cosmos-sdk/types.AccAddress" json:"signers,omitempty"` +} + +func (m *TestMsg) Reset() { *m = TestMsg{} } +func (m *TestMsg) String() string { return proto.CompactTextString(m) } +func (*TestMsg) ProtoMessage() {} +func (*TestMsg) Descriptor() ([]byte, []int) { + return fileDescriptor_2fcc84b9998d60d8, []int{9} +} +func (m *TestMsg) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TestMsg) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_TestMsg.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *TestMsg) XXX_Merge(src proto.Message) { + xxx_messageInfo_TestMsg.Merge(m, src) +} +func (m *TestMsg) XXX_Size() int { + return m.Size() +} +func (m *TestMsg) XXX_DiscardUnknown() { + xxx_messageInfo_TestMsg.DiscardUnknown(m) +} + +var xxx_messageInfo_TestMsg proto.InternalMessageInfo + +func (m *TestMsg) GetSigners() []github_com_cosmos_cosmos_sdk_types.AccAddress { + if m != nil { + return m.Signers + } + return nil +} + func init() { proto.RegisterType((*Dog)(nil), "testdata.Dog") proto.RegisterType((*Cat)(nil), "testdata.Cat") @@ -458,38 +505,43 @@ func init() { proto.RegisterType((*EchoResponse)(nil), "testdata.EchoResponse") proto.RegisterType((*SayHelloRequest)(nil), "testdata.SayHelloRequest") proto.RegisterType((*SayHelloResponse)(nil), "testdata.SayHelloResponse") + proto.RegisterType((*TestMsg)(nil), "testdata.TestMsg") } func init() { proto.RegisterFile("proto.proto", fileDescriptor_2fcc84b9998d60d8) } var fileDescriptor_2fcc84b9998d60d8 = []byte{ - // 414 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0xb1, 0x8e, 0xd3, 0x40, - 0x10, 0x86, 0xb3, 0xe4, 0xee, 0x48, 0xc6, 0x16, 0x87, 0x56, 0x07, 0xca, 0xb9, 0xb0, 0x90, 0x25, - 0xc4, 0x49, 0x70, 0x6b, 0xe9, 0x4e, 0xd7, 0xd0, 0x85, 0x10, 0x91, 0x86, 0xc6, 0xa1, 0xa2, 0x41, - 0x1b, 0x67, 0xb0, 0xad, 0xd8, 0xde, 0xe0, 0xdd, 0x44, 0x09, 0x2f, 0x40, 0xcb, 0x63, 0x51, 0xa6, - 0xa4, 0x44, 0xc9, 0x8b, 0x20, 0xef, 0xda, 0x71, 0x14, 0x21, 0x94, 0xc6, 0x9e, 0x19, 0xff, 0xff, - 0xb7, 0xe3, 0x99, 0x05, 0x6b, 0x5e, 0x08, 0x25, 0x98, 0x7e, 0xd2, 0x8e, 0x42, 0xa9, 0xa6, 0x5c, - 0x71, 0xe7, 0x3a, 0x12, 0x22, 0x4a, 0xd1, 0xd7, 0xf5, 0xc9, 0xe2, 0xab, 0xcf, 0xf3, 0xb5, 0x11, - 0x79, 0xb7, 0xd0, 0x7e, 0x2f, 0x22, 0x4a, 0xe1, 0x4c, 0x26, 0xdf, 0xb1, 0x47, 0x5e, 0x90, 0x9b, - 0x6e, 0xa0, 0xe3, 0xb2, 0x96, 0xf3, 0x0c, 0x7b, 0x8f, 0x4c, 0xad, 0x8c, 0xbd, 0x07, 0x68, 0x0f, - 0xb8, 0xa2, 0x3d, 0x78, 0x9c, 0x89, 0x3c, 0x99, 0x61, 0x51, 0x39, 0xea, 0x94, 0x5e, 0xc1, 0x79, - 0x9a, 0x2c, 0x51, 0x6a, 0xd7, 0x79, 0x60, 0x12, 0xef, 0x03, 0x74, 0x47, 0x5c, 0xf6, 0xf3, 0x24, - 0xe3, 0x29, 0x7d, 0x03, 0x17, 0x5c, 0x47, 0xda, 0x6b, 0xdd, 0x5d, 0x31, 0xd3, 0x1e, 0xab, 0xdb, - 0x63, 0xfd, 0x7c, 0x1d, 0x54, 0x1a, 0x6a, 0x03, 0x59, 0x69, 0x58, 0x3b, 0x20, 0x2b, 0x6f, 0x00, - 0xf6, 0x88, 0xcb, 0x86, 0x75, 0x0f, 0x10, 0x73, 0xf9, 0xe5, 0x04, 0x5e, 0x37, 0xae, 0x4d, 0xde, - 0x47, 0xb8, 0x34, 0x90, 0x86, 0xf3, 0x16, 0x9e, 0x94, 0x9c, 0x13, 0x59, 0x76, 0x7c, 0xe0, 0xf5, - 0x5e, 0x81, 0x35, 0x0c, 0x63, 0x11, 0xe0, 0xb7, 0x05, 0x4a, 0x33, 0x1b, 0x94, 0x92, 0x47, 0xb8, - 0x9f, 0x8d, 0x49, 0xbd, 0x1b, 0xb0, 0x8d, 0x50, 0xce, 0x45, 0x2e, 0xf1, 0x3f, 0xca, 0x97, 0x70, - 0x39, 0xe6, 0xeb, 0x11, 0xa6, 0xe9, 0x1e, 0x5b, 0x6f, 0x83, 0x1c, 0x6c, 0x83, 0xc1, 0xd3, 0x46, - 0x56, 0x41, 0x1d, 0xe8, 0x44, 0x05, 0xa2, 0x4a, 0xf2, 0xa8, 0xd2, 0xee, 0xf3, 0xbb, 0x1f, 0x04, - 0xac, 0x4f, 0x28, 0xd5, 0x18, 0x8b, 0x65, 0x12, 0x22, 0x7d, 0x80, 0xb3, 0xb2, 0x21, 0xfa, 0x8c, - 0xd5, 0x57, 0x85, 0x1d, 0xfc, 0x89, 0xf3, 0xfc, 0xb8, 0x5c, 0x1d, 0xd1, 0x87, 0x4e, 0x7d, 0x2c, - 0xbd, 0x6e, 0x34, 0x47, 0x1d, 0x3b, 0xce, 0xbf, 0x3e, 0x19, 0xc4, 0xbb, 0xe1, 0xaf, 0xad, 0x4b, - 0x36, 0x5b, 0x97, 0xfc, 0xd9, 0xba, 0xe4, 0xe7, 0xce, 0x6d, 0x6d, 0x76, 0x6e, 0xeb, 0xf7, 0xce, - 0x6d, 0x7d, 0x7e, 0x1d, 0x25, 0x2a, 0x5e, 0x4c, 0x58, 0x28, 0x32, 0x3f, 0x14, 0x32, 0x13, 0xb2, - 0x7a, 0xdd, 0xca, 0xe9, 0xcc, 0x0f, 0xc5, 0x14, 0x43, 0xbf, 0xe6, 0x4e, 0x2e, 0xf4, 0x5a, 0xee, - 0xff, 0x06, 0x00, 0x00, 0xff, 0xff, 0x38, 0x43, 0xe8, 0xad, 0xf8, 0x02, 0x00, 0x00, + // 471 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0x4f, 0x6f, 0xd3, 0x4c, + 0x10, 0xc6, 0xb3, 0x6f, 0xda, 0x26, 0x99, 0x58, 0x6f, 0xd1, 0x2a, 0xa0, 0xd4, 0x07, 0x53, 0x59, + 0x42, 0x44, 0x82, 0xd8, 0xa2, 0x55, 0x2f, 0xdc, 0xdc, 0x52, 0x11, 0x09, 0xf5, 0xe2, 0x22, 0x0e, + 0x5c, 0xd0, 0xc6, 0x1e, 0xd6, 0x56, 0x6d, 0x6f, 0xf0, 0x38, 0x55, 0xc3, 0x17, 0xe0, 0xca, 0xc7, + 0xe2, 0xd8, 0x23, 0x27, 0x84, 0x92, 0x6f, 0xc1, 0x09, 0xd9, 0x6b, 0x27, 0x51, 0x85, 0xaa, 0x5e, + 0xec, 0x99, 0xf1, 0xf3, 0xfc, 0x34, 0x7f, 0x0c, 0xfd, 0x59, 0xae, 0x0a, 0xe5, 0x54, 0x4f, 0xde, + 0x2d, 0x90, 0x8a, 0x50, 0x14, 0xc2, 0x3c, 0x90, 0x4a, 0xc9, 0x04, 0xdd, 0xaa, 0x3e, 0x9d, 0x7f, + 0x76, 0x45, 0xb6, 0xd0, 0x22, 0x73, 0x20, 0x95, 0x54, 0x55, 0xe8, 0x96, 0x91, 0xae, 0xda, 0x63, + 0x68, 0xbf, 0x51, 0x92, 0x73, 0xd8, 0xa1, 0xf8, 0x2b, 0x0e, 0xd9, 0x21, 0x1b, 0xf5, 0xfc, 0x2a, + 0x2e, 0x6b, 0x99, 0x48, 0x71, 0xf8, 0x9f, 0xae, 0x95, 0xb1, 0x7d, 0x02, 0xed, 0x33, 0x51, 0xf0, + 0x21, 0x74, 0x52, 0x95, 0xc5, 0x57, 0x98, 0xd7, 0x8e, 0x26, 0xe5, 0x03, 0xd8, 0x4d, 0xe2, 0x6b, + 0xa4, 0xca, 0xb5, 0xeb, 0xeb, 0xc4, 0x7e, 0x0b, 0xbd, 0x89, 0x20, 0x2f, 0x8b, 0x53, 0x91, 0xf0, + 0x97, 0xb0, 0x27, 0xaa, 0xa8, 0xf2, 0xf6, 0x8f, 0x06, 0x8e, 0x6e, 0xda, 0x69, 0x9a, 0x76, 0xbc, + 0x6c, 0xe1, 0xd7, 0x1a, 0x6e, 0x00, 0xbb, 0xa9, 0x60, 0x6d, 0x9f, 0xdd, 0xd8, 0x67, 0x60, 0x4c, + 0x04, 0x6d, 0x58, 0xc7, 0x00, 0x91, 0xa0, 0x4f, 0x0f, 0xe0, 0xf5, 0xa2, 0xc6, 0x64, 0x5f, 0xc0, + 0xbe, 0x86, 0x6c, 0x38, 0xaf, 0xe1, 0xff, 0x92, 0xf3, 0x40, 0x96, 0x11, 0x6d, 0x79, 0xed, 0xe7, + 0xd0, 0x3f, 0x0f, 0x22, 0xe5, 0xe3, 0x97, 0x39, 0x92, 0xde, 0x0d, 0x12, 0x09, 0x89, 0xeb, 0xdd, + 0xe8, 0xd4, 0x1e, 0x81, 0xa1, 0x85, 0x34, 0x53, 0x19, 0xe1, 0x3d, 0xca, 0x67, 0xb0, 0x7f, 0x29, + 0x16, 0x13, 0x4c, 0x92, 0x35, 0xb6, 0xb9, 0x06, 0xdb, 0xba, 0x86, 0x03, 0x8f, 0x36, 0xb2, 0x1a, + 0x6a, 0x42, 0x57, 0xe6, 0x88, 0x45, 0x9c, 0xc9, 0x5a, 0xbb, 0xce, 0xed, 0x0f, 0xd0, 0x79, 0x8f, + 0x54, 0x5c, 0x90, 0xe4, 0xef, 0xa0, 0x43, 0xb1, 0xcc, 0x30, 0xa7, 0x21, 0x3b, 0x6c, 0x8f, 0x8c, + 0xd3, 0x57, 0x7f, 0x7e, 0x3d, 0x1d, 0xcb, 0xb8, 0x88, 0xe6, 0x53, 0x27, 0x50, 0xa9, 0x1b, 0x28, + 0x4a, 0x15, 0xd5, 0xaf, 0x31, 0x85, 0x57, 0x6e, 0xb1, 0x98, 0x21, 0x39, 0x5e, 0x10, 0x78, 0x61, + 0x98, 0x23, 0x91, 0xdf, 0x10, 0x8e, 0xbe, 0x31, 0xe8, 0x97, 0xe0, 0x4b, 0xcc, 0xaf, 0xe3, 0x00, + 0xf9, 0x09, 0xec, 0x94, 0x83, 0xf2, 0xc7, 0x4e, 0xf3, 0x63, 0x3a, 0x5b, 0x1b, 0x32, 0x9f, 0xdc, + 0x2d, 0xd7, 0xad, 0x7b, 0xd0, 0x6d, 0xc6, 0xe1, 0x07, 0x1b, 0xcd, 0x9d, 0x4d, 0x98, 0xe6, 0xbf, + 0x3e, 0x69, 0xc4, 0xe9, 0xf9, 0x8f, 0xa5, 0xc5, 0x6e, 0x97, 0x16, 0xfb, 0xbd, 0xb4, 0xd8, 0xf7, + 0x95, 0xd5, 0xba, 0x5d, 0x59, 0xad, 0x9f, 0x2b, 0xab, 0xf5, 0xf1, 0xc5, 0xbd, 0xb3, 0x05, 0x2a, + 0xc4, 0xc0, 0x6d, 0xb8, 0xd3, 0xbd, 0xea, 0xdc, 0xc7, 0x7f, 0x03, 0x00, 0x00, 0xff, 0xff, 0xc0, + 0x24, 0x11, 0x66, 0x66, 0x03, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -910,6 +962,38 @@ func (m *SayHelloResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } +func (m *TestMsg) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *TestMsg) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TestMsg) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Signers) > 0 { + for iNdEx := len(m.Signers) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Signers[iNdEx]) + copy(dAtA[i:], m.Signers[iNdEx]) + i = encodeVarintProto(dAtA, i, uint64(len(m.Signers[iNdEx]))) + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + func encodeVarintProto(dAtA []byte, offset int, v uint64) int { offset -= sovProto(v) base := offset @@ -1048,6 +1132,21 @@ func (m *SayHelloResponse) Size() (n int) { return n } +func (m *TestMsg) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Signers) > 0 { + for _, b := range m.Signers { + l = len(b) + n += 1 + l + sovProto(uint64(l)) + } + } + return n +} + func sovProto(x uint64) (n int) { return (math_bits.Len64(x|1) + 6) / 7 } @@ -1901,6 +2000,91 @@ func (m *SayHelloResponse) Unmarshal(dAtA []byte) error { } return nil } +func (m *TestMsg) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowProto + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: TestMsg: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: TestMsg: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Signers", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowProto + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthProto + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthProto + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Signers = append(m.Signers, make([]byte, postIndex-iNdEx)) + copy(m.Signers[len(m.Signers)-1], dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipProto(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthProto + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthProto + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func skipProto(dAtA []byte) (n int, err error) { l := len(dAtA) iNdEx := 0 From 09866449d7fce7ef861e494474aafbb2c1c9a248 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Wed, 1 Jul 2020 15:57:18 -0400 Subject: [PATCH 32/43] Fix CompactBitArray.Size() bug --- crypto/types/compact_bit_array.go | 18 ++--- crypto/types/crypto.pb.go | 83 +++++++++++++---------- crypto/types/multisig/threshold_pubkey.go | 4 +- proto/cosmos/crypto/crypto.proto | 1 - x/auth/ante/sigverify.go | 2 +- x/auth/client/cli/validate_sigs.go | 2 +- x/auth/types/stdtx.go | 2 +- 7 files changed, 63 insertions(+), 49 deletions(-) diff --git a/crypto/types/compact_bit_array.go b/crypto/types/compact_bit_array.go index f2d68100eec3..7c7188f6abd5 100644 --- a/crypto/types/compact_bit_array.go +++ b/crypto/types/compact_bit_array.go @@ -26,8 +26,8 @@ func NewCompactBitArray(bits int) *CompactBitArray { } } -// Size returns the number of bits in the bitarray -func (bA *CompactBitArray) Size() int { +// Count returns the number of bits in the bitarray +func (bA *CompactBitArray) Count() int { if bA == nil { return 0 } else if bA.ExtraBitsStored == uint32(0) { @@ -38,12 +38,12 @@ func (bA *CompactBitArray) Size() int { } // GetIndex returns the bit at index i within the bit array. -// The behavior is undefined if i >= bA.Size() +// The behavior is undefined if i >= bA.Count() func (bA *CompactBitArray) GetIndex(i int) bool { if bA == nil { return false } - if i >= bA.Size() { + if i >= bA.Count() { return false } @@ -51,13 +51,13 @@ func (bA *CompactBitArray) GetIndex(i int) bool { } // SetIndex sets the bit at index i within the bit array. -// The behavior is undefined if i >= bA.Size() +// The behavior is undefined if i >= bA.Count() func (bA *CompactBitArray) SetIndex(i int, v bool) bool { if bA == nil { return false } - if i >= bA.Size() { + if i >= bA.Count() { return false } @@ -115,7 +115,7 @@ func (bA *CompactBitArray) StringIndented(indent string) string { } lines := []string{} bits := "" - size := bA.Size() + size := bA.Count() for i := 0; i < size; i++ { if bA.GetIndex(i) { bits += "x" @@ -152,7 +152,7 @@ func (bA *CompactBitArray) MarshalJSON() ([]byte, error) { } bits := `"` - size := bA.Size() + size := bA.Count() for i := 0; i < size; i++ { if bA.GetIndex(i) { bits += `x` @@ -204,7 +204,7 @@ func (bA *CompactBitArray) UnmarshalJSON(bz []byte) error { // CompactMarshal is a space efficient encoding for CompactBitArray. // It is not amino compatible. func (bA *CompactBitArray) CompactMarshal() []byte { - size := bA.Size() + size := bA.Count() if size <= 0 { return []byte("null") } diff --git a/crypto/types/crypto.pb.go b/crypto/types/crypto.pb.go index 8fbc185d1190..54455a928ce0 100644 --- a/crypto/types/crypto.pb.go +++ b/crypto/types/crypto.pb.go @@ -299,7 +299,7 @@ func (m *CompactBitArray) XXX_Merge(src proto.Message) { xxx_messageInfo_CompactBitArray.Merge(m, src) } func (m *CompactBitArray) XXX_Size() int { - return xxx_messageInfo_CompactBitArray.Size(m) + return m.Size() } func (m *CompactBitArray) XXX_DiscardUnknown() { xxx_messageInfo_CompactBitArray.DiscardUnknown(m) @@ -331,39 +331,38 @@ func init() { func init() { proto.RegisterFile("cosmos/crypto/crypto.proto", fileDescriptor_5fa415c569c5d31a) } var fileDescriptor_5fa415c569c5d31a = []byte{ - // 500 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x74, 0x92, 0xc1, 0x6e, 0xd3, 0x30, - 0x18, 0xc7, 0xe3, 0x76, 0x65, 0xab, 0xbb, 0xad, 0x60, 0x55, 0x22, 0xab, 0x44, 0x52, 0xe5, 0x80, - 0x0a, 0x12, 0xa9, 0x5a, 0xd4, 0x21, 0x7a, 0x5b, 0xc6, 0x61, 0x52, 0x85, 0x54, 0x65, 0x1c, 0x10, - 0x12, 0xaa, 0x92, 0xd4, 0xa4, 0x51, 0x93, 0x38, 0xb2, 0x1d, 0x09, 0x3f, 0x01, 0x57, 0x8e, 0x1c, - 0xb7, 0x3b, 0x0f, 0xc2, 0xb1, 0x47, 0x4e, 0x15, 0x4a, 0xdf, 0x60, 0x4f, 0x80, 0x6a, 0x27, 0xdb, - 0x00, 0x71, 0x72, 0xbe, 0xff, 0xef, 0x73, 0xfc, 0xff, 0x7f, 0x36, 0xec, 0x06, 0x84, 0x25, 0x84, - 0x0d, 0x02, 0x2a, 0x32, 0x4e, 0xca, 0xc5, 0xce, 0x28, 0xe1, 0x04, 0x1d, 0x29, 0x66, 0x2b, 0xb1, - 0xdb, 0x09, 0x49, 0x48, 0x24, 0x19, 0xec, 0xbe, 0x54, 0x53, 0xf7, 0x24, 0x24, 0x24, 0x8c, 0xf1, - 0x40, 0x56, 0x7e, 0xfe, 0x69, 0xe0, 0xa5, 0x42, 0x21, 0xeb, 0x4b, 0x0d, 0x36, 0x67, 0xb9, 0x1f, - 0x47, 0xc1, 0x14, 0x0b, 0x64, 0xc0, 0x26, 0xc3, 0x41, 0x36, 0x1a, 0x9f, 0xae, 0x86, 0x3a, 0xe8, - 0x81, 0xfe, 0xe1, 0x85, 0xe6, 0xde, 0x49, 0xa8, 0x0b, 0xf7, 0xf1, 0x62, 0x34, 0x1e, 0x0f, 0x5f, - 0xeb, 0xb5, 0x92, 0x56, 0xc2, 0x8e, 0x31, 0xaa, 0x58, 0xbd, 0x62, 0xa5, 0x80, 0xde, 0xc0, 0x83, - 0x24, 0x8f, 0x79, 0xc4, 0xa2, 0x50, 0xdf, 0xeb, 0x81, 0x7e, 0x6b, 0xf4, 0xd4, 0xfe, 0xc3, 0xb8, - 0x3d, 0xcb, 0xfd, 0x29, 0x16, 0x6f, 0xcb, 0xa6, 0x77, 0x4b, 0x8a, 0xd9, 0x92, 0xc4, 0x8b, 0x0b, - 0xcd, 0xbd, 0xdd, 0x79, 0xcf, 0x1d, 0x1d, 0xea, 0x8d, 0xbf, 0xdc, 0xd1, 0x21, 0x1a, 0x43, 0xe8, - 0xa5, 0x62, 0x9e, 0xe5, 0xfe, 0x0a, 0x0b, 0xbd, 0x2d, 0xcf, 0xe9, 0xd8, 0x2a, 0xbb, 0x5d, 0x65, - 0xb7, 0xcf, 0x52, 0xb1, 0xdb, 0xe6, 0xa5, 0x62, 0x26, 0x1b, 0x9d, 0x06, 0xac, 0xb3, 0x3c, 0xb1, - 0xbe, 0x03, 0xf8, 0xf8, 0x3f, 0x2e, 0xd0, 0x2b, 0xd8, 0xe4, 0x55, 0x21, 0xe7, 0x72, 0xe4, 0x9c, - 0x14, 0x1b, 0x13, 0x4c, 0x6f, 0x36, 0xe6, 0x43, 0xe1, 0x25, 0xf1, 0xc4, 0xba, 0xe5, 0x96, 0x7b, - 0xd7, 0x8b, 0xde, 0xc3, 0x56, 0x26, 0xa7, 0x3b, 0x5f, 0x61, 0xc1, 0xf4, 0x5a, 0xaf, 0xde, 0x6f, - 0x8d, 0xf4, 0x7f, 0xb3, 0xab, 0xf9, 0x3b, 0x4f, 0x8a, 0x8d, 0xb9, 0xaf, 0x4c, 0xb0, 0x9b, 0x8d, - 0x79, 0xac, 0x7e, 0xad, 0x02, 0x31, 0xcb, 0x85, 0x59, 0xd5, 0xc9, 0xac, 0x53, 0x78, 0x2c, 0x7d, - 0x5e, 0x46, 0x61, 0xea, 0xf1, 0x9c, 0x62, 0x64, 0x40, 0xc8, 0xaa, 0x82, 0xe9, 0xa0, 0x57, 0xef, - 0x1f, 0xba, 0xf7, 0x94, 0xc9, 0xde, 0xfa, 0xda, 0x04, 0xd6, 0x47, 0xd8, 0x3e, 0x27, 0x49, 0xe6, - 0x05, 0xdc, 0x89, 0xf8, 0x19, 0xa5, 0x9e, 0x40, 0xcf, 0xe1, 0x23, 0xfc, 0x99, 0x53, 0x6f, 0xee, - 0x47, 0x9c, 0xcd, 0x19, 0x27, 0x14, 0x97, 0x29, 0xdd, 0xb6, 0x04, 0x4e, 0xc4, 0xd9, 0xa5, 0x94, - 0x51, 0x07, 0x36, 0x70, 0x8c, 0x13, 0xa6, 0xee, 0xdf, 0x55, 0xc5, 0xe4, 0xe0, 0xdb, 0x95, 0xa9, - 0x5d, 0x5d, 0x9b, 0x9a, 0x73, 0xfe, 0xa3, 0x30, 0xc0, 0xba, 0x30, 0xc0, 0xaf, 0xc2, 0x00, 0x5f, - 0xb7, 0x86, 0xb6, 0xde, 0x1a, 0xda, 0xcf, 0xad, 0xa1, 0x7d, 0x78, 0x16, 0x46, 0x7c, 0x99, 0xfb, - 0x76, 0x40, 0x92, 0x41, 0xf5, 0xa0, 0xe5, 0xf2, 0x82, 0x2d, 0x56, 0xd5, 0xdb, 0xe6, 0x22, 0xc3, - 0xcc, 0x7f, 0x20, 0x2f, 0xeb, 0xe5, 0xef, 0x00, 0x00, 0x00, 0xff, 0xff, 0x1c, 0xa2, 0x1f, 0xee, - 0xf9, 0x02, 0x00, 0x00, + // 495 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x74, 0x92, 0x4f, 0x6f, 0xd3, 0x30, + 0x18, 0xc6, 0xe3, 0xfe, 0x61, 0xd4, 0xdd, 0x56, 0xb0, 0x2a, 0x91, 0x55, 0x22, 0xa9, 0x72, 0x40, + 0x05, 0x89, 0x54, 0x2d, 0xea, 0x10, 0xbd, 0x2d, 0xe3, 0x30, 0xa9, 0x42, 0xaa, 0x32, 0x0e, 0xc0, + 0xa5, 0x4a, 0x52, 0x93, 0x46, 0x4d, 0xe2, 0xc8, 0x76, 0x24, 0xfc, 0x09, 0xb8, 0x72, 0xe4, 0x08, + 0x77, 0x3e, 0x08, 0xc7, 0x1e, 0x39, 0x55, 0x28, 0xfd, 0x06, 0xfb, 0x04, 0xa8, 0x76, 0xb2, 0x0d, + 0xd0, 0x4e, 0xce, 0xfb, 0xfc, 0x5e, 0xc7, 0xcf, 0xf3, 0xda, 0xb0, 0x17, 0x10, 0x96, 0x10, 0x36, + 0x0c, 0xa8, 0xc8, 0x38, 0x29, 0x17, 0x3b, 0xa3, 0x84, 0x13, 0x74, 0xa4, 0x98, 0xad, 0xc4, 0x5e, + 0x37, 0x24, 0x21, 0x91, 0x64, 0xb8, 0xff, 0x52, 0x4d, 0xbd, 0x93, 0x90, 0x90, 0x30, 0xc6, 0x43, + 0x59, 0xf9, 0xf9, 0xc7, 0xa1, 0x97, 0x0a, 0x85, 0xac, 0xcf, 0x35, 0xd8, 0x9a, 0xe7, 0x7e, 0x1c, + 0x05, 0x33, 0x2c, 0x90, 0x01, 0x5b, 0x0c, 0x07, 0xd9, 0x78, 0x72, 0xba, 0x1e, 0xe9, 0xa0, 0x0f, + 0x06, 0x87, 0x17, 0x9a, 0x7b, 0x23, 0xa1, 0x1e, 0x3c, 0xc0, 0xcb, 0xf1, 0x64, 0x32, 0x7a, 0xa5, + 0xd7, 0x4a, 0x5a, 0x09, 0x7b, 0xc6, 0xa8, 0x62, 0xf5, 0x8a, 0x95, 0x02, 0x7a, 0x0d, 0xef, 0x27, + 0x79, 0xcc, 0x23, 0x16, 0x85, 0x7a, 0xa3, 0x0f, 0x06, 0xed, 0xf1, 0x13, 0xfb, 0x2f, 0xe3, 0xf6, + 0x3c, 0xf7, 0x67, 0x58, 0xbc, 0x29, 0x9b, 0xde, 0xae, 0x28, 0x66, 0x2b, 0x12, 0x2f, 0x2f, 0x34, + 0xf7, 0x7a, 0xe7, 0x2d, 0x77, 0x74, 0xa4, 0x37, 0xff, 0x71, 0x47, 0x47, 0x68, 0x02, 0xa1, 0x97, + 0x8a, 0x45, 0x96, 0xfb, 0x6b, 0x2c, 0xf4, 0x8e, 0x3c, 0xa7, 0x6b, 0xab, 0xec, 0x76, 0x95, 0xdd, + 0x3e, 0x4b, 0xc5, 0x7e, 0x9b, 0x97, 0x8a, 0xb9, 0x6c, 0x74, 0x9a, 0xb0, 0xce, 0xf2, 0xc4, 0xfa, + 0x01, 0xe0, 0xa3, 0x3b, 0x5c, 0xa0, 0x97, 0xb0, 0xc5, 0xab, 0x42, 0xce, 0xe5, 0xc8, 0x39, 0x29, + 0xb6, 0x26, 0x98, 0x5d, 0x6d, 0xcd, 0x07, 0xc2, 0x4b, 0xe2, 0xa9, 0x75, 0xcd, 0x2d, 0xf7, 0xa6, + 0x17, 0xbd, 0x83, 0xed, 0x4c, 0x4e, 0x77, 0xb1, 0xc6, 0x82, 0xe9, 0xb5, 0x7e, 0x7d, 0xd0, 0x1e, + 0xeb, 0xff, 0x67, 0x57, 0xf3, 0x77, 0x1e, 0x17, 0x5b, 0xf3, 0x40, 0x99, 0x60, 0x57, 0x5b, 0xf3, + 0x58, 0xfd, 0x5a, 0x05, 0x62, 0x96, 0x0b, 0xb3, 0xaa, 0x93, 0x59, 0xa7, 0xf0, 0x58, 0xfa, 0xbc, + 0x8c, 0xc2, 0xd4, 0xe3, 0x39, 0xc5, 0xc8, 0x80, 0x90, 0x55, 0x05, 0xd3, 0x41, 0xbf, 0x3e, 0x38, + 0x74, 0x6f, 0x29, 0xd3, 0xc6, 0xe6, 0xbb, 0x09, 0xac, 0xf7, 0xb0, 0x73, 0x4e, 0x92, 0xcc, 0x0b, + 0xb8, 0x13, 0xf1, 0x33, 0x4a, 0x3d, 0x81, 0x9e, 0xc1, 0x87, 0xf8, 0x13, 0xa7, 0xde, 0xc2, 0x8f, + 0x38, 0x5b, 0x30, 0x4e, 0x28, 0x2e, 0x53, 0xba, 0x1d, 0x09, 0x9c, 0x88, 0xb3, 0x4b, 0x29, 0xa3, + 0x2e, 0x6c, 0xe2, 0x18, 0x27, 0x4c, 0xdd, 0xbf, 0xab, 0x8a, 0x69, 0xe3, 0xeb, 0x37, 0x53, 0x73, + 0xce, 0x7f, 0x16, 0x06, 0xd8, 0x14, 0x06, 0xf8, 0x5d, 0x18, 0xe0, 0xcb, 0xce, 0xd0, 0x36, 0x3b, + 0x43, 0xfb, 0xb5, 0x33, 0xb4, 0x0f, 0x4f, 0xc3, 0x88, 0xaf, 0x72, 0xdf, 0x0e, 0x48, 0x32, 0xac, + 0x1e, 0xb3, 0x5c, 0x9e, 0xb3, 0xe5, 0xba, 0x7a, 0xd7, 0x5c, 0x64, 0x98, 0xf9, 0xf7, 0xe4, 0x45, + 0xbd, 0xf8, 0x13, 0x00, 0x00, 0xff, 0xff, 0x73, 0x8c, 0x25, 0x71, 0xf5, 0x02, 0x00, 0x00, } func (m *PublicKey) Marshal() (dAtA []byte, err error) { @@ -748,6 +747,22 @@ func (m *MultiSignature) Size() (n int) { return n } +func (m *CompactBitArray) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.ExtraBitsStored != 0 { + n += 1 + sovCrypto(uint64(m.ExtraBitsStored)) + } + l = len(m.Elems) + if l > 0 { + n += 1 + l + sovCrypto(uint64(l)) + } + return n +} + func sovCrypto(x uint64) (n int) { return (math_bits.Len64(x|1) + 6) / 7 } diff --git a/crypto/types/multisig/threshold_pubkey.go b/crypto/types/multisig/threshold_pubkey.go index f27f2001cc9e..911843e35cc1 100644 --- a/crypto/types/multisig/threshold_pubkey.go +++ b/crypto/types/multisig/threshold_pubkey.go @@ -48,7 +48,7 @@ func (pk PubKeyMultisigThreshold) VerifyBytes(msg []byte, marshalledSig []byte) if err != nil { return false } - size := sig.BitArray.Size() + size := sig.BitArray.Count() // ensure bit array is the correct size if len(pk.PubKeys) != size { return false @@ -78,7 +78,7 @@ func (pk PubKeyMultisigThreshold) VerifyBytes(msg []byte, marshalledSig []byte) func (pk PubKeyMultisigThreshold) VerifyMultisignature(getSignBytes GetSignBytesFunc, sig *signing.MultiSignatureData) error { bitarray := sig.BitArray sigs := sig.Signatures - size := bitarray.Size() + size := bitarray.Count() // ensure bit array is the correct size if len(pk.PubKeys) != size { return fmt.Errorf("bit array size is incorrect %d", len(pk.PubKeys)) diff --git a/proto/cosmos/crypto/crypto.proto b/proto/cosmos/crypto/crypto.proto index ad31f6686333..7c5e31280450 100644 --- a/proto/cosmos/crypto/crypto.proto +++ b/proto/cosmos/crypto/crypto.proto @@ -42,7 +42,6 @@ message MultiSignature { // space after proto encoding. // This is not thread safe, and is not intended for concurrent usage. message CompactBitArray { - option (gogoproto.sizer) = false; option (gogoproto.goproto_stringer) = false; uint32 extra_bits_stored = 1; diff --git a/x/auth/ante/sigverify.go b/x/auth/ante/sigverify.go index 52a6a3de6055..c04217b58d79 100644 --- a/x/auth/ante/sigverify.go +++ b/x/auth/ante/sigverify.go @@ -349,7 +349,7 @@ func ConsumeMultisignatureVerificationGas( meter sdk.GasMeter, sig *signing.MultiSignatureData, pubkey multisig.PubKey, params types.Params, ) error { - size := sig.BitArray.Size() + size := sig.BitArray.Count() sigIndex := 0 for i := 0; i < size; i++ { diff --git a/x/auth/client/cli/validate_sigs.go b/x/auth/client/cli/validate_sigs.go index e961f98bbc8b..e6d90509fc03 100644 --- a/x/auth/client/cli/validate_sigs.go +++ b/x/auth/client/cli/validate_sigs.go @@ -114,7 +114,7 @@ func printAndValidateSigs( var b strings.Builder b.WriteString("\n MultiSig Signatures:\n") - for i := 0; i < multiSig.BitArray.Size(); i++ { + for i := 0; i < multiSig.BitArray.Count(); i++ { if multiSig.BitArray.GetIndex(i) { addr := sdk.AccAddress(multiPK.PubKeys[i].Address().Bytes()) b.WriteString(fmt.Sprintf(" %d: %s (weight: %d)\n", i, addr, 1)) diff --git a/x/auth/types/stdtx.go b/x/auth/types/stdtx.go index 7bcc550f93af..589e494285c8 100644 --- a/x/auth/types/stdtx.go +++ b/x/auth/types/stdtx.go @@ -413,7 +413,7 @@ func pubKeySigToSigData(cdc *codec.Codec, key crypto.PubKey, sig []byte) (signin sigDatas := make([]signing.SignatureData, len(sigs)) pubKeys := multiPK.GetPubKeys() bitArray := multiSig.BitArray - n := multiSig.BitArray.Size() + n := multiSig.BitArray.Count() signatures := multisig.NewMultisig(n) sigIdx := 0 for i := 0; i < n; i++ { From 24f644ef2ed25884830ddb49155d7de9abe24682 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Wed, 1 Jul 2020 15:58:33 -0400 Subject: [PATCH 33/43] Rename --- x/auth/signing/direct/direct_test.go | 2 +- x/auth/tx/generator.go | 4 ++-- x/auth/tx/generator_test.go | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index 9975533b3105..a66f237edc9b 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -30,7 +30,7 @@ func TestDirectModeHandler(t *testing.T) { marshaler := codec.NewProtoCodec(interfaceRegistry) pubKeyCdc := std.DefaultPublicKeyCodec{} - txGen := tx.New(marshaler, pubKeyCdc, tx.DefaultSignModeHandler()) + txGen := tx.NewTxGenerator(marshaler, pubKeyCdc, tx.DefaultSignModeHandler()) txBuilder := txGen.NewTxBuilder() memo := "sometestmemo" diff --git a/x/auth/tx/generator.go b/x/auth/tx/generator.go index 88465c8f037c..0de4bd318e59 100644 --- a/x/auth/tx/generator.go +++ b/x/auth/tx/generator.go @@ -18,8 +18,8 @@ type generator struct { jsonEncoder sdk.TxEncoder } -// New returns a new protobuf TxGenerator using the provided Marshaler, PublicKeyCodec and SignModeHandler. -func New(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec, signModeHandler signing.SignModeHandler) client.TxGenerator { +// NewTxGenerator returns a new protobuf TxGenerator using the provided Marshaler, PublicKeyCodec and SignModeHandler. +func NewTxGenerator(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec, signModeHandler signing.SignModeHandler) client.TxGenerator { return &generator{ marshaler: marshaler, pubkeyCodec: pubkeyCodec, diff --git a/x/auth/tx/generator_test.go b/x/auth/tx/generator_test.go index 83bd113e2b09..ca63ecfc1f79 100644 --- a/x/auth/tx/generator_test.go +++ b/x/auth/tx/generator_test.go @@ -21,5 +21,5 @@ func TestGenerator(t *testing.T) { marshaler := codec.NewProtoCodec(interfaceRegistry) pubKeyCodec := std.DefaultPublicKeyCodec{} signModeHandler := DefaultSignModeHandler() - suite.Run(t, testutil.NewTxGeneratorTestSuite(New(marshaler, pubKeyCodec, signModeHandler))) + suite.Run(t, testutil.NewTxGeneratorTestSuite(NewTxGenerator(marshaler, pubKeyCodec, signModeHandler))) } From 10e450c2455678d5e37203a3c4bf330f4a0feba3 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Wed, 1 Jul 2020 16:07:43 -0400 Subject: [PATCH 34/43] Remove Builder interface --- x/auth/tx/builder.go | 52 ++++++++++++++++----------------------- x/auth/tx/builder_test.go | 2 +- x/auth/tx/generator.go | 2 +- 3 files changed, 23 insertions(+), 33 deletions(-) diff --git a/x/auth/tx/builder.go b/x/auth/tx/builder.go index 538585c440f1..7df625aa7515 100644 --- a/x/auth/tx/builder.go +++ b/x/auth/tx/builder.go @@ -3,13 +3,12 @@ package tx import ( "fmt" - authsigning "github.com/cosmos/cosmos-sdk/x/auth/signing" - + "github.com/cosmos/cosmos-sdk/client" "github.com/cosmos/cosmos-sdk/x/auth/signing/direct" - "github.com/cosmos/cosmos-sdk/types/tx" + authsigning "github.com/cosmos/cosmos-sdk/x/auth/signing" - "github.com/cosmos/cosmos-sdk/client" + "github.com/cosmos/cosmos-sdk/types/tx" "github.com/cosmos/cosmos-sdk/types/tx/signing" @@ -23,32 +22,6 @@ import ( sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" ) -// Builder defines a type that is to be used for building, signing and verifying -// protobuf transactions. The protobuf Tx type is not used directly because a) protobuf -// SIGN_MODE_DIRECT signing uses raw body and auth_info bytes and b) Tx does does not retain -// crypto.PubKey instances. -type Builder interface { - authsigning.SigFeeMemoTx - - client.TxBuilder - - direct.ProtoTx -} - -// NewBuilder returns a new Builder instance -func NewBuilder(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) Builder { - return &builder{ - tx: &tx.Tx{ - Body: &tx.TxBody{}, - AuthInfo: &tx.AuthInfo{ - Fee: &tx.Fee{}, - }, - }, - marshaler: marshaler, - pubkeyCodec: pubkeyCodec, - } -} - type builder struct { tx *tx.Tx @@ -68,7 +41,24 @@ type builder struct { pubkeyCodec types.PublicKeyCodec } -var _ Builder = &builder{} +var ( + _ authsigning.SigFeeMemoTx = &builder{} + _ client.TxBuilder = &builder{} + _ direct.ProtoTx = &builder{} +) + +func newBuilder(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec) *builder { + return &builder{ + tx: &tx.Tx{ + Body: &tx.TxBody{}, + AuthInfo: &tx.AuthInfo{ + Fee: &tx.Fee{}, + }, + }, + marshaler: marshaler, + pubkeyCodec: pubkeyCodec, + } +} func (t *builder) GetMsgs() []sdk.Msg { anys := t.tx.Body.Messages diff --git a/x/auth/tx/builder_test.go b/x/auth/tx/builder_test.go index 6f47d9557282..446f4a7fc152 100644 --- a/x/auth/tx/builder_test.go +++ b/x/auth/tx/builder_test.go @@ -23,7 +23,7 @@ func TestTxBuilder(t *testing.T) { _, pubkey, addr := authtypes.KeyTestPubAddr() marshaler := codec.NewHybridCodec(codec.New(), codectypes.NewInterfaceRegistry()) - tx := NewBuilder(marshaler, std.DefaultPublicKeyCodec{}) + tx := newBuilder(marshaler, std.DefaultPublicKeyCodec{}) cdc := std.DefaultPublicKeyCodec{} diff --git a/x/auth/tx/generator.go b/x/auth/tx/generator.go index 0de4bd318e59..de54b017b974 100644 --- a/x/auth/tx/generator.go +++ b/x/auth/tx/generator.go @@ -32,7 +32,7 @@ func NewTxGenerator(marshaler codec.Marshaler, pubkeyCodec types.PublicKeyCodec, } func (g generator) NewTxBuilder() client.TxBuilder { - return NewBuilder(g.marshaler, g.pubkeyCodec) + return newBuilder(g.marshaler, g.pubkeyCodec) } func (g generator) SignModeHandler() signing.SignModeHandler { From 5714dd64fbbd16062171582337de13811bc262f9 Mon Sep 17 00:00:00 2001 From: sahith-narahari Date: Mon, 6 Jul 2020 18:38:03 +0530 Subject: [PATCH 35/43] Address review comments --- x/auth/tx/builder_test.go | 87 +++++++++++++++++++++++++++++++++++++++ x/auth/tx/encoder.go | 4 +- x/auth/tx/sigs.go | 4 +- 3 files changed, 91 insertions(+), 4 deletions(-) diff --git a/x/auth/tx/builder_test.go b/x/auth/tx/builder_test.go index 446f4a7fc152..cdce28aeb314 100644 --- a/x/auth/tx/builder_test.go +++ b/x/auth/tx/builder_test.go @@ -4,6 +4,7 @@ import ( "testing" "github.com/cosmos/cosmos-sdk/codec/testdata" + sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" tx2 "github.com/cosmos/cosmos-sdk/types/tx" @@ -111,3 +112,89 @@ func TestTxBuilder(t *testing.T) { require.Equal(t, 1, len(tx.GetPubKeys())) require.Equal(t, pubkey.Bytes(), tx.GetPubKeys()[0].Bytes()) } + +func TestBuilderValidateBasic(t *testing.T) { + // keys and addresses + _, pubKey1, addr1 := authtypes.KeyTestPubAddr() + _, pubKey2, addr2 := authtypes.KeyTestPubAddr() + + // msg and signatures + msg1 := authtypes.NewTestMsg(addr1, addr2) + fee := authtypes.NewTestStdFee() + + msgs := []sdk.Msg{msg1} + + // require to fail validation upon invalid fee + badFee := authtypes.NewTestStdFee() + badFee.Amount[0].Amount = sdk.NewInt(-5) + marshaler := codec.NewHybridCodec(codec.New(), codectypes.NewInterfaceRegistry()) + builder := newBuilder(marshaler, std.DefaultPublicKeyCodec{}) + + var sig1, sig2 signing.SignatureV2 + sig1 = signing.SignatureV2{ + PubKey: pubKey1, + Data: &signing.SingleSignatureData{ + SignMode: signing.SignMode_SIGN_MODE_DIRECT, + Signature: pubKey1.Bytes(), + }, + } + + sig2 = signing.SignatureV2{ + PubKey: pubKey2, + Data: &signing.SingleSignatureData{ + SignMode: signing.SignMode_SIGN_MODE_DIRECT, + Signature: pubKey2.Bytes(), + }, + } + + err := builder.SetMsgs(msgs...) + require.NoError(t, err) + builder.SetGasLimit(200000) + err = builder.SetSignatures(sig1, sig2) + require.NoError(t, err) + builder.SetFeeAmount(badFee.Amount) + err = builder.ValidateBasic() + require.Error(t, err) + _, code, _ := sdkerrors.ABCIInfo(err, false) + require.Equal(t, sdkerrors.ErrInsufficientFee.ABCICode(), code) + + // require to fail validation when no signatures exist + err = builder.SetSignatures() + require.NoError(t, err) + builder.SetFeeAmount(fee.Amount) + err = builder.ValidateBasic() + require.Error(t, err) + _, code, _ = sdkerrors.ABCIInfo(err, false) + require.Equal(t, sdkerrors.ErrNoSignatures.ABCICode(), code) + + // require to fail with nil values for tx, authinfo + err = builder.SetMsgs(nil) + require.NoError(t, err) + err = builder.ValidateBasic() + require.Error(t, err) + + // require to fail validation when signatures do not match expected signers + err = builder.SetSignatures(sig1) + require.NoError(t, err) + + err = builder.ValidateBasic() + require.Error(t, err) + _, code, _ = sdkerrors.ABCIInfo(err, false) + require.Equal(t, sdkerrors.ErrUnauthorized.ABCICode(), code) + + // TODO: uncomment after SetFee is added + // // require to fail with invalid gas supplied + // badFee = authtypes.NewTestStdFee() + // badFee.Gas = 9223372036854775808 + // builder.SetFeeAmount(badFee) + // + // err = tx.ValidateBasic() + // require.Error(t, err) + // _, code, _ = sdkerrors.ABCIInfo(err, false) + // require.Equal(t, sdkerrors.ErrInvalidRequest.ABCICode(), code) + + builder.SetFeeAmount(fee.Amount) + builder.SetSignatures(sig1, sig2) + err = builder.ValidateBasic() + require.NoError(t, err) +} diff --git a/x/auth/tx/encoder.go b/x/auth/tx/encoder.go index d8419d98c0e4..3c39a20a61fd 100644 --- a/x/auth/tx/encoder.go +++ b/x/auth/tx/encoder.go @@ -13,7 +13,7 @@ func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { return func(tx types.Tx) ([]byte, error) { wrapper, ok := tx.(*builder) if !ok { - return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) + return nil, fmt.Errorf("expected %T, got %T", &builder{}, tx) } raw := &txtypes.TxRaw{ @@ -31,7 +31,7 @@ func DefaultJSONTxEncoder(marshaler codec.Marshaler) types.TxEncoder { return func(tx types.Tx) ([]byte, error) { wrapper, ok := tx.(*builder) if !ok { - return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) + return nil, fmt.Errorf("expected %T, got %T", &builder{}, tx) } return marshaler.MarshalJSON(wrapper.tx) diff --git a/x/auth/tx/sigs.go b/x/auth/tx/sigs.go index 852aca667116..5c69da094e5d 100644 --- a/x/auth/tx/sigs.go +++ b/x/auth/tx/sigs.go @@ -47,7 +47,7 @@ func SignatureDataToModeInfoAndSig(data signing.SignatureData) (*tx.ModeInfo, [] }, }, sig default: - panic("unexpected case") + panic(fmt.Sprintf("unexpected signature data type %T", data)) } } @@ -83,7 +83,7 @@ func ModeInfoAndSigToSignatureData(modeInfo *tx.ModeInfo, sig []byte) (signing.S }, nil default: - panic("unexpected case") + panic(fmt.Sprintf("unexpected data type %T of modeInfo", modeInfo)) } } From 90a6a97436f8b87c1daac27b0d49769bcd372b65 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Mon, 6 Jul 2020 10:49:02 -0400 Subject: [PATCH 36/43] Update x/auth/tx/sigs.go Co-authored-by: Federico Kunze <31522760+fedekunze@users.noreply.github.com> --- x/auth/tx/sigs.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x/auth/tx/sigs.go b/x/auth/tx/sigs.go index 852aca667116..facc9ca2d33d 100644 --- a/x/auth/tx/sigs.go +++ b/x/auth/tx/sigs.go @@ -47,7 +47,7 @@ func SignatureDataToModeInfoAndSig(data signing.SignatureData) (*tx.ModeInfo, [] }, }, sig default: - panic("unexpected case") + panic(fmt.Sprintf("unexpected signature data type %T", data)) } } From d4eab3db06648686c9e8e4e3d164d0816974e39e Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Mon, 6 Jul 2020 10:49:16 -0400 Subject: [PATCH 37/43] Update x/auth/tx/encoder.go Co-authored-by: Federico Kunze <31522760+fedekunze@users.noreply.github.com> --- x/auth/tx/encoder.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x/auth/tx/encoder.go b/x/auth/tx/encoder.go index d8419d98c0e4..d1bc467e2ddc 100644 --- a/x/auth/tx/encoder.go +++ b/x/auth/tx/encoder.go @@ -31,7 +31,7 @@ func DefaultJSONTxEncoder(marshaler codec.Marshaler) types.TxEncoder { return func(tx types.Tx) ([]byte, error) { wrapper, ok := tx.(*builder) if !ok { - return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) + return nil, fmt.Errorf("expected %T, got %T", &builder{}, tx) } return marshaler.MarshalJSON(wrapper.tx) From c06d2e6cdacba13da2124aaf44d437124bfed813 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Mon, 6 Jul 2020 10:49:29 -0400 Subject: [PATCH 38/43] Update x/auth/tx/encoder.go Co-authored-by: Federico Kunze <31522760+fedekunze@users.noreply.github.com> --- x/auth/tx/encoder.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/x/auth/tx/encoder.go b/x/auth/tx/encoder.go index d1bc467e2ddc..3c39a20a61fd 100644 --- a/x/auth/tx/encoder.go +++ b/x/auth/tx/encoder.go @@ -13,7 +13,7 @@ func DefaultTxEncoder(marshaler codec.Marshaler) types.TxEncoder { return func(tx types.Tx) ([]byte, error) { wrapper, ok := tx.(*builder) if !ok { - return nil, fmt.Errorf("expected %T, got %T", builder{}, tx) + return nil, fmt.Errorf("expected %T, got %T", &builder{}, tx) } raw := &txtypes.TxRaw{ From fe81982ddb6c2ab9a6887b5193777ff3043882ec Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Mon, 6 Jul 2020 10:58:17 -0400 Subject: [PATCH 39/43] Address review feedback --- codec/testdata/proto.pb.go | 245 +++++++++++++++++++++++---- x/auth/ante/ante_test.go | 72 ++++---- x/auth/ante/basic_test.go | 8 +- x/auth/ante/fee_test.go | 6 +- x/auth/ante/setup_test.go | 6 +- x/auth/ante/sigverify_test.go | 9 +- x/auth/signing/direct/direct.go | 2 +- x/auth/signing/direct/direct_test.go | 2 +- x/auth/signing/verify_test.go | 4 +- x/auth/tx/sigs.go | 2 +- x/auth/types/stdtx_test.go | 4 +- x/auth/types/test_utils.go | 6 - x/upgrade/types/query.pb.go | 10 +- 13 files changed, 281 insertions(+), 95 deletions(-) diff --git a/codec/testdata/proto.pb.go b/codec/testdata/proto.pb.go index 01e5f19edad7..29cb95b9fe16 100644 --- a/codec/testdata/proto.pb.go +++ b/codec/testdata/proto.pb.go @@ -7,6 +7,8 @@ import ( context "context" fmt "fmt" types "github.com/cosmos/cosmos-sdk/codec/types" + github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" + _ "github.com/gogo/protobuf/gogoproto" grpc1 "github.com/gogo/protobuf/grpc" proto "github.com/gogo/protobuf/proto" grpc "google.golang.org/grpc" @@ -536,6 +538,51 @@ func (m *TestAnyResponse) GetHasAnimal() *HasAnimal { return nil } +// msg type for testing +type TestMsg struct { + Signers []github_com_cosmos_cosmos_sdk_types.AccAddress `protobuf:"bytes,1,rep,name=signers,proto3,casttype=github.com/cosmos/cosmos-sdk/types.AccAddress" json:"signers,omitempty"` +} + +func (m *TestMsg) Reset() { *m = TestMsg{} } +func (m *TestMsg) String() string { return proto.CompactTextString(m) } +func (*TestMsg) ProtoMessage() {} +func (*TestMsg) Descriptor() ([]byte, []int) { + return fileDescriptor_2fcc84b9998d60d8, []int{11} +} +func (m *TestMsg) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *TestMsg) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_TestMsg.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *TestMsg) XXX_Merge(src proto.Message) { + xxx_messageInfo_TestMsg.Merge(m, src) +} +func (m *TestMsg) XXX_Size() int { + return m.Size() +} +func (m *TestMsg) XXX_DiscardUnknown() { + xxx_messageInfo_TestMsg.DiscardUnknown(m) +} + +var xxx_messageInfo_TestMsg proto.InternalMessageInfo + +func (m *TestMsg) GetSigners() []github_com_cosmos_cosmos_sdk_types.AccAddress { + if m != nil { + return m.Signers + } + return nil +} + func init() { proto.RegisterType((*Dog)(nil), "testdata.Dog") proto.RegisterType((*Cat)(nil), "testdata.Cat") @@ -548,42 +595,46 @@ func init() { proto.RegisterType((*SayHelloResponse)(nil), "testdata.SayHelloResponse") proto.RegisterType((*TestAnyRequest)(nil), "testdata.TestAnyRequest") proto.RegisterType((*TestAnyResponse)(nil), "testdata.TestAnyResponse") + proto.RegisterType((*TestMsg)(nil), "testdata.TestMsg") } func init() { proto.RegisterFile("proto.proto", fileDescriptor_2fcc84b9998d60d8) } var fileDescriptor_2fcc84b9998d60d8 = []byte{ - // 467 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0x4f, 0x6f, 0xd3, 0x30, - 0x18, 0xc6, 0x6b, 0xba, 0x3f, 0xed, 0xdb, 0x6a, 0x45, 0x66, 0xa0, 0x36, 0x87, 0x08, 0x45, 0x42, - 0x4c, 0x82, 0x25, 0x52, 0xab, 0x5d, 0x38, 0x20, 0x95, 0x51, 0xd1, 0x0b, 0x97, 0x8c, 0x13, 0x17, - 0xe4, 0xa6, 0x2f, 0x49, 0xb4, 0xc4, 0x1e, 0x75, 0x3a, 0x2d, 0x7c, 0x0a, 0xbe, 0x15, 0x1c, 0x77, - 0xe4, 0x88, 0xda, 0x2f, 0x82, 0x62, 0x3b, 0x7f, 0x98, 0x2a, 0xd4, 0x4b, 0xeb, 0xf7, 0xf5, 0xf3, - 0xfc, 0x6c, 0x3f, 0x6f, 0xa0, 0x77, 0xb3, 0x12, 0x99, 0x70, 0xd5, 0x2f, 0xed, 0x64, 0x28, 0xb3, - 0x25, 0xcb, 0x98, 0x35, 0x0a, 0x85, 0x08, 0x13, 0xf4, 0x54, 0x7f, 0xb1, 0xfe, 0xea, 0x31, 0x9e, - 0x6b, 0x91, 0x73, 0x0e, 0xed, 0xf7, 0x22, 0xa4, 0x14, 0x0e, 0x64, 0xfc, 0x1d, 0x87, 0xe4, 0x39, - 0x39, 0xeb, 0xfa, 0x6a, 0x5d, 0xf4, 0x38, 0x4b, 0x71, 0xf8, 0x48, 0xf7, 0x8a, 0xb5, 0x73, 0x01, - 0xed, 0x4b, 0x96, 0xd1, 0x21, 0x1c, 0xa7, 0x82, 0xc7, 0xd7, 0xb8, 0x32, 0x8e, 0xb2, 0xa4, 0xa7, - 0x70, 0x98, 0xc4, 0xb7, 0x28, 0x95, 0xeb, 0xd0, 0xd7, 0x85, 0xf3, 0x01, 0xba, 0x73, 0x26, 0xa7, - 0x3c, 0x4e, 0x59, 0x42, 0x5f, 0xc3, 0x11, 0x53, 0x2b, 0xe5, 0xed, 0x8d, 0x4f, 0x5d, 0x7d, 0x3d, - 0xb7, 0xbc, 0x9e, 0x3b, 0xe5, 0xb9, 0x6f, 0x34, 0xb4, 0x0f, 0xe4, 0x4e, 0xc1, 0xda, 0x3e, 0xb9, - 0x73, 0x2e, 0xa1, 0x3f, 0x67, 0xb2, 0x66, 0x4d, 0x00, 0x22, 0x26, 0xbf, 0xec, 0xc1, 0xeb, 0x46, - 0xa5, 0xc9, 0xf9, 0x08, 0x03, 0x0d, 0xa9, 0x39, 0x6f, 0xe0, 0xa4, 0xe0, 0xec, 0xc9, 0xea, 0x47, - 0x0d, 0xaf, 0xf3, 0x12, 0x7a, 0xb3, 0x20, 0x12, 0x3e, 0x7e, 0x5b, 0xa3, 0xd4, 0xd9, 0xa0, 0x94, - 0x2c, 0xc4, 0x2a, 0x1b, 0x5d, 0x3a, 0x67, 0xd0, 0xd7, 0x42, 0x79, 0x23, 0xb8, 0xc4, 0xff, 0x28, - 0x5f, 0xc0, 0xe0, 0x8a, 0xe5, 0x73, 0x4c, 0x92, 0x0a, 0x5b, 0x4e, 0x83, 0x34, 0xa6, 0xe1, 0xc2, - 0xe3, 0x5a, 0x66, 0xa0, 0x16, 0x74, 0xc2, 0x15, 0x62, 0x16, 0xf3, 0xd0, 0x68, 0xab, 0xda, 0x99, - 0xc1, 0xc9, 0x27, 0x94, 0x59, 0xf1, 0x04, 0x43, 0x9d, 0x00, 0x30, 0x9e, 0xef, 0x95, 0x1f, 0xe3, - 0xb9, 0x79, 0xf0, 0x0c, 0x06, 0x15, 0xc6, 0x9c, 0x3a, 0xde, 0x31, 0x87, 0x27, 0x6e, 0xf9, 0x01, - 0xba, 0x55, 0x58, 0x8d, 0x31, 0x8c, 0x7f, 0x12, 0xe8, 0x15, 0x9c, 0x2b, 0x5c, 0xdd, 0xc6, 0x01, - 0xd2, 0x0b, 0x38, 0x28, 0xe2, 0xa1, 0x4f, 0x6b, 0x5f, 0x23, 0x57, 0xeb, 0xd9, 0xc3, 0xb6, 0x39, - 0x7a, 0x0a, 0x9d, 0x32, 0x04, 0x3a, 0xaa, 0x35, 0x0f, 0xf2, 0xb3, 0xac, 0x5d, 0x5b, 0x06, 0xf1, - 0x16, 0x8e, 0xcd, 0x83, 0xe8, 0xb0, 0x96, 0xfd, 0x1b, 0x95, 0x35, 0xda, 0xb1, 0xa3, 0xfd, 0xef, - 0x66, 0xbf, 0x36, 0x36, 0xb9, 0xdf, 0xd8, 0xe4, 0xcf, 0xc6, 0x26, 0x3f, 0xb6, 0x76, 0xeb, 0x7e, - 0x6b, 0xb7, 0x7e, 0x6f, 0xed, 0xd6, 0xe7, 0x57, 0x61, 0x9c, 0x45, 0xeb, 0x85, 0x1b, 0x88, 0xd4, - 0x0b, 0x84, 0x4c, 0x85, 0x34, 0x7f, 0xe7, 0x72, 0x79, 0xed, 0x05, 0x62, 0x89, 0x81, 0x57, 0x62, - 0x17, 0x47, 0x2a, 0xf0, 0xc9, 0xdf, 0x00, 0x00, 0x00, 0xff, 0xff, 0x82, 0x85, 0xb8, 0x56, 0xc6, - 0x03, 0x00, 0x00, + // 523 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0x41, 0x8f, 0xd2, 0x50, + 0x10, 0xc7, 0xa9, 0xec, 0x2e, 0x30, 0x90, 0xc5, 0x3c, 0xd1, 0x40, 0x0f, 0x75, 0xd3, 0xc4, 0x48, + 0xa2, 0xb4, 0x11, 0xb2, 0x17, 0x0f, 0x26, 0xdd, 0x95, 0x48, 0x62, 0xf6, 0xd2, 0x35, 0x1e, 0xbc, + 0x98, 0x47, 0x19, 0x4b, 0xb3, 0xf0, 0x1e, 0x76, 0xca, 0x66, 0xeb, 0xa7, 0xf0, 0x5b, 0xe9, 0x71, + 0x8f, 0x9e, 0x8c, 0x81, 0x6f, 0xe1, 0xc9, 0xb4, 0xaf, 0xa5, 0xb8, 0x21, 0x1b, 0x2e, 0xed, 0xcc, + 0xbc, 0xff, 0xfc, 0xfa, 0x66, 0xfe, 0x85, 0xfa, 0x22, 0x94, 0x91, 0xb4, 0xd2, 0x27, 0xab, 0x46, + 0x48, 0xd1, 0x84, 0x47, 0x5c, 0xef, 0xf8, 0x52, 0xfa, 0x33, 0xb4, 0xd3, 0xfa, 0x78, 0xf9, 0xc5, + 0xe6, 0x22, 0x56, 0x22, 0xbd, 0xe5, 0x4b, 0x5f, 0xa6, 0xa1, 0x9d, 0x44, 0xaa, 0x6a, 0xf6, 0xa0, + 0xfc, 0x56, 0xfa, 0x8c, 0xc1, 0x01, 0x05, 0xdf, 0xb0, 0xad, 0x9d, 0x68, 0xdd, 0x9a, 0x9b, 0xc6, + 0x49, 0x4d, 0xf0, 0x39, 0xb6, 0x1f, 0xa8, 0x5a, 0x12, 0x9b, 0xa7, 0x50, 0x3e, 0xe7, 0x11, 0x6b, + 0x43, 0x65, 0x2e, 0x45, 0x70, 0x85, 0x61, 0xd6, 0x91, 0xa7, 0xac, 0x05, 0x87, 0xb3, 0xe0, 0x1a, + 0x29, 0xed, 0x3a, 0x74, 0x55, 0x62, 0xbe, 0x83, 0xda, 0x88, 0x93, 0x23, 0x82, 0x39, 0x9f, 0xb1, + 0x97, 0x70, 0xc4, 0xd3, 0x28, 0xed, 0xad, 0xf7, 0x5b, 0x96, 0xba, 0xb4, 0x95, 0x5f, 0xda, 0x72, + 0x44, 0xec, 0x66, 0x1a, 0xd6, 0x00, 0xed, 0x26, 0x85, 0x95, 0x5d, 0xed, 0xc6, 0x3c, 0x87, 0xc6, + 0x88, 0x53, 0xc1, 0x1a, 0x00, 0x4c, 0x39, 0x7d, 0xde, 0x83, 0x57, 0x9b, 0xe6, 0x4d, 0xe6, 0x05, + 0x34, 0x15, 0xa4, 0xe0, 0xbc, 0x86, 0xe3, 0x84, 0xb3, 0x27, 0xab, 0x31, 0xdd, 0xea, 0x35, 0x9f, + 0x43, 0x7d, 0xe8, 0x4d, 0xa5, 0x8b, 0x5f, 0x97, 0x48, 0x6a, 0x37, 0x48, 0xc4, 0x7d, 0xdc, 0xec, + 0x46, 0xa5, 0x66, 0x17, 0x1a, 0x4a, 0x48, 0x0b, 0x29, 0x08, 0xef, 0x51, 0x3e, 0x83, 0xe6, 0x25, + 0x8f, 0x47, 0x38, 0x9b, 0x6d, 0xb0, 0xb9, 0x1b, 0xda, 0x96, 0x1b, 0x16, 0x3c, 0x2c, 0x64, 0x19, + 0x54, 0x87, 0xaa, 0x1f, 0x22, 0x46, 0x81, 0xf0, 0x33, 0xed, 0x26, 0x37, 0x87, 0x70, 0xfc, 0x01, + 0x29, 0x4a, 0x46, 0xc8, 0xa8, 0x03, 0x00, 0x2e, 0xe2, 0xbd, 0xf6, 0xc7, 0x45, 0x9c, 0x0d, 0x3c, + 0x84, 0xe6, 0x06, 0x93, 0x7d, 0xb5, 0xbf, 0xc3, 0x87, 0x47, 0x56, 0xfe, 0x5b, 0x5a, 0x9b, 0x65, + 0x6d, 0xdb, 0xf0, 0x11, 0x2a, 0x09, 0xe6, 0x82, 0x7c, 0xf6, 0x1e, 0x2a, 0x14, 0xf8, 0x02, 0x43, + 0x6a, 0x6b, 0x27, 0xe5, 0x6e, 0xe3, 0xec, 0xd5, 0xdf, 0xdf, 0x4f, 0x7b, 0x7e, 0x10, 0x4d, 0x97, + 0x63, 0xcb, 0x93, 0x73, 0xdb, 0x93, 0x34, 0x97, 0x94, 0xbd, 0x7a, 0x34, 0xb9, 0xb2, 0xa3, 0x78, + 0x81, 0x64, 0x39, 0x9e, 0xe7, 0x4c, 0x26, 0x21, 0x12, 0xb9, 0x39, 0xa1, 0xff, 0x43, 0x83, 0x7a, + 0x02, 0xbe, 0xc4, 0xf0, 0x3a, 0xf0, 0x90, 0x9d, 0xc2, 0x41, 0xb2, 0x76, 0xf6, 0xb8, 0xb8, 0xcf, + 0x96, 0x5f, 0xfa, 0x93, 0xbb, 0xe5, 0x6c, 0x24, 0x07, 0xaa, 0xf9, 0x72, 0x59, 0xa7, 0xd0, 0xdc, + 0xf1, 0x45, 0xd7, 0x77, 0x1d, 0x65, 0x88, 0x37, 0x6a, 0x42, 0x47, 0xc4, 0xac, 0x5d, 0xc8, 0xfe, + 0xb7, 0x40, 0xef, 0xec, 0x38, 0x51, 0xfd, 0x67, 0xc3, 0x9f, 0x2b, 0x43, 0xbb, 0x5d, 0x19, 0xda, + 0x9f, 0x95, 0xa1, 0x7d, 0x5f, 0x1b, 0xa5, 0xdb, 0xb5, 0x51, 0xfa, 0xb5, 0x36, 0x4a, 0x9f, 0x5e, + 0xdc, 0xbb, 0x1b, 0x4f, 0x4e, 0xd0, 0xb3, 0x73, 0xec, 0xf8, 0x28, 0x35, 0x72, 0xf0, 0x2f, 0x00, + 0x00, 0xff, 0xff, 0xa6, 0x32, 0xfd, 0x15, 0x34, 0x04, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -1110,6 +1161,38 @@ func (m *TestAnyResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } +func (m *TestMsg) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *TestMsg) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *TestMsg) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if len(m.Signers) > 0 { + for iNdEx := len(m.Signers) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Signers[iNdEx]) + copy(dAtA[i:], m.Signers[iNdEx]) + i = encodeVarintProto(dAtA, i, uint64(len(m.Signers[iNdEx]))) + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + func encodeVarintProto(dAtA []byte, offset int, v uint64) int { offset -= sovProto(v) base := offset @@ -1274,6 +1357,21 @@ func (m *TestAnyResponse) Size() (n int) { return n } +func (m *TestMsg) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Signers) > 0 { + for _, b := range m.Signers { + l = len(b) + n += 1 + l + sovProto(uint64(l)) + } + } + return n +} + func sovProto(x uint64) (n int) { return (math_bits.Len64(x|1) + 6) / 7 } @@ -2305,6 +2403,91 @@ func (m *TestAnyResponse) Unmarshal(dAtA []byte) error { } return nil } +func (m *TestMsg) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowProto + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: TestMsg: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: TestMsg: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Signers", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowProto + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthProto + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthProto + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Signers = append(m.Signers, make([]byte, postIndex-iNdEx)) + copy(m.Signers[len(m.Signers)-1], dAtA[iNdEx:postIndex]) + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipProto(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthProto + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthProto + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func skipProto(dAtA []byte) (n int, err error) { l := len(dAtA) iNdEx := 0 diff --git a/x/auth/ante/ante_test.go b/x/auth/ante/ante_test.go index 1c77e44baa7f..44366659d7e6 100644 --- a/x/auth/ante/ante_test.go +++ b/x/auth/ante/ante_test.go @@ -7,6 +7,8 @@ import ( "strings" "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/cosmos/cosmos-sdk/types/tx/signing" "github.com/stretchr/testify/require" @@ -65,9 +67,9 @@ func TestSimulateGasCost(t *testing.T) { // set up msgs and fee var tx sdk.Tx - msg1 := types.NewTestMsg(addr1, addr2) - msg2 := types.NewTestMsg(addr3, addr1) - msg3 := types.NewTestMsg(addr2, addr3) + msg1 := testdata.NewTestMsg(addr1, addr2) + msg2 := testdata.NewTestMsg(addr3, addr1) + msg3 := testdata.NewTestMsg(addr2, addr3) msgs := []sdk.Msg{msg1, msg2, msg3} fee := types.NewTestStdFee() @@ -102,8 +104,8 @@ func TestAnteHandlerSigErrors(t *testing.T) { // msg and signatures var tx sdk.Tx - msg1 := types.NewTestMsg(addr1, addr2) - msg2 := types.NewTestMsg(addr1, addr3) + msg1 := testdata.NewTestMsg(addr1, addr2) + msg2 := testdata.NewTestMsg(addr1, addr3) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg1, msg2} @@ -163,7 +165,7 @@ func TestAnteHandlerAccountNumbers(t *testing.T) { // msg and signatures var tx sdk.Tx - msg := types.NewTestMsg(addr1) + msg := testdata.NewTestMsg(addr1) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg} @@ -184,8 +186,8 @@ func TestAnteHandlerAccountNumbers(t *testing.T) { checkValidTx(t, anteHandler, ctx, tx, false) // new tx with another signer and incorrect account numbers - msg1 := types.NewTestMsg(addr1, addr2) - msg2 := types.NewTestMsg(addr2, addr1) + msg1 := testdata.NewTestMsg(addr1, addr2) + msg2 := testdata.NewTestMsg(addr2, addr1) msgs = []sdk.Msg{msg1, msg2} privs, accnums, seqs = []crypto.PrivKey{priv1, priv2}, []uint64{1, 0}, []uint64{2, 0} tx = types.NewTestTx(ctx, msgs, privs, accnums, seqs, fee) @@ -221,7 +223,7 @@ func TestAnteHandlerAccountNumbersAtBlockHeightZero(t *testing.T) { // msg and signatures var tx sdk.Tx - msg := types.NewTestMsg(addr1) + msg := testdata.NewTestMsg(addr1) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg} @@ -242,8 +244,8 @@ func TestAnteHandlerAccountNumbersAtBlockHeightZero(t *testing.T) { checkValidTx(t, anteHandler, ctx, tx, false) // new tx with another signer and incorrect account numbers - msg1 := types.NewTestMsg(addr1, addr2) - msg2 := types.NewTestMsg(addr2, addr1) + msg1 := testdata.NewTestMsg(addr1, addr2) + msg2 := testdata.NewTestMsg(addr2, addr1) msgs = []sdk.Msg{msg1, msg2} privs, accnums, seqs = []crypto.PrivKey{priv1, priv2}, []uint64{1, 0}, []uint64{2, 0} tx = types.NewTestTx(ctx, msgs, privs, accnums, seqs, fee) @@ -283,7 +285,7 @@ func TestAnteHandlerSequences(t *testing.T) { // msg and signatures var tx sdk.Tx - msg := types.NewTestMsg(addr1) + msg := testdata.NewTestMsg(addr1) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg} @@ -302,8 +304,8 @@ func TestAnteHandlerSequences(t *testing.T) { checkValidTx(t, anteHandler, ctx, tx, false) // new tx with another signer and correct sequences - msg1 := types.NewTestMsg(addr1, addr2) - msg2 := types.NewTestMsg(addr3, addr1) + msg1 := testdata.NewTestMsg(addr1, addr2) + msg2 := testdata.NewTestMsg(addr3, addr1) msgs = []sdk.Msg{msg1, msg2} privs, accnums, seqs = []crypto.PrivKey{priv1, priv2, priv3}, []uint64{0, 1, 2}, []uint64{2, 0, 0} @@ -314,7 +316,7 @@ func TestAnteHandlerSequences(t *testing.T) { checkInvalidTx(t, anteHandler, ctx, tx, false, sdkerrors.ErrUnauthorized) // tx from just second signer with incorrect sequence fails - msg = types.NewTestMsg(addr2) + msg = testdata.NewTestMsg(addr2) msgs = []sdk.Msg{msg} privs, accnums, seqs = []crypto.PrivKey{priv2}, []uint64{1}, []uint64{0} tx = types.NewTestTx(ctx, msgs, privs, accnums, seqs, fee) @@ -325,7 +327,7 @@ func TestAnteHandlerSequences(t *testing.T) { checkValidTx(t, anteHandler, ctx, tx, false) // another tx from both of them that passes - msg = types.NewTestMsg(addr1, addr2) + msg = testdata.NewTestMsg(addr1, addr2) msgs = []sdk.Msg{msg} privs, accnums, seqs = []crypto.PrivKey{priv1, priv2}, []uint64{0, 1}, []uint64{3, 2} tx = types.NewTestTx(ctx, msgs, privs, accnums, seqs, fee) @@ -347,7 +349,7 @@ func TestAnteHandlerFees(t *testing.T) { // msg and signatures var tx sdk.Tx - msg := types.NewTestMsg(addr1) + msg := testdata.NewTestMsg(addr1) privs, accnums, seqs := []crypto.PrivKey{priv1}, []uint64{0}, []uint64{0} fee := types.NewTestStdFee() msgs := []sdk.Msg{msg} @@ -390,7 +392,7 @@ func TestAnteHandlerMemoGas(t *testing.T) { // msg and signatures var tx sdk.Tx - msg := types.NewTestMsg(addr1) + msg := testdata.NewTestMsg(addr1) privs, accnums, seqs := []crypto.PrivKey{priv1}, []uint64{0}, []uint64{0} fee := types.NewStdFee(0, sdk.NewCoins(sdk.NewInt64Coin("atom", 0))) @@ -441,9 +443,9 @@ func TestAnteHandlerMultiSigner(t *testing.T) { // set up msgs and fee var tx sdk.Tx - msg1 := types.NewTestMsg(addr1, addr2) - msg2 := types.NewTestMsg(addr3, addr1) - msg3 := types.NewTestMsg(addr2, addr3) + msg1 := testdata.NewTestMsg(addr1, addr2) + msg2 := testdata.NewTestMsg(addr3, addr1) + msg3 := testdata.NewTestMsg(addr2, addr3) msgs := []sdk.Msg{msg1, msg2, msg3} fee := types.NewTestStdFee() @@ -485,7 +487,7 @@ func TestAnteHandlerBadSignBytes(t *testing.T) { app.BankKeeper.SetBalances(ctx, addr2, types.NewTestCoins()) var tx sdk.Tx - msg := types.NewTestMsg(addr1) + msg := testdata.NewTestMsg(addr1) msgs := []sdk.Msg{msg} fee := types.NewTestStdFee() fee2 := types.NewTestStdFee() @@ -510,12 +512,12 @@ func TestAnteHandlerBadSignBytes(t *testing.T) { msgs []sdk.Msg err error }{ - {chainID2, 0, 1, fee, msgs, errUnauth}, // test wrong chain_id - {chainID, 0, 2, fee, msgs, errUnauth}, // test wrong seqs - {chainID, 1, 1, fee, msgs, errUnauth}, // test wrong accnum - {chainID, 0, 1, fee, []sdk.Msg{types.NewTestMsg(addr2)}, errUnauth}, // test wrong msg - {chainID, 0, 1, fee2, msgs, errUnauth}, // test wrong fee - {chainID, 0, 1, fee3, msgs, errUnauth}, // test wrong fee + {chainID2, 0, 1, fee, msgs, errUnauth}, // test wrong chain_id + {chainID, 0, 2, fee, msgs, errUnauth}, // test wrong seqs + {chainID, 1, 1, fee, msgs, errUnauth}, // test wrong accnum + {chainID, 0, 1, fee, []sdk.Msg{testdata.NewTestMsg(addr2)}, errUnauth}, // test wrong msg + {chainID, 0, 1, fee2, msgs, errUnauth}, // test wrong fee + {chainID, 0, 1, fee3, msgs, errUnauth}, // test wrong fee } privs, seqs = []crypto.PrivKey{priv1}, []uint64{1} @@ -534,7 +536,7 @@ func TestAnteHandlerBadSignBytes(t *testing.T) { checkInvalidTx(t, anteHandler, ctx, tx, false, sdkerrors.ErrInvalidPubKey) // test wrong signer if public doesn't exist - msg = types.NewTestMsg(addr2) + msg = testdata.NewTestMsg(addr2) msgs = []sdk.Msg{msg} privs, accnums, seqs = []crypto.PrivKey{priv1}, []uint64{1}, []uint64{0} tx = types.NewTestTx(ctx, msgs, privs, accnums, seqs, fee) @@ -564,7 +566,7 @@ func TestAnteHandlerSetPubKey(t *testing.T) { var tx sdk.Tx // test good tx and set public key - msg := types.NewTestMsg(addr1) + msg := testdata.NewTestMsg(addr1) msgs := []sdk.Msg{msg} privs, accnums, seqs := []crypto.PrivKey{priv1}, []uint64{0}, []uint64{0} fee := types.NewTestStdFee() @@ -575,7 +577,7 @@ func TestAnteHandlerSetPubKey(t *testing.T) { require.Equal(t, acc1.GetPubKey(), priv1.PubKey()) // test public key not found - msg = types.NewTestMsg(addr2) + msg = testdata.NewTestMsg(addr2) msgs = []sdk.Msg{msg} tx = types.NewTestTx(ctx, msgs, privs, []uint64{1}, seqs, fee) sigs := tx.(types.StdTx).Signatures @@ -693,7 +695,7 @@ func TestAnteHandlerSigLimitExceeded(t *testing.T) { } var tx sdk.Tx - msg := types.NewTestMsg(addr1, addr2, addr3, addr4, addr5, addr6, addr7, addr8) + msg := testdata.NewTestMsg(addr1, addr2, addr3, addr4, addr5, addr6, addr7, addr8) msgs := []sdk.Msg{msg} fee := types.NewTestStdFee() @@ -727,7 +729,7 @@ func TestCustomSignatureVerificationGasConsumer(t *testing.T) { app.BankKeeper.SetBalances(ctx, addr1, sdk.NewCoins(sdk.NewInt64Coin("atom", 150))) var tx sdk.Tx - msg := types.NewTestMsg(addr1) + msg := testdata.NewTestMsg(addr1) privs, accnums, seqs := []crypto.PrivKey{priv1}, []uint64{0}, []uint64{0} fee := types.NewTestStdFee() msgs := []sdk.Msg{msg} @@ -743,7 +745,7 @@ func TestCustomSignatureVerificationGasConsumer(t *testing.T) { require.NoError(t, app.BankKeeper.SetBalances(ctx, addr2, sdk.NewCoins(sdk.NewInt64Coin("atom", 150)))) require.NoError(t, acc2.SetAccountNumber(1)) app.AccountKeeper.SetAccount(ctx, acc2) - msg = types.NewTestMsg(addr2) + msg = testdata.NewTestMsg(addr2) privs, accnums, seqs = []crypto.PrivKey{priv2}, []uint64{1}, []uint64{0} fee = types.NewTestStdFee() msgs = []sdk.Msg{msg} @@ -772,7 +774,7 @@ func TestAnteHandlerReCheck(t *testing.T) { // test that operations skipped on recheck do not run - msg := types.NewTestMsg(addr1) + msg := testdata.NewTestMsg(addr1) msgs := []sdk.Msg{msg} fee := types.NewTestStdFee() diff --git a/x/auth/ante/basic_test.go b/x/auth/ante/basic_test.go index 145137f4cb9f..ce97bc43e270 100644 --- a/x/auth/ante/basic_test.go +++ b/x/auth/ante/basic_test.go @@ -5,6 +5,8 @@ import ( "strings" "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" "github.com/tendermint/tendermint/crypto" @@ -21,7 +23,7 @@ func TestValidateBasic(t *testing.T) { priv1, _, addr1 := types.KeyTestPubAddr() // msg and signatures - msg1 := types.NewTestMsg(addr1) + msg1 := testdata.NewTestMsg(addr1) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg1} @@ -58,7 +60,7 @@ func TestValidateMemo(t *testing.T) { priv1, _, addr1 := types.KeyTestPubAddr() // msg and signatures - msg1 := types.NewTestMsg(addr1) + msg1 := testdata.NewTestMsg(addr1) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg1} @@ -88,7 +90,7 @@ func TestConsumeGasForTxSize(t *testing.T) { priv1, _, addr1 := types.KeyTestPubAddr() // msg and signatures - msg1 := types.NewTestMsg(addr1) + msg1 := testdata.NewTestMsg(addr1) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg1} diff --git a/x/auth/ante/fee_test.go b/x/auth/ante/fee_test.go index 23e5b7e9b789..c56ca7219dfc 100644 --- a/x/auth/ante/fee_test.go +++ b/x/auth/ante/fee_test.go @@ -3,6 +3,8 @@ package ante_test import ( "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" "github.com/tendermint/tendermint/crypto" @@ -22,7 +24,7 @@ func TestEnsureMempoolFees(t *testing.T) { priv1, _, addr1 := types.KeyTestPubAddr() // msg and signatures - msg1 := types.NewTestMsg(addr1) + msg1 := testdata.NewTestMsg(addr1) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg1} @@ -68,7 +70,7 @@ func TestDeductFees(t *testing.T) { priv1, _, addr1 := types.KeyTestPubAddr() // msg and signatures - msg1 := types.NewTestMsg(addr1) + msg1 := testdata.NewTestMsg(addr1) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg1} diff --git a/x/auth/ante/setup_test.go b/x/auth/ante/setup_test.go index 698a0ecedbd1..ad1346760ca1 100644 --- a/x/auth/ante/setup_test.go +++ b/x/auth/ante/setup_test.go @@ -3,6 +3,8 @@ package ante_test import ( "testing" + "github.com/cosmos/cosmos-sdk/codec/testdata" + "github.com/stretchr/testify/require" "github.com/tendermint/tendermint/crypto" @@ -20,7 +22,7 @@ func TestSetup(t *testing.T) { priv1, _, addr1 := types.KeyTestPubAddr() // msg and signatures - msg1 := types.NewTestMsg(addr1) + msg1 := testdata.NewTestMsg(addr1) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg1} @@ -52,7 +54,7 @@ func TestRecoverPanic(t *testing.T) { priv1, _, addr1 := types.KeyTestPubAddr() // msg and signatures - msg1 := types.NewTestMsg(addr1) + msg1 := testdata.NewTestMsg(addr1) fee := types.NewTestStdFee() msgs := []sdk.Msg{msg1} diff --git a/x/auth/ante/sigverify_test.go b/x/auth/ante/sigverify_test.go index 2f65478aff5d..cdbd88888d2a 100644 --- a/x/auth/ante/sigverify_test.go +++ b/x/auth/ante/sigverify_test.go @@ -2,6 +2,7 @@ package ante_test import ( "fmt" + "github.com/cosmos/cosmos-sdk/codec/testdata" "testing" "github.com/cosmos/cosmos-sdk/types/tx/signing" @@ -37,7 +38,7 @@ func TestSetPubKey(t *testing.T) { acc := app.AccountKeeper.NewAccountWithAddress(ctx, addr) require.NoError(t, acc.SetAccountNumber(uint64(i))) app.AccountKeeper.SetAccount(ctx, acc) - msgs[i] = types.NewTestMsg(addr) + msgs[i] = testdata.NewTestMsg(addr) } fee := types.NewTestStdFee() @@ -131,7 +132,7 @@ func TestSigVerification(t *testing.T) { acc := app.AccountKeeper.NewAccountWithAddress(ctx, addr) require.NoError(t, acc.SetAccountNumber(uint64(i))) app.AccountKeeper.SetAccount(ctx, acc) - msgs[i] = types.NewTestMsg(addr) + msgs[i] = testdata.NewTestMsg(addr) } fee := types.NewTestStdFee() @@ -203,7 +204,7 @@ func runSigDecorators(t *testing.T, params types.Params, _ bool, privs ...crypto acc := app.AccountKeeper.NewAccountWithAddress(ctx, addr) require.NoError(t, acc.SetAccountNumber(uint64(i))) app.AccountKeeper.SetAccount(ctx, acc) - msgs[i] = types.NewTestMsg(addr) + msgs[i] = testdata.NewTestMsg(addr) accNums[i] = uint64(i) seqs[i] = uint64(0) } @@ -233,7 +234,7 @@ func TestIncrementSequenceDecorator(t *testing.T) { require.NoError(t, acc.SetAccountNumber(uint64(50))) app.AccountKeeper.SetAccount(ctx, acc) - msgs := []sdk.Msg{types.NewTestMsg(addr)} + msgs := []sdk.Msg{testdata.NewTestMsg(addr)} privKeys := []crypto.PrivKey{priv} accNums := []uint64{app.AccountKeeper.GetAccount(ctx, addr).GetAccountNumber()} accSeqs := []uint64{app.AccountKeeper.GetAccount(ctx, addr).GetSequence()} diff --git a/x/auth/signing/direct/direct.go b/x/auth/signing/direct/direct.go index a22ce6022a96..8377f4403430 100644 --- a/x/auth/signing/direct/direct.go +++ b/x/auth/signing/direct/direct.go @@ -26,7 +26,7 @@ type ModeHandler struct{} var _ signing.SignModeHandler = ModeHandler{} // DefaultMode implements SignModeHandler.DefaultMode -func (h ModeHandler) DefaultMode() signingtypes.SignMode { +func (ModeHandler) DefaultMode() signingtypes.SignMode { return signingtypes.SignMode_SIGN_MODE_DIRECT } diff --git a/x/auth/signing/direct/direct_test.go b/x/auth/signing/direct/direct_test.go index a66f237edc9b..442ebbfacbc7 100644 --- a/x/auth/signing/direct/direct_test.go +++ b/x/auth/signing/direct/direct_test.go @@ -34,7 +34,7 @@ func TestDirectModeHandler(t *testing.T) { txBuilder := txGen.NewTxBuilder() memo := "sometestmemo" - msgs := []sdk.Msg{authtypes.NewTestMsg(addr)} + msgs := []sdk.Msg{testdata.NewTestMsg(addr)} pk, err := pubKeyCdc.Encode(pubkey) require.NoError(t, err) diff --git a/x/auth/signing/verify_test.go b/x/auth/signing/verify_test.go index 9b415a69e3f9..98b820478ad1 100644 --- a/x/auth/signing/verify_test.go +++ b/x/auth/signing/verify_test.go @@ -43,7 +43,7 @@ func TestVerifySignature(t *testing.T) { acc, err := ante.GetSignerAcc(ctx, app.AccountKeeper, addr) require.NoError(t, app.BankKeeper.SetBalances(ctx, addr, balances)) - msgs := []sdk.Msg{types.NewTestMsg(addr)} + msgs := []sdk.Msg{testdata.NewTestMsg(addr)} fee := types.NewStdFee(50000, sdk.Coins{sdk.NewInt64Coin("atom", 150)}) signerData := signing.SignerData{ ChainID: chainId, @@ -67,7 +67,7 @@ func TestVerifySignature(t *testing.T) { pkSet := []crypto.PubKey{pubKey, pubKey1} multisigKey := multisig.NewPubKeyMultisigThreshold(2, pkSet) multisignature := multisig.NewMultisig(2) - msgs = []sdk.Msg{types.NewTestMsg(addr, addr1)} + msgs = []sdk.Msg{testdata.NewTestMsg(addr, addr1)} multiSignBytes := types.StdSignBytes(signerData.ChainID, signerData.AccountNumber, signerData.AccountSequence, fee, msgs, memo) diff --git a/x/auth/tx/sigs.go b/x/auth/tx/sigs.go index facc9ca2d33d..2752fa8da4c3 100644 --- a/x/auth/tx/sigs.go +++ b/x/auth/tx/sigs.go @@ -83,7 +83,7 @@ func ModeInfoAndSigToSignatureData(modeInfo *tx.ModeInfo, sig []byte) (signing.S }, nil default: - panic("unexpected case") + panic(fmt.Errorf("unexpected ModeInfo data type %T", modeInfo)) } } diff --git a/x/auth/types/stdtx_test.go b/x/auth/types/stdtx_test.go index fecb2a761dd1..15d3f89eb572 100644 --- a/x/auth/types/stdtx_test.go +++ b/x/auth/types/stdtx_test.go @@ -74,7 +74,7 @@ func TestTxValidateBasic(t *testing.T) { priv2, _, addr2 := KeyTestPubAddr() // msg and signatures - msg1 := NewTestMsg(addr1, addr2) + msg1 := testdata.NewTestMsg(addr1, addr2) fee := NewTestStdFee() msgs := []sdk.Msg{msg1} @@ -240,7 +240,7 @@ func TestGetSignaturesV2(t *testing.T) { fee := NewStdFee(50000, sdk.Coins{sdk.NewInt64Coin("atom", 150)}) sig := StdSignature{PubKey: pubKey.Bytes(), Signature: dummy} - stdTx := NewStdTx([]sdk.Msg{NewTestMsg()}, fee, []StdSignature{sig}, "testsigs") + stdTx := NewStdTx([]sdk.Msg{testdata.NewTestMsg()}, fee, []StdSignature{sig}, "testsigs") sigs, err := stdTx.GetSignaturesV2() require.Nil(t, err) diff --git a/x/auth/types/test_utils.go b/x/auth/types/test_utils.go index e221b4d48379..c25f8d89c682 100644 --- a/x/auth/types/test_utils.go +++ b/x/auth/types/test_utils.go @@ -4,15 +4,9 @@ import ( "github.com/tendermint/tendermint/crypto" "github.com/tendermint/tendermint/crypto/secp256k1" - "github.com/cosmos/cosmos-sdk/codec/testdata" - sdk "github.com/cosmos/cosmos-sdk/types" ) -func NewTestMsg(addrs ...sdk.AccAddress) *testdata.TestMsg { - return testdata.NewTestMsg(addrs...) -} - func NewTestStdFee() StdFee { return NewStdFee(100000, sdk.NewCoins(sdk.NewInt64Coin("atom", 150)), diff --git a/x/upgrade/types/query.pb.go b/x/upgrade/types/query.pb.go index 5494897faecb..6c1218611e73 100644 --- a/x/upgrade/types/query.pb.go +++ b/x/upgrade/types/query.pb.go @@ -66,7 +66,7 @@ var xxx_messageInfo_QueryCurrentPlanRequest proto.InternalMessageInfo // QueryCurrentPlanResponse is the response type for the Query/CurrentPlan RPC method type QueryCurrentPlanResponse struct { - // plan is the current plan + // plan is the current upgrade plan Plan *Plan `protobuf:"bytes,1,opt,name=plan,proto3" json:"plan,omitempty"` } @@ -245,9 +245,9 @@ const _ = grpc.SupportPackageIsVersion4 // // For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. type QueryClient interface { - // CurrentPlan queries the current plan + // CurrentPlan queries the current upgrade plan CurrentPlan(ctx context.Context, in *QueryCurrentPlanRequest, opts ...grpc.CallOption) (*QueryCurrentPlanResponse, error) - // AppliedPlan queries a previously applied plan by its name + // AppliedPlan queries a previously applied upgrade plan by its name AppliedPlan(ctx context.Context, in *QueryAppliedPlanRequest, opts ...grpc.CallOption) (*QueryAppliedPlanResponse, error) } @@ -279,9 +279,9 @@ func (c *queryClient) AppliedPlan(ctx context.Context, in *QueryAppliedPlanReque // QueryServer is the server API for Query service. type QueryServer interface { - // CurrentPlan queries the current plan + // CurrentPlan queries the current upgrade plan CurrentPlan(context.Context, *QueryCurrentPlanRequest) (*QueryCurrentPlanResponse, error) - // AppliedPlan queries a previously applied plan by its name + // AppliedPlan queries a previously applied upgrade plan by its name AppliedPlan(context.Context, *QueryAppliedPlanRequest) (*QueryAppliedPlanResponse, error) } From 7b9217a4661c6a5f915a73d9e26108ba2ddf6c0c Mon Sep 17 00:00:00 2001 From: sahith-narahari Date: Mon, 6 Jul 2020 20:30:26 +0530 Subject: [PATCH 40/43] Fix build issues --- x/auth/tx/builder_test.go | 15 ++------------- 1 file changed, 2 insertions(+), 13 deletions(-) diff --git a/x/auth/tx/builder_test.go b/x/auth/tx/builder_test.go index cdce28aeb314..1c157b68ddb7 100644 --- a/x/auth/tx/builder_test.go +++ b/x/auth/tx/builder_test.go @@ -29,7 +29,7 @@ func TestTxBuilder(t *testing.T) { cdc := std.DefaultPublicKeyCodec{} memo := "sometestmemo" - msgs := []sdk.Msg{testdata.NewTestMsg(addr)} + msgs := []sdk.Msg{*testdata.NewTestMsg(addr)} pk, err := cdc.Encode(pubkey) require.NoError(t, err) @@ -122,7 +122,7 @@ func TestBuilderValidateBasic(t *testing.T) { msg1 := authtypes.NewTestMsg(addr1, addr2) fee := authtypes.NewTestStdFee() - msgs := []sdk.Msg{msg1} + msgs := []sdk.Msg{*msg1} // require to fail validation upon invalid fee badFee := authtypes.NewTestStdFee() @@ -182,17 +182,6 @@ func TestBuilderValidateBasic(t *testing.T) { _, code, _ = sdkerrors.ABCIInfo(err, false) require.Equal(t, sdkerrors.ErrUnauthorized.ABCICode(), code) - // TODO: uncomment after SetFee is added - // // require to fail with invalid gas supplied - // badFee = authtypes.NewTestStdFee() - // badFee.Gas = 9223372036854775808 - // builder.SetFeeAmount(badFee) - // - // err = tx.ValidateBasic() - // require.Error(t, err) - // _, code, _ = sdkerrors.ABCIInfo(err, false) - // require.Equal(t, sdkerrors.ErrInvalidRequest.ABCICode(), code) - builder.SetFeeAmount(fee.Amount) builder.SetSignatures(sig1, sig2) err = builder.ValidateBasic() From a8aa845deffd9351c8f12c23ad4408e2ea63ae97 Mon Sep 17 00:00:00 2001 From: sahith-narahari Date: Mon, 6 Jul 2020 20:34:58 +0530 Subject: [PATCH 41/43] Resolve conflicts --- x/auth/tx/builder_test.go | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/x/auth/tx/builder_test.go b/x/auth/tx/builder_test.go index 1c157b68ddb7..bce6f390f927 100644 --- a/x/auth/tx/builder_test.go +++ b/x/auth/tx/builder_test.go @@ -29,7 +29,7 @@ func TestTxBuilder(t *testing.T) { cdc := std.DefaultPublicKeyCodec{} memo := "sometestmemo" - msgs := []sdk.Msg{*testdata.NewTestMsg(addr)} + msgs := []sdk.Msg{testdata.NewTestMsg(addr)} pk, err := cdc.Encode(pubkey) require.NoError(t, err) @@ -119,10 +119,10 @@ func TestBuilderValidateBasic(t *testing.T) { _, pubKey2, addr2 := authtypes.KeyTestPubAddr() // msg and signatures - msg1 := authtypes.NewTestMsg(addr1, addr2) + msg1 := testdata.NewTestMsg(addr1, addr2) fee := authtypes.NewTestStdFee() - msgs := []sdk.Msg{*msg1} + msgs := []sdk.Msg{msg1} // require to fail validation upon invalid fee badFee := authtypes.NewTestStdFee() From d15a5119765b449bc84419cbc52b32fdc6b65936 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Mon, 6 Jul 2020 11:23:57 -0400 Subject: [PATCH 42/43] Fix ValidateBasic test coverage --- x/auth/tx/builder_test.go | 77 +++++++++++++++++++++++++++++++-------- 1 file changed, 61 insertions(+), 16 deletions(-) diff --git a/x/auth/tx/builder_test.go b/x/auth/tx/builder_test.go index bce6f390f927..64040c953f76 100644 --- a/x/auth/tx/builder_test.go +++ b/x/auth/tx/builder_test.go @@ -29,6 +29,7 @@ func TestTxBuilder(t *testing.T) { cdc := std.DefaultPublicKeyCodec{} memo := "sometestmemo" + msgs := []sdk.Msg{testdata.NewTestMsg(addr)} pk, err := cdc.Encode(pubkey) @@ -128,7 +129,7 @@ func TestBuilderValidateBasic(t *testing.T) { badFee := authtypes.NewTestStdFee() badFee.Amount[0].Amount = sdk.NewInt(-5) marshaler := codec.NewHybridCodec(codec.New(), codectypes.NewInterfaceRegistry()) - builder := newBuilder(marshaler, std.DefaultPublicKeyCodec{}) + bldr := newBuilder(marshaler, std.DefaultPublicKeyCodec{}) var sig1, sig2 signing.SignatureV2 sig1 = signing.SignatureV2{ @@ -147,43 +148,87 @@ func TestBuilderValidateBasic(t *testing.T) { }, } - err := builder.SetMsgs(msgs...) + err := bldr.SetMsgs(msgs...) require.NoError(t, err) - builder.SetGasLimit(200000) - err = builder.SetSignatures(sig1, sig2) + bldr.SetGasLimit(200000) + err = bldr.SetSignatures(sig1, sig2) require.NoError(t, err) - builder.SetFeeAmount(badFee.Amount) - err = builder.ValidateBasic() + bldr.SetFeeAmount(badFee.Amount) + err = bldr.ValidateBasic() require.Error(t, err) _, code, _ := sdkerrors.ABCIInfo(err, false) require.Equal(t, sdkerrors.ErrInsufficientFee.ABCICode(), code) // require to fail validation when no signatures exist - err = builder.SetSignatures() + err = bldr.SetSignatures() require.NoError(t, err) - builder.SetFeeAmount(fee.Amount) - err = builder.ValidateBasic() + bldr.SetFeeAmount(fee.Amount) + err = bldr.ValidateBasic() require.Error(t, err) _, code, _ = sdkerrors.ABCIInfo(err, false) require.Equal(t, sdkerrors.ErrNoSignatures.ABCICode(), code) // require to fail with nil values for tx, authinfo - err = builder.SetMsgs(nil) + err = bldr.SetMsgs(msgs...) require.NoError(t, err) - err = builder.ValidateBasic() + err = bldr.ValidateBasic() require.Error(t, err) // require to fail validation when signatures do not match expected signers - err = builder.SetSignatures(sig1) + err = bldr.SetSignatures(sig1) require.NoError(t, err) - err = builder.ValidateBasic() + err = bldr.ValidateBasic() require.Error(t, err) _, code, _ = sdkerrors.ABCIInfo(err, false) require.Equal(t, sdkerrors.ErrUnauthorized.ABCICode(), code) - builder.SetFeeAmount(fee.Amount) - builder.SetSignatures(sig1, sig2) - err = builder.ValidateBasic() + require.Error(t, err) + bldr.SetFeeAmount(fee.Amount) + err = bldr.SetSignatures(sig1, sig2) + require.NoError(t, err) + err = bldr.ValidateBasic() + require.NoError(t, err) + + // gas limit too high + bldr.SetGasLimit(MaxGasWanted + 1) + err = bldr.ValidateBasic() + require.Error(t, err) + bldr.SetGasLimit(MaxGasWanted - 1) + err = bldr.ValidateBasic() + require.NoError(t, err) + + // bad builder structs + + // missing body + body := bldr.tx.Body + bldr.tx.Body = nil + err = bldr.ValidateBasic() + require.Error(t, err) + bldr.tx.Body = body + err = bldr.ValidateBasic() require.NoError(t, err) + + // missing fee + f := bldr.tx.AuthInfo.Fee + bldr.tx.AuthInfo.Fee = nil + err = bldr.ValidateBasic() + require.Error(t, err) + bldr.tx.AuthInfo.Fee = f + err = bldr.ValidateBasic() + require.NoError(t, err) + + // missing AuthInfo + authInfo := bldr.tx.AuthInfo + bldr.tx.AuthInfo = nil + err = bldr.ValidateBasic() + require.Error(t, err) + bldr.tx.AuthInfo = authInfo + err = bldr.ValidateBasic() + require.NoError(t, err) + + // missing tx + bldr.tx = nil + err = bldr.ValidateBasic() + require.Error(t, err) } From f2cbd95f1675959efbc28431b08e63f492e78879 Mon Sep 17 00:00:00 2001 From: Aaron Craelius Date: Mon, 6 Jul 2020 11:29:31 -0400 Subject: [PATCH 43/43] Add test for malicious multisig --- codec/testdata/proto.pb.go | 312 +++++++++++++++++++++++++++++++++---- codec/testdata/proto.proto | 7 + x/auth/tx/sigs_test.go | 40 +++++ 3 files changed, 325 insertions(+), 34 deletions(-) create mode 100644 x/auth/tx/sigs_test.go diff --git a/codec/testdata/proto.pb.go b/codec/testdata/proto.pb.go index 29cb95b9fe16..e83df04d9cc1 100644 --- a/codec/testdata/proto.pb.go +++ b/codec/testdata/proto.pb.go @@ -583,6 +583,60 @@ func (m *TestMsg) GetSigners() []github_com_cosmos_cosmos_sdk_types.AccAddress { return nil } +// bad MultiSignature with extra fields +type BadMultiSignature struct { + Signatures [][]byte `protobuf:"bytes,1,rep,name=signatures,proto3" json:"signatures,omitempty"` + MaliciousField []byte `protobuf:"bytes,5,opt,name=malicious_field,json=maliciousField,proto3" json:"malicious_field,omitempty"` + XXX_unrecognized []byte `json:"-"` +} + +func (m *BadMultiSignature) Reset() { *m = BadMultiSignature{} } +func (m *BadMultiSignature) String() string { return proto.CompactTextString(m) } +func (*BadMultiSignature) ProtoMessage() {} +func (*BadMultiSignature) Descriptor() ([]byte, []int) { + return fileDescriptor_2fcc84b9998d60d8, []int{12} +} +func (m *BadMultiSignature) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *BadMultiSignature) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_BadMultiSignature.Marshal(b, m, deterministic) + } else { + b = b[:cap(b)] + n, err := m.MarshalToSizedBuffer(b) + if err != nil { + return nil, err + } + return b[:n], nil + } +} +func (m *BadMultiSignature) XXX_Merge(src proto.Message) { + xxx_messageInfo_BadMultiSignature.Merge(m, src) +} +func (m *BadMultiSignature) XXX_Size() int { + return m.Size() +} +func (m *BadMultiSignature) XXX_DiscardUnknown() { + xxx_messageInfo_BadMultiSignature.DiscardUnknown(m) +} + +var xxx_messageInfo_BadMultiSignature proto.InternalMessageInfo + +func (m *BadMultiSignature) GetSignatures() [][]byte { + if m != nil { + return m.Signatures + } + return nil +} + +func (m *BadMultiSignature) GetMaliciousField() []byte { + if m != nil { + return m.MaliciousField + } + return nil +} + func init() { proto.RegisterType((*Dog)(nil), "testdata.Dog") proto.RegisterType((*Cat)(nil), "testdata.Cat") @@ -596,45 +650,50 @@ func init() { proto.RegisterType((*TestAnyRequest)(nil), "testdata.TestAnyRequest") proto.RegisterType((*TestAnyResponse)(nil), "testdata.TestAnyResponse") proto.RegisterType((*TestMsg)(nil), "testdata.TestMsg") + proto.RegisterType((*BadMultiSignature)(nil), "testdata.BadMultiSignature") } func init() { proto.RegisterFile("proto.proto", fileDescriptor_2fcc84b9998d60d8) } var fileDescriptor_2fcc84b9998d60d8 = []byte{ - // 523 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0x41, 0x8f, 0xd2, 0x50, - 0x10, 0xc7, 0xa9, 0xec, 0x2e, 0x30, 0x90, 0xc5, 0x3c, 0xd1, 0x40, 0x0f, 0x75, 0xd3, 0xc4, 0x48, - 0xa2, 0xb4, 0x11, 0xb2, 0x17, 0x0f, 0x26, 0xdd, 0x95, 0x48, 0x62, 0xf6, 0xd2, 0x35, 0x1e, 0xbc, - 0x98, 0x47, 0x19, 0x4b, 0xb3, 0xf0, 0x1e, 0x76, 0xca, 0x66, 0xeb, 0xa7, 0xf0, 0x5b, 0xe9, 0x71, - 0x8f, 0x9e, 0x8c, 0x81, 0x6f, 0xe1, 0xc9, 0xb4, 0xaf, 0xa5, 0xb8, 0x21, 0x1b, 0x2e, 0xed, 0xcc, - 0xbc, 0xff, 0xfc, 0xfa, 0x66, 0xfe, 0x85, 0xfa, 0x22, 0x94, 0x91, 0xb4, 0xd2, 0x27, 0xab, 0x46, - 0x48, 0xd1, 0x84, 0x47, 0x5c, 0xef, 0xf8, 0x52, 0xfa, 0x33, 0xb4, 0xd3, 0xfa, 0x78, 0xf9, 0xc5, - 0xe6, 0x22, 0x56, 0x22, 0xbd, 0xe5, 0x4b, 0x5f, 0xa6, 0xa1, 0x9d, 0x44, 0xaa, 0x6a, 0xf6, 0xa0, - 0xfc, 0x56, 0xfa, 0x8c, 0xc1, 0x01, 0x05, 0xdf, 0xb0, 0xad, 0x9d, 0x68, 0xdd, 0x9a, 0x9b, 0xc6, - 0x49, 0x4d, 0xf0, 0x39, 0xb6, 0x1f, 0xa8, 0x5a, 0x12, 0x9b, 0xa7, 0x50, 0x3e, 0xe7, 0x11, 0x6b, - 0x43, 0x65, 0x2e, 0x45, 0x70, 0x85, 0x61, 0xd6, 0x91, 0xa7, 0xac, 0x05, 0x87, 0xb3, 0xe0, 0x1a, - 0x29, 0xed, 0x3a, 0x74, 0x55, 0x62, 0xbe, 0x83, 0xda, 0x88, 0x93, 0x23, 0x82, 0x39, 0x9f, 0xb1, - 0x97, 0x70, 0xc4, 0xd3, 0x28, 0xed, 0xad, 0xf7, 0x5b, 0x96, 0xba, 0xb4, 0x95, 0x5f, 0xda, 0x72, - 0x44, 0xec, 0x66, 0x1a, 0xd6, 0x00, 0xed, 0x26, 0x85, 0x95, 0x5d, 0xed, 0xc6, 0x3c, 0x87, 0xc6, - 0x88, 0x53, 0xc1, 0x1a, 0x00, 0x4c, 0x39, 0x7d, 0xde, 0x83, 0x57, 0x9b, 0xe6, 0x4d, 0xe6, 0x05, - 0x34, 0x15, 0xa4, 0xe0, 0xbc, 0x86, 0xe3, 0x84, 0xb3, 0x27, 0xab, 0x31, 0xdd, 0xea, 0x35, 0x9f, - 0x43, 0x7d, 0xe8, 0x4d, 0xa5, 0x8b, 0x5f, 0x97, 0x48, 0x6a, 0x37, 0x48, 0xc4, 0x7d, 0xdc, 0xec, - 0x46, 0xa5, 0x66, 0x17, 0x1a, 0x4a, 0x48, 0x0b, 0x29, 0x08, 0xef, 0x51, 0x3e, 0x83, 0xe6, 0x25, - 0x8f, 0x47, 0x38, 0x9b, 0x6d, 0xb0, 0xb9, 0x1b, 0xda, 0x96, 0x1b, 0x16, 0x3c, 0x2c, 0x64, 0x19, - 0x54, 0x87, 0xaa, 0x1f, 0x22, 0x46, 0x81, 0xf0, 0x33, 0xed, 0x26, 0x37, 0x87, 0x70, 0xfc, 0x01, - 0x29, 0x4a, 0x46, 0xc8, 0xa8, 0x03, 0x00, 0x2e, 0xe2, 0xbd, 0xf6, 0xc7, 0x45, 0x9c, 0x0d, 0x3c, - 0x84, 0xe6, 0x06, 0x93, 0x7d, 0xb5, 0xbf, 0xc3, 0x87, 0x47, 0x56, 0xfe, 0x5b, 0x5a, 0x9b, 0x65, - 0x6d, 0xdb, 0xf0, 0x11, 0x2a, 0x09, 0xe6, 0x82, 0x7c, 0xf6, 0x1e, 0x2a, 0x14, 0xf8, 0x02, 0x43, - 0x6a, 0x6b, 0x27, 0xe5, 0x6e, 0xe3, 0xec, 0xd5, 0xdf, 0xdf, 0x4f, 0x7b, 0x7e, 0x10, 0x4d, 0x97, - 0x63, 0xcb, 0x93, 0x73, 0xdb, 0x93, 0x34, 0x97, 0x94, 0xbd, 0x7a, 0x34, 0xb9, 0xb2, 0xa3, 0x78, - 0x81, 0x64, 0x39, 0x9e, 0xe7, 0x4c, 0x26, 0x21, 0x12, 0xb9, 0x39, 0xa1, 0xff, 0x43, 0x83, 0x7a, - 0x02, 0xbe, 0xc4, 0xf0, 0x3a, 0xf0, 0x90, 0x9d, 0xc2, 0x41, 0xb2, 0x76, 0xf6, 0xb8, 0xb8, 0xcf, - 0x96, 0x5f, 0xfa, 0x93, 0xbb, 0xe5, 0x6c, 0x24, 0x07, 0xaa, 0xf9, 0x72, 0x59, 0xa7, 0xd0, 0xdc, - 0xf1, 0x45, 0xd7, 0x77, 0x1d, 0x65, 0x88, 0x37, 0x6a, 0x42, 0x47, 0xc4, 0xac, 0x5d, 0xc8, 0xfe, - 0xb7, 0x40, 0xef, 0xec, 0x38, 0x51, 0xfd, 0x67, 0xc3, 0x9f, 0x2b, 0x43, 0xbb, 0x5d, 0x19, 0xda, - 0x9f, 0x95, 0xa1, 0x7d, 0x5f, 0x1b, 0xa5, 0xdb, 0xb5, 0x51, 0xfa, 0xb5, 0x36, 0x4a, 0x9f, 0x5e, - 0xdc, 0xbb, 0x1b, 0x4f, 0x4e, 0xd0, 0xb3, 0x73, 0xec, 0xf8, 0x28, 0x35, 0x72, 0xf0, 0x2f, 0x00, - 0x00, 0xff, 0xff, 0xa6, 0x32, 0xfd, 0x15, 0x34, 0x04, 0x00, 0x00, + // 583 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x92, 0xcd, 0x6e, 0xd4, 0x30, + 0x10, 0xc7, 0x6b, 0xb6, 0x9f, 0xb3, 0x51, 0x17, 0x4c, 0x41, 0x69, 0x0e, 0x69, 0x15, 0x09, 0x75, + 0x25, 0x68, 0x22, 0x5a, 0xf5, 0xd2, 0x03, 0x52, 0x5a, 0x16, 0x2a, 0xa1, 0x5e, 0x52, 0xc4, 0x81, + 0x4b, 0xe5, 0x4d, 0x5c, 0xaf, 0xd5, 0xc4, 0x2e, 0x71, 0x52, 0x35, 0x3c, 0x05, 0xaf, 0xc0, 0xd3, + 0xc0, 0x71, 0x8f, 0x9c, 0x10, 0xda, 0x7d, 0x0b, 0x4e, 0x28, 0xdf, 0x4b, 0xb5, 0xaa, 0xf6, 0x92, + 0xcc, 0x8c, 0xff, 0xf3, 0xb3, 0x3d, 0x7f, 0x43, 0xf7, 0x26, 0x96, 0x89, 0xb4, 0x8b, 0x2f, 0x5e, + 0x4f, 0xa8, 0x4a, 0x02, 0x92, 0x10, 0x63, 0x9b, 0x49, 0xc9, 0x42, 0xea, 0x14, 0xf5, 0x61, 0x7a, + 0xe5, 0x10, 0x91, 0x95, 0x22, 0x63, 0x8b, 0x49, 0x26, 0x8b, 0xd0, 0xc9, 0xa3, 0xb2, 0x6a, 0xed, + 0x43, 0xe7, 0xad, 0x64, 0x18, 0xc3, 0xb2, 0xe2, 0x5f, 0xa9, 0x8e, 0x76, 0x51, 0x7f, 0xc3, 0x2b, + 0xe2, 0xbc, 0x26, 0x48, 0x44, 0xf5, 0x47, 0x65, 0x2d, 0x8f, 0xad, 0x23, 0xe8, 0x9c, 0x92, 0x04, + 0xeb, 0xb0, 0x16, 0x49, 0xc1, 0xaf, 0x69, 0x5c, 0x75, 0xd4, 0x29, 0xde, 0x82, 0x95, 0x90, 0xdf, + 0x52, 0x55, 0x74, 0xad, 0x78, 0x65, 0x62, 0xbd, 0x87, 0x8d, 0x33, 0xa2, 0x5c, 0xc1, 0x23, 0x12, + 0xe2, 0x57, 0xb0, 0x4a, 0x8a, 0xa8, 0xe8, 0xed, 0x1e, 0x6c, 0xd9, 0xe5, 0xa1, 0xed, 0xfa, 0xd0, + 0xb6, 0x2b, 0x32, 0xaf, 0xd2, 0x60, 0x0d, 0xd0, 0x5d, 0x01, 0xeb, 0x78, 0xe8, 0xce, 0x3a, 0x05, + 0xed, 0x8c, 0xa8, 0x96, 0x75, 0x08, 0x30, 0x22, 0xea, 0x72, 0x01, 0xde, 0xc6, 0xa8, 0x6e, 0xb2, + 0xce, 0xa1, 0x57, 0x42, 0x5a, 0xce, 0x31, 0x6c, 0xe6, 0x9c, 0x05, 0x59, 0xda, 0x68, 0xa6, 0xd7, + 0xda, 0x83, 0xee, 0xc0, 0x1f, 0x49, 0x8f, 0x7e, 0x49, 0xa9, 0x2a, 0x67, 0x43, 0x95, 0x22, 0x8c, + 0x36, 0xb3, 0x29, 0x53, 0xab, 0x0f, 0x5a, 0x29, 0x54, 0x37, 0x52, 0x28, 0xfa, 0x80, 0xf2, 0x05, + 0xf4, 0x2e, 0x48, 0x76, 0x46, 0xc3, 0xb0, 0xc1, 0xd6, 0x6e, 0xa0, 0x19, 0x37, 0x6c, 0x78, 0xdc, + 0xca, 0x2a, 0xa8, 0x01, 0xeb, 0x2c, 0xa6, 0x34, 0xe1, 0x82, 0x55, 0xda, 0x26, 0xb7, 0x06, 0xb0, + 0xf9, 0x91, 0xaa, 0x24, 0xbf, 0x42, 0x45, 0x3d, 0x04, 0x20, 0x22, 0x5b, 0x68, 0x7e, 0x44, 0x64, + 0xd5, 0x85, 0x07, 0xd0, 0x6b, 0x30, 0xd5, 0xae, 0x07, 0x73, 0x7c, 0x78, 0x6a, 0xd7, 0xcf, 0xd2, + 0x6e, 0x86, 0x35, 0x6b, 0xc3, 0x27, 0x58, 0xcb, 0x31, 0xe7, 0x8a, 0xe1, 0x0f, 0xb0, 0xa6, 0x38, + 0x13, 0x34, 0x56, 0x3a, 0xda, 0xed, 0xf4, 0xb5, 0x93, 0xd7, 0x7f, 0x7f, 0xef, 0xec, 0x33, 0x9e, + 0x8c, 0xd2, 0xa1, 0xed, 0xcb, 0xc8, 0xf1, 0xa5, 0x8a, 0xa4, 0xaa, 0x7e, 0xfb, 0x2a, 0xb8, 0x76, + 0x92, 0xec, 0x86, 0x2a, 0xdb, 0xf5, 0x7d, 0x37, 0x08, 0x62, 0xaa, 0x94, 0x57, 0x13, 0xac, 0x21, + 0x3c, 0x39, 0x21, 0xc1, 0x79, 0x1a, 0x26, 0xfc, 0x82, 0x33, 0x41, 0x92, 0x34, 0xa6, 0xd8, 0x04, + 0x50, 0x75, 0x52, 0x6d, 0xe2, 0xcd, 0x54, 0xf0, 0x1e, 0xf4, 0x22, 0x12, 0x72, 0x9f, 0xcb, 0x54, + 0x5d, 0x5e, 0x71, 0x1a, 0x06, 0xfa, 0xca, 0x2e, 0xea, 0x6b, 0xde, 0x66, 0x53, 0x7e, 0x97, 0x57, + 0x8f, 0x97, 0xc7, 0xdf, 0x77, 0xd0, 0xc1, 0x0f, 0x04, 0xdd, 0xfc, 0xf0, 0x17, 0x34, 0xbe, 0xe5, + 0x3e, 0xc5, 0x47, 0xb0, 0x9c, 0x5b, 0x8b, 0x9f, 0xb5, 0x77, 0x9e, 0x79, 0x13, 0xc6, 0xf3, 0xfb, + 0xe5, 0x6a, 0x6c, 0x2e, 0xac, 0xd7, 0x06, 0xe2, 0xed, 0x56, 0x73, 0xcf, 0x7b, 0xc3, 0x98, 0xb7, + 0x54, 0x21, 0xde, 0x94, 0x53, 0x74, 0x45, 0x86, 0xf5, 0x56, 0xf6, 0xbf, 0xcd, 0xc6, 0xf6, 0x9c, + 0x95, 0xb2, 0xff, 0x64, 0xf0, 0x73, 0x62, 0xa2, 0xf1, 0xc4, 0x44, 0x7f, 0x26, 0x26, 0xfa, 0x36, + 0x35, 0x97, 0xc6, 0x53, 0x73, 0xe9, 0xd7, 0xd4, 0x5c, 0xfa, 0xfc, 0xf2, 0xc1, 0xf9, 0xfb, 0x32, + 0xa0, 0xbe, 0x53, 0x63, 0x87, 0xab, 0xc5, 0x63, 0x39, 0xfc, 0x17, 0x00, 0x00, 0xff, 0xff, 0x6f, + 0x03, 0x13, 0xf7, 0x98, 0x04, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -1193,6 +1252,49 @@ func (m *TestMsg) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } +func (m *BadMultiSignature) Marshal() (dAtA []byte, err error) { + size := m.Size() + dAtA = make([]byte, size) + n, err := m.MarshalToSizedBuffer(dAtA[:size]) + if err != nil { + return nil, err + } + return dAtA[:n], nil +} + +func (m *BadMultiSignature) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *BadMultiSignature) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.XXX_unrecognized != nil { + i -= len(m.XXX_unrecognized) + copy(dAtA[i:], m.XXX_unrecognized) + } + if len(m.MaliciousField) > 0 { + i -= len(m.MaliciousField) + copy(dAtA[i:], m.MaliciousField) + i = encodeVarintProto(dAtA, i, uint64(len(m.MaliciousField))) + i-- + dAtA[i] = 0x2a + } + if len(m.Signatures) > 0 { + for iNdEx := len(m.Signatures) - 1; iNdEx >= 0; iNdEx-- { + i -= len(m.Signatures[iNdEx]) + copy(dAtA[i:], m.Signatures[iNdEx]) + i = encodeVarintProto(dAtA, i, uint64(len(m.Signatures[iNdEx]))) + i-- + dAtA[i] = 0xa + } + } + return len(dAtA) - i, nil +} + func encodeVarintProto(dAtA []byte, offset int, v uint64) int { offset -= sovProto(v) base := offset @@ -1372,6 +1474,28 @@ func (m *TestMsg) Size() (n int) { return n } +func (m *BadMultiSignature) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if len(m.Signatures) > 0 { + for _, b := range m.Signatures { + l = len(b) + n += 1 + l + sovProto(uint64(l)) + } + } + l = len(m.MaliciousField) + if l > 0 { + n += 1 + l + sovProto(uint64(l)) + } + if m.XXX_unrecognized != nil { + n += len(m.XXX_unrecognized) + } + return n +} + func sovProto(x uint64) (n int) { return (math_bits.Len64(x|1) + 6) / 7 } @@ -2488,6 +2612,126 @@ func (m *TestMsg) Unmarshal(dAtA []byte) error { } return nil } +func (m *BadMultiSignature) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowProto + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: BadMultiSignature: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: BadMultiSignature: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field Signatures", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowProto + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthProto + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthProto + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.Signatures = append(m.Signatures, make([]byte, postIndex-iNdEx)) + copy(m.Signatures[len(m.Signatures)-1], dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field MaliciousField", wireType) + } + var byteLen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowProto + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + byteLen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if byteLen < 0 { + return ErrInvalidLengthProto + } + postIndex := iNdEx + byteLen + if postIndex < 0 { + return ErrInvalidLengthProto + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.MaliciousField = append(m.MaliciousField[:0], dAtA[iNdEx:postIndex]...) + if m.MaliciousField == nil { + m.MaliciousField = []byte{} + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipProto(dAtA[iNdEx:]) + if err != nil { + return err + } + if skippy < 0 { + return ErrInvalidLengthProto + } + if (iNdEx + skippy) < 0 { + return ErrInvalidLengthProto + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + m.XXX_unrecognized = append(m.XXX_unrecognized, dAtA[iNdEx:iNdEx+skippy]...) + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func skipProto(dAtA []byte) (n int, err error) { l := len(dAtA) iNdEx := 0 diff --git a/codec/testdata/proto.proto b/codec/testdata/proto.proto index 1382d49cf9fe..5767bbd3b6c6 100644 --- a/codec/testdata/proto.proto +++ b/codec/testdata/proto.proto @@ -63,3 +63,10 @@ message TestAnyResponse { message TestMsg { repeated bytes signers = 1 [(gogoproto.casttype) = "github.com/cosmos/cosmos-sdk/types.AccAddress"]; } + +// bad MultiSignature with extra fields +message BadMultiSignature { + option (gogoproto.goproto_unrecognized) = true; + repeated bytes signatures = 1; + bytes malicious_field = 5; +} diff --git a/x/auth/tx/sigs_test.go b/x/auth/tx/sigs_test.go new file mode 100644 index 000000000000..7280188d0fba --- /dev/null +++ b/x/auth/tx/sigs_test.go @@ -0,0 +1,40 @@ +package tx + +import ( + "testing" + + "github.com/stretchr/testify/require" + + "github.com/cosmos/cosmos-sdk/crypto/types" + + "github.com/cosmos/cosmos-sdk/codec/testdata" +) + +func TestDecodeMultisignatures(t *testing.T) { + testSigs := [][]byte{ + []byte("dummy1"), + []byte("dummy2"), + []byte("dummy3"), + } + + badMultisig := testdata.BadMultiSignature{ + Signatures: testSigs, + MaliciousField: []byte("bad stuff..."), + } + bz, err := badMultisig.Marshal() + require.NoError(t, err) + + _, err = decodeMultisignatures(bz) + require.Error(t, err) + + goodMultisig := types.MultiSignature{ + Signatures: testSigs, + } + bz, err = goodMultisig.Marshal() + require.NoError(t, err) + + decodedSigs, err := decodeMultisignatures(bz) + require.NoError(t, err) + + require.Equal(t, testSigs, decodedSigs) +}