From dce76d20c1bfb5ddeb113ff8bb5143a06465a187 Mon Sep 17 00:00:00 2001 From: srdtrk <59252793+srdtrk@users.noreply.github.com> Date: Fri, 19 Jul 2024 09:21:59 +0200 Subject: [PATCH 01/33] imp(02-client,03-connection)!: remove `ValidateSelfClient` (#6853) * imp: removed ValidateSelfClient * docs: updated a godoc --- modules/core/02-client/keeper/keeper.go | 8 - modules/core/02-client/types/client.go | 1 - .../core/03-connection/keeper/handshake.go | 10 -- .../03-connection/keeper/handshake_test.go | 18 --- .../03-connection/types/expected_keepers.go | 1 - .../07-tendermint/consensus_host.go | 71 --------- .../07-tendermint/consensus_host_test.go | 139 ------------------ .../08-wasm/types/consensus_host.go | 24 +-- .../08-wasm/types/consensus_host_test.go | 71 --------- testing/mock/consensus_host.go | 9 -- 10 files changed, 1 insertion(+), 351 deletions(-) diff --git a/modules/core/02-client/keeper/keeper.go b/modules/core/02-client/keeper/keeper.go index 65c54f2f298..f05bfe65be2 100644 --- a/modules/core/02-client/keeper/keeper.go +++ b/modules/core/02-client/keeper/keeper.go @@ -322,14 +322,6 @@ func (k *Keeper) GetSelfConsensusState(ctx sdk.Context, height exported.Height) return k.consensusHost.GetSelfConsensusState(ctx, height) } -// ValidateSelfClient validates the client parameters for a client of the running chain. -// This function is only used to validate the client state the counterparty stores for this chain. -// NOTE: If the client type is not of type Tendermint then delegate to a custom client validator function. -// This allows support for non-Tendermint clients, for example 08-wasm clients. -func (k *Keeper) ValidateSelfClient(ctx sdk.Context, clientState exported.ClientState) error { - return k.consensusHost.ValidateSelfClient(ctx, clientState) -} - // VerifyMembershipProof retrieves the light client module for the clientID and verifies the proof of the existence of a key-value pair at a specified height. func (k *Keeper) VerifyMembershipProof(ctx sdk.Context, clientID string, height exported.Height, delayTimePeriod uint64, delayBlockPeriod uint64, proof []byte, path exported.Path, value []byte) error { clientModule, err := k.Route(ctx, clientID) diff --git a/modules/core/02-client/types/client.go b/modules/core/02-client/types/client.go index 993f43d570a..6e9dbc99404 100644 --- a/modules/core/02-client/types/client.go +++ b/modules/core/02-client/types/client.go @@ -25,7 +25,6 @@ var ( // ConsensusHost defines an interface used to validate an IBC ClientState and ConsensusState against the host chain's underlying consensus parameters. type ConsensusHost interface { GetSelfConsensusState(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) - ValidateSelfClient(ctx sdk.Context, clientState exported.ClientState) error } // NewIdentifiedClientState creates a new IdentifiedClientState instance diff --git a/modules/core/03-connection/keeper/handshake.go b/modules/core/03-connection/keeper/handshake.go index e43733e4ed9..3ae100c7592 100644 --- a/modules/core/03-connection/keeper/handshake.go +++ b/modules/core/03-connection/keeper/handshake.go @@ -88,11 +88,6 @@ func (k *Keeper) ConnOpenTry( ) } - // validate client parameters of a chainB client stored on chainA - if err := k.clientKeeper.ValidateSelfClient(ctx, clientState); err != nil { - return "", err - } - expectedConsensusState, err := k.clientKeeper.GetSelfConsensusState(ctx, consensusHeight) if err != nil { return "", errorsmod.Wrapf(err, "self consensus state not found for height %s", consensusHeight.String()) @@ -199,11 +194,6 @@ func (k *Keeper) ConnOpenAck( ) } - // validate client parameters of a chainA client stored on chainB - if err := k.clientKeeper.ValidateSelfClient(ctx, clientState); err != nil { - return err - } - // Retrieve chainA's consensus state at consensusheight expectedConsensusState, err := k.clientKeeper.GetSelfConsensusState(ctx, consensusHeight) if err != nil { diff --git a/modules/core/03-connection/keeper/handshake_test.go b/modules/core/03-connection/keeper/handshake_test.go index f697a2cf27a..5a9e456a996 100644 --- a/modules/core/03-connection/keeper/handshake_test.go +++ b/modules/core/03-connection/keeper/handshake_test.go @@ -3,15 +3,12 @@ package keeper_test import ( "time" - sdk "github.com/cosmos/cosmos-sdk/types" - clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" "github.com/cosmos/ibc-go/v9/modules/core/03-connection/types" host "github.com/cosmos/ibc-go/v9/modules/core/24-host" "github.com/cosmos/ibc-go/v9/modules/core/exported" ibctm "github.com/cosmos/ibc-go/v9/modules/light-clients/07-tendermint" ibctesting "github.com/cosmos/ibc-go/v9/testing" - "github.com/cosmos/ibc-go/v9/testing/mock" ) // TestConnOpenInit - chainA initializes (INIT state) a connection with @@ -220,21 +217,6 @@ func (suite *KeeperTestSuite) TestConnOpenTry() { err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) }, false}, - {"override self consensus host", func() { - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) - - // retrieve client state of chainA to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) - - mockValidator := mock.ConsensusHost{ - ValidateSelfClientFn: func(ctx sdk.Context, clientState exported.ClientState) error { - return mock.MockApplicationCallbackError - }, - } - - suite.chainB.App.GetIBCKeeper().SetConsensusHost(&mockValidator) - }, false}, } for _, tc := range testCases { diff --git a/modules/core/03-connection/types/expected_keepers.go b/modules/core/03-connection/types/expected_keepers.go index 90a7d85f237..01e9970699d 100644 --- a/modules/core/03-connection/types/expected_keepers.go +++ b/modules/core/03-connection/types/expected_keepers.go @@ -13,7 +13,6 @@ type ClientKeeper interface { GetClientState(ctx sdk.Context, clientID string) (exported.ClientState, bool) GetClientConsensusState(ctx sdk.Context, clientID string, height exported.Height) (exported.ConsensusState, bool) GetSelfConsensusState(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) - ValidateSelfClient(ctx sdk.Context, clientState exported.ClientState) error VerifyMembershipProof(ctx sdk.Context, clientID string, height exported.Height, delayTimePeriod uint64, delayBlockPeriod uint64, proof []byte, path exported.Path, value []byte) error VerifyNonMembership(ctx sdk.Context, clientID string, height exported.Height, delayTimePeriod uint64, delayBlockPeriod uint64, proof []byte, path exported.Path) error IterateClientStates(ctx sdk.Context, prefix []byte, cb func(string, exported.ClientState) bool) diff --git a/modules/light-clients/07-tendermint/consensus_host.go b/modules/light-clients/07-tendermint/consensus_host.go index fb7d8dc66a3..051f5c81887 100644 --- a/modules/light-clients/07-tendermint/consensus_host.go +++ b/modules/light-clients/07-tendermint/consensus_host.go @@ -2,17 +2,13 @@ package tendermint import ( "context" - "reflect" "time" errorsmod "cosmossdk.io/errors" - upgradetypes "cosmossdk.io/x/upgrade/types" sdk "github.com/cosmos/cosmos-sdk/types" stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" - "github.com/cometbft/cometbft/light" - clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" commitmenttypes "github.com/cosmos/ibc-go/v9/modules/core/23-commitment/types" ibcerrors "github.com/cosmos/ibc-go/v9/modules/core/errors" @@ -69,70 +65,3 @@ func (c *ConsensusHost) GetSelfConsensusState(ctx sdk.Context, height exported.H return consensusState, nil } - -// ValidateSelfClient implements the 02-client clienttypes.ConsensusHost interface. -func (c *ConsensusHost) ValidateSelfClient(ctx sdk.Context, clientState exported.ClientState) error { - tmClient, ok := clientState.(*ClientState) - if !ok { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "client must be a Tendermint client, expected: %T, got: %T", &ClientState{}, tmClient) - } - - if !tmClient.FrozenHeight.IsZero() { - return clienttypes.ErrClientFrozen - } - - if ctx.ChainID() != tmClient.ChainId { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "invalid chain-id. expected: %s, got: %s", - ctx.ChainID(), tmClient.ChainId) - } - - revision := clienttypes.ParseChainID(ctx.ChainID()) - - // client must be in the same revision as executing chain - if tmClient.LatestHeight.RevisionNumber != revision { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "client is not in the same revision as the chain. expected revision: %d, got: %d", - tmClient.LatestHeight.RevisionNumber, revision) - } - - selfHeight := clienttypes.NewHeight(revision, uint64(ctx.BlockHeight())) - if tmClient.LatestHeight.GTE(selfHeight) { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "client has LatestHeight %d greater than or equal to chain height %d", - tmClient.LatestHeight, selfHeight) - } - - expectedProofSpecs := commitmenttypes.GetSDKSpecs() - if !reflect.DeepEqual(expectedProofSpecs, tmClient.ProofSpecs) { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "client has invalid proof specs. expected: %v got: %v", - expectedProofSpecs, tmClient.ProofSpecs) - } - - if err := light.ValidateTrustLevel(tmClient.TrustLevel.ToTendermint()); err != nil { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "trust-level invalid: %v", err) - } - - expectedUbdPeriod, err := c.stakingKeeper.UnbondingTime(ctx) - if err != nil { - return errorsmod.Wrapf(err, "failed to retrieve unbonding period") - } - - if expectedUbdPeriod != tmClient.UnbondingPeriod { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "invalid unbonding period. expected: %s, got: %s", - expectedUbdPeriod, tmClient.UnbondingPeriod) - } - - if tmClient.UnbondingPeriod < tmClient.TrustingPeriod { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "unbonding period must be greater than trusting period. unbonding period (%d) < trusting period (%d)", - tmClient.UnbondingPeriod, tmClient.TrustingPeriod) - } - - if len(tmClient.UpgradePath) != 0 { - // For now, SDK IBC implementation assumes that upgrade path (if defined) is defined by SDK upgrade module - expectedUpgradePath := []string{upgradetypes.StoreKey, upgradetypes.KeyUpgradedIBCState} - if !reflect.DeepEqual(expectedUpgradePath, tmClient.UpgradePath) { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "upgrade path must be the upgrade path defined by upgrade module. expected %v, got %v", - expectedUpgradePath, tmClient.UpgradePath) - } - } - - return nil -} diff --git a/modules/light-clients/07-tendermint/consensus_host_test.go b/modules/light-clients/07-tendermint/consensus_host_test.go index f0dca0148df..87dbd474f10 100644 --- a/modules/light-clients/07-tendermint/consensus_host_test.go +++ b/modules/light-clients/07-tendermint/consensus_host_test.go @@ -5,11 +5,8 @@ import ( stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" - commitmenttypes "github.com/cosmos/ibc-go/v9/modules/core/23-commitment/types" "github.com/cosmos/ibc-go/v9/modules/core/exported" solomachine "github.com/cosmos/ibc-go/v9/modules/light-clients/06-solomachine" - ibctm "github.com/cosmos/ibc-go/v9/modules/light-clients/07-tendermint" - ibctesting "github.com/cosmos/ibc-go/v9/testing" "github.com/cosmos/ibc-go/v9/testing/mock" ) @@ -111,139 +108,3 @@ func (suite *TendermintTestSuite) TestGetSelfConsensusState() { }) } } - -func (suite *TendermintTestSuite) TestValidateSelfClient() { - testClientHeight := clienttypes.GetSelfHeight(suite.chainA.GetContext()) - testClientHeight.RevisionHeight-- - - var clientState exported.ClientState - - testCases := []struct { - name string - malleate func() - expError error - }{ - { - name: "success", - malleate: func() { - clientState = ibctm.NewClientState(suite.chainA.ChainID, ibctm.DefaultTrustLevel, trustingPeriod, ubdPeriod, maxClockDrift, testClientHeight, commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath) - }, - expError: nil, - }, - { - name: "success with nil UpgradePath", - malleate: func() { - clientState = ibctm.NewClientState(suite.chainA.ChainID, ibctm.DefaultTrustLevel, trustingPeriod, ubdPeriod, maxClockDrift, testClientHeight, commitmenttypes.GetSDKSpecs(), nil) - }, - expError: nil, - }, - { - name: "success with custom self validator: solomachine", - malleate: func() { - clientState = solomachine.NewClientState(1, &solomachine.ConsensusState{}) - - smConsensusHost := &mock.ConsensusHost{ - ValidateSelfClientFn: func(ctx sdk.Context, clientState exported.ClientState) error { - smClientState, ok := clientState.(*solomachine.ClientState) - suite.Require().True(ok) - suite.Require().Equal(uint64(1), smClientState.Sequence) - - return nil - }, - } - - // add mock validation logic - suite.chainA.App.GetIBCKeeper().SetConsensusHost(smConsensusHost) - }, - expError: nil, - }, - { - name: "frozen client", - malleate: func() { - clientState = &ibctm.ClientState{ChainId: suite.chainA.ChainID, TrustLevel: ibctm.DefaultTrustLevel, TrustingPeriod: trustingPeriod, UnbondingPeriod: ubdPeriod, MaxClockDrift: maxClockDrift, FrozenHeight: testClientHeight, LatestHeight: testClientHeight, ProofSpecs: commitmenttypes.GetSDKSpecs(), UpgradePath: ibctesting.UpgradePath} - }, - expError: clienttypes.ErrClientFrozen, - }, - { - name: "incorrect chainID", - malleate: func() { - clientState = ibctm.NewClientState("gaiatestnet", ibctm.DefaultTrustLevel, trustingPeriod, ubdPeriod, maxClockDrift, testClientHeight, commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath) - }, - expError: clienttypes.ErrInvalidClient, - }, - { - name: "invalid client height", - malleate: func() { - clientState = ibctm.NewClientState(suite.chainA.ChainID, ibctm.DefaultTrustLevel, trustingPeriod, ubdPeriod, maxClockDrift, clienttypes.GetSelfHeight(suite.chainA.GetContext()).Increment().(clienttypes.Height), commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath) - }, - expError: clienttypes.ErrInvalidClient, - }, - { - name: "invalid client type", - malleate: func() { - clientState = solomachine.NewClientState(0, &solomachine.ConsensusState{}) - }, - expError: clienttypes.ErrInvalidClient, - }, - { - name: "invalid client revision", - malleate: func() { - clientState = ibctm.NewClientState(suite.chainA.ChainID, ibctm.DefaultTrustLevel, trustingPeriod, ubdPeriod, maxClockDrift, clienttypes.NewHeight(1, 5), commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath) - }, - expError: clienttypes.ErrInvalidClient, - }, - { - name: "invalid proof specs", - malleate: func() { - clientState = ibctm.NewClientState(suite.chainA.ChainID, ibctm.DefaultTrustLevel, trustingPeriod, ubdPeriod, maxClockDrift, testClientHeight, nil, ibctesting.UpgradePath) - }, - expError: clienttypes.ErrInvalidClient, - }, - { - name: "invalid trust level", - malleate: func() { - clientState = ibctm.NewClientState(suite.chainA.ChainID, ibctm.Fraction{Numerator: 0, Denominator: 1}, trustingPeriod, ubdPeriod, maxClockDrift, testClientHeight, commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath) - }, - expError: clienttypes.ErrInvalidClient, - }, - { - name: "invalid unbonding period", - malleate: func() { - clientState = ibctm.NewClientState(suite.chainA.ChainID, ibctm.DefaultTrustLevel, trustingPeriod, ubdPeriod+10, maxClockDrift, testClientHeight, commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath) - }, - expError: clienttypes.ErrInvalidClient, - }, - { - name: "invalid trusting period", - malleate: func() { - clientState = ibctm.NewClientState(suite.chainA.ChainID, ibctm.DefaultTrustLevel, ubdPeriod+10, ubdPeriod, maxClockDrift, testClientHeight, commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath) - }, - expError: clienttypes.ErrInvalidClient, - }, - { - name: "invalid upgrade path", - malleate: func() { - clientState = ibctm.NewClientState(suite.chainA.ChainID, ibctm.DefaultTrustLevel, trustingPeriod, ubdPeriod, maxClockDrift, testClientHeight, commitmenttypes.GetSDKSpecs(), []string{"bad", "upgrade", "path"}) - }, - expError: clienttypes.ErrInvalidClient, - }, - } - - for _, tc := range testCases { - tc := tc - suite.Run(tc.name, func() { - suite.SetupTest() - - tc.malleate() - - err := suite.chainA.App.GetIBCKeeper().ClientKeeper.ValidateSelfClient(suite.chainA.GetContext(), clientState) - - expPass := tc.expError == nil - if expPass { - suite.Require().NoError(err, "expected valid client for case: %s", tc.name) - } else { - suite.Require().Error(err, "expected invalid client for case: %s", tc.name) - } - }) - } -} diff --git a/modules/light-clients/08-wasm/types/consensus_host.go b/modules/light-clients/08-wasm/types/consensus_host.go index 2cdfe189243..37fc17d5211 100644 --- a/modules/light-clients/08-wasm/types/consensus_host.go +++ b/modules/light-clients/08-wasm/types/consensus_host.go @@ -3,8 +3,6 @@ package types import ( "errors" - errorsmod "cosmossdk.io/errors" - "github.com/cosmos/cosmos-sdk/codec" sdk "github.com/cosmos/cosmos-sdk/types" @@ -20,7 +18,7 @@ type WasmConsensusHost struct { var _ clienttypes.ConsensusHost = (*WasmConsensusHost)(nil) -// NewWasmConsensusHost creates and returns a new ConsensusHost for wasm wrapped consensus client state and consensus state self validation. +// NewWasmConsensusHost creates and returns a new ConsensusHost for wasm wrapped consensus client state. func NewWasmConsensusHost(cdc codec.BinaryCodec, delegate clienttypes.ConsensusHost) (*WasmConsensusHost, error) { if cdc == nil { return nil, errors.New("wasm consensus host codec is nil") @@ -55,23 +53,3 @@ func (w *WasmConsensusHost) GetSelfConsensusState(ctx sdk.Context, height export return wasmConsensusState, nil } - -// ValidateSelfClient implements the 02-client types.ConsensusHost interface. -func (w *WasmConsensusHost) ValidateSelfClient(ctx sdk.Context, clientState exported.ClientState) error { - wasmClientState, ok := clientState.(*ClientState) - if !ok { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "client must be a wasm client, expected: %T, got: %T", ClientState{}, wasmClientState) - } - - if wasmClientState.Data == nil { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "wasm client state data is nil") - } - - // unmarshal the wasmClientState bytes into the ClientState interface and call self validation - var unwrappedClientState exported.ClientState - if err := w.cdc.UnmarshalInterface(wasmClientState.Data, &unwrappedClientState); err != nil { - return err - } - - return w.delegate.ValidateSelfClient(ctx, unwrappedClientState) -} diff --git a/modules/light-clients/08-wasm/types/consensus_host_test.go b/modules/light-clients/08-wasm/types/consensus_host_test.go index d85c8143191..d3e5629ab51 100644 --- a/modules/light-clients/08-wasm/types/consensus_host_test.go +++ b/modules/light-clients/08-wasm/types/consensus_host_test.go @@ -7,7 +7,6 @@ import ( "github.com/cosmos/ibc-go/modules/light-clients/08-wasm/types" clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" "github.com/cosmos/ibc-go/v9/modules/core/exported" - ibctm "github.com/cosmos/ibc-go/v9/modules/light-clients/07-tendermint" "github.com/cosmos/ibc-go/v9/testing/mock" ) @@ -76,73 +75,3 @@ func (suite *TypesTestSuite) TestGetSelfConsensusState() { }) } } - -func (suite *TypesTestSuite) TestValidateSelfClient() { - var ( - mockChecksum = []byte("checksum") - clientState exported.ClientState - consensusHost clienttypes.ConsensusHost - ) - - testCases := []struct { - name string - malleate func() - expError error - }{ - { - name: "success", - malleate: func() {}, - expError: nil, - }, - { - name: "failure: invalid data", - malleate: func() { - clientState = types.NewClientState(nil, wasmtesting.Code, clienttypes.ZeroHeight()) - }, - expError: clienttypes.ErrInvalidClient, - }, - { - name: "failure: invalid clientstate type", - malleate: func() { - clientState = &ibctm.ClientState{} - }, - expError: clienttypes.ErrInvalidClient, - }, - { - name: "failure: delegate error propagates", - malleate: func() { - consensusHost.(*mock.ConsensusHost).ValidateSelfClientFn = func(ctx sdk.Context, clientState exported.ClientState) error { - return mock.MockApplicationCallbackError - } - }, - expError: mock.MockApplicationCallbackError, - }, - } - - for _, tc := range testCases { - tc := tc - suite.Run(tc.name, func() { - suite.SetupTest() - - clientState = types.NewClientState(wasmtesting.CreateMockClientStateBz(suite.chainA.Codec, mockChecksum), wasmtesting.Code, clienttypes.ZeroHeight()) - consensusHost = &mock.ConsensusHost{} - - tc.malleate() - - var err error - consensusHost, err = types.NewWasmConsensusHost(suite.chainA.Codec, consensusHost) - suite.Require().NoError(err) - - suite.chainA.App.GetIBCKeeper().ClientKeeper.SetConsensusHost(consensusHost) - - err = suite.chainA.App.GetIBCKeeper().ClientKeeper.ValidateSelfClient(suite.chainA.GetContext(), clientState) - - expPass := tc.expError == nil - if expPass { - suite.Require().NoError(err, "expected valid client for case: %s", tc.name) - } else { - suite.Require().ErrorIs(err, tc.expError, "expected %s got %s", tc.expError, err) - } - }) - } -} diff --git a/testing/mock/consensus_host.go b/testing/mock/consensus_host.go index 00d0773a3cc..504885c6a64 100644 --- a/testing/mock/consensus_host.go +++ b/testing/mock/consensus_host.go @@ -11,7 +11,6 @@ var _ clienttypes.ConsensusHost = (*ConsensusHost)(nil) type ConsensusHost struct { GetSelfConsensusStateFn func(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) - ValidateSelfClientFn func(ctx sdk.Context, clientState exported.ClientState) error } func (cv *ConsensusHost) GetSelfConsensusState(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) { @@ -21,11 +20,3 @@ func (cv *ConsensusHost) GetSelfConsensusState(ctx sdk.Context, height exported. return cv.GetSelfConsensusStateFn(ctx, height) } - -func (cv *ConsensusHost) ValidateSelfClient(ctx sdk.Context, clientState exported.ClientState) error { - if cv.ValidateSelfClientFn == nil { - return nil - } - - return cv.ValidateSelfClientFn(ctx, clientState) -} From 9af4a223253d9756a6bbd929c74b12e85d98ca5d Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 13:32:17 +0800 Subject: [PATCH 02/33] imp: deleted consensus host from core --- modules/core/02-client/keeper/keeper.go | 20 +-- modules/core/02-client/types/client.go | 6 - .../core/03-connection/keeper/handshake.go | 35 ----- modules/core/03-connection/keeper/verify.go | 73 ---------- .../core/03-connection/keeper/verify_test.go | 136 ------------------ .../03-connection/types/expected_keepers.go | 1 - modules/core/keeper/keeper.go | 17 +-- modules/core/keeper/keeper_test.go | 16 --- .../07-tendermint/consensus_host.go | 67 --------- .../07-tendermint/consensus_host_test.go | 110 -------------- testing/mock/consensus_host.go | 22 --- testing/simapp/app.go | 2 +- 12 files changed, 4 insertions(+), 501 deletions(-) delete mode 100644 modules/light-clients/07-tendermint/consensus_host.go delete mode 100644 modules/light-clients/07-tendermint/consensus_host_test.go delete mode 100644 testing/mock/consensus_host.go diff --git a/modules/core/02-client/keeper/keeper.go b/modules/core/02-client/keeper/keeper.go index f05bfe65be2..491d72876b5 100644 --- a/modules/core/02-client/keeper/keeper.go +++ b/modules/core/02-client/keeper/keeper.go @@ -27,13 +27,12 @@ type Keeper struct { storeKey storetypes.StoreKey cdc codec.BinaryCodec router *types.Router - consensusHost types.ConsensusHost legacySubspace types.ParamSubspace upgradeKeeper types.UpgradeKeeper } // NewKeeper creates a new NewKeeper instance -func NewKeeper(cdc codec.BinaryCodec, key storetypes.StoreKey, legacySubspace types.ParamSubspace, consensusHost types.ConsensusHost, uk types.UpgradeKeeper) *Keeper { +func NewKeeper(cdc codec.BinaryCodec, key storetypes.StoreKey, legacySubspace types.ParamSubspace, uk types.UpgradeKeeper) *Keeper { router := types.NewRouter() localhostModule := localhost.NewLightClientModule(cdc, key) router.AddRoute(exported.Localhost, localhostModule) @@ -42,7 +41,6 @@ func NewKeeper(cdc codec.BinaryCodec, key storetypes.StoreKey, legacySubspace ty storeKey: key, cdc: cdc, router: router, - consensusHost: consensusHost, legacySubspace: legacySubspace, upgradeKeeper: uk, } @@ -90,15 +88,6 @@ func (k *Keeper) Route(ctx sdk.Context, clientID string) (exported.LightClientMo return clientModule, nil } -// SetConsensusHost sets a custom ConsensusHost for self client state and consensus state validation. -func (k *Keeper) SetConsensusHost(consensusHost types.ConsensusHost) { - if consensusHost == nil { - panic(errors.New("cannot set a nil self consensus host")) - } - - k.consensusHost = consensusHost -} - // GenerateClientIdentifier returns the next client identifier. func (k *Keeper) GenerateClientIdentifier(ctx sdk.Context, clientType string) string { nextClientSeq := k.GetNextClientSequence(ctx) @@ -315,13 +304,6 @@ func (k *Keeper) GetLatestClientConsensusState(ctx sdk.Context, clientID string) return k.GetClientConsensusState(ctx, clientID, clientModule.LatestHeight(ctx, clientID)) } -// GetSelfConsensusState introspects the (self) past historical info at a given height -// and returns the expected consensus state at that height. -// For now, can only retrieve self consensus states for the current revision -func (k *Keeper) GetSelfConsensusState(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) { - return k.consensusHost.GetSelfConsensusState(ctx, height) -} - // VerifyMembershipProof retrieves the light client module for the clientID and verifies the proof of the existence of a key-value pair at a specified height. func (k *Keeper) VerifyMembershipProof(ctx sdk.Context, clientID string, height exported.Height, delayTimePeriod uint64, delayBlockPeriod uint64, proof []byte, path exported.Path, value []byte) error { clientModule, err := k.Route(ctx, clientID) diff --git a/modules/core/02-client/types/client.go b/modules/core/02-client/types/client.go index 6e9dbc99404..6e3df24694e 100644 --- a/modules/core/02-client/types/client.go +++ b/modules/core/02-client/types/client.go @@ -11,7 +11,6 @@ import ( errorsmod "cosmossdk.io/errors" codectypes "github.com/cosmos/cosmos-sdk/codec/types" - sdk "github.com/cosmos/cosmos-sdk/types" host "github.com/cosmos/ibc-go/v9/modules/core/24-host" "github.com/cosmos/ibc-go/v9/modules/core/exported" @@ -22,11 +21,6 @@ var ( _ codectypes.UnpackInterfacesMessage = (*ConsensusStateWithHeight)(nil) ) -// ConsensusHost defines an interface used to validate an IBC ClientState and ConsensusState against the host chain's underlying consensus parameters. -type ConsensusHost interface { - GetSelfConsensusState(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) -} - // NewIdentifiedClientState creates a new IdentifiedClientState instance func NewIdentifiedClientState(clientID string, clientState exported.ClientState) IdentifiedClientState { msg, ok := clientState.(proto.Message) diff --git a/modules/core/03-connection/keeper/handshake.go b/modules/core/03-connection/keeper/handshake.go index 3ae100c7592..dc716de2a5c 100644 --- a/modules/core/03-connection/keeper/handshake.go +++ b/modules/core/03-connection/keeper/handshake.go @@ -88,11 +88,6 @@ func (k *Keeper) ConnOpenTry( ) } - expectedConsensusState, err := k.clientKeeper.GetSelfConsensusState(ctx, consensusHeight) - if err != nil { - return "", errorsmod.Wrapf(err, "self consensus state not found for height %s", consensusHeight.String()) - } - // expectedConnection defines Chain A's ConnectionEnd // NOTE: chain A's counterparty is chain B (i.e where this code is executed) // NOTE: chainA and chainB must have the same delay period @@ -119,18 +114,6 @@ func (k *Keeper) ConnOpenTry( return "", err } - // Check that ChainA stored the clientState provided in the msg - if err := k.VerifyClientState(ctx, connection, proofHeight, clientProof, clientState); err != nil { - return "", err - } - - // Check that ChainA stored the correct ConsensusState of chainB at the given consensusHeight - if err := k.VerifyClientConsensusState( - ctx, connection, proofHeight, consensusHeight, consensusProof, expectedConsensusState, - ); err != nil { - return "", err - } - // store connection in chainB state if err := k.addConnectionToClient(ctx, clientID, connectionID); err != nil { return "", errorsmod.Wrapf(err, "failed to add connection with ID %s to client with ID %s", connectionID, clientID) @@ -194,12 +177,6 @@ func (k *Keeper) ConnOpenAck( ) } - // Retrieve chainA's consensus state at consensusheight - expectedConsensusState, err := k.clientKeeper.GetSelfConsensusState(ctx, consensusHeight) - if err != nil { - return errorsmod.Wrapf(err, "self consensus state not found for height %s", consensusHeight.String()) - } - prefix := k.GetCommitmentPrefix() expectedCounterparty := types.NewCounterparty(connection.ClientId, connectionID, commitmenttypes.NewMerklePrefix(prefix.Bytes())) expectedConnection := types.NewConnectionEnd(types.TRYOPEN, connection.Counterparty.ClientId, expectedCounterparty, []*types.Version{version}, connection.DelayPeriod) @@ -212,18 +189,6 @@ func (k *Keeper) ConnOpenAck( return err } - // Check that ChainB stored the clientState provided in the msg - if err := k.VerifyClientState(ctx, connection, proofHeight, clientProof, clientState); err != nil { - return err - } - - // Ensure that ChainB has stored the correct ConsensusState for chainA at the consensusHeight - if err := k.VerifyClientConsensusState( - ctx, connection, proofHeight, consensusHeight, consensusProof, expectedConsensusState, - ); err != nil { - return err - } - k.Logger(ctx).Info("connection state updated", "connection-id", connectionID, "previous-state", types.INIT, "new-state", types.OPEN) defer telemetry.IncrCounter(1, "ibc", "connection", "open-ack") diff --git a/modules/core/03-connection/keeper/verify.go b/modules/core/03-connection/keeper/verify.go index fe2894dd7bb..fece92609f2 100644 --- a/modules/core/03-connection/keeper/verify.go +++ b/modules/core/03-connection/keeper/verify.go @@ -15,79 +15,6 @@ import ( "github.com/cosmos/ibc-go/v9/modules/core/exported" ) -// VerifyClientState verifies a proof of a client state of the running machine -// stored on the target machine -func (k *Keeper) VerifyClientState( - ctx sdk.Context, - connection types.ConnectionEnd, - height exported.Height, - proof []byte, - clientState exported.ClientState, -) error { - clientID := connection.ClientId - if status := k.clientKeeper.GetClientStatus(ctx, clientID); status != exported.Active { - return errorsmod.Wrapf(clienttypes.ErrClientNotActive, "client (%s) status is %s", clientID, status) - } - - merklePath := commitmenttypes.NewMerklePath(host.FullClientStateKey(connection.Counterparty.ClientId)) - merklePath, err := commitmenttypes.ApplyPrefix(connection.Counterparty.Prefix, merklePath) - if err != nil { - return err - } - - bz, err := k.cdc.MarshalInterface(clientState) - if err != nil { - return err - } - - if err := k.clientKeeper.VerifyMembershipProof( - ctx, clientID, height, - 0, 0, // skip delay period checks for non-packet processing verification - proof, merklePath, bz, - ); err != nil { - return errorsmod.Wrapf(err, "failed client state verification for target client: %s", clientID) - } - - return nil -} - -// VerifyClientConsensusState verifies a proof of the consensus state of the -// specified client stored on the target machine. -func (k *Keeper) VerifyClientConsensusState( - ctx sdk.Context, - connection types.ConnectionEnd, - height exported.Height, - consensusHeight exported.Height, - proof []byte, - consensusState exported.ConsensusState, -) error { - clientID := connection.ClientId - if status := k.clientKeeper.GetClientStatus(ctx, clientID); status != exported.Active { - return errorsmod.Wrapf(clienttypes.ErrClientNotActive, "client (%s) status is %s", clientID, status) - } - - merklePath := commitmenttypes.NewMerklePath(host.FullConsensusStateKey(connection.Counterparty.ClientId, consensusHeight)) - merklePath, err := commitmenttypes.ApplyPrefix(connection.Counterparty.Prefix, merklePath) - if err != nil { - return err - } - - bz, err := k.cdc.MarshalInterface(consensusState) - if err != nil { - return err - } - - if err := k.clientKeeper.VerifyMembershipProof( - ctx, clientID, height, - 0, 0, // skip delay period checks for non-packet processing verification - proof, merklePath, bz, - ); err != nil { - return errorsmod.Wrapf(err, "failed consensus state verification for client (%s)", clientID) - } - - return nil -} - // VerifyConnectionState verifies a proof of the connection state of the // specified connection end stored on the target machine. func (k *Keeper) VerifyConnectionState( diff --git a/modules/core/03-connection/keeper/verify_test.go b/modules/core/03-connection/keeper/verify_test.go index 00fb18c7335..b7e439442ad 100644 --- a/modules/core/03-connection/keeper/verify_test.go +++ b/modules/core/03-connection/keeper/verify_test.go @@ -16,142 +16,6 @@ import ( var defaultTimeoutHeight = clienttypes.NewHeight(1, 100000) -// TestVerifyClientState verifies a client state of chainA -// stored on path.EndpointB (which is on chainB) -func (suite *KeeperTestSuite) TestVerifyClientState() { - var ( - path *ibctesting.Path - heightDiff uint64 - ) - cases := []struct { - name string - malleate func() - expPass bool - }{ - {"verification success", func() {}, true}, - {"client state not found", func() { - path.EndpointA.UpdateConnection(func(c *types.ConnectionEnd) { c.ClientId = ibctesting.InvalidID }) - }, false}, - {"consensus state for proof height not found", func() { - heightDiff = 5 - }, false}, - {"verification failed", func() { - counterpartyClient, ok := path.EndpointB.GetClientState().(*ibctm.ClientState) - suite.Require().True(ok) - counterpartyClient.ChainId = "wrongChainID" - path.EndpointB.SetClientState(counterpartyClient) - }, false}, - {"client status is not active - client is expired", func() { - clientState, ok := path.EndpointA.GetClientState().(*ibctm.ClientState) - suite.Require().True(ok) - clientState.FrozenHeight = clienttypes.NewHeight(0, 1) - path.EndpointA.SetClientState(clientState) - }, false}, - } - - for _, tc := range cases { - tc := tc - - suite.Run(tc.name, func() { - suite.SetupTest() // reset - heightDiff = 0 // must be explicitly changed - - path = ibctesting.NewPath(suite.chainA, suite.chainB) - path.SetupConnections() - - tc.malleate() - - counterpartyClient, clientProof := path.EndpointB.QueryClientStateProof() - proofHeight := clienttypes.NewHeight(1, uint64(suite.chainB.GetContext().BlockHeight()-1)) - - connection := path.EndpointA.GetConnection() - - err := suite.chainA.App.GetIBCKeeper().ConnectionKeeper.VerifyClientState( - suite.chainA.GetContext(), connection, - malleateHeight(proofHeight, heightDiff), clientProof, counterpartyClient, - ) - - if tc.expPass { - suite.Require().NoError(err) - } else { - suite.Require().Error(err) - } - }) - } -} - -// TestVerifyClientConsensusState verifies that the consensus state of -// chainA stored on path.EndpointB.ClientID (which is on chainB) matches the consensus -// state for chainA at that height. -func (suite *KeeperTestSuite) TestVerifyClientConsensusState() { - var ( - path *ibctesting.Path - heightDiff uint64 - ) - cases := []struct { - name string - malleate func() - expPass bool - }{ - {"verification success", func() {}, true}, - {"client state not found", func() { - path.EndpointA.UpdateConnection(func(c *types.ConnectionEnd) { c.ClientId = ibctesting.InvalidID }) - }, false}, - {"consensus state not found", func() { - heightDiff = 5 - }, false}, - {"verification failed", func() { - // give chainB wrong consensus state for chainA - consState, found := suite.chainB.App.GetIBCKeeper().ClientKeeper.GetLatestClientConsensusState(suite.chainB.GetContext(), path.EndpointB.ClientID) - suite.Require().True(found) - - tmConsState, ok := consState.(*ibctm.ConsensusState) - suite.Require().True(ok) - - tmConsState.Timestamp = time.Now() - suite.chainB.App.GetIBCKeeper().ClientKeeper.SetClientConsensusState(suite.chainB.GetContext(), path.EndpointB.ClientID, path.EndpointB.GetClientLatestHeight(), tmConsState) - - suite.coordinator.CommitBlock(suite.chainB) - }, false}, - {"client status is not active - client is expired", func() { - clientState, ok := path.EndpointA.GetClientState().(*ibctm.ClientState) - suite.Require().True(ok) - clientState.FrozenHeight = clienttypes.NewHeight(0, 1) - path.EndpointA.SetClientState(clientState) - }, false}, - } - - for _, tc := range cases { - tc := tc - - suite.Run(tc.name, func() { - suite.SetupTest() // reset - heightDiff = 0 // must be explicitly changed in malleate - path = ibctesting.NewPath(suite.chainA, suite.chainB) - path.SetupConnections() - - tc.malleate() - - connection := path.EndpointA.GetConnection() - proof, consensusHeight := suite.chainB.QueryConsensusStateProof(path.EndpointB.ClientID) - proofHeight := clienttypes.NewHeight(1, uint64(suite.chainB.GetContext().BlockHeight()-1)) - consensusState, err := suite.chainA.App.GetIBCKeeper().ClientKeeper.GetSelfConsensusState(suite.chainA.GetContext(), consensusHeight) - suite.Require().NoError(err) - - err = suite.chainA.App.GetIBCKeeper().ConnectionKeeper.VerifyClientConsensusState( - suite.chainA.GetContext(), connection, - malleateHeight(proofHeight, heightDiff), consensusHeight, proof, consensusState, - ) - - if tc.expPass { - suite.Require().NoError(err) - } else { - suite.Require().Error(err) - } - }) - } -} - // TestVerifyConnectionState verifies the connection state of the connection // on chainB. The connections on chainA and chainB are fully opened. func (suite *KeeperTestSuite) TestVerifyConnectionState() { diff --git a/modules/core/03-connection/types/expected_keepers.go b/modules/core/03-connection/types/expected_keepers.go index 01e9970699d..3f8730d2b9f 100644 --- a/modules/core/03-connection/types/expected_keepers.go +++ b/modules/core/03-connection/types/expected_keepers.go @@ -12,7 +12,6 @@ type ClientKeeper interface { GetClientStatus(ctx sdk.Context, clientID string) exported.Status GetClientState(ctx sdk.Context, clientID string) (exported.ClientState, bool) GetClientConsensusState(ctx sdk.Context, clientID string, height exported.Height) (exported.ConsensusState, bool) - GetSelfConsensusState(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) VerifyMembershipProof(ctx sdk.Context, clientID string, height exported.Height, delayTimePeriod uint64, delayBlockPeriod uint64, proof []byte, path exported.Path, value []byte) error VerifyNonMembership(ctx sdk.Context, clientID string, height exported.Height, delayTimePeriod uint64, delayBlockPeriod uint64, proof []byte, path exported.Path) error IterateClientStates(ctx sdk.Context, prefix []byte, cb func(string, exported.ClientState) bool) diff --git a/modules/core/keeper/keeper.go b/modules/core/keeper/keeper.go index 0e89feee358..fed78a94888 100644 --- a/modules/core/keeper/keeper.go +++ b/modules/core/keeper/keeper.go @@ -34,14 +34,10 @@ type Keeper struct { // NewKeeper creates a new ibc Keeper func NewKeeper( cdc codec.BinaryCodec, key storetypes.StoreKey, paramSpace types.ParamSubspace, - consensusHost clienttypes.ConsensusHost, upgradeKeeper clienttypes.UpgradeKeeper, + upgradeKeeper clienttypes.UpgradeKeeper, scopedKeeper capabilitykeeper.ScopedKeeper, authority string, ) *Keeper { // panic if any of the keepers passed in is empty - if isEmpty(consensusHost) { - panic(errors.New("cannot initialize IBC keeper: empty consensus host")) - } - if isEmpty(upgradeKeeper) { panic(errors.New("cannot initialize IBC keeper: empty upgrade keeper")) } @@ -54,7 +50,7 @@ func NewKeeper( panic(errors.New("authority must be non-empty")) } - clientKeeper := clientkeeper.NewKeeper(cdc, key, paramSpace, consensusHost, upgradeKeeper) + clientKeeper := clientkeeper.NewKeeper(cdc, key, paramSpace, upgradeKeeper) connectionKeeper := connectionkeeper.NewKeeper(cdc, key, paramSpace, clientKeeper) portKeeper := portkeeper.NewKeeper(scopedKeeper) channelKeeper := channelkeeper.NewKeeper(cdc, key, clientKeeper, connectionKeeper, portKeeper, scopedKeeper) @@ -74,15 +70,6 @@ func (k *Keeper) Codec() codec.BinaryCodec { return k.cdc } -// SetConsensusHost sets a custom ConsensusHost for self client state and consensus state validation. -func (k *Keeper) SetConsensusHost(consensusHost clienttypes.ConsensusHost) { - if consensusHost == nil { - panic(errors.New("cannot set a nil self consensus host")) - } - - k.ClientKeeper.SetConsensusHost(consensusHost) -} - // SetRouter sets the Router in IBC Keeper and seals it. The method panics if // there is an existing router that's already sealed. func (k *Keeper) SetRouter(rtr *porttypes.Router) { diff --git a/modules/core/keeper/keeper_test.go b/modules/core/keeper/keeper_test.go index 282a8a4bc34..d7c7f8b6340 100644 --- a/modules/core/keeper/keeper_test.go +++ b/modules/core/keeper/keeper_test.go @@ -15,7 +15,6 @@ import ( clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" ibcexported "github.com/cosmos/ibc-go/v9/modules/core/exported" ibckeeper "github.com/cosmos/ibc-go/v9/modules/core/keeper" - ibctm "github.com/cosmos/ibc-go/v9/modules/light-clients/07-tendermint" ibctesting "github.com/cosmos/ibc-go/v9/testing" ) @@ -61,7 +60,6 @@ func (MockStakingKeeper) UnbondingTime(_ context.Context) (time.Duration, error) // It verifies if ibckeeper.NewKeeper panic when any of the keepers passed in is empty. func (suite *KeeperTestSuite) TestNewKeeper() { var ( - consensusHost clienttypes.ConsensusHost upgradeKeeper clienttypes.UpgradeKeeper scopedKeeper capabilitykeeper.ScopedKeeper newIBCKeeperFn func() @@ -72,12 +70,6 @@ func (suite *KeeperTestSuite) TestNewKeeper() { malleate func() expPass bool }{ - {"failure: empty consensus host value", func() { - consensusHost = &ibctm.ConsensusHost{} - }, false}, - {"failure: nil consensus host value", func() { - consensusHost = nil - }, false}, {"failure: empty upgrade keeper value", func() { emptyUpgradeKeeperValue := upgradekeeper.Keeper{} @@ -99,18 +91,12 @@ func (suite *KeeperTestSuite) TestNewKeeper() { suite.chainA.GetSimApp().AppCodec(), suite.chainA.GetSimApp().GetKey(ibcexported.StoreKey), suite.chainA.GetSimApp().GetSubspace(ibcexported.ModuleName), - consensusHost, upgradeKeeper, scopedKeeper, "", // authority ) } }, false}, - {"success: replace stakingKeeper with non-empty MockStakingKeeper", func() { - // use a different implementation of clienttypes.StakingKeeper - mockStakingKeeper := MockStakingKeeper{"not empty"} - consensusHost = ibctm.NewConsensusHost(mockStakingKeeper) - }, true}, } for _, tc := range testCases { @@ -124,14 +110,12 @@ func (suite *KeeperTestSuite) TestNewKeeper() { suite.chainA.GetSimApp().AppCodec(), suite.chainA.GetSimApp().GetKey(ibcexported.StoreKey), suite.chainA.GetSimApp().GetSubspace(ibcexported.ModuleName), - consensusHost, upgradeKeeper, scopedKeeper, suite.chainA.App.GetIBCKeeper().GetAuthority(), ) } - consensusHost = ibctm.NewConsensusHost(suite.chainA.GetSimApp().StakingKeeper) upgradeKeeper = suite.chainA.GetSimApp().UpgradeKeeper scopedKeeper = suite.chainA.GetSimApp().ScopedIBCKeeper diff --git a/modules/light-clients/07-tendermint/consensus_host.go b/modules/light-clients/07-tendermint/consensus_host.go deleted file mode 100644 index 051f5c81887..00000000000 --- a/modules/light-clients/07-tendermint/consensus_host.go +++ /dev/null @@ -1,67 +0,0 @@ -package tendermint - -import ( - "context" - "time" - - errorsmod "cosmossdk.io/errors" - - sdk "github.com/cosmos/cosmos-sdk/types" - stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" - - clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" - commitmenttypes "github.com/cosmos/ibc-go/v9/modules/core/23-commitment/types" - ibcerrors "github.com/cosmos/ibc-go/v9/modules/core/errors" - "github.com/cosmos/ibc-go/v9/modules/core/exported" -) - -var _ clienttypes.ConsensusHost = (*ConsensusHost)(nil) - -// ConsensusHost implements the 02-client clienttypes.ConsensusHost interface. -type ConsensusHost struct { - stakingKeeper StakingKeeper -} - -// StakingKeeper defines an expected interface for the tendermint ConsensusHost. -type StakingKeeper interface { - GetHistoricalInfo(ctx context.Context, height int64) (stakingtypes.HistoricalInfo, error) - UnbondingTime(ctx context.Context) (time.Duration, error) -} - -// NewConsensusHost creates and returns a new ConsensusHost for tendermint consensus. -func NewConsensusHost(stakingKeeper clienttypes.StakingKeeper) clienttypes.ConsensusHost { - if stakingKeeper == nil { - panic("staking keeper cannot be nil") - } - - return &ConsensusHost{ - stakingKeeper: stakingKeeper, - } -} - -// GetSelfConsensusState implements the 02-client clienttypes.ConsensusHost interface. -func (c *ConsensusHost) GetSelfConsensusState(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) { - selfHeight, ok := height.(clienttypes.Height) - if !ok { - return nil, errorsmod.Wrapf(ibcerrors.ErrInvalidType, "expected %T, got %T", clienttypes.Height{}, height) - } - - // check that height revision matches chainID revision - revision := clienttypes.ParseChainID(ctx.ChainID()) - if revision != height.GetRevisionNumber() { - return nil, errorsmod.Wrapf(clienttypes.ErrInvalidHeight, "chainID revision number does not match height revision number: expected %d, got %d", revision, height.GetRevisionNumber()) - } - - histInfo, err := c.stakingKeeper.GetHistoricalInfo(ctx, int64(selfHeight.RevisionHeight)) - if err != nil { - return nil, errorsmod.Wrapf(err, "height %d", selfHeight.RevisionHeight) - } - - consensusState := &ConsensusState{ - Timestamp: histInfo.Header.Time, - Root: commitmenttypes.NewMerkleRoot(histInfo.Header.GetAppHash()), - NextValidatorsHash: histInfo.Header.NextValidatorsHash, - } - - return consensusState, nil -} diff --git a/modules/light-clients/07-tendermint/consensus_host_test.go b/modules/light-clients/07-tendermint/consensus_host_test.go deleted file mode 100644 index 87dbd474f10..00000000000 --- a/modules/light-clients/07-tendermint/consensus_host_test.go +++ /dev/null @@ -1,110 +0,0 @@ -package tendermint_test - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" - - clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" - "github.com/cosmos/ibc-go/v9/modules/core/exported" - solomachine "github.com/cosmos/ibc-go/v9/modules/light-clients/06-solomachine" - "github.com/cosmos/ibc-go/v9/testing/mock" -) - -func (suite *TendermintTestSuite) TestGetSelfConsensusState() { - var height clienttypes.Height - - cases := []struct { - name string - malleate func() - expError error - }{ - { - name: "zero height", - malleate: func() {}, - expError: clienttypes.ErrInvalidHeight, - }, - { - name: "height > latest height", - malleate: func() { - height = clienttypes.NewHeight(1, uint64(suite.chainA.GetContext().BlockHeight())+1) - }, - expError: stakingtypes.ErrNoHistoricalInfo, - }, - { - name: "pruned historical info", - malleate: func() { - height = clienttypes.NewHeight(1, uint64(suite.chainA.GetContext().BlockHeight())-1) - - err := suite.chainA.GetSimApp().StakingKeeper.DeleteHistoricalInfo(suite.chainA.GetContext(), int64(height.GetRevisionHeight())) - suite.Require().NoError(err) - }, - expError: stakingtypes.ErrNoHistoricalInfo, - }, - { - name: "custom consensus host: failure", - malleate: func() { - consensusHost := &mock.ConsensusHost{ - GetSelfConsensusStateFn: func(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) { - return nil, mock.MockApplicationCallbackError - }, - } - suite.chainA.GetSimApp().GetIBCKeeper().SetConsensusHost(consensusHost) - }, - expError: mock.MockApplicationCallbackError, - }, - { - name: "custom consensus host: success", - malleate: func() { - consensusHost := &mock.ConsensusHost{ - GetSelfConsensusStateFn: func(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) { - return &solomachine.ConsensusState{}, nil - }, - } - suite.chainA.GetSimApp().GetIBCKeeper().SetConsensusHost(consensusHost) - }, - expError: nil, - }, - { - name: "latest height - 1", - malleate: func() { - height = clienttypes.NewHeight(1, uint64(suite.chainA.GetContext().BlockHeight())-1) - }, - expError: nil, - }, - { - name: "latest height", - malleate: func() { - // historical info is set on BeginBlock in x/staking, which is now encapsulated within the FinalizeBlock abci method, - // thus, we do not have historical info for current height due to how the ibctesting library operates. - // ibctesting calls app.Commit() as a final step on NextBlock and we invoke test code before FinalizeBlock is called at the current height once again. - err := suite.chainA.GetSimApp().StakingKeeper.TrackHistoricalInfo(suite.chainA.GetContext()) - suite.Require().NoError(err) - - height = clienttypes.GetSelfHeight(suite.chainA.GetContext()) - }, - expError: nil, - }, - } - - for i, tc := range cases { - tc := tc - suite.Run(tc.name, func() { - suite.SetupTest() - - height = clienttypes.ZeroHeight() - - tc.malleate() - - cs, err := suite.chainA.GetSimApp().GetIBCKeeper().ClientKeeper.GetSelfConsensusState(suite.chainA.GetContext(), height) - - expPass := tc.expError == nil - if expPass { - suite.Require().NoError(err, "Case %d should have passed: %s", i, tc.name) - suite.Require().NotNil(cs, "Case %d should have passed: %s", i, tc.name) - } else { - suite.Require().ErrorIs(err, tc.expError, "Case %d should have failed: %s", i, tc.name) - suite.Require().Nil(cs, "Case %d should have failed: %s", i, tc.name) - } - }) - } -} diff --git a/testing/mock/consensus_host.go b/testing/mock/consensus_host.go deleted file mode 100644 index 504885c6a64..00000000000 --- a/testing/mock/consensus_host.go +++ /dev/null @@ -1,22 +0,0 @@ -package mock - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - - clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" - "github.com/cosmos/ibc-go/v9/modules/core/exported" -) - -var _ clienttypes.ConsensusHost = (*ConsensusHost)(nil) - -type ConsensusHost struct { - GetSelfConsensusStateFn func(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) -} - -func (cv *ConsensusHost) GetSelfConsensusState(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) { - if cv.GetSelfConsensusStateFn == nil { - return nil, nil - } - - return cv.GetSelfConsensusStateFn(ctx, height) -} diff --git a/testing/simapp/app.go b/testing/simapp/app.go index 3c608c7c085..de8fd6d8118 100644 --- a/testing/simapp/app.go +++ b/testing/simapp/app.go @@ -367,7 +367,7 @@ func NewSimApp( app.UpgradeKeeper = upgradekeeper.NewKeeper(skipUpgradeHeights, runtime.NewKVStoreService(keys[upgradetypes.StoreKey]), appCodec, homePath, app.BaseApp, authtypes.NewModuleAddress(govtypes.ModuleName).String()) app.IBCKeeper = ibckeeper.NewKeeper( - appCodec, keys[ibcexported.StoreKey], app.GetSubspace(ibcexported.ModuleName), ibctm.NewConsensusHost(app.StakingKeeper), app.UpgradeKeeper, scopedIBCKeeper, authtypes.NewModuleAddress(govtypes.ModuleName).String(), + appCodec, keys[ibcexported.StoreKey], app.GetSubspace(ibcexported.ModuleName), app.UpgradeKeeper, scopedIBCKeeper, authtypes.NewModuleAddress(govtypes.ModuleName).String(), ) govConfig := govtypes.DefaultConfig() From 06322781fd4a227ab107387fc69fd6e0f683e849 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 13:34:03 +0800 Subject: [PATCH 03/33] imp(08-wasm): removed consensus host --- .../08-wasm/testing/simapp/app.go | 2 +- .../08-wasm/types/consensus_host.go | 55 ------------- .../08-wasm/types/consensus_host_test.go | 77 ------------------- 3 files changed, 1 insertion(+), 133 deletions(-) delete mode 100644 modules/light-clients/08-wasm/types/consensus_host.go delete mode 100644 modules/light-clients/08-wasm/types/consensus_host_test.go diff --git a/modules/light-clients/08-wasm/testing/simapp/app.go b/modules/light-clients/08-wasm/testing/simapp/app.go index 1f6b98d663c..92a9886eec9 100644 --- a/modules/light-clients/08-wasm/testing/simapp/app.go +++ b/modules/light-clients/08-wasm/testing/simapp/app.go @@ -413,7 +413,7 @@ func NewSimApp( app.UpgradeKeeper = upgradekeeper.NewKeeper(skipUpgradeHeights, runtime.NewKVStoreService(keys[upgradetypes.StoreKey]), appCodec, homePath, app.BaseApp, authtypes.NewModuleAddress(govtypes.ModuleName).String()) app.IBCKeeper = ibckeeper.NewKeeper( - appCodec, keys[ibcexported.StoreKey], app.GetSubspace(ibcexported.ModuleName), ibctm.NewConsensusHost(app.StakingKeeper), app.UpgradeKeeper, scopedIBCKeeper, authtypes.NewModuleAddress(govtypes.ModuleName).String(), + appCodec, keys[ibcexported.StoreKey], app.GetSubspace(ibcexported.ModuleName), app.UpgradeKeeper, scopedIBCKeeper, authtypes.NewModuleAddress(govtypes.ModuleName).String(), ) govConfig := govtypes.DefaultConfig() diff --git a/modules/light-clients/08-wasm/types/consensus_host.go b/modules/light-clients/08-wasm/types/consensus_host.go deleted file mode 100644 index 37fc17d5211..00000000000 --- a/modules/light-clients/08-wasm/types/consensus_host.go +++ /dev/null @@ -1,55 +0,0 @@ -package types - -import ( - "errors" - - "github.com/cosmos/cosmos-sdk/codec" - sdk "github.com/cosmos/cosmos-sdk/types" - - clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" - "github.com/cosmos/ibc-go/v9/modules/core/exported" -) - -// WasmConsensusHost implements the 02-client types.ConsensusHost interface. -type WasmConsensusHost struct { - cdc codec.BinaryCodec - delegate clienttypes.ConsensusHost -} - -var _ clienttypes.ConsensusHost = (*WasmConsensusHost)(nil) - -// NewWasmConsensusHost creates and returns a new ConsensusHost for wasm wrapped consensus client state. -func NewWasmConsensusHost(cdc codec.BinaryCodec, delegate clienttypes.ConsensusHost) (*WasmConsensusHost, error) { - if cdc == nil { - return nil, errors.New("wasm consensus host codec is nil") - } - - if delegate == nil { - return nil, errors.New("wasm delegate consensus host is nil") - } - - return &WasmConsensusHost{ - cdc: cdc, - delegate: delegate, - }, nil -} - -// GetSelfConsensusState implements the 02-client types.ConsensusHost interface. -func (w *WasmConsensusHost) GetSelfConsensusState(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) { - consensusState, err := w.delegate.GetSelfConsensusState(ctx, height) - if err != nil { - return nil, err - } - - // encode consensusState to wasm.ConsensusState.Data - bz, err := w.cdc.MarshalInterface(consensusState) - if err != nil { - return nil, err - } - - wasmConsensusState := &ConsensusState{ - Data: bz, - } - - return wasmConsensusState, nil -} diff --git a/modules/light-clients/08-wasm/types/consensus_host_test.go b/modules/light-clients/08-wasm/types/consensus_host_test.go deleted file mode 100644 index d3e5629ab51..00000000000 --- a/modules/light-clients/08-wasm/types/consensus_host_test.go +++ /dev/null @@ -1,77 +0,0 @@ -package types_test - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - - wasmtesting "github.com/cosmos/ibc-go/modules/light-clients/08-wasm/testing" - "github.com/cosmos/ibc-go/modules/light-clients/08-wasm/types" - clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" - "github.com/cosmos/ibc-go/v9/modules/core/exported" - "github.com/cosmos/ibc-go/v9/testing/mock" -) - -func (suite *TypesTestSuite) TestGetSelfConsensusState() { - var ( - consensusHost clienttypes.ConsensusHost - consensusState exported.ConsensusState - height clienttypes.Height - ) - - cases := []struct { - name string - malleate func() - expError error - }{ - { - name: "success", - malleate: func() {}, - expError: nil, - }, - { - name: "failure: delegate error", - malleate: func() { - consensusHost.(*mock.ConsensusHost).GetSelfConsensusStateFn = func(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) { - return nil, mock.MockApplicationCallbackError - } - }, - expError: mock.MockApplicationCallbackError, - }, - } - - for i, tc := range cases { - tc := tc - suite.Run(tc.name, func() { - suite.SetupTest() - height = clienttypes.ZeroHeight() - - wrappedClientConsensusStateBz := clienttypes.MustMarshalConsensusState(suite.chainA.App.AppCodec(), wasmtesting.MockTendermintClientConsensusState) - consensusState = types.NewConsensusState(wrappedClientConsensusStateBz) - - consensusHost = &mock.ConsensusHost{ - GetSelfConsensusStateFn: func(ctx sdk.Context, height exported.Height) (exported.ConsensusState, error) { - return consensusState, nil - }, - } - - tc.malleate() - - var err error - consensusHost, err = types.NewWasmConsensusHost(suite.chainA.Codec, consensusHost) - suite.Require().NoError(err) - - suite.chainA.App.GetIBCKeeper().SetConsensusHost(consensusHost) - - cs, err := suite.chainA.App.GetIBCKeeper().ClientKeeper.GetSelfConsensusState(suite.chainA.GetContext(), height) - - expPass := tc.expError == nil - if expPass { - suite.Require().NoError(err, "Case %d should have passed: %s", i, tc.name) - suite.Require().NotNil(cs, "Case %d should have passed: %s", i, tc.name) - suite.Require().NotNil(cs.(*types.ConsensusState).Data, "Case %d should have passed: %s", i, tc.name) - } else { - suite.Require().ErrorIs(err, tc.expError, "Case %d should have failed: %s", i, tc.name) - suite.Require().Nil(cs, "Case %d should have failed: %s", i, tc.name) - } - }) - } -} From 5bfa510c4c2e6331c4de05cee38ded87d81d6852 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 13:35:46 +0800 Subject: [PATCH 04/33] imp: fix linter --- modules/core/keeper/keeper_test.go | 17 ----------------- 1 file changed, 17 deletions(-) diff --git a/modules/core/keeper/keeper_test.go b/modules/core/keeper/keeper_test.go index d7c7f8b6340..ff7fb8b8f11 100644 --- a/modules/core/keeper/keeper_test.go +++ b/modules/core/keeper/keeper_test.go @@ -1,16 +1,12 @@ package keeper_test import ( - "context" "testing" - "time" testifysuite "github.com/stretchr/testify/suite" upgradekeeper "cosmossdk.io/x/upgrade/keeper" - stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" - capabilitykeeper "github.com/cosmos/ibc-go/modules/capability/keeper" clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" ibcexported "github.com/cosmos/ibc-go/v9/modules/core/exported" @@ -43,19 +39,6 @@ func TestKeeperTestSuite(t *testing.T) { testifysuite.Run(t, new(KeeperTestSuite)) } -// MockStakingKeeper implements clienttypes.StakingKeeper used in ibckeeper.NewKeeper -type MockStakingKeeper struct { - mockField string -} - -func (MockStakingKeeper) GetHistoricalInfo(_ context.Context, _ int64) (stakingtypes.HistoricalInfo, error) { - return stakingtypes.HistoricalInfo{}, nil -} - -func (MockStakingKeeper) UnbondingTime(_ context.Context) (time.Duration, error) { - return 0, nil -} - // Test ibckeeper.NewKeeper used to initialize IBCKeeper when creating an app instance. // It verifies if ibckeeper.NewKeeper panic when any of the keepers passed in is empty. func (suite *KeeperTestSuite) TestNewKeeper() { From dfbbac0ae0e1a2b7fc2613e8ca72bab39fcfb871 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 13:40:42 +0800 Subject: [PATCH 05/33] imp: fixed linter --- modules/apps/callbacks/testing/simapp/app.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/apps/callbacks/testing/simapp/app.go b/modules/apps/callbacks/testing/simapp/app.go index 7050412e5fb..021a5a6efd4 100644 --- a/modules/apps/callbacks/testing/simapp/app.go +++ b/modules/apps/callbacks/testing/simapp/app.go @@ -405,7 +405,7 @@ func NewSimApp( app.UpgradeKeeper = upgradekeeper.NewKeeper(skipUpgradeHeights, runtime.NewKVStoreService(keys[upgradetypes.StoreKey]), appCodec, homePath, app.BaseApp, authtypes.NewModuleAddress(govtypes.ModuleName).String()) app.IBCKeeper = ibckeeper.NewKeeper( - appCodec, keys[ibcexported.StoreKey], app.GetSubspace(ibcexported.ModuleName), ibctm.NewConsensusHost(app.StakingKeeper), app.UpgradeKeeper, scopedIBCKeeper, authtypes.NewModuleAddress(govtypes.ModuleName).String(), + appCodec, keys[ibcexported.StoreKey], app.GetSubspace(ibcexported.ModuleName), app.UpgradeKeeper, scopedIBCKeeper, authtypes.NewModuleAddress(govtypes.ModuleName).String(), ) // NOTE: The mock ContractKeeper is only created for testing. From d0c97d8887b1d58634006446d038c79b94521f44 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 13:41:20 +0800 Subject: [PATCH 06/33] imp: fixed simapp --- simapp/app.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/simapp/app.go b/simapp/app.go index 77d82f1333d..e9a32662127 100644 --- a/simapp/app.go +++ b/simapp/app.go @@ -404,7 +404,7 @@ func NewSimApp( app.UpgradeKeeper = upgradekeeper.NewKeeper(skipUpgradeHeights, runtime.NewKVStoreService(keys[upgradetypes.StoreKey]), appCodec, homePath, app.BaseApp, authtypes.NewModuleAddress(govtypes.ModuleName).String()) app.IBCKeeper = ibckeeper.NewKeeper( - appCodec, keys[ibcexported.StoreKey], app.GetSubspace(ibcexported.ModuleName), ibctm.NewConsensusHost(app.StakingKeeper), app.UpgradeKeeper, scopedIBCKeeper, authtypes.NewModuleAddress(govtypes.ModuleName).String(), + appCodec, keys[ibcexported.StoreKey], app.GetSubspace(ibcexported.ModuleName), app.UpgradeKeeper, scopedIBCKeeper, authtypes.NewModuleAddress(govtypes.ModuleName).String(), ) govConfig := govtypes.DefaultConfig() From 9e624da8fe10b93d0cf1d9b67629dad1c92deb64 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 13:45:14 +0800 Subject: [PATCH 07/33] imp: updated docs --- docs/docs/01-ibc/02-integration.md | 1 - modules/light-clients/08-wasm/CHANGELOG.md | 4 +--- 2 files changed, 1 insertion(+), 4 deletions(-) diff --git a/docs/docs/01-ibc/02-integration.md b/docs/docs/01-ibc/02-integration.md index f4cf0f206ca..b93a5f27dc3 100644 --- a/docs/docs/01-ibc/02-integration.md +++ b/docs/docs/01-ibc/02-integration.md @@ -98,7 +98,6 @@ func NewApp(...args) *App { appCodec, keys[ibcexported.StoreKey], app.GetSubspace(ibcexported.ModuleName), - ibctm.NewConsensusHost(app.StakingKeeper), app.UpgradeKeeper, scopedIBCKeeper, authtypes.NewModuleAddress(govtypes.ModuleName).String(), diff --git a/modules/light-clients/08-wasm/CHANGELOG.md b/modules/light-clients/08-wasm/CHANGELOG.md index 5a9da678180..50d01cc710a 100644 --- a/modules/light-clients/08-wasm/CHANGELOG.md +++ b/modules/light-clients/08-wasm/CHANGELOG.md @@ -34,7 +34,7 @@ Ref: https://keepachangelog.com/en/1.0.0/ # Changelog -## [[Unreleased]] +## [Unreleased] ### Dependencies @@ -53,8 +53,6 @@ Ref: https://keepachangelog.com/en/1.0.0/ ### Features -* [\#6055](https://github.com/cosmos/ibc-go/pull/6055) feat: add 08-wasm `ConsensusHost` implementation for custom self client/consensus state validation in 03-connection handshake. - ### Bug Fixes * [\#6815](https://github.com/cosmos/ibc-go/pull/6815) Decode to bytes the hex-encoded checksum argument of the `migrate-contract` CLI. From 47f5c84e470987427000cee5cb2f0d17f58bc7c5 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 16:29:41 +0800 Subject: [PATCH 08/33] imp: removed more code --- .../core/03-connection/keeper/handshake.go | 30 +-- .../03-connection/keeper/handshake_test.go | 241 +----------------- modules/core/03-connection/keeper/verify.go | 4 + modules/core/keeper/msg_server.go | 20 +- testing/solomachine.go | 58 +---- 5 files changed, 26 insertions(+), 327 deletions(-) diff --git a/modules/core/03-connection/keeper/handshake.go b/modules/core/03-connection/keeper/handshake.go index dc716de2a5c..852541a6f19 100644 --- a/modules/core/03-connection/keeper/handshake.go +++ b/modules/core/03-connection/keeper/handshake.go @@ -9,7 +9,6 @@ import ( clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" "github.com/cosmos/ibc-go/v9/modules/core/03-connection/types" commitmenttypes "github.com/cosmos/ibc-go/v9/modules/core/23-commitment/types" - ibcerrors "github.com/cosmos/ibc-go/v9/modules/core/errors" "github.com/cosmos/ibc-go/v9/modules/core/exported" ) @@ -67,27 +66,13 @@ func (k *Keeper) ConnOpenTry( counterparty types.Counterparty, // counterpartyConnectionIdentifier, counterpartyPrefix and counterpartyClientIdentifier delayPeriod uint64, clientID string, // clientID of chainA - clientState exported.ClientState, // clientState that chainA has for chainB counterpartyVersions []*types.Version, // supported versions of chain A initProof []byte, // proof that chainA stored connectionEnd in state (on ConnOpenInit) - clientProof []byte, // proof that chainA stored a light client of chainB - consensusProof []byte, // proof that chainA stored chainB's consensus state at consensus height proofHeight exported.Height, // height at which relayer constructs proof of A storing connectionEnd in state - consensusHeight exported.Height, // latest height of chain B which chain A has stored in its chain B client ) (string, error) { // generate a new connection connectionID := k.GenerateConnectionIdentifier(ctx) - // check that the consensus height the counterparty chain is using to store a representation - // of this chain's consensus state is at a height in the past - selfHeight := clienttypes.GetSelfHeight(ctx) - if consensusHeight.GTE(selfHeight) { - return "", errorsmod.Wrapf( - ibcerrors.ErrInvalidHeight, - "consensus height is greater than or equal to the current block height (%s >= %s)", consensusHeight, selfHeight, - ) - } - // expectedConnection defines Chain A's ConnectionEnd // NOTE: chain A's counterparty is chain B (i.e where this code is executed) // NOTE: chainA and chainB must have the same delay period @@ -133,28 +118,15 @@ func (k *Keeper) ConnOpenTry( // to chain A (this code is executed on chain A). // // NOTE: Identifiers are checked on msg validation. +// TODO: Remove uneeded proofs func (k *Keeper) ConnOpenAck( ctx sdk.Context, connectionID string, - clientState exported.ClientState, // client state for chainA on chainB version *types.Version, // version that ChainB chose in ConnOpenTry counterpartyConnectionID string, tryProof []byte, // proof that connectionEnd was added to ChainB state in ConnOpenTry - clientProof []byte, // proof of client state on chainB for chainA - consensusProof []byte, // proof that chainB has stored ConsensusState of chainA on its client proofHeight exported.Height, // height that relayer constructed proofTry - consensusHeight exported.Height, // latest height of chainA that chainB has stored on its chainA client ) error { - // check that the consensus height the counterparty chain is using to store a representation - // of this chain's consensus state is at a height in the past - selfHeight := clienttypes.GetSelfHeight(ctx) - if consensusHeight.GTE(selfHeight) { - return errorsmod.Wrapf( - ibcerrors.ErrInvalidHeight, - "consensus height is greater than or equal to the current block height (%s >= %s)", consensusHeight, selfHeight, - ) - } - // Retrieve connection connection, found := k.GetConnection(ctx, connectionID) if !found { diff --git a/modules/core/03-connection/keeper/handshake_test.go b/modules/core/03-connection/keeper/handshake_test.go index 5a9e456a996..e233c68fbe3 100644 --- a/modules/core/03-connection/keeper/handshake_test.go +++ b/modules/core/03-connection/keeper/handshake_test.go @@ -3,11 +3,8 @@ package keeper_test import ( "time" - clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" "github.com/cosmos/ibc-go/v9/modules/core/03-connection/types" host "github.com/cosmos/ibc-go/v9/modules/core/24-host" - "github.com/cosmos/ibc-go/v9/modules/core/exported" - ibctm "github.com/cosmos/ibc-go/v9/modules/light-clients/07-tendermint" ibctesting "github.com/cosmos/ibc-go/v9/testing" ) @@ -94,11 +91,9 @@ func (suite *KeeperTestSuite) TestConnOpenInit() { // connection on chainA is INIT func (suite *KeeperTestSuite) TestConnOpenTry() { var ( - path *ibctesting.Path - delayPeriod uint64 - versions []*types.Version - consensusHeight exported.Height - counterpartyClient exported.ClientState + path *ibctesting.Path + delayPeriod uint64 + versions []*types.Version ) testCases := []struct { @@ -109,9 +104,6 @@ func (suite *KeeperTestSuite) TestConnOpenTry() { {"success", func() { err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) - - // retrieve client state of chainA to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) }, true}, {"success with delay period", func() { err := path.EndpointA.ConnOpenInit() @@ -126,96 +118,22 @@ func (suite *KeeperTestSuite) TestConnOpenTry() { suite.coordinator.CommitBlock(suite.chainA) err = path.EndpointB.UpdateClient() suite.Require().NoError(err) - - // retrieve client state of chainA to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) }, true}, - {"invalid counterparty client", func() { - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) - - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) - - // Set an invalid client of chainA on chainB - tmClient, ok := counterpartyClient.(*ibctm.ClientState) - suite.Require().True(ok) - tmClient.ChainId = "wrongchainid" - - suite.chainA.App.GetIBCKeeper().ClientKeeper.SetClientState(suite.chainA.GetContext(), path.EndpointA.ClientID, tmClient) - }, false}, - {"consensus height >= latest height", func() { - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) - - // retrieve client state of chainA to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) - - consensusHeight = clienttypes.GetSelfHeight(suite.chainB.GetContext()) - }, false}, - {"self consensus state not found", func() { - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) - - // retrieve client state of chainA to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) - - consensusHeight = clienttypes.NewHeight(0, 1) - }, false}, {"counterparty versions is empty", func() { err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) - // retrieve client state of chainA to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) - versions = nil }, false}, {"counterparty versions don't have a match", func() { err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) - // retrieve client state of chainA to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) - version := types.NewVersion("0.0", nil) versions = []*types.Version{version} }, false}, {"connection state verification failed", func() { // chainA connection not created - - // retrieve client state of chainA to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) - }, false}, - {"client state verification failed", func() { - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) - - // retrieve client state of chainA to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) - - // modify counterparty client without setting in store so it still passes validate but fails proof verification - tmClient, ok := counterpartyClient.(*ibctm.ClientState) - suite.Require().True(ok) - tmClient.LatestHeight, ok = tmClient.LatestHeight.Increment().(clienttypes.Height) - suite.Require().True(ok) - }, false}, - {"consensus state verification failed", func() { - // retrieve client state of chainA to pass as counterpartyClient - counterpartyClient = suite.chainA.GetClientState(path.EndpointA.ClientID) - - // give chainA wrong consensus state for chainB - consState, found := suite.chainA.App.GetIBCKeeper().ClientKeeper.GetLatestClientConsensusState(suite.chainA.GetContext(), path.EndpointA.ClientID) - suite.Require().True(found) - - tmConsState, ok := consState.(*ibctm.ConsensusState) - suite.Require().True(ok) - - tmConsState.Timestamp = time.Now() - suite.chainA.App.GetIBCKeeper().ClientKeeper.SetClientConsensusState(suite.chainA.GetContext(), path.EndpointA.ClientID, path.EndpointA.GetClientLatestHeight(), tmConsState) - - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) }, false}, } @@ -223,10 +141,9 @@ func (suite *KeeperTestSuite) TestConnOpenTry() { tc := tc suite.Run(tc.msg, func() { - suite.SetupTest() // reset - consensusHeight = clienttypes.ZeroHeight() // may be changed in malleate - versions = types.GetCompatibleVersions() // may be changed in malleate - delayPeriod = 0 // may be changed in malleate + suite.SetupTest() // reset + versions = types.GetCompatibleVersions() // may be changed in malleate + delayPeriod = 0 // may be changed in malleate path = ibctesting.NewPath(suite.chainA, suite.chainB) path.SetupClients() @@ -241,22 +158,9 @@ func (suite *KeeperTestSuite) TestConnOpenTry() { connectionKey := host.ConnectionKey(path.EndpointA.ConnectionID) initProof, proofHeight := suite.chainA.QueryProof(connectionKey) - if consensusHeight.IsZero() { - // retrieve consensus state height to provide proof for - consensusHeight = path.EndpointA.GetClientLatestHeight() - } - - consensusKey := host.FullConsensusStateKey(path.EndpointA.ClientID, consensusHeight) - consensusProof, _ := suite.chainA.QueryProof(consensusKey) - - // retrieve proof of counterparty clientstate on chainA - clientKey := host.FullClientStateKey(path.EndpointA.ClientID) - clientProof, _ := suite.chainA.QueryProof(clientKey) - connectionID, err := suite.chainB.App.GetIBCKeeper().ConnectionKeeper.ConnOpenTry( - suite.chainB.GetContext(), counterparty, delayPeriod, path.EndpointB.ClientID, counterpartyClient, - versions, initProof, clientProof, consensusProof, - proofHeight, consensusHeight, + suite.chainB.GetContext(), counterparty, delayPeriod, path.EndpointB.ClientID, + versions, initProof, proofHeight, ) if tc.expPass { @@ -274,10 +178,8 @@ func (suite *KeeperTestSuite) TestConnOpenTry() { // the initialization (TRYINIT) of the connection on Chain B (ID #2). func (suite *KeeperTestSuite) TestConnOpenAck() { var ( - path *ibctesting.Path - consensusHeight exported.Height - version *types.Version - counterpartyClient exported.ClientState + path *ibctesting.Path + version *types.Version ) testCases := []struct { @@ -291,57 +193,20 @@ func (suite *KeeperTestSuite) TestConnOpenAck() { err = path.EndpointB.ConnOpenTry() suite.Require().NoError(err) - - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) }, true}, - {"invalid counterparty client", func() { - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) - - err = path.EndpointB.ConnOpenTry() - suite.Require().NoError(err) - - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - - // Set an invalid client of chainA on chainB - tmClient, ok := counterpartyClient.(*ibctm.ClientState) - suite.Require().True(ok) - tmClient.ChainId = "wrongchainid" - - suite.chainB.App.GetIBCKeeper().ClientKeeper.SetClientState(suite.chainB.GetContext(), path.EndpointB.ClientID, tmClient) - }, false}, - {"consensus height >= latest height", func() { - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) - - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - - err = path.EndpointB.ConnOpenTry() - suite.Require().NoError(err) - - consensusHeight = clienttypes.GetSelfHeight(suite.chainA.GetContext()) - }, false}, {"connection not found", func() { // connections are never created - - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) }, false}, {"invalid counterparty connection ID", func() { err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - err = path.EndpointB.ConnOpenTry() suite.Require().NoError(err) // modify connB to set counterparty connection identifier to wrong identifier - path.EndpointA.UpdateConnection(func(c *types.ConnectionEnd) { c.Counterparty.ConnectionId = "badconnectionid" }) + path.EndpointA.UpdateConnection(func(c *types.ConnectionEnd) { c.Counterparty.ConnectionId = ibctesting.InvalidID }) + path.EndpointB.ConnectionID = ibctesting.InvalidID err = path.EndpointA.UpdateClient() suite.Require().NoError(err) @@ -354,9 +219,6 @@ func (suite *KeeperTestSuite) TestConnOpenAck() { err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - err = path.EndpointB.ConnOpenTry() suite.Require().NoError(err) @@ -368,9 +230,6 @@ func (suite *KeeperTestSuite) TestConnOpenAck() { err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - err = path.EndpointB.ConnOpenTry() suite.Require().NoError(err) @@ -380,9 +239,6 @@ func (suite *KeeperTestSuite) TestConnOpenAck() { err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - err = path.EndpointB.ConnOpenTry() suite.Require().NoError(err) @@ -393,9 +249,6 @@ func (suite *KeeperTestSuite) TestConnOpenAck() { err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - err = path.EndpointB.ConnOpenTry() suite.Require().NoError(err) @@ -405,69 +258,15 @@ func (suite *KeeperTestSuite) TestConnOpenAck() { err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - err = path.EndpointB.ConnOpenTry() suite.Require().NoError(err) version = types.NewVersion(types.DefaultIBCVersionIdentifier, []string{"ORDER_ORDERED", "ORDER_UNORDERED", "ORDER_DAG"}) }, false}, - {"self consensus state not found", func() { - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) - - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - - err = path.EndpointB.ConnOpenTry() - suite.Require().NoError(err) - - consensusHeight = clienttypes.NewHeight(0, 1) - }, false}, {"connection state verification failed", func() { // chainB connection is not in INIT err := path.EndpointA.ConnOpenInit() suite.Require().NoError(err) - - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - }, false}, - {"client state verification failed", func() { - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) - - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - - // modify counterparty client without setting in store so it still passes validate but fails proof verification - tmClient, ok := counterpartyClient.(*ibctm.ClientState) - suite.Require().True(ok) - tmClient.LatestHeight, ok = tmClient.LatestHeight.Increment().(clienttypes.Height) - suite.Require().True(ok) - - err = path.EndpointB.ConnOpenTry() - suite.Require().NoError(err) - }, false}, - {"consensus state verification failed", func() { - err := path.EndpointA.ConnOpenInit() - suite.Require().NoError(err) - - // retrieve client state of chainB to pass as counterpartyClient - counterpartyClient = suite.chainB.GetClientState(path.EndpointB.ClientID) - - // give chainB wrong consensus state for chainA - consState, found := suite.chainB.App.GetIBCKeeper().ClientKeeper.GetLatestClientConsensusState(suite.chainB.GetContext(), path.EndpointB.ClientID) - suite.Require().True(found) - - tmConsState, ok := consState.(*ibctm.ConsensusState) - suite.Require().True(ok) - - tmConsState.Timestamp = tmConsState.Timestamp.Add(time.Second) - suite.chainB.App.GetIBCKeeper().ClientKeeper.SetClientConsensusState(suite.chainB.GetContext(), path.EndpointB.ClientID, path.EndpointB.GetClientLatestHeight(), tmConsState) - - err = path.EndpointB.ConnOpenTry() - suite.Require().NoError(err) }, false}, } @@ -476,7 +275,6 @@ func (suite *KeeperTestSuite) TestConnOpenAck() { suite.Run(tc.msg, func() { suite.SetupTest() // reset version = types.GetCompatibleVersions()[0] // must be explicitly changed in malleate - consensusHeight = clienttypes.ZeroHeight() // must be explicitly changed in malleate path = ibctesting.NewPath(suite.chainA, suite.chainB) path.SetupClients() @@ -489,20 +287,9 @@ func (suite *KeeperTestSuite) TestConnOpenAck() { connectionKey := host.ConnectionKey(path.EndpointB.ConnectionID) tryProof, proofHeight := suite.chainB.QueryProof(connectionKey) - if consensusHeight.IsZero() { - // retrieve consensus state height to provide proof for - consensusHeight = path.EndpointB.GetClientLatestHeight() - } - consensusKey := host.FullConsensusStateKey(path.EndpointB.ClientID, consensusHeight) - consensusProof, _ := suite.chainB.QueryProof(consensusKey) - - // retrieve proof of counterparty clientstate on chainA - clientKey := host.FullClientStateKey(path.EndpointB.ClientID) - clientProof, _ := suite.chainB.QueryProof(clientKey) - err = suite.chainA.App.GetIBCKeeper().ConnectionKeeper.ConnOpenAck( - suite.chainA.GetContext(), path.EndpointA.ConnectionID, counterpartyClient, version, path.EndpointB.ConnectionID, - tryProof, clientProof, consensusProof, proofHeight, consensusHeight, + suite.chainA.GetContext(), path.EndpointA.ConnectionID, version, + path.EndpointB.ConnectionID, tryProof, proofHeight, ) if tc.expPass { diff --git a/modules/core/03-connection/keeper/verify.go b/modules/core/03-connection/keeper/verify.go index fece92609f2..c992984a062 100644 --- a/modules/core/03-connection/keeper/verify.go +++ b/modules/core/03-connection/keeper/verify.go @@ -25,6 +25,10 @@ func (k *Keeper) VerifyConnectionState( connectionID string, counterpartyConnection types.ConnectionEnd, // opposite connection ) error { + if !types.IsValidConnectionID(connectionID) { + return types.ErrInvalidConnectionIdentifier + } + clientID := connection.ClientId if status := k.clientKeeper.GetClientStatus(ctx, clientID); status != exported.Active { return errorsmod.Wrapf(clienttypes.ErrClientNotActive, "client (%s) status is %s", clientID, status) diff --git a/modules/core/keeper/msg_server.go b/modules/core/keeper/msg_server.go index 345f73c5dce..9412e0020e1 100644 --- a/modules/core/keeper/msg_server.go +++ b/modules/core/keeper/msg_server.go @@ -149,15 +149,9 @@ func (k *Keeper) ConnectionOpenInit(goCtx context.Context, msg *connectiontypes. func (k *Keeper) ConnectionOpenTry(goCtx context.Context, msg *connectiontypes.MsgConnectionOpenTry) (*connectiontypes.MsgConnectionOpenTryResponse, error) { ctx := sdk.UnwrapSDKContext(goCtx) - targetClient, err := clienttypes.UnpackClientState(msg.ClientState) - if err != nil { - return nil, err - } - if _, err := k.ConnectionKeeper.ConnOpenTry( - ctx, msg.Counterparty, msg.DelayPeriod, msg.ClientId, targetClient, - msg.CounterpartyVersions, msg.ProofInit, msg.ProofClient, msg.ProofConsensus, - msg.ProofHeight, msg.ConsensusHeight, + ctx, msg.Counterparty, msg.DelayPeriod, msg.ClientId, + msg.CounterpartyVersions, msg.ProofInit, msg.ProofHeight, ); err != nil { return nil, errorsmod.Wrap(err, "connection handshake open try failed") } @@ -169,15 +163,9 @@ func (k *Keeper) ConnectionOpenTry(goCtx context.Context, msg *connectiontypes.M func (k *Keeper) ConnectionOpenAck(goCtx context.Context, msg *connectiontypes.MsgConnectionOpenAck) (*connectiontypes.MsgConnectionOpenAckResponse, error) { ctx := sdk.UnwrapSDKContext(goCtx) - targetClient, err := clienttypes.UnpackClientState(msg.ClientState) - if err != nil { - return nil, err - } - if err := k.ConnectionKeeper.ConnOpenAck( - ctx, msg.ConnectionId, targetClient, msg.Version, msg.CounterpartyConnectionId, - msg.ProofTry, msg.ProofClient, msg.ProofConsensus, - msg.ProofHeight, msg.ConsensusHeight, + ctx, msg.ConnectionId, msg.Version, msg.CounterpartyConnectionId, + msg.ProofTry, msg.ProofHeight, ); err != nil { return nil, errorsmod.Wrap(err, "connection handshake open ack failed") } diff --git a/testing/solomachine.go b/testing/solomachine.go index 4b57ae2dac1..d1aa471f4d4 100644 --- a/testing/solomachine.go +++ b/testing/solomachine.go @@ -28,9 +28,9 @@ import ( ) var ( - clientIDSolomachine = "client-on-solomachine" // clientID generated on solo machine side - connectionIDSolomachine = "connection-on-solomachine" // connectionID generated on solo machine side - channelIDSolomachine = "channel-on-solomachine" // channelID generated on solo machine side + clientIDSolomachine = "client-on-solomachine" // clientID generated on solo machine side + connectionIDSolomachine = "connection-0" // connectionID generated on solo machine side + channelIDSolomachine = "channel-on-solomachine" // channelID generated on solo machine side ) // DefaultSolomachineClientID is the default solo machine client id used for testing @@ -513,42 +513,6 @@ func (solo *Solomachine) GenerateProof(signBytes *solomachine.SignBytes) []byte return proof } -// GenerateClientStateProof generates the proof of the client state required for the connection open try and ack handshake steps. -// The client state should be the self client states of the tendermint chain. -func (solo *Solomachine) GenerateClientStateProof(clientState exported.ClientState) []byte { - data, err := clienttypes.MarshalClientState(solo.cdc, clientState) - require.NoError(solo.t, err) - - path := host.FullClientStateKey(clientIDSolomachine) - signBytes := &solomachine.SignBytes{ - Sequence: solo.Sequence, - Timestamp: solo.Time, - Diversifier: solo.Diversifier, - Path: path, - Data: data, - } - - return solo.GenerateProof(signBytes) -} - -// GenerateConsensusStateProof generates the proof of the consensus state required for the connection open try and ack handshake steps. -// The consensus state should be the self consensus states of the tendermint chain. -func (solo *Solomachine) GenerateConsensusStateProof(consensusState exported.ConsensusState, consensusHeight exported.Height) []byte { - data, err := clienttypes.MarshalConsensusState(solo.cdc, consensusState) - require.NoError(solo.t, err) - - path := host.FullConsensusStateKey(clientIDSolomachine, consensusHeight) - signBytes := &solomachine.SignBytes{ - Sequence: solo.Sequence, - Timestamp: solo.Time, - Diversifier: solo.Diversifier, - Path: path, - Data: data, - } - - return solo.GenerateProof(signBytes) -} - // GenerateConnOpenTryProof generates the proofTry required for the connection open ack handshake step. // The clientID, connectionID provided represent the clientID and connectionID created on the counterparty chain, that is the tendermint chain. func (solo *Solomachine) GenerateConnOpenTryProof(counterpartyClientID, counterpartyConnectionID string) []byte { @@ -657,22 +621,6 @@ func (solo *Solomachine) GenerateReceiptAbsenceProof(packet channeltypes.Packet) return solo.GenerateProof(signBytes) } -// GetClientStatePath returns the commitment path for the client state. -func (solo *Solomachine) GetClientStatePath(counterpartyClientIdentifier string) commitmenttypesv2.MerklePath { - path, err := commitmenttypes.ApplyPrefix(prefix, commitmenttypes.NewMerklePath(host.FullClientStateKey(counterpartyClientIdentifier))) - require.NoError(solo.t, err) - - return path -} - -// GetConsensusStatePath returns the commitment path for the consensus state. -func (solo *Solomachine) GetConsensusStatePath(counterpartyClientIdentifier string, consensusHeight exported.Height) commitmenttypesv2.MerklePath { - path, err := commitmenttypes.ApplyPrefix(prefix, commitmenttypes.NewMerklePath(host.FullConsensusStateKey(counterpartyClientIdentifier, consensusHeight))) - require.NoError(solo.t, err) - - return path -} - // GetConnectionStatePath returns the commitment path for the connection state. func (solo *Solomachine) GetConnectionStatePath(connID string) commitmenttypesv2.MerklePath { connectionPath := commitmenttypes.NewMerklePath(host.ConnectionKey(connID)) From e7465f524340f981361fd94f260cbaf36dbdcd6e Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 16:33:22 +0800 Subject: [PATCH 09/33] revert --- testing/solomachine.go | 52 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) diff --git a/testing/solomachine.go b/testing/solomachine.go index d1aa471f4d4..ef8c5dc8b5e 100644 --- a/testing/solomachine.go +++ b/testing/solomachine.go @@ -513,6 +513,42 @@ func (solo *Solomachine) GenerateProof(signBytes *solomachine.SignBytes) []byte return proof } +// GenerateClientStateProof generates the proof of the client state required for the connection open try and ack handshake steps. +// The client state should be the self client states of the tendermint chain. +func (solo *Solomachine) GenerateClientStateProof(clientState exported.ClientState) []byte { + data, err := clienttypes.MarshalClientState(solo.cdc, clientState) + require.NoError(solo.t, err) + + path := host.FullClientStateKey(clientIDSolomachine) + signBytes := &solomachine.SignBytes{ + Sequence: solo.Sequence, + Timestamp: solo.Time, + Diversifier: solo.Diversifier, + Path: path, + Data: data, + } + + return solo.GenerateProof(signBytes) +} + +// GenerateConsensusStateProof generates the proof of the consensus state required for the connection open try and ack handshake steps. +// The consensus state should be the self consensus states of the tendermint chain. +func (solo *Solomachine) GenerateConsensusStateProof(consensusState exported.ConsensusState, consensusHeight exported.Height) []byte { + data, err := clienttypes.MarshalConsensusState(solo.cdc, consensusState) + require.NoError(solo.t, err) + + path := host.FullConsensusStateKey(clientIDSolomachine, consensusHeight) + signBytes := &solomachine.SignBytes{ + Sequence: solo.Sequence, + Timestamp: solo.Time, + Diversifier: solo.Diversifier, + Path: path, + Data: data, + } + + return solo.GenerateProof(signBytes) +} + // GenerateConnOpenTryProof generates the proofTry required for the connection open ack handshake step. // The clientID, connectionID provided represent the clientID and connectionID created on the counterparty chain, that is the tendermint chain. func (solo *Solomachine) GenerateConnOpenTryProof(counterpartyClientID, counterpartyConnectionID string) []byte { @@ -621,6 +657,22 @@ func (solo *Solomachine) GenerateReceiptAbsenceProof(packet channeltypes.Packet) return solo.GenerateProof(signBytes) } +// GetClientStatePath returns the commitment path for the client state. +func (solo *Solomachine) GetClientStatePath(counterpartyClientIdentifier string) commitmenttypesv2.MerklePath { + path, err := commitmenttypes.ApplyPrefix(prefix, commitmenttypes.NewMerklePath(host.FullClientStateKey(counterpartyClientIdentifier))) + require.NoError(solo.t, err) + + return path +} + +// GetConsensusStatePath returns the commitment path for the consensus state. +func (solo *Solomachine) GetConsensusStatePath(counterpartyClientIdentifier string, consensusHeight exported.Height) commitmenttypesv2.MerklePath { + path, err := commitmenttypes.ApplyPrefix(prefix, commitmenttypes.NewMerklePath(host.FullConsensusStateKey(counterpartyClientIdentifier, consensusHeight))) + require.NoError(solo.t, err) + + return path +} + // GetConnectionStatePath returns the commitment path for the connection state. func (solo *Solomachine) GetConnectionStatePath(connID string) commitmenttypesv2.MerklePath { connectionPath := commitmenttypes.NewMerklePath(host.ConnectionKey(connID)) From 147e7749092fe49470067e6e3abcd7b56537927f Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 16:41:46 +0800 Subject: [PATCH 10/33] imp: removed unneeded proto fields --- proto/ibc/core/connection/v1/tx.proto | 22 +++------------------- 1 file changed, 3 insertions(+), 19 deletions(-) diff --git a/proto/ibc/core/connection/v1/tx.proto b/proto/ibc/core/connection/v1/tx.proto index b0cd777d1b8..3ec28203cf4 100644 --- a/proto/ibc/core/connection/v1/tx.proto +++ b/proto/ibc/core/connection/v1/tx.proto @@ -57,10 +57,8 @@ message MsgConnectionOpenTry { option (gogoproto.goproto_getters) = false; + reserved 2, 3, 9 to 11, 13; string client_id = 1; - // Deprecated: this field is unused. Crossing hellos are no longer supported in core IBC. - string previous_connection_id = 2 [deprecated = true]; - google.protobuf.Any client_state = 3; Counterparty counterparty = 4 [(gogoproto.nullable) = false]; uint64 delay_period = 5; repeated Version counterparty_versions = 6; @@ -68,14 +66,7 @@ message MsgConnectionOpenTry { // proof of the initialization the connection on Chain A: `UNINITIALIZED -> // INIT` bytes proof_init = 8; - // proof of client state included in message - bytes proof_client = 9; - // proof of client consensus state - bytes proof_consensus = 10; - ibc.core.client.v1.Height consensus_height = 11 [(gogoproto.nullable) = false]; string signer = 12; - // optional proof data for host state machines that are unable to introspect their own consensus state - bytes host_consensus_state_proof = 13; } // MsgConnectionOpenTryResponse defines the Msg/ConnectionOpenTry response type. @@ -88,22 +79,15 @@ message MsgConnectionOpenAck { option (gogoproto.goproto_getters) = false; + reserved 4, 7 to 9, 11; string connection_id = 1; string counterparty_connection_id = 2; Version version = 3; - google.protobuf.Any client_state = 4; ibc.core.client.v1.Height proof_height = 5 [(gogoproto.nullable) = false]; // proof of the initialization the connection on Chain B: `UNINITIALIZED -> // TRYOPEN` bytes proof_try = 6; - // proof of client state included in message - bytes proof_client = 7; - // proof of client consensus state - bytes proof_consensus = 8; - ibc.core.client.v1.Height consensus_height = 9 [(gogoproto.nullable) = false]; string signer = 10; - // optional proof data for host state machines that are unable to introspect their own consensus state - bytes host_consensus_state_proof = 11; } // MsgConnectionOpenAckResponse defines the Msg/ConnectionOpenAck response type. @@ -143,4 +127,4 @@ message MsgUpdateParams { } // MsgUpdateParamsResponse defines the MsgUpdateParams response type. -message MsgUpdateParamsResponse {} \ No newline at end of file +message MsgUpdateParamsResponse {} From 14c1449aa2e1f11fd9038f994578ef3b65cc931a Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 16:48:06 +0800 Subject: [PATCH 11/33] imp: lint --- proto/ibc/core/connection/v1/tx.proto | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/proto/ibc/core/connection/v1/tx.proto b/proto/ibc/core/connection/v1/tx.proto index 3ec28203cf4..4915a7726d5 100644 --- a/proto/ibc/core/connection/v1/tx.proto +++ b/proto/ibc/core/connection/v1/tx.proto @@ -58,15 +58,15 @@ message MsgConnectionOpenTry { option (gogoproto.goproto_getters) = false; reserved 2, 3, 9 to 11, 13; - string client_id = 1; - Counterparty counterparty = 4 [(gogoproto.nullable) = false]; - uint64 delay_period = 5; - repeated Version counterparty_versions = 6; - ibc.core.client.v1.Height proof_height = 7 [(gogoproto.nullable) = false]; + string client_id = 1; + Counterparty counterparty = 4 [(gogoproto.nullable) = false]; + uint64 delay_period = 5; + repeated Version counterparty_versions = 6; + ibc.core.client.v1.Height proof_height = 7 [(gogoproto.nullable) = false]; // proof of the initialization the connection on Chain A: `UNINITIALIZED -> // INIT` - bytes proof_init = 8; - string signer = 12; + bytes proof_init = 8; + string signer = 12; } // MsgConnectionOpenTryResponse defines the Msg/ConnectionOpenTry response type. @@ -86,8 +86,8 @@ message MsgConnectionOpenAck { ibc.core.client.v1.Height proof_height = 5 [(gogoproto.nullable) = false]; // proof of the initialization the connection on Chain B: `UNINITIALIZED -> // TRYOPEN` - bytes proof_try = 6; - string signer = 10; + bytes proof_try = 6; + string signer = 10; } // MsgConnectionOpenAckResponse defines the Msg/ConnectionOpenAck response type. From 702cc7c73f1cdd7f3a4b362959119926ad9c7427 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 16:55:25 +0800 Subject: [PATCH 12/33] lint --- proto/ibc/core/connection/v1/tx.proto | 1 - 1 file changed, 1 deletion(-) diff --git a/proto/ibc/core/connection/v1/tx.proto b/proto/ibc/core/connection/v1/tx.proto index 4915a7726d5..65885571cf5 100644 --- a/proto/ibc/core/connection/v1/tx.proto +++ b/proto/ibc/core/connection/v1/tx.proto @@ -6,7 +6,6 @@ option go_package = "github.com/cosmos/ibc-go/v9/modules/core/03-connection/type import "gogoproto/gogo.proto"; import "cosmos/msg/v1/msg.proto"; -import "google/protobuf/any.proto"; import "ibc/core/client/v1/client.proto"; import "ibc/core/connection/v1/connection.proto"; From 3694cd34bacb3cfbc678718de75a04dc55ee4a9d Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 16:56:59 +0800 Subject: [PATCH 13/33] imp: auto generated code --- modules/core/03-connection/types/tx.pb.go | 666 +++------------------- 1 file changed, 66 insertions(+), 600 deletions(-) diff --git a/modules/core/03-connection/types/tx.pb.go b/modules/core/03-connection/types/tx.pb.go index 070ba6e6250..a3e882f2a99 100644 --- a/modules/core/03-connection/types/tx.pb.go +++ b/modules/core/03-connection/types/tx.pb.go @@ -6,12 +6,11 @@ package types import ( context "context" fmt "fmt" - types "github.com/cosmos/cosmos-sdk/codec/types" _ "github.com/cosmos/cosmos-sdk/types/msgservice" _ "github.com/cosmos/gogoproto/gogoproto" grpc1 "github.com/cosmos/gogoproto/grpc" proto "github.com/cosmos/gogoproto/proto" - types1 "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" + types "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" grpc "google.golang.org/grpc" codes "google.golang.org/grpc/codes" status "google.golang.org/grpc/status" @@ -115,25 +114,15 @@ var xxx_messageInfo_MsgConnectionOpenInitResponse proto.InternalMessageInfo // MsgConnectionOpenTry defines a msg sent by a Relayer to try to open a // connection on Chain B. type MsgConnectionOpenTry struct { - ClientId string `protobuf:"bytes,1,opt,name=client_id,json=clientId,proto3" json:"client_id,omitempty"` - // Deprecated: this field is unused. Crossing hellos are no longer supported in core IBC. - PreviousConnectionId string `protobuf:"bytes,2,opt,name=previous_connection_id,json=previousConnectionId,proto3" json:"previous_connection_id,omitempty"` // Deprecated: Do not use. - ClientState *types.Any `protobuf:"bytes,3,opt,name=client_state,json=clientState,proto3" json:"client_state,omitempty"` - Counterparty Counterparty `protobuf:"bytes,4,opt,name=counterparty,proto3" json:"counterparty"` - DelayPeriod uint64 `protobuf:"varint,5,opt,name=delay_period,json=delayPeriod,proto3" json:"delay_period,omitempty"` - CounterpartyVersions []*Version `protobuf:"bytes,6,rep,name=counterparty_versions,json=counterpartyVersions,proto3" json:"counterparty_versions,omitempty"` - ProofHeight types1.Height `protobuf:"bytes,7,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` + ClientId string `protobuf:"bytes,1,opt,name=client_id,json=clientId,proto3" json:"client_id,omitempty"` + Counterparty Counterparty `protobuf:"bytes,4,opt,name=counterparty,proto3" json:"counterparty"` + DelayPeriod uint64 `protobuf:"varint,5,opt,name=delay_period,json=delayPeriod,proto3" json:"delay_period,omitempty"` + CounterpartyVersions []*Version `protobuf:"bytes,6,rep,name=counterparty_versions,json=counterpartyVersions,proto3" json:"counterparty_versions,omitempty"` + ProofHeight types.Height `protobuf:"bytes,7,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` // proof of the initialization the connection on Chain A: `UNINITIALIZED -> // INIT` ProofInit []byte `protobuf:"bytes,8,opt,name=proof_init,json=proofInit,proto3" json:"proof_init,omitempty"` - // proof of client state included in message - ProofClient []byte `protobuf:"bytes,9,opt,name=proof_client,json=proofClient,proto3" json:"proof_client,omitempty"` - // proof of client consensus state - ProofConsensus []byte `protobuf:"bytes,10,opt,name=proof_consensus,json=proofConsensus,proto3" json:"proof_consensus,omitempty"` - ConsensusHeight types1.Height `protobuf:"bytes,11,opt,name=consensus_height,json=consensusHeight,proto3" json:"consensus_height"` - Signer string `protobuf:"bytes,12,opt,name=signer,proto3" json:"signer,omitempty"` - // optional proof data for host state machines that are unable to introspect their own consensus state - HostConsensusStateProof []byte `protobuf:"bytes,13,opt,name=host_consensus_state_proof,json=hostConsensusStateProof,proto3" json:"host_consensus_state_proof,omitempty"` + Signer string `protobuf:"bytes,12,opt,name=signer,proto3" json:"signer,omitempty"` } func (m *MsgConnectionOpenTry) Reset() { *m = MsgConnectionOpenTry{} } @@ -209,22 +198,14 @@ var xxx_messageInfo_MsgConnectionOpenTryResponse proto.InternalMessageInfo // MsgConnectionOpenAck defines a msg sent by a Relayer to Chain A to // acknowledge the change of connection state to TRYOPEN on Chain B. type MsgConnectionOpenAck struct { - ConnectionId string `protobuf:"bytes,1,opt,name=connection_id,json=connectionId,proto3" json:"connection_id,omitempty"` - CounterpartyConnectionId string `protobuf:"bytes,2,opt,name=counterparty_connection_id,json=counterpartyConnectionId,proto3" json:"counterparty_connection_id,omitempty"` - Version *Version `protobuf:"bytes,3,opt,name=version,proto3" json:"version,omitempty"` - ClientState *types.Any `protobuf:"bytes,4,opt,name=client_state,json=clientState,proto3" json:"client_state,omitempty"` - ProofHeight types1.Height `protobuf:"bytes,5,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` + ConnectionId string `protobuf:"bytes,1,opt,name=connection_id,json=connectionId,proto3" json:"connection_id,omitempty"` + CounterpartyConnectionId string `protobuf:"bytes,2,opt,name=counterparty_connection_id,json=counterpartyConnectionId,proto3" json:"counterparty_connection_id,omitempty"` + Version *Version `protobuf:"bytes,3,opt,name=version,proto3" json:"version,omitempty"` + ProofHeight types.Height `protobuf:"bytes,5,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` // proof of the initialization the connection on Chain B: `UNINITIALIZED -> // TRYOPEN` ProofTry []byte `protobuf:"bytes,6,opt,name=proof_try,json=proofTry,proto3" json:"proof_try,omitempty"` - // proof of client state included in message - ProofClient []byte `protobuf:"bytes,7,opt,name=proof_client,json=proofClient,proto3" json:"proof_client,omitempty"` - // proof of client consensus state - ProofConsensus []byte `protobuf:"bytes,8,opt,name=proof_consensus,json=proofConsensus,proto3" json:"proof_consensus,omitempty"` - ConsensusHeight types1.Height `protobuf:"bytes,9,opt,name=consensus_height,json=consensusHeight,proto3" json:"consensus_height"` - Signer string `protobuf:"bytes,10,opt,name=signer,proto3" json:"signer,omitempty"` - // optional proof data for host state machines that are unable to introspect their own consensus state - HostConsensusStateProof []byte `protobuf:"bytes,11,opt,name=host_consensus_state_proof,json=hostConsensusStateProof,proto3" json:"host_consensus_state_proof,omitempty"` + Signer string `protobuf:"bytes,10,opt,name=signer,proto3" json:"signer,omitempty"` } func (m *MsgConnectionOpenAck) Reset() { *m = MsgConnectionOpenAck{} } @@ -302,9 +283,9 @@ var xxx_messageInfo_MsgConnectionOpenAckResponse proto.InternalMessageInfo type MsgConnectionOpenConfirm struct { ConnectionId string `protobuf:"bytes,1,opt,name=connection_id,json=connectionId,proto3" json:"connection_id,omitempty"` // proof for the change of the connection state on Chain A: `INIT -> OPEN` - ProofAck []byte `protobuf:"bytes,2,opt,name=proof_ack,json=proofAck,proto3" json:"proof_ack,omitempty"` - ProofHeight types1.Height `protobuf:"bytes,3,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` - Signer string `protobuf:"bytes,4,opt,name=signer,proto3" json:"signer,omitempty"` + ProofAck []byte `protobuf:"bytes,2,opt,name=proof_ack,json=proofAck,proto3" json:"proof_ack,omitempty"` + ProofHeight types.Height `protobuf:"bytes,3,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` + Signer string `protobuf:"bytes,4,opt,name=signer,proto3" json:"signer,omitempty"` } func (m *MsgConnectionOpenConfirm) Reset() { *m = MsgConnectionOpenConfirm{} } @@ -474,65 +455,57 @@ func init() { func init() { proto.RegisterFile("ibc/core/connection/v1/tx.proto", fileDescriptor_5d00fde5fc97399e) } var fileDescriptor_5d00fde5fc97399e = []byte{ - // 928 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x96, 0x41, 0x6f, 0xe3, 0x44, - 0x14, 0xc7, 0xe3, 0xd6, 0x49, 0x9b, 0x97, 0x2c, 0x85, 0x51, 0xda, 0x7a, 0xbd, 0xac, 0x93, 0x2d, - 0x48, 0xad, 0x56, 0xd4, 0xde, 0xee, 0x82, 0xd8, 0x85, 0x5e, 0xda, 0x5c, 0xa8, 0x50, 0x61, 0x65, - 0xca, 0x1e, 0xb8, 0x44, 0x89, 0x33, 0x75, 0x47, 0x6d, 0x3c, 0x96, 0xc7, 0x09, 0x6b, 0x4e, 0x08, - 0x2e, 0x48, 0x5c, 0xf8, 0x08, 0x7c, 0x84, 0xfd, 0x18, 0x2b, 0x0e, 0x68, 0xc5, 0x89, 0x13, 0x42, - 0xed, 0x61, 0xbf, 0x00, 0x1f, 0x00, 0x79, 0x66, 0xec, 0x38, 0x89, 0x53, 0x39, 0xdb, 0xbd, 0x25, - 0xcf, 0xff, 0xf7, 0xe6, 0x3f, 0xef, 0xfd, 0xc6, 0x1e, 0x68, 0x92, 0x9e, 0x63, 0x39, 0x34, 0xc0, - 0x96, 0x43, 0x3d, 0x0f, 0x3b, 0x21, 0xa1, 0x9e, 0x35, 0xda, 0xb3, 0xc2, 0xe7, 0xa6, 0x1f, 0xd0, - 0x90, 0xa2, 0x0d, 0xd2, 0x73, 0xcc, 0x58, 0x60, 0x8e, 0x05, 0xe6, 0x68, 0x4f, 0x6f, 0xb8, 0xd4, - 0xa5, 0x5c, 0x62, 0xc5, 0xbf, 0x84, 0x5a, 0xdf, 0x74, 0x28, 0x1b, 0x50, 0x66, 0x0d, 0x98, 0x1b, - 0x57, 0x19, 0x30, 0x57, 0x3e, 0xb8, 0xed, 0x52, 0xea, 0x5e, 0x60, 0x8b, 0xff, 0xeb, 0x0d, 0x4f, - 0xad, 0xae, 0x17, 0xc9, 0x47, 0x19, 0x0b, 0x17, 0x04, 0x7b, 0x61, 0x9c, 0x28, 0x7e, 0x49, 0xc1, - 0xf6, 0x1c, 0x8f, 0x19, 0x43, 0x5c, 0xb8, 0xf5, 0xeb, 0x12, 0xac, 0x1f, 0x33, 0xb7, 0x9d, 0xc6, - 0xbf, 0xf6, 0xb1, 0x77, 0xe4, 0x91, 0x10, 0xdd, 0x81, 0xaa, 0x28, 0xd9, 0x21, 0x7d, 0x4d, 0x69, - 0x29, 0x3b, 0x55, 0x7b, 0x55, 0x04, 0x8e, 0xfa, 0xe8, 0x2b, 0xa8, 0x3b, 0x74, 0xe8, 0x85, 0x38, - 0xf0, 0xbb, 0x41, 0x18, 0x69, 0x4b, 0x2d, 0x65, 0xa7, 0xf6, 0xf0, 0x43, 0x33, 0x7f, 0xe7, 0x66, - 0x3b, 0xa3, 0x3d, 0x54, 0x5f, 0xfe, 0xd3, 0x2c, 0xd9, 0x13, 0xf9, 0xe8, 0x09, 0xac, 0x8c, 0x70, - 0xc0, 0x08, 0xf5, 0xb4, 0x65, 0x5e, 0xaa, 0x39, 0xaf, 0xd4, 0x33, 0x21, 0xb3, 0x13, 0x3d, 0xba, - 0x07, 0xf5, 0x3e, 0xbe, 0xe8, 0x46, 0x1d, 0x1f, 0x07, 0x84, 0xf6, 0x35, 0xb5, 0xa5, 0xec, 0xa8, - 0x76, 0x8d, 0xc7, 0x9e, 0xf2, 0x10, 0xda, 0x80, 0x0a, 0x23, 0xae, 0x87, 0x03, 0xad, 0xcc, 0xf7, - 0x21, 0xff, 0x7d, 0xb6, 0xf6, 0xcb, 0xef, 0xcd, 0xd2, 0x4f, 0xaf, 0x5f, 0xdc, 0x97, 0x81, 0xad, - 0x26, 0xdc, 0xcd, 0x6d, 0x86, 0x8d, 0x99, 0x4f, 0x3d, 0x86, 0xb7, 0xfe, 0x2a, 0x43, 0x63, 0x46, - 0x71, 0x12, 0x44, 0xd7, 0x77, 0xeb, 0x31, 0x6c, 0xf8, 0x01, 0x1e, 0x11, 0x3a, 0x64, 0x9d, 0xf1, - 0x6e, 0x62, 0x65, 0xdc, 0xb7, 0xea, 0xe1, 0x92, 0xa6, 0xd8, 0x8d, 0x44, 0x31, 0xae, 0x7d, 0xd4, - 0x47, 0x9f, 0x42, 0x5d, 0x96, 0x65, 0x61, 0x37, 0xc4, 0xb2, 0x39, 0x0d, 0x53, 0xa0, 0x61, 0x26, - 0x68, 0x98, 0x07, 0x5e, 0x64, 0xd7, 0x84, 0xf2, 0x9b, 0x58, 0x38, 0x33, 0x20, 0xf5, 0x86, 0x03, - 0x9a, 0xee, 0x72, 0x79, 0xb6, 0xcb, 0x27, 0xb0, 0x9e, 0x4d, 0xe9, 0xc8, 0x01, 0x31, 0xad, 0xd2, - 0x5a, 0x2e, 0x32, 0xd1, 0x46, 0x36, 0x5b, 0x06, 0x19, 0x6a, 0x43, 0xdd, 0x0f, 0x28, 0x3d, 0xed, - 0x9c, 0x61, 0xe2, 0x9e, 0x85, 0xda, 0x0a, 0xdf, 0x88, 0x9e, 0x29, 0x26, 0xb8, 0x1f, 0xed, 0x99, - 0x5f, 0x70, 0x85, 0xb4, 0x5f, 0xe3, 0x59, 0x22, 0x84, 0xee, 0x02, 0x88, 0x22, 0xc4, 0x23, 0xa1, - 0xb6, 0xda, 0x52, 0x76, 0xea, 0x76, 0x95, 0x47, 0x38, 0xea, 0xf7, 0x92, 0x35, 0x44, 0x2d, 0xad, - 0xca, 0x05, 0xa2, 0x42, 0x9b, 0x87, 0xd0, 0x36, 0xac, 0x49, 0x49, 0xcc, 0x81, 0xc7, 0x86, 0x4c, - 0x03, 0xae, 0x7a, 0x47, 0xa8, 0x92, 0x28, 0xfa, 0x12, 0xde, 0x4d, 0x25, 0x89, 0xe7, 0x5a, 0x41, - 0xcf, 0x6b, 0x69, 0xa6, 0xf4, 0x3d, 0x06, 0xb7, 0x9e, 0x05, 0x17, 0x7d, 0x0e, 0xfa, 0x19, 0x65, - 0xe1, 0xd8, 0x8c, 0xc0, 0xa3, 0xc3, 0xbd, 0x68, 0xb7, 0xb8, 0xb1, 0xcd, 0x58, 0x91, 0xfa, 0xe2, - 0x54, 0x3c, 0x8d, 0x1f, 0xcf, 0x52, 0x6f, 0xc0, 0xfb, 0x79, 0x4c, 0xa7, 0xd0, 0xff, 0xa9, 0xe6, - 0x40, 0x7f, 0xe0, 0x9c, 0xa3, 0x0f, 0xe0, 0xd6, 0x24, 0xce, 0x02, 0xfc, 0xba, 0x93, 0x45, 0x78, - 0x1f, 0xf4, 0x09, 0x2c, 0x72, 0x0e, 0x80, 0xad, 0x65, 0x15, 0x13, 0x07, 0xe0, 0x06, 0x2f, 0x86, - 0xe9, 0xb3, 0xa3, 0x16, 0x3d, 0x3b, 0xd3, 0xc8, 0x95, 0xdf, 0x04, 0xb9, 0x3b, 0x20, 0x00, 0xeb, - 0x84, 0x41, 0xa4, 0x55, 0xf8, 0x44, 0x56, 0x79, 0x20, 0x7e, 0x5b, 0x4c, 0x03, 0xb7, 0x52, 0x08, - 0xb8, 0xd5, 0xc2, 0xc0, 0x55, 0x6f, 0x0e, 0x1c, 0x2c, 0x00, 0x5c, 0xed, 0x2d, 0x00, 0x77, 0xe0, - 0x9c, 0xa7, 0xc0, 0xfd, 0xa1, 0x80, 0x36, 0x23, 0x68, 0x53, 0xef, 0x94, 0x04, 0x83, 0x62, 0xd0, - 0xa5, 0xdd, 0xef, 0x3a, 0xe7, 0x9c, 0xb1, 0xa4, 0xfb, 0x31, 0xb6, 0xd3, 0xf3, 0x5d, 0x7e, 0x93, - 0xf9, 0x8e, 0x3b, 0xa5, 0x5e, 0xff, 0x4d, 0xd9, 0x82, 0xd6, 0xbc, 0xbd, 0xa4, 0x1b, 0x7e, 0x0e, - 0x6b, 0xc7, 0xcc, 0xfd, 0xd6, 0xef, 0xc7, 0x3d, 0xeb, 0x06, 0xdd, 0x01, 0xcb, 0xd4, 0x57, 0x26, - 0x26, 0xb1, 0x0f, 0x15, 0x9f, 0x2b, 0xe4, 0x37, 0xd7, 0x98, 0x77, 0x1e, 0x44, 0x1d, 0x69, 0x5d, - 0xe6, 0xcc, 0xba, 0xbb, 0x0d, 0x9b, 0x53, 0x2b, 0x27, 0xa6, 0x1e, 0xfe, 0xa7, 0xc2, 0xf2, 0x31, - 0x73, 0xd1, 0x0f, 0x80, 0x72, 0xae, 0x07, 0xbb, 0xf3, 0xd6, 0xcd, 0xfd, 0x80, 0xea, 0x9f, 0x2c, - 0x24, 0x4f, 0x3c, 0xa0, 0xef, 0xe1, 0xbd, 0xd9, 0x6f, 0xed, 0x47, 0x85, 0x6b, 0x9d, 0x04, 0x91, - 0xfe, 0xf1, 0x22, 0xea, 0xf9, 0x0b, 0xc7, 0xe0, 0x14, 0x5f, 0xf8, 0xc0, 0x39, 0x5f, 0x60, 0xe1, - 0x0c, 0xfb, 0xe8, 0x67, 0x05, 0xd6, 0xf3, 0xc1, 0x7f, 0x50, 0xb8, 0x9e, 0xcc, 0xd0, 0x1f, 0x2f, - 0x9a, 0x91, 0xba, 0x08, 0x60, 0x43, 0x30, 0x31, 0x96, 0x49, 0x2e, 0xb7, 0xaf, 0xa9, 0x99, 0xc5, - 0x48, 0xb7, 0x0a, 0x0a, 0x93, 0x35, 0xf5, 0xf2, 0x8f, 0xaf, 0x5f, 0xdc, 0x57, 0x0e, 0x9f, 0xbd, - 0xbc, 0x34, 0x94, 0x57, 0x97, 0x86, 0xf2, 0xef, 0xa5, 0xa1, 0xfc, 0x76, 0x65, 0x94, 0x5e, 0x5d, - 0x19, 0xa5, 0xbf, 0xaf, 0x8c, 0xd2, 0x77, 0xfb, 0x2e, 0x09, 0xcf, 0x86, 0x3d, 0xd3, 0xa1, 0x03, - 0x4b, 0x5e, 0x9a, 0x49, 0xcf, 0xd9, 0x75, 0xa9, 0x35, 0x7a, 0x62, 0x0d, 0x68, 0x7f, 0x78, 0x81, - 0x99, 0xb8, 0xf4, 0x3e, 0x78, 0xb4, 0x9b, 0xb9, 0xf7, 0x86, 0x91, 0x8f, 0x59, 0xaf, 0xc2, 0x5f, - 0xf8, 0x8f, 0xfe, 0x0f, 0x00, 0x00, 0xff, 0xff, 0x7c, 0x65, 0xfc, 0xe6, 0xbf, 0x0b, 0x00, 0x00, + // 798 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xa4, 0x56, 0xcd, 0x4e, 0xdb, 0x4a, + 0x14, 0x8e, 0x13, 0x27, 0x38, 0x13, 0x73, 0xc9, 0x1d, 0xf1, 0xe3, 0x6b, 0x2e, 0x4e, 0x6e, 0x6e, + 0x25, 0x22, 0x54, 0x6c, 0x7e, 0x5a, 0xa9, 0x54, 0x6c, 0x20, 0x9b, 0x12, 0x89, 0x16, 0x45, 0x94, + 0x45, 0x37, 0x51, 0xe2, 0x0c, 0x66, 0x14, 0xe2, 0xb1, 0x3c, 0x26, 0x25, 0x5d, 0x55, 0xed, 0xa6, + 0x52, 0x37, 0x7d, 0x84, 0xf6, 0x0d, 0x78, 0x0c, 0xd4, 0x15, 0xdd, 0x75, 0x55, 0x55, 0xb0, 0xe0, + 0x05, 0xfa, 0x00, 0x95, 0xc7, 0x4e, 0x6c, 0x12, 0x87, 0x26, 0xb0, 0x4b, 0x8e, 0xbf, 0xf3, 0x9d, + 0x73, 0xbe, 0xf3, 0xe9, 0x68, 0x40, 0x0e, 0xd7, 0x75, 0x4d, 0x27, 0x36, 0xd2, 0x74, 0x62, 0x9a, + 0x48, 0x77, 0x30, 0x31, 0xb5, 0xf6, 0xaa, 0xe6, 0x9c, 0xaa, 0x96, 0x4d, 0x1c, 0x02, 0x67, 0x71, + 0x5d, 0x57, 0x5d, 0x80, 0x1a, 0x00, 0xd4, 0xf6, 0xaa, 0x3c, 0x6d, 0x10, 0x83, 0x30, 0x88, 0xe6, + 0xfe, 0xf2, 0xd0, 0xf2, 0x9c, 0x4e, 0x68, 0x8b, 0x50, 0xad, 0x45, 0x0d, 0x97, 0xa5, 0x45, 0x0d, + 0xff, 0x43, 0xa8, 0xce, 0x31, 0x46, 0xa6, 0xe3, 0x7e, 0xf5, 0x7e, 0xf9, 0x80, 0xc5, 0x21, 0x8d, + 0x84, 0xaa, 0x32, 0x60, 0xe1, 0x63, 0x1c, 0xcc, 0xec, 0x52, 0xa3, 0xd4, 0x8b, 0xbf, 0xb0, 0x90, + 0xb9, 0x63, 0x62, 0x07, 0xce, 0x83, 0xb4, 0x47, 0x59, 0xc5, 0x0d, 0x89, 0xcb, 0x73, 0xc5, 0x74, + 0x45, 0xf0, 0x02, 0x3b, 0x0d, 0xf8, 0x1c, 0x88, 0x3a, 0x39, 0x31, 0x1d, 0x64, 0x5b, 0x35, 0xdb, + 0xe9, 0x48, 0xf1, 0x3c, 0x57, 0xcc, 0xac, 0x3d, 0x50, 0xa3, 0xc7, 0x53, 0x4b, 0x21, 0xec, 0x36, + 0x7f, 0xfe, 0x23, 0x17, 0xab, 0xdc, 0xc8, 0x87, 0x1b, 0x60, 0xa2, 0x8d, 0x6c, 0x8a, 0x89, 0x29, + 0x25, 0x18, 0x55, 0x6e, 0x18, 0xd5, 0x81, 0x07, 0xab, 0x74, 0xf1, 0xf0, 0x3f, 0x20, 0x36, 0xd0, + 0x71, 0xad, 0x53, 0xb5, 0x90, 0x8d, 0x49, 0x43, 0xe2, 0xf3, 0x5c, 0x91, 0xaf, 0x64, 0x58, 0x6c, + 0x8f, 0x85, 0xe0, 0x2c, 0x48, 0x51, 0x6c, 0x98, 0xc8, 0x96, 0x92, 0x6c, 0x0e, 0xff, 0xdf, 0xd3, + 0xa9, 0x0f, 0x9f, 0x73, 0xb1, 0x77, 0xd7, 0x67, 0x4b, 0x7e, 0xa0, 0x90, 0x03, 0x0b, 0x91, 0x62, + 0x54, 0x10, 0xb5, 0x88, 0x49, 0x51, 0xe1, 0x4b, 0x02, 0x4c, 0x0f, 0x20, 0xf6, 0xed, 0xce, 0x78, + 0x6a, 0xf1, 0xf7, 0x54, 0xab, 0x7f, 0xe4, 0xe4, 0xe0, 0xc8, 0xfb, 0x60, 0x26, 0x9c, 0x52, 0xf5, + 0xd5, 0xa2, 0x52, 0x2a, 0x9f, 0x18, 0x45, 0xde, 0xe9, 0x70, 0xb6, 0x1f, 0xa4, 0xb0, 0x04, 0x44, + 0xcb, 0x26, 0xe4, 0xb0, 0x7a, 0x84, 0xb0, 0x71, 0xe4, 0x48, 0x13, 0x6c, 0x10, 0x39, 0x44, 0xe6, + 0x99, 0xb0, 0xbd, 0xaa, 0x3e, 0x63, 0x08, 0xbf, 0xfd, 0x0c, 0xcb, 0xf2, 0x42, 0x70, 0x01, 0x00, + 0x8f, 0x04, 0x9b, 0xd8, 0x91, 0x84, 0x3c, 0x57, 0x14, 0x2b, 0x69, 0x16, 0x61, 0xbe, 0x0b, 0x96, + 0x25, 0xde, 0xba, 0xac, 0x32, 0x2f, 0xc4, 0xb3, 0x89, 0x32, 0x2f, 0x24, 0xb2, 0x7c, 0x99, 0x17, + 0xd2, 0x59, 0xb1, 0xcc, 0x0b, 0x93, 0xd9, 0xbf, 0x0a, 0x0a, 0xf8, 0x37, 0x6a, 0x45, 0xbd, 0x1d, + 0x7e, 0x8b, 0x47, 0xec, 0x70, 0x4b, 0x6f, 0xc2, 0xff, 0xc1, 0x64, 0x20, 0x46, 0xb0, 0x47, 0x31, + 0x08, 0xee, 0x34, 0xe0, 0x26, 0x90, 0x6f, 0x08, 0x7b, 0x33, 0x23, 0xce, 0x32, 0xa4, 0x30, 0xa2, + 0x14, 0xce, 0xbe, 0x87, 0xcf, 0xfb, 0xb5, 0x4f, 0xde, 0x45, 0xfb, 0x79, 0xe0, 0x29, 0x5d, 0x75, + 0xec, 0x8e, 0x94, 0x62, 0xd2, 0x0b, 0x2c, 0xe0, 0x7a, 0x38, 0x50, 0x1e, 0xfc, 0x49, 0x79, 0x3e, + 0x9b, 0x2c, 0xf3, 0xc2, 0x44, 0x16, 0x94, 0x79, 0x21, 0x93, 0x15, 0x23, 0x35, 0xdf, 0xd2, 0x9b, + 0x3d, 0xcd, 0xbf, 0x72, 0x40, 0x1a, 0x00, 0x94, 0x88, 0x79, 0x88, 0xed, 0xd6, 0x68, 0xba, 0xf7, + 0x3a, 0xaf, 0xe9, 0x4d, 0x26, 0x73, 0xb7, 0x73, 0x77, 0x73, 0xfd, 0xda, 0x24, 0xee, 0xa2, 0x4d, + 0x30, 0x3e, 0x7f, 0xfb, 0x95, 0x28, 0x80, 0xfc, 0xb0, 0x59, 0x7a, 0x03, 0x9f, 0x82, 0xa9, 0x5d, + 0x6a, 0xbc, 0xb4, 0x1a, 0x35, 0x07, 0xed, 0xd5, 0xec, 0x5a, 0x8b, 0x86, 0xf8, 0xb9, 0x30, 0x3f, + 0xdc, 0x04, 0x29, 0x8b, 0x21, 0xfc, 0x2b, 0xaa, 0x0c, 0xb3, 0x84, 0xc7, 0xe3, 0xb7, 0xee, 0xe7, + 0x0c, 0x76, 0xf7, 0x0f, 0x98, 0xeb, 0xab, 0xdc, 0x6d, 0x6a, 0xed, 0x17, 0x0f, 0x12, 0xbb, 0xd4, + 0x80, 0x6f, 0x00, 0x8c, 0x38, 0xf8, 0xcb, 0xc3, 0xea, 0x46, 0x9e, 0x44, 0xf9, 0xf1, 0x58, 0xf0, + 0x6e, 0x0f, 0xf0, 0x35, 0xf8, 0x7b, 0xf0, 0x7a, 0x3e, 0x1c, 0x99, 0x6b, 0xdf, 0xee, 0xc8, 0x8f, + 0xc6, 0x41, 0x0f, 0x2f, 0xec, 0x1a, 0x67, 0xf4, 0xc2, 0x5b, 0x7a, 0x73, 0x8c, 0xc2, 0x21, 0xef, + 0xc3, 0xf7, 0x1c, 0x98, 0x89, 0x36, 0xfe, 0xca, 0xc8, 0x7c, 0x7e, 0x86, 0xfc, 0x64, 0xdc, 0x8c, + 0x5e, 0x17, 0x36, 0x98, 0xf5, 0x3c, 0x11, 0xc0, 0x7c, 0x5f, 0x2e, 0xde, 0xc2, 0x19, 0xb6, 0x91, + 0xac, 0x8d, 0x08, 0xec, 0xd6, 0x94, 0x93, 0x6f, 0xaf, 0xcf, 0x96, 0xb8, 0xed, 0x83, 0xf3, 0x4b, + 0x85, 0xbb, 0xb8, 0x54, 0xb8, 0x9f, 0x97, 0x0a, 0xf7, 0xe9, 0x4a, 0x89, 0x5d, 0x5c, 0x29, 0xb1, + 0xef, 0x57, 0x4a, 0xec, 0xd5, 0xa6, 0x81, 0x9d, 0xa3, 0x93, 0xba, 0xaa, 0x93, 0x96, 0xe6, 0xbf, + 0x75, 0x70, 0x5d, 0x5f, 0x36, 0x88, 0xd6, 0xde, 0xd0, 0x5a, 0xa4, 0x71, 0x72, 0x8c, 0xa8, 0xf7, + 0x8c, 0x59, 0x59, 0x5f, 0x0e, 0xbd, 0x64, 0x9c, 0x8e, 0x85, 0x68, 0x3d, 0xc5, 0x9e, 0x30, 0xeb, + 0xbf, 0x03, 0x00, 0x00, 0xff, 0xff, 0x4b, 0x3f, 0x5a, 0x3e, 0x76, 0x09, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -880,13 +853,6 @@ func (m *MsgConnectionOpenTry) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l - if len(m.HostConsensusStateProof) > 0 { - i -= len(m.HostConsensusStateProof) - copy(dAtA[i:], m.HostConsensusStateProof) - i = encodeVarintTx(dAtA, i, uint64(len(m.HostConsensusStateProof))) - i-- - dAtA[i] = 0x6a - } if len(m.Signer) > 0 { i -= len(m.Signer) copy(dAtA[i:], m.Signer) @@ -894,30 +860,6 @@ func (m *MsgConnectionOpenTry) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x62 } - { - size, err := m.ConsensusHeight.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x5a - if len(m.ProofConsensus) > 0 { - i -= len(m.ProofConsensus) - copy(dAtA[i:], m.ProofConsensus) - i = encodeVarintTx(dAtA, i, uint64(len(m.ProofConsensus))) - i-- - dAtA[i] = 0x52 - } - if len(m.ProofClient) > 0 { - i -= len(m.ProofClient) - copy(dAtA[i:], m.ProofClient) - i = encodeVarintTx(dAtA, i, uint64(len(m.ProofClient))) - i-- - dAtA[i] = 0x4a - } if len(m.ProofInit) > 0 { i -= len(m.ProofInit) copy(dAtA[i:], m.ProofInit) @@ -964,25 +906,6 @@ func (m *MsgConnectionOpenTry) MarshalToSizedBuffer(dAtA []byte) (int, error) { } i-- dAtA[i] = 0x22 - if m.ClientState != nil { - { - size, err := m.ClientState.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - } - if len(m.PreviousConnectionId) > 0 { - i -= len(m.PreviousConnectionId) - copy(dAtA[i:], m.PreviousConnectionId) - i = encodeVarintTx(dAtA, i, uint64(len(m.PreviousConnectionId))) - i-- - dAtA[i] = 0x12 - } if len(m.ClientId) > 0 { i -= len(m.ClientId) copy(dAtA[i:], m.ClientId) @@ -1036,13 +959,6 @@ func (m *MsgConnectionOpenAck) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l - if len(m.HostConsensusStateProof) > 0 { - i -= len(m.HostConsensusStateProof) - copy(dAtA[i:], m.HostConsensusStateProof) - i = encodeVarintTx(dAtA, i, uint64(len(m.HostConsensusStateProof))) - i-- - dAtA[i] = 0x5a - } if len(m.Signer) > 0 { i -= len(m.Signer) copy(dAtA[i:], m.Signer) @@ -1050,30 +966,6 @@ func (m *MsgConnectionOpenAck) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x52 } - { - size, err := m.ConsensusHeight.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x4a - if len(m.ProofConsensus) > 0 { - i -= len(m.ProofConsensus) - copy(dAtA[i:], m.ProofConsensus) - i = encodeVarintTx(dAtA, i, uint64(len(m.ProofConsensus))) - i-- - dAtA[i] = 0x42 - } - if len(m.ProofClient) > 0 { - i -= len(m.ProofClient) - copy(dAtA[i:], m.ProofClient) - i = encodeVarintTx(dAtA, i, uint64(len(m.ProofClient))) - i-- - dAtA[i] = 0x3a - } if len(m.ProofTry) > 0 { i -= len(m.ProofTry) copy(dAtA[i:], m.ProofTry) @@ -1091,18 +983,6 @@ func (m *MsgConnectionOpenAck) MarshalToSizedBuffer(dAtA []byte) (int, error) { } i-- dAtA[i] = 0x2a - if m.ClientState != nil { - { - size, err := m.ClientState.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x22 - } if m.Version != nil { { size, err := m.Version.MarshalToSizedBuffer(dAtA[:i]) @@ -1351,14 +1231,6 @@ func (m *MsgConnectionOpenTry) Size() (n int) { if l > 0 { n += 1 + l + sovTx(uint64(l)) } - l = len(m.PreviousConnectionId) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - if m.ClientState != nil { - l = m.ClientState.Size() - n += 1 + l + sovTx(uint64(l)) - } l = m.Counterparty.Size() n += 1 + l + sovTx(uint64(l)) if m.DelayPeriod != 0 { @@ -1376,24 +1248,10 @@ func (m *MsgConnectionOpenTry) Size() (n int) { if l > 0 { n += 1 + l + sovTx(uint64(l)) } - l = len(m.ProofClient) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - l = len(m.ProofConsensus) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - l = m.ConsensusHeight.Size() - n += 1 + l + sovTx(uint64(l)) l = len(m.Signer) if l > 0 { n += 1 + l + sovTx(uint64(l)) } - l = len(m.HostConsensusStateProof) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } return n } @@ -1424,34 +1282,16 @@ func (m *MsgConnectionOpenAck) Size() (n int) { l = m.Version.Size() n += 1 + l + sovTx(uint64(l)) } - if m.ClientState != nil { - l = m.ClientState.Size() - n += 1 + l + sovTx(uint64(l)) - } l = m.ProofHeight.Size() n += 1 + l + sovTx(uint64(l)) l = len(m.ProofTry) if l > 0 { n += 1 + l + sovTx(uint64(l)) } - l = len(m.ProofClient) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - l = len(m.ProofConsensus) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - l = m.ConsensusHeight.Size() - n += 1 + l + sovTx(uint64(l)) l = len(m.Signer) if l > 0 { n += 1 + l + sovTx(uint64(l)) } - l = len(m.HostConsensusStateProof) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } return n } @@ -1839,74 +1679,6 @@ func (m *MsgConnectionOpenTry) Unmarshal(dAtA []byte) error { } m.ClientId = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PreviousConnectionId", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - stringLen |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - intStringLen := int(stringLen) - if intStringLen < 0 { - return ErrInvalidLengthTx - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthTx - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PreviousConnectionId = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ClientState", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthTx - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthTx - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.ClientState == nil { - m.ClientState = &types.Any{} - } - if err := m.ClientState.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex case 4: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Counterparty", wireType) @@ -2060,107 +1832,6 @@ func (m *MsgConnectionOpenTry) Unmarshal(dAtA []byte) error { m.ProofInit = []byte{} } iNdEx = postIndex - case 9: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ProofClient", 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.ProofClient = append(m.ProofClient[:0], dAtA[iNdEx:postIndex]...) - if m.ProofClient == nil { - m.ProofClient = []byte{} - } - iNdEx = postIndex - case 10: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ProofConsensus", 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.ProofConsensus = append(m.ProofConsensus[:0], dAtA[iNdEx:postIndex]...) - if m.ProofConsensus == nil { - m.ProofConsensus = []byte{} - } - iNdEx = postIndex - case 11: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ConsensusHeight", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthTx - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthTx - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.ConsensusHeight.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex case 12: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Signer", wireType) @@ -2193,40 +1864,6 @@ func (m *MsgConnectionOpenTry) Unmarshal(dAtA []byte) error { } m.Signer = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex - case 13: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field HostConsensusStateProof", 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.HostConsensusStateProof = append(m.HostConsensusStateProof[:0], dAtA[iNdEx:postIndex]...) - if m.HostConsensusStateProof == nil { - m.HostConsensusStateProof = []byte{} - } - iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -2427,42 +2064,6 @@ func (m *MsgConnectionOpenAck) Unmarshal(dAtA []byte) error { return err } iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ClientState", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthTx - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthTx - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.ClientState == nil { - m.ClientState = &types.Any{} - } - if err := m.ClientState.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex case 5: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field ProofHeight", wireType) @@ -2530,107 +2131,6 @@ func (m *MsgConnectionOpenAck) Unmarshal(dAtA []byte) error { m.ProofTry = []byte{} } iNdEx = postIndex - case 7: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ProofClient", 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.ProofClient = append(m.ProofClient[:0], dAtA[iNdEx:postIndex]...) - if m.ProofClient == nil { - m.ProofClient = []byte{} - } - iNdEx = postIndex - case 8: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ProofConsensus", 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.ProofConsensus = append(m.ProofConsensus[:0], dAtA[iNdEx:postIndex]...) - if m.ProofConsensus == nil { - m.ProofConsensus = []byte{} - } - iNdEx = postIndex - case 9: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ConsensusHeight", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthTx - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthTx - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.ConsensusHeight.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex case 10: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Signer", wireType) @@ -2663,40 +2163,6 @@ func (m *MsgConnectionOpenAck) Unmarshal(dAtA []byte) error { } m.Signer = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex - case 11: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field HostConsensusStateProof", 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.HostConsensusStateProof = append(m.HostConsensusStateProof[:0], dAtA[iNdEx:postIndex]...) - if m.HostConsensusStateProof == nil { - m.HostConsensusStateProof = []byte{} - } - iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) From 041bbfeb5ad49f66d275f18f80ff773d4cb1b298 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 17:27:39 +0800 Subject: [PATCH 14/33] imp: removed conflicts --- .../core/03-connection/keeper/events_test.go | 16 ++-- .../03-connection/types/connection_test.go | 1 - modules/core/03-connection/types/msgs.go | 80 ++--------------- modules/core/03-connection/types/msgs_test.go | 86 ++++--------------- testing/endpoint.go | 33 ++----- testing/solomachine.go | 14 +-- 6 files changed, 40 insertions(+), 190 deletions(-) diff --git a/modules/core/03-connection/keeper/events_test.go b/modules/core/03-connection/keeper/events_test.go index 8c718da8545..1612074e051 100644 --- a/modules/core/03-connection/keeper/events_test.go +++ b/modules/core/03-connection/keeper/events_test.go @@ -48,13 +48,13 @@ func (suite *KeeperTestSuite) TestMsgConnectionOpenTryEvents() { suite.Require().NoError(path.EndpointB.UpdateClient()) - counterpartyClient, clientProof, consensusProof, consensusHeight, initProof, proofHeight := path.EndpointB.QueryConnectionHandshakeProof() + initProof, proofHeight := path.EndpointB.QueryConnectionHandshakeProof() msg := types.NewMsgConnectionOpenTry( path.EndpointB.ClientID, path.EndpointB.Counterparty.ConnectionID, path.EndpointB.Counterparty.ClientID, - counterpartyClient, path.EndpointB.Counterparty.Chain.GetPrefix(), []*types.Version{ibctesting.ConnectionVersion}, path.EndpointB.ConnectionConfig.DelayPeriod, - initProof, clientProof, consensusProof, - proofHeight, consensusHeight, + path.EndpointB.Counterparty.Chain.GetPrefix(), []*types.Version{ibctesting.ConnectionVersion}, path.EndpointB.ConnectionConfig.DelayPeriod, + initProof, + proofHeight, path.EndpointB.Chain.SenderAccount.GetAddress().String(), ) @@ -88,13 +88,11 @@ func (suite *KeeperTestSuite) TestMsgConnectionOpenAckEvents() { suite.Require().NoError(path.EndpointA.UpdateClient()) - counterpartyClient, clientProof, consensusProof, consensusHeight, tryProof, proofHeight := path.EndpointA.QueryConnectionHandshakeProof() + tryProof, proofHeight := path.EndpointA.QueryConnectionHandshakeProof() msg := types.NewMsgConnectionOpenAck( - path.EndpointA.ConnectionID, path.EndpointA.Counterparty.ConnectionID, counterpartyClient, - tryProof, clientProof, consensusProof, - proofHeight, consensusHeight, - ibctesting.ConnectionVersion, + path.EndpointA.ConnectionID, path.EndpointA.Counterparty.ConnectionID, + tryProof, proofHeight, ibctesting.ConnectionVersion, path.EndpointA.Chain.SenderAccount.GetAddress().String(), ) diff --git a/modules/core/03-connection/types/connection_test.go b/modules/core/03-connection/types/connection_test.go index 0bfae042558..ba88f05b8e9 100644 --- a/modules/core/03-connection/types/connection_test.go +++ b/modules/core/03-connection/types/connection_test.go @@ -12,7 +12,6 @@ import ( ) var ( - chainID = "gaiamainnet" connectionID = "connection-0" clientID = "clientidone" connectionID2 = "connectionidtwo" diff --git a/modules/core/03-connection/types/msgs.go b/modules/core/03-connection/types/msgs.go index 79a741d3429..ed69c34bcf8 100644 --- a/modules/core/03-connection/types/msgs.go +++ b/modules/core/03-connection/types/msgs.go @@ -3,7 +3,6 @@ package types import ( errorsmod "cosmossdk.io/errors" - codectypes "github.com/cosmos/cosmos-sdk/codec/types" sdk "github.com/cosmos/cosmos-sdk/types" clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" @@ -25,9 +24,6 @@ var ( _ sdk.HasValidateBasic = (*MsgConnectionOpenAck)(nil) _ sdk.HasValidateBasic = (*MsgConnectionOpenTry)(nil) _ sdk.HasValidateBasic = (*MsgUpdateParams)(nil) - - _ codectypes.UnpackInterfacesMessage = (*MsgConnectionOpenTry)(nil) - _ codectypes.UnpackInterfacesMessage = (*MsgConnectionOpenAck)(nil) ) // NewMsgConnectionOpenInit creates a new MsgConnectionOpenInit instance. It sets the @@ -77,25 +73,18 @@ func (msg MsgConnectionOpenInit) ValidateBasic() error { // NewMsgConnectionOpenTry creates a new MsgConnectionOpenTry instance func NewMsgConnectionOpenTry( clientID, counterpartyConnectionID, counterpartyClientID string, - counterpartyClient exported.ClientState, counterpartyPrefix commitmenttypes.MerklePrefix, counterpartyVersions []*Version, delayPeriod uint64, - initProof, clientProof, consensusProof []byte, - proofHeight, consensusHeight clienttypes.Height, signer string, + initProof []byte, proofHeight clienttypes.Height, signer string, ) *MsgConnectionOpenTry { counterparty := NewCounterparty(counterpartyClientID, counterpartyConnectionID, counterpartyPrefix) - protoAny, _ := clienttypes.PackClientState(counterpartyClient) return &MsgConnectionOpenTry{ ClientId: clientID, - ClientState: protoAny, Counterparty: counterparty, CounterpartyVersions: counterpartyVersions, DelayPeriod: delayPeriod, ProofInit: initProof, - ProofClient: clientProof, - ProofConsensus: consensusProof, ProofHeight: proofHeight, - ConsensusHeight: consensusHeight, Signer: signer, } } @@ -106,9 +95,6 @@ func (msg MsgConnectionOpenTry) ValidateBasic() error { return errorsmod.Wrap(clienttypes.ErrInvalidClientType, "localhost connection handshakes are disallowed") } - if msg.PreviousConnectionId != "" { - return errorsmod.Wrap(ErrInvalidConnectionIdentifier, "previous connection identifier must be empty, this field has been deprecated as crossing hellos are no longer supported") - } if err := host.ClientIdentifierValidator(msg.ClientId); err != nil { return errorsmod.Wrap(err, "invalid client ID") } @@ -116,16 +102,6 @@ func (msg MsgConnectionOpenTry) ValidateBasic() error { if err := host.ConnectionIdentifierValidator(msg.Counterparty.ConnectionId); err != nil { return errorsmod.Wrap(err, "invalid counterparty connection ID") } - if msg.ClientState == nil { - return errorsmod.Wrap(clienttypes.ErrInvalidClient, "counterparty client is nil") - } - clientState, err := clienttypes.UnpackClientState(msg.ClientState) - if err != nil { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "unpack err: %v", err) - } - if err := clientState.Validate(); err != nil { - return errorsmod.Wrap(err, "counterparty client is invalid") - } if len(msg.CounterpartyVersions) == 0 { return errorsmod.Wrap(ibcerrors.ErrInvalidVersion, "empty counterparty versions") } @@ -140,55 +116,28 @@ func (msg MsgConnectionOpenTry) ValidateBasic() error { if len(msg.ProofInit) == 0 { return errorsmod.Wrap(commitmenttypes.ErrInvalidProof, "cannot submit an empty proof init") } - if len(msg.ProofClient) == 0 { - return errorsmod.Wrap(commitmenttypes.ErrInvalidProof, "cannot submit empty proof client") - } - if len(msg.ProofConsensus) == 0 { - return errorsmod.Wrap(commitmenttypes.ErrInvalidProof, "cannot submit an empty proof of consensus state") - } - if msg.ConsensusHeight.IsZero() { - return errorsmod.Wrap(ibcerrors.ErrInvalidHeight, "consensus height must be non-zero") - } - _, err = sdk.AccAddressFromBech32(msg.Signer) + _, err := sdk.AccAddressFromBech32(msg.Signer) if err != nil { return errorsmod.Wrapf(ibcerrors.ErrInvalidAddress, "string could not be parsed as address: %v", err) } return msg.Counterparty.ValidateBasic() } -// UnpackInterfaces implements UnpackInterfacesMessage.UnpackInterfaces -func (msg MsgConnectionOpenTry) UnpackInterfaces(unpacker codectypes.AnyUnpacker) error { - return unpacker.UnpackAny(msg.ClientState, new(exported.ClientState)) -} - // NewMsgConnectionOpenAck creates a new MsgConnectionOpenAck instance func NewMsgConnectionOpenAck( - connectionID, counterpartyConnectionID string, counterpartyClient exported.ClientState, - tryProof, clientProof, consensusProof []byte, - proofHeight, consensusHeight clienttypes.Height, - version *Version, - signer string, + connectionID, counterpartyConnectionID string, tryProof []byte, + proofHeight clienttypes.Height, version *Version, signer string, ) *MsgConnectionOpenAck { - protoAny, _ := clienttypes.PackClientState(counterpartyClient) return &MsgConnectionOpenAck{ ConnectionId: connectionID, CounterpartyConnectionId: counterpartyConnectionID, - ClientState: protoAny, ProofTry: tryProof, - ProofClient: clientProof, - ProofConsensus: consensusProof, ProofHeight: proofHeight, - ConsensusHeight: consensusHeight, Version: version, Signer: signer, } } -// UnpackInterfaces implements UnpackInterfacesMessage.UnpackInterfaces -func (msg MsgConnectionOpenAck) UnpackInterfaces(unpacker codectypes.AnyUnpacker) error { - return unpacker.UnpackAny(msg.ClientState, new(exported.ClientState)) -} - // ValidateBasic implements sdk.Msg func (msg MsgConnectionOpenAck) ValidateBasic() error { if !IsValidConnectionID(msg.ConnectionId) { @@ -200,29 +149,10 @@ func (msg MsgConnectionOpenAck) ValidateBasic() error { if err := ValidateVersion(msg.Version); err != nil { return err } - if msg.ClientState == nil { - return errorsmod.Wrap(clienttypes.ErrInvalidClient, "counterparty client is nil") - } - clientState, err := clienttypes.UnpackClientState(msg.ClientState) - if err != nil { - return errorsmod.Wrapf(clienttypes.ErrInvalidClient, "unpack err: %v", err) - } - if err := clientState.Validate(); err != nil { - return errorsmod.Wrap(err, "counterparty client is invalid") - } if len(msg.ProofTry) == 0 { return errorsmod.Wrap(commitmenttypes.ErrInvalidProof, "cannot submit an empty proof try") } - if len(msg.ProofClient) == 0 { - return errorsmod.Wrap(commitmenttypes.ErrInvalidProof, "cannot submit empty proof client") - } - if len(msg.ProofConsensus) == 0 { - return errorsmod.Wrap(commitmenttypes.ErrInvalidProof, "cannot submit an empty proof of consensus state") - } - if msg.ConsensusHeight.IsZero() { - return errorsmod.Wrap(ibcerrors.ErrInvalidHeight, "consensus height must be non-zero") - } - _, err = sdk.AccAddressFromBech32(msg.Signer) + _, err := sdk.AccAddressFromBech32(msg.Signer) if err != nil { return errorsmod.Wrapf(ibcerrors.ErrInvalidAddress, "string could not be parsed as address: %v", err) } diff --git a/modules/core/03-connection/types/msgs_test.go b/modules/core/03-connection/types/msgs_test.go index 60d1edb3ec1..7e8f6f23504 100644 --- a/modules/core/03-connection/types/msgs_test.go +++ b/modules/core/03-connection/types/msgs_test.go @@ -3,7 +3,6 @@ package types_test import ( "fmt" "testing" - "time" dbm "github.com/cosmos/cosmos-db" "github.com/stretchr/testify/require" @@ -19,11 +18,9 @@ import ( moduletestutil "github.com/cosmos/cosmos-sdk/types/module/testutil" ibc "github.com/cosmos/ibc-go/v9/modules/core" - clienttypes "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" "github.com/cosmos/ibc-go/v9/modules/core/03-connection/types" commitmenttypes "github.com/cosmos/ibc-go/v9/modules/core/23-commitment/types" "github.com/cosmos/ibc-go/v9/modules/core/exported" - ibctm "github.com/cosmos/ibc-go/v9/modules/light-clients/07-tendermint" ibctesting "github.com/cosmos/ibc-go/v9/testing" "github.com/cosmos/ibc-go/v9/testing/simapp" ) @@ -120,49 +117,26 @@ func (suite *MsgTestSuite) TestNewMsgConnectionOpenInit() { func (suite *MsgTestSuite) TestNewMsgConnectionOpenTry() { prefix := commitmenttypes.NewMerklePrefix([]byte("storePrefixKey")) - - clientState := ibctm.NewClientState( - chainID, ibctm.DefaultTrustLevel, ibctesting.TrustingPeriod, ibctesting.UnbondingPeriod, ibctesting.MaxClockDrift, clientHeight, commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath, - ) - protoAny, err := clienttypes.PackClientState(clientState) - suite.Require().NoError(err) - - // Pack consensus state into any to test unpacking error - consState := ibctm.NewConsensusState( - time.Now(), commitmenttypes.NewMerkleRoot([]byte("root")), []byte("nextValsHash"), - ) - invalidAny := clienttypes.MustPackConsensusState(consState) counterparty := types.NewCounterparty("connectiontotest", "clienttotest", prefix) - // invalidClientState fails validateBasic - invalidClient := ibctm.NewClientState( - chainID, ibctm.DefaultTrustLevel, ibctesting.TrustingPeriod, ibctesting.UnbondingPeriod, ibctesting.MaxClockDrift, clienttypes.ZeroHeight(), commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath, - ) - testCases := []struct { name string msg *types.MsgConnectionOpenTry expPass bool }{ - {"non empty connection ID", &types.MsgConnectionOpenTry{"connection-0", "clienttotesta", protoAny, counterparty, 500, []*types.Version{ibctesting.ConnectionVersion}, clientHeight, suite.proof, suite.proof, suite.proof, clientHeight, signer, nil}, false}, - {"localhost client ID", types.NewMsgConnectionOpenTry(exported.LocalhostClientID, "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"invalid client ID", types.NewMsgConnectionOpenTry("test/iris", "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"invalid counterparty connection ID", types.NewMsgConnectionOpenTry("clienttotesta", "ibc/test", "clienttotest", clientState, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"invalid counterparty client ID", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "test/conn1", clientState, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"invalid nil counterparty client", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", nil, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"invalid client unpacking", &types.MsgConnectionOpenTry{"", "clienttotesta", invalidAny, counterparty, 500, []*types.Version{ibctesting.ConnectionVersion}, clientHeight, suite.proof, suite.proof, suite.proof, clientHeight, signer, nil}, false}, - {"counterparty failed validate", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", invalidClient, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"empty counterparty prefix", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, emptyPrefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"empty counterpartyVersions", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"empty proofInit", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, emptyProof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"empty proofClient", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, emptyProof, suite.proof, clientHeight, clientHeight, signer), false}, - {"empty proofConsensus", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, emptyProof, clientHeight, clientHeight, signer), false}, - {"invalid consensusHeight", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clienttypes.ZeroHeight(), signer), false}, - {"empty singer", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, ""), false}, - {"invalid version", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{{}}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"too many counterparty versions", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, prefix, make([]*types.Version, types.MaxCounterpartyVersionsLength+1), 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"too many features in counterparty version", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{{"v1", make([]string, types.MaxFeaturesLength+1)}}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), false}, - {"success", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", clientState, prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, signer), true}, + {"success", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, signer), true}, + {"non empty connection ID", &types.MsgConnectionOpenTry{"connection-0", counterparty, 500, []*types.Version{ibctesting.ConnectionVersion}, clientHeight, suite.proof, signer}, false}, + {"localhost client ID", types.NewMsgConnectionOpenTry(exported.LocalhostClientID, "connectiontotest", "clienttotest", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, signer), false}, + {"invalid client ID", types.NewMsgConnectionOpenTry("test/iris", "connectiontotest", "clienttotest", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, signer), false}, + {"invalid counterparty connection ID", types.NewMsgConnectionOpenTry("clienttotesta", "ibc/test", "clienttotest", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, signer), false}, + {"invalid counterparty client ID", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "test/conn1", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, signer), false}, + {"empty counterparty prefix", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", emptyPrefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, signer), false}, + {"empty counterpartyVersions", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", prefix, []*types.Version{}, 500, suite.proof, clientHeight, signer), false}, + {"empty proofInit", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, emptyProof, clientHeight, signer), false}, + {"empty singer", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, ""), false}, + {"invalid version", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", prefix, []*types.Version{{}}, 500, suite.proof, clientHeight, signer), false}, + {"too many counterparty versions", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", prefix, make([]*types.Version, types.MaxCounterpartyVersionsLength+1), 500, suite.proof, clientHeight, signer), false}, + {"too many features in counterparty version", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", prefix, []*types.Version{{"v1", make([]string, types.MaxFeaturesLength+1)}}, 500, suite.proof, clientHeight, signer), false}, } for _, tc := range testCases { @@ -178,39 +152,17 @@ func (suite *MsgTestSuite) TestNewMsgConnectionOpenTry() { } func (suite *MsgTestSuite) TestNewMsgConnectionOpenAck() { - clientState := ibctm.NewClientState( - chainID, ibctm.DefaultTrustLevel, ibctesting.TrustingPeriod, ibctesting.UnbondingPeriod, ibctesting.MaxClockDrift, clientHeight, commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath, - ) - - // Pack consensus state into any to test unpacking error - consState := ibctm.NewConsensusState( - time.Now(), commitmenttypes.NewMerkleRoot([]byte("root")), []byte("nextValsHash"), - ) - invalidAny := clienttypes.MustPackConsensusState(consState) - - // invalidClientState fails validateBasic - invalidClient := ibctm.NewClientState( - chainID, ibctm.DefaultTrustLevel, ibctesting.TrustingPeriod, ibctesting.UnbondingPeriod, ibctesting.MaxClockDrift, clienttypes.ZeroHeight(), commitmenttypes.GetSDKSpecs(), ibctesting.UpgradePath, - ) - connectionID := "connection-0" - testCases := []struct { name string msg *types.MsgConnectionOpenAck expPass bool }{ - {"invalid connection ID", types.NewMsgConnectionOpenAck("test/conn1", connectionID, clientState, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, ibctesting.ConnectionVersion, signer), false}, - {"invalid counterparty connection ID", types.NewMsgConnectionOpenAck(connectionID, "test/conn1", clientState, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, ibctesting.ConnectionVersion, signer), false}, - {"invalid nil counterparty client", types.NewMsgConnectionOpenAck(connectionID, connectionID, nil, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, ibctesting.ConnectionVersion, signer), false}, - {"invalid unpacking counterparty client", &types.MsgConnectionOpenAck{connectionID, connectionID, ibctesting.ConnectionVersion, invalidAny, clientHeight, suite.proof, suite.proof, suite.proof, clientHeight, signer, nil}, false}, - {"counterparty client failed validate", types.NewMsgConnectionOpenAck(connectionID, connectionID, invalidClient, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, ibctesting.ConnectionVersion, signer), false}, - {"empty proofTry", types.NewMsgConnectionOpenAck(connectionID, connectionID, clientState, emptyProof, suite.proof, suite.proof, clientHeight, clientHeight, ibctesting.ConnectionVersion, signer), false}, - {"empty proofClient", types.NewMsgConnectionOpenAck(connectionID, connectionID, clientState, suite.proof, emptyProof, suite.proof, clientHeight, clientHeight, ibctesting.ConnectionVersion, signer), false}, - {"empty proofConsensus", types.NewMsgConnectionOpenAck(connectionID, connectionID, clientState, suite.proof, suite.proof, emptyProof, clientHeight, clientHeight, ibctesting.ConnectionVersion, signer), false}, - {"invalid consensusHeight", types.NewMsgConnectionOpenAck(connectionID, connectionID, clientState, suite.proof, suite.proof, suite.proof, clientHeight, clienttypes.ZeroHeight(), ibctesting.ConnectionVersion, signer), false}, - {"invalid version", types.NewMsgConnectionOpenAck(connectionID, connectionID, clientState, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, &types.Version{}, signer), false}, - {"empty signer", types.NewMsgConnectionOpenAck(connectionID, connectionID, clientState, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, ibctesting.ConnectionVersion, ""), false}, - {"success", types.NewMsgConnectionOpenAck(connectionID, connectionID, clientState, suite.proof, suite.proof, suite.proof, clientHeight, clientHeight, ibctesting.ConnectionVersion, signer), true}, + {"success", types.NewMsgConnectionOpenAck(connectionID, connectionID, suite.proof, clientHeight, ibctesting.ConnectionVersion, signer), true}, + {"invalid connection ID", types.NewMsgConnectionOpenAck("test/conn1", connectionID, suite.proof, clientHeight, ibctesting.ConnectionVersion, signer), false}, + {"invalid counterparty connection ID", types.NewMsgConnectionOpenAck(connectionID, "test/conn1", suite.proof, clientHeight, ibctesting.ConnectionVersion, signer), false}, + {"empty proofTry", types.NewMsgConnectionOpenAck(connectionID, connectionID, emptyProof, clientHeight, ibctesting.ConnectionVersion, signer), false}, + {"invalid version", types.NewMsgConnectionOpenAck(connectionID, connectionID, suite.proof, clientHeight, &types.Version{}, signer), false}, + {"empty signer", types.NewMsgConnectionOpenAck(connectionID, connectionID, suite.proof, clientHeight, ibctesting.ConnectionVersion, ""), false}, } for _, tc := range testCases { diff --git a/testing/endpoint.go b/testing/endpoint.go index a790cdd8be7..9aea724b3b9 100644 --- a/testing/endpoint.go +++ b/testing/endpoint.go @@ -244,13 +244,12 @@ func (endpoint *Endpoint) ConnOpenTry() error { err := endpoint.UpdateClient() require.NoError(endpoint.Chain.TB, err) - counterpartyClient, clientProof, consensusProof, consensusHeight, initProof, proofHeight := endpoint.QueryConnectionHandshakeProof() + initProof, proofHeight := endpoint.QueryConnectionHandshakeProof() msg := connectiontypes.NewMsgConnectionOpenTry( endpoint.ClientID, endpoint.Counterparty.ConnectionID, endpoint.Counterparty.ClientID, - counterpartyClient, endpoint.Counterparty.Chain.GetPrefix(), []*connectiontypes.Version{ConnectionVersion}, endpoint.ConnectionConfig.DelayPeriod, - initProof, clientProof, consensusProof, - proofHeight, consensusHeight, + endpoint.Counterparty.Chain.GetPrefix(), []*connectiontypes.Version{ConnectionVersion}, + endpoint.ConnectionConfig.DelayPeriod, initProof, proofHeight, endpoint.Chain.SenderAccount.GetAddress().String(), ) res, err := endpoint.Chain.SendMsgs(msg) @@ -271,13 +270,11 @@ func (endpoint *Endpoint) ConnOpenAck() error { err := endpoint.UpdateClient() require.NoError(endpoint.Chain.TB, err) - counterpartyClient, clientProof, consensusProof, consensusHeight, tryProof, proofHeight := endpoint.QueryConnectionHandshakeProof() + tryProof, proofHeight := endpoint.QueryConnectionHandshakeProof() msg := connectiontypes.NewMsgConnectionOpenAck( - endpoint.ConnectionID, endpoint.Counterparty.ConnectionID, counterpartyClient, // testing doesn't use flexible selection - tryProof, clientProof, consensusProof, - proofHeight, consensusHeight, - ConnectionVersion, + endpoint.ConnectionID, endpoint.Counterparty.ConnectionID, // testing doesn't use flexible selection + tryProof, proofHeight, ConnectionVersion, endpoint.Chain.SenderAccount.GetAddress().String(), ) return endpoint.Chain.sendMsgs(msg) @@ -304,29 +301,13 @@ func (endpoint *Endpoint) ConnOpenConfirm() error { // client state, proof of the counterparty consensus state, the consensus state height, proof of // the counterparty connection, and the proof height for all the proofs returned. func (endpoint *Endpoint) QueryConnectionHandshakeProof() ( - clientState exported.ClientState, clientProof, - consensusProof []byte, consensusHeight clienttypes.Height, connectionProof []byte, proofHeight clienttypes.Height, ) { - // obtain the client state on the counterparty chain - clientState = endpoint.Counterparty.Chain.GetClientState(endpoint.Counterparty.ClientID) - - // query proof for the client state on the counterparty - clientKey := host.FullClientStateKey(endpoint.Counterparty.ClientID) - clientProof, proofHeight = endpoint.Counterparty.QueryProof(clientKey) - - var ok bool - consensusHeight, ok = endpoint.Counterparty.GetClientLatestHeight().(clienttypes.Height) - require.True(endpoint.Chain.TB, ok) - // query proof for the consensus state on the counterparty - consensusKey := host.FullConsensusStateKey(endpoint.Counterparty.ClientID, consensusHeight) - consensusProof, _ = endpoint.Counterparty.QueryProofAtHeight(consensusKey, proofHeight.GetRevisionHeight()) - // query proof for the connection on the counterparty connectionKey := host.ConnectionKey(endpoint.Counterparty.ConnectionID) connectionProof, _ = endpoint.Counterparty.QueryProofAtHeight(connectionKey, proofHeight.GetRevisionHeight()) - return clientState, clientProof, consensusProof, consensusHeight, connectionProof, proofHeight + return connectionProof, proofHeight } var sequenceNumber int diff --git a/testing/solomachine.go b/testing/solomachine.go index ef8c5dc8b5e..538391eec76 100644 --- a/testing/solomachine.go +++ b/testing/solomachine.go @@ -24,7 +24,6 @@ import ( host "github.com/cosmos/ibc-go/v9/modules/core/24-host" "github.com/cosmos/ibc-go/v9/modules/core/exported" solomachine "github.com/cosmos/ibc-go/v9/modules/light-clients/06-solomachine" - ibctm "github.com/cosmos/ibc-go/v9/modules/light-clients/07-tendermint" ) var ( @@ -287,18 +286,9 @@ func (solo *Solomachine) ConnOpenInit(chain *TestChain, clientID string) string func (solo *Solomachine) ConnOpenAck(chain *TestChain, clientID, connectionID string) { tryProof := solo.GenerateConnOpenTryProof(clientID, connectionID) - clientState := ibctm.NewClientState(chain.ChainID, DefaultTrustLevel, TrustingPeriod, UnbondingPeriod, MaxClockDrift, chain.LatestCommittedHeader.GetHeight().(clienttypes.Height), commitmenttypes.GetSDKSpecs(), UpgradePath) - clientProof := solo.GenerateClientStateProof(clientState) - - consensusState := chain.LatestCommittedHeader.ConsensusState() - consensusHeight := chain.LatestCommittedHeader.GetHeight() - consensusProof := solo.GenerateConsensusStateProof(consensusState, consensusHeight) - msgConnOpenAck := connectiontypes.NewMsgConnectionOpenAck( - connectionID, connectionIDSolomachine, clientState, - tryProof, clientProof, consensusProof, - clienttypes.ZeroHeight(), clientState.LatestHeight, - ConnectionVersion, + connectionID, connectionIDSolomachine, tryProof, + clienttypes.ZeroHeight(), ConnectionVersion, chain.SenderAccount.GetAddress().String(), ) From 3d8c8ccbf595ef3d9282ec882b9bb14e72610032 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 17:29:09 +0800 Subject: [PATCH 15/33] imp: removed more code --- testing/solomachine.go | 36 ------------------------------------ 1 file changed, 36 deletions(-) diff --git a/testing/solomachine.go b/testing/solomachine.go index 538391eec76..5ad66250e69 100644 --- a/testing/solomachine.go +++ b/testing/solomachine.go @@ -503,42 +503,6 @@ func (solo *Solomachine) GenerateProof(signBytes *solomachine.SignBytes) []byte return proof } -// GenerateClientStateProof generates the proof of the client state required for the connection open try and ack handshake steps. -// The client state should be the self client states of the tendermint chain. -func (solo *Solomachine) GenerateClientStateProof(clientState exported.ClientState) []byte { - data, err := clienttypes.MarshalClientState(solo.cdc, clientState) - require.NoError(solo.t, err) - - path := host.FullClientStateKey(clientIDSolomachine) - signBytes := &solomachine.SignBytes{ - Sequence: solo.Sequence, - Timestamp: solo.Time, - Diversifier: solo.Diversifier, - Path: path, - Data: data, - } - - return solo.GenerateProof(signBytes) -} - -// GenerateConsensusStateProof generates the proof of the consensus state required for the connection open try and ack handshake steps. -// The consensus state should be the self consensus states of the tendermint chain. -func (solo *Solomachine) GenerateConsensusStateProof(consensusState exported.ConsensusState, consensusHeight exported.Height) []byte { - data, err := clienttypes.MarshalConsensusState(solo.cdc, consensusState) - require.NoError(solo.t, err) - - path := host.FullConsensusStateKey(clientIDSolomachine, consensusHeight) - signBytes := &solomachine.SignBytes{ - Sequence: solo.Sequence, - Timestamp: solo.Time, - Diversifier: solo.Diversifier, - Path: path, - Data: data, - } - - return solo.GenerateProof(signBytes) -} - // GenerateConnOpenTryProof generates the proofTry required for the connection open ack handshake step. // The clientID, connectionID provided represent the clientID and connectionID created on the counterparty chain, that is the tendermint chain. func (solo *Solomachine) GenerateConnOpenTryProof(counterpartyClientID, counterpartyConnectionID string) []byte { From 6f45ddfb19faf4e7f70d43fc694062b0da269fb5 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 17:46:48 +0800 Subject: [PATCH 16/33] fix: tests --- testing/endpoint.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/testing/endpoint.go b/testing/endpoint.go index 9aea724b3b9..931bc814a95 100644 --- a/testing/endpoint.go +++ b/testing/endpoint.go @@ -305,7 +305,7 @@ func (endpoint *Endpoint) QueryConnectionHandshakeProof() ( ) { // query proof for the connection on the counterparty connectionKey := host.ConnectionKey(endpoint.Counterparty.ConnectionID) - connectionProof, _ = endpoint.Counterparty.QueryProofAtHeight(connectionKey, proofHeight.GetRevisionHeight()) + connectionProof, proofHeight = endpoint.Counterparty.QueryProof(connectionKey) return connectionProof, proofHeight } From ab3d3b0a3d8ae1ffb248d70c910c6c672f36bb46 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 17:49:18 +0800 Subject: [PATCH 17/33] feat: all tests passing --- modules/core/03-connection/types/msgs_test.go | 2 -- 1 file changed, 2 deletions(-) diff --git a/modules/core/03-connection/types/msgs_test.go b/modules/core/03-connection/types/msgs_test.go index 7e8f6f23504..6e6b741bd3f 100644 --- a/modules/core/03-connection/types/msgs_test.go +++ b/modules/core/03-connection/types/msgs_test.go @@ -117,7 +117,6 @@ func (suite *MsgTestSuite) TestNewMsgConnectionOpenInit() { func (suite *MsgTestSuite) TestNewMsgConnectionOpenTry() { prefix := commitmenttypes.NewMerklePrefix([]byte("storePrefixKey")) - counterparty := types.NewCounterparty("connectiontotest", "clienttotest", prefix) testCases := []struct { name string @@ -125,7 +124,6 @@ func (suite *MsgTestSuite) TestNewMsgConnectionOpenTry() { expPass bool }{ {"success", types.NewMsgConnectionOpenTry("clienttotesta", "connectiontotest", "clienttotest", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, signer), true}, - {"non empty connection ID", &types.MsgConnectionOpenTry{"connection-0", counterparty, 500, []*types.Version{ibctesting.ConnectionVersion}, clientHeight, suite.proof, signer}, false}, {"localhost client ID", types.NewMsgConnectionOpenTry(exported.LocalhostClientID, "connectiontotest", "clienttotest", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, signer), false}, {"invalid client ID", types.NewMsgConnectionOpenTry("test/iris", "connectiontotest", "clienttotest", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, signer), false}, {"invalid counterparty connection ID", types.NewMsgConnectionOpenTry("clienttotesta", "ibc/test", "clienttotest", prefix, []*types.Version{ibctesting.ConnectionVersion}, 500, suite.proof, clientHeight, signer), false}, From f9132f301c0d1ddb57308b604c1ba7d513b4a6d0 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 19:01:06 +0800 Subject: [PATCH 18/33] fix: added the reserved proto fields back with deprecation notice --- proto/ibc/core/connection/v1/tx.proto | 42 ++++++++++++++++++++------- 1 file changed, 31 insertions(+), 11 deletions(-) diff --git a/proto/ibc/core/connection/v1/tx.proto b/proto/ibc/core/connection/v1/tx.proto index 65885571cf5..f0f8a901d5a 100644 --- a/proto/ibc/core/connection/v1/tx.proto +++ b/proto/ibc/core/connection/v1/tx.proto @@ -6,6 +6,7 @@ option go_package = "github.com/cosmos/ibc-go/v9/modules/core/03-connection/type import "gogoproto/gogo.proto"; import "cosmos/msg/v1/msg.proto"; +import "google/protobuf/any.proto"; import "ibc/core/client/v1/client.proto"; import "ibc/core/connection/v1/connection.proto"; @@ -56,16 +57,26 @@ message MsgConnectionOpenTry { option (gogoproto.goproto_getters) = false; - reserved 2, 3, 9 to 11, 13; - string client_id = 1; - Counterparty counterparty = 4 [(gogoproto.nullable) = false]; - uint64 delay_period = 5; - repeated Version counterparty_versions = 6; - ibc.core.client.v1.Height proof_height = 7 [(gogoproto.nullable) = false]; + string client_id = 1; + // Deprecated: this field is unused. Crossing hellos are no longer supported in core IBC. + string previous_connection_id = 2 [deprecated = true]; + google.protobuf.Any client_state = 3 [deprecated = true]; + Counterparty counterparty = 4 [(gogoproto.nullable) = false]; + uint64 delay_period = 5; + repeated Version counterparty_versions = 6; + ibc.core.client.v1.Height proof_height = 7 [(gogoproto.nullable) = false]; // proof of the initialization the connection on Chain A: `UNINITIALIZED -> // INIT` - bytes proof_init = 8; - string signer = 12; + bytes proof_init = 8; + // Deprecated: this field is unused. + bytes proof_client = 9 [deprecated = true]; + // Deprecated: this field is unused. + bytes proof_consensus = 10 [deprecated = true]; + // Deprecated: this field is unused. + ibc.core.client.v1.Height consensus_height = 11 [deprecated = true]; + string signer = 12; + // Deprecated: this field is unused. + bytes host_consensus_state_proof = 13 [deprecated = true]; } // MsgConnectionOpenTryResponse defines the Msg/ConnectionOpenTry response type. @@ -78,15 +89,24 @@ message MsgConnectionOpenAck { option (gogoproto.goproto_getters) = false; - reserved 4, 7 to 9, 11; string connection_id = 1; string counterparty_connection_id = 2; Version version = 3; + // Deprecated: this field is unused. + google.protobuf.Any client_state = 4 [deprecated = true]; ibc.core.client.v1.Height proof_height = 5 [(gogoproto.nullable) = false]; // proof of the initialization the connection on Chain B: `UNINITIALIZED -> // TRYOPEN` - bytes proof_try = 6; - string signer = 10; + bytes proof_try = 6; + // Deprecated: this field is unused. + bytes proof_client = 7 [deprecated = true]; + // Deprecated: this field is unused. + bytes proof_consensus = 8 [deprecated = true]; + // Deprecated: this field is unused. + ibc.core.client.v1.Height consensus_height = 9 [deprecated = true]; + string signer = 10; + // Deprecated: this field is unused. + bytes host_consensus_state_proof = 11 [deprecated = true]; } // MsgConnectionOpenAckResponse defines the Msg/ConnectionOpenAck response type. From de6244a0c7f88fdedebeb6dcea7c45cacdbdfa04 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 19:03:11 +0800 Subject: [PATCH 19/33] style: linted --- proto/ibc/core/connection/v1/tx.proto | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/proto/ibc/core/connection/v1/tx.proto b/proto/ibc/core/connection/v1/tx.proto index f0f8a901d5a..aea19ceb4fa 100644 --- a/proto/ibc/core/connection/v1/tx.proto +++ b/proto/ibc/core/connection/v1/tx.proto @@ -71,7 +71,7 @@ message MsgConnectionOpenTry { // Deprecated: this field is unused. bytes proof_client = 9 [deprecated = true]; // Deprecated: this field is unused. - bytes proof_consensus = 10 [deprecated = true]; + bytes proof_consensus = 10 [deprecated = true]; // Deprecated: this field is unused. ibc.core.client.v1.Height consensus_height = 11 [deprecated = true]; string signer = 12; @@ -89,19 +89,19 @@ message MsgConnectionOpenAck { option (gogoproto.goproto_getters) = false; - string connection_id = 1; - string counterparty_connection_id = 2; - Version version = 3; + string connection_id = 1; + string counterparty_connection_id = 2; + Version version = 3; // Deprecated: this field is unused. - google.protobuf.Any client_state = 4 [deprecated = true]; - ibc.core.client.v1.Height proof_height = 5 [(gogoproto.nullable) = false]; + google.protobuf.Any client_state = 4 [deprecated = true]; + ibc.core.client.v1.Height proof_height = 5 [(gogoproto.nullable) = false]; // proof of the initialization the connection on Chain B: `UNINITIALIZED -> // TRYOPEN` bytes proof_try = 6; // Deprecated: this field is unused. bytes proof_client = 7 [deprecated = true]; // Deprecated: this field is unused. - bytes proof_consensus = 8 [deprecated = true]; + bytes proof_consensus = 8 [deprecated = true]; // Deprecated: this field is unused. ibc.core.client.v1.Height consensus_height = 9 [deprecated = true]; string signer = 10; From 90c8394c2ae4f4f89630e3f7cc2b7a2ee14d6835 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 19:09:26 +0800 Subject: [PATCH 20/33] imp: regenerated proto --- modules/core/03-connection/types/tx.pb.go | 684 +++++++++++++++++++--- 1 file changed, 618 insertions(+), 66 deletions(-) diff --git a/modules/core/03-connection/types/tx.pb.go b/modules/core/03-connection/types/tx.pb.go index a3e882f2a99..6e415bdd662 100644 --- a/modules/core/03-connection/types/tx.pb.go +++ b/modules/core/03-connection/types/tx.pb.go @@ -6,11 +6,12 @@ package types import ( context "context" fmt "fmt" + types "github.com/cosmos/cosmos-sdk/codec/types" _ "github.com/cosmos/cosmos-sdk/types/msgservice" _ "github.com/cosmos/gogoproto/gogoproto" grpc1 "github.com/cosmos/gogoproto/grpc" proto "github.com/cosmos/gogoproto/proto" - types "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" + types1 "github.com/cosmos/ibc-go/v9/modules/core/02-client/types" grpc "google.golang.org/grpc" codes "google.golang.org/grpc/codes" status "google.golang.org/grpc/status" @@ -114,15 +115,26 @@ var xxx_messageInfo_MsgConnectionOpenInitResponse proto.InternalMessageInfo // MsgConnectionOpenTry defines a msg sent by a Relayer to try to open a // connection on Chain B. type MsgConnectionOpenTry struct { - ClientId string `protobuf:"bytes,1,opt,name=client_id,json=clientId,proto3" json:"client_id,omitempty"` - Counterparty Counterparty `protobuf:"bytes,4,opt,name=counterparty,proto3" json:"counterparty"` - DelayPeriod uint64 `protobuf:"varint,5,opt,name=delay_period,json=delayPeriod,proto3" json:"delay_period,omitempty"` - CounterpartyVersions []*Version `protobuf:"bytes,6,rep,name=counterparty_versions,json=counterpartyVersions,proto3" json:"counterparty_versions,omitempty"` - ProofHeight types.Height `protobuf:"bytes,7,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` + ClientId string `protobuf:"bytes,1,opt,name=client_id,json=clientId,proto3" json:"client_id,omitempty"` + // Deprecated: this field is unused. Crossing hellos are no longer supported in core IBC. + PreviousConnectionId string `protobuf:"bytes,2,opt,name=previous_connection_id,json=previousConnectionId,proto3" json:"previous_connection_id,omitempty"` // Deprecated: Do not use. + ClientState *types.Any `protobuf:"bytes,3,opt,name=client_state,json=clientState,proto3" json:"client_state,omitempty"` // Deprecated: Do not use. + Counterparty Counterparty `protobuf:"bytes,4,opt,name=counterparty,proto3" json:"counterparty"` + DelayPeriod uint64 `protobuf:"varint,5,opt,name=delay_period,json=delayPeriod,proto3" json:"delay_period,omitempty"` + CounterpartyVersions []*Version `protobuf:"bytes,6,rep,name=counterparty_versions,json=counterpartyVersions,proto3" json:"counterparty_versions,omitempty"` + ProofHeight types1.Height `protobuf:"bytes,7,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` // proof of the initialization the connection on Chain A: `UNINITIALIZED -> // INIT` ProofInit []byte `protobuf:"bytes,8,opt,name=proof_init,json=proofInit,proto3" json:"proof_init,omitempty"` - Signer string `protobuf:"bytes,12,opt,name=signer,proto3" json:"signer,omitempty"` + // Deprecated: this field is unused. + ProofClient []byte `protobuf:"bytes,9,opt,name=proof_client,json=proofClient,proto3" json:"proof_client,omitempty"` // Deprecated: Do not use. + // Deprecated: this field is unused. + ProofConsensus []byte `protobuf:"bytes,10,opt,name=proof_consensus,json=proofConsensus,proto3" json:"proof_consensus,omitempty"` // Deprecated: Do not use. + // Deprecated: this field is unused. + ConsensusHeight *types1.Height `protobuf:"bytes,11,opt,name=consensus_height,json=consensusHeight,proto3" json:"consensus_height,omitempty"` // Deprecated: Do not use. + Signer string `protobuf:"bytes,12,opt,name=signer,proto3" json:"signer,omitempty"` + // Deprecated: this field is unused. + HostConsensusStateProof []byte `protobuf:"bytes,13,opt,name=host_consensus_state_proof,json=hostConsensusStateProof,proto3" json:"host_consensus_state_proof,omitempty"` // Deprecated: Do not use. } func (m *MsgConnectionOpenTry) Reset() { *m = MsgConnectionOpenTry{} } @@ -198,14 +210,24 @@ var xxx_messageInfo_MsgConnectionOpenTryResponse proto.InternalMessageInfo // MsgConnectionOpenAck defines a msg sent by a Relayer to Chain A to // acknowledge the change of connection state to TRYOPEN on Chain B. type MsgConnectionOpenAck struct { - ConnectionId string `protobuf:"bytes,1,opt,name=connection_id,json=connectionId,proto3" json:"connection_id,omitempty"` - CounterpartyConnectionId string `protobuf:"bytes,2,opt,name=counterparty_connection_id,json=counterpartyConnectionId,proto3" json:"counterparty_connection_id,omitempty"` - Version *Version `protobuf:"bytes,3,opt,name=version,proto3" json:"version,omitempty"` - ProofHeight types.Height `protobuf:"bytes,5,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` + ConnectionId string `protobuf:"bytes,1,opt,name=connection_id,json=connectionId,proto3" json:"connection_id,omitempty"` + CounterpartyConnectionId string `protobuf:"bytes,2,opt,name=counterparty_connection_id,json=counterpartyConnectionId,proto3" json:"counterparty_connection_id,omitempty"` + Version *Version `protobuf:"bytes,3,opt,name=version,proto3" json:"version,omitempty"` + // Deprecated: this field is unused. + ClientState *types.Any `protobuf:"bytes,4,opt,name=client_state,json=clientState,proto3" json:"client_state,omitempty"` // Deprecated: Do not use. + ProofHeight types1.Height `protobuf:"bytes,5,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` // proof of the initialization the connection on Chain B: `UNINITIALIZED -> // TRYOPEN` ProofTry []byte `protobuf:"bytes,6,opt,name=proof_try,json=proofTry,proto3" json:"proof_try,omitempty"` - Signer string `protobuf:"bytes,10,opt,name=signer,proto3" json:"signer,omitempty"` + // Deprecated: this field is unused. + ProofClient []byte `protobuf:"bytes,7,opt,name=proof_client,json=proofClient,proto3" json:"proof_client,omitempty"` // Deprecated: Do not use. + // Deprecated: this field is unused. + ProofConsensus []byte `protobuf:"bytes,8,opt,name=proof_consensus,json=proofConsensus,proto3" json:"proof_consensus,omitempty"` // Deprecated: Do not use. + // Deprecated: this field is unused. + ConsensusHeight *types1.Height `protobuf:"bytes,9,opt,name=consensus_height,json=consensusHeight,proto3" json:"consensus_height,omitempty"` // Deprecated: Do not use. + Signer string `protobuf:"bytes,10,opt,name=signer,proto3" json:"signer,omitempty"` + // Deprecated: this field is unused. + HostConsensusStateProof []byte `protobuf:"bytes,11,opt,name=host_consensus_state_proof,json=hostConsensusStateProof,proto3" json:"host_consensus_state_proof,omitempty"` // Deprecated: Do not use. } func (m *MsgConnectionOpenAck) Reset() { *m = MsgConnectionOpenAck{} } @@ -283,9 +305,9 @@ var xxx_messageInfo_MsgConnectionOpenAckResponse proto.InternalMessageInfo type MsgConnectionOpenConfirm struct { ConnectionId string `protobuf:"bytes,1,opt,name=connection_id,json=connectionId,proto3" json:"connection_id,omitempty"` // proof for the change of the connection state on Chain A: `INIT -> OPEN` - ProofAck []byte `protobuf:"bytes,2,opt,name=proof_ack,json=proofAck,proto3" json:"proof_ack,omitempty"` - ProofHeight types.Height `protobuf:"bytes,3,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` - Signer string `protobuf:"bytes,4,opt,name=signer,proto3" json:"signer,omitempty"` + ProofAck []byte `protobuf:"bytes,2,opt,name=proof_ack,json=proofAck,proto3" json:"proof_ack,omitempty"` + ProofHeight types1.Height `protobuf:"bytes,3,opt,name=proof_height,json=proofHeight,proto3" json:"proof_height"` + Signer string `protobuf:"bytes,4,opt,name=signer,proto3" json:"signer,omitempty"` } func (m *MsgConnectionOpenConfirm) Reset() { *m = MsgConnectionOpenConfirm{} } @@ -455,57 +477,66 @@ func init() { func init() { proto.RegisterFile("ibc/core/connection/v1/tx.proto", fileDescriptor_5d00fde5fc97399e) } var fileDescriptor_5d00fde5fc97399e = []byte{ - // 798 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xa4, 0x56, 0xcd, 0x4e, 0xdb, 0x4a, - 0x14, 0x8e, 0x13, 0x27, 0x38, 0x13, 0x73, 0xc9, 0x1d, 0xf1, 0xe3, 0x6b, 0x2e, 0x4e, 0x6e, 0x6e, - 0x25, 0x22, 0x54, 0x6c, 0x7e, 0x5a, 0xa9, 0x54, 0x6c, 0x20, 0x9b, 0x12, 0x89, 0x16, 0x45, 0x94, - 0x45, 0x37, 0x51, 0xe2, 0x0c, 0x66, 0x14, 0xe2, 0xb1, 0x3c, 0x26, 0x25, 0x5d, 0x55, 0xed, 0xa6, - 0x52, 0x37, 0x7d, 0x84, 0xf6, 0x0d, 0x78, 0x0c, 0xd4, 0x15, 0xdd, 0x75, 0x55, 0x55, 0xb0, 0xe0, - 0x05, 0xfa, 0x00, 0x95, 0xc7, 0x4e, 0x6c, 0x12, 0x87, 0x26, 0xb0, 0x4b, 0x8e, 0xbf, 0xf3, 0x9d, - 0x73, 0xbe, 0xf3, 0xe9, 0x68, 0x40, 0x0e, 0xd7, 0x75, 0x4d, 0x27, 0x36, 0xd2, 0x74, 0x62, 0x9a, - 0x48, 0x77, 0x30, 0x31, 0xb5, 0xf6, 0xaa, 0xe6, 0x9c, 0xaa, 0x96, 0x4d, 0x1c, 0x02, 0x67, 0x71, - 0x5d, 0x57, 0x5d, 0x80, 0x1a, 0x00, 0xd4, 0xf6, 0xaa, 0x3c, 0x6d, 0x10, 0x83, 0x30, 0x88, 0xe6, - 0xfe, 0xf2, 0xd0, 0xf2, 0x9c, 0x4e, 0x68, 0x8b, 0x50, 0xad, 0x45, 0x0d, 0x97, 0xa5, 0x45, 0x0d, - 0xff, 0x43, 0xa8, 0xce, 0x31, 0x46, 0xa6, 0xe3, 0x7e, 0xf5, 0x7e, 0xf9, 0x80, 0xc5, 0x21, 0x8d, - 0x84, 0xaa, 0x32, 0x60, 0xe1, 0x63, 0x1c, 0xcc, 0xec, 0x52, 0xa3, 0xd4, 0x8b, 0xbf, 0xb0, 0x90, - 0xb9, 0x63, 0x62, 0x07, 0xce, 0x83, 0xb4, 0x47, 0x59, 0xc5, 0x0d, 0x89, 0xcb, 0x73, 0xc5, 0x74, - 0x45, 0xf0, 0x02, 0x3b, 0x0d, 0xf8, 0x1c, 0x88, 0x3a, 0x39, 0x31, 0x1d, 0x64, 0x5b, 0x35, 0xdb, - 0xe9, 0x48, 0xf1, 0x3c, 0x57, 0xcc, 0xac, 0x3d, 0x50, 0xa3, 0xc7, 0x53, 0x4b, 0x21, 0xec, 0x36, - 0x7f, 0xfe, 0x23, 0x17, 0xab, 0xdc, 0xc8, 0x87, 0x1b, 0x60, 0xa2, 0x8d, 0x6c, 0x8a, 0x89, 0x29, - 0x25, 0x18, 0x55, 0x6e, 0x18, 0xd5, 0x81, 0x07, 0xab, 0x74, 0xf1, 0xf0, 0x3f, 0x20, 0x36, 0xd0, - 0x71, 0xad, 0x53, 0xb5, 0x90, 0x8d, 0x49, 0x43, 0xe2, 0xf3, 0x5c, 0x91, 0xaf, 0x64, 0x58, 0x6c, - 0x8f, 0x85, 0xe0, 0x2c, 0x48, 0x51, 0x6c, 0x98, 0xc8, 0x96, 0x92, 0x6c, 0x0e, 0xff, 0xdf, 0xd3, - 0xa9, 0x0f, 0x9f, 0x73, 0xb1, 0x77, 0xd7, 0x67, 0x4b, 0x7e, 0xa0, 0x90, 0x03, 0x0b, 0x91, 0x62, - 0x54, 0x10, 0xb5, 0x88, 0x49, 0x51, 0xe1, 0x4b, 0x02, 0x4c, 0x0f, 0x20, 0xf6, 0xed, 0xce, 0x78, - 0x6a, 0xf1, 0xf7, 0x54, 0xab, 0x7f, 0xe4, 0xe4, 0xe0, 0xc8, 0xfb, 0x60, 0x26, 0x9c, 0x52, 0xf5, - 0xd5, 0xa2, 0x52, 0x2a, 0x9f, 0x18, 0x45, 0xde, 0xe9, 0x70, 0xb6, 0x1f, 0xa4, 0xb0, 0x04, 0x44, - 0xcb, 0x26, 0xe4, 0xb0, 0x7a, 0x84, 0xb0, 0x71, 0xe4, 0x48, 0x13, 0x6c, 0x10, 0x39, 0x44, 0xe6, - 0x99, 0xb0, 0xbd, 0xaa, 0x3e, 0x63, 0x08, 0xbf, 0xfd, 0x0c, 0xcb, 0xf2, 0x42, 0x70, 0x01, 0x00, - 0x8f, 0x04, 0x9b, 0xd8, 0x91, 0x84, 0x3c, 0x57, 0x14, 0x2b, 0x69, 0x16, 0x61, 0xbe, 0x0b, 0x96, - 0x25, 0xde, 0xba, 0xac, 0x32, 0x2f, 0xc4, 0xb3, 0x89, 0x32, 0x2f, 0x24, 0xb2, 0x7c, 0x99, 0x17, - 0xd2, 0x59, 0xb1, 0xcc, 0x0b, 0x93, 0xd9, 0xbf, 0x0a, 0x0a, 0xf8, 0x37, 0x6a, 0x45, 0xbd, 0x1d, - 0x7e, 0x8b, 0x47, 0xec, 0x70, 0x4b, 0x6f, 0xc2, 0xff, 0xc1, 0x64, 0x20, 0x46, 0xb0, 0x47, 0x31, - 0x08, 0xee, 0x34, 0xe0, 0x26, 0x90, 0x6f, 0x08, 0x7b, 0x33, 0x23, 0xce, 0x32, 0xa4, 0x30, 0xa2, - 0x14, 0xce, 0xbe, 0x87, 0xcf, 0xfb, 0xb5, 0x4f, 0xde, 0x45, 0xfb, 0x79, 0xe0, 0x29, 0x5d, 0x75, - 0xec, 0x8e, 0x94, 0x62, 0xd2, 0x0b, 0x2c, 0xe0, 0x7a, 0x38, 0x50, 0x1e, 0xfc, 0x49, 0x79, 0x3e, - 0x9b, 0x2c, 0xf3, 0xc2, 0x44, 0x16, 0x94, 0x79, 0x21, 0x93, 0x15, 0x23, 0x35, 0xdf, 0xd2, 0x9b, - 0x3d, 0xcd, 0xbf, 0x72, 0x40, 0x1a, 0x00, 0x94, 0x88, 0x79, 0x88, 0xed, 0xd6, 0x68, 0xba, 0xf7, - 0x3a, 0xaf, 0xe9, 0x4d, 0x26, 0x73, 0xb7, 0x73, 0x77, 0x73, 0xfd, 0xda, 0x24, 0xee, 0xa2, 0x4d, - 0x30, 0x3e, 0x7f, 0xfb, 0x95, 0x28, 0x80, 0xfc, 0xb0, 0x59, 0x7a, 0x03, 0x9f, 0x82, 0xa9, 0x5d, - 0x6a, 0xbc, 0xb4, 0x1a, 0x35, 0x07, 0xed, 0xd5, 0xec, 0x5a, 0x8b, 0x86, 0xf8, 0xb9, 0x30, 0x3f, - 0xdc, 0x04, 0x29, 0x8b, 0x21, 0xfc, 0x2b, 0xaa, 0x0c, 0xb3, 0x84, 0xc7, 0xe3, 0xb7, 0xee, 0xe7, - 0x0c, 0x76, 0xf7, 0x0f, 0x98, 0xeb, 0xab, 0xdc, 0x6d, 0x6a, 0xed, 0x17, 0x0f, 0x12, 0xbb, 0xd4, - 0x80, 0x6f, 0x00, 0x8c, 0x38, 0xf8, 0xcb, 0xc3, 0xea, 0x46, 0x9e, 0x44, 0xf9, 0xf1, 0x58, 0xf0, - 0x6e, 0x0f, 0xf0, 0x35, 0xf8, 0x7b, 0xf0, 0x7a, 0x3e, 0x1c, 0x99, 0x6b, 0xdf, 0xee, 0xc8, 0x8f, - 0xc6, 0x41, 0x0f, 0x2f, 0xec, 0x1a, 0x67, 0xf4, 0xc2, 0x5b, 0x7a, 0x73, 0x8c, 0xc2, 0x21, 0xef, - 0xc3, 0xf7, 0x1c, 0x98, 0x89, 0x36, 0xfe, 0xca, 0xc8, 0x7c, 0x7e, 0x86, 0xfc, 0x64, 0xdc, 0x8c, - 0x5e, 0x17, 0x36, 0x98, 0xf5, 0x3c, 0x11, 0xc0, 0x7c, 0x5f, 0x2e, 0xde, 0xc2, 0x19, 0xb6, 0x91, - 0xac, 0x8d, 0x08, 0xec, 0xd6, 0x94, 0x93, 0x6f, 0xaf, 0xcf, 0x96, 0xb8, 0xed, 0x83, 0xf3, 0x4b, - 0x85, 0xbb, 0xb8, 0x54, 0xb8, 0x9f, 0x97, 0x0a, 0xf7, 0xe9, 0x4a, 0x89, 0x5d, 0x5c, 0x29, 0xb1, - 0xef, 0x57, 0x4a, 0xec, 0xd5, 0xa6, 0x81, 0x9d, 0xa3, 0x93, 0xba, 0xaa, 0x93, 0x96, 0xe6, 0xbf, - 0x75, 0x70, 0x5d, 0x5f, 0x36, 0x88, 0xd6, 0xde, 0xd0, 0x5a, 0xa4, 0x71, 0x72, 0x8c, 0xa8, 0xf7, - 0x8c, 0x59, 0x59, 0x5f, 0x0e, 0xbd, 0x64, 0x9c, 0x8e, 0x85, 0x68, 0x3d, 0xc5, 0x9e, 0x30, 0xeb, - 0xbf, 0x03, 0x00, 0x00, 0xff, 0xff, 0x4b, 0x3f, 0x5a, 0x3e, 0x76, 0x09, 0x00, 0x00, + // 935 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x96, 0xcd, 0x6e, 0xe3, 0x54, + 0x14, 0xc7, 0xe3, 0x36, 0x49, 0x9b, 0x93, 0x0c, 0x85, 0xab, 0xb4, 0xf5, 0x78, 0x18, 0x27, 0x14, + 0xd0, 0x54, 0x03, 0xb5, 0xa7, 0x33, 0x20, 0xcd, 0x40, 0x25, 0xd4, 0x66, 0x43, 0x17, 0x85, 0x91, + 0x29, 0xb3, 0x60, 0x13, 0x25, 0xce, 0xad, 0x7b, 0xd5, 0xc6, 0xd7, 0xf2, 0x75, 0xc2, 0x98, 0x15, + 0x82, 0x0d, 0x12, 0x1b, 0x1e, 0x81, 0x47, 0x98, 0xc7, 0x18, 0xb1, 0x9a, 0x25, 0x0b, 0x84, 0x46, + 0xed, 0x62, 0x5e, 0x80, 0x07, 0x40, 0xf7, 0xc3, 0x8e, 0x93, 0x38, 0x25, 0x69, 0xd9, 0xd9, 0xc7, + 0xff, 0x73, 0xee, 0xb9, 0xe7, 0xfc, 0x8e, 0xef, 0x85, 0x06, 0xe9, 0xba, 0xb6, 0x4b, 0x43, 0x6c, + 0xbb, 0xd4, 0xf7, 0xb1, 0x1b, 0x11, 0xea, 0xdb, 0xc3, 0x5d, 0x3b, 0x7a, 0x6e, 0x05, 0x21, 0x8d, + 0x28, 0xda, 0x20, 0x5d, 0xd7, 0xe2, 0x02, 0x6b, 0x24, 0xb0, 0x86, 0xbb, 0x46, 0xdd, 0xa3, 0x1e, + 0x15, 0x12, 0x9b, 0x3f, 0x49, 0xb5, 0xb1, 0xe9, 0x52, 0xd6, 0xa7, 0xcc, 0xee, 0x33, 0x8f, 0x47, + 0xe9, 0x33, 0x4f, 0x7d, 0xb8, 0xed, 0x51, 0xea, 0x9d, 0x63, 0x5b, 0xbc, 0x75, 0x07, 0x27, 0x76, + 0xc7, 0x8f, 0xd5, 0xa7, 0x4c, 0x0a, 0xe7, 0x04, 0xfb, 0x11, 0x77, 0x94, 0x4f, 0x4a, 0x70, 0x6f, + 0x46, 0x8e, 0x99, 0x84, 0x84, 0x70, 0xeb, 0xd7, 0x25, 0x58, 0x3f, 0x62, 0x5e, 0x2b, 0xb5, 0x7f, + 0x1d, 0x60, 0xff, 0xd0, 0x27, 0x11, 0xba, 0x03, 0x15, 0x19, 0xb2, 0x4d, 0x7a, 0xba, 0xd6, 0xd4, + 0xb6, 0x2b, 0xce, 0xaa, 0x34, 0x1c, 0xf6, 0xd0, 0x57, 0x50, 0x73, 0xe9, 0xc0, 0x8f, 0x70, 0x18, + 0x74, 0xc2, 0x28, 0xd6, 0x97, 0x9a, 0xda, 0x76, 0xf5, 0xe1, 0x07, 0x56, 0xfe, 0xce, 0xad, 0x56, + 0x46, 0x7b, 0x50, 0x7c, 0xf9, 0x77, 0xa3, 0xe0, 0x8c, 0xf9, 0xa3, 0x27, 0xb0, 0x32, 0xc4, 0x21, + 0x23, 0xd4, 0xd7, 0x97, 0x45, 0xa8, 0xc6, 0xac, 0x50, 0xcf, 0xa4, 0xcc, 0x49, 0xf4, 0xe8, 0x3d, + 0xa8, 0xf5, 0xf0, 0x79, 0x27, 0x6e, 0x07, 0x38, 0x24, 0xb4, 0xa7, 0x17, 0x9b, 0xda, 0x76, 0xd1, + 0xa9, 0x0a, 0xdb, 0x53, 0x61, 0x42, 0x1b, 0x50, 0x66, 0xc4, 0xf3, 0x71, 0xa8, 0x97, 0xc4, 0x3e, + 0xd4, 0xdb, 0x67, 0x6b, 0xbf, 0xfc, 0xde, 0x28, 0xfc, 0xf4, 0xe6, 0xc5, 0x7d, 0x65, 0xd8, 0x6a, + 0xc0, 0xdd, 0xdc, 0x62, 0x38, 0x98, 0x05, 0xd4, 0x67, 0x78, 0xeb, 0x75, 0x09, 0xea, 0x53, 0x8a, + 0xe3, 0x30, 0xbe, 0xba, 0x5a, 0x8f, 0x61, 0x23, 0x08, 0xf1, 0x90, 0xd0, 0x01, 0x6b, 0x8f, 0x76, + 0xc3, 0x95, 0xbc, 0x6e, 0x95, 0x83, 0x25, 0x5d, 0x73, 0xea, 0x89, 0x62, 0x14, 0xfb, 0xb0, 0x87, + 0x3e, 0x87, 0x9a, 0x0a, 0xcb, 0xa2, 0x4e, 0x84, 0x55, 0x71, 0xea, 0x96, 0x44, 0xc3, 0x4a, 0xd0, + 0xb0, 0xf6, 0xfd, 0x58, 0x44, 0xa9, 0x4a, 0xf5, 0x37, 0x5c, 0x3c, 0xd5, 0xa4, 0xe2, 0x0d, 0x9b, + 0x34, 0x59, 0xe9, 0xd2, 0x74, 0xa5, 0x8f, 0x61, 0x3d, 0xeb, 0xd2, 0x56, 0x4d, 0x62, 0x7a, 0xb9, + 0xb9, 0x3c, 0x4f, 0x57, 0xeb, 0x59, 0x6f, 0x65, 0x64, 0xa8, 0x05, 0xb5, 0x20, 0xa4, 0xf4, 0xa4, + 0x7d, 0x8a, 0x89, 0x77, 0x1a, 0xe9, 0x2b, 0x62, 0x23, 0x46, 0x26, 0x98, 0x64, 0x7f, 0xb8, 0x6b, + 0x7d, 0x29, 0x14, 0x2a, 0xfd, 0xaa, 0xf0, 0x92, 0x26, 0x74, 0x17, 0x40, 0x06, 0x21, 0x3e, 0x89, + 0xf4, 0xd5, 0xa6, 0xb6, 0x5d, 0x73, 0x2a, 0xc2, 0x22, 0x70, 0xff, 0x30, 0x59, 0x43, 0xc6, 0xd2, + 0x2b, 0x5c, 0x20, 0x6b, 0x2a, 0xec, 0x2d, 0x61, 0x46, 0x1f, 0xc1, 0x9a, 0x92, 0x71, 0x1e, 0x7c, + 0x36, 0x60, 0x3a, 0xa4, 0xca, 0xb7, 0xa4, 0x32, 0xf9, 0x82, 0x0e, 0xe1, 0xed, 0x54, 0x96, 0xe4, + 0x5e, 0xfd, 0xcf, 0xdc, 0x79, 0xa4, 0xb5, 0xd4, 0x4f, 0x65, 0x3f, 0x42, 0xb8, 0x96, 0x45, 0x18, + 0x7d, 0x01, 0xc6, 0x29, 0x65, 0xd1, 0x28, 0x1d, 0x09, 0x4a, 0x5b, 0x64, 0xa2, 0xdf, 0x4a, 0x53, + 0xdb, 0xe4, 0xaa, 0x34, 0x33, 0xc1, 0xc7, 0x53, 0x2e, 0x99, 0x9e, 0x01, 0x13, 0xde, 0xcd, 0x23, + 0x3c, 0x1d, 0x81, 0xbf, 0x8a, 0x39, 0x23, 0xb0, 0xef, 0x9e, 0xa1, 0xf7, 0xe1, 0xd6, 0x38, 0xdc, + 0x72, 0x0c, 0x6a, 0x6e, 0x16, 0xe8, 0x3d, 0x30, 0xc6, 0x00, 0xc9, 0x19, 0x07, 0x47, 0xcf, 0x2a, + 0xc6, 0xc6, 0xe1, 0x06, 0xbf, 0x89, 0xc9, 0x49, 0x2a, 0x2e, 0x32, 0x49, 0x93, 0x00, 0x96, 0xae, + 0x03, 0xe0, 0x1d, 0x90, 0xb8, 0xb5, 0xa3, 0x30, 0xd6, 0xcb, 0x82, 0xbf, 0x55, 0x61, 0xe0, 0xff, + 0x8f, 0x49, 0xfc, 0x56, 0xe6, 0xc6, 0x6f, 0x75, 0x21, 0xfc, 0x2a, 0x37, 0xc5, 0x0f, 0x16, 0xc0, + 0xaf, 0xfa, 0x3f, 0xe1, 0xb7, 0xef, 0x9e, 0xa5, 0xf8, 0xfd, 0xa1, 0x81, 0x3e, 0x25, 0x68, 0x51, + 0xff, 0x84, 0x84, 0xfd, 0xf9, 0x10, 0x4c, 0xfb, 0xd0, 0x71, 0xcf, 0x04, 0x71, 0x49, 0x1f, 0x38, + 0xc4, 0x93, 0x9d, 0x5e, 0xbe, 0x4e, 0xa7, 0x47, 0xd5, 0x2a, 0x5e, 0x7d, 0xde, 0x6c, 0x41, 0x73, + 0xd6, 0x5e, 0xd2, 0x0d, 0x3f, 0x87, 0xb5, 0x23, 0xe6, 0x7d, 0x1b, 0xf4, 0x78, 0xcd, 0x3a, 0x61, + 0xa7, 0xcf, 0x32, 0xf1, 0xb5, 0xb1, 0x6e, 0xec, 0x41, 0x39, 0x10, 0x0a, 0x75, 0x1e, 0x9b, 0xb3, + 0xa6, 0x43, 0xc6, 0x51, 0xa9, 0x2b, 0x9f, 0xe9, 0xec, 0x6e, 0xc3, 0xe6, 0xc4, 0xca, 0x49, 0x52, + 0x0f, 0xff, 0x29, 0xc2, 0xf2, 0x11, 0xf3, 0xd0, 0x0f, 0x80, 0x72, 0xae, 0x0e, 0x3b, 0xb3, 0xd6, + 0xcd, 0x3d, 0x5c, 0x8d, 0x4f, 0x17, 0x92, 0x27, 0x39, 0xa0, 0xef, 0xe1, 0x9d, 0xe9, 0x73, 0xf8, + 0xe3, 0xb9, 0x63, 0x1d, 0x87, 0xb1, 0xf1, 0xc9, 0x22, 0xea, 0xd9, 0x0b, 0x73, 0x70, 0xe6, 0x5f, + 0x78, 0xdf, 0x3d, 0x5b, 0x60, 0xe1, 0x0c, 0xfb, 0xe8, 0x67, 0x0d, 0xd6, 0xf3, 0xc1, 0x7f, 0x30, + 0x77, 0x3c, 0xe5, 0x61, 0x3c, 0x5e, 0xd4, 0x23, 0xcd, 0x22, 0x84, 0x0d, 0xc9, 0xc4, 0x48, 0xa6, + 0xb8, 0xbc, 0x77, 0x45, 0xcc, 0x2c, 0x46, 0x86, 0x3d, 0xa7, 0x30, 0x59, 0xd3, 0x28, 0xfd, 0xf8, + 0xe6, 0xc5, 0x7d, 0xed, 0xe0, 0xd9, 0xcb, 0x0b, 0x53, 0x7b, 0x75, 0x61, 0x6a, 0xaf, 0x2f, 0x4c, + 0xed, 0xb7, 0x4b, 0xb3, 0xf0, 0xea, 0xd2, 0x2c, 0xfc, 0x79, 0x69, 0x16, 0xbe, 0xdb, 0xf3, 0x48, + 0x74, 0x3a, 0xe8, 0x5a, 0x2e, 0xed, 0xdb, 0xea, 0x42, 0x4d, 0xba, 0xee, 0x8e, 0x47, 0xed, 0xe1, + 0x13, 0xbb, 0x4f, 0x7b, 0x83, 0x73, 0xcc, 0xe4, 0x85, 0xf8, 0xc1, 0xa3, 0x9d, 0xcc, 0x9d, 0x38, + 0x8a, 0x03, 0xcc, 0xba, 0x65, 0xf1, 0xfb, 0x7f, 0xf4, 0x6f, 0x00, 0x00, 0x00, 0xff, 0xff, 0x81, + 0x77, 0x9b, 0x70, 0xdb, 0x0b, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -853,6 +884,13 @@ func (m *MsgConnectionOpenTry) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l + if len(m.HostConsensusStateProof) > 0 { + i -= len(m.HostConsensusStateProof) + copy(dAtA[i:], m.HostConsensusStateProof) + i = encodeVarintTx(dAtA, i, uint64(len(m.HostConsensusStateProof))) + i-- + dAtA[i] = 0x6a + } if len(m.Signer) > 0 { i -= len(m.Signer) copy(dAtA[i:], m.Signer) @@ -860,6 +898,32 @@ func (m *MsgConnectionOpenTry) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x62 } + if m.ConsensusHeight != nil { + { + size, err := m.ConsensusHeight.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintTx(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x5a + } + if len(m.ProofConsensus) > 0 { + i -= len(m.ProofConsensus) + copy(dAtA[i:], m.ProofConsensus) + i = encodeVarintTx(dAtA, i, uint64(len(m.ProofConsensus))) + i-- + dAtA[i] = 0x52 + } + if len(m.ProofClient) > 0 { + i -= len(m.ProofClient) + copy(dAtA[i:], m.ProofClient) + i = encodeVarintTx(dAtA, i, uint64(len(m.ProofClient))) + i-- + dAtA[i] = 0x4a + } if len(m.ProofInit) > 0 { i -= len(m.ProofInit) copy(dAtA[i:], m.ProofInit) @@ -906,6 +970,25 @@ func (m *MsgConnectionOpenTry) MarshalToSizedBuffer(dAtA []byte) (int, error) { } i-- dAtA[i] = 0x22 + if m.ClientState != nil { + { + size, err := m.ClientState.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintTx(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x1a + } + if len(m.PreviousConnectionId) > 0 { + i -= len(m.PreviousConnectionId) + copy(dAtA[i:], m.PreviousConnectionId) + i = encodeVarintTx(dAtA, i, uint64(len(m.PreviousConnectionId))) + i-- + dAtA[i] = 0x12 + } if len(m.ClientId) > 0 { i -= len(m.ClientId) copy(dAtA[i:], m.ClientId) @@ -959,6 +1042,13 @@ func (m *MsgConnectionOpenAck) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l + if len(m.HostConsensusStateProof) > 0 { + i -= len(m.HostConsensusStateProof) + copy(dAtA[i:], m.HostConsensusStateProof) + i = encodeVarintTx(dAtA, i, uint64(len(m.HostConsensusStateProof))) + i-- + dAtA[i] = 0x5a + } if len(m.Signer) > 0 { i -= len(m.Signer) copy(dAtA[i:], m.Signer) @@ -966,6 +1056,32 @@ func (m *MsgConnectionOpenAck) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x52 } + if m.ConsensusHeight != nil { + { + size, err := m.ConsensusHeight.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintTx(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x4a + } + if len(m.ProofConsensus) > 0 { + i -= len(m.ProofConsensus) + copy(dAtA[i:], m.ProofConsensus) + i = encodeVarintTx(dAtA, i, uint64(len(m.ProofConsensus))) + i-- + dAtA[i] = 0x42 + } + if len(m.ProofClient) > 0 { + i -= len(m.ProofClient) + copy(dAtA[i:], m.ProofClient) + i = encodeVarintTx(dAtA, i, uint64(len(m.ProofClient))) + i-- + dAtA[i] = 0x3a + } if len(m.ProofTry) > 0 { i -= len(m.ProofTry) copy(dAtA[i:], m.ProofTry) @@ -983,6 +1099,18 @@ func (m *MsgConnectionOpenAck) MarshalToSizedBuffer(dAtA []byte) (int, error) { } i-- dAtA[i] = 0x2a + if m.ClientState != nil { + { + size, err := m.ClientState.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintTx(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + } if m.Version != nil { { size, err := m.Version.MarshalToSizedBuffer(dAtA[:i]) @@ -1231,6 +1359,14 @@ func (m *MsgConnectionOpenTry) Size() (n int) { if l > 0 { n += 1 + l + sovTx(uint64(l)) } + l = len(m.PreviousConnectionId) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + if m.ClientState != nil { + l = m.ClientState.Size() + n += 1 + l + sovTx(uint64(l)) + } l = m.Counterparty.Size() n += 1 + l + sovTx(uint64(l)) if m.DelayPeriod != 0 { @@ -1248,10 +1384,26 @@ func (m *MsgConnectionOpenTry) Size() (n int) { if l > 0 { n += 1 + l + sovTx(uint64(l)) } + l = len(m.ProofClient) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = len(m.ProofConsensus) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + if m.ConsensusHeight != nil { + l = m.ConsensusHeight.Size() + n += 1 + l + sovTx(uint64(l)) + } l = len(m.Signer) if l > 0 { n += 1 + l + sovTx(uint64(l)) } + l = len(m.HostConsensusStateProof) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } return n } @@ -1282,16 +1434,36 @@ func (m *MsgConnectionOpenAck) Size() (n int) { l = m.Version.Size() n += 1 + l + sovTx(uint64(l)) } + if m.ClientState != nil { + l = m.ClientState.Size() + n += 1 + l + sovTx(uint64(l)) + } l = m.ProofHeight.Size() n += 1 + l + sovTx(uint64(l)) l = len(m.ProofTry) if l > 0 { n += 1 + l + sovTx(uint64(l)) } + l = len(m.ProofClient) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + l = len(m.ProofConsensus) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } + if m.ConsensusHeight != nil { + l = m.ConsensusHeight.Size() + n += 1 + l + sovTx(uint64(l)) + } l = len(m.Signer) if l > 0 { n += 1 + l + sovTx(uint64(l)) } + l = len(m.HostConsensusStateProof) + if l > 0 { + n += 1 + l + sovTx(uint64(l)) + } return n } @@ -1679,6 +1851,74 @@ func (m *MsgConnectionOpenTry) Unmarshal(dAtA []byte) error { } m.ClientId = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field PreviousConnectionId", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + stringLen |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + intStringLen := int(stringLen) + if intStringLen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.PreviousConnectionId = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ClientState", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ClientState == nil { + m.ClientState = &types.Any{} + } + if err := m.ClientState.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex case 4: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Counterparty", wireType) @@ -1832,6 +2072,110 @@ func (m *MsgConnectionOpenTry) Unmarshal(dAtA []byte) error { m.ProofInit = []byte{} } iNdEx = postIndex + case 9: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ProofClient", 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.ProofClient = append(m.ProofClient[:0], dAtA[iNdEx:postIndex]...) + if m.ProofClient == nil { + m.ProofClient = []byte{} + } + iNdEx = postIndex + case 10: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ProofConsensus", 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.ProofConsensus = append(m.ProofConsensus[:0], dAtA[iNdEx:postIndex]...) + if m.ProofConsensus == nil { + m.ProofConsensus = []byte{} + } + iNdEx = postIndex + case 11: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ConsensusHeight", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ConsensusHeight == nil { + m.ConsensusHeight = &types1.Height{} + } + if err := m.ConsensusHeight.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex case 12: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Signer", wireType) @@ -1864,6 +2208,40 @@ func (m *MsgConnectionOpenTry) Unmarshal(dAtA []byte) error { } m.Signer = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex + case 13: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field HostConsensusStateProof", 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.HostConsensusStateProof = append(m.HostConsensusStateProof[:0], dAtA[iNdEx:postIndex]...) + if m.HostConsensusStateProof == nil { + m.HostConsensusStateProof = []byte{} + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) @@ -2064,6 +2442,42 @@ func (m *MsgConnectionOpenAck) Unmarshal(dAtA []byte) error { return err } iNdEx = postIndex + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ClientState", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ClientState == nil { + m.ClientState = &types.Any{} + } + if err := m.ClientState.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex case 5: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field ProofHeight", wireType) @@ -2131,6 +2545,110 @@ func (m *MsgConnectionOpenAck) Unmarshal(dAtA []byte) error { m.ProofTry = []byte{} } iNdEx = postIndex + case 7: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ProofClient", 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.ProofClient = append(m.ProofClient[:0], dAtA[iNdEx:postIndex]...) + if m.ProofClient == nil { + m.ProofClient = []byte{} + } + iNdEx = postIndex + case 8: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ProofConsensus", 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.ProofConsensus = append(m.ProofConsensus[:0], dAtA[iNdEx:postIndex]...) + if m.ProofConsensus == nil { + m.ProofConsensus = []byte{} + } + iNdEx = postIndex + case 9: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ConsensusHeight", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowTx + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthTx + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthTx + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.ConsensusHeight == nil { + m.ConsensusHeight = &types1.Height{} + } + if err := m.ConsensusHeight.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex case 10: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Signer", wireType) @@ -2163,6 +2681,40 @@ func (m *MsgConnectionOpenAck) Unmarshal(dAtA []byte) error { } m.Signer = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex + case 11: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field HostConsensusStateProof", 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.HostConsensusStateProof = append(m.HostConsensusStateProof[:0], dAtA[iNdEx:postIndex]...) + if m.HostConsensusStateProof == nil { + m.HostConsensusStateProof = []byte{} + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipTx(dAtA[iNdEx:]) From 3252e55b9134a6d2e63763d8373daf0e0400bbfb Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 19:18:13 +0800 Subject: [PATCH 21/33] imp: review item --- modules/core/03-connection/keeper/handshake.go | 1 - modules/core/03-connection/keeper/verify.go | 4 ---- 2 files changed, 5 deletions(-) diff --git a/modules/core/03-connection/keeper/handshake.go b/modules/core/03-connection/keeper/handshake.go index 852541a6f19..1e646b787e3 100644 --- a/modules/core/03-connection/keeper/handshake.go +++ b/modules/core/03-connection/keeper/handshake.go @@ -118,7 +118,6 @@ func (k *Keeper) ConnOpenTry( // to chain A (this code is executed on chain A). // // NOTE: Identifiers are checked on msg validation. -// TODO: Remove uneeded proofs func (k *Keeper) ConnOpenAck( ctx sdk.Context, connectionID string, diff --git a/modules/core/03-connection/keeper/verify.go b/modules/core/03-connection/keeper/verify.go index 9c81939d4e1..a46f4cf0a99 100644 --- a/modules/core/03-connection/keeper/verify.go +++ b/modules/core/03-connection/keeper/verify.go @@ -25,10 +25,6 @@ func (k *Keeper) VerifyConnectionState( connectionID string, counterpartyConnection types.ConnectionEnd, // opposite connection ) error { - if !types.IsValidConnectionID(connectionID) { - return types.ErrInvalidConnectionIdentifier - } - clientID := connection.ClientId if status := k.clientKeeper.GetClientStatus(ctx, clientID); status != exported.Active { return errorsmod.Wrapf(clienttypes.ErrClientNotActive, "client (%s) status is %s", clientID, status) From fb1ccec7d21e77f5bcf988577d48a8ba8cbfa329 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 19:22:09 +0800 Subject: [PATCH 22/33] revert: conn name change --- testing/solomachine.go | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/testing/solomachine.go b/testing/solomachine.go index 5ad66250e69..cca8908a33a 100644 --- a/testing/solomachine.go +++ b/testing/solomachine.go @@ -27,9 +27,9 @@ import ( ) var ( - clientIDSolomachine = "client-on-solomachine" // clientID generated on solo machine side - connectionIDSolomachine = "connection-0" // connectionID generated on solo machine side - channelIDSolomachine = "channel-on-solomachine" // channelID generated on solo machine side + clientIDSolomachine = "client-on-solomachine" // clientID generated on solo machine side + connectionIDSolomachine = "connection-on-solomachine" // connectionID generated on solo machine side + channelIDSolomachine = "channel-on-solomachine" // channelID generated on solo machine side ) // DefaultSolomachineClientID is the default solo machine client id used for testing From d9228c665ba92700cf8d2e92f88028a8e6a834bb Mon Sep 17 00:00:00 2001 From: srdtrk Date: Wed, 24 Jul 2024 19:36:23 +0800 Subject: [PATCH 23/33] docs: added changelog --- CHANGELOG.md | 1 + modules/core/03-connection/keeper/events_test.go | 5 ++--- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index ee56fa3031e..a24cfd78304 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -67,6 +67,7 @@ Ref: https://keepachangelog.com/en/1.0.0/ * (core/types) [\#6794](https://github.com/cosmos/ibc-go/pull/6794) The composite interface `QueryServer` has been removed from package `core/types`. Please use the granular `QueryServer` interfaces provided by each core submodule. * (light-clients/06-solomachine) [\#6888](https://github.com/cosmos/ibc-go/pull/6888) Remove `TypeClientMisbehaviour` constant and the `Type` method on `Misbehaviour`. * (light-clients/06-solomachine, light-clients/07-tendermint) [\#6891](https://github.com/cosmos/ibc-go/pull/6891) The `VerifyMembership` and `VerifyNonMembership` functions of solomachine's `ClientState` have been made private. The `VerifyMembership`, `VerifyNonMembership`, `GetTimestampAtHeight`, `Status` and `Initialize` functions of tendermint's `ClientState` have been made private. +* (core/03-connection, core/02-client) [\#6937](https://github.com/cosmos/ibc-go/pull/6937) Remove 'ConsensusHost' interface, also removing self client and consensus state validation. ### State Machine Breaking diff --git a/modules/core/03-connection/keeper/events_test.go b/modules/core/03-connection/keeper/events_test.go index 1612074e051..43ceaacdbd7 100644 --- a/modules/core/03-connection/keeper/events_test.go +++ b/modules/core/03-connection/keeper/events_test.go @@ -52,9 +52,8 @@ func (suite *KeeperTestSuite) TestMsgConnectionOpenTryEvents() { msg := types.NewMsgConnectionOpenTry( path.EndpointB.ClientID, path.EndpointB.Counterparty.ConnectionID, path.EndpointB.Counterparty.ClientID, - path.EndpointB.Counterparty.Chain.GetPrefix(), []*types.Version{ibctesting.ConnectionVersion}, path.EndpointB.ConnectionConfig.DelayPeriod, - initProof, - proofHeight, + path.EndpointB.Counterparty.Chain.GetPrefix(), []*types.Version{ibctesting.ConnectionVersion}, + path.EndpointB.ConnectionConfig.DelayPeriod, initProof, proofHeight, path.EndpointB.Chain.SenderAccount.GetAddress().String(), ) From 956420aa5432b2e05e8a2f9dafc72652b35f0d87 Mon Sep 17 00:00:00 2001 From: Carlos Rodriguez Date: Thu, 25 Jul 2024 12:49:54 +0200 Subject: [PATCH 24/33] add godoc string of QueryConnectionHandshakeProof --- testing/endpoint.go | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/testing/endpoint.go b/testing/endpoint.go index 931bc814a95..92bad3331c3 100644 --- a/testing/endpoint.go +++ b/testing/endpoint.go @@ -297,9 +297,7 @@ func (endpoint *Endpoint) ConnOpenConfirm() error { } // QueryConnectionHandshakeProof returns all the proofs necessary to execute OpenTry or Open Ack of -// the connection handshakes. It returns the counterparty client state, proof of the counterparty -// client state, proof of the counterparty consensus state, the consensus state height, proof of -// the counterparty connection, and the proof height for all the proofs returned. +// the connection handshakes. It returns the proof of the counterparty connection and the proof height. func (endpoint *Endpoint) QueryConnectionHandshakeProof() ( connectionProof []byte, proofHeight clienttypes.Height, ) { From f596f0da3d596e58dd17bd95723c715a50df6620 Mon Sep 17 00:00:00 2001 From: Carlos Rodriguez Date: Thu, 25 Jul 2024 12:56:08 +0200 Subject: [PATCH 25/33] add migration docs for ibc-go --- docs/docs/05-migrations/13-v8-to-v9.md | 66 ++++++++++++++++++++++++++ 1 file changed, 66 insertions(+) diff --git a/docs/docs/05-migrations/13-v8-to-v9.md b/docs/docs/05-migrations/13-v8-to-v9.md index 73013c092bf..67f0cf03e62 100644 --- a/docs/docs/05-migrations/13-v8-to-v9.md +++ b/docs/docs/05-migrations/13-v8-to-v9.md @@ -17,6 +17,7 @@ There are four sections based on the four potential user groups of this document - [API removals](#api-removals) - [02-client](#02-client) - [03-connection](#03-connection) + - [Removal of self client and consensus state from connection handshake](#removal-of-self-client-and-consensus-state-from-connection-handshake) - [04-channel](#04-channel) - [05-port](#05-port) - [23-commitment](#23-commitment) @@ -55,6 +56,17 @@ govRouter.AddRoute(govtypes.RouterKey, govv1beta1.ProposalHandler). ## IBC core +- Because the self client and consensus state validation has been removed from the connection handshake (see section [Removal of self client and consensus state from connection handshake](#removal-of-self-client-and-consensus-state-from-connection-handshake) for more details), the IBC core keeper does not need the staking keeper anymore to introspects the (self) past historical info at a given height and construct the expected consensus state at that height. Thus, the signature of IBC core keeper constructor function `NewKeeper` has been updated: + +```diff +func NewKeeper( + cdc codec.BinaryCodec, key storetypes.StoreKey, paramSpace types.ParamSubspace, +- stakingKeeper clienttypes.StakingKeeper, + upgradeKeeper clienttypes.UpgradeKeeper, + scopedKeeper capabilitykeeper.ScopedKeeper, authority string, +) *Keeper +``` + ### API removals - The [`exported.ChannelI`](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/exported/channel.go#L3-L11) and [`exported.CounterpartyChannelI`](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/exported/channel.go#L13-L19) interfaces have been removed. Please use the concrete types. @@ -62,6 +74,7 @@ govRouter.AddRoute(govtypes.RouterKey, govv1beta1.ProposalHandler). - The [`Router` reference](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/keeper/keeper.go#L35) has been removed from the IBC core keeper in [#6138](https://github.com/cosmos/ibc-go/pull/6138). Please use `PortKeeper.Router` instead. - The [composite interface `QueryServer`](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/types/query.go#L14-L19) has been removed from package `core/types`. Please use the granular `QueryServer` interfaces for IBC submodules directly. - The [`TypeClientMisbehaviour` constant](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/exported/client.go#L17) has been removed. +- The function [`SetConsensusHost`](https://github.com/cosmos/ibc-go/blob/v8.3.0/modules/core/keeper/keeper.go#L88-L96) has been removed because the self client and consensus state validation has been removed from the connection handshake. See section [Removal of self client and consensus state from connection handshake](#removal-of-self-client-and-consensus-state-from-connection-handshake) for more details. ### 02-client @@ -69,12 +82,52 @@ govRouter.AddRoute(govtypes.RouterKey, govv1beta1.ProposalHandler). - The function [`CreateLocalhostClient`](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/02-client/keeper/keeper.go#L56) has been removed. The localhost client is now stateless. - The function [`NewClientProposalHandler`](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/02-client/proposal_handler.go#L18) has been removed in [#6777](https://github.com/cosmos/ibc-go/pull/6777). - The deprecated [`ClientUpdateProposal` and `UpgradeProposal` messages](https://github.com/cosmos/ibc-go/blob/v8.0.0/proto/ibc/core/client/v1/client.proto#L67-L113) have been removed in [\#6782](https://github.com/cosmos/ibc-go/pull/6782). Please use [`MsgRecoverClient`](https://github.com/cosmos/ibc-go/blob/release/v9.0.x/proto/ibc/core/client/v1/tx.proto#L125-L138) and [`MsgIBCSoftwareUpgrade`](https://github.com/cosmos/ibc-go/blob/release/v9.0.x/proto/ibc/core/client/v1/tx.proto#L143-L158) respectively instead. +- Because the self client and consensus state validation has been removed from the connection handshake (see section [Removal of self client and consensus state from connection handshake](#removal-of-self-client-and-consensus-state-from-connection-handshake) for more details): + - The [ConsensusHost interface](https://github.com/cosmos/ibc-go/blob/v8.3.0/modules/core/02-client/types/client.go#L25-L29) has been removed. + - The function [`SetConsensusHost`](https://github.com/cosmos/ibc-go/blob/v8.3.0/modules/core/02-client/keeper/keeper.go#L61-L68) has been removed. + - The functions [`GetSelfConsensusState` and `ValidateSelfClient`](https://github.com/cosmos/ibc-go/blob/v8.3.0/modules/core/02-client/keeper/keeper.go#L256-L269) have been removed. ### 03-connection - The [functions `GetState()`, `GetClientID()`, `GetCounterparty()`, `GetVersions()`, and `GetDelayPeriod()`](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/03-connection/types/connection.go#L25-L48) of the `Connection` type have been removed. - The [functions `GetClientID()`, `GetConnectionID()`, and `GetPrefix()`](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/03-connection/types/connection.go#L79-L92) of the `Counterparty` type have been removed. +#### Removal of self client and consensus state from connection handshake + +The `ConnectionOpenTry` and `ConnectionOpenAck` handlers no longer validate that the light client on counterparty chain has a valid representation of the executing chain's consensus protocol (please see [#1128](https://github.com/cosmos/ibc/pull/1128) in cosmos/ibc repository for an exhaustive explanation of the reasoning). + +- The fields `client_state`, `proof_client`, `proof_consensus`, `consensus_height` and `host_consensus_state_proof` of `MsgConnectionOpenTry` and `MsgConnectionOpenAck` have been deprecated, and the signature of the constructor functions [`NewMsgConnectionOpenTry`](https://github.com/cosmos/ibc-go/blob/release/v9.0.x/modules/core/03-connection/types/msgs.go#L78) and [`NewMsgConnectionOpenTry`](https://github.com/cosmos/ibc-go/blob/release/v9.0.x/modules/core/03-connection/types/msgs.go#L165) has been accordingly updated: + +```diff +func NewMsgConnectionOpenTry( + clientID, counterpartyConnectionID, counterpartyClientID string, +- counterpartyClient exported.ClientState, + counterpartyPrefix commitmenttypes.MerklePrefix, + counterpartyVersions []*Version, delayPeriod uint64, + initProof []byte, +- clientProof []byte, +- consensusProof []byte, + proofHeight lienttypes.Height, +- consensusHeight clienttypes.Height, + signer string, +) *MsgConnectionOpenTry + +func NewMsgConnectionOpenAck( + connectionID, counterpartyConnectionID string, +- counterpartyClient exported.ClientState, + tryProof []byte, +- clientProof []byte, +- consensusProof []byte, + proofHeight clienttypes.Height, +- consensusHeight clienttypes.Height, + version *Version, + signer string, +) *MsgConnectionOpenAck +``` + +- The functions [`VerifyClientState` and `VerifyClientConsensusState`](https://github.com/cosmos/ibc-go/blob/v8.3.0/modules/core/03-connection/keeper/verify.go#L20-L101) have been removed. +- The function [`UnpackInterfaces`](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/03-connection/types/msgs.go#L166) has been removed. + ### 04-channel - The utility function [`QueryLatestConsensusState`](https://github.com/cosmos/ibc-go/blob/v8.0.0/modules/core/04-channel/client/utils/utils.go#L130) of the CLI has been removed. @@ -243,6 +296,19 @@ func AssertEvents( clientQueryServer := clientkeeper.NewQueryServer(app.IBCKeeper.ClientKeeper) ``` +- The signature of the function `QueryConnectionHandshakeProof` has changed, since the validation of self client and consensus state has been remove from the connection handshake: + +```diff +func (endpoint *Endpoint) QueryConnectionHandshakeProof() ( +- clientState exported.ClientState, clientProof, +- consensusProof []byte, consensusHeight clienttypes.Height, + connectioProof []byte, proofHeight clienttypes.Height, +) +``` + +- The functions [`GenerateClientStateProof` and `GenerateConsensusStateProof`](https://github.com/cosmos/ibc-go/blob/v8.0.0/testing/solomachine.go#L513-L547) +have been removed. + ### API deprecation notice - The testing package functions `Setup`, `SetupClients`, `SetupConnections`, `CreateConnections`, and `CreateChannels` of the `Coordinator` type have been deprecated and will be removed in v10. Please use the new functions `Setup`, `SetupClients`, `SetupConnections`, `CreateConnections`, `CreateChannels` of the `Path` type. From 5bec21b34ac72bec8c931406b87637558ed5e75e Mon Sep 17 00:00:00 2001 From: Carlos Rodriguez Date: Thu, 25 Jul 2024 23:14:58 +0200 Subject: [PATCH 26/33] Update CHANGELOG.md --- modules/light-clients/08-wasm/CHANGELOG.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/modules/light-clients/08-wasm/CHANGELOG.md b/modules/light-clients/08-wasm/CHANGELOG.md index f09146095ce..fcc8961a0ed 100644 --- a/modules/light-clients/08-wasm/CHANGELOG.md +++ b/modules/light-clients/08-wasm/CHANGELOG.md @@ -34,7 +34,7 @@ Ref: https://keepachangelog.com/en/1.0.0/ # Changelog -## [Unreleased] +## [[Unreleased]] ### Dependencies @@ -67,6 +67,8 @@ Ref: https://keepachangelog.com/en/1.0.0/ ### Features +* [\#6055](https://github.com/cosmos/ibc-go/pull/6055) feat: add 08-wasm `ConsensusHost` implementation for custom self client/consensus state validation in 03-connection handshake. + ### Bug Fixes * [\#6815](https://github.com/cosmos/ibc-go/pull/6815) Decode to bytes the hex-encoded checksum argument of the `migrate-contract` CLI. From 1113d22d5defccfacbfa02d41f5f5466c97b2513 Mon Sep 17 00:00:00 2001 From: Carlos Rodriguez Date: Thu, 25 Jul 2024 23:17:37 +0200 Subject: [PATCH 27/33] update changelog --- modules/light-clients/08-wasm/CHANGELOG.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/modules/light-clients/08-wasm/CHANGELOG.md b/modules/light-clients/08-wasm/CHANGELOG.md index fcc8961a0ed..69cfe38719c 100644 --- a/modules/light-clients/08-wasm/CHANGELOG.md +++ b/modules/light-clients/08-wasm/CHANGELOG.md @@ -42,6 +42,8 @@ Ref: https://keepachangelog.com/en/1.0.0/ ### API Breaking +* [\#6937](https://github.com/cosmos/ibc-go/pull/6937) Remove `WasmConsensusHost` implementation of the `ConsensusHost` interface. + ### State Machine Breaking ### Improvements From 7bae8b835d94ca4c90d33f520936db4f2b5d328e Mon Sep 17 00:00:00 2001 From: srdtrk Date: Thu, 1 Aug 2024 11:49:57 +0900 Subject: [PATCH 28/33] imp(proto): added deprecation notice to field --- proto/ibc/core/connection/v1/tx.proto | 1 + 1 file changed, 1 insertion(+) diff --git a/proto/ibc/core/connection/v1/tx.proto b/proto/ibc/core/connection/v1/tx.proto index aea19ceb4fa..2def4e9c487 100644 --- a/proto/ibc/core/connection/v1/tx.proto +++ b/proto/ibc/core/connection/v1/tx.proto @@ -60,6 +60,7 @@ message MsgConnectionOpenTry { string client_id = 1; // Deprecated: this field is unused. Crossing hellos are no longer supported in core IBC. string previous_connection_id = 2 [deprecated = true]; + // Deprecated: this field is unused. google.protobuf.Any client_state = 3 [deprecated = true]; Counterparty counterparty = 4 [(gogoproto.nullable) = false]; uint64 delay_period = 5; From 61333b512f1367b56111a5ad1323daf595df3d7c Mon Sep 17 00:00:00 2001 From: srdtrk Date: Thu, 1 Aug 2024 11:54:29 +0900 Subject: [PATCH 29/33] imp: ran 'make proto-all' --- modules/core/03-connection/types/tx.pb.go | 5 +++-- proto/ibc/core/connection/v1/tx.proto | 12 ++++++------ 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/modules/core/03-connection/types/tx.pb.go b/modules/core/03-connection/types/tx.pb.go index 6e415bdd662..6576333d522 100644 --- a/modules/core/03-connection/types/tx.pb.go +++ b/modules/core/03-connection/types/tx.pb.go @@ -117,8 +117,9 @@ var xxx_messageInfo_MsgConnectionOpenInitResponse proto.InternalMessageInfo type MsgConnectionOpenTry struct { ClientId string `protobuf:"bytes,1,opt,name=client_id,json=clientId,proto3" json:"client_id,omitempty"` // Deprecated: this field is unused. Crossing hellos are no longer supported in core IBC. - PreviousConnectionId string `protobuf:"bytes,2,opt,name=previous_connection_id,json=previousConnectionId,proto3" json:"previous_connection_id,omitempty"` // Deprecated: Do not use. - ClientState *types.Any `protobuf:"bytes,3,opt,name=client_state,json=clientState,proto3" json:"client_state,omitempty"` // Deprecated: Do not use. + PreviousConnectionId string `protobuf:"bytes,2,opt,name=previous_connection_id,json=previousConnectionId,proto3" json:"previous_connection_id,omitempty"` // Deprecated: Do not use. + // Deprecated: this field is unused. + ClientState *types.Any `protobuf:"bytes,3,opt,name=client_state,json=clientState,proto3" json:"client_state,omitempty"` // Deprecated: Do not use. Counterparty Counterparty `protobuf:"bytes,4,opt,name=counterparty,proto3" json:"counterparty"` DelayPeriod uint64 `protobuf:"varint,5,opt,name=delay_period,json=delayPeriod,proto3" json:"delay_period,omitempty"` CounterpartyVersions []*Version `protobuf:"bytes,6,rep,name=counterparty_versions,json=counterpartyVersions,proto3" json:"counterparty_versions,omitempty"` diff --git a/proto/ibc/core/connection/v1/tx.proto b/proto/ibc/core/connection/v1/tx.proto index 2def4e9c487..151f72fb2d0 100644 --- a/proto/ibc/core/connection/v1/tx.proto +++ b/proto/ibc/core/connection/v1/tx.proto @@ -59,13 +59,13 @@ message MsgConnectionOpenTry { string client_id = 1; // Deprecated: this field is unused. Crossing hellos are no longer supported in core IBC. - string previous_connection_id = 2 [deprecated = true]; + string previous_connection_id = 2 [deprecated = true]; // Deprecated: this field is unused. - google.protobuf.Any client_state = 3 [deprecated = true]; - Counterparty counterparty = 4 [(gogoproto.nullable) = false]; - uint64 delay_period = 5; - repeated Version counterparty_versions = 6; - ibc.core.client.v1.Height proof_height = 7 [(gogoproto.nullable) = false]; + google.protobuf.Any client_state = 3 [deprecated = true]; + Counterparty counterparty = 4 [(gogoproto.nullable) = false]; + uint64 delay_period = 5; + repeated Version counterparty_versions = 6; + ibc.core.client.v1.Height proof_height = 7 [(gogoproto.nullable) = false]; // proof of the initialization the connection on Chain A: `UNINITIALIZED -> // INIT` bytes proof_init = 8; From 84b92b050cf064af957ac91f5f632fd3f3b3d4a7 Mon Sep 17 00:00:00 2001 From: srdtrk Date: Thu, 1 Aug 2024 16:12:10 +0900 Subject: [PATCH 30/33] imp: removed unused keeper --- modules/core/02-client/types/expected_keepers.go | 8 -------- 1 file changed, 8 deletions(-) diff --git a/modules/core/02-client/types/expected_keepers.go b/modules/core/02-client/types/expected_keepers.go index ed4caa5e881..914dfd080f8 100644 --- a/modules/core/02-client/types/expected_keepers.go +++ b/modules/core/02-client/types/expected_keepers.go @@ -2,21 +2,13 @@ package types import ( "context" - "time" upgradetypes "cosmossdk.io/x/upgrade/types" sdk "github.com/cosmos/cosmos-sdk/types" paramtypes "github.com/cosmos/cosmos-sdk/x/params/types" - stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" ) -// StakingKeeper expected staking keeper -type StakingKeeper interface { - GetHistoricalInfo(ctx context.Context, height int64) (stakingtypes.HistoricalInfo, error) - UnbondingTime(ctx context.Context) (time.Duration, error) -} - // UpgradeKeeper expected upgrade keeper type UpgradeKeeper interface { GetUpgradePlan(ctx context.Context) (plan upgradetypes.Plan, err error) From 4e7a4f6cac223345eef3cf80152f4916a8f9029a Mon Sep 17 00:00:00 2001 From: srdtrk <59252793+srdtrk@users.noreply.github.com> Date: Fri, 2 Aug 2024 07:27:21 +0700 Subject: [PATCH 31/33] Update CHANGELOG.md MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: colin axnér <25233464+colin-axner@users.noreply.github.com> --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index b741f7982a8..140af70c0a8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -76,7 +76,7 @@ Ref: https://keepachangelog.com/en/1.0.0/ * (light-clients/06-solomachine) [\#6888](https://github.com/cosmos/ibc-go/pull/6888) Remove `TypeClientMisbehaviour` constant and the `Type` method on `Misbehaviour`. * (light-clients/06-solomachine, light-clients/07-tendermint) [\#6891](https://github.com/cosmos/ibc-go/pull/6891) The `VerifyMembership` and `VerifyNonMembership` functions of solomachine's `ClientState` have been made private. The `VerifyMembership`, `VerifyNonMembership`, `GetTimestampAtHeight`, `Status` and `Initialize` functions of tendermint's `ClientState` have been made private. * (core/04-channel) [\#6902](https://github.com/cosmos/ibc-go/pull/6902) Add channel version to core application callbacks. -* (core/03-connection, core/02-client) [\#6937](https://github.com/cosmos/ibc-go/pull/6937) Remove 'ConsensusHost' interface, also removing self client and consensus state validation. +* (core/03-connection, core/02-client) [\#6937](https://github.com/cosmos/ibc-go/pull/6937) Remove 'ConsensusHost' interface, also removing self client and consensus state validation in the connection handshake. ### State Machine Breaking From 01eb9332e655f762c9c335bb628cedf663a46a5b Mon Sep 17 00:00:00 2001 From: srdtrk <59252793+srdtrk@users.noreply.github.com> Date: Fri, 2 Aug 2024 07:27:39 +0700 Subject: [PATCH 32/33] Update docs/docs/05-migrations/13-v8-to-v9.md MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: colin axnér <25233464+colin-axner@users.noreply.github.com> --- docs/docs/05-migrations/13-v8-to-v9.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/docs/05-migrations/13-v8-to-v9.md b/docs/docs/05-migrations/13-v8-to-v9.md index 4f7fac7c9d9..fc490204beb 100644 --- a/docs/docs/05-migrations/13-v8-to-v9.md +++ b/docs/docs/05-migrations/13-v8-to-v9.md @@ -371,7 +371,7 @@ clientQueryServer := clientkeeper.NewQueryServer(app.IBCKeeper.ClientKeeper) func (endpoint *Endpoint) QueryConnectionHandshakeProof() ( - clientState exported.ClientState, clientProof, - consensusProof []byte, consensusHeight clienttypes.Height, - connectioProof []byte, proofHeight clienttypes.Height, + connectionProof []byte, proofHeight clienttypes.Height, ) ``` From 4153f6f250800dbd073a0320a8184709f64aa3dd Mon Sep 17 00:00:00 2001 From: srdtrk <59252793+srdtrk@users.noreply.github.com> Date: Fri, 2 Aug 2024 07:27:47 +0700 Subject: [PATCH 33/33] Update docs/docs/05-migrations/13-v8-to-v9.md MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: colin axnér <25233464+colin-axner@users.noreply.github.com> --- docs/docs/05-migrations/13-v8-to-v9.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/docs/05-migrations/13-v8-to-v9.md b/docs/docs/05-migrations/13-v8-to-v9.md index fc490204beb..3446998e03a 100644 --- a/docs/docs/05-migrations/13-v8-to-v9.md +++ b/docs/docs/05-migrations/13-v8-to-v9.md @@ -56,7 +56,7 @@ govRouter.AddRoute(govtypes.RouterKey, govv1beta1.ProposalHandler). ## IBC core -- Because the self client and consensus state validation has been removed from the connection handshake (see section [Removal of self client and consensus state from connection handshake](#removal-of-self-client-and-consensus-state-from-connection-handshake) for more details), the IBC core keeper does not need the staking keeper anymore to introspects the (self) past historical info at a given height and construct the expected consensus state at that height. Thus, the signature of IBC core keeper constructor function `NewKeeper` has been updated: +- Because the self client and consensus state validation has been removed from the connection handshake (see section [Removal of self client and consensus state from connection handshake](#removal-of-self-client-and-consensus-state-from-connection-handshake) for more details), the IBC core keeper does not need the staking keeper anymore to introspect the (self) past historical info at a given height and construct the expected consensus state at that height. Thus, the signature of IBC core keeper constructor function `NewKeeper` has been updated: ```diff func NewKeeper(