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 Rate Limit - integration and tests #2410

Closed
wants to merge 246 commits into from
Closed
Show file tree
Hide file tree
Changes from 224 commits
Commits
Show all changes
246 commits
Select commit Hold shift + click to select a range
8fe23ab
added initial rate limiting contract
nicolaslara Aug 3, 2022
0ed673a
added expiration
nicolaslara Aug 3, 2022
e61ab68
fixed integration test
nicolaslara Aug 3, 2022
187b49c
added initial middleware
nicolaslara Aug 4, 2022
d53529e
simple test to debug weirdness in ibctesting
nicolaslara Aug 4, 2022
b6947a0
using helpers
nicolaslara Aug 4, 2022
38cfe4d
Merge branch 'main' into ibc-rate-limit-weird-tests
nicolaslara Aug 4, 2022
773ea2b
testing with test changes from PR##2274
nicolaslara Aug 4, 2022
7c23a31
fixed tests and updated requirement to match cosmos-sdk fork branch w…
nicolaslara Aug 4, 2022
2c7dd18
updated to latest commit
nicolaslara Aug 4, 2022
a4b8dc2
using branch of the sdk fork that allows for ibc tests
nicolaslara Aug 4, 2022
cd950ce
Merge branch 'ibc-rate-limit-weird-tests' into ibc-rate-limit
nicolaslara Aug 4, 2022
8069131
Merge branch 'main' into supply-offset-changes-on-sdk-fork
nicolaslara Aug 5, 2022
bef2500
using the latest sdk fork changes with a new constructor
nicolaslara Aug 5, 2022
ef44407
Merge branch 'supply-offset-changes-on-sdk-fork' into ibc-rate-limit
nicolaslara Aug 5, 2022
2b2ba93
initial ibctest setup
nicolaslara Aug 5, 2022
19d9c94
propperly sending the package for testing
nicolaslara Aug 5, 2022
574b109
Initialize app before tests and add default genesis state
nicolaslara Aug 6, 2022
c423f12
initial middleware with working testing framework
nicolaslara Aug 6, 2022
2791d6a
improved testing framework
nicolaslara Aug 8, 2022
d45a830
can test both send and recv for success and failure
nicolaslara Aug 8, 2022
64a5ef0
cleanner testing framework
nicolaslara Aug 8, 2022
875214b
added contract instantiation
nicolaslara Aug 8, 2022
23ad652
working wasm integration
nicolaslara Aug 8, 2022
c1d52d9
added params for contract config
nicolaslara Aug 9, 2022
3cbcafe
extracted param registration
nicolaslara Aug 9, 2022
6d79e71
active rate limiting
nicolaslara Aug 9, 2022
225dfcf
calculating channel value
nicolaslara Aug 9, 2022
863abef
cleaner tests
nicolaslara Aug 9, 2022
76c0678
fix issue with epochs
nicolaslara Aug 9, 2022
c52c96e
fixed tests
nicolaslara Aug 9, 2022
de5e919
testing rate limit reset
nicolaslara Aug 10, 2022
5aa644e
linting
nicolaslara Aug 10, 2022
8309b95
added receive middleware
nicolaslara Aug 10, 2022
6432034
added test for non-configured channel
nicolaslara Aug 10, 2022
9ffdc37
make format
nicolaslara Aug 10, 2022
80b8008
Revert "make format"
nicolaslara Aug 10, 2022
de08caf
only applying format to ibc-rate-limit
nicolaslara Aug 10, 2022
bebec8b
applying fmt to app.go
nicolaslara Aug 10, 2022
2d1cacb
added gov_module and changed no-quota default to "allow all"
nicolaslara Aug 10, 2022
0fd7e64
added asymetric quotas
nicolaslara Aug 10, 2022
2733060
moved getters to modules.go
nicolaslara Aug 10, 2022
d040f84
Merge branch 'main' into ibc-rate-limit
nicolaslara Aug 10, 2022
ef47f16
initial work to support multiple quotas
nicolaslara Aug 11, 2022
fb072ed
added multiple quotas
nicolaslara Aug 11, 2022
010628c
small fixes
nicolaslara Aug 11, 2022
c604c0d
reordered imports
nicolaslara Aug 11, 2022
b9ffbab
added management messages
nicolaslara Aug 11, 2022
1ec6b8e
reorganized management messages and experimenting with e2e testing
nicolaslara Aug 12, 2022
73607f7
commenting out test configuration test for now
nicolaslara Aug 12, 2022
241aa9e
added query
nicolaslara Aug 12, 2022
66a55b0
added flow unit test
nicolaslara Aug 12, 2022
73535d4
cleanup
nicolaslara Aug 12, 2022
8f8b7d2
added AddChannel tests
nicolaslara Aug 12, 2022
e007ca6
format
nicolaslara Aug 12, 2022
b16fa70
test values are properly stored
nicolaslara Aug 12, 2022
c171bb8
testing remove channel
nicolaslara Aug 12, 2022
8ca29e7
some more rate limiting tests
nicolaslara Aug 12, 2022
66c3346
moved tests about test setup to the right place
nicolaslara Aug 15, 2022
3a37701
fixed params
nicolaslara Aug 15, 2022
8c97907
Merge branch 'main' into ibc-rate-limit
nicolaslara Aug 15, 2022
6a331dd
merged main
nicolaslara Aug 15, 2022
5ef145e
running gofumpt
nicolaslara Aug 15, 2022
0a2656c
added ibc-rate-limiting contract
nicolaslara Aug 15, 2022
2fd6e04
added ibc-rate-limit middleware
nicolaslara Aug 15, 2022
49ad2cd
Merge branch 'nicolas/ibc-rate-limit-middlware' into nicolas/ibc-rate…
nicolaslara Aug 15, 2022
7105550
added chain integration and tests
nicolaslara Aug 15, 2022
17c05af
reverted change to match merged branch in main (#2341 instead of #2274)
nicolaslara Aug 15, 2022
a6cf294
added cosmwasm workflow
nicolaslara Aug 15, 2022
4855c0f
Merge branch 'nicolas/ibc-rate-limit-contract' into nicolas/ibc-rate-…
nicolaslara Aug 15, 2022
3d8aa96
added a migrate message
nicolaslara Aug 16, 2022
318cf57
added some doc comments to the state
nicolaslara Aug 16, 2022
15cbcec
added doc comments
nicolaslara Aug 16, 2022
3357e94
fixed dependency after merging https://github.com/osmosis-labs/cosmos…
nicolaslara Aug 16, 2022
9f605fc
added migration msg
nicolaslara Aug 16, 2022
70a11b4
added workflow
nicolaslara Aug 17, 2022
2daf2ba
experimenting with better workflow
nicolaslara Aug 17, 2022
be0fa76
added missing $
nicolaslara Aug 17, 2022
04a2a7a
using env
nicolaslara Aug 17, 2022
26fc15b
Update x/ibc-rate-limit/contracts/rate-limiter/src/msg.rs
nicolaslara Aug 17, 2022
2723f07
using stable for clippy
nicolaslara Aug 17, 2022
a9dd5bf
removed gitkeep
nicolaslara Aug 17, 2022
94f079b
Merge branch 'nicolas/ibc-rate-limit-contract' into ibc-rate-limit
nicolaslara Aug 17, 2022
a7e7d75
using the minimal profile for clippy
nicolaslara Aug 17, 2022
8917e77
experimenting with cache
nicolaslara Aug 17, 2022
61bc4fe
removed target from lints
nicolaslara Aug 17, 2022
67b1477
cleaner matrix?
nicolaslara Aug 17, 2022
11c5765
COmments & questions
ValarDragon Aug 17, 2022
1f237e8
Merge branch 'nicolas/ibc-rate-limit-contract' of github.com:osmosis-…
ValarDragon Aug 17, 2022
d9dd5b3
debugging
nicolaslara Aug 17, 2022
bf41b6f
more debugging
nicolaslara Aug 17, 2022
8b6390b
debug faster
nicolaslara Aug 17, 2022
1faa8c5
quick cache debug
nicolaslara Aug 17, 2022
a8a9b88
typo
nicolaslara Aug 17, 2022
12accb3
quick workflow check
nicolaslara Aug 17, 2022
aee867f
working tests with optimization
nicolaslara Aug 17, 2022
2758919
testing artifacts
nicolaslara Aug 17, 2022
f726d2c
split the wasm target into its own step
nicolaslara Aug 17, 2022
506453a
artifacts without slash
nicolaslara Aug 17, 2022
2fa15b8
full working tests
nicolaslara Aug 17, 2022
4b66483
clippy fixes
nicolaslara Aug 17, 2022
8128b0c
Merge branch 'nicolas/ibc-rate-limit-contract' into ibc-rate-limit
nicolaslara Aug 17, 2022
73acb2f
workflow without test data checks and clippy fixes
nicolaslara Aug 17, 2022
5b66bdc
renamed CHANNEL_FLOWS
nicolaslara Aug 17, 2022
2e4a6ab
renaming and code clenaup
nicolaslara Aug 17, 2022
4af7fe9
more renames
nicolaslara Aug 17, 2022
48b19cb
renames and code fixes
nicolaslara Aug 17, 2022
0dd7fc9
Merge branch 'nicolas/ibc-rate-limit-contract' into ibc-rate-limit
nicolaslara Aug 17, 2022
6180eb8
reordered imports
nicolaslara Aug 17, 2022
82c83b1
cargo fmt
nicolaslara Aug 17, 2022
92b4bb3
Merge branch 'nicolas/ibc-rate-limit-contract' into ibc-rate-limit
nicolaslara Aug 17, 2022
d4ace7b
added danom tracking
nicolaslara Aug 17, 2022
746daa9
cleanup
nicolaslara Aug 17, 2022
fe97ee8
refactoring
nicolaslara Aug 18, 2022
c6758f1
changes to the expiration logic so that balances are calculated based…
nicolaslara Aug 18, 2022
e1d52f4
slightly slower but considerably cleanner
nicolaslara Aug 18, 2022
7434a44
cleanup attributes and removed redundancy when not testing
nicolaslara Aug 18, 2022
727fef2
update to edition 2021
nicolaslara Aug 18, 2022
7859a55
added comments explaining the tests
nicolaslara Aug 18, 2022
628db47
removed .beaker
nicolaslara Aug 18, 2022
9facb27
unified gitignore
nicolaslara Aug 18, 2022
042f3f4
removed second gitignore
nicolaslara Aug 18, 2022
c37a968
better doc comments
nicolaslara Aug 18, 2022
e5d72d6
spelling
nicolaslara Aug 18, 2022
d658fdd
spelling
nicolaslara Aug 18, 2022
c2a72ad
added channel value cache
nicolaslara Aug 18, 2022
0b738c9
Merge branch 'nicolas/ibc-rate-limit-contract' into ibc-rate-limit
nicolaslara Aug 19, 2022
71d8aca
updated the middlware to use the new contract interface
nicolaslara Aug 19, 2022
8135a90
update middleware to match new contract interface
nicolaslara Aug 19, 2022
2151825
added missing updates
nicolaslara Aug 19, 2022
a800e9b
updated dependencies
nicolaslara Aug 19, 2022
ae15972
added missing helpers
nicolaslara Aug 19, 2022
f8b972a
go.mod changes shouldn't be in this branch
nicolaslara Aug 19, 2022
e15c77c
Revert "go.mod changes shouldn't be in this branch"
nicolaslara Aug 19, 2022
63b23f0
moved send and receive to sudo
nicolaslara Aug 22, 2022
7aa90e3
reorganizing
nicolaslara Aug 22, 2022
fcec5b9
calling the contract via sudo
nicolaslara Aug 22, 2022
7acacb3
lint
nicolaslara Aug 22, 2022
4268c79
removed gitkeep
nicolaslara Aug 22, 2022
80617e8
using sudo instead of execute
nicolaslara Aug 22, 2022
0529667
cleaned up and updated contract and integration
nicolaslara Aug 22, 2022
294e19a
updated x86 test wasm file
nicolaslara Aug 22, 2022
6c49460
fixed bad print
nicolaslara Aug 23, 2022
3028b38
storing and instantiating the contract
nicolaslara Aug 23, 2022
f332e23
setting up E2E tests for ibc rate limits
nicolaslara Aug 24, 2022
5bdccfc
fixed proposal. Now just have to get the math right and cleanup
nicolaslara Aug 24, 2022
b9408e6
Using the supply for the channel value
nicolaslara Aug 25, 2022
6916ffa
experimenting with e2e tests
nicolaslara Aug 25, 2022
216bcee
passing the contract keeper instead of instantiating it each time
nicolaslara Aug 25, 2022
f1cdb16
changes from code review
nicolaslara Aug 25, 2022
314455e
added contract from main and changes to the middleware from code review
nicolaslara Aug 25, 2022
0aed029
using the correct bank supply method
nicolaslara Aug 26, 2022
54056fa
debugging issues with e2e tests. Everything works after one interacti…
nicolaslara Aug 26, 2022
cd74eaa
Merge branch 'main' into nicolas/merged-supply-offset-dependency
nicolaslara Aug 26, 2022
a69b58f
updated dependency to match latest sdk form (now that the changes to …
nicolaslara Aug 26, 2022
e8e9012
working E2E test for rate limiting
nicolaslara Aug 26, 2022
381e5e2
added e2e tests and changes from code review
nicolaslara Aug 26, 2022
fa8cafe
removed debug logs
nicolaslara Aug 26, 2022
cc91a76
remove debug logs
nicolaslara Aug 26, 2022
bbcc8af
Merge branch 'main' into nicolas/ibc-rate-limit-middlware
nicolaslara Aug 26, 2022
d4e10bd
Merge branch 'ibc-rate-limit' into nicolas/ibc-rate-limit-integration…
nicolaslara Aug 26, 2022
45ca648
Merge branch 'main' into nicolas/ibc-rate-limit-integration-and-tests
nicolaslara Aug 26, 2022
c425518
Merge branch 'nicolas/merged-supply-offset-dependency' into nicolas/i…
nicolaslara Aug 26, 2022
fde1440
Merge branch 'nicolas/merged-supply-offset-dependency' into nicolas/i…
nicolaslara Aug 26, 2022
79843a1
Merge branch 'nicolas/merged-supply-offset-dependency' into ibc-rate-…
nicolaslara Aug 26, 2022
fd54ed3
updated test to also use GetSupplyWithOffset
nicolaslara Aug 26, 2022
298636d
using correct GetSupplyWithOffset method
nicolaslara Aug 26, 2022
5561530
using correct GetSupplyWithOffset method
nicolaslara Aug 26, 2022
6e47abc
lint
nicolaslara Aug 26, 2022
deaacfd
Merge branch 'ibc-rate-limit' into nicolas/ibc-rate-limit-integration…
nicolaslara Aug 26, 2022
c676404
removed e2e from this branch as it's not doing anything without the i…
nicolaslara Aug 26, 2022
7544235
lint
nicolaslara Aug 26, 2022
98b720d
Merge branch 'ibc-rate-limit' into nicolas/ibc-rate-limit-integration…
nicolaslara Aug 26, 2022
a7f5bc4
tests fail on CI because of "inactive" proposal. Is the deposit the i…
nicolaslara Aug 26, 2022
89cf19f
remove rate limiting after the test so it doesn't interfeer with the …
nicolaslara Aug 26, 2022
10424b4
using standard proposals instead of expedited
nicolaslara Aug 26, 2022
4b23e98
Merge branch 'ibc-rate-limit' into nicolas/ibc-rate-limit-integration…
nicolaslara Aug 26, 2022
443fff3
added packet reverts on unsuccessful acks and timeouts
nicolaslara Aug 29, 2022
76c9cc9
lint
nicolaslara Aug 29, 2022
d46b51c
ran gofumpt
nicolaslara Aug 29, 2022
af4d9a7
lint
nicolaslara Aug 29, 2022
2751bee
added undo to the contract
nicolaslara Aug 30, 2022
b682542
integrating undo
nicolaslara Aug 30, 2022
fa12ff0
updated contract with x86 wasm file
nicolaslara Aug 30, 2022
25a7767
added undo for sent packages when they are rejected bia timeout or a …
nicolaslara Aug 30, 2022
219118c
added a readme
nicolaslara Aug 30, 2022
803d26e
markdown lint
nicolaslara Aug 30, 2022
f474ee4
added readme
nicolaslara Aug 30, 2022
a3f82e9
abstracted params
nicolaslara Aug 30, 2022
ddfcac0
better params and param tests
nicolaslara Aug 31, 2022
3018357
using a helper function instead of returning from the test
nicolaslara Aug 31, 2022
42b354d
updated contract to allow for undo
nicolaslara Aug 31, 2022
3350c57
added undo, readme, and cleanup based on reviews
nicolaslara Aug 31, 2022
a183a0e
Merge branch 'main' into ibc-rate-limit
nicolaslara Aug 31, 2022
2825e21
updated wasm file with x86 version
nicolaslara Aug 31, 2022
ca5fecf
using string params in e2e tests
nicolaslara Aug 31, 2022
20b40de
Merge branch 'main' into nicolas/ibc-rate-limit-middlware
nicolaslara Aug 31, 2022
3f98ebe
Merge branch 'main' into ibc-rate-limit
nicolaslara Sep 7, 2022
463f1cc
updated to v12
nicolaslara Sep 7, 2022
eb6471b
removed unnecessary keeper
nicolaslara Sep 7, 2022
f2ba12f
only exposing what's needed
nicolaslara Sep 7, 2022
4b68e46
refactoring
nicolaslara Sep 7, 2022
1506c3f
updated types
nicolaslara Sep 7, 2022
33ad060
added shell history to gitignore
nicolaslara Sep 7, 2022
30fb80b
adding only one wasm file to the codebase
nicolaslara Sep 7, 2022
acf1f50
remove test for same wasm files. No longer needed.
nicolaslara Sep 7, 2022
4541b87
Merge branch 'main' into nicolas/ibc-rate-limit-middlware
nicolaslara Sep 7, 2022
f9ee22d
refactor based on code review
nicolaslara Sep 7, 2022
d9df73c
removed integration tests as they won't pass without integration
nicolaslara Sep 7, 2022
e681a7d
added params unit test
nicolaslara Sep 7, 2022
9e14d15
Merge branch 'main' into nicolas/ibc-rate-limit-integration-and-tests
nicolaslara Sep 7, 2022
11a4957
Merge branch 'nicolas/ibc-rate-limit-middlware' into nicolas/ibc-rate…
nicolaslara Sep 7, 2022
4fc7abb
reorganized tests
nicolaslara Sep 7, 2022
d2daad6
reorganizing tests
nicolaslara Sep 7, 2022
24a3e2e
refactoring
nicolaslara Sep 7, 2022
2095003
Merge branch 'main' into ibc-rate-limit
nicolaslara Sep 8, 2022
65f0485
Merge branch 'ibc-rate-limit' into nicolas/ibc-rate-limit-integration…
nicolaslara Sep 8, 2022
9240011
added address length limit
nicolaslara Sep 9, 2022
0ca235b
Merge branch 'nicolas/ibc-receiver-field-cap' into ibc-rate-limit
nicolaslara Sep 9, 2022
71d60b8
Merge branch 'main' into nicolas/ibc-rate-limit-integration-and-tests
nicolaslara Sep 9, 2022
69b4954
added tests and fixed lack of return
nicolaslara Sep 9, 2022
21e7f51
Merge branch 'ibc-rate-limit' into nicolas/ibc-rate-limit-integration…
nicolaslara Sep 9, 2022
a78c757
remove tests from bad merge
nicolaslara Sep 9, 2022
93413be
remove from bad merge again
nicolaslara Sep 9, 2022
29f61fd
Merge branch 'main' into nicolas/ibc-rate-limit-integration-and-tests
nicolaslara Oct 4, 2022
7b79685
comment
nicolaslara Oct 4, 2022
08a1cd8
test helpers for cosmwasm contracts
nicolaslara Oct 4, 2022
27ee3ee
added helpers for ibctesting
nicolaslara Oct 4, 2022
8c36532
comments
nicolaslara Oct 4, 2022
d125dbd
Merge branch 'nicolas/test-helpers' into nicolas/ibc-rate-limit-integ…
nicolaslara Oct 4, 2022
cc42cab
removed unnecessary txConfig
nicolaslara Oct 4, 2022
41b3cae
fixed typos
nicolaslara Oct 4, 2022
0ad0a90
clearer comment
nicolaslara Oct 4, 2022
7b50cb4
using second helper function for ExportGenesis
nicolaslara Oct 4, 2022
40f8cc6
Merge branch 'nicolas/export_for_modules' into nicolas/ibc-rate-limit…
nicolaslara Oct 5, 2022
e7798a1
added new wasm file
nicolaslara Oct 5, 2022
88b1c4a
Merge branch 'main' into nicolas/ibc-rate-limit-integration-and-tests
nicolaslara Oct 5, 2022
032f33b
Fixed send with ibc assets. Better tests and error messages
nicolaslara Oct 21, 2022
f107877
updated contract with x86 version
nicolaslara Oct 21, 2022
237f144
gofumpt
nicolaslara Oct 21, 2022
caad1f2
fixed clippy errors
nicolaslara Oct 21, 2022
13f2621
using the escrowed value as the channel value for native tokens
nicolaslara Oct 22, 2022
79109a2
gofumpt
nicolaslara Oct 22, 2022
60811cf
update fail string
nicolaslara Oct 23, 2022
c50cf10
Merge branch 'main' into nicolas/ibc-rate-limit-integration-and-tests
nicolaslara Oct 23, 2022
952a2e6
Merge branch 'main' into nicolas/ibc-rate-limit-integration-and-tests
ValarDragon Oct 29, 2022
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
10 changes: 5 additions & 5 deletions .github/workflows/contracts.yml
Original file line number Diff line number Diff line change
Expand Up @@ -82,11 +82,11 @@ jobs:
path: ${{ matrix.contract.workdir }}${{ matrix.contract.build }}
retention-days: 1

# - name: Check Test Data
# working-directory: ${{ matrix.contract.workdir }}
# if: ${{ matrix.contract.output != null }}
# run: >
# diff ${{ matrix.contract.output }} ${{ matrix.contract.build }}
- name: Check Test Data
working-directory: ${{ matrix.contract.workdir }}
if: ${{ matrix.contract.output != null }}
run: >
diff ${{ matrix.contract.output }} ${{ matrix.contract.build }}


lints:
Expand Down
4 changes: 4 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -230,3 +230,7 @@ Cargo.lock
.beaker
blocks.db
**/blocks.db*

# Ignore e2e test artifacts (which clould leak information if commited)
.ash_history
.bash_history
2 changes: 2 additions & 0 deletions app/app.go
Original file line number Diff line number Diff line change
Expand Up @@ -130,6 +130,7 @@ type OsmosisApp struct {
mm *module.Manager
sm *simtypes.Manager
configurator module.Configurator
txConfig client.TxConfig
Copy link
Member

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

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done!

}

// init sets DefaultNodeHome to default osmosisd install location.
Expand Down Expand Up @@ -173,6 +174,7 @@ func NewOsmosisApp(
appCodec: appCodec,
interfaceRegistry: interfaceRegistry,
invCheckPeriod: invCheckPeriod,
txConfig: encodingConfig.TxConfig,
}

wasmDir := filepath.Join(homePath, "wasm")
Expand Down
31 changes: 28 additions & 3 deletions app/keepers/keepers.go
Original file line number Diff line number Diff line change
Expand Up @@ -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"
Expand Down Expand Up @@ -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"
Expand Down Expand Up @@ -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
Expand Down Expand Up @@ -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,
Expand All @@ -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),
Expand All @@ -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)
Copy link
Member

Choose a reason for hiding this comment

The 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?

Copy link
Contributor Author

Choose a reason for hiding this comment

The 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

Copy link
Member

Choose a reason for hiding this comment

The 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)

Copy link
Contributor Author

Choose a reason for hiding this comment

The 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
Expand Down Expand Up @@ -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))
Expand Down Expand Up @@ -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
}
Expand Down
21 changes: 21 additions & 0 deletions app/modules.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,13 @@ package app

import (
"github.com/CosmWasm/wasmd/x/wasm"
"github.com/cosmos/cosmos-sdk/client"
capabilitykeeper "github.com/cosmos/cosmos-sdk/x/capability/keeper"
stakingkeeper "github.com/cosmos/cosmos-sdk/x/staking/keeper"
ibctransfertypes "github.com/cosmos/ibc-go/v3/modules/apps/transfer/types"
ibc "github.com/cosmos/ibc-go/v3/modules/core"
ibchost "github.com/cosmos/ibc-go/v3/modules/core/24-host"
ibckeeper "github.com/cosmos/ibc-go/v3/modules/core/keeper"

ica "github.com/cosmos/ibc-go/v3/modules/apps/27-interchain-accounts"
icatypes "github.com/cosmos/ibc-go/v3/modules/apps/27-interchain-accounts/types"
Expand Down Expand Up @@ -245,3 +249,20 @@ func (app *OsmosisApp) GetAccountKeeper() simtypes.AccountKeeper {
func (app *OsmosisApp) GetBankKeeper() simtypes.BankKeeper {
return app.AppKeepers.BankKeeper
}

// Required for ibctesting
func (app *OsmosisApp) GetStakingKeeper() stakingkeeper.Keeper {
return *app.AppKeepers.StakingKeeper
}

func (app *OsmosisApp) GetIBCKeeper() *ibckeeper.Keeper {
return app.AppKeepers.IBCKeeper
}

func (app *OsmosisApp) GetScopedIBCKeeper() capabilitykeeper.ScopedKeeper {
return app.AppKeepers.ScopedIBCKeeper
}

func (app *OsmosisApp) GetTxConfig() client.TxConfig {
return app.txConfig
}
4 changes: 3 additions & 1 deletion tests/e2e/configurer/chain/chain.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,8 @@ type Config struct {
LatestLockNumber int
NodeConfigs []*NodeConfig

LatestCodeId int

t *testing.T
containerManager *containers.Manager
}
Expand Down Expand Up @@ -126,7 +128,7 @@ func (c *Config) SendIBC(dstChain *Config, recipient string, token sdk.Coin) {
if ibcCoin.Len() == 1 {
tokenPre := balancesDstPre.AmountOfNoDenomValidation(ibcCoin[0].Denom)
tokenPost := balancesDstPost.AmountOfNoDenomValidation(ibcCoin[0].Denom)
resPre := initialization.OsmoToken.Amount
resPre := token.Amount
resPost := tokenPost.Sub(tokenPre)
return resPost.Uint64() == resPre.Uint64()
} else {
Expand Down
75 changes: 75 additions & 0 deletions tests/e2e/configurer/chain/commands.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
package chain

import (
"encoding/json"
"fmt"
"os"
"regexp"
"strconv"
"strings"
Expand Down Expand Up @@ -36,6 +38,79 @@ func (n *NodeConfig) CreatePool(poolFile, from string) uint64 {
return poolID
}

func (n *NodeConfig) StoreWasmCode(wasmFile, from string) {
n.LogActionF("storing wasm code from file %s", wasmFile)
cmd := []string{"osmosisd", "tx", "wasm", "store", wasmFile, fmt.Sprintf("--from=%s", from), "--gas=auto", "--gas-prices=0.1uosmo", "--gas-adjustment=1.3"}
_, _, err := n.containerManager.ExecTxCmd(n.t, n.chainId, n.Name, cmd)
require.NoError(n.t, err)
n.LogActionF("successfully stored")
}

func (n *NodeConfig) InstantiateWasmContract(codeId, initMsg, from string) {
n.LogActionF("instantiating wasm contract %s with %s", codeId, initMsg)
cmd := []string{"osmosisd", "tx", "wasm", "instantiate", codeId, initMsg, fmt.Sprintf("--from=%s", from), "--no-admin", "--label=ratelimit"}
n.LogActionF(strings.Join(cmd, " "))
_, _, err := n.containerManager.ExecTxCmd(n.t, n.chainId, n.Name, cmd)
require.NoError(n.t, err)
n.LogActionF("successfully initialized")
}

func (n *NodeConfig) WasmExecute(contract, execMsg, from string) {
n.LogActionF("executing %s on wasm contract %s from %s", execMsg, contract, from)
cmd := []string{"osmosisd", "tx", "wasm", "execute", contract, execMsg, fmt.Sprintf("--from=%s", from)}
n.LogActionF(strings.Join(cmd, " "))
_, _, err := n.containerManager.ExecTxCmd(n.t, n.chainId, n.Name, cmd)
require.NoError(n.t, err)
n.LogActionF("successfully executed")
}

// QueryParams extracts the params for a given subspace and key. This is done generically via json to avoid having to
// specify the QueryParamResponse type (which may not exist for all params).
func (n *NodeConfig) QueryParams(subspace, key string, result any) {
cmd := []string{"osmosisd", "query", "params", "subspace", subspace, key, "--output=json"}

out, _, err := n.containerManager.ExecCmd(n.t, n.Name, cmd, "")
require.NoError(n.t, err)

err = json.Unmarshal(out.Bytes(), &result)
require.NoError(n.t, err)
}

func (n *NodeConfig) SubmitParamChangeProposal(proposalJson, from string) {
n.LogActionF("submitting param change proposal %s", proposalJson)
// ToDo: Is there a better way to do this?
wd, err := os.Getwd()
require.NoError(n.t, err)
localProposalFile := wd + "/scripts/param_change_proposal.json"
f, err := os.Create(localProposalFile)
require.NoError(n.t, err)
_, err = f.WriteString(proposalJson)
require.NoError(n.t, err)
err = f.Close()
require.NoError(n.t, err)

cmd := []string{"osmosisd", "tx", "gov", "submit-proposal", "param-change", "/osmosis/param_change_proposal.json", fmt.Sprintf("--from=%s", from)}

_, _, err = n.containerManager.ExecTxCmd(n.t, n.chainId, n.Name, cmd)
require.NoError(n.t, err)

err = os.Remove(localProposalFile)
require.NoError(n.t, err)

n.LogActionF("successfully submitted param change proposal")
}

func (n *NodeConfig) FailIBCTransfer(from, recipient, amount string) {
n.LogActionF("IBC sending %s from %s to %s", amount, from, recipient)

cmd := []string{"osmosisd", "tx", "ibc-transfer", "transfer", "transfer", "channel-0", recipient, amount, fmt.Sprintf("--from=%s", from)}

_, _, err := n.containerManager.ExecTxCmdWithSuccessString(n.t, n.chainId, n.Name, cmd, "rate limit exceeded")
require.NoError(n.t, err)

n.LogActionF("Failed to send IBC transfer (as expected)")
}

// SwapExactAmountIn swaps tokenInCoin to get at least tokenOutMinAmountInt of the other token's pool out.
// swapRoutePoolIds is the comma separated list of pool ids to swap through.
// swapRouteDenoms is the comma separated list of denoms to swap through.
Expand Down
27 changes: 27 additions & 0 deletions tests/e2e/configurer/chain/queries.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@ import (
"strconv"
"time"

wasmtypes "github.com/CosmWasm/wasmd/x/wasm/types"

sdk "github.com/cosmos/cosmos-sdk/types"
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
govtypes "github.com/cosmos/cosmos-sdk/x/gov/types"
Expand Down Expand Up @@ -82,6 +84,31 @@ func (n *NodeConfig) QueryBalances(address string) (sdk.Coins, error) {
return balancesResp.GetBalances(), nil
}

func (n *NodeConfig) QueryTotalSupply() (sdk.Coins, error) {
bz, err := n.QueryGRPCGateway("cosmos/bank/v1beta1/supply")
require.NoError(n.t, err)

var supplyResp banktypes.QueryTotalSupplyResponse
if err := util.Cdc.UnmarshalJSON(bz, &supplyResp); err != nil {
return sdk.Coins{}, err
}
return supplyResp.GetSupply(), nil
}

func (n *NodeConfig) QueryContractsFromId(codeId int) ([]string, error) {
path := fmt.Sprintf("/cosmwasm/wasm/v1/code/%d/contracts", codeId)
bz, err := n.QueryGRPCGateway(path)

require.NoError(n.t, err)

var contractsResponse wasmtypes.QueryContractsByCodeResponse
if err := util.Cdc.UnmarshalJSON(bz, &contractsResponse); err != nil {
return nil, err
}

return contractsResponse.Contracts, nil
}

func (n *NodeConfig) QueryPropTally(proposalNumber int) (sdk.Int, sdk.Int, sdk.Int, sdk.Int, error) {
path := fmt.Sprintf("cosmos/gov/v1beta1/proposals/%d/tally", proposalNumber)
bz, err := n.QueryGRPCGateway(path)
Expand Down
12 changes: 8 additions & 4 deletions tests/e2e/containers/containers.go
Original file line number Diff line number Diff line change
Expand Up @@ -53,13 +53,17 @@ func NewManager(isUpgrade bool, isFork bool, isDebugLogEnabled bool) (docker *Ma
return docker, nil
}

// ExecTxCmd Runs ExecCmd, with flags for txs added.
// namely adding flags `--chain-id={chain-id} -b=block --yes --keyring-backend=test "--log_format=json"`,
// and searching for `code: 0`
// ExecTxCmd Runs ExecTxCmdWithSuccessString searching for `code: 0`
func (m *Manager) ExecTxCmd(t *testing.T, chainId string, containerName string, command []string) (bytes.Buffer, bytes.Buffer, error) {
return m.ExecTxCmdWithSuccessString(t, chainId, containerName, command, "code: 0")
}

// ExecTxCmdWithSuccessString Runs ExecCmd, with flags for txs added.
// namely adding flags `--chain-id={chain-id} -b=block --yes --keyring-backend=test "--log_format=json"`,
// and searching for `successStr`
func (m *Manager) ExecTxCmdWithSuccessString(t *testing.T, chainId string, containerName string, command []string, successStr string) (bytes.Buffer, bytes.Buffer, error) {
allTxArgs := []string{fmt.Sprintf("--chain-id=%s", chainId), "-b=block", "--yes", "--keyring-backend=test", "--log_format=json"}
txCommand := append(command, allTxArgs...)
successStr := "code: 0"
return m.ExecCmd(t, containerName, txCommand, successStr)
}

Expand Down
Loading