-
Notifications
You must be signed in to change notification settings - Fork 610
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 Rate Limit - integration and tests #2410
Changes from 224 commits
8fe23ab
0ed673a
e61ab68
187b49c
d53529e
b6947a0
38cfe4d
773ea2b
7c23a31
2c7dd18
a4b8dc2
cd950ce
8069131
bef2500
ef44407
2b2ba93
19d9c94
574b109
c423f12
2791d6a
d45a830
64a5ef0
875214b
23ad652
c1d52d9
3cbcafe
6d79e71
225dfcf
863abef
76c0678
c52c96e
de5e919
5aa644e
8309b95
6432034
9ffdc37
80b8008
de08caf
bebec8b
2d1cacb
0fd7e64
2733060
d040f84
ef47f16
fb072ed
010628c
c604c0d
b9ffbab
1ec6b8e
73607f7
241aa9e
66a55b0
73535d4
8f8b7d2
e007ca6
b16fa70
c171bb8
8ca29e7
66c3346
3a37701
8c97907
6a331dd
5ef145e
0a2656c
2fd6e04
49ad2cd
7105550
17c05af
a6cf294
4855c0f
3d8aa96
318cf57
15cbcec
3357e94
9f605fc
70a11b4
2daf2ba
be0fa76
04a2a7a
26fc15b
2723f07
a9dd5bf
94f079b
a7e7d75
8917e77
61bc4fe
67b1477
11c5765
1f237e8
d9dd5b3
bf41b6f
8b6390b
1faa8c5
a8a9b88
12accb3
aee867f
2758919
f726d2c
506453a
2fa15b8
4b66483
8128b0c
73acb2f
5b66bdc
2e4a6ab
4af7fe9
48b19cb
0dd7fc9
6180eb8
82c83b1
92b4bb3
d4ace7b
746daa9
fe97ee8
c6758f1
e1d52f4
7434a44
727fef2
7859a55
628db47
9facb27
042f3f4
c37a968
e5d72d6
d658fdd
c2a72ad
0b738c9
71d8aca
8135a90
2151825
a800e9b
ae15972
f8b972a
e15c77c
63b23f0
7aa90e3
fcec5b9
7acacb3
4268c79
80617e8
0529667
294e19a
6c49460
3028b38
f332e23
5bdccfc
b9408e6
6916ffa
216bcee
f1cdb16
314455e
0aed029
54056fa
cd74eaa
a69b58f
e8e9012
381e5e2
fa8cafe
cc91a76
bbcc8af
d4e10bd
45ca648
c425518
fde1440
79843a1
fd54ed3
298636d
5561530
6e47abc
deaacfd
c676404
7544235
98b720d
a7f5bc4
89cf19f
10424b4
4b23e98
443fff3
76c9cc9
d46b51c
af4d9a7
2751bee
b682542
fa12ff0
25a7767
219118c
803d26e
f474ee4
a3f82e9
ddfcac0
3018357
42b354d
3350c57
a183a0e
2825e21
ca5fecf
20b40de
3f98ebe
463f1cc
eb6471b
f2ba12f
4b68e46
1506c3f
33ad060
30fb80b
acf1f50
4541b87
f9ee22d
d9df73c
e681a7d
9e14d15
11a4957
4fc7abb
d2daad6
24a3e2e
2095003
65f0485
9240011
0ca235b
71d60b8
69b4954
21e7f51
a78c757
93413be
29f61fd
7b79685
08a1cd8
27ee3ee
8c36532
d125dbd
cc42cab
41b3cae
0ad0a90
7b50cb4
40f8cc6
e7798a1
88b1c4a
032f33b
f107877
237f144
caad1f2
13f2621
79109a2
60811cf
c50cf10
952a2e6
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,6 +2,7 @@ package keepers | |
|
||
import ( | ||
"github.com/CosmWasm/wasmd/x/wasm" | ||
wasmkeeper "github.com/CosmWasm/wasmd/x/wasm/keeper" | ||
"github.com/cosmos/cosmos-sdk/baseapp" | ||
"github.com/cosmos/cosmos-sdk/codec" | ||
sdk "github.com/cosmos/cosmos-sdk/types" | ||
|
@@ -32,6 +33,8 @@ import ( | |
"github.com/cosmos/cosmos-sdk/x/upgrade" | ||
upgradekeeper "github.com/cosmos/cosmos-sdk/x/upgrade/keeper" | ||
upgradetypes "github.com/cosmos/cosmos-sdk/x/upgrade/types" | ||
ibcratelimit "github.com/osmosis-labs/osmosis/v12/x/ibc-rate-limit" | ||
ibcratelimittypes "github.com/osmosis-labs/osmosis/v12/x/ibc-rate-limit/types" | ||
|
||
icahost "github.com/cosmos/ibc-go/v3/modules/apps/27-interchain-accounts/host" | ||
icahostkeeper "github.com/cosmos/ibc-go/v3/modules/apps/27-interchain-accounts/host/keeper" | ||
|
@@ -110,10 +113,13 @@ type AppKeepers struct { | |
SuperfluidKeeper *superfluidkeeper.Keeper | ||
GovKeeper *govkeeper.Keeper | ||
WasmKeeper *wasm.Keeper | ||
ContractKeeper *wasmkeeper.PermissionedKeeper | ||
TokenFactoryKeeper *tokenfactorykeeper.Keeper | ||
|
||
// IBC modules | ||
// transfer module | ||
TransferModule transfer.AppModule | ||
TransferModule transfer.AppModule | ||
RateLimitingICS4Wrapper *ibcratelimit.ICS4Wrapper | ||
|
||
// keys to access the substores | ||
keys map[string]*sdk.KVStoreKey | ||
|
@@ -195,12 +201,24 @@ func (appKeepers *AppKeepers) InitNormalKeepers( | |
appKeepers.ScopedIBCKeeper, | ||
) | ||
|
||
// ChannelKeeper wrapper for rate limiting SendPacket(). The wasmKeeper needs to be added after it's created | ||
rateLimitingParams := appKeepers.GetSubspace(ibcratelimittypes.ModuleName) | ||
rateLimitingParams = rateLimitingParams.WithKeyTable(ibcratelimittypes.ParamKeyTable()) | ||
rateLimitingICS4Wrapper := ibcratelimit.NewICS4Middleware( | ||
appKeepers.IBCKeeper.ChannelKeeper, | ||
appKeepers.AccountKeeper, | ||
nil, | ||
appKeepers.BankKeeper, | ||
rateLimitingParams, | ||
) | ||
appKeepers.RateLimitingICS4Wrapper = &rateLimitingICS4Wrapper | ||
|
||
// Create Transfer Keepers | ||
transferKeeper := ibctransferkeeper.NewKeeper( | ||
appCodec, | ||
appKeepers.keys[ibctransfertypes.StoreKey], | ||
appKeepers.GetSubspace(ibctransfertypes.ModuleName), | ||
appKeepers.IBCKeeper.ChannelKeeper, | ||
appKeepers.RateLimitingICS4Wrapper, // The ICS4Wrapper is replaced by the rateLimitingICS4Wrapper instead of the channel | ||
appKeepers.IBCKeeper.ChannelKeeper, | ||
&appKeepers.IBCKeeper.PortKeeper, | ||
appKeepers.AccountKeeper, | ||
|
@@ -211,6 +229,9 @@ func (appKeepers *AppKeepers) InitNormalKeepers( | |
appKeepers.TransferModule = transfer.NewAppModule(*appKeepers.TransferKeeper) | ||
transferIBCModule := transfer.NewIBCModule(*appKeepers.TransferKeeper) | ||
|
||
// RateLimiting IBC Middleware | ||
rateLimitingTransferModule := ibcratelimit.NewIBCModule(transferIBCModule, appKeepers.RateLimitingICS4Wrapper) | ||
|
||
icaHostKeeper := icahostkeeper.NewKeeper( | ||
appCodec, appKeepers.keys[icahosttypes.StoreKey], | ||
appKeepers.GetSubspace(icahosttypes.SubModuleName), | ||
|
@@ -226,7 +247,7 @@ func (appKeepers *AppKeepers) InitNormalKeepers( | |
// Create static IBC router, add transfer route, then set and seal it | ||
ibcRouter := porttypes.NewRouter() | ||
ibcRouter.AddRoute(icahosttypes.SubModuleName, icaHostIBCModule). | ||
AddRoute(ibctransfertypes.ModuleName, transferIBCModule) | ||
AddRoute(ibctransfertypes.ModuleName, &rateLimitingTransferModule) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm confused about this wiring. We make our middleware the transfer module, but we pass the middleware into the transfer keeper as well? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. yeah, this is confusing, but that's how you wire up the middlewares. What we pass into the keeper is not the middleware, but the ICS4Wrapper which would be the middleware's keeper if we had one (Notice that the transfer keeper has two params that originally pointed to the channel: ics4Wrapper and channelKeeper; we override the first one) So the ibc module's methods (the OnSomething methods) all go to the part implementing the IBCModule interface, but the ICS4 methods (SendPacket and WriteAck) go to the ICS4Wrapper (which ends up in the channel). This is because things go in one direction on send and the other on receive. So we get: SendPacket -> Transfer -> RateLimit -> channel OnRecv -> RateLimit -> transfer -> channel But I'll double check this to make sure I'm wrapping it correctly There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. hrmm, I somewhat think I get it? So middleware from IBC is currently insufficient to do everything we need, since we want rate limit code before other code in the receive code path? (Not sure why it couldn't be in transfer first though, since as long as we error anywhere, it should get atomically reverted) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. No, this is not a workaround to get our use case to work; this is unfortunately the way the middleware wiring us designed to be used. The transfer IBCModule doesn't implement SendPacket or WriteAcknowledgement, as it only implements porttypes.IBCModule and not porttypes.ICS4Wrapper (definitions). It instead relies on the transfer module's keeper to have an ICS4Wrapper that is initialized to either the channelKeeper (which implements ICS4Wrapper) or the ICS4Wrapper implementation of the middleware. The middleware interface from IBC requires users to implement both porttypes.IBCModule and porttypes.ICS4Wrapper, but the later can't really wrap SendPacket or WriteAcknowledgement because they don't exist in the transfer ibc module. I think the reason for designing it this way is so that a middleware would behave the same way as if it was a function wrapping another: what originates from the outside (other chain) must flow inwards and what originates in the last function called (our chain) must flow outwards. It's probably easier if I go over the code in a call though, so let me know so we can screenshare |
||
// Note: the sealing is done after creating wasmd and wiring that up | ||
|
||
// create evidence keeper with router | ||
|
@@ -347,6 +368,9 @@ func (appKeepers *AppKeepers) InitNormalKeepers( | |
wasmOpts..., | ||
) | ||
appKeepers.WasmKeeper = &wasmKeeper | ||
// Update the ICS4Wrapper with the proper contractKeeper | ||
appKeepers.ContractKeeper = wasmkeeper.NewDefaultPermissionKeeper(appKeepers.WasmKeeper) | ||
appKeepers.RateLimitingICS4Wrapper.ContractKeeper = appKeepers.ContractKeeper | ||
|
||
// wire up x/wasm to IBC | ||
ibcRouter.AddRoute(wasm.ModuleName, wasm.NewIBCHandler(appKeepers.WasmKeeper, appKeepers.IBCKeeper.ChannelKeeper)) | ||
|
@@ -440,6 +464,7 @@ func (appKeepers *AppKeepers) initParamsKeeper(appCodec codec.BinaryCodec, legac | |
paramsKeeper.Subspace(wasm.ModuleName) | ||
paramsKeeper.Subspace(tokenfactorytypes.ModuleName) | ||
paramsKeeper.Subspace(twaptypes.ModuleName) | ||
paramsKeeper.Subspace(ibcratelimittypes.ModuleName) | ||
|
||
return paramsKeeper | ||
} | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we remove this is a field, and just make the function return
MakeEncodingConfig().TxConfig
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
done!