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

IBC v1.0.0 #5245

Merged
merged 496 commits into from
Nov 5, 2019
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
496 commits
Select commit Hold shift + click to select a range
09e6600
applying review in progress
mossid Sep 11, 2019
6f5f633
Merge branch 'joon/store-mapping' of github.com:cosmos/cosmos-sdk int…
mossid Sep 11, 2019
4116bb7
apply review - make querier interface
mossid Sep 11, 2019
bb006fd
Merge branch 'master' of github.com:cosmos/cosmos-sdk into joon/ibc-s…
mossid Sep 12, 2019
08efad1
fix cli errors
mossid Sep 16, 2019
8040c81
Merge branch 'master' of github.com:cosmos/cosmos-sdk into joon/store…
mossid Sep 17, 2019
48bb32d
Merge branch 'joon/store-mapping' into joon/ics-23-implementation
mossid Sep 17, 2019
9b63a6b
fix dependency
mossid Sep 17, 2019
a7df43c
Merge branch 'joon/ics-23-implementation' into joon/ics-02-implementa…
mossid Sep 17, 2019
acaaaf2
fix dependency
mossid Sep 17, 2019
c18ba68
Merge branch 'joon/ics-02-implementation' into joon/ics-03-implementa…
mossid Sep 17, 2019
ab71a6e
Merge branch 'joon/ics-03-implementation' into joon/ics-04-implementa…
mossid Sep 17, 2019
4e53dcd
reflect method name change
mossid Sep 17, 2019
70a1c97
Merge branch 'joon/ics-04-implementation' into joon/ibc-sdk-interface
mossid Sep 17, 2019
828badd
revise querier interface to work both on cli & store
mossid Sep 18, 2019
f88d8d3
revise querier interface to work both on cli & store
mossid Sep 18, 2019
1e64e92
revise querier interface to work both on cli & store
mossid Sep 18, 2019
b4d7491
reflect downstream change
mossid Sep 18, 2019
a59d1e7
Merge branch 'joon/store-mapping' into joon/ics-23-implementation
mossid Sep 18, 2019
bb09ad9
Merge branch 'joon/ics-23-implementation' into joon/ics-02-implementa…
mossid Sep 18, 2019
3ba9f9c
Merge branch 'joon/ics-02-implementation' into joon/ics-03-implementa…
mossid Sep 18, 2019
de1a045
fix cli
mossid Sep 18, 2019
2ef039a
Merge branch 'joon/ics-02-implementation' into joon/ics-03-implementa…
mossid Sep 18, 2019
a600589
reflect downstream changes
mossid Sep 18, 2019
1fd3040
Merge branch 'joon/ics-03-implementation' into joon/ics-04-implementa…
mossid Sep 18, 2019
c90ed2d
reflect downstream changes
mossid Sep 18, 2019
ffed153
Merge branch 'joon/ics-04-implementation' into joon/ibc-sdk-interface
mossid Sep 18, 2019
cbfb043
fix from address in tx cli
mossid Sep 18, 2019
b15a44d
fix cli in progress(squash later)
mossid Sep 19, 2019
8820838
fix cli
mossid Sep 19, 2019
a72f6c5
remove timeout, add channel cli
mossid Sep 20, 2019
4b81cb5
fix golangci
mossid Sep 20, 2019
3866942
fix cli
mossid Sep 20, 2019
6e6c186
Clean up
tnachen Sep 25, 2019
025caf1
fix mock cli in progress
mossid Sep 25, 2019
c289635
Merge branch 'joon/ibc-sdk-interface' of github.com:cosmos/cosmos-sdk…
mossid Sep 25, 2019
1cea7e3
finalize cleanup, mock cli wip
mossid Sep 28, 2019
45dcdb3
add cli for mocksend
mossid Sep 28, 2019
56be11e
fix handler
mossid Sep 28, 2019
9f63629
rm commented lines
mossid Sep 28, 2019
b4e71e1
address review in progress
mossid Sep 28, 2019
3f509ee
address review, rm cleanup/closing
mossid Sep 28, 2019
10bf523
rename mock packages
mossid Oct 1, 2019
fea2ba6
fix interface for gaia
mossid Oct 1, 2019
6b966a3
rename Path -> Prefix
mossid Oct 1, 2019
21bd8d0
Store accessor upstream changes (#5119)
fedekunze Oct 1, 2019
af2564b
Merge branch 'joon/store-mapping' of https://github.com/cosmos/cosmos…
fedekunze Oct 1, 2019
303ebf3
Merge branch 'master' of https://github.com/cosmos/cosmos-sdk into jo…
fedekunze Oct 1, 2019
9b3b120
Merge branch 'master' into joon/store-mapping
fedekunze Oct 1, 2019
18f8d70
Merge branch 'joon/store-mapping' of https://github.com/cosmos/cosmos…
fedekunze Oct 1, 2019
df5b21a
add comments, reformat merkle querier
mossid Oct 1, 2019
7afe221
Merge branch 'joon/ics-23-implementation' of github.com:cosmos/cosmos…
mossid Oct 1, 2019
1ac982c
rm merkle/utils
mossid Oct 1, 2019
fa04419
ICS 23 upstream changes (#5120)
fedekunze Oct 1, 2019
0d5a317
downstream changes
fedekunze Oct 1, 2019
db8d382
update Value
fedekunze Oct 1, 2019
02b31a5
Merge branch 'joon/ics-23-implementation' of https://github.com/cosmo…
fedekunze Oct 1, 2019
4d518f2
update test
fedekunze Oct 1, 2019
8a3e5ea
fix
fedekunze Oct 1, 2019
9975a1d
ICS 02 upstream changes (#5122)
fedekunze Oct 1, 2019
ffc6918
merge ICS 02
fedekunze Oct 1, 2019
11bdbd7
ICS 03 upstream changes (#5123)
fedekunze Oct 1, 2019
5db0863
merge ICS 02
fedekunze Oct 1, 2019
dbbe703
merge upstream changes
fedekunze Oct 1, 2019
7428e5b
update test
fedekunze Oct 1, 2019
cc404a0
cleanup types and submodule
fedekunze Oct 2, 2019
d93a0ae
more cleanup and godocs
fedekunze Oct 2, 2019
9b6afe9
remove counterPartyManager/State and cleanup
fedekunze Oct 2, 2019
c8a0ab4
implement SubmitMisbehaviour and refactor
fedekunze Oct 2, 2019
4483182
errors
fedekunze Oct 4, 2019
23fbb5d
events
fedekunze Oct 4, 2019
ebecbce
fix test
fedekunze Oct 4, 2019
0e85ed0
refactors
fedekunze Oct 4, 2019
03574cb
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
fedekunze Oct 7, 2019
f16d6e9
WIP refactor ICS03
fedekunze Oct 7, 2019
a7d2d98
remove Mapping
fedekunze Oct 7, 2019
1b7e466
remove store accessors
fedekunze Oct 7, 2019
c09a84c
Merge branch 'master' of https://github.com/cosmos/cosmos-sdk into jo…
fedekunze Oct 7, 2019
99c586b
Merge branch 'joon/ics-23-implementation' of https://github.com/cosmo…
fedekunze Oct 7, 2019
02bd6f7
proposed refactor
fedekunze Oct 7, 2019
0e37d75
remove store accessors from ICS02
fedekunze Oct 7, 2019
8dec96f
refactor queriers, handler and clean keeper
fedekunze Oct 8, 2019
83f4c1b
logger and tx long description
fedekunze Oct 8, 2019
178912f
ineffassign
fedekunze Oct 8, 2019
c4617e0
merge ICS02
fedekunze Oct 8, 2019
9a225e9
Apply suggestions from code review
fedekunze Oct 8, 2019
fe7da5f
Apply suggestions from code review
fedekunze Oct 8, 2019
c8ff483
remove store accessors
fedekunze Oct 8, 2019
8bcf17f
refactor handshake to update it to the latest ICS03 spec
fedekunze Oct 9, 2019
3df5378
update handler and msgs
fedekunze Oct 9, 2019
21f7d2c
add verification functions
fedekunze Oct 9, 2019
4e9d2bb
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
fedekunze Oct 9, 2019
604afd5
update verification
fedekunze Oct 9, 2019
cf347bf
ICS02 module.go
fedekunze Oct 9, 2019
5514e9e
top level x/ibc structure
fedekunze Oct 9, 2019
39dd637
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
fedekunze Oct 9, 2019
eefa08b
update connection queries
fedekunze Oct 9, 2019
482f24d
update connection tx
fedekunze Oct 10, 2019
e4ffd8e
remove extra files
fedekunze Oct 10, 2019
f69ac00
Merge branch 'joon/ics-03-implementation' of https://github.com/cosmo…
fedekunze Oct 10, 2019
e334947
refactor: remove store accessors, update keeper and types to match sp…
fedekunze Oct 11, 2019
0125276
update handshake and packet
fedekunze Oct 14, 2019
038d7cf
implement packet timeouts
fedekunze Oct 14, 2019
931ef76
implement send and receive packet
fedekunze Oct 14, 2019
de156d3
implement packet ACK
fedekunze Oct 14, 2019
9cc1447
update handler
fedekunze Oct 14, 2019
bb4c551
add channel errors
fedekunze Oct 14, 2019
4c50d4f
channel querier
fedekunze Oct 14, 2019
0163482
update expected client keeper and export verification funcs
fedekunze Oct 14, 2019
7c37222
ICS 05 Implementation
fedekunze Oct 14, 2019
a8244dc
release port and godocs
fedekunze Oct 14, 2019
a1c22e9
Merge branch 'master' into joon/ics-23-implementation
fedekunze Oct 15, 2019
a8ceb45
Update x/ibc/02-client/client/cli/query.go
fedekunze Oct 15, 2019
956eb5c
Update x/ibc/02-client/types/tendermint/consensus_state.go
fedekunze Oct 15, 2019
2cc23b2
Merge branch 'joon/ics-23-implementation' of https://github.com/cosmo…
fedekunze Oct 15, 2019
2e1e894
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
fedekunze Oct 15, 2019
c573d57
address some of the review comments
fedekunze Oct 15, 2019
6913146
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
fedekunze Oct 15, 2019
f852b1b
resolve some TODOs and address comments from review
fedekunze Oct 15, 2019
245901c
update connection versioning
fedekunze Oct 15, 2019
7a82144
minor error updates
fedekunze Oct 15, 2019
99829bb
Merge branch 'joon/ics-03-implementation' of https://github.com/cosmo…
fedekunze Oct 15, 2019
105cd5a
Merge branch 'fedekunze/ics-05-implementation' of https://github.com/…
fedekunze Oct 15, 2019
1b45a24
update ICS04 with downstream changes
fedekunze Oct 15, 2019
c079abb
Implement tx cli actions
jackzampolin Oct 15, 2019
791b245
Merge branch 'joon/ics-04-implementation' of github.com:cosmos/cosmos…
jackzampolin Oct 15, 2019
2b4cb05
add MsgSendPacket handler; msg validation, errors and events
fedekunze Oct 16, 2019
012bf54
update errors and add port Keeper to ibc Keeper
fedekunze Oct 16, 2019
b2cd838
merge ICS05 - port PR
fedekunze Oct 16, 2019
6af2ce7
minor UX improvements
fedekunze Oct 16, 2019
8be3af7
rename pkg
fedekunze Oct 16, 2019
53ab47d
fixes
fedekunze Oct 16, 2019
d3a533a
Merge branch 'master' of https://github.com/cosmos/cosmos-sdk into jo…
fedekunze Oct 16, 2019
0d56b51
implement query proofs
fedekunze Oct 17, 2019
7ba777e
Merge branch 'master' of https://github.com/cosmos/cosmos-sdk into jo…
fedekunze Oct 18, 2019
499abb4
refactor ICS23
fedekunze Oct 18, 2019
a925d88
cleanup types
fedekunze Oct 18, 2019
a0cafbf
Merge branch 'joon/ics-03-implementation' of https://github.com/cosmo…
fedekunze Oct 18, 2019
b174427
Merge branch 'fedekunze/ics-05-implementation' of https://github.com/…
fedekunze Oct 18, 2019
c3b6b18
ICS 5 updates (#5222)
cwgoes Oct 21, 2019
74d8a4b
rename pkg and fix import
fedekunze Oct 21, 2019
53f5fad
Merge branch 'master' of https://github.com/cosmos/cosmos-sdk into jo…
fedekunze Oct 21, 2019
c12c298
implement batch verification
fedekunze Oct 21, 2019
a34b741
gosimple suggestion
fedekunze Oct 21, 2019
bf4f096
Merge branch 'master' into joon/ics-23-implementation
fedekunze Oct 21, 2019
386489b
Merge branch 'joon/ics-23-implementation' of https://github.com/cosmo…
fedekunze Oct 21, 2019
383ba49
merge ICS23
fedekunze Oct 21, 2019
9b77275
various fixes; remove legacy tests; remove commitment path query
fedekunze Oct 22, 2019
40fca1a
alias
fedekunze Oct 22, 2019
1eaf55e
Merge branch 'joon/ics-23-implementation' of https://github.com/cosmo…
fedekunze Oct 22, 2019
deceeb8
minor updates from ICS23
fedekunze Oct 22, 2019
2a1a144
renaming
fedekunze Oct 22, 2019
2aa4734
ICS02 changes
fedekunze Oct 22, 2019
714e6e2
update verification and rename root funcs
fedekunze Oct 22, 2019
93bb9d7
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
fedekunze Oct 22, 2019
3351c08
Merge branch 'joon/ics-03-implementation' of https://github.com/cosmo…
fedekunze Oct 22, 2019
323bc8d
Merge branch 'fedekunze/ics-05-implementation' of https://github.com/…
fedekunze Oct 22, 2019
4680ad3
merge downstream changes
fedekunze Oct 22, 2019
4282729
rm legacy tests; add query proofs support
fedekunze Oct 22, 2019
8fe17f6
remove capability key generation and authentication logic
fedekunze Oct 22, 2019
de13f5a
move querier to x/ibc
fedekunze Oct 22, 2019
aae117f
update query.go to use 'custom/...' query path
fedekunze Oct 22, 2019
f8fd580
add tests
AdityaSripal Oct 22, 2019
cbc1106
ICS 24 Implementation (#5229)
AdityaSripal Oct 22, 2019
f8d99ca
Merge branch 'master' of https://github.com/cosmos/cosmos-sdk into jo…
fedekunze Oct 23, 2019
23ae994
flatten ICS23 structure
fedekunze Oct 23, 2019
e1fa5f8
fix ApplyPrefix
fedekunze Oct 23, 2019
7222642
Merge branch 'joon/ics-23-implementation' of https://github.com/cosmo…
fedekunze Oct 23, 2019
4f89602
updates from ICS23 and ICS24
fedekunze Oct 23, 2019
22f874a
msg.ValidateBasic and ADR09 evidence interface
fedekunze Oct 23, 2019
2edb03f
complete types testing
AdityaSripal Oct 23, 2019
5783b03
merge
AdityaSripal Oct 23, 2019
696db2e
delete empty test file
AdityaSripal Oct 23, 2019
69db1f2
remove ibc errors from core error package
AdityaSripal Oct 23, 2019
c22faa1
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
fedekunze Oct 24, 2019
021544f
custom JSON marshaling; msg.ValidateBasic; renaming of variables
fedekunze Oct 24, 2019
7809e4d
minor update
fedekunze Oct 24, 2019
102ab3d
custom JSON marshaling
fedekunze Oct 24, 2019
2f68c0c
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
fedekunze Oct 24, 2019
b9654da
Merge branch 'joon/ics-03-implementation' of https://github.com/cosmo…
fedekunze Oct 24, 2019
c8289a8
use host validation for port ids
fedekunze Oct 24, 2019
73be9cc
Merge branch 'fedekunze/ics-05-implementation' of https://github.com/…
fedekunze Oct 24, 2019
7cab018
downstream changes; custom marshal JSON; msg validation, and update e…
fedekunze Oct 24, 2019
a81f236
update errors and aliases
fedekunze Oct 24, 2019
33312c2
start batch-verify tests
AdityaSripal Oct 24, 2019
8d95afa
update msg validation and CLI UX
fedekunze Oct 25, 2019
49d08e3
Merge branch 'master' of https://github.com/cosmos/cosmos-sdk into jo…
fedekunze Oct 25, 2019
5239720
minor changes on commitment types
fedekunze Oct 25, 2019
46f9cbd
fix channel and packet check (#5243)
chengwenxi Oct 25, 2019
e048a6c
R4R - Store consensus state correctly (#5242)
chengwenxi Oct 25, 2019
093c004
Merge branch 'joon/ics-23-implementation' of https://github.com/cosmo…
fedekunze Oct 25, 2019
3965928
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
fedekunze Oct 25, 2019
0c187bf
update alias
fedekunze Oct 25, 2019
29bc19e
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
fedekunze Oct 25, 2019
24e6d29
update alias
fedekunze Oct 25, 2019
a06f30a
Merge branch 'joon/ics-03-implementation' of https://github.com/cosmo…
fedekunze Oct 25, 2019
bd21702
update alias and keeper.GetPort()
fedekunze Oct 25, 2019
ed07a05
downstream changes
fedekunze Oct 25, 2019
afc0583
authenticate port ID; remove send packet msg from CLI
fedekunze Oct 25, 2019
335954c
comment out handlers
fedekunze Oct 25, 2019
09adf43
add ibc module to simapp
fedekunze Oct 25, 2019
0363390
ICS20 implementation (#5204)
chengwenxi Oct 25, 2019
8a62201
switch ibc antehandler to decorator pattern
AdityaSripal Oct 25, 2019
2a6a77a
fix name/comment
AdityaSripal Oct 25, 2019
f3120bf
ICS 20 implementation (#5250)
chengwenxi Oct 29, 2019
9742c14
update ICS20 escrow address
fedekunze Oct 29, 2019
90d0354
fix querier routes
jackzampolin Oct 29, 2019
94ffaeb
fix create client cli
mossid Oct 29, 2019
5a397db
minor updates
fedekunze Oct 30, 2019
af6bed9
ibc querier test
fedekunze Oct 30, 2019
d1f71dd
Merge branch 'master' into joon/ics-23-implementation
fedekunze Oct 30, 2019
82d9124
Refactor ibc/mock/bank into ICS 20 (#5264)
cwgoes Oct 30, 2019
d5363c0
setup ics20 test suite
fedekunze Oct 30, 2019
5004f00
Merge branch 'fedekunze/ibc' of https://github.com/cosmos/cosmos-sdk …
fedekunze Oct 30, 2019
b772c8e
add event to MsgRecvPacket
fedekunze Oct 30, 2019
7655278
update ibc keeper test to use test suite
fedekunze Oct 30, 2019
64b09cb
Add handshake commands
jackzampolin Oct 30, 2019
3ebd0e7
Merge branch 'fedekunze/ibc' of github.com:cosmos/cosmos-sdk into fed…
jackzampolin Oct 30, 2019
600ab59
WIP connection handshake
jackzampolin Oct 30, 2019
0d595c8
WIP Connection Handshake
jackzampolin Oct 30, 2019
0a461b5
use testsuite
AdityaSripal Oct 30, 2019
dac68df
Merge branch 'joon/ics-23-implementation' of https://github.com/cosmo…
AdityaSripal Oct 30, 2019
ccb405a
Add cliCtx.WaitForNBlocks
jackzampolin Oct 30, 2019
89b5844
fix connection handshake in progress
mossid Oct 30, 2019
99c9490
Merge branch 'fedekunze/ibc' of github.com:cosmos/cosmos-sdk into fed…
mossid Oct 30, 2019
6098833
fix connection handshake in progress
mossid Oct 31, 2019
7f9c166
Integrate Evidence Implementation into ICS-02 (#5258)
AdityaSripal Nov 4, 2019
a74ebf3
Merge branch 'master' into joon/ics-23-implementation
fedekunze Nov 4, 2019
6d580aa
finish tendermint tests
AdityaSripal Nov 5, 2019
0dd779e
Merge branch 'joon/ics-02-implementation' of https://github.com/cosmo…
AdityaSripal Nov 5, 2019
e875ca7
complete merge
AdityaSripal Nov 5, 2019
cd0aa22
Add tests for msgs
AdityaSripal Nov 5, 2019
0c8b759
upstream changes
fedekunze Nov 5, 2019
c6fa07b
fix
fedekunze Nov 5, 2019
17abbda
Merge branch 'master' of https://github.com/cosmos/cosmos-sdk into jo…
fedekunze Nov 5, 2019
820482f
upstream changes
fedekunze Nov 5, 2019
962979d
ICS23 changes
fedekunze Nov 5, 2019
b5442d3
fix cons state
fedekunze Nov 5, 2019
7c67236
context changes
fedekunze Nov 5, 2019
4866753
Merge branch 'joon/ics-23-implementation' of https://github.com/cosmo…
fedekunze Nov 5, 2019
a696f05
upstream changes
fedekunze Nov 5, 2019
df6bd66
fix cli tx
fedekunze Nov 5, 2019
024486c
upstream changes
fedekunze Nov 5, 2019
b039d37
Merge branch joon/ics-03-implementation' of https://github.com/cosmos…
fedekunze Nov 5, 2019
ab50629
upstream changes
fedekunze Nov 5, 2019
6ec0148
downstream changes
fedekunze Nov 5, 2019
6106861
upstream changes
fedekunze Nov 5, 2019
ab7b2a6
downstream changes
fedekunze Nov 5, 2019
8e669fe
upstream changes
fedekunze Nov 5, 2019
5c4b0d2
conflicts
fedekunze Nov 5, 2019
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
Clean up
  • Loading branch information
tnachen committed Sep 25, 2019
commit 6e6c186342266a14e16ef3990beeb8c719cf0417
2 changes: 1 addition & 1 deletion x/ibc/02-client/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -46,4 +46,4 @@ each corresponds to `spec: Header.{height, proof, state, root}`.

### manager.go

`spec: interface ClientState` is implemented by `type Object`. // TODO
`spec: interface ClientState` is implemented by `type State`. // TODO
6 changes: 0 additions & 6 deletions x/ibc/02-client/codec.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,11 +15,5 @@ func RegisterCodec(cdc *codec.Codec) {
}

func SetMsgCodec(cdc *codec.Codec) {
// TODO
/*
if MsgCdc != nil && MsgCdc != cdc {
panic("MsgCdc set more than once")
}
*/
MsgCdc = cdc
}
2 changes: 1 addition & 1 deletion x/ibc/02-client/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ func (man CounterpartyManager) Query(id string) CounterObject {
return man.Object(id)
}

// Any actor holding the Object can access on and modify that client information
// Any actor holding the Stage can access on and modify that client information
type Object struct {
id string
Roots state.Indexer
Expand Down
24 changes: 12 additions & 12 deletions x/ibc/03-connection/cli.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,55 +7,55 @@ import (
"github.com/cosmos/cosmos-sdk/x/ibc/23-commitment/merkle"
)

func (man Manager) CLIObject(connid, clientid string) Object {
func (man Manager) CLIObject(connid, clientid string) State {
obj := man.Object(connid)
obj.Client = man.client.Object(clientid)
return obj
}

func (obj Object) prefix() []byte {
func (obj State) prefix() []byte {
return bytes.Split(obj.Connection.KeyBytes(), LocalRoot())[0]
}

func (obj Object) ConnectionCLI(q state.ABCIQuerier) (res Connection, proof merkle.Proof, err error) {
func (obj State) ConnectionCLI(q state.ABCIQuerier) (res Connection, proof merkle.Proof, err error) {
tmproof, err := obj.Connection.Query(q, &res)
proof = merkle.NewProofFromValue(tmproof, obj.prefix(), obj.Connection)
return
}

func (obj Object) AvailableCLI(q state.ABCIQuerier) (res bool, proof merkle.Proof, err error) {
func (obj State) AvailableCLI(q state.ABCIQuerier) (res bool, proof merkle.Proof, err error) {
res, tmproof, err := obj.Available.Query(q)
proof = merkle.NewProofFromValue(tmproof, obj.prefix(), obj.Available)
return
}

func (obj Object) KindCLI(q state.ABCIQuerier) (res string, proof merkle.Proof, err error) {
func (obj State) KindCLI(q state.ABCIQuerier) (res string, proof merkle.Proof, err error) {
res, tmproof, err := obj.Kind.Query(q)
proof = merkle.NewProofFromValue(tmproof, obj.prefix(), obj.Kind)
return
}

func (man Handshaker) CLIObject(connid, clientid string) HandshakeObject {
return man.Object(man.man.CLIObject(connid, clientid))
func (man Handshaker) CLIObject(connid, clientid string) HandshakeState {
return man.CreateState(man.man.CLIObject(connid, clientid))
}

func (man Handshaker) CLIQuery(q state.ABCIQuerier, connid string) (HandshakeObject, error) {
func (man Handshaker) CLIQuery(q state.ABCIQuerier, connid string) (HandshakeState, error) {
obj := man.man.Object(connid)
conn, _, err := obj.ConnectionCLI(q)
if err != nil {
return HandshakeObject{}, err
return HandshakeState{}, err
}
obj.Client = man.man.client.Object(conn.Client)
return man.Object(obj), nil
return man.CreateState(obj), nil
}

func (obj HandshakeObject) StateCLI(q state.ABCIQuerier) (res byte, proof merkle.Proof, err error) {
func (obj HandshakeState) StateCLI(q state.ABCIQuerier) (res byte, proof merkle.Proof, err error) {
res, tmproof, err := obj.State.Query(q)
proof = merkle.NewProofFromValue(tmproof, obj.prefix(), obj.State)
return
}

func (obj HandshakeObject) CounterpartyClientCLI(q state.ABCIQuerier) (res string, proof merkle.Proof, err error) {
func (obj HandshakeState) CounterpartyClientCLI(q state.ABCIQuerier) (res string, proof merkle.Proof, err error) {
res, tmproof, err := obj.CounterpartyClient.Query(q)
proof = merkle.NewProofFromValue(tmproof, obj.prefix(), obj.CounterpartyClient)
return
Expand Down
4 changes: 2 additions & 2 deletions x/ibc/03-connection/client/cli/query.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ const (
FlagProve = "prove"
)

func object(cdc *codec.Codec, storeKey string, prefix []byte, connid, clientid string) connection.Object {
func object(cdc *codec.Codec, storeKey string, prefix []byte, connid, clientid string) connection.State {
base := state.NewMapping(sdk.NewKVStoreKey(storeKey), cdc, prefix)
climan := client.NewManager(base)
man := connection.NewManager(base, climan)
Expand All @@ -43,7 +43,7 @@ func GetQueryCmd(storeKey string, cdc *codec.Codec) *cobra.Command {
return ibcQueryCmd
}

func QueryConnection(ctx context.CLIContext, obj connection.Object, prove bool) (res utils.JSONObject, err error) {
func QueryConnection(ctx context.CLIContext, obj connection.State, prove bool) (res utils.JSONObject, err error) {
q := state.NewCLIQuerier(ctx)

conn, connp, err := obj.ConnectionCLI(q)
Expand Down
85 changes: 42 additions & 43 deletions x/ibc/03-connection/client/cli/tx.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,26 +26,21 @@ import (
"github.com/cosmos/cosmos-sdk/x/ibc/version"
)

/*
func GetTxCmd(storeKey string, cdc *codec.Codec) *cobra.Command {

}
*/
const (
FlagNode1 = "node1"
FlagNode2 = "node2"
FlagFrom1 = "from1"
FlagFrom2 = "from2"
)

func handshake(q state.ABCIQuerier, cdc *codec.Codec, storeKey string, prefix []byte, connid string) (connection.HandshakeObject, error) {
func handshake(q state.ABCIQuerier, cdc *codec.Codec, storeKey string, prefix []byte, connid string) (connection.HandshakeState, error) {
base := state.NewMapping(sdk.NewKVStoreKey(storeKey), cdc, prefix)
climan := client.NewManager(base)
man := connection.NewHandshaker(connection.NewManager(base, climan))
clientManager := client.NewManager(base)
man := connection.NewHandshaker(connection.NewManager(base, clientManager))
return man.CLIQuery(q, connid)
}

func lastheight(ctx context.CLIContext) (uint64, error) {
func lastHeight(ctx context.CLIContext) (uint64, error) {
node, err := ctx.GetNode()
if err != nil {
return 0, err
Expand Down Expand Up @@ -116,7 +111,6 @@ func GetCmdHandshake(storeKey string, cdc *codec.Codec) *cobra.Command {
Use: "handshake",
Short: "initiate connection handshake between two chains",
Args: cobra.ExactArgs(6),
// Args: []string{connid1, clientid1, path1, connid2, clientid2, connfilepath2}
RunE: func(cmd *cobra.Command, args []string) error {
txBldr := auth.NewTxBuilderFromCLI().WithTxEncoder(utils.GetTxEncoder(cdc))
ctx1 := context.NewCLIContextWithFrom(viper.GetString(FlagFrom1)).
Expand All @@ -131,10 +125,10 @@ func GetCmdHandshake(storeKey string, cdc *codec.Codec) *cobra.Command {
WithBroadcastMode(flags.BroadcastBlock)
q2 := state.NewCLIQuerier(ctx2)

connid1 := args[0]
clientid1 := args[1]
connid2 := args[3]
clientid2 := args[4]
connId1 := args[0]
clientId1 := args[1]
connId2 := args[3]
clientId2 := args[4]

var path1 commitment.Path
path1bz, err := ioutil.ReadFile(args[2])
Expand All @@ -145,12 +139,12 @@ func GetCmdHandshake(storeKey string, cdc *codec.Codec) *cobra.Command {
return err
}
conn1 := connection.Connection{
Client: clientid1,
Counterparty: connid2,
Client: clientId1,
Counterparty: connId2,
Path: path1,
}

obj1, err := handshake(q1, cdc, storeKey, version.DefaultPrefix(), connid1)
obj1, err := handshake(q1, cdc, storeKey, version.DefaultPrefix(), connId1)
if err != nil {
return err
}
Expand All @@ -164,51 +158,51 @@ func GetCmdHandshake(storeKey string, cdc *codec.Codec) *cobra.Command {
return err
}
conn2 := connection.Connection{
Client: clientid2,
Counterparty: connid1,
Client: clientId2,
Counterparty: connId1,
Path: path2,
}

obj2, err := handshake(q2, cdc, storeKey, version.DefaultPrefix(), connid2)
obj2, err := handshake(q2, cdc, storeKey, version.DefaultPrefix(), connId2)
if err != nil {
return err
}

// TODO: check state and if not Idle continue existing process
msginit := connection.MsgOpenInit{
ConnectionID: connid1,
msgInit := connection.MsgOpenInit{
ConnectionID: connId1,
Connection: conn1,
CounterpartyClient: conn2.Client,
Signer: ctx1.GetFromAddress(),
}

err = utils.GenerateOrBroadcastMsgs(ctx1, txBldr, []sdk.Msg{msginit})
err = utils.GenerateOrBroadcastMsgs(ctx1, txBldr, []sdk.Msg{msgInit})
if err != nil {
return err
}

// Another block has to be passed after msginit is committed
// Another block has to be passed after msgInit is committed
// to retrieve the correct proofs
// TODO: Modify this to actually check two blocks being processed, and
// remove hardcoding this to 8 seconds.
time.Sleep(8 * time.Second)

header, err := getHeader(ctx1)
if err != nil {
return err
}

msgupdate := client.MsgUpdateClient{
msgUpdate := client.MsgUpdateClient{
ClientID: conn2.Client,
Header: header,
Signer: ctx2.GetFromAddress(),
}

err = utils.GenerateOrBroadcastMsgs(ctx2, txBldr, []sdk.Msg{msgupdate})
err = utils.GenerateOrBroadcastMsgs(ctx2, txBldr, []sdk.Msg{msgUpdate})
if err != nil {
return err
}

fmt.Printf("updated apphash to %X\n", header.AppHash)

q1 = state.NewCLIQuerier(ctx1.WithHeight(header.Height - 1))
fmt.Printf("querying from %d\n", header.Height-1)

Expand All @@ -225,36 +219,38 @@ func GetCmdHandshake(storeKey string, cdc *codec.Codec) *cobra.Command {
return err
}

msgtry := connection.MsgOpenTry{
ConnectionID: connid2,
msgTry := connection.MsgOpenTry{
ConnectionID: connId2,
Connection: conn2,
CounterpartyClient: conn1.Client,
Proofs: []commitment.Proof{pconn, pstate, pcounter},
Height: uint64(header.Height),
Signer: ctx2.GetFromAddress(),
}

err = utils.GenerateOrBroadcastMsgs(ctx2, txBldr, []sdk.Msg{msgtry})
err = utils.GenerateOrBroadcastMsgs(ctx2, txBldr, []sdk.Msg{msgTry})
if err != nil {
return err
}

// Another block has to be passed after msginit is committed
// Another block has to be passed after msgInit is committed
// to retrieve the correct proofs
// TODO: Modify this to actually check two blocks being processed, and
// remove hardcoding this to 8 seconds.
time.Sleep(8 * time.Second)

header, err = getHeader(ctx2)
if err != nil {
return err
}

msgupdate = client.MsgUpdateClient{
msgUpdate = client.MsgUpdateClient{
ClientID: conn1.Client,
Header: header,
Signer: ctx1.GetFromAddress(),
}

err = utils.GenerateOrBroadcastMsgs(ctx1, txBldr, []sdk.Msg{msgupdate})
err = utils.GenerateOrBroadcastMsgs(ctx1, txBldr, []sdk.Msg{msgUpdate})
if err != nil {
return err
}
Expand All @@ -274,34 +270,36 @@ func GetCmdHandshake(storeKey string, cdc *codec.Codec) *cobra.Command {
return err
}

msgack := connection.MsgOpenAck{
ConnectionID: connid1,
msgAck := connection.MsgOpenAck{
ConnectionID: connId1,
Proofs: []commitment.Proof{pconn, pstate, pcounter},
Height: uint64(header.Height),
Signer: ctx1.GetFromAddress(),
}

err = utils.GenerateOrBroadcastMsgs(ctx1, txBldr, []sdk.Msg{msgack})
err = utils.GenerateOrBroadcastMsgs(ctx1, txBldr, []sdk.Msg{msgAck})
if err != nil {
return err
}

// Another block has to be passed after msginit is committed
// Another block has to be passed after msgInit is committed
// to retrieve the correct proofs
// TODO: Modify this to actually check two blocks being processed, and
// remove hardcoding this to 8 seconds.
time.Sleep(8 * time.Second)

header, err = getHeader(ctx1)
if err != nil {
return err
}

msgupdate = client.MsgUpdateClient{
msgUpdate = client.MsgUpdateClient{
ClientID: conn2.Client,
Header: header,
Signer: ctx2.GetFromAddress(),
}

err = utils.GenerateOrBroadcastMsgs(ctx2, txBldr, []sdk.Msg{msgupdate})
err = utils.GenerateOrBroadcastMsgs(ctx2, txBldr, []sdk.Msg{msgUpdate})
if err != nil {
return err
}
Expand All @@ -313,14 +311,14 @@ func GetCmdHandshake(storeKey string, cdc *codec.Codec) *cobra.Command {
return err
}

msgconfirm := connection.MsgOpenConfirm{
ConnectionID: connid2,
msgConfirm := connection.MsgOpenConfirm{
ConnectionID: connId2,
Proofs: []commitment.Proof{pstate},
Height: uint64(header.Height),
Signer: ctx2.GetFromAddress(),
}

err = utils.GenerateOrBroadcastMsgs(ctx2, txBldr, []sdk.Msg{msgconfirm})
err = utils.GenerateOrBroadcastMsgs(ctx2, txBldr, []sdk.Msg{msgConfirm})
if err != nil {
return err
}
Expand All @@ -329,6 +327,7 @@ func GetCmdHandshake(storeKey string, cdc *codec.Codec) *cobra.Command {
},
}

// TODO: Provide flag description
cmd.Flags().String(FlagNode1, "tcp://localhost:26657", "")
cmd.Flags().String(FlagNode2, "tcp://localhost:26657", "")
cmd.Flags().String(FlagFrom1, "", "")
Expand Down
4 changes: 4 additions & 0 deletions x/ibc/03-connection/handler.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import (
func HandleMsgOpenInit(ctx sdk.Context, msg MsgOpenInit, man Handshaker) sdk.Result {
_, err := man.OpenInit(ctx, msg.ConnectionID, msg.Connection, msg.CounterpartyClient)
if err != nil {
// TODO: Define the error code in errors
return sdk.NewError(sdk.CodespaceType("ibc"), 100, err.Error()).Result()
}
return sdk.Result{}
Expand All @@ -15,6 +16,7 @@ func HandleMsgOpenInit(ctx sdk.Context, msg MsgOpenInit, man Handshaker) sdk.Res
func HandleMsgOpenTry(ctx sdk.Context, msg MsgOpenTry, man Handshaker) sdk.Result {
_, err := man.OpenTry(ctx, msg.Proofs, msg.Height, msg.ConnectionID, msg.Connection, msg.CounterpartyClient)
if err != nil {
// TODO: Define the error code in errors
return sdk.NewError(sdk.CodespaceType("ibc"), 200, err.Error()).Result()
}
return sdk.Result{}
Expand All @@ -23,6 +25,7 @@ func HandleMsgOpenTry(ctx sdk.Context, msg MsgOpenTry, man Handshaker) sdk.Resul
func HandleMsgOpenAck(ctx sdk.Context, msg MsgOpenAck, man Handshaker) sdk.Result {
_, err := man.OpenAck(ctx, msg.Proofs, msg.Height, msg.ConnectionID)
if err != nil {
// TODO: Define the error code in errors
return sdk.NewError(sdk.CodespaceType("ibc"), 300, err.Error()).Result()
}
return sdk.Result{}
Expand All @@ -31,6 +34,7 @@ func HandleMsgOpenAck(ctx sdk.Context, msg MsgOpenAck, man Handshaker) sdk.Resul
func HandleMsgOpenConfirm(ctx sdk.Context, msg MsgOpenConfirm, man Handshaker) sdk.Result {
_, err := man.OpenConfirm(ctx, msg.Proofs, msg.Height, msg.ConnectionID)
if err != nil {
// TODO: Define the error code in errors
return sdk.NewError(sdk.CodespaceType("ibc"), 400, err.Error()).Result()
}
return sdk.Result{}
Expand Down
Loading