Skip to content

Commit

Permalink
IBC: panic on GetSignBytes and remove SubModuleCdc (#7645)
Browse files Browse the repository at this point in the history
* panic on GetSignBytes and remove SubModuleCdc where possible

* fix build

Co-authored-by: Federico Kunze <31522760+fedekunze@users.noreply.github.com>
  • Loading branch information
colin-axner and fedekunze authored Oct 23, 2020
1 parent c6cbe3a commit e4378e7
Show file tree
Hide file tree
Showing 11 changed files with 57 additions and 108 deletions.
5 changes: 3 additions & 2 deletions x/ibc/applications/transfer/types/msgs.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,9 +64,10 @@ func (msg MsgTransfer) ValidateBasic() error {
return ValidateIBCDenom(msg.Token.Denom)
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgTransfer) GetSignBytes() []byte {
return sdk.MustSortJSON(ModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down
10 changes: 0 additions & 10 deletions x/ibc/applications/transfer/types/msgs_test.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package types

import (
"fmt"
"testing"

"github.com/stretchr/testify/require"
Expand Down Expand Up @@ -85,15 +84,6 @@ func TestMsgTransferValidation(t *testing.T) {
}
}

// TestMsgTransferGetSignBytes tests GetSignBytes for MsgTransfer
func TestMsgTransferGetSignBytes(t *testing.T) {
msg := NewMsgTransfer(validPort, validChannel, coin, addr1, addr2, clienttypes.NewHeight(0, 110), 10)
res := msg.GetSignBytes()

expected := fmt.Sprintf(`{"receiver":"cosmos1w3jhxarpv3j8yvs7f9y7g","sender":"%s","source_channel":"testchannel","source_port":"testportid","timeout_height":{"version_height":"110","version_number":"0"},"timeout_timestamp":"10","token":{"amount":"100","denom":"atom"}}`, addr1.String())
require.Equal(t, expected, string(res))
}

// TestMsgTransferGetSigners tests GetSigners for MsgTransfer
func TestMsgTransferGetSigners(t *testing.T) {
msg := NewMsgTransfer(validPort, validChannel, coin, addr1, addr2, timeoutHeight, 0)
Expand Down
10 changes: 0 additions & 10 deletions x/ibc/core/02-client/types/codec.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ package types
import (
proto "github.com/gogo/protobuf/proto"

"github.com/cosmos/cosmos-sdk/codec"
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
sdk "github.com/cosmos/cosmos-sdk/types"
sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
Expand Down Expand Up @@ -44,15 +43,6 @@ func RegisterInterfaces(registry codectypes.InterfaceRegistry) {
)
}

var (
// SubModuleCdc references the global x/ibc/core/02-client module codec. Note, the codec should
// ONLY be used in certain instances of tests and for JSON encoding.
//
// The actual codec used for serialization should be provided to x/ibc/core/02-client and
// defined at the application level.
SubModuleCdc = codec.NewProtoCodec(codectypes.NewInterfaceRegistry())
)

// PackClientState constructs a new Any packed with the given client state value. It returns
// an error if the client state can't be casted to a protobuf message or if the concrete
// implemention is not registered to the protobuf codec.
Expand Down
21 changes: 12 additions & 9 deletions x/ibc/core/02-client/types/msgs.go
Original file line number Diff line number Diff line change
Expand Up @@ -87,9 +87,10 @@ func (msg MsgCreateClient) ValidateBasic() error {
return host.ClientIdentifierValidator(msg.ClientId)
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgCreateClient) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -156,9 +157,10 @@ func (msg MsgUpdateClient) ValidateBasic() error {
return host.ClientIdentifierValidator(msg.ClientId)
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgUpdateClient) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -233,9 +235,10 @@ func (msg MsgUpgradeClient) ValidateBasic() error {
return host.ClientIdentifierValidator(msg.ClientId)
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgUpgradeClient) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -299,10 +302,10 @@ func (msg MsgSubmitMisbehaviour) ValidateBasic() error {
return host.ClientIdentifierValidator(msg.ClientId)
}

// GetSignBytes returns the raw bytes a signer is expected to sign when submitting
// a MsgSubmitMisbehaviour message.
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgSubmitMisbehaviour) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners returns the single expected signer for a MsgSubmitMisbehaviour.
Expand Down
20 changes: 12 additions & 8 deletions x/ibc/core/03-connection/types/msgs.go
Original file line number Diff line number Diff line change
Expand Up @@ -58,9 +58,10 @@ func (msg MsgConnectionOpenInit) ValidateBasic() error {
return msg.Counterparty.ValidateBasic()
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgConnectionOpenInit) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -172,9 +173,10 @@ func (msg MsgConnectionOpenTry) UnpackInterfaces(unpacker codectypes.AnyUnpacker
return nil
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgConnectionOpenTry) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -268,9 +270,10 @@ func (msg MsgConnectionOpenAck) ValidateBasic() error {
return nil
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgConnectionOpenAck) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -325,9 +328,10 @@ func (msg MsgConnectionOpenConfirm) ValidateBasic() error {
return nil
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgConnectionOpenConfirm) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down
50 changes: 30 additions & 20 deletions x/ibc/core/04-channel/types/msgs.go
Original file line number Diff line number Diff line change
Expand Up @@ -50,9 +50,10 @@ func (msg MsgChannelOpenInit) ValidateBasic() error {
return msg.Channel.ValidateBasic()
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgChannelOpenInit) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -118,9 +119,10 @@ func (msg MsgChannelOpenTry) ValidateBasic() error {
return msg.Channel.ValidateBasic()
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgChannelOpenTry) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -182,9 +184,10 @@ func (msg MsgChannelOpenAck) ValidateBasic() error {
return nil
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgChannelOpenAck) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -241,9 +244,10 @@ func (msg MsgChannelOpenConfirm) ValidateBasic() error {
return nil
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgChannelOpenConfirm) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -291,9 +295,10 @@ func (msg MsgChannelCloseInit) ValidateBasic() error {
return nil
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgChannelCloseInit) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -350,9 +355,10 @@ func (msg MsgChannelCloseConfirm) ValidateBasic() error {
return nil
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgChannelCloseConfirm) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -400,9 +406,10 @@ func (msg MsgRecvPacket) ValidateBasic() error {
return msg.Packet.ValidateBasic()
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgRecvPacket) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetDataSignBytes returns the base64-encoded bytes used for the
Expand Down Expand Up @@ -463,9 +470,10 @@ func (msg MsgTimeout) ValidateBasic() error {
return msg.Packet.ValidateBasic()
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgTimeout) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -522,9 +530,10 @@ func (msg MsgTimeoutOnClose) ValidateBasic() error {
return msg.Packet.ValidateBasic()
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgTimeoutOnClose) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down Expand Up @@ -576,9 +585,10 @@ func (msg MsgAcknowledgement) ValidateBasic() error {
return msg.Packet.ValidateBasic()
}

// GetSignBytes implements sdk.Msg
// GetSignBytes implements sdk.Msg. The function will panic since it is used
// for amino transaction verification which IBC does not support.
func (msg MsgAcknowledgement) GetSignBytes() []byte {
return sdk.MustSortJSON(SubModuleCdc.MustMarshalJSON(&msg))
panic("IBC messages do not support amino")
}

// GetSigners implements sdk.Msg
Expand Down
12 changes: 0 additions & 12 deletions x/ibc/core/04-channel/types/msgs_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -346,18 +346,6 @@ func (suite *TypesTestSuite) TestMsgRecvPacketValidateBasic() {
}
}

func (suite *TypesTestSuite) TestMsgRecvPacketGetSignBytes() {
msg := types.NewMsgRecvPacket(packet, suite.proof, height, addr)
res := msg.GetSignBytes()

expected := fmt.Sprintf(
`{"packet":{"data":%s,"destination_channel":"testcpchannel","destination_port":"testcpport","sequence":"1","source_channel":"testchannel","source_port":"testportid","timeout_height":{"version_height":"100","version_number":"0"},"timeout_timestamp":"100"},"proof":"Co0BCi4KCmljczIzOmlhdmwSA0tFWRobChkKA0tFWRIFVkFMVUUaCwgBGAEgASoDAAICClsKDGljczIzOnNpbXBsZRIMaWF2bFN0b3JlS2V5Gj0KOwoMaWF2bFN0b3JlS2V5EiAcIiDXSHQRSvh/Wa07MYpTK0B4XtbaXtzxBED76xk0WhoJCAEYASABKgEA","proof_height":{"version_height":"1","version_number":"0"},"signer":"%s"}`,
string(msg.GetDataSignBytes()),
addr.String(),
)
suite.Equal(expected, string(res))
}

func (suite *TypesTestSuite) TestMsgRecvPacketGetSigners() {
msg := types.NewMsgRecvPacket(packet, suite.proof, height, addr)
res := msg.GetSigners()
Expand Down
10 changes: 0 additions & 10 deletions x/ibc/core/23-commitment/types/codec.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package types

import (
"github.com/cosmos/cosmos-sdk/codec"
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
"github.com/cosmos/cosmos-sdk/x/ibc/core/exported"
)
Expand Down Expand Up @@ -42,12 +41,3 @@ func RegisterInterfaces(registry codectypes.InterfaceRegistry) {
&MerkleProof{},
)
}

var (
// SubModuleCdc references the global x/ibc/core/23-commitmentl module codec. Note, the codec should
// ONLY be used in certain instances of tests and for JSON encoding.
//
// The actual codec used for serialization should be provided to x/ibc/core/23-commitmentl and
// defined at the application level.
SubModuleCdc = codec.NewProtoCodec(codectypes.NewInterfaceRegistry())
)
9 changes: 0 additions & 9 deletions x/ibc/light-clients/06-solomachine/types/codec.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,15 +30,6 @@ func RegisterInterfaces(registry codectypes.InterfaceRegistry) {
)
}

var (
// SubModuleCdc references the global x/ibc/light-clients/06-solomachine module codec. Note, the codec
// should ONLY be used in certain instances of tests and for JSON encoding.
//
// The actual codec used for serialization should be provided to x/ibc/light-clients/06-solomachine and
// defined at the application level.
SubModuleCdc = codec.NewProtoCodec(codectypes.NewInterfaceRegistry())
)

func UnmarshalSignatureData(cdc codec.BinaryMarshaler, data []byte) (signing.SignatureData, error) {
protoSigData := &signing.SignatureDescriptor_Data{}
if err := cdc.UnmarshalBinaryBare(data, protoSigData); err != nil {
Expand Down
10 changes: 0 additions & 10 deletions x/ibc/light-clients/07-tendermint/types/codec.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package types

import (
"github.com/cosmos/cosmos-sdk/codec"
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
"github.com/cosmos/cosmos-sdk/x/ibc/core/exported"
)
Expand Down Expand Up @@ -30,12 +29,3 @@ func RegisterInterfaces(registry codectypes.InterfaceRegistry) {
&Header{},
)
}

var (
// SubModuleCdc references the global x/ibc/light-clients/07-tendermint module codec. Note, the codec should
// ONLY be used in certain instances of tests and for JSON encoding.
//
// The actual codec used for serialization should be provided to x/ibc/light-clients/07-tendermint and
// defined at the application level.
SubModuleCdc = codec.NewProtoCodec(codectypes.NewInterfaceRegistry())
)
8 changes: 0 additions & 8 deletions x/ibc/light-clients/09-localhost/types/codec.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package types

import (
"github.com/cosmos/cosmos-sdk/codec"
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
"github.com/cosmos/cosmos-sdk/x/ibc/core/exported"
)
Expand All @@ -14,10 +13,3 @@ func RegisterInterfaces(registry codectypes.InterfaceRegistry) {
&ClientState{},
)
}

var (
// SubModuleCdc references the global x/ibc/light-clients/09-localhost module codec.
// The actual codec used for serialization should be provided to x/ibc/light-clients/09-localhost and
// defined at the application level.
SubModuleCdc = codec.NewProtoCodec(codectypes.NewInterfaceRegistry())
)

0 comments on commit e4378e7

Please sign in to comment.