Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

x/ibc proto migration #5704

Closed
wants to merge 62 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
62 commits
Select commit Hold shift + click to select a range
e59c32d
proto: remove cdc from ICS05
fedekunze Feb 26, 2020
6ef884f
proto: start ICS07 proto files
fedekunze Feb 26, 2020
85cc953
proto: ICS20 types
fedekunze Feb 26, 2020
d172449
proto: ICS07 messages
fedekunze Feb 26, 2020
796fe70
proto: ICS04 messages
fedekunze Feb 26, 2020
8a38c3e
proto: various ICS proto definitions
fedekunze Feb 26, 2020
a1c9ae0
proto: fixes
fedekunze Feb 26, 2020
fad6b52
godocs for ICS 07 proto file
fedekunze Feb 27, 2020
8b83fb1
proto: generate files
fedekunze Feb 27, 2020
43e38d6
merge ICS23 changes
fedekunze Mar 2, 2020
d574210
merge ibc-alpha changes
fedekunze Mar 23, 2020
5510c34
ibc: protobuf changes
fedekunze Mar 23, 2020
2d251e4
codec: move ibc client proto interfaces
fedekunze Mar 23, 2020
fc70c2e
ibc: fix some msgs and types
fedekunze Mar 23, 2020
8da8960
proto: cycles and other fixes
fedekunze Mar 24, 2020
0db08a3
proto: changes and fixes
fedekunze Mar 24, 2020
5a5816f
update types
fedekunze Mar 24, 2020
fa84a19
merge ibc-alpha changes
fedekunze Mar 24, 2020
ff66afb
fix dep cycle
fedekunze Mar 25, 2020
dfe061d
codec/std: add msgs
fedekunze Mar 25, 2020
3475fca
commitment: proto changes
fedekunze Mar 25, 2020
ee12807
fix dep cycle with Status and Order
fedekunze Mar 25, 2020
daf8f01
add tmtypes proto3 to third party
fedekunze Mar 25, 2020
ccdb13b
fixes fixes fixes
fedekunze Mar 27, 2020
94a62ca
revert GetDestination{Channel.Port}
fedekunze Mar 27, 2020
01d4651
cleanup
fedekunze Mar 27, 2020
934a576
fixes
fedekunze Mar 27, 2020
a4749e3
util funcs for tm <-> proto
fedekunze Mar 27, 2020
ea46b7f
more cleanup
fedekunze Mar 27, 2020
cff3c94
more util funcs
fedekunze Mar 30, 2020
c8229a3
more fixes
fedekunze Mar 30, 2020
610fafc
Merge branch 'ibc-alpha' of https://github.com/cosmos/cosmos-sdk into…
fedekunze Mar 31, 2020
ced1d63
more test fixes
fedekunze Mar 31, 2020
077a13f
fixes
fedekunze Mar 31, 2020
554de2d
remove PacketData and PacketAck interfaces
fedekunze Apr 1, 2020
ba1cb08
FINALLY! build
fedekunze Apr 1, 2020
2ecbb5b
fix some tests
fedekunze Apr 1, 2020
c5d00b5
fix more tests
fedekunze Apr 1, 2020
8b3400f
lint
fedekunze Apr 2, 2020
3c38a61
proto cleanup
fedekunze Apr 2, 2020
048b8d1
Merge branch 'ibc-alpha' of https://github.com/cosmos/cosmos-sdk into…
fedekunze Apr 2, 2020
2614026
try fix ics07 errors
fedekunze Apr 2, 2020
5079c78
lint
fedekunze Apr 2, 2020
80ec515
merge ibc-alpha
fedekunze Apr 3, 2020
cced361
Merge branch 'ibc-alpha' of https://github.com/cosmos/cosmos-sdk into…
fedekunze Apr 3, 2020
48828f0
Merge branch 'ibc-alpha' of github.com:cosmos/cosmos-sdk into fedekun…
fedekunze Apr 3, 2020
773a6ec
merge tm-proto
fedekunze Apr 6, 2020
9bd476f
fixes
fedekunze Apr 6, 2020
99cab85
minor updates
fedekunze Apr 7, 2020
bc0f744
merge ibc-alpha changes
fedekunze Apr 8, 2020
9dd94c0
update proto files
fedekunze Apr 8, 2020
c8669df
build
fedekunze Apr 8, 2020
f8d64c8
updates from downstream
fedekunze Apr 14, 2020
0d62302
update proto deps
fedekunze Apr 14, 2020
524cce4
fix ics07 test
fedekunze Apr 14, 2020
e5d4641
changes from master
fedekunze Apr 16, 2020
dd9df29
fix build
fedekunze Apr 16, 2020
6dac284
test fixes
fedekunze Apr 16, 2020
4d3058a
updates from downstream
fedekunze Apr 21, 2020
1b7b9c8
fixes
fedekunze Apr 21, 2020
e422b08
proto ics09
fedekunze Apr 21, 2020
8d794fa
changes from master
fedekunze Apr 29, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fixes
  • Loading branch information
fedekunze committed Apr 6, 2020
commit 9bd476f7a669df17c7466015baedf64d297faec2
4 changes: 3 additions & 1 deletion x/ibc/04-channel/types/types.pb.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

12 changes: 6 additions & 6 deletions x/ibc/07-tendermint/misbehaviour.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,16 +85,16 @@ func checkMisbehaviour(

// - ValidatorSet must have 2/3 similarity with trusted FromValidatorSet
// - ValidatorSets on both headers are valid given the last trusted ValidatorSet
if err := consensusState.ValidatorSet.ToTmTypes().VerifyCommitTrusting(
evidence.ChainID, evidence.Header1.SignedHeader.ToTmTypes().Commit.BlockID, int64(evidence.Header1.GetHeight()),
evidence.Header1.SignedHeader.ToTmTypes().Commit, lite.DefaultTrustLevel,
if err := consensusState.ValidatorSet.VerifyCommitTrusting(
evidence.ChainID, evidence.Header1.SignedHeader.Commit.BlockID, int64(evidence.Header1.GetHeight()),
evidence.Header1.SignedHeader.Commit, lite.DefaultTrustLevel,
); err != nil {
return fmt.Errorf("validator set in header 1 has too much change from last known validator set: %v", err)
}

if err := consensusState.ValidatorSet.ToTmTypes().VerifyCommitTrusting(
evidence.ChainID, evidence.Header2.SignedHeader.ToTmTypes().Commit.BlockID, int64(evidence.Header2.GetHeight()),
evidence.Header2.SignedHeader.ToTmTypes().Commit, lite.DefaultTrustLevel,
if err := consensusState.ValidatorSet.VerifyCommitTrusting(
evidence.ChainID, evidence.Header2.SignedHeader.Commit.BlockID, int64(evidence.Header2.GetHeight()),
evidence.Header2.SignedHeader.Commit, lite.DefaultTrustLevel,
); err != nil {
return fmt.Errorf("validator set in header 2 has too much change from last known validator set: %v", err)
}
Expand Down
9 changes: 5 additions & 4 deletions x/ibc/07-tendermint/types/evidence.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import (

"github.com/tendermint/tendermint/crypto/tmhash"
tmbytes "github.com/tendermint/tendermint/libs/bytes"
tmproto "github.com/tendermint/tendermint/proto/types"
tmtypes "github.com/tendermint/tendermint/types"

sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
Expand Down Expand Up @@ -92,21 +93,21 @@ func (ev Evidence) ValidateBasic() error {
return sdkerrors.Wrapf(clienttypes.ErrInvalidEvidence, "headers in evidence are on different heights (%d ≠ %d)", ev.Header1.GetHeight(), ev.Header2.GetHeight())
}
// Ensure that Commit Hashes are different
if ev.Header1.SignedHeader.Commit.BlockID == ev.Header2.SignedHeader.Commit.BlockID {
if ev.Header1.SignedHeader.Commit.BlockID.Equal(ev.Header2.SignedHeader.Commit.BlockID) {
return sdkerrors.Wrap(clienttypes.ErrInvalidEvidence, "headers commit to same blockID")
}
if err := ValidCommit(ev.ChainID, ev.Header1.SignedHeader.Commit.ToTmTypes(), ev.Header1.ValidatorSet.ToTmTypes()); err != nil {
if err := ValidCommit(ev.ChainID, ev.Header1.SignedHeader.Commit, ev.Header1.ValidatorSet.ToTmTypes()); err != nil {
return err
}
return ValidCommit(ev.ChainID, ev.Header2.SignedHeader.Commit.ToTmTypes(), ev.Header2.ValidatorSet.ToTmTypes())
return ValidCommit(ev.ChainID, ev.Header2.SignedHeader.Commit, ev.Header2.ValidatorSet.ToTmTypes())
}

// ValidCommit checks if the given commit is a valid commit from the passed-in validatorset
//
// CommitToVoteSet will panic if the commit cannot be converted to a valid voteset given the validatorset
// This implies that someone tried to submit evidence that wasn't actually committed by the validatorset
// thus we should return an error here and reject the evidence rather than panicing.
func ValidCommit(chainID string, commit *tmtypes.Commit, valSet *tmtypes.ValidatorSet) (err error) {
func ValidCommit(chainID string, commit *tmproto.Commit, valSet *tmtypes.ValidatorSet) (err error) {
defer func() {
if r := recover(); r != nil {
err = sdkerrors.Wrapf(clienttypes.ErrInvalidEvidence, "invalid commit: %v", r)
Expand Down
6 changes: 3 additions & 3 deletions x/ibc/07-tendermint/types/evidence_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -156,11 +156,11 @@ func (suite *TendermintTestSuite) TestEvidenceValidateBasic() {
func(ev *ibctmtypes.Evidence) error {
// voteSet contains only altVal which is less than 2/3 of total power (height/1height)
wrongVoteSet := tmtypes.NewVoteSet(chainID, ev.Header2.SignedHeader.Header.Height, 1, tmtypes.PrecommitType, altValSet)
commit, err := tmtypes.MakeCommit(ev.Header2.SignedHeader.Commit.BlockID.ToTmTypes(), ev.Header2.SignedHeader.Header.Height, ev.Header2.SignedHeader.Commit.ToTmTypes().Round, wrongVoteSet, altSigners, suite.now)
commit, err := tmtypes.MakeCommit(ev.Header2.SignedHeader.Commit.BlockID, ev.Header2.SignedHeader.Header.Height, ev.Header2.SignedHeader.Commit.Round, wrongVoteSet, altSigners, suite.now)
if err != nil {
return err
}
ev.Header2.SignedHeader.Commit = ibctmtypes.CommitFromTmTypes(commit)
ev.Header2.SignedHeader.Commit = commit
return nil
},
false,
Expand All @@ -175,7 +175,7 @@ func (suite *TendermintTestSuite) TestEvidenceValidateBasic() {
},
func(ev *ibctmtypes.Evidence) error {
blockID := ibctmtypes.MakeBlockID(tmhash.Sum([]byte("other_hash")), 3, tmhash.Sum([]byte("other_partset")))
ev.Header2.SignedHeader.Commit.BlockID = ibctmtypes.BlockIDFromTmTypes(blockID)
ev.Header2.SignedHeader.Commit.BlockID = blockID
return nil
},
false,
Expand Down
2 changes: 1 addition & 1 deletion x/ibc/07-tendermint/types/header.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ func (h Header) GetTime() time.Time {
// ValidateBasic calls the SignedHeader ValidateBasic function
// and checks that validatorsets are not nil
func (h Header) ValidateBasic(chainID string) error {
if err := h.SignedHeader.ToTmTypes().ValidateBasic(chainID); err != nil {
if err := h.SignedHeader.Header.ValidateBasic(chainID); err != nil {
return sdkerrors.Wrap(clienttypes.ErrInvalidHeader, err.Error())
}
if h.ValidatorSet == nil {
Expand Down
2 changes: 1 addition & 1 deletion x/ibc/07-tendermint/types/tendermint_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ func (suite *TendermintTestSuite) SetupTest() {

val := tmtypes.NewValidator(pk, 10)
suite.valSet = tmtypes.NewValidatorSet([]*tmtypes.Validator{val})
suite.header = ibctmtypes.CreateTestHeader(chainID, height, suite.now, suite.valSet, []tmtypes.PrivValidator{suite.privVal})
suite.header = ibctmtypes.CreateTestHeader(chainID, height, suite.now, suite.valSet.ToTmTypes(), []tmtypes.PrivValidator{suite.privVal})
}

func TestTendermintTestSuite(t *testing.T) {
Expand Down
22 changes: 11 additions & 11 deletions x/ibc/07-tendermint/types/test_utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import (
"time"

"github.com/tendermint/tendermint/crypto/tmhash"
tmproto "github.com/tendermint/tendermint/proto/types"
tmtypes "github.com/tendermint/tendermint/types"
"github.com/tendermint/tendermint/version"
)
Expand Down Expand Up @@ -41,42 +42,41 @@ func CreateTestHeader(chainID string, height int64, timestamp time.Time, valSet
}

blockID := MakeBlockID(tmHeader.Hash(), 3, tmhash.Sum([]byte("part_set")))
voteSet := tmtypes.NewVoteSet(chainID, height, 1, tmtypes.PrecommitType, valSet)
voteSet := tmtypes.NewVoteSet(chainID, height, 1, tmproto.PrecommitType, valSet)
commit, err := tmtypes.MakeCommit(blockID, height, 1, voteSet, signers, timestamp)
if err != nil {
panic(err)
}

commitSigs := make([]*CommitSig, len(commit.Signatures))
commitSigs := make([]tmproto.CommitSig, len(commit.Signatures))

for i := range commit.Signatures {
cs := CommitSig{
BlockIDFlag: []byte{byte(commit.Signatures[i].BlockIDFlag)},
commitSigs[i] = tmproto.CommitSig{
BlockIdFlag: commit.Signatures[i].BlockIDFlag,
ValidatorAddress: commit.Signatures[i].ValidatorAddress,
Timestamp: commit.Signatures[i].Timestamp,
Signature: commit.Signatures[i].Signature,
}
commitSigs[i] = &cs
}

abciBlockID := tmtypes.TM2PB.BlockID(blockID)
abciHeader := tmtypes.TM2PB.Header(tmHeader)

signedHeader := SignedHeader{
signedHeader := tmproto.SignedHeader{
Header: &abciHeader,
Commit: Commit{
Commit: &tmproto.Commit{
Height: commit.Height,
Round: int32(commit.Round),
BlockID: &BlockID{
BlockID: tmproto.BlockID{
Hash: abciBlockID.Hash,
PartsHeader: &PartsHeader{
PartsHeader: tmproto.PartsHeader{
Total: abciBlockID.PartsHeader.Total,
Hash: abciBlockID.PartsHeader.Hash,
},
},
Signatures: commitSigs,
hash: commit.Hash(),
bitArray: commit.BitArray().Bytes(),
Hash: commit.Hash(),
BitArray: commit.BitArray(),
},
}

Expand Down
Loading