From b3204f95d9c836db4549decf7abe9e3a0c5e544f Mon Sep 17 00:00:00 2001 From: Uday Patil Date: Mon, 8 Jul 2024 10:30:28 -0500 Subject: [PATCH] Deprecate dex (#1686) * Remove CPUFeature panic * Add dex list all contract info query * Update tests and add max gas allowed * Remove dex usages and register module removal upgrade * Update CI and other usages to remove dex * fix ignite * remove dex mention * update test * Update sei-cosmos and fix test * Update sei-cosmos tag * Update the store removal upgrade name --------- Co-authored-by: codchen --- .github/workflows/fuzz.yml | 40 - aclmapping/bank/mappings.go | 1 - aclmapping/dependency_generator.go | 2 - aclmapping/dex/mappings.go | 229 - aclmapping/dex/mappings_test.go | 292 - aclmapping/utils/resource_type.go | 70 - app/ante.go | 10 - app/ante_test.go | 2 - app/antedecorators/gasless.go | 38 - app/antedecorators/gasless_test.go | 33 +- app/antedecorators/priority_test.go | 3 +- app/app.go | 80 +- app/app_test.go | 70 +- app/apptesting/test_suite.go | 2 - app/test_helpers.go | 2 - cmd/seid/cmd/debug.go | 2 +- cmd/seid/cmd/iavl_parser.go | 61 - go.mod | 4 +- go.sum | 4 +- .../dex_module/cancel_order_test.yaml | 25 - .../dex_module/place_order_test.yaml | 46 - loadtest/main.go | 166 - occ_tests/utils/utils.go | 5 - proto/dex/asset_list.proto | 23 - proto/dex/contract.proto | 47 - proto/dex/deposit.proto | 21 - proto/dex/enums.proto | 42 - proto/dex/genesis.proto | 37 - proto/dex/gov.proto | 22 - proto/dex/long_book.proto | 19 - proto/dex/match_result.proto | 15 - proto/dex/order.proto | 108 - proto/dex/order_entry.proto | 46 - proto/dex/pair.proto | 30 - proto/dex/params.proto | 70 - proto/dex/price.proto | 52 - proto/dex/query.proto | 401 - proto/dex/settlement.proto | 40 - proto/dex/short_book.proto | 19 - proto/dex/tick_size.proto | 22 - proto/dex/twap.proto | 24 - proto/dex/tx.proto | 147 - proto/mint/v1beta1/gov.proto | 2 - scripts/dump_app_state_for_height.sh | 2 +- scripts/upload_clearing_house_contract.sh | 18 - testutil/fuzzing/dex.go | 228 - testutil/keeper/dex.go | 196 - testutil/keeper/epoch.go | 5 + testutil/processblock/msgs/dex.go | 101 - testutil/processblock/presets.go | 36 - testutil/processblock/verify/bank.go | 7 - testutil/processblock/verify/dex.go | 269 - wasmbinding/bindings/msg.go | 13 - wasmbinding/encoder.go | 7 - wasmbinding/queries.go | 73 +- wasmbinding/query_plugin.go | 3 - wasmbinding/test/encoder_test.go | 68 - wasmbinding/test/query_test.go | 131 +- wasmbinding/wasm.go | 6 +- x/dex/README.md | 57 - x/dex/ante.go | 178 - x/dex/ante_test.go | 283 - x/dex/cache/cache.go | 318 - x/dex/cache/cache_test.go | 225 - x/dex/cache/cancel.go | 65 - x/dex/cache/cancel_test.go | 76 - x/dex/cache/context.go | 44 - x/dex/cache/deposit.go | 51 - x/dex/cache/deposit_test.go | 48 - x/dex/cache/order.go | 142 - x/dex/cache/order_test.go | 257 - x/dex/client/cli/query/query.go | 48 - x/dex/client/cli/query/query_asset_list.go | 80 - .../cli/query/query_get_latest_price.go | 53 - .../client/cli/query/query_get_order_count.go | 52 - x/dex/client/cli/query/query_get_price.go | 58 - x/dex/client/cli/query/query_get_prices.go | 53 - x/dex/client/cli/query/query_get_twaps.go | 53 - x/dex/client/cli/query/query_long_book.go | 90 - .../client/cli/query/query_long_book_test.go | 176 - x/dex/client/cli/query/query_match_result.go | 49 - x/dex/client/cli/query/query_orders.go | 96 - x/dex/client/cli/query/query_params.go | 34 - .../cli/query/query_registered_contract.go | 48 - .../cli/query/query_registered_pairs.go | 48 - x/dex/client/cli/query/query_short_book.go | 92 - .../client/cli/query/query_short_book_test.go | 181 - x/dex/client/cli/tx/gov_tx.go | 60 - x/dex/client/cli/tx/tx.go | 40 - x/dex/client/cli/tx/tx_cancel_orders.go | 75 - .../client/cli/tx/tx_contract_deposit_rent.go | 52 - x/dex/client/cli/tx/tx_place_orders.go | 98 - x/dex/client/cli/tx/tx_register_contract.go | 68 - x/dex/client/cli/tx/tx_register_pairs.go | 54 - x/dex/client/cli/tx/tx_unregister_contract.go | 46 - x/dex/client/cli/tx/tx_unsuspend_contract.go | 46 - .../cli/tx/tx_update_price_tick_size.go | 54 - .../cli/tx/tx_update_quantity_tick_size.go | 54 - x/dex/client/utils/utils.go | 203 - x/dex/client/wasm/bindings/queries.go | 12 - x/dex/client/wasm/encoder.go | 36 - x/dex/client/wasm/query.go | 48 - x/dex/contract/abci.go | 323 - x/dex/contract/abci_test.go | 43 - x/dex/contract/dag.go | 78 - x/dex/contract/dag_test.go | 110 - x/dex/contract/execution.go | 219 - x/dex/contract/execution_test.go | 373 - x/dex/contract/market_order.go | 68 - x/dex/contract/runner.go | 178 - x/dex/contract/runner_test.go | 141 - x/dex/contract/settlement.go | 39 - x/dex/contract/whitelist.go | 91 - x/dex/contract/whitelist_test.go | 28 - .../example/add-asset-metadata-proposal.json | 55 - x/dex/example/register-pair-tx.json | 15 - x/dex/example/update-tick-size-tx.json | 12 - x/dex/exchange/cancel_order.go | 53 - x/dex/exchange/cancel_order_test.go | 105 - x/dex/exchange/helpers.go | 24 - x/dex/exchange/helpers_test.go | 64 - x/dex/exchange/limit_order.go | 103 - x/dex/exchange/limit_order_fuzz_test.go | 55 - x/dex/exchange/limit_order_test.go | 1165 -- x/dex/exchange/market_order.go | 273 - x/dex/exchange/market_order_fuzz_test.go | 92 - x/dex/exchange/market_order_test.go | 1175 -- x/dex/exchange/settlement.go | 129 - x/dex/exchange/settlement_fuzz_test.go | 118 - x/dex/genesis.go | 85 - x/dex/genesis_test.go | 105 - x/dex/gov.go | 14 - x/dex/handler.go | 67 - x/dex/keeper/abci/end_block_cancel_orders.go | 45 - x/dex/keeper/abci/end_block_deposit.go | 58 - x/dex/keeper/abci/end_block_place_orders.go | 83 - .../abci/end_block_place_orders_test.go | 67 - x/dex/keeper/abci/keeper_wrapper.go | 9 - x/dex/keeper/asset_list.go | 43 - x/dex/keeper/asset_list_test.go | 35 - x/dex/keeper/common.go | 22 - x/dex/keeper/contract.go | 244 - x/dex/keeper/contract_test.go | 368 - x/dex/keeper/epoch.go | 26 - x/dex/keeper/keeper.go | 78 - x/dex/keeper/long_book.go | 184 - x/dex/keeper/long_book_test.go | 92 - x/dex/keeper/match_result.go | 45 - x/dex/keeper/msgserver/msg_server.go | 18 - .../msgserver/msg_server_cancel_orders.go | 12 - .../msg_server_cancel_orders_test.go | 36 - .../msg_server_contract_deposit_rent.go | 12 - .../msg_server_contract_deposit_rent_test.go | 34 - .../msgserver/msg_server_place_orders.go | 12 - .../msg_server_place_orders_fuzz_test.go | 65 - .../msgserver/msg_server_place_orders_test.go | 49 - .../msgserver/msg_server_register_contract.go | 12 - .../msg_server_register_contract_test.go | 34 - .../msgserver/msg_server_register_pairs.go | 12 - .../msg_server_register_pairs_test.go | 38 - .../msg_server_unregister_contract.go | 12 - .../msg_server_unregister_contract_test.go | 34 - .../msg_server_unsuspend_contract.go | 12 - .../msg_server_unsuspend_contract_test.go | 23 - .../msg_server_update_price_tick_size.go | 12 - .../msg_server_update_price_tick_size_test.go | 40 - .../msg_server_update_quantity_tick_size.go | 12 - ...g_server_update_quantity_tick_size_test.go | 41 - x/dex/keeper/msgserver/testdata/hackatom.wasm | Bin 208805 -> 0 bytes x/dex/keeper/msgserver/validations.go | 40 - x/dex/keeper/order_count.go | 56 - x/dex/keeper/order_count_test.go | 35 - x/dex/keeper/order_placement.go | 33 - x/dex/keeper/pair.go | 56 - x/dex/keeper/pair_test.go | 41 - x/dex/keeper/params.go | 42 - x/dex/keeper/params_test.go | 24 - x/dex/keeper/price.go | 98 - x/dex/keeper/price_test.go | 20 - x/dex/keeper/query/grpc_query.go | 7 - x/dex/keeper/query/grpc_query_asset_list.go | 36 - .../query/grpc_query_asset_list_test.go | 50 - .../query/grpc_query_get_historical_prices.go | 119 - .../grpc_query_get_historical_prices_test.go | 185 - .../query/grpc_query_get_latest_price.go | 37 - .../query/grpc_query_get_latest_price_test.go | 30 - .../query/grpc_query_get_market_summary.go | 49 - .../grpc_query_get_market_summary_test.go | 33 - .../query/grpc_query_get_order_count.go | 19 - .../query/grpc_query_get_order_count_test.go | 29 - x/dex/keeper/query/grpc_query_get_price.go | 25 - .../keeper/query/grpc_query_get_price_test.go | 32 - x/dex/keeper/query/grpc_query_get_prices.go | 24 - x/dex/keeper/query/grpc_query_get_twaps.go | 57 - .../keeper/query/grpc_query_get_twaps_test.go | 143 - x/dex/keeper/query/grpc_query_long_book.go | 50 - .../keeper/query/grpc_query_long_book_test.go | 123 - x/dex/keeper/query/grpc_query_match_result.go | 24 - x/dex/keeper/query/grpc_query_order.go | 112 - .../query/grpc_query_order_simulation.go | 120 - .../query/grpc_query_order_simulation_test.go | 101 - x/dex/keeper/query/grpc_query_order_test.go | 75 - x/dex/keeper/query/grpc_query_params.go | 19 - x/dex/keeper/query/grpc_query_params_test.go | 23 - .../query/grpc_query_registered_contract.go | 24 - .../grpc_query_registered_contract_test.go | 42 - .../query/grpc_query_registered_pairs.go | 21 - .../query/grpc_query_registered_pairs_test.go | 39 - x/dex/keeper/query/grpc_query_short_book.go | 46 - .../query/grpc_query_short_book_test.go | 123 - x/dex/keeper/query/keeper_wrapper.go | 9 - x/dex/keeper/short_book.go | 165 - x/dex/keeper/short_book_test.go | 92 - x/dex/keeper/tick.go | 60 - x/dex/keeper/tick_test.go | 42 - x/dex/keeper/utils/order_book.go | 89 - x/dex/keeper/utils/price.go | 28 - x/dex/keeper/utils/wasm.go | 116 - x/dex/migrations/v10_to_v11.go | 45 - x/dex/migrations/v10_to_v11_test.go | 60 - x/dex/migrations/v11_to_v12.go | 13 - x/dex/migrations/v11_to_v12_test.go | 31 - x/dex/migrations/v12_to_v13.go | 15 - x/dex/migrations/v12_to_v13_test.go | 32 - x/dex/migrations/v13_to_v14.go | 69 - x/dex/migrations/v13_to_v14_test.go | 79 - x/dex/migrations/v14_to_v15.go | 15 - x/dex/migrations/v14_to_v15_test.go | 26 - x/dex/migrations/v15_to_v16.go | 15 - x/dex/migrations/v15_to_v16_test.go | 24 - x/dex/migrations/v16_to_v17.go | 110 - x/dex/migrations/v16_to_v17_test.go | 89 - x/dex/migrations/v17_to_v18.go | 33 - x/dex/migrations/v17_to_v18_test.go | 62 - x/dex/migrations/v2_to_v3.go | 35 - x/dex/migrations/v3_to_v4.go | 21 - x/dex/migrations/v3_to_v4_test.go | 48 - x/dex/migrations/v4_to_v5.go | 28 - x/dex/migrations/v4_to_v5_test.go | 59 - x/dex/migrations/v5_to_v6.go | 57 - x/dex/migrations/v5_to_v6_test.go | 79 - x/dex/migrations/v6_to_v7.go | 84 - x/dex/migrations/v6_to_v7_test.go | 89 - x/dex/migrations/v7_to_v8.go | 101 - x/dex/migrations/v7_to_v8_test.go | 98 - x/dex/migrations/v8_to_v9.go | 38 - x/dex/migrations/v8_to_v9_test.go | 42 - x/dex/migrations/v9_to_v10.go | 91 - x/dex/migrations/v9_to_v10_test.go | 94 - x/dex/module.go | 362 - x/dex/module_simulation.go | 91 - x/dex/module_test.go | 835 -- x/dex/simulation/simap.go | 15 - x/dex/spec/README.md | 56 - x/dex/testdata/clearing_house.wasm | Bin 833624 -> 0 bytes x/dex/testdata/mars.wasm | Bin 191011 -> 0 bytes x/dex/types/alias.go | 24 - x/dex/types/alias_test.go | 20 - x/dex/types/asset_list.pb.go | 768 -- x/dex/types/codec.go | 71 - x/dex/types/contract.pb.go | 1902 --- x/dex/types/deposit.go | 19 - x/dex/types/deposit.pb.go | 422 - x/dex/types/enums.go | 29 - x/dex/types/enums.pb.go | 235 - x/dex/types/enums_test.go | 53 - x/dex/types/errors.go | 28 - x/dex/types/events.go | 21 - x/dex/types/expected_keepers.go | 18 - x/dex/types/genesis.go | 75 - x/dex/types/genesis.pb.go | 1188 -- x/dex/types/genesis_test.go | 228 - x/dex/types/gov.go | 57 - x/dex/types/gov.pb.go | 418 - x/dex/types/keys.go | 190 - x/dex/types/keys_test.go | 29 - x/dex/types/long_book.pb.go | 380 - x/dex/types/match_result.go | 28 - x/dex/types/match_result.pb.go | 548 - x/dex/types/match_result_test.go | 54 - x/dex/types/message_cancel_orders.go | 72 - x/dex/types/message_cancel_orders_test.go | 42 - x/dex/types/message_contract_deposit_rent.go | 56 - x/dex/types/message_place_orders.go | 85 - x/dex/types/message_place_orders_test.go | 102 - x/dex/types/message_register_contract.go | 75 - x/dex/types/message_register_pairs.go | 83 - x/dex/types/message_unregister_contract.go | 55 - x/dex/types/message_unsuspend_contract.go | 55 - x/dex/types/message_update_price_tick_size.go | 69 - .../message_update_quantity_tick_size.go | 69 - x/dex/types/order.pb.go | 1680 --- x/dex/types/order_cancellation.go | 9 - x/dex/types/order_entry.pb.go | 790 -- x/dex/types/order_placement.go | 31 - x/dex/types/orders.go | 244 - x/dex/types/orders_test.go | 166 - x/dex/types/pair.pb.go | 718 -- x/dex/types/params.go | 143 - x/dex/types/params.pb.go | 870 -- x/dex/types/params_test.go | 17 - x/dex/types/price.pb.go | 881 -- x/dex/types/query.pb.go | 10031 ---------------- x/dex/types/query.pb.gw.go | 2389 ---- x/dex/types/settlement.go | 36 - x/dex/types/settlement.pb.go | 1044 -- x/dex/types/settlement_test.go | 31 - x/dex/types/short_book.pb.go | 380 - x/dex/types/tick_size.pb.go | 433 - x/dex/types/twap.pb.go | 416 - x/dex/types/tx.pb.go | 3884 ------ x/dex/types/types.go | 6 - x/dex/types/utils.go | 14 - x/dex/utils/context.go | 18 - x/dex/utils/dec.go | 71 - x/dex/utils/dec_test.go | 54 - x/dex/utils/errors.go | 11 - x/evm/keeper/msg_server_test.go | 6 - x/mint/keeper/hooks_test.go | 10 - x/mint/types/gov.pb.go | 2 - 320 files changed, 38 insertions(+), 52576 deletions(-) delete mode 100644 .github/workflows/fuzz.yml delete mode 100644 aclmapping/dex/mappings.go delete mode 100644 aclmapping/dex/mappings_test.go delete mode 100644 integration_test/dex_module/cancel_order_test.yaml delete mode 100644 integration_test/dex_module/place_order_test.yaml delete mode 100644 proto/dex/asset_list.proto delete mode 100644 proto/dex/contract.proto delete mode 100644 proto/dex/deposit.proto delete mode 100644 proto/dex/enums.proto delete mode 100644 proto/dex/genesis.proto delete mode 100644 proto/dex/gov.proto delete mode 100644 proto/dex/long_book.proto delete mode 100644 proto/dex/match_result.proto delete mode 100644 proto/dex/order.proto delete mode 100644 proto/dex/order_entry.proto delete mode 100644 proto/dex/pair.proto delete mode 100644 proto/dex/params.proto delete mode 100644 proto/dex/price.proto delete mode 100644 proto/dex/query.proto delete mode 100644 proto/dex/settlement.proto delete mode 100644 proto/dex/short_book.proto delete mode 100644 proto/dex/tick_size.proto delete mode 100644 proto/dex/twap.proto delete mode 100644 proto/dex/tx.proto delete mode 100755 scripts/upload_clearing_house_contract.sh delete mode 100644 testutil/fuzzing/dex.go delete mode 100644 testutil/keeper/dex.go delete mode 100644 testutil/processblock/msgs/dex.go delete mode 100644 testutil/processblock/verify/dex.go delete mode 100644 x/dex/README.md delete mode 100644 x/dex/ante.go delete mode 100644 x/dex/ante_test.go delete mode 100644 x/dex/cache/cache.go delete mode 100644 x/dex/cache/cache_test.go delete mode 100644 x/dex/cache/cancel.go delete mode 100644 x/dex/cache/cancel_test.go delete mode 100644 x/dex/cache/context.go delete mode 100644 x/dex/cache/deposit.go delete mode 100644 x/dex/cache/deposit_test.go delete mode 100644 x/dex/cache/order.go delete mode 100644 x/dex/cache/order_test.go delete mode 100644 x/dex/client/cli/query/query.go delete mode 100644 x/dex/client/cli/query/query_asset_list.go delete mode 100644 x/dex/client/cli/query/query_get_latest_price.go delete mode 100644 x/dex/client/cli/query/query_get_order_count.go delete mode 100644 x/dex/client/cli/query/query_get_price.go delete mode 100644 x/dex/client/cli/query/query_get_prices.go delete mode 100644 x/dex/client/cli/query/query_get_twaps.go delete mode 100644 x/dex/client/cli/query/query_long_book.go delete mode 100644 x/dex/client/cli/query/query_long_book_test.go delete mode 100644 x/dex/client/cli/query/query_match_result.go delete mode 100644 x/dex/client/cli/query/query_orders.go delete mode 100644 x/dex/client/cli/query/query_params.go delete mode 100644 x/dex/client/cli/query/query_registered_contract.go delete mode 100644 x/dex/client/cli/query/query_registered_pairs.go delete mode 100644 x/dex/client/cli/query/query_short_book.go delete mode 100644 x/dex/client/cli/query/query_short_book_test.go delete mode 100644 x/dex/client/cli/tx/gov_tx.go delete mode 100644 x/dex/client/cli/tx/tx.go delete mode 100644 x/dex/client/cli/tx/tx_cancel_orders.go delete mode 100644 x/dex/client/cli/tx/tx_contract_deposit_rent.go delete mode 100644 x/dex/client/cli/tx/tx_place_orders.go delete mode 100644 x/dex/client/cli/tx/tx_register_contract.go delete mode 100644 x/dex/client/cli/tx/tx_register_pairs.go delete mode 100644 x/dex/client/cli/tx/tx_unregister_contract.go delete mode 100644 x/dex/client/cli/tx/tx_unsuspend_contract.go delete mode 100644 x/dex/client/cli/tx/tx_update_price_tick_size.go delete mode 100644 x/dex/client/cli/tx/tx_update_quantity_tick_size.go delete mode 100644 x/dex/client/utils/utils.go delete mode 100644 x/dex/client/wasm/bindings/queries.go delete mode 100644 x/dex/client/wasm/encoder.go delete mode 100644 x/dex/client/wasm/query.go delete mode 100644 x/dex/contract/abci.go delete mode 100644 x/dex/contract/abci_test.go delete mode 100644 x/dex/contract/dag.go delete mode 100644 x/dex/contract/dag_test.go delete mode 100644 x/dex/contract/execution.go delete mode 100644 x/dex/contract/execution_test.go delete mode 100644 x/dex/contract/market_order.go delete mode 100644 x/dex/contract/runner.go delete mode 100644 x/dex/contract/runner_test.go delete mode 100644 x/dex/contract/settlement.go delete mode 100644 x/dex/contract/whitelist.go delete mode 100644 x/dex/contract/whitelist_test.go delete mode 100644 x/dex/example/add-asset-metadata-proposal.json delete mode 100644 x/dex/example/register-pair-tx.json delete mode 100644 x/dex/example/update-tick-size-tx.json delete mode 100644 x/dex/exchange/cancel_order.go delete mode 100644 x/dex/exchange/cancel_order_test.go delete mode 100644 x/dex/exchange/helpers.go delete mode 100644 x/dex/exchange/helpers_test.go delete mode 100644 x/dex/exchange/limit_order.go delete mode 100644 x/dex/exchange/limit_order_fuzz_test.go delete mode 100644 x/dex/exchange/limit_order_test.go delete mode 100644 x/dex/exchange/market_order.go delete mode 100644 x/dex/exchange/market_order_fuzz_test.go delete mode 100644 x/dex/exchange/market_order_test.go delete mode 100644 x/dex/exchange/settlement.go delete mode 100644 x/dex/exchange/settlement_fuzz_test.go delete mode 100644 x/dex/genesis.go delete mode 100644 x/dex/genesis_test.go delete mode 100644 x/dex/gov.go delete mode 100644 x/dex/handler.go delete mode 100644 x/dex/keeper/abci/end_block_cancel_orders.go delete mode 100644 x/dex/keeper/abci/end_block_deposit.go delete mode 100644 x/dex/keeper/abci/end_block_place_orders.go delete mode 100644 x/dex/keeper/abci/end_block_place_orders_test.go delete mode 100644 x/dex/keeper/abci/keeper_wrapper.go delete mode 100644 x/dex/keeper/asset_list.go delete mode 100644 x/dex/keeper/asset_list_test.go delete mode 100644 x/dex/keeper/common.go delete mode 100644 x/dex/keeper/contract.go delete mode 100644 x/dex/keeper/contract_test.go delete mode 100644 x/dex/keeper/epoch.go delete mode 100644 x/dex/keeper/keeper.go delete mode 100644 x/dex/keeper/long_book.go delete mode 100644 x/dex/keeper/long_book_test.go delete mode 100644 x/dex/keeper/match_result.go delete mode 100644 x/dex/keeper/msgserver/msg_server.go delete mode 100644 x/dex/keeper/msgserver/msg_server_cancel_orders.go delete mode 100644 x/dex/keeper/msgserver/msg_server_cancel_orders_test.go delete mode 100644 x/dex/keeper/msgserver/msg_server_contract_deposit_rent.go delete mode 100644 x/dex/keeper/msgserver/msg_server_contract_deposit_rent_test.go delete mode 100644 x/dex/keeper/msgserver/msg_server_place_orders.go delete mode 100644 x/dex/keeper/msgserver/msg_server_place_orders_fuzz_test.go delete mode 100644 x/dex/keeper/msgserver/msg_server_place_orders_test.go delete mode 100644 x/dex/keeper/msgserver/msg_server_register_contract.go delete mode 100644 x/dex/keeper/msgserver/msg_server_register_contract_test.go delete mode 100644 x/dex/keeper/msgserver/msg_server_register_pairs.go delete mode 100644 x/dex/keeper/msgserver/msg_server_register_pairs_test.go delete mode 100644 x/dex/keeper/msgserver/msg_server_unregister_contract.go delete mode 100644 x/dex/keeper/msgserver/msg_server_unregister_contract_test.go delete mode 100644 x/dex/keeper/msgserver/msg_server_unsuspend_contract.go delete mode 100644 x/dex/keeper/msgserver/msg_server_unsuspend_contract_test.go delete mode 100644 x/dex/keeper/msgserver/msg_server_update_price_tick_size.go delete mode 100644 x/dex/keeper/msgserver/msg_server_update_price_tick_size_test.go delete mode 100644 x/dex/keeper/msgserver/msg_server_update_quantity_tick_size.go delete mode 100644 x/dex/keeper/msgserver/msg_server_update_quantity_tick_size_test.go delete mode 100644 x/dex/keeper/msgserver/testdata/hackatom.wasm delete mode 100644 x/dex/keeper/msgserver/validations.go delete mode 100644 x/dex/keeper/order_count.go delete mode 100644 x/dex/keeper/order_count_test.go delete mode 100644 x/dex/keeper/order_placement.go delete mode 100644 x/dex/keeper/pair.go delete mode 100644 x/dex/keeper/pair_test.go delete mode 100644 x/dex/keeper/params.go delete mode 100644 x/dex/keeper/params_test.go delete mode 100644 x/dex/keeper/price.go delete mode 100644 x/dex/keeper/price_test.go delete mode 100644 x/dex/keeper/query/grpc_query.go delete mode 100644 x/dex/keeper/query/grpc_query_asset_list.go delete mode 100644 x/dex/keeper/query/grpc_query_asset_list_test.go delete mode 100644 x/dex/keeper/query/grpc_query_get_historical_prices.go delete mode 100644 x/dex/keeper/query/grpc_query_get_historical_prices_test.go delete mode 100644 x/dex/keeper/query/grpc_query_get_latest_price.go delete mode 100644 x/dex/keeper/query/grpc_query_get_latest_price_test.go delete mode 100644 x/dex/keeper/query/grpc_query_get_market_summary.go delete mode 100644 x/dex/keeper/query/grpc_query_get_market_summary_test.go delete mode 100644 x/dex/keeper/query/grpc_query_get_order_count.go delete mode 100644 x/dex/keeper/query/grpc_query_get_order_count_test.go delete mode 100644 x/dex/keeper/query/grpc_query_get_price.go delete mode 100644 x/dex/keeper/query/grpc_query_get_price_test.go delete mode 100644 x/dex/keeper/query/grpc_query_get_prices.go delete mode 100644 x/dex/keeper/query/grpc_query_get_twaps.go delete mode 100644 x/dex/keeper/query/grpc_query_get_twaps_test.go delete mode 100644 x/dex/keeper/query/grpc_query_long_book.go delete mode 100644 x/dex/keeper/query/grpc_query_long_book_test.go delete mode 100644 x/dex/keeper/query/grpc_query_match_result.go delete mode 100644 x/dex/keeper/query/grpc_query_order.go delete mode 100644 x/dex/keeper/query/grpc_query_order_simulation.go delete mode 100644 x/dex/keeper/query/grpc_query_order_simulation_test.go delete mode 100644 x/dex/keeper/query/grpc_query_order_test.go delete mode 100644 x/dex/keeper/query/grpc_query_params.go delete mode 100644 x/dex/keeper/query/grpc_query_params_test.go delete mode 100644 x/dex/keeper/query/grpc_query_registered_contract.go delete mode 100644 x/dex/keeper/query/grpc_query_registered_contract_test.go delete mode 100644 x/dex/keeper/query/grpc_query_registered_pairs.go delete mode 100644 x/dex/keeper/query/grpc_query_registered_pairs_test.go delete mode 100644 x/dex/keeper/query/grpc_query_short_book.go delete mode 100644 x/dex/keeper/query/grpc_query_short_book_test.go delete mode 100644 x/dex/keeper/query/keeper_wrapper.go delete mode 100644 x/dex/keeper/short_book.go delete mode 100644 x/dex/keeper/short_book_test.go delete mode 100644 x/dex/keeper/tick.go delete mode 100644 x/dex/keeper/tick_test.go delete mode 100644 x/dex/keeper/utils/order_book.go delete mode 100644 x/dex/keeper/utils/price.go delete mode 100644 x/dex/keeper/utils/wasm.go delete mode 100644 x/dex/migrations/v10_to_v11.go delete mode 100644 x/dex/migrations/v10_to_v11_test.go delete mode 100644 x/dex/migrations/v11_to_v12.go delete mode 100644 x/dex/migrations/v11_to_v12_test.go delete mode 100644 x/dex/migrations/v12_to_v13.go delete mode 100644 x/dex/migrations/v12_to_v13_test.go delete mode 100644 x/dex/migrations/v13_to_v14.go delete mode 100644 x/dex/migrations/v13_to_v14_test.go delete mode 100644 x/dex/migrations/v14_to_v15.go delete mode 100644 x/dex/migrations/v14_to_v15_test.go delete mode 100644 x/dex/migrations/v15_to_v16.go delete mode 100644 x/dex/migrations/v15_to_v16_test.go delete mode 100644 x/dex/migrations/v16_to_v17.go delete mode 100644 x/dex/migrations/v16_to_v17_test.go delete mode 100644 x/dex/migrations/v17_to_v18.go delete mode 100644 x/dex/migrations/v17_to_v18_test.go delete mode 100644 x/dex/migrations/v2_to_v3.go delete mode 100644 x/dex/migrations/v3_to_v4.go delete mode 100644 x/dex/migrations/v3_to_v4_test.go delete mode 100644 x/dex/migrations/v4_to_v5.go delete mode 100644 x/dex/migrations/v4_to_v5_test.go delete mode 100644 x/dex/migrations/v5_to_v6.go delete mode 100644 x/dex/migrations/v5_to_v6_test.go delete mode 100644 x/dex/migrations/v6_to_v7.go delete mode 100644 x/dex/migrations/v6_to_v7_test.go delete mode 100644 x/dex/migrations/v7_to_v8.go delete mode 100644 x/dex/migrations/v7_to_v8_test.go delete mode 100644 x/dex/migrations/v8_to_v9.go delete mode 100644 x/dex/migrations/v8_to_v9_test.go delete mode 100644 x/dex/migrations/v9_to_v10.go delete mode 100644 x/dex/migrations/v9_to_v10_test.go delete mode 100644 x/dex/module.go delete mode 100644 x/dex/module_simulation.go delete mode 100644 x/dex/module_test.go delete mode 100644 x/dex/simulation/simap.go delete mode 100644 x/dex/spec/README.md delete mode 100644 x/dex/testdata/clearing_house.wasm delete mode 100644 x/dex/testdata/mars.wasm delete mode 100644 x/dex/types/alias.go delete mode 100644 x/dex/types/alias_test.go delete mode 100644 x/dex/types/asset_list.pb.go delete mode 100644 x/dex/types/codec.go delete mode 100644 x/dex/types/contract.pb.go delete mode 100644 x/dex/types/deposit.go delete mode 100644 x/dex/types/deposit.pb.go delete mode 100644 x/dex/types/enums.go delete mode 100644 x/dex/types/enums.pb.go delete mode 100644 x/dex/types/enums_test.go delete mode 100644 x/dex/types/errors.go delete mode 100644 x/dex/types/events.go delete mode 100644 x/dex/types/expected_keepers.go delete mode 100644 x/dex/types/genesis.go delete mode 100644 x/dex/types/genesis.pb.go delete mode 100644 x/dex/types/genesis_test.go delete mode 100644 x/dex/types/gov.go delete mode 100644 x/dex/types/gov.pb.go delete mode 100644 x/dex/types/keys.go delete mode 100644 x/dex/types/keys_test.go delete mode 100644 x/dex/types/long_book.pb.go delete mode 100644 x/dex/types/match_result.go delete mode 100644 x/dex/types/match_result.pb.go delete mode 100644 x/dex/types/match_result_test.go delete mode 100644 x/dex/types/message_cancel_orders.go delete mode 100644 x/dex/types/message_cancel_orders_test.go delete mode 100644 x/dex/types/message_contract_deposit_rent.go delete mode 100644 x/dex/types/message_place_orders.go delete mode 100644 x/dex/types/message_place_orders_test.go delete mode 100644 x/dex/types/message_register_contract.go delete mode 100644 x/dex/types/message_register_pairs.go delete mode 100644 x/dex/types/message_unregister_contract.go delete mode 100644 x/dex/types/message_unsuspend_contract.go delete mode 100644 x/dex/types/message_update_price_tick_size.go delete mode 100644 x/dex/types/message_update_quantity_tick_size.go delete mode 100644 x/dex/types/order.pb.go delete mode 100644 x/dex/types/order_cancellation.go delete mode 100644 x/dex/types/order_entry.pb.go delete mode 100644 x/dex/types/order_placement.go delete mode 100644 x/dex/types/orders.go delete mode 100644 x/dex/types/orders_test.go delete mode 100644 x/dex/types/pair.pb.go delete mode 100644 x/dex/types/params.go delete mode 100644 x/dex/types/params.pb.go delete mode 100644 x/dex/types/params_test.go delete mode 100644 x/dex/types/price.pb.go delete mode 100644 x/dex/types/query.pb.go delete mode 100644 x/dex/types/query.pb.gw.go delete mode 100644 x/dex/types/settlement.go delete mode 100644 x/dex/types/settlement.pb.go delete mode 100644 x/dex/types/settlement_test.go delete mode 100644 x/dex/types/short_book.pb.go delete mode 100644 x/dex/types/tick_size.pb.go delete mode 100644 x/dex/types/twap.pb.go delete mode 100644 x/dex/types/tx.pb.go delete mode 100644 x/dex/types/types.go delete mode 100644 x/dex/types/utils.go delete mode 100644 x/dex/utils/context.go delete mode 100644 x/dex/utils/dec.go delete mode 100644 x/dex/utils/dec_test.go delete mode 100644 x/dex/utils/errors.go diff --git a/.github/workflows/fuzz.yml b/.github/workflows/fuzz.yml deleted file mode 100644 index 01f3ef71a7..0000000000 --- a/.github/workflows/fuzz.yml +++ /dev/null @@ -1,40 +0,0 @@ -name: Fuzzing - - -on: - push: - branches: - - main - pull_request: - branches: - - main - -defaults: - run: - shell: bash - -jobs: - build: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - - name: Set up Go - uses: actions/setup-go@v2 - with: - go-version: 1.21 - - - name: Fuzz Place Order Msg - run: go test github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver -fuzz FuzzPlaceOrders -fuzztime 30s - - - name: Fuzz Limit Order Matching - run: go test github.com/sei-protocol/sei-chain/x/dex/exchange -fuzz FuzzMatchLimitOrders -fuzztime 30s - - - name: Fuzz Market Order Matching - run: go test github.com/sei-protocol/sei-chain/x/dex/exchange -fuzz FuzzMatchMarketOrders -fuzztime 30s - - - name: Fuzz Limit Order Settlement - run: go test github.com/sei-protocol/sei-chain/x/dex/exchange -fuzz FuzzSettleLimitOrder -fuzztime 30s - - - name: Fuzz Market Order Settlement - run: go test github.com/sei-protocol/sei-chain/x/dex/exchange -fuzz FuzzSettleMarketOrder -fuzztime 30s diff --git a/aclmapping/bank/mappings.go b/aclmapping/bank/mappings.go index 047c9092a1..140e9d463b 100644 --- a/aclmapping/bank/mappings.go +++ b/aclmapping/bank/mappings.go @@ -18,7 +18,6 @@ var ErrorInvalidMsgType = fmt.Errorf("invalid message received for bank module") func GetBankDepedencyGenerator() aclkeeper.DependencyGeneratorMap { dependencyGeneratorMap := make(aclkeeper.DependencyGeneratorMap) - // dex place orders placeOrdersKey := acltypes.GenerateMessageKey(&banktypes.MsgSend{}) dependencyGeneratorMap[placeOrdersKey] = MsgSendDependencyGenerator diff --git a/aclmapping/dependency_generator.go b/aclmapping/dependency_generator.go index 8a8cabe811..2e83c1ca7d 100644 --- a/aclmapping/dependency_generator.go +++ b/aclmapping/dependency_generator.go @@ -3,7 +3,6 @@ package aclmapping import ( aclkeeper "github.com/cosmos/cosmos-sdk/x/accesscontrol/keeper" aclbankmapping "github.com/sei-protocol/sei-chain/aclmapping/bank" - acldexmapping "github.com/sei-protocol/sei-chain/aclmapping/dex" aclevmmapping "github.com/sei-protocol/sei-chain/aclmapping/evm" acloraclemapping "github.com/sei-protocol/sei-chain/aclmapping/oracle" acltokenfactorymapping "github.com/sei-protocol/sei-chain/aclmapping/tokenfactory" @@ -21,7 +20,6 @@ func (customDepGen CustomDependencyGenerator) GetCustomDependencyGenerators(evmK dependencyGeneratorMap := make(aclkeeper.DependencyGeneratorMap) wasmDependencyGenerators := aclwasmmapping.NewWasmDependencyGenerator() - dependencyGeneratorMap = dependencyGeneratorMap.Merge(acldexmapping.GetDexDependencyGenerators()) dependencyGeneratorMap = dependencyGeneratorMap.Merge(aclbankmapping.GetBankDepedencyGenerator()) dependencyGeneratorMap = dependencyGeneratorMap.Merge(acltokenfactorymapping.GetTokenFactoryDependencyGenerators()) dependencyGeneratorMap = dependencyGeneratorMap.Merge(wasmDependencyGenerators.GetWasmDependencyGenerators()) diff --git a/aclmapping/dex/mappings.go b/aclmapping/dex/mappings.go deleted file mode 100644 index df5350c120..0000000000 --- a/aclmapping/dex/mappings.go +++ /dev/null @@ -1,229 +0,0 @@ -package acldexmapping - -import ( - "encoding/hex" - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkacltypes "github.com/cosmos/cosmos-sdk/types/accesscontrol" - aclkeeper "github.com/cosmos/cosmos-sdk/x/accesscontrol/keeper" - acltypes "github.com/cosmos/cosmos-sdk/x/accesscontrol/types" - authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - banktypes "github.com/cosmos/cosmos-sdk/x/bank/types" - dexkeeper "github.com/sei-protocol/sei-chain/x/dex/keeper" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" -) - -var ErrPlaceOrdersGenerator = fmt.Errorf("invalid message received for dex module") - -func GetDexDependencyGenerators() aclkeeper.DependencyGeneratorMap { - dependencyGeneratorMap := make(aclkeeper.DependencyGeneratorMap) - - // dex place orders - placeOrdersKey := acltypes.GenerateMessageKey(&dextypes.MsgPlaceOrders{}) - cancelOrdersKey := acltypes.GenerateMessageKey(&dextypes.MsgCancelOrders{}) - dependencyGeneratorMap[placeOrdersKey] = DexPlaceOrdersDependencyGenerator - dependencyGeneratorMap[cancelOrdersKey] = DexCancelOrdersDependencyGenerator - - return dependencyGeneratorMap -} - -func GetLongShortOrderBookOps(contractAddr string, priceDenom string, assetDenom string) []sdkacltypes.AccessOperation { - return []sdkacltypes.AccessOperation{ - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_CONTRACT_LONGBOOK, - IdentifierTemplate: hex.EncodeToString(dextypes.OrderBookPrefix(true, contractAddr, priceDenom, assetDenom)), - }, - - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_CONTRACT_SHORTBOOK, - IdentifierTemplate: hex.EncodeToString(dextypes.OrderBookPrefix(false, contractAddr, priceDenom, assetDenom)), - }, - } -} - -func DexPlaceOrdersDependencyGenerator(keeper aclkeeper.Keeper, _ sdk.Context, msg sdk.Msg) ([]sdkacltypes.AccessOperation, error) { - // TODO: read + write downstream, write contracts to process - placeOrdersMsg, ok := msg.(*dextypes.MsgPlaceOrders) - if !ok { - return []sdkacltypes.AccessOperation{}, ErrPlaceOrdersGenerator - } - - moduleAdr := keeper.AccountKeeper.GetModuleAddress(dextypes.ModuleName) - - senderBankAddrIdentifier := hex.EncodeToString(banktypes.CreateAccountBalancesPrefixFromBech32(placeOrdersMsg.Creator)) - contractAddr := placeOrdersMsg.ContractAddr - - aclOps := []sdkacltypes.AccessOperation{ - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_NEXT_ORDER_ID, - IdentifierTemplate: hex.EncodeToString(dextypes.NextOrderIDPrefix(contractAddr)), - }, - { - AccessType: sdkacltypes.AccessType_WRITE, - ResourceType: sdkacltypes.ResourceType_KV_DEX_NEXT_ORDER_ID, - IdentifierTemplate: hex.EncodeToString(dextypes.NextOrderIDPrefix(contractAddr)), - }, - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_REGISTERED_PAIR, - IdentifierTemplate: hex.EncodeToString(dextypes.RegisteredPairPrefix(contractAddr)), - }, - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_DEPOSIT, - IdentifierTemplate: hex.EncodeToString(append( - dextypes.MemDepositPrefix(contractAddr), - []byte(placeOrdersMsg.Creator)..., - )), - }, - { - AccessType: sdkacltypes.AccessType_WRITE, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_DEPOSIT, - IdentifierTemplate: hex.EncodeToString(append( - dextypes.MemDepositPrefix(contractAddr), - []byte(placeOrdersMsg.Creator)..., - )), - }, - - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_ORDER, - IdentifierTemplate: hex.EncodeToString(dextypes.MemOrderPrefix(contractAddr)), - }, - { - AccessType: sdkacltypes.AccessType_WRITE, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_ORDER, - IdentifierTemplate: hex.EncodeToString(dextypes.MemOrderPrefix(contractAddr)), - }, - - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_DOWNSTREAM_CONTRACTS, - IdentifierTemplate: hex.EncodeToString(dextypes.MemDownstreamContractsKey(contractAddr)), - }, - { - AccessType: sdkacltypes.AccessType_WRITE, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_DOWNSTREAM_CONTRACTS, - IdentifierTemplate: hex.EncodeToString(dextypes.MemDownstreamContractsKey(contractAddr)), - }, - { - AccessType: sdkacltypes.AccessType_WRITE, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_CONTRACTS_TO_PROCESS, - IdentifierTemplate: hex.EncodeToString(dextypes.MemContractsToProcessKey(contractAddr)), - }, - - // Checks balance of sender - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_BANK_BALANCES, - IdentifierTemplate: senderBankAddrIdentifier, - }, - // Reduce the amount from the sender's balance - { - AccessType: sdkacltypes.AccessType_WRITE, - ResourceType: sdkacltypes.ResourceType_KV_BANK_BALANCES, - IdentifierTemplate: senderBankAddrIdentifier, - }, - - // update the amounts for dex module balance - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_AUTH_ADDRESS_STORE, - IdentifierTemplate: hex.EncodeToString(authtypes.AddressStoreKey(moduleAdr)), - }, - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_BANK_BALANCES, - IdentifierTemplate: hex.EncodeToString(banktypes.CreateAccountBalancesPrefix(moduleAdr)), - }, - { - AccessType: sdkacltypes.AccessType_WRITE, - ResourceType: sdkacltypes.ResourceType_KV_BANK_BALANCES, - IdentifierTemplate: hex.EncodeToString(banktypes.CreateAccountBalancesPrefix(moduleAdr)), - }, - - // Gets Account Info for the sender - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_AUTH_ADDRESS_STORE, - IdentifierTemplate: hex.EncodeToString(authtypes.CreateAddressStoreKeyFromBech32(placeOrdersMsg.Creator)), - }, - - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_CONTRACT, - IdentifierTemplate: hex.EncodeToString([]byte(dexkeeper.ContractPrefixKey)), - }, - - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_LONG_ORDER_COUNT, - IdentifierTemplate: hex.EncodeToString([]byte(dextypes.LongOrderCountKey)), - }, - - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_SHORT_ORDER_COUNT, - IdentifierTemplate: hex.EncodeToString([]byte(dextypes.ShortOrderCountKey)), - }, - } - - // Last Operation should always be a commit - aclOps = append(aclOps, *acltypes.CommitAccessOp()) - return aclOps, nil -} - -func DexCancelOrdersDependencyGenerator(_ aclkeeper.Keeper, _ sdk.Context, msg sdk.Msg) ([]sdkacltypes.AccessOperation, error) { - cancelOrdersMsg, ok := msg.(*dextypes.MsgCancelOrders) - if !ok { - return []sdkacltypes.AccessOperation{}, ErrPlaceOrdersGenerator - } - contractAddr := cancelOrdersMsg.ContractAddr - - aclOps := []sdkacltypes.AccessOperation{ - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_CANCEL, - IdentifierTemplate: hex.EncodeToString(dextypes.MemCancelPrefix(contractAddr)), - }, - { - AccessType: sdkacltypes.AccessType_WRITE, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_CANCEL, - IdentifierTemplate: hex.EncodeToString(dextypes.MemCancelPrefix(contractAddr)), - }, - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_CONTRACT, - IdentifierTemplate: hex.EncodeToString([]byte(dexkeeper.ContractPrefixKey)), - }, - { - AccessType: sdkacltypes.AccessType_READ, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_DOWNSTREAM_CONTRACTS, - IdentifierTemplate: hex.EncodeToString(dextypes.MemDownstreamContractsKey(contractAddr)), - }, - { - AccessType: sdkacltypes.AccessType_WRITE, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_DOWNSTREAM_CONTRACTS, - IdentifierTemplate: hex.EncodeToString(dextypes.MemDownstreamContractsKey(contractAddr)), - }, - { - AccessType: sdkacltypes.AccessType_WRITE, - ResourceType: sdkacltypes.ResourceType_KV_DEX_MEM_CONTRACTS_TO_PROCESS, - IdentifierTemplate: hex.EncodeToString(dextypes.MemContractsToProcessKey(contractAddr)), - }, - } - - for _, order := range cancelOrdersMsg.GetCancellations() { - priceDenom := order.GetPriceDenom() - assetDenom := order.GetAssetDenom() - aclOps = append(aclOps, GetLongShortOrderBookOps(contractAddr, priceDenom, assetDenom)...) - } - - // Last Operation should always be a commit - aclOps = append(aclOps, *acltypes.CommitAccessOp()) - return aclOps, nil -} diff --git a/aclmapping/dex/mappings_test.go b/aclmapping/dex/mappings_test.go deleted file mode 100644 index 5e189ac8d1..0000000000 --- a/aclmapping/dex/mappings_test.go +++ /dev/null @@ -1,292 +0,0 @@ -package acldexmapping_test - -import ( - "context" - "fmt" - "testing" - "time" - - "github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1" - sdk "github.com/cosmos/cosmos-sdk/types" - sdkacltypes "github.com/cosmos/cosmos-sdk/types/accesscontrol" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - acltypes "github.com/cosmos/cosmos-sdk/x/accesscontrol/types" - "github.com/k0kubun/pp/v3" - dexacl "github.com/sei-protocol/sei-chain/aclmapping/dex" - aclutils "github.com/sei-protocol/sei-chain/aclmapping/utils" - "github.com/sei-protocol/sei-chain/app" - "github.com/sei-protocol/sei-chain/app/apptesting" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - dexmsgserver "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - "github.com/sei-protocol/sei-chain/x/dex/types" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - oracletypes "github.com/sei-protocol/sei-chain/x/oracle/types" - "github.com/stretchr/testify/require" - "github.com/stretchr/testify/suite" -) - -type KeeperTestSuite struct { - apptesting.KeeperTestHelper - - queryClient dextypes.QueryClient - msgServer dextypes.MsgServer - defaultDenom string - defaultExchangeRate string - initialBalance sdk.Coins - creator string - contract string - - msgPlaceOrders *dextypes.MsgPlaceOrders - msgCancelOrders *dextypes.MsgCancelOrders -} - -func TestKeeperTestSuite(t *testing.T) { - suite.Run(t, new(KeeperTestSuite)) -} - -// Runs before each test case -func (suite *KeeperTestSuite) SetupTest() { - suite.Setup() -} - -// Explicitly only run once during setup -func (suite *KeeperTestSuite) PrepareTest() { - suite.defaultDenom = "usei" - suite.defaultExchangeRate = fmt.Sprintf("%dusei", sdk.NewDec(1700)) - - suite.initialBalance = sdk.Coins{sdk.NewInt64Coin(suite.defaultDenom, 100000000000)} - suite.initialBalance = sdk.Coins{sdk.NewInt64Coin("usei", 100000000000)} - suite.FundAcc(suite.TestAccs[0], suite.initialBalance) - - suite.queryClient = dextypes.NewQueryClient(suite.QueryHelper) - suite.msgServer = dexmsgserver.NewMsgServerImpl(suite.App.DexKeeper) - - msgValidator := sdkacltypes.NewMsgValidator(aclutils.StoreKeyToResourceTypePrefixMap) - suite.Ctx = suite.Ctx.WithMsgValidator(msgValidator) - - suite.Ctx = suite.Ctx.WithBlockHeight(10) - suite.Ctx = suite.Ctx.WithBlockTime(time.Unix(333, 0)) - - suite.creator = suite.TestAccs[0].String() - suite.contract = "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m" - - suite.App.DexKeeper.AddRegisteredPair(suite.Ctx, suite.contract, keepertest.TestPair) - suite.App.DexKeeper.SetPriceTickSizeForPair(suite.Ctx, suite.contract, keepertest.TestPair, *keepertest.TestPair.PriceTicksize) - suite.App.DexKeeper.SetQuantityTickSizeForPair(suite.Ctx, suite.contract, keepertest.TestPair, *keepertest.TestPair.PriceTicksize) - - suite.msgPlaceOrders = &types.MsgPlaceOrders{ - Creator: suite.creator, - ContractAddr: suite.contract, - Orders: []*types.Order{ - { - Price: sdk.MustNewDecFromStr("10"), - Quantity: sdk.MustNewDecFromStr("10"), - Data: "", - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_LIMIT, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - { - Price: sdk.MustNewDecFromStr("20"), - Quantity: sdk.MustNewDecFromStr("5"), - Data: "", - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_MARKET, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - }, - } - - suite.msgCancelOrders = &types.MsgCancelOrders{ - Creator: suite.creator, - ContractAddr: suite.contract, - Cancellations: []*types.Cancellation{ - { - Id: 1, - Price: sdk.MustNewDecFromStr("10"), - Creator: suite.creator, - PositionDirection: types.PositionDirection_LONG, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - { - Id: 2, - Creator: suite.creator, - Price: sdk.MustNewDecFromStr("20"), - PositionDirection: types.PositionDirection_SHORT, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - }, - } -} - -func (suite *KeeperTestSuite) TestMsgPlaceOrder() { - suite.PrepareTest() - tests := []struct { - name string - expectedError error - msg *dextypes.MsgPlaceOrders - dynamicDep bool - }{ - { - name: "default place order", - msg: suite.msgPlaceOrders, - expectedError: sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated"), - dynamicDep: true, - }, - { - name: "dont check synchronous", - msg: suite.msgPlaceOrders, - expectedError: sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated"), - dynamicDep: false, - }, - } - for _, tc := range tests { - suite.Run(fmt.Sprintf("Test Case: %s", tc.name), func() { - goCtx := context.WithValue(suite.Ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(suite.App.GetMemKey(dextypes.MemStoreKey))) - suite.Ctx = suite.Ctx.WithContext(goCtx) - - handlerCtx, cms := aclutils.CacheTxContext(suite.Ctx) - _, err := suite.msgServer.PlaceOrders( - sdk.WrapSDKContext(handlerCtx), - tc.msg, - ) - - depdenencies, _ := dexacl.DexPlaceOrdersDependencyGenerator( - suite.App.AccessControlKeeper, - handlerCtx, - tc.msg, - ) - - if !tc.dynamicDep { - depdenencies = sdkacltypes.SynchronousAccessOps() - } - - if tc.expectedError != nil { - suite.Require().EqualError(err, tc.expectedError.Error()) - } else { - suite.Require().NoError(err) - } - - missing := handlerCtx.MsgValidator().ValidateAccessOperations(depdenencies, cms.GetEvents()) - pp.Default.SetColoringEnabled(false) - - suite.Require().Empty(missing) - }) - } -} - -func (suite *KeeperTestSuite) TestMsgCancelOrder() { - suite.PrepareTest() - tests := []struct { - name string - expectedError error - msg *dextypes.MsgCancelOrders - dynamicDep bool - }{ - { - name: "default cancel order", - msg: suite.msgCancelOrders, - expectedError: sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated"), - dynamicDep: true, - }, - { - name: "dont check synchronous", - msg: suite.msgCancelOrders, - expectedError: sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated"), - dynamicDep: false, - }, - } - for _, tc := range tests { - suite.Run(fmt.Sprintf("Test Case: %s", tc.name), func() { - goCtx := context.WithValue(suite.Ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(suite.App.GetMemKey(dextypes.MemStoreKey))) - suite.Ctx = suite.Ctx.WithContext(goCtx) - - _, err := suite.msgServer.PlaceOrders( - sdk.WrapSDKContext(suite.Ctx), - suite.msgPlaceOrders, - ) - - handlerCtx, cms := aclutils.CacheTxContext(suite.Ctx) - _, err = suite.msgServer.CancelOrders( - sdk.WrapSDKContext(handlerCtx), - tc.msg, - ) - - depdenencies, _ := dexacl.DexCancelOrdersDependencyGenerator( - suite.App.AccessControlKeeper, - handlerCtx, - tc.msg, - ) - - if !tc.dynamicDep { - depdenencies = sdkacltypes.SynchronousAccessOps() - } - - if tc.expectedError != nil { - suite.Require().EqualError(err, tc.expectedError.Error()) - } else { - suite.Require().NoError(err) - } - - missing := handlerCtx.MsgValidator().ValidateAccessOperations(depdenencies, cms.GetEvents()) - suite.Require().Empty(missing) - }) - } -} - -func TestGeneratorInvalidMessageTypes(t *testing.T) { - tm := time.Now().UTC() - valPub := secp256k1.GenPrivKey().PubKey() - testWrapper := app.NewTestWrapper(t, tm, valPub, false) - - oracleVote := oracletypes.MsgAggregateExchangeRateVote{ - ExchangeRates: "1usei", - Feeder: "test", - Validator: "validator", - } - - _, err := dexacl.DexPlaceOrdersDependencyGenerator( - testWrapper.App.AccessControlKeeper, - testWrapper.Ctx, - &oracleVote, - ) - require.Error(t, err) - - _, err = dexacl.DexCancelOrdersDependencyGenerator( - testWrapper.App.AccessControlKeeper, - testWrapper.Ctx, - &oracleVote, - ) - require.Error(t, err) -} - -func (suite *KeeperTestSuite) TestMsgPlaceOrderGenerator() { - suite.PrepareTest() - - accessOps, err := dexacl.DexPlaceOrdersDependencyGenerator( - suite.App.AccessControlKeeper, - suite.Ctx, - suite.msgPlaceOrders, - ) - require.NoError(suite.T(), err) - err = acltypes.ValidateAccessOps(accessOps) - require.NoError(suite.T(), err) -} - -func (suite *KeeperTestSuite) TestMsgCancelOrderGenerator() { - suite.PrepareTest() - accessOps, err := dexacl.DexCancelOrdersDependencyGenerator( - suite.App.AccessControlKeeper, - suite.Ctx, - suite.msgCancelOrders, - ) - require.NoError(suite.T(), err) - err = acltypes.ValidateAccessOps(accessOps) - require.NoError(suite.T(), err) -} diff --git a/aclmapping/utils/resource_type.go b/aclmapping/utils/resource_type.go index 34fd3cbd60..747cc086cd 100644 --- a/aclmapping/utils/resource_type.go +++ b/aclmapping/utils/resource_type.go @@ -11,8 +11,6 @@ import ( feegranttypes "github.com/cosmos/cosmos-sdk/x/feegrant" slashingtypes "github.com/cosmos/cosmos-sdk/x/slashing/types" stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" - dexkeeper "github.com/sei-protocol/sei-chain/x/dex/keeper" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" epochtypes "github.com/sei-protocol/sei-chain/x/epoch/types" evmtypes "github.com/sei-protocol/sei-chain/x/evm/types" oracletypes "github.com/sei-protocol/sei-chain/x/oracle/types" @@ -29,40 +27,6 @@ var StoreKeyToResourceTypePrefixMap = aclsdktypes.StoreKeyToResourceTypePrefixMa aclsdktypes.ResourceType_KV: aclsdktypes.EmptyPrefix, aclsdktypes.ResourceType_Mem: aclsdktypes.EmptyPrefix, }, - dextypes.StoreKey: { - aclsdktypes.ResourceType_KV_DEX: aclsdktypes.EmptyPrefix, - aclsdktypes.ResourceType_DexMem: aclsdktypes.EmptyPrefix, - aclsdktypes.ResourceType_KV_DEX_CONTRACT_LONGBOOK: dextypes.KeyPrefix(dextypes.LongBookKey), - aclsdktypes.ResourceType_KV_DEX_CONTRACT_SHORTBOOK: dextypes.KeyPrefix(dextypes.ShortBookKey), - // pricedenom and assetdenoms are the prefixes - aclsdktypes.ResourceType_KV_DEX_PAIR_PREFIX: aclsdktypes.EmptyPrefix, - aclsdktypes.ResourceType_KV_DEX_TWAP: dextypes.KeyPrefix(dextypes.TwapKey), - aclsdktypes.ResourceType_KV_DEX_PRICE: dextypes.KeyPrefix(dextypes.PriceKey), - aclsdktypes.ResourceType_KV_DEX_SETTLEMENT_ENTRY: dextypes.KeyPrefix(dextypes.SettlementEntryKey), - aclsdktypes.ResourceType_KV_DEX_REGISTERED_PAIR: dextypes.KeyPrefix(dextypes.RegisteredPairKey), - aclsdktypes.ResourceType_KV_DEX_ORDER: dextypes.KeyPrefix(dextypes.OrderKey), - aclsdktypes.ResourceType_KV_DEX_CANCEL: dextypes.KeyPrefix(dextypes.CancelKey), - aclsdktypes.ResourceType_KV_DEX_ACCOUNT_ACTIVE_ORDERS: dextypes.KeyPrefix(dextypes.AccountActiveOrdersKey), - aclsdktypes.ResourceType_KV_DEX_ASSET_LIST: dextypes.KeyPrefix(dextypes.AssetListKey), - aclsdktypes.ResourceType_KV_DEX_NEXT_ORDER_ID: dextypes.KeyPrefix(dextypes.NextOrderIDKey), - aclsdktypes.ResourceType_KV_DEX_NEXT_SETTLEMENT_ID: dextypes.KeyPrefix(dextypes.NextSettlementIDKey), - aclsdktypes.ResourceType_KV_DEX_MATCH_RESULT: dextypes.KeyPrefix(dextypes.MatchResultKey), - aclsdktypes.ResourceType_KV_DEX_CONTRACT: dextypes.KeyPrefix(dexkeeper.ContractPrefixKey), - aclsdktypes.ResourceType_KV_DEX_ORDER_BOOK: dextypes.KeyPrefix(dextypes.NextOrderIDKey), - aclsdktypes.ResourceType_KV_DEX_LONG_ORDER_COUNT: dextypes.KeyPrefix(dextypes.LongOrderCountKey), - aclsdktypes.ResourceType_KV_DEX_SHORT_ORDER_COUNT: dextypes.KeyPrefix(dextypes.ShortOrderCountKey), - // SETTLEMENT keys are prefixed with account and order id - aclsdktypes.ResourceType_KV_DEX_SETTLEMENT_ORDER_ID: aclsdktypes.EmptyPrefix, - aclsdktypes.ResourceType_KV_DEX_SETTLEMENT: aclsdktypes.EmptyPrefix, - }, - dextypes.MemStoreKey: { - // mem - aclsdktypes.ResourceType_KV_DEX_MEM_ORDER: dextypes.KeyPrefix(dextypes.MemOrderKey), - aclsdktypes.ResourceType_KV_DEX_MEM_CANCEL: dextypes.KeyPrefix(dextypes.MemCancelKey), - aclsdktypes.ResourceType_KV_DEX_MEM_DEPOSIT: dextypes.KeyPrefix(dextypes.MemDepositKey), - aclsdktypes.ResourceType_KV_DEX_MEM_CONTRACTS_TO_PROCESS: dextypes.KeyPrefix(dextypes.MemContractsToProcess), - aclsdktypes.ResourceType_KV_DEX_MEM_DOWNSTREAM_CONTRACTS: dextypes.KeyPrefix(dextypes.MemDownstreamContracts), - }, banktypes.StoreKey: { aclsdktypes.ResourceType_KV_BANK: aclsdktypes.EmptyPrefix, aclsdktypes.ResourceType_KV_BANK_BALANCES: banktypes.BalancesPrefix, @@ -173,40 +137,6 @@ var StoreKeyToResourceTypePrefixMap = aclsdktypes.StoreKeyToResourceTypePrefixMa // ResourceTypeToStoreKeyMap this maps between resource types and their respective storekey var ResourceTypeToStoreKeyMap = aclsdktypes.ResourceTypeToStoreKeyMap{ // ANY, KV, and MEM are intentionally excluded because they don't map to a specific store key - - // ~~~~ DEX Resource Types ~~~~ - aclsdktypes.ResourceType_KV_DEX: dextypes.StoreKey, - aclsdktypes.ResourceType_DexMem: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_CONTRACT_LONGBOOK: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_CONTRACT_SHORTBOOK: dextypes.StoreKey, - // pricedenom and assetdenoms are the prefixes - aclsdktypes.ResourceType_KV_DEX_PAIR_PREFIX: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_TWAP: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_PRICE: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_SETTLEMENT_ENTRY: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_REGISTERED_PAIR: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_ORDER: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_CANCEL: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_ACCOUNT_ACTIVE_ORDERS: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_ASSET_LIST: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_NEXT_ORDER_ID: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_NEXT_SETTLEMENT_ID: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_MATCH_RESULT: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_CONTRACT: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_ORDER_BOOK: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_LONG_ORDER_COUNT: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_SHORT_ORDER_COUNT: dextypes.StoreKey, - // SETTLEMENT keys are prefixed with account and order id - aclsdktypes.ResourceType_KV_DEX_SETTLEMENT_ORDER_ID: dextypes.StoreKey, - aclsdktypes.ResourceType_KV_DEX_SETTLEMENT: dextypes.StoreKey, - - // ~~~~ DEX MEM Resource Types ~~~~ - aclsdktypes.ResourceType_KV_DEX_MEM_ORDER: dextypes.MemStoreKey, - aclsdktypes.ResourceType_KV_DEX_MEM_CANCEL: dextypes.MemStoreKey, - aclsdktypes.ResourceType_KV_DEX_MEM_DEPOSIT: dextypes.MemStoreKey, - aclsdktypes.ResourceType_KV_DEX_MEM_CONTRACTS_TO_PROCESS: dextypes.MemStoreKey, - aclsdktypes.ResourceType_KV_DEX_MEM_DOWNSTREAM_CONTRACTS: dextypes.MemStoreKey, - // ~~~~ BANK Resource Types ~~~~ aclsdktypes.ResourceType_KV_BANK: banktypes.StoreKey, aclsdktypes.ResourceType_KV_BANK_BALANCES: banktypes.StoreKey, diff --git a/app/ante.go b/app/ante.go index 3106816df2..73fe48a616 100644 --- a/app/ante.go +++ b/app/ante.go @@ -14,9 +14,6 @@ import ( ibckeeper "github.com/cosmos/ibc-go/v3/modules/core/keeper" "github.com/sei-protocol/sei-chain/app/antedecorators" "github.com/sei-protocol/sei-chain/app/antedecorators/depdecorators" - "github.com/sei-protocol/sei-chain/x/dex" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - dexkeeper "github.com/sei-protocol/sei-chain/x/dex/keeper" evmante "github.com/sei-protocol/sei-chain/x/evm/ante" evmkeeper "github.com/sei-protocol/sei-chain/x/evm/keeper" "github.com/sei-protocol/sei-chain/x/oracle" @@ -32,11 +29,9 @@ type HandlerOptions struct { WasmConfig *wasmtypes.WasmConfig WasmKeeper *wasm.Keeper OracleKeeper *oraclekeeper.Keeper - DexKeeper *dexkeeper.Keeper AccessControlKeeper *aclkeeper.Keeper EVMKeeper *evmkeeper.Keeper TXCounterStoreKey sdk.StoreKey - CheckTxMemState *dexcache.MemState LatestCtxGetter func() sdk.Context TracingInfo *tracing.Info @@ -70,9 +65,6 @@ func NewAnteHandlerAndDepGenerator(options HandlerOptions) (sdk.AnteHandler, sdk if options.TracingInfo == nil { return nil, nil, sdkerrors.Wrap(sdkerrors.ErrLogic, "tracing info is required for ante builder") } - if options.CheckTxMemState == nil { - return nil, nil, sdkerrors.Wrap(sdkerrors.ErrLogic, "checktx memstate is required for ante builder") - } if options.EVMKeeper == nil { return nil, nil, sdkerrors.Wrap(sdkerrors.ErrLogic, "evm keeper is required for ante builder") } @@ -109,8 +101,6 @@ func NewAnteHandlerAndDepGenerator(options HandlerOptions) (sdk.AnteHandler, sdk sdk.DefaultWrappedAnteDecorator(evmante.NewEVMAddressDecorator(options.EVMKeeper, options.EVMKeeper.AccountKeeper())), sdk.DefaultWrappedAnteDecorator(antedecorators.NewAuthzNestedMessageDecorator()), sdk.DefaultWrappedAnteDecorator(ibcante.NewAnteDecorator(options.IBCKeeper)), - sdk.DefaultWrappedAnteDecorator(dex.NewTickSizeMultipleDecorator(*options.DexKeeper)), - dex.NewCheckDexGasDecorator(*options.DexKeeper, options.CheckTxMemState), antedecorators.NewACLWasmDependencyDecorator(*options.AccessControlKeeper, *options.WasmKeeper), } diff --git a/app/ante_test.go b/app/ante_test.go index a433e5d830..dfbf7a5337 100644 --- a/app/ante_test.go +++ b/app/ante_test.go @@ -99,10 +99,8 @@ func (suite *AnteTestSuite) SetupTest(isCheckTx bool) { WasmConfig: &wasmConfig, WasmKeeper: &suite.App.WasmKeeper, OracleKeeper: &suite.App.OracleKeeper, - DexKeeper: &suite.App.DexKeeper, AccessControlKeeper: &suite.App.AccessControlKeeper, TracingInfo: tracingInfo, - CheckTxMemState: suite.App.CheckTxMemState, EVMKeeper: &suite.App.EvmKeeper, LatestCtxGetter: func() sdk.Context { return suite.Ctx }, }, diff --git a/app/antedecorators/gasless.go b/app/antedecorators/gasless.go index f71798b1da..2835b93ba8 100644 --- a/app/antedecorators/gasless.go +++ b/app/antedecorators/gasless.go @@ -1,7 +1,6 @@ package antedecorators import ( - "bytes" "encoding/hex" storetypes "github.com/cosmos/cosmos-sdk/store/types" @@ -9,7 +8,6 @@ import ( sdkacltypes "github.com/cosmos/cosmos-sdk/types/accesscontrol" sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" evmkeeper "github.com/sei-protocol/sei-chain/x/evm/keeper" evmtypes "github.com/sei-protocol/sei-chain/x/evm/types" oraclekeeper "github.com/sei-protocol/sei-chain/x/oracle/keeper" @@ -118,15 +116,6 @@ func IsTxGasless(tx sdk.Tx, ctx sdk.Context, oracleKeeper oraclekeeper.Keeper, e } for _, msg := range tx.GetMsgs() { switch m := msg.(type) { - case *dextypes.MsgPlaceOrders: - if !dexPlaceOrdersIsGasless(m) { - return false, nil - } - - case *dextypes.MsgCancelOrders: - if !dexCancelOrdersIsGasless(m) { - return false, nil - } case *oracletypes.MsgAggregateExchangeRateVote: isGasless, err := oracleVoteIsGasless(m, ctx, oracleKeeper) if err != nil || !isGasless { @@ -143,33 +132,6 @@ func IsTxGasless(tx sdk.Tx, ctx sdk.Context, oracleKeeper oraclekeeper.Keeper, e return true, nil } -func dexPlaceOrdersIsGasless(_ *dextypes.MsgPlaceOrders) bool { - return false -} - -// WhitelistedGaslessCancellationAddrs TODO: migrate this into params state -var WhitelistedGaslessCancellationAddrs = []sdk.AccAddress{} - -func dexCancelOrdersIsGasless(msg *dextypes.MsgCancelOrders) bool { - return allSignersWhitelisted(msg) -} - -func allSignersWhitelisted(msg *dextypes.MsgCancelOrders) bool { - for _, signer := range msg.GetSigners() { - isWhitelisted := false - for _, whitelisted := range WhitelistedGaslessCancellationAddrs { - if bytes.Compare(signer, whitelisted) == 0 { //nolint:gosimple - isWhitelisted = true - break - } - } - if !isWhitelisted { - return false - } - } - return true -} - func oracleVoteIsGasless(msg *oracletypes.MsgAggregateExchangeRateVote, ctx sdk.Context, keeper oraclekeeper.Keeper) (bool, error) { feederAddr, err := sdk.AccAddressFromBech32(msg.Feeder) if err != nil { diff --git a/app/antedecorators/gasless_test.go b/app/antedecorators/gasless_test.go index 58143c1ceb..8152dceab1 100644 --- a/app/antedecorators/gasless_test.go +++ b/app/antedecorators/gasless_test.go @@ -8,12 +8,10 @@ import ( "github.com/cosmos/cosmos-sdk/types/accesscontrol" "github.com/cosmos/cosmos-sdk/x/staking" "github.com/sei-protocol/sei-chain/app/antedecorators" - "github.com/sei-protocol/sei-chain/x/dex/types" evmkeeper "github.com/sei-protocol/sei-chain/x/evm/keeper" oraclekeeper "github.com/sei-protocol/sei-chain/x/oracle/keeper" oracletypes "github.com/sei-protocol/sei-chain/x/oracle/types" "github.com/stretchr/testify/require" - "github.com/tendermint/tendermint/crypto/secp256k1" tmproto "github.com/tendermint/tendermint/proto/tendermint/types" ) @@ -151,40 +149,11 @@ func TestOracleVoteGasless(t *testing.T) { require.True(t, gasless) } -func TestDexCancelOrderGasless(t *testing.T) { - addr1 := sdk.AccAddress(secp256k1.GenPrivKey().PubKey().Address()) - addr2 := sdk.AccAddress(secp256k1.GenPrivKey().PubKey().Address()) - - antedecorators.WhitelistedGaslessCancellationAddrs = []sdk.AccAddress{ - addr2, - } - - cancelMsg1 := types.MsgCancelOrders{ - Creator: addr1.String(), - } - cancelMsg2 := types.MsgCancelOrders{ - Creator: addr2.String(), - } - // not whitelisted - // reset gasless - gasless = true - err := CallGaslessDecoratorWithMsg(sdk.NewContext(nil, tmproto.Header{}, false, nil).WithIsCheckTx(true), &cancelMsg1, oraclekeeper.Keeper{}, nil) - require.NoError(t, err) - require.False(t, gasless) - - // whitelisted - // reset gasless - gasless = true - err = CallGaslessDecoratorWithMsg(sdk.NewContext(nil, tmproto.Header{}, false, nil).WithIsCheckTx(true), &cancelMsg2, oraclekeeper.Keeper{}, nil) - require.NoError(t, err) - require.True(t, gasless) -} - func TestNonGaslessMsg(t *testing.T) { // this needs to be updated if its changed from constant true // reset gasless gasless = true - err := CallGaslessDecoratorWithMsg(sdk.NewContext(nil, tmproto.Header{}, false, nil).WithIsCheckTx(true), &types.MsgRegisterContract{}, oraclekeeper.Keeper{}, nil) + err := CallGaslessDecoratorWithMsg(sdk.NewContext(nil, tmproto.Header{}, false, nil).WithIsCheckTx(true), &oracletypes.MsgDelegateFeedConsent{}, oraclekeeper.Keeper{}, nil) require.NoError(t, err) require.False(t, gasless) } diff --git a/app/antedecorators/priority_test.go b/app/antedecorators/priority_test.go index bc5ceff197..4083fac1eb 100644 --- a/app/antedecorators/priority_test.go +++ b/app/antedecorators/priority_test.go @@ -7,7 +7,6 @@ import ( sdk "github.com/cosmos/cosmos-sdk/types" "github.com/sei-protocol/sei-chain/app/antedecorators" - "github.com/sei-protocol/sei-chain/x/dex/types" oracletypes "github.com/sei-protocol/sei-chain/x/oracle/types" "github.com/stretchr/testify/require" tmproto "github.com/tendermint/tendermint/proto/tendermint/types" @@ -42,7 +41,7 @@ func TestPriorityAnteDecoratorTooHighPriority(t *testing.T) { ctx.WithPriority(math.MaxInt64-50), FakeTx{ FakeMsgs: []sdk.Msg{ - &types.MsgPlaceOrders{}, + &oracletypes.MsgDelegateFeedConsent{}, }, }, false, diff --git a/app/app.go b/app/app.go index 2aaedeca80..d459b12ade 100644 --- a/app/app.go +++ b/app/app.go @@ -140,12 +140,6 @@ import ( "github.com/sei-protocol/sei-chain/utils/metrics" - dexmodule "github.com/sei-protocol/sei-chain/x/dex" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - dexmodulekeeper "github.com/sei-protocol/sei-chain/x/dex/keeper" - dexmoduletypes "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - oraclemodule "github.com/sei-protocol/sei-chain/x/oracle" oraclekeeper "github.com/sei-protocol/sei-chain/x/oracle/keeper" oracletypes "github.com/sei-protocol/sei-chain/x/oracle/types" @@ -217,7 +211,6 @@ var ( oraclemodule.AppModuleBasic{}, evm.AppModuleBasic{}, wasm.AppModuleBasic{}, - dexmodule.AppModuleBasic{}, epochmodule.AppModuleBasic{}, tokenfactorymodule.AppModuleBasic{}, // this line is used by starport scaffolding # stargate/app/moduleBasic @@ -236,7 +229,6 @@ var ( oracletypes.ModuleName: nil, wasm.ModuleName: {authtypes.Burner}, evmtypes.ModuleName: {authtypes.Minter, authtypes.Burner}, - dexmoduletypes.ModuleName: {authtypes.Burner}, tokenfactorytypes.ModuleName: {authtypes.Minter, authtypes.Burner}, // this line is used by starport scaffolding # stargate/app/maccPerms } @@ -350,8 +342,6 @@ type App struct { ScopedTransferKeeper capabilitykeeper.ScopedKeeper ScopedWasmKeeper capabilitykeeper.ScopedKeeper - DexKeeper dexmodulekeeper.Keeper - EpochKeeper epochmodulekeeper.Keeper TokenFactoryKeeper tokenfactorykeeper.Keeper @@ -376,10 +366,6 @@ type App struct { mounter func() - CheckTxMemState *dexcache.MemState - ProcessProposalMemState *dexcache.MemState - MemState *dexcache.MemState - HardForkManager *upgrades.HardForkManager encodingConfig appparams.EncodingConfig @@ -427,13 +413,12 @@ func New( govtypes.StoreKey, paramstypes.StoreKey, ibchost.StoreKey, upgradetypes.StoreKey, feegrant.StoreKey, evidencetypes.StoreKey, ibctransfertypes.StoreKey, capabilitytypes.StoreKey, oracletypes.StoreKey, evmtypes.StoreKey, wasm.StoreKey, - dexmoduletypes.StoreKey, epochmoduletypes.StoreKey, tokenfactorytypes.StoreKey, // this line is used by starport scaffolding # stargate/app/storeKey ) tkeys := sdk.NewTransientStoreKeys(paramstypes.TStoreKey, evmtypes.TransientStoreKey) - memKeys := sdk.NewMemoryStoreKeys(capabilitytypes.MemStoreKey, dexmoduletypes.MemStoreKey, banktypes.DeferredCacheStoreKey, oracletypes.MemStoreKey) + memKeys := sdk.NewMemoryStoreKeys(capabilitytypes.MemStoreKey, banktypes.DeferredCacheStoreKey, oracletypes.MemStoreKey) app := &App{ BaseApp: bApp, @@ -550,15 +535,7 @@ func New( app.GetSubspace(epochmoduletypes.ModuleName), ).SetHooks(epochmoduletypes.NewMultiEpochHooks( app.MintKeeper.Hooks())) - app.DexKeeper = *dexmodulekeeper.NewKeeper( - appCodec, - keys[dexmoduletypes.StoreKey], - memKeys[dexmoduletypes.MemStoreKey], - app.GetSubspace(dexmoduletypes.ModuleName), - app.EpochKeeper, - app.BankKeeper, - app.AccountKeeper, - ) + app.TokenFactoryKeeper = tokenfactorykeeper.NewKeeper( appCodec, app.keys[tokenfactorytypes.StoreKey], @@ -574,7 +551,6 @@ func New( wasmOpts = append( wasmbinding.RegisterCustomPlugins( &app.OracleKeeper, - &app.DexKeeper, &app.EpochKeeper, &app.TokenFactoryKeeper, &app.AccountKeeper, @@ -674,8 +650,6 @@ func New( aclOpts..., ) - app.DexKeeper.SetWasmKeeper(&app.WasmKeeper) - dexModule := dexmodule.NewAppModule(appCodec, app.DexKeeper, app.AccountKeeper, app.BankKeeper, app.WasmKeeper, app.GetBaseApp().TracingInfo) epochModule := epochmodule.NewAppModule(appCodec, app.EpochKeeper, app.AccountKeeper, app.BankKeeper) // register the proposal types @@ -685,7 +659,6 @@ func New( AddRoute(distrtypes.RouterKey, distr.NewCommunityPoolSpendProposalHandler(app.DistrKeeper)). AddRoute(upgradetypes.RouterKey, upgrade.NewSoftwareUpgradeProposalHandler(app.UpgradeKeeper)). AddRoute(ibcclienttypes.RouterKey, ibcclient.NewClientProposalHandler(app.IBCKeeper.ClientKeeper)). - AddRoute(dexmoduletypes.RouterKey, dexmodule.NewProposalHandler(app.DexKeeper)). AddRoute(minttypes.RouterKey, mint.NewProposalHandler(app.MintKeeper)). AddRoute(tokenfactorytypes.RouterKey, tokenfactorymodule.NewProposalHandler(app.TokenFactoryKeeper)). AddRoute(acltypes.ModuleName, aclmodule.NewProposalHandler(app.AccessControlKeeper)). @@ -763,7 +736,6 @@ func New( wasm.NewAppModule(appCodec, &app.WasmKeeper, app.StakingKeeper, app.AccountKeeper, app.BankKeeper), evm.NewAppModule(appCodec, &app.EvmKeeper), transferModule, - dexModule, epochModule, tokenfactorymodule.NewAppModule(app.TokenFactoryKeeper, app.AccountKeeper, app.BankKeeper), authzmodule.NewAppModule(appCodec, app.AuthzKeeper, app.AccountKeeper, app.BankKeeper, app.interfaceRegistry), @@ -795,7 +767,6 @@ func New( ibchost.ModuleName, ibctransfertypes.ModuleName, oracletypes.ModuleName, - dexmoduletypes.ModuleName, evmtypes.ModuleName, wasm.ModuleName, tokenfactorytypes.ModuleName, @@ -827,7 +798,6 @@ func New( ibctransfertypes.ModuleName, oracletypes.ModuleName, epochmoduletypes.ModuleName, - dexmoduletypes.ModuleName, evmtypes.ModuleName, wasm.ModuleName, tokenfactorytypes.ModuleName, @@ -853,7 +823,6 @@ func New( vestingtypes.ModuleName, crisistypes.ModuleName, ibchost.ModuleName, - dexmoduletypes.ModuleName, genutiltypes.ModuleName, evidencetypes.ModuleName, ibctransfertypes.ModuleName, @@ -890,7 +859,6 @@ func New( wasm.NewAppModule(appCodec, &app.WasmKeeper, app.StakingKeeper, app.AccountKeeper, app.BankKeeper), ibc.NewAppModule(app.IBCKeeper), transferModule, - dexModule, epochModule, tokenfactorymodule.NewAppModule(app.TokenFactoryKeeper, app.AccountKeeper, app.BankKeeper), // this line is used by starport scaffolding # stargate/app/appModule @@ -908,10 +876,6 @@ func New( } app.mounter() - app.CheckTxMemState = dexcache.NewMemState(app.GetMemKey(dexmoduletypes.MemStoreKey)) - app.ProcessProposalMemState = dexcache.NewMemState(app.GetMemKey(dexmoduletypes.MemStoreKey)) - app.MemState = dexcache.NewMemState(app.GetMemKey(dexmoduletypes.MemStoreKey)) - // initialize BaseApp app.SetInitChainer(app.InitChainer) app.SetBeginBlocker(app.BeginBlocker) @@ -935,11 +899,9 @@ func New( WasmConfig: &wasmConfig, WasmKeeper: &app.WasmKeeper, OracleKeeper: &app.OracleKeeper, - DexKeeper: &app.DexKeeper, EVMKeeper: &app.EvmKeeper, TracingInfo: app.GetBaseApp().TracingInfo, AccessControlKeeper: &app.AccessControlKeeper, - CheckTxMemState: app.CheckTxMemState, LatestCtxGetter: func() sdk.Context { return app.GetCheckCtx() }, @@ -1071,6 +1033,16 @@ func (app *App) SetStoreUpgradeHandlers() { Added: []string{evmtypes.StoreKey}, } + // configure store loader that checks if version == upgradeHeight and applies store upgrades + app.SetStoreLoader(upgradetypes.UpgradeStoreLoader(upgradeInfo.Height, &storeUpgrades)) + } + // TODO: change this upgrade name if the planned upgrade version number ends up changing more + if upgradeInfo.Name == "v5.7.0" && !app.UpgradeKeeper.IsSkipHeight(upgradeInfo.Height) { + dexStoreKeyName := "dex" + storeUpgrades := storetypes.StoreUpgrades{ + Deleted: []string{dexStoreKeyName}, + } + // configure store loader that checks if version == upgradeHeight and applies store upgrades app.SetStoreLoader(upgradetypes.UpgradeStoreLoader(upgradeInfo.Height, &storeUpgrades)) } @@ -1108,7 +1080,6 @@ func (app *App) InitChainer(ctx sdk.Context, req abci.RequestInitChain) abci.Res if err := json.Unmarshal(req.AppStateBytes, &genesisState); err != nil { panic(err) } - ctx = ctx.WithContext(app.decorateContextWithDexMemState(ctx.Context())) app.UpgradeKeeper.SetModuleVersionMap(ctx, app.mm.GetVersionMap()) return app.mm.InitGenesis(ctx, app.appCodec, genesisState) } @@ -1155,7 +1126,6 @@ func (app *App) ProcessProposalHandler(ctx sdk.Context, req *abci.RequestProcess app.optimisticProcessingInfo.Completion <- struct{}{} } else { go func() { - ctx = ctx.WithContext(app.decorateProcessProposalContextWithDexMemState(ctx.Context())) events, txResults, endBlockResp, _ := app.ProcessBlock(ctx, req.Txs, req, req.ProposedLastCommit) optimisticProcessingInfo.Events = events optimisticProcessingInfo.TxRes = txResults @@ -1195,7 +1165,6 @@ func (app *App) FinalizeBlocker(ctx sdk.Context, req *abci.RequestFinalizeBlock) } metrics.IncrementOptimisticProcessingCounter(false) ctx.Logger().Info("optimistic processing ineligible") - ctx = ctx.WithContext(app.decorateContextWithDexMemState(ctx.Context())) events, txResults, endBlockResp, _ := app.ProcessBlock(ctx, req.Txs, req, req.DecidedLastCommit) @@ -1405,7 +1374,6 @@ func (app *App) ProcessTxs( dependencyDag.TxMsgAccessOpMapping, absoluteTxIndices, ) - oldDexMemState := dexutils.GetMemState(ctx.Context()).DeepCopy() if ok { // Write the results back to the concurrent contexts - if concurrent execution fails, // this should not be called and the state is rolled back and retried with synchronous execution @@ -1416,13 +1384,6 @@ func (app *App) ProcessTxs( ctx = app.addBadWasmDependenciesToContext(ctx, concurrentResults) ctx.Logger().Error("Concurrent Execution failed, retrying with Synchronous") - oldDexMemStateCtx := context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, oldDexMemState) - ctx = ctx.WithContext(oldDexMemStateCtx) - - dexMemState := dexutils.GetMemState(ctx.Context()) - dexMemState.Clear(ctx) - dexMemState.ClearContractToDependencies(ctx) - txResults := app.ProcessBlockSynchronous(ctx, txs, typedTxs, absoluteTxIndices) processBlockCache.Write() return txResults, ctx @@ -1448,12 +1409,6 @@ func (app *App) PartitionPrioritizedTxs(_ sdk.Context, txs [][]byte, typedTxs [] switch msg.(type) { case *oracletypes.MsgAggregateExchangeRateVote: prioritized = true - case *dexmoduletypes.MsgRegisterContract: - prioritized = true - case *dexmoduletypes.MsgUnregisterContract: - prioritized = true - case *dexmoduletypes.MsgUnsuspendContract: - prioritized = true default: prioritized = false break msgLoop @@ -1563,8 +1518,6 @@ func (app *App) BuildDependenciesAndRunTxs(ctx sdk.Context, txs [][]byte, typedT func (app *App) ProcessBlock(ctx sdk.Context, txs [][]byte, req BlockProcessRequest, lastCommit abci.CommitInfo) ([]abci.Event, []*abci.ExecTxResult, abci.ResponseEndBlock, error) { ctx = ctx.WithIsOCCEnabled(app.OccEnabled()) - goCtx := app.decorateContextWithDexMemState(ctx.Context()) - ctx = ctx.WithContext(goCtx) events := []abci.Event{} beginBlockReq := abci.RequestBeginBlock{ @@ -1925,7 +1878,6 @@ func initParamsKeeper(appCodec codec.BinaryCodec, legacyAmino *codec.LegacyAmino paramsKeeper.Subspace(oracletypes.ModuleName) paramsKeeper.Subspace(wasm.ModuleName) paramsKeeper.Subspace(evmtypes.ModuleName) - paramsKeeper.Subspace(dexmoduletypes.ModuleName) paramsKeeper.Subspace(epochmoduletypes.ModuleName) paramsKeeper.Subspace(tokenfactorytypes.ModuleName) // this line is used by starport scaffolding # stargate/app/paramSubspace @@ -1947,14 +1899,6 @@ func (app *App) BlacklistedAccAddrs() map[string]bool { return blacklistedAddrs } -func (app *App) decorateProcessProposalContextWithDexMemState(base context.Context) context.Context { - return context.WithValue(base, dexutils.DexMemStateContextKey, app.ProcessProposalMemState) -} - -func (app *App) decorateContextWithDexMemState(base context.Context) context.Context { - return context.WithValue(base, dexutils.DexMemStateContextKey, app.MemState) -} - func init() { // override max wasm size to 2MB wasmtypes.MaxWasmSize = 2 * 1024 * 1024 diff --git a/app/app_test.go b/app/app_test.go index ad689e27db..60d51d42f5 100644 --- a/app/app_test.go +++ b/app/app_test.go @@ -26,7 +26,6 @@ import ( "github.com/k0kubun/pp/v3" "github.com/sei-protocol/sei-chain/app" testkeeper "github.com/sei-protocol/sei-chain/testutil/keeper" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" "github.com/sei-protocol/sei-chain/x/evm/config" evmtypes "github.com/sei-protocol/sei-chain/x/evm/types" "github.com/sei-protocol/sei-chain/x/evm/types/ethtx" @@ -135,25 +134,6 @@ func TestPartitionPrioritizedTxs(t *testing.T) { Validator: validator, } - contractRegisterMsg := &dextypes.MsgRegisterContract{ - Creator: account, - Contract: &dextypes.ContractInfoV2{ - CodeId: 1, - ContractAddr: "sei1dc34p57spmhguak2ns88u3vxmt73gnu3c0j6phqv5ukfytklkqjsgepv26", - NeedOrderMatching: true, - }, - } - - contractUnregisterMsg := &dextypes.MsgUnregisterContract{ - Creator: account, - ContractAddr: "sei1dc34p57spmhguak2ns88u3vxmt73gnu3c0j6phqv5ukfytklkqjsgepv26", - } - - contractUnsuspendMsg := &dextypes.MsgUnsuspendContract{ - Creator: account, - ContractAddr: "sei1dc34p57spmhguak2ns88u3vxmt73gnu3c0j6phqv5ukfytklkqjsgepv26", - } - otherMsg := &stakingtypes.MsgDelegate{ DelegatorAddress: account, ValidatorAddress: validator, @@ -162,9 +142,6 @@ func TestPartitionPrioritizedTxs(t *testing.T) { txEncoder := app.MakeEncodingConfig().TxConfig.TxEncoder() oracleTxBuilder := app.MakeEncodingConfig().TxConfig.NewTxBuilder() - contractRegisterBuilder := app.MakeEncodingConfig().TxConfig.NewTxBuilder() - contractUnregisterBuilder := app.MakeEncodingConfig().TxConfig.NewTxBuilder() - contractUnsuspendBuilder := app.MakeEncodingConfig().TxConfig.NewTxBuilder() otherTxBuilder := app.MakeEncodingConfig().TxConfig.NewTxBuilder() mixedTxBuilder := app.MakeEncodingConfig().TxConfig.NewTxBuilder() @@ -173,21 +150,6 @@ func TestPartitionPrioritizedTxs(t *testing.T) { oracleTx, err := txEncoder(oracleTxBuilder.GetTx()) require.NoError(t, err) - err = contractRegisterBuilder.SetMsgs(contractRegisterMsg) - require.NoError(t, err) - contractRegisterTx, err := txEncoder(contractRegisterBuilder.GetTx()) - require.NoError(t, err) - - err = contractUnregisterBuilder.SetMsgs(contractUnregisterMsg) - require.NoError(t, err) - contractUnregisterTx, err := txEncoder(contractUnregisterBuilder.GetTx()) - require.NoError(t, err) - - err = contractUnsuspendBuilder.SetMsgs(contractUnsuspendMsg) - require.NoError(t, err) - contractSuspendTx, err := txEncoder(contractUnsuspendBuilder.GetTx()) - require.NoError(t, err) - err = otherTxBuilder.SetMsgs(otherMsg) require.NoError(t, err) otherTx, err := txEncoder(otherTxBuilder.GetTx()) @@ -201,52 +163,40 @@ func TestPartitionPrioritizedTxs(t *testing.T) { txs := [][]byte{ oracleTx, - contractRegisterTx, - contractUnregisterTx, - contractSuspendTx, otherTx, mixedTx, } typedTxs := []sdk.Tx{ oracleTxBuilder.GetTx(), - contractRegisterBuilder.GetTx(), - contractUnregisterBuilder.GetTx(), - contractUnsuspendBuilder.GetTx(), otherTxBuilder.GetTx(), mixedTxBuilder.GetTx(), } prioritizedTxs, otherTxs, prioritizedTypedTxs, otherTypedTxs, prioIdxs, otherIdxs := testWrapper.App.PartitionPrioritizedTxs(testWrapper.Ctx, txs, typedTxs) - require.Equal(t, [][]byte{oracleTx, contractRegisterTx, contractUnregisterTx, contractSuspendTx}, prioritizedTxs) + require.Equal(t, [][]byte{oracleTx}, prioritizedTxs) require.Equal(t, [][]byte{otherTx, mixedTx}, otherTxs) - require.Equal(t, []int{0, 1, 2, 3}, prioIdxs) - require.Equal(t, []int{4, 5}, otherIdxs) - require.Equal(t, 4, len(prioritizedTypedTxs)) + require.Equal(t, []int{0}, prioIdxs) + require.Equal(t, []int{1, 2}, otherIdxs) + require.Equal(t, 1, len(prioritizedTypedTxs)) require.Equal(t, 2, len(otherTypedTxs)) diffOrderTxs := [][]byte{ - oracleTx, otherTx, - contractRegisterTx, - contractUnregisterTx, + oracleTx, mixedTx, - contractSuspendTx, } differOrderTypedTxs := []sdk.Tx{ - oracleTxBuilder.GetTx(), otherTxBuilder.GetTx(), - contractRegisterBuilder.GetTx(), - contractUnregisterBuilder.GetTx(), + oracleTxBuilder.GetTx(), mixedTxBuilder.GetTx(), - contractUnsuspendBuilder.GetTx(), } prioritizedTxs, otherTxs, prioritizedTypedTxs, otherTypedTxs, prioIdxs, otherIdxs = testWrapper.App.PartitionPrioritizedTxs(testWrapper.Ctx, diffOrderTxs, differOrderTypedTxs) - require.Equal(t, [][]byte{oracleTx, contractRegisterTx, contractUnregisterTx, contractSuspendTx}, prioritizedTxs) + require.Equal(t, [][]byte{oracleTx}, prioritizedTxs) require.Equal(t, [][]byte{otherTx, mixedTx}, otherTxs) - require.Equal(t, []int{0, 2, 3, 5}, prioIdxs) - require.Equal(t, []int{1, 4}, otherIdxs) - require.Equal(t, 4, len(prioritizedTypedTxs)) + require.Equal(t, []int{1}, prioIdxs) + require.Equal(t, []int{0, 2}, otherIdxs) + require.Equal(t, 1, len(prioritizedTypedTxs)) require.Equal(t, 2, len(otherTypedTxs)) } diff --git a/app/apptesting/test_suite.go b/app/apptesting/test_suite.go index 9d72cc9f64..26ec97dd3d 100644 --- a/app/apptesting/test_suite.go +++ b/app/apptesting/test_suite.go @@ -16,7 +16,6 @@ import ( slashingtypes "github.com/cosmos/cosmos-sdk/x/slashing/types" "github.com/cosmos/cosmos-sdk/x/staking/teststaking" stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" "github.com/stretchr/testify/suite" abci "github.com/tendermint/tendermint/abci/types" "github.com/tendermint/tendermint/crypto/ed25519" @@ -40,7 +39,6 @@ type KeeperTestHelper struct { func (s *KeeperTestHelper) Setup() { s.App = app.Setup(false, false) s.Ctx = s.App.BaseApp.NewContext(false, tmtypes.Header{Height: 1, ChainID: "sei-test", Time: time.Now().UTC()}) - s.Ctx = s.Ctx.WithContext(context.WithValue(s.Ctx.Context(), dexutils.DexMemStateContextKey, s.App.MemState)) s.QueryHelper = &baseapp.QueryServiceTestHelper{ GRPCQueryRouter: s.App.GRPCQueryRouter(), Ctx: s.Ctx, diff --git a/app/test_helpers.go b/app/test_helpers.go index e80e7f3573..16c1c80c1f 100644 --- a/app/test_helpers.go +++ b/app/test_helpers.go @@ -22,7 +22,6 @@ import ( tmproto "github.com/tendermint/tendermint/proto/tendermint/types" dbm "github.com/tendermint/tm-db" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" minttypes "github.com/sei-protocol/sei-chain/x/mint/types" ) @@ -82,7 +81,6 @@ func newTestWrapper(t *testing.T, tm time.Time, valPub crptotypes.PubKey, enable appPtr = Setup(false, enableEVMCustomPrecompiles, baseAppOptions...) } ctx := appPtr.BaseApp.NewContext(false, tmproto.Header{Height: 1, ChainID: "sei-test", Time: tm}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, appPtr.MemState)) wrapper := &TestWrapper{ App: appPtr, Ctx: ctx, diff --git a/cmd/seid/cmd/debug.go b/cmd/seid/cmd/debug.go index d0a7e3240b..ed95da5727 100644 --- a/cmd/seid/cmd/debug.go +++ b/cmd/seid/cmd/debug.go @@ -26,7 +26,7 @@ const ( ) var modules = []string{ - "dex", "wasm", "aclaccesscontrol", "oracle", "epoch", "mint", "acc", "bank", "crisis", "feegrant", "staking", "distribution", "slashing", "gov", "params", "ibc", "upgrade", "evidence", "transfer", "tokenfactory", + "wasm", "aclaccesscontrol", "oracle", "epoch", "mint", "acc", "bank", "crisis", "feegrant", "staking", "distribution", "slashing", "gov", "params", "ibc", "upgrade", "evidence", "transfer", "tokenfactory", } func DumpIavlCmd() *cobra.Command { diff --git a/cmd/seid/cmd/iavl_parser.go b/cmd/seid/cmd/iavl_parser.go index fcb54a182f..345332f53f 100644 --- a/cmd/seid/cmd/iavl_parser.go +++ b/cmd/seid/cmd/iavl_parser.go @@ -9,8 +9,6 @@ import ( banktypes "github.com/cosmos/cosmos-sdk/x/bank/types" stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" "github.com/sei-protocol/sei-chain/app/params" - dexkeeper "github.com/sei-protocol/sei-chain/x/dex/keeper" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" minttypes "github.com/sei-protocol/sei-chain/x/mint/types" ) @@ -21,7 +19,6 @@ const UNRECOGNIZED = "Unrecognized Prefix" var ModuleParserMap = map[string]ModuleParser{ "bank": BankParser, "mint": MintParser, - "dex": DexParser, "staking": StakingParser, "acc": AccountParser, } @@ -84,64 +81,6 @@ func BankParser(key []byte) ([]string, error) { return keyItems, nil } -func DexParser(key []byte) ([]string, error) { - keyItems := []string{} - if matched, items, _, err := MatchAndExtractDexAddressPrefixKeys(key); matched { - if err != nil { - return keyItems, err - } - keyItems = append(keyItems, items...) - return keyItems, nil - } - switch { - case bytes.HasPrefix(key, []byte(dexkeeper.EpochKey)): - // do nothing since the key is a string and no other data to be parsed - default: - keyItems = append(keyItems, UNRECOGNIZED) - } - return keyItems, nil -} - -func MatchAndExtractDexAddressPrefixKeys(key []byte) (bool, []string, []byte, error) { - keyItems := []string{} - keysToMatch := []string{ - // Source of truth: github.com/sei-protocol/sei-chain/x/dex/types/keys.go - contains key constants represented here - dextypes.LongBookKey, - dextypes.ShortBookKey, - dextypes.PriceKey, - dextypes.TwapKey, - dextypes.SettlementEntryKey, - dextypes.RegisteredPairKey, - dextypes.OrderKey, - dextypes.CancelKey, - dextypes.AccountActiveOrdersKey, - dextypes.NextOrderIDKey, - dextypes.NextSettlementIDKey, - dextypes.MatchResultKey, - dextypes.MemOrderKey, - dextypes.MemCancelKey, - dextypes.MemDepositKey, - dexkeeper.ContractPrefixKey, - } - - for _, prefix := range keysToMatch { - if bytes.HasPrefix(key, dextypes.KeyPrefix(prefix)) { - keyItems = append(keyItems, prefix) - remaining := bytes.TrimPrefix(key, dextypes.KeyPrefix(prefix)) - items, remaining, err := parseLengthPrefixedAddress(remaining) - if err != nil { - return true, keyItems, remaining, err - } - keyItems = append(keyItems, items...) - if len(remaining) > 0 { - keyItems = append(keyItems, fmt.Sprintf("RemainingString: %s", string(remaining))) - } - return true, keyItems, remaining, nil - } - } - return false, keyItems, key, nil -} - func parseLengthPrefixedAddress(remainingKey []byte) ([]string, []byte, error) { keyItems := []string{} lengthPrefix, remaining := int(remainingKey[0]), remainingKey[1:] diff --git a/go.mod b/go.mod index f5fcc7f236..1aae20b4c9 100644 --- a/go.mod +++ b/go.mod @@ -42,7 +42,6 @@ require ( go.opentelemetry.io/otel/trace v1.9.0 golang.org/x/exp v0.0.0-20231110203233-9a3e6036ecaa golang.org/x/sync v0.7.0 - golang.org/x/text v0.15.0 golang.org/x/time v0.3.0 google.golang.org/genproto/googleapis/api v0.0.0-20240513163218-0867130af1f8 google.golang.org/grpc v1.64.0 @@ -319,6 +318,7 @@ require ( golang.org/x/net v0.25.0 // indirect golang.org/x/sys v0.20.0 // indirect golang.org/x/term v0.20.0 // indirect + golang.org/x/text v0.15.0 // indirect golang.org/x/tools v0.21.0 // indirect google.golang.org/genproto v0.0.0-20240116215550-a9fa1716bcac // indirect google.golang.org/genproto/googleapis/rpc v0.0.0-20240513163218-0867130af1f8 // indirect @@ -346,7 +346,7 @@ require ( replace ( github.com/CosmWasm/wasmd => github.com/sei-protocol/sei-wasmd v0.1.9 github.com/confio/ics23/go => github.com/cosmos/cosmos-sdk/ics23/go v0.8.0 - github.com/cosmos/cosmos-sdk => github.com/sei-protocol/sei-cosmos v0.3.24 + github.com/cosmos/cosmos-sdk => github.com/sei-protocol/sei-cosmos v0.3.25 github.com/cosmos/iavl => github.com/sei-protocol/sei-iavl v0.1.9 github.com/cosmos/ibc-go/v3 => github.com/sei-protocol/sei-ibc-go/v3 v3.3.1 github.com/ethereum/go-ethereum => github.com/sei-protocol/go-ethereum v1.13.5-sei-22 diff --git a/go.sum b/go.sum index b235cd5cb6..8441700038 100644 --- a/go.sum +++ b/go.sum @@ -1347,8 +1347,8 @@ github.com/sei-protocol/go-ethereum v1.13.5-sei-22 h1:t/m1qXER+DEMrcpqgoYmUxifkA github.com/sei-protocol/go-ethereum v1.13.5-sei-22/go.mod h1:kcRZmuzRn1lVejiFNTz4l4W7imnpq1bDAnuKS/RyhbQ= github.com/sei-protocol/goutils v0.0.2 h1:Bfa7Sv+4CVLNM20QcpvGb81B8C5HkQC/kW1CQpIbXDA= github.com/sei-protocol/goutils v0.0.2/go.mod h1:iYE2DuJfEnM+APPehr2gOUXfuLuPsVxorcDO+Tzq9q8= -github.com/sei-protocol/sei-cosmos v0.3.24 h1:7pvXNvsQ3P6wovH2Z6wK/G9UuRTHYgQtQNpPjt9ypZQ= -github.com/sei-protocol/sei-cosmos v0.3.24/go.mod h1:og/KbejR/zSQ8otapODEDU9zYNhFSUDbq9+tgeYePyU= +github.com/sei-protocol/sei-cosmos v0.3.25 h1:S/hAcTK1mAep4zlOc0vHZUvR0kClZEBvILtBJ0hVv/c= +github.com/sei-protocol/sei-cosmos v0.3.25/go.mod h1:og/KbejR/zSQ8otapODEDU9zYNhFSUDbq9+tgeYePyU= github.com/sei-protocol/sei-db v0.0.39 h1:/XwwlObPhWnX8zH8GDbDvyn+a/K2911HZlmlBZzN+gQ= github.com/sei-protocol/sei-db v0.0.39/go.mod h1:F/ZKZA8HJPcUzSZPA8yt6pfwlGriJ4RDR4eHKSGLStI= github.com/sei-protocol/sei-iavl v0.1.9 h1:y4mVYftxLNRs6533zl7N0/Ch+CzRQc04JDfHolIxgBE= diff --git a/integration_test/dex_module/cancel_order_test.yaml b/integration_test/dex_module/cancel_order_test.yaml deleted file mode 100644 index 31496bd87d..0000000000 --- a/integration_test/dex_module/cancel_order_test.yaml +++ /dev/null @@ -1,25 +0,0 @@ -- name: Test cancel a placed order and query the cancelled order - inputs: - # Get contract address, this requires contract already deployed - - cmd: tail -1 integration_test/contracts/mars-addr.txt - env: CONTRACT_ADDR - # Prepare parameter to first place the order - - cmd: echo "LONG?1.01?5?SEI?ATOM?LIMIT?{\"leverage\":\"1\",\"position_effect\":\"Open\"}" - env: PARAMS - # Place an order and set ORDER_ID - - cmd: printf "12345678\n" | seid tx dex place-orders $CONTRACT_ADDR $PARAMS --amount=1000000000usei -y --from=admin --chain-id=sei --fees=1000000usei --gas=500000 --broadcast-mode=block --output json|jq -M -r ".logs[].events[].attributes[] | select(.key == \"order_id\").value" - env: ORDER_ID - # Prepare parameter to cancel the placed order - - cmd: echo $ORDER_ID"?LONG?1.01?SEI?ATOM" - env: PARAMS - # Cancel the order - - cmd: printf "12345678\n" | seid tx dex cancel-orders $CONTRACT_ADDR $PARAMS -y --from=admin --chain-id=sei --fees=1000000usei --gas=5000000 --broadcast-mode=block --output json - env: RES - - cmd: printf "12345678\n" | seid keys show admin --output json |jq -r .address - env: ADMIN_ADDR - # Query the order by id - - cmd: seid q dex get-orders $CONTRACT_ADDR $ADMIN_ADDR --output json |jq ".[] | length" - env: NUMORDER - verifiers: - - type: eval - expr: NUMORDER == 4 # placed from the place_order test diff --git a/integration_test/dex_module/place_order_test.yaml b/integration_test/dex_module/place_order_test.yaml deleted file mode 100644 index 168d4080c8..0000000000 --- a/integration_test/dex_module/place_order_test.yaml +++ /dev/null @@ -1,46 +0,0 @@ -- name: Test placing a new order and query the placed order - inputs: - # Get contract address, this requires contract already deployed - - cmd: tail -1 integration_test/contracts/mars-addr.txt - env: CONTRACT_ADDR - # Prepare parameter - - cmd: echo "LONG?1.01?5?SEI?ATOM?LIMIT?{\"leverage\":\"1\",\"position_effect\":\"Open\"}" - env: PARAMS - # Place an order and set ORDER_ID - - cmd: printf "12345678\n" | seid tx dex place-orders $CONTRACT_ADDR $PARAMS --amount=1000000000usei -y --from=admin --chain-id=sei --fees=1000000usei --gas=500000 --broadcast-mode=block --output json|jq -M -r ".logs[].events[].attributes[] | select(.key == \"order_id\").value" - env: ORDER_ID - # Query the order by id - - cmd: seid q dex get-orders-by-id $CONTRACT_ADDR SEI ATOM $ORDER_ID --output json |jq .order.status - env: RESULT - verifiers: - # Order ids should be greater or equal to 0 - - type: eval - expr: ORDER_ID >= 0 - # Order status should be something like PLACED - - type: regex - result: RESULT - expr: '^.*PLACED.*' - -- name: Test place multiple orders should give the correct asset denom - inputs: - # Get contract address, this requires contract already deployed - - cmd: tail -1 integration_test/contracts/mars-addr.txt - env: CONTRACT_ADDR - # Get admin account address - - cmd: printf "12345678\n" | seid keys show admin --output json |jq -r .address - env: ADMIN_ADDR - - cmd: seid q dex get-orders $CONTRACT_ADDR $ADMIN_ADDR --output json |jq ".[] | length" - env: ORDER_COUNT_BEFORE - # Prepare parameter - - cmd: echo "LONG?1.0?10?usei?uatom?LIMIT? LONG?3.0?3000?usei?uatomatomatom?LIMIT? LONG?3.0?1000?usei?uatomatom?LIMIT?" - env: PARAMS - # Place 3 orders - - cmd: printf "12345678\n" | seid tx dex place-orders $CONTRACT_ADDR $PARAMS --amount=1000000000usei -y --from=admin --chain-id=sei --fees=1000000usei --gas=500000 --broadcast-mode=block --output json| jq .code - - # Query all the orders - - cmd: seid q dex get-orders $CONTRACT_ADDR $ADMIN_ADDR --output json |jq ".[] | length" - env: ORDER_COUNT_AFTER - verifiers: - # Verify we should only see 3 orders - - type: eval - expr: ( ORDER_COUNT_AFTER - ORDER_COUNT_BEFORE ) == 3 diff --git a/loadtest/main.go b/loadtest/main.go index 1b094892d1..938b19061d 100644 --- a/loadtest/main.go +++ b/loadtest/main.go @@ -39,7 +39,6 @@ import ( "github.com/sei-protocol/sei-chain/app" "github.com/sei-protocol/sei-chain/utils/metrics" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" tokenfactorytypes "github.com/sei-protocol/sei-chain/x/tokenfactory/types" ) @@ -330,10 +329,6 @@ func (c *LoadTestClient) generateMessage(key cryptotypes.PrivKey, msgType string } switch msgType { - case Vortex: - price := config.PriceDistr.Sample() - quantity := config.QuantityDistr.Sample() - msgs = c.generateVortexOrder(config, key, config.WasmMsgTypes.Vortex.NumOrdersPerTx, price, quantity) case WasmMintNft: contract := config.WasmMsgTypes.MintNftType.ContractAddr // TODO: Potentially just hard code the Funds amount here @@ -403,21 +398,6 @@ func (c *LoadTestClient) generateMessage(key cryptotypes.PrivKey, msgType string signer = adminKey gas = 10000000 fee = 1000000 - case Dex: - price := config.PriceDistr.Sample() - quantity := config.QuantityDistr.Sample() - contract := config.ContractDistr.Sample() - orderPlacements := generateDexOrderPlacements(config, key, msgPerTx, price, quantity) - amount, err := sdk.ParseCoinsNormalized(fmt.Sprintf("%d%s", price.Mul(quantity).Ceil().RoundInt64(), "usei")) - if err != nil { - panic(err) - } - msgs = []sdk.Msg{&dextypes.MsgPlaceOrders{ - Creator: sdk.AccAddress(key.PubKey().Address()).String(), - Orders: orderPlacements, - ContractAddr: contract, - Funds: amount, - }} case Staking: delegatorAddr := sdk.AccAddress(key.PubKey().Address()).String() chosenValidator := c.Validators[r.Intn(len(c.Validators))].OperatorAddress @@ -484,42 +464,6 @@ func (c *LoadTestClient) generateMessage(key cryptotypes.PrivKey, msgType string Amount: sdk.NewInt(amountUsei), }), }} - case FailureDexMalformed: - price := config.PriceDistr.InvalidSample() - quantity := config.QuantityDistr.InvalidSample() - contract := config.ContractDistr.Sample() - orderPlacements := generateDexOrderPlacements(config, key, msgPerTx, price, quantity) - amount, err := sdk.ParseCoinsNormalized(fmt.Sprintf("%d%s", price.Mul(quantity).Ceil().RoundInt64(), "usei")) - if err != nil { - panic(err) - } - msgs = []sdk.Msg{&dextypes.MsgPlaceOrders{ - Creator: sdk.AccAddress(key.PubKey().Address()).String(), - Orders: orderPlacements, - ContractAddr: contract, - Funds: amount, - }} - case FailureDexInvalid: - price := config.PriceDistr.Sample() - quantity := config.QuantityDistr.Sample() - contract := config.ContractDistr.Sample() - orderPlacements := generateDexOrderPlacements(config, key, msgPerTx, price, quantity) - var amountUsei int64 - if r.Float64() < 0.5 { - amountUsei = 10000 * price.Mul(quantity).Ceil().RoundInt64() - } else { - amountUsei = 0 - } - amount, err := sdk.ParseCoinsNormalized(fmt.Sprintf("%d%s", amountUsei, "usei")) - if err != nil { - panic(err) - } - msgs = []sdk.Msg{&dextypes.MsgPlaceOrders{ - Creator: sdk.AccAddress(key.PubKey().Address()).String(), - Orders: orderPlacements, - ContractAddr: contract, - Funds: amount, - }} case WasmOccIteratorWrite: // generate some values for indices 1-100 indices := []int{} @@ -578,51 +522,6 @@ func (c *LoadTestClient) generateMessage(key cryptotypes.PrivKey, msgType string return msgs, false, signer, gas, int64(fee) } -func sampleDexOrderType(config Config) (orderType dextypes.OrderType) { - if len(config.MessageTypes) == 1 && config.MessageTypes[0] == "failure_bank_malformed" { - orderType = -1 - } else { - msgType := config.MsgTypeDistr.SampleDexMsgs() - switch msgType { - case Limit: - orderType = dextypes.OrderType_LIMIT - case Market: - orderType = dextypes.OrderType_MARKET - default: - panic(fmt.Sprintf("Unknown message type %s\n", msgType)) - } - } - return orderType -} - -func generateDexOrderPlacements(config Config, key cryptotypes.PrivKey, msgPerTx uint64, price sdk.Dec, quantity sdk.Dec) (orderPlacements []*dextypes.Order) { - orderType := sampleDexOrderType(config) - - r := rand.New(rand.NewSource(time.Now().UnixNano())) - var direction dextypes.PositionDirection - if r.Float64() < 0.5 { - direction = dextypes.PositionDirection_LONG - } else { - direction = dextypes.PositionDirection_SHORT - } - - contract := config.ContractDistr.Sample() - for j := 0; j < int(msgPerTx); j++ { - orderPlacements = append(orderPlacements, &dextypes.Order{ - Account: sdk.AccAddress(key.PubKey().Address()).String(), - ContractAddr: contract, - PositionDirection: direction, - Price: price.Quo(FromMili), - Quantity: quantity.Quo(FromMili), - PriceDenom: "SEI", - AssetDenom: "ATOM", - OrderType: orderType, - Data: VortexData, - }) - } - return orderPlacements -} - func (c *LoadTestClient) generateStakingMsg(delegatorAddr string, chosenValidator string, srcAddr string) sdk.Msg { c.mtx.Lock() defer c.mtx.Unlock() @@ -663,71 +562,6 @@ func (c *LoadTestClient) generateStakingMsg(delegatorAddr string, chosenValidato return msg } -// generateVortexOrder generates Vortex order messages. If short order, creates a deposit message first -func (c *LoadTestClient) generateVortexOrder(config Config, key cryptotypes.PrivKey, numOrders int64, price sdk.Dec, quantity sdk.Dec) []sdk.Msg { - var msgs []sdk.Msg - contract := config.WasmMsgTypes.Vortex.ContractAddr - - r := rand.New(rand.NewSource(time.Now().UnixNano())) - // Randomly select Position Direction - var direction dextypes.PositionDirection - if r.Float64() < 0.5 { - direction = dextypes.PositionDirection_LONG - } else { - direction = dextypes.PositionDirection_SHORT - } - - orderType := sampleDexOrderType(config) - - // If placing short order on vortex, first deposit for buying power - if direction == dextypes.PositionDirection_SHORT { - // TODO: Considering depositing more up front when numOrders > 1 - amountDeposit, err := sdk.ParseCoinsNormalized(fmt.Sprintf("%d%s", price.Mul(quantity).Ceil().RoundInt64(), "usei")) - if err != nil { - panic(err) - } - vortexDeposit := &wasmtypes.MsgExecuteContract{ - Sender: sdk.AccAddress(key.PubKey().Address()).String(), - Contract: contract, - Msg: wasmtypes.RawContractMessage([]byte("{\"deposit\":{}}")), - Funds: amountDeposit, - } - msgs = append(msgs, vortexDeposit) - } - - // Create a MsgPlaceOrders with numOrders Orders - var orderPlacements []*dextypes.Order - for j := 0; j < int(numOrders); j++ { - vortexOrder := &dextypes.Order{ - Account: sdk.AccAddress(key.PubKey().Address()).String(), - ContractAddr: contract, - PositionDirection: direction, - Price: price.Quo(FromMili), - Quantity: quantity.Quo(FromMili), - PriceDenom: "SEI", - AssetDenom: "ATOM", - OrderType: orderType, - Data: VortexData, - } - orderPlacements = append(orderPlacements, vortexOrder) - } - - amount, err := sdk.ParseCoinsNormalized(fmt.Sprintf("%d%s", price.Mul(quantity).Ceil().RoundInt64(), "usei")) - if err != nil { - panic(err) - } - vortexOrderMsg := &dextypes.MsgPlaceOrders{ - Creator: sdk.AccAddress(key.PubKey().Address()).String(), - Orders: orderPlacements, - ContractAddr: contract, - Funds: amount, - } - - msgs = append(msgs, vortexOrderMsg) - - return msgs -} - // nolint func getLastHeight(blockchainEndpoint string) int { out, err := exec.Command("curl", blockchainEndpoint+"/blockchain").Output() diff --git a/occ_tests/utils/utils.go b/occ_tests/utils/utils.go index e64772664c..877f92db15 100644 --- a/occ_tests/utils/utils.go +++ b/occ_tests/utils/utils.go @@ -1,7 +1,6 @@ package utils import ( - "context" "crypto/ecdsa" "encoding/hex" "math/big" @@ -32,9 +31,6 @@ import ( "github.com/sei-protocol/sei-chain/app" utils2 "github.com/sei-protocol/sei-chain/utils" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" "github.com/sei-protocol/sei-chain/x/evm/config" types2 "github.com/sei-protocol/sei-chain/x/evm/types" minttypes "github.com/sei-protocol/sei-chain/x/mint/types" @@ -129,7 +125,6 @@ func NewTestContext(t *testing.T, testAccts []TestAcct, blockTime time.Time, wor }) testApp := wrapper.App ctx := wrapper.Ctx - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(dextypes.MemStoreKey)))) ctx = ctx.WithBlockHeader(tmproto.Header{Height: ctx.BlockHeader().Height, ChainID: ctx.BlockHeader().ChainID, Time: blockTime}) amounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(1000000000000000)), sdk.NewCoin("uusdc", sdk.NewInt(1000000000000000))) bankkeeper := testApp.BankKeeper diff --git a/proto/dex/asset_list.proto b/proto/dex/asset_list.proto deleted file mode 100644 index b80d54f716..0000000000 --- a/proto/dex/asset_list.proto +++ /dev/null @@ -1,23 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "cosmos/bank/v1beta1/bank.proto"; -import "gogoproto/gogo.proto"; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -message AssetIBCInfo { - string sourceChannel = 1 [(gogoproto.jsontag) = "source_channel"]; - string dstChannel = 2 [(gogoproto.jsontag) = "dst_channel"]; - string sourceDenom = 3 [(gogoproto.jsontag) = "source_denom"]; - string sourceChainID = 4 [(gogoproto.jsontag) = "source_chain_id"]; -} - -message AssetMetadata { - AssetIBCInfo ibcInfo = 1 [(gogoproto.jsontag) = "ibc_info"]; - string type_asset = 2 [(gogoproto.jsontag) = "type_asset"]; // Ex: cw20, ics20, erc20 - cosmos.bank.v1beta1.Metadata metadata = 3 [ - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "metadata" - ]; -} diff --git a/proto/dex/contract.proto b/proto/dex/contract.proto deleted file mode 100644 index 11d87ceb67..0000000000 --- a/proto/dex/contract.proto +++ /dev/null @@ -1,47 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -message ContractInfo { - uint64 codeId = 1; - string contractAddr = 2; - bool needHook = 3; - bool needOrderMatching = 4; - repeated ContractDependencyInfo dependencies = 5; - int64 numIncomingDependencies = 6; -} - -message ContractInfoV2 { - uint64 codeId = 1; - string contractAddr = 2; - bool needHook = 3; - bool needOrderMatching = 4; - repeated ContractDependencyInfo dependencies = 5; - int64 numIncomingDependencies = 6; - string creator = 7; - uint64 rentBalance = 8; - bool suspended = 9; - string suspensionReason = 10; -} - -// suppose A is first registered and depends on X, then B is added and depends on X, -// and then C is added and depends on X, then A is the elder sibling to B and B is -// the younger sibling to A, and B is the elder sibling to C and C is the younger to B -message ContractDependencyInfo { - string dependency = 1; - string immediateElderSibling = 2; - string immediateYoungerSibling = 3; -} - -message LegacyContractInfo { - uint64 codeId = 1; - string contractAddr = 2; - bool needHook = 3; - bool needOrderMatching = 4; - repeated string dependentContractAddrs = 5; -} - -message DownsteamContracts { - repeated string contractAddrs = 1; -} \ No newline at end of file diff --git a/proto/dex/deposit.proto b/proto/dex/deposit.proto deleted file mode 100644 index 5f09e2ffa1..0000000000 --- a/proto/dex/deposit.proto +++ /dev/null @@ -1,21 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "gogoproto/gogo.proto"; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -message DepositInfoEntry { - string creator = 1 [ - (gogoproto.jsontag) = "creator" - ]; - string denom = 2 [ - (gogoproto.jsontag) = "denom" - ]; - string amount = 3 [ - (gogoproto.moretags) = "yaml:\"amount\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "amount" - ]; -} diff --git a/proto/dex/enums.proto b/proto/dex/enums.proto deleted file mode 100644 index 0eb89c5c0e..0000000000 --- a/proto/dex/enums.proto +++ /dev/null @@ -1,42 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -enum PositionDirection { - LONG = 0; - SHORT = 1; -} - -enum PositionEffect { - OPEN = 0; - CLOSE = 1; -} - -enum OrderType { - LIMIT = 0; - MARKET = 1; - FOKMARKET = 3; // fill-or-kill market order - FOKMARKETBYVALUE = 4; // fill-or-kill market by value order - STOPLOSS = 5; - STOPLIMIT = 6; -} - -enum Unit { - STANDARD = 0; - MILLI = 1; - MICRO = 2; - NANO = 3; -} - -enum OrderStatus { - PLACED = 0; - FAILED_TO_PLACE = 1; - CANCELLED = 2; - FULFILLED = 3; -} - -enum CancellationInitiator { - USER = 0; - LIQUIDATED = 1; -} diff --git a/proto/dex/genesis.proto b/proto/dex/genesis.proto deleted file mode 100644 index 5e46bc73ad..0000000000 --- a/proto/dex/genesis.proto +++ /dev/null @@ -1,37 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "gogoproto/gogo.proto"; -import "dex/params.proto"; -import "dex/long_book.proto"; -import "dex/short_book.proto"; -import "dex/order.proto"; -import "dex/contract.proto"; -import "dex/pair.proto"; -import "dex/price.proto"; -// this line is used by starport scaffolding # genesis/proto/import - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -// GenesisState defines the dex module's genesis state. -message GenesisState { - Params params = 1 [(gogoproto.nullable) = false]; - repeated ContractState contractState = 2 [(gogoproto.nullable) = false]; - uint64 lastEpoch = 3; - // this line is used by starport scaffolding # genesis/proto/state -} - -message ContractState { - ContractInfoV2 contractInfo = 1 [(gogoproto.nullable) = false]; - repeated LongBook longBookList = 2 [(gogoproto.nullable) = false]; - repeated ShortBook shortBookList = 3 [(gogoproto.nullable) = false]; - repeated Order triggeredOrdersList = 4 [(gogoproto.nullable) = false]; - repeated Pair pairList = 5 [(gogoproto.nullable) = false]; - repeated ContractPairPrices priceList = 6 [(gogoproto.nullable) = false]; - uint64 nextOrderId = 7; -} - -message ContractPairPrices { - Pair pricePair = 1 [(gogoproto.nullable) = false]; - repeated Price prices = 2; -} diff --git a/proto/dex/gov.proto b/proto/dex/gov.proto deleted file mode 100644 index 4fa4d04e76..0000000000 --- a/proto/dex/gov.proto +++ /dev/null @@ -1,22 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "gogoproto/gogo.proto"; -import "dex/asset_list.proto"; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -// AddAssetMetadataProposal is a gov Content type for adding a new asset -// to the dex module's asset list. -message AddAssetMetadataProposal { - option (gogoproto.equal) = false; - option (gogoproto.goproto_getters) = false; - option (gogoproto.goproto_stringer) = false; - - string title = 1 [ (gogoproto.moretags) = "yaml:\"title\"" ]; - string description = 2 [ (gogoproto.moretags) = "yaml:\"description\"" ]; - repeated AssetMetadata assetList = 3 [ - (gogoproto.moretags) = "yaml:\"asset_list\"", - (gogoproto.nullable) = false - ]; -} diff --git a/proto/dex/long_book.proto b/proto/dex/long_book.proto deleted file mode 100644 index c9b810f234..0000000000 --- a/proto/dex/long_book.proto +++ /dev/null @@ -1,19 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; -import "dex/order_entry.proto"; -import "gogoproto/gogo.proto"; - -message LongBook { - string price = 1 [ - (gogoproto.moretags) = "yaml:\"price\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "price" - ]; - OrderEntry entry = 2 [ - (gogoproto.jsontag) = "entry" - ]; - -} \ No newline at end of file diff --git a/proto/dex/match_result.proto b/proto/dex/match_result.proto deleted file mode 100644 index c6d76c8075..0000000000 --- a/proto/dex/match_result.proto +++ /dev/null @@ -1,15 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; -import "dex/order.proto"; -import "dex/settlement.proto"; -import "gogoproto/gogo.proto"; - -message MatchResult { - int64 height = 1 [(gogoproto.jsontag) = "height"]; - string contractAddr = 2 [(gogoproto.jsontag) = "contract_address"]; - repeated Order orders = 3 [(gogoproto.jsontag) = "orders"]; - repeated SettlementEntry settlements = 4 [(gogoproto.jsontag) = "settlements"]; - repeated Cancellation cancellations = 5 [(gogoproto.jsontag) = "cancellations"]; -} \ No newline at end of file diff --git a/proto/dex/order.proto b/proto/dex/order.proto deleted file mode 100644 index 8b366eb6e6..0000000000 --- a/proto/dex/order.proto +++ /dev/null @@ -1,108 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "gogoproto/gogo.proto"; -import "dex/enums.proto"; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -message Order { - uint64 id = 1 [ - (gogoproto.jsontag) = "id", - (gogoproto.nullable) = true - ]; - OrderStatus status = 2 [ - (gogoproto.jsontag) = "status", - (gogoproto.nullable) = true - ]; - string account = 3 [ - (gogoproto.jsontag) = "account", - (gogoproto.nullable) = true - ]; - string contractAddr = 4 [ - (gogoproto.jsontag) = "contract_address", - (gogoproto.nullable) = true - ]; - string price = 5 [ - (gogoproto.moretags) = "yaml:\"price\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "price" - ]; - string quantity = 6 [ - (gogoproto.moretags) = "yaml:\"quantity\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "quantity" - ]; - string priceDenom = 7 [ - (gogoproto.jsontag) = "price_denom" - ]; - string assetDenom = 8 [ - (gogoproto.jsontag) = "asset_denom" - ]; - OrderType orderType = 9 [ - (gogoproto.jsontag) = "order_type" - ]; - PositionDirection positionDirection = 10 [ - (gogoproto.jsontag) = "position_direction" - ]; - string data = 11 [ - (gogoproto.jsontag) = "data" - ]; - string statusDescription = 12 [ - (gogoproto.jsontag) = "status_description" - ]; - string nominal = 13 [ - (gogoproto.moretags) = "yaml:\"nominal\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "nominal" - ]; - string triggerPrice = 14 [ - (gogoproto.moretags) = "yaml:\"trigger_price\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "trigger_price" - ]; - bool triggerStatus = 15 [ - (gogoproto.jsontag) = "trigger_status" - ]; -} - -message Cancellation { - uint64 id = 1 [ - (gogoproto.jsontag) = "id" - ]; - CancellationInitiator initiator = 2 [ - (gogoproto.jsontag) = "initiator" - ]; - string creator = 3 [ - (gogoproto.jsontag) = "creator", - (gogoproto.nullable) = true - ]; - string contractAddr = 4 [ - (gogoproto.jsontag) = "contract_address" - ]; - string priceDenom = 5 [ - (gogoproto.jsontag) = "price_denom" - ]; - string assetDenom = 6 [ - (gogoproto.jsontag) = "asset_denom" - ]; - PositionDirection positionDirection = 7 [ - (gogoproto.jsontag) = "position_direction" - ]; - string price = 8 [ - (gogoproto.moretags) = "yaml:\"price\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "price" - ]; -} - -message ActiveOrders { - repeated uint64 ids = 1 [ - (gogoproto.jsontag) = "ids" - ]; -} diff --git a/proto/dex/order_entry.proto b/proto/dex/order_entry.proto deleted file mode 100644 index a35d8075f3..0000000000 --- a/proto/dex/order_entry.proto +++ /dev/null @@ -1,46 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "gogoproto/gogo.proto"; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -message OrderEntry { - - string price = 1 [ - (gogoproto.moretags) = "yaml:\"price\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "price" - ]; - string quantity = 2 [ - (gogoproto.moretags) = "yaml:\"quantity\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "quantity" - ]; - repeated Allocation allocations = 3 [ - (gogoproto.jsontag) = "allocations" - ]; - string priceDenom = 4 [ - (gogoproto.jsontag) = "price_denom" - ]; - string assetDenom = 5 [ - (gogoproto.jsontag) = "asset_denom" - ]; -} - -message Allocation { - uint64 orderId = 1 [ - (gogoproto.jsontag) = "order_id" - ]; - string quantity = 2 [ - (gogoproto.moretags) = "yaml:\"quantity\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "quantity" - ]; - string account = 3 [ - (gogoproto.jsontag) = "account" - ]; -} diff --git a/proto/dex/pair.proto b/proto/dex/pair.proto deleted file mode 100644 index 721e459ea8..0000000000 --- a/proto/dex/pair.proto +++ /dev/null @@ -1,30 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "gogoproto/gogo.proto"; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -message Pair { - string priceDenom = 1 [ - (gogoproto.jsontag) = "price_denom" - ]; - string assetDenom = 2 [ - (gogoproto.jsontag) = "asset_denom" - ]; - string priceTicksize = 3 [ - (gogoproto.jsontag) = "price_tick_size", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = true - ]; - string quantityTicksize = 4 [ - (gogoproto.jsontag) = "quantity_tick_size", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = true - ]; -} - -message BatchContractPair { - string contractAddr = 1 [(gogoproto.jsontag) = "contract_addr"]; - repeated Pair pairs = 2 [(gogoproto.jsontag) = "pairs"]; -} diff --git a/proto/dex/params.proto b/proto/dex/params.proto deleted file mode 100644 index de96e47901..0000000000 --- a/proto/dex/params.proto +++ /dev/null @@ -1,70 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "gogoproto/gogo.proto"; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -// Params defines the parameters for the module. -message Params { - option (gogoproto.equal) = true; - option (gogoproto.goproto_stringer) = false; - - uint64 price_snapshot_retention = 1 [ - (gogoproto.moretags) = "yaml:\"price_snapshot_retention\"", - (gogoproto.jsontag) = "price_snapshot_retention" - ]; - string sudo_call_gas_price = 2 [ - (gogoproto.jsontag) = "sudo_call_gas_price", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false - ]; - uint64 begin_block_gas_limit = 3 [ - (gogoproto.jsontag) = "begin_block_gas_limit", - (gogoproto.moretags) = "yaml:\"begin_block_gas_limit\"" - ]; - uint64 end_block_gas_limit = 4 [ - (gogoproto.jsontag) = "end_block_gas_limit", - (gogoproto.moretags) = "yaml:\"end_block_gas_limit\"" - ]; - uint64 default_gas_per_order = 5 [ - (gogoproto.jsontag) = "default_gas_per_order", - (gogoproto.moretags) = "yaml:\"default_gas_per_order\"" - ]; - uint64 default_gas_per_cancel = 6 [ - (gogoproto.jsontag) = "default_gas_per_cancel", - (gogoproto.moretags) = "yaml:\"default_gas_per_cancel\"" - ]; - uint64 min_rent_deposit = 7 [ - (gogoproto.jsontag) = "min_rent_deposit", - (gogoproto.moretags) = "yaml:\"min_rent_deposit\"" - ]; - uint64 gas_allowance_per_settlement = 8 [ - (gogoproto.jsontag) = "gas_allowance_per_settlement", - (gogoproto.moretags) = "yaml:\"gas_allowance_per_settlement\"" - ]; - uint64 min_processable_rent = 9 [ - (gogoproto.jsontag) = "min_processable_rent", - (gogoproto.moretags) = "yaml:\"min_processable_rent\"" - ]; - uint64 order_book_entries_per_load = 10 [ - (gogoproto.jsontag) = "order_book_entries_per_load", - (gogoproto.moretags) = "yaml:\"order_book_entries_per_load\"" - ]; - uint64 contract_unsuspend_cost = 11 [ - (gogoproto.jsontag) = "contract_unsuspend_cost", - (gogoproto.moretags) = "yaml:\"contract_unsuspend_cost\"" - ]; - uint64 max_order_per_price = 12 [ - (gogoproto.jsontag) = "max_order_per_price", - (gogoproto.moretags) = "yaml:\"max_order_per_price\"" - ]; - uint64 max_pairs_per_contract = 13 [ - (gogoproto.jsontag) = "max_pairs_per_contract", - (gogoproto.moretags) = "yaml:\"max_pairs_per_contract\"" - ]; - uint64 default_gas_per_order_data_byte = 14 [ - (gogoproto.jsontag) = "default_gas_per_order_data_byte", - (gogoproto.moretags) = "yaml:\"default_gas_per_order_data_byte\"" - ]; -} diff --git a/proto/dex/price.proto b/proto/dex/price.proto deleted file mode 100644 index 65b5447179..0000000000 --- a/proto/dex/price.proto +++ /dev/null @@ -1,52 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "gogoproto/gogo.proto"; -import "dex/pair.proto"; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -message Price { - - uint64 snapshotTimestampInSeconds = 1 [ - (gogoproto.jsontag) = "snapshot_timestamp_in_seconds" - ]; - string price = 2 [ - (gogoproto.moretags) = "yaml:\"price\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "price" - ]; - Pair pair = 3 [ - (gogoproto.jsontag) = "pair" - ]; -} - -message PriceCandlestick { - uint64 beginTimestamp = 1 [ - (gogoproto.jsontag) = "begin_timestamp" - ]; - uint64 endTimestamp = 2 [ - (gogoproto.jsontag) = "end_timestamp" - ]; - string open = 3 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "open" - ]; - string high = 4 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "high" - ]; - string low = 5 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "low" - ]; - string close = 6 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "close" - ]; - string volume = 7 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "volume" - ]; -} diff --git a/proto/dex/query.proto b/proto/dex/query.proto deleted file mode 100644 index 4aeccce56b..0000000000 --- a/proto/dex/query.proto +++ /dev/null @@ -1,401 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "gogoproto/gogo.proto"; -import "google/api/annotations.proto"; -import "cosmos/base/query/v1beta1/pagination.proto"; -import "dex/params.proto"; -import "dex/long_book.proto"; -import "dex/short_book.proto"; -import "dex/price.proto"; -import "dex/contract.proto"; -import "dex/twap.proto"; -import "dex/asset_list.proto"; -import "dex/pair.proto"; -import "dex/order.proto"; -import "dex/match_result.proto"; -import "dex/enums.proto"; -// this line is used by starport scaffolding # 1 - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -// Query defines the gRPC querier service. -service Query { - // Parameters queries the parameters of the module. - rpc Params(QueryParamsRequest) returns (QueryParamsResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/params"; - } - // Queries a LongBook by id. - rpc LongBook(QueryGetLongBookRequest) returns (QueryGetLongBookResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/long_book/{contractAddr}/{priceDenom}/{assetDenom}/{price}"; - } - - // Queries a list of LongBook items. - rpc LongBookAll(QueryAllLongBookRequest) returns (QueryAllLongBookResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/long_book/{contractAddr}/{priceDenom}/{assetDenom}"; - } - -// Queries a ShortBook by id. - rpc ShortBook(QueryGetShortBookRequest) returns (QueryGetShortBookResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/short_book/{contractAddr}/{priceDenom}/{assetDenom}/{price}"; - } - - // Queries a list of ShortBook items. - rpc ShortBookAll(QueryAllShortBookRequest) returns (QueryAllShortBookResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/short_book/{contractAddr}/{priceDenom}/{assetDenom}"; - } - - rpc GetPrice(QueryGetPriceRequest) returns (QueryGetPriceResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/get_price/{contractAddr}/{priceDenom}/{assetDenom}/{timestamp}"; - } - - rpc GetLatestPrice(QueryGetLatestPriceRequest) returns (QueryGetLatestPriceResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/get_latest_price/{contractAddr}/{priceDenom}/{assetDenom}"; - } - - rpc GetPrices(QueryGetPricesRequest) returns (QueryGetPricesResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/get_prices/{contractAddr}/{priceDenom}/{assetDenom}"; - } - - rpc GetTwaps(QueryGetTwapsRequest) returns (QueryGetTwapsResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/get_twaps/{contractAddr}/{lookbackSeconds}"; - } - - // Returns the metadata for a specified denom / display type - rpc AssetMetadata(QueryAssetMetadataRequest) returns (QueryAssetMetadataResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/asset_list/{denom}"; - } - - // Returns metadata for all the assets - rpc AssetList(QueryAssetListRequest) returns (QueryAssetListResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/asset_list"; - } - - // Returns all registered pairs for specified contract address - rpc GetRegisteredPairs(QueryRegisteredPairsRequest) returns (QueryRegisteredPairsResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/registered_pairs"; - } - - // Returns registered contract information - rpc GetRegisteredContract(QueryRegisteredContractRequest) returns (QueryRegisteredContractResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/registered_contract/{contractAddr}"; - } - - rpc GetOrders(QueryGetOrdersRequest) returns (QueryGetOrdersResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/get_orders/{contractAddr}/{account}"; - } - - rpc GetOrder(QueryGetOrderByIDRequest) returns (QueryGetOrderByIDResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/get_order_by_id/{contractAddr}/{priceDenom}/{assetDenom}/{id}"; - } - - rpc GetHistoricalPrices(QueryGetHistoricalPricesRequest) returns (QueryGetHistoricalPricesResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/get_historical_prices/{contractAddr}/{priceDenom}/{assetDenom}/{periodLengthInSeconds}/{numOfPeriods}"; - } - - rpc GetMarketSummary(QueryGetMarketSummaryRequest) returns (QueryGetMarketSummaryResponse) { - option (google.api.http).get = "/sei-protocol/seichain/dex/get_market_summary/{contractAddr}/{priceDenom}/{assetDenom}/{lookbackInSeconds}"; - } - - rpc GetOrderSimulation(QueryOrderSimulationRequest) returns (QueryOrderSimulationResponse) {} - - rpc GetMatchResult(QueryGetMatchResultRequest) returns (QueryGetMatchResultResponse) {} - - rpc GetOrderCount(QueryGetOrderCountRequest) returns (QueryGetOrderCountResponse) {} - -// this line is used by starport scaffolding # 2 -} - -// QueryParamsRequest is request type for the Query/Params RPC method. -message QueryParamsRequest {} - -// QueryParamsResponse is response type for the Query/Params RPC method. -message QueryParamsResponse { - // params holds all the parameters of this module. - Params params = 1 [(gogoproto.nullable) = false]; -} - -message QueryGetLongBookRequest { - string price = 1; - string contractAddr = 2; - string priceDenom = 3; - string assetDenom = 4; -} - -message QueryGetLongBookResponse { - LongBook LongBook = 1 [(gogoproto.nullable) = false]; -} - -message QueryAllLongBookRequest { - cosmos.base.query.v1beta1.PageRequest pagination = 1; - string contractAddr = 2; - string priceDenom = 3; - string assetDenom = 4; -} - -message QueryAllLongBookResponse { - repeated LongBook LongBook = 1 [(gogoproto.nullable) = false]; - cosmos.base.query.v1beta1.PageResponse pagination = 2; -} - -message QueryGetShortBookRequest { - string price = 1; - string contractAddr = 2; - string priceDenom = 3; - string assetDenom = 4; -} - -message QueryGetShortBookResponse { - ShortBook ShortBook = 1 [(gogoproto.nullable) = false]; -} - -message QueryAllShortBookRequest { - cosmos.base.query.v1beta1.PageRequest pagination = 1; - string contractAddr = 2; - string priceDenom = 3; - string assetDenom = 4; -} - -message QueryAllShortBookResponse { - repeated ShortBook ShortBook = 1 [(gogoproto.nullable) = false]; - cosmos.base.query.v1beta1.PageResponse pagination = 2; -} - -message QueryGetPricesRequest { - string priceDenom = 1; - string assetDenom = 2; - string contractAddr = 3; -} - -message QueryGetPricesResponse { - repeated Price prices = 1; -} - -message QueryGetPriceRequest { - string priceDenom = 1; - string assetDenom = 2; - string contractAddr = 3; - uint64 timestamp = 4; -} - -message QueryGetPriceResponse { - Price price = 1; - bool found = 2; -} - -message QueryGetLatestPriceRequest { - string priceDenom = 1 [ - (gogoproto.jsontag) = "price_denom" - ]; - string assetDenom = 2 [ - (gogoproto.jsontag) = "asset_denom" - ]; - string contractAddr = 3 [ - (gogoproto.jsontag) = "contract_address" - ]; -} - -message QueryGetLatestPriceResponse { - Price price = 1; -} - -message QueryGetTwapsRequest { - string contractAddr = 1 [ - (gogoproto.jsontag) = "contract_address" - ]; - uint64 lookbackSeconds = 2 [ - (gogoproto.jsontag) = "lookback_seconds" - ]; - } - -message QueryGetTwapsResponse { - repeated Twap twaps = 1 [ - (gogoproto.jsontag) = "twaps" - ]; -} - -message QueryAssetListRequest {} - -message QueryAssetListResponse { - repeated AssetMetadata assetList = 1 [(gogoproto.nullable) = false]; -} - -message QueryAssetMetadataRequest { - string denom = 1; -} - -message QueryAssetMetadataResponse { - AssetMetadata metadata = 1; -} - -message QueryRegisteredPairsRequest { - string contractAddr = 1 [ - (gogoproto.jsontag) = "contract_address" - ]; -} - -message QueryRegisteredPairsResponse { - repeated Pair pairs = 1 [(gogoproto.nullable) = false]; -} - -message QueryRegisteredContractRequest { - string contractAddr = 1 [ - (gogoproto.jsontag) = "contract_address" - ]; -} - -message QueryRegisteredContractResponse { - ContractInfoV2 contract_info = 1; -} - -message QueryGetOrdersRequest{ - string contractAddr = 1 [ - (gogoproto.jsontag) = "contract_address" - ]; - string account = 2 [ - (gogoproto.jsontag) = "account" - ]; -} - -message QueryGetOrdersResponse { - repeated Order orders = 1 [ - (gogoproto.jsontag) = "orders" - ]; -} - -message QueryGetOrderByIDRequest{ - string contractAddr = 1 [ - (gogoproto.jsontag) = "contract_address" - ]; - string priceDenom = 2 [ - (gogoproto.jsontag) = "price_denom" - ]; - string assetDenom = 3 [ - (gogoproto.jsontag) = "asset_denom" - ]; - uint64 id = 4 [ - (gogoproto.jsontag) = "id" - ]; -} - -message QueryGetOrderByIDResponse { - Order order = 1 [ - (gogoproto.jsontag) = "order" - ]; -} - -message QueryGetHistoricalPricesRequest { - string contractAddr = 1 [ - (gogoproto.jsontag) = "contract_address" - ]; - string priceDenom = 2 [ - (gogoproto.jsontag) = "price_denom" - ]; - string assetDenom = 3 [ - (gogoproto.jsontag) = "asset_denom" - ]; - uint64 periodLengthInSeconds = 4 [ - (gogoproto.jsontag) = "period_length_in_seconds" - ]; - uint64 numOfPeriods = 5 [ - (gogoproto.jsontag) = "number_of_periods" - ]; -} - -message QueryGetHistoricalPricesResponse { - repeated PriceCandlestick prices = 1[ - (gogoproto.jsontag) = "prices" - ]; -} - -message QueryGetMarketSummaryRequest { - string contractAddr = 1 [ - (gogoproto.jsontag) = "contract_address" - ]; - string priceDenom = 2 [ - (gogoproto.jsontag) = "price_denom" - ]; - string assetDenom = 3 [ - (gogoproto.jsontag) = "asset_denom" - ]; - uint64 lookbackInSeconds = 4 [ - (gogoproto.jsontag) = "lookback_in_seconds" - ]; -} - -message QueryGetMarketSummaryResponse{ - string totalVolume = 1 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "total_volume" - ]; - string totalVolumeNotional = 2 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "total_volume_notional" - ]; - string highPrice = 3 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "high_price" - ]; - string lowPrice = 4 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "low_price" - ]; - string lastPrice = 5 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "last_price" - ]; -} - -message QueryOrderSimulationRequest { - Order order = 1 [ - (gogoproto.jsontag) = "order" - ]; - string contractAddr = 2 [ - (gogoproto.jsontag) = "contract_address" - ]; -} - -message QueryOrderSimulationResponse { - string ExecutedQuantity = 1 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "executed_quantity" - ]; -} - -message QueryGetMatchResultRequest { - string contractAddr = 1 [ - (gogoproto.jsontag) = "contract_address" - ]; -} - -message QueryGetMatchResultResponse { - MatchResult result = 1 [ - (gogoproto.jsontag) = "result" - ]; -} - -message QueryGetOrderCountRequest { - string contractAddr = 1 [ - (gogoproto.jsontag) = "contract_address" - ]; - string priceDenom = 2 [ - (gogoproto.jsontag) = "price_denom" - ]; - string assetDenom = 3 [ - (gogoproto.jsontag) = "asset_denom" - ]; - string price = 4 [ - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.jsontag) = "price" - ]; - PositionDirection positionDirection = 5 [ - (gogoproto.jsontag) = "position_direction" - ]; -} - -message QueryGetOrderCountResponse { - uint64 count = 1 [ - (gogoproto.jsontag) = "count" - ]; -} -// this line is used by starport scaffolding # 3 diff --git a/proto/dex/settlement.proto b/proto/dex/settlement.proto deleted file mode 100644 index 8e5487ebd1..0000000000 --- a/proto/dex/settlement.proto +++ /dev/null @@ -1,40 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; -import "gogoproto/gogo.proto"; - -message SettlementEntry { - string account = 1 [(gogoproto.jsontag) = "account"]; - string priceDenom = 2 [(gogoproto.jsontag) = "price_denom"]; - string assetDenom = 3 [(gogoproto.jsontag) = "asset_denom"]; - string quantity = 4 [ - (gogoproto.moretags) = "yaml:\"quantity\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "quantity" - ]; - string executionCostOrProceed = 5 [ - (gogoproto.moretags) = "yaml:\"execution_cost_or_proceed\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "execution_cost_or_proceed" - ]; - string expectedCostOrProceed = 6 [ - (gogoproto.moretags) = "yaml:\"expected_cost_or_proceed\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "expected_cost_or_proceed" - ]; - string positionDirection = 7 [(gogoproto.jsontag) = "position_direction"]; - string orderType = 8 [(gogoproto.jsontag) = "order_type"]; - uint64 orderId = 9 [(gogoproto.jsontag) = "order_id"]; - uint64 timestamp = 10 [(gogoproto.jsontag) = "timestamp"]; - uint64 height = 11 [(gogoproto.jsontag) = "height"]; - uint64 settlementId = 12 [(gogoproto.jsontag) = "settlement_id"]; -} - -message Settlements { - int64 epoch = 1 [(gogoproto.jsontag) = "epoch"]; - repeated SettlementEntry entries = 2 [(gogoproto.jsontag) = "entries"]; -} \ No newline at end of file diff --git a/proto/dex/short_book.proto b/proto/dex/short_book.proto deleted file mode 100644 index b355c3cab2..0000000000 --- a/proto/dex/short_book.proto +++ /dev/null @@ -1,19 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; -import "dex/order_entry.proto"; -import "gogoproto/gogo.proto"; - -message ShortBook { - string price = 1 [ - (gogoproto.moretags) = "yaml:\"price\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "price" - ]; - OrderEntry entry = 2 [ - (gogoproto.jsontag) = "entry" - ]; - -} \ No newline at end of file diff --git a/proto/dex/tick_size.proto b/proto/dex/tick_size.proto deleted file mode 100644 index 80eece546e..0000000000 --- a/proto/dex/tick_size.proto +++ /dev/null @@ -1,22 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; -import "dex/pair.proto"; -import "gogoproto/gogo.proto"; - -message TickSize { - Pair pair = 1 [ - (gogoproto.jsontag) = "pair" - ]; - string ticksize = 2 [ - (gogoproto.moretags) = "yaml:\"tick_size\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "tick_size" - ]; - string contractAddr = 3 [ - (gogoproto.moretags) = "yaml:\"tick_size\"", - (gogoproto.jsontag) = "contract_addr" - ]; -} \ No newline at end of file diff --git a/proto/dex/twap.proto b/proto/dex/twap.proto deleted file mode 100644 index cca0836fb9..0000000000 --- a/proto/dex/twap.proto +++ /dev/null @@ -1,24 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "gogoproto/gogo.proto"; -import "dex/pair.proto"; - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - - -message Twap { - - Pair pair = 1 [ - (gogoproto.jsontag) = "pair" - ]; - string twap = 2 [ - (gogoproto.moretags) = "yaml:\"twap\"", - (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Dec", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "twap" - ]; - uint64 lookbackSeconds = 3 [ - (gogoproto.jsontag) = "lookback_seconds" - ]; -} diff --git a/proto/dex/tx.proto b/proto/dex/tx.proto deleted file mode 100644 index b21f5dde76..0000000000 --- a/proto/dex/tx.proto +++ /dev/null @@ -1,147 +0,0 @@ -syntax = "proto3"; -package seiprotocol.seichain.dex; - -import "cosmos/base/v1beta1/coin.proto"; -import "gogoproto/gogo.proto"; -import "dex/contract.proto"; -import "dex/order.proto"; -import "dex/pair.proto"; -import "dex/tick_size.proto"; - -// this line is used by starport scaffolding # proto/tx/import - -option go_package = "github.com/sei-protocol/sei-chain/x/dex/types"; - -// Msg defines the Msg service. -service Msg { - rpc PlaceOrders(MsgPlaceOrders) returns (MsgPlaceOrdersResponse); - rpc CancelOrders(MsgCancelOrders) returns (MsgCancelOrdersResponse); - rpc RegisterContract(MsgRegisterContract) returns(MsgRegisterContractResponse); - rpc ContractDepositRent(MsgContractDepositRent) returns(MsgContractDepositRentResponse); - rpc UnregisterContract(MsgUnregisterContract) returns(MsgUnregisterContractResponse); - rpc RegisterPairs(MsgRegisterPairs) returns(MsgRegisterPairsResponse); - rpc UpdatePriceTickSize(MsgUpdatePriceTickSize) returns(MsgUpdateTickSizeResponse); - rpc UpdateQuantityTickSize(MsgUpdateQuantityTickSize) returns(MsgUpdateTickSizeResponse); - rpc UnsuspendContract(MsgUnsuspendContract) returns(MsgUnsuspendContractResponse); - // privileged endpoints below - -// this line is used by starport scaffolding # proto/tx/rpc -} - -message MsgPlaceOrders { - string creator = 1 [ - (gogoproto.jsontag) = "creator" - ]; - repeated Order orders = 2 [ - (gogoproto.jsontag) = "orders" - ]; - string contractAddr = 3 [ - (gogoproto.jsontag) = "contract_address" - ]; - repeated cosmos.base.v1beta1.Coin funds = 4 [ - (gogoproto.nullable) = false, - (gogoproto.castrepeated) = "github.com/cosmos/cosmos-sdk/types.Coins", - (gogoproto.jsontag) = "funds" - ]; -} - -message MsgPlaceOrdersResponse { - repeated uint64 orderIds = 1 [ - (gogoproto.moretags) = "yaml:\"order_ids\"", - (gogoproto.jsontag) = "order_ids" - ]; -} - -message MsgCancelOrders { - string creator = 1 [ - (gogoproto.jsontag) = "creator" - ]; - repeated Cancellation cancellations = 2 [ - (gogoproto.jsontag) = "cancellations" - ]; - string contractAddr = 3 [ - (gogoproto.jsontag) = "contract_address" - ]; -} - -message MsgCancelOrdersResponse {} - -message MsgRegisterContract { - string creator = 1; - ContractInfoV2 contract = 2; -} - -message MsgRegisterContractResponse {} - -message MsgContractDepositRent { - string contractAddr = 1 [ - (gogoproto.jsontag) = "contract_address" - ]; - uint64 amount = 2 [ - (gogoproto.jsontag) = "amount" - ]; - string sender = 3 [ - (gogoproto.jsontag) = "sender" - ]; -} - -message MsgContractDepositRentResponse {} - -message MsgUnregisterContract { - string creator = 1 [ - (gogoproto.jsontag) = "creator" - ]; - string contractAddr = 2 [ - (gogoproto.jsontag) = "contract_address" - ]; -} - -message MsgUnregisterContractResponse {} - -message MsgRegisterPairs { - string creator = 1; - repeated BatchContractPair batchcontractpair = 3 [ - (gogoproto.moretags) = "yaml:\"batch_contract_pair\"", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "batch_contract_pair" - ]; -} - -message MsgRegisterPairsResponse {} - -message MsgUpdatePriceTickSize { - string creator = 1 [ - (gogoproto.jsontag) = "creator" - ]; - repeated TickSize tickSizeList = 2 [ - (gogoproto.moretags) = "yaml:\"tick_size_list\"", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "tick_size_list" - ]; -} - -message MsgUpdateQuantityTickSize { - string creator = 1 [ - (gogoproto.jsontag) = "creator" - ]; - repeated TickSize tickSizeList = 2 [ - (gogoproto.moretags) = "yaml:\"tick_size_list\"", - (gogoproto.nullable) = false, - (gogoproto.jsontag) = "tick_size_list" - ]; -} - -message MsgUpdateTickSizeResponse {} - -message MsgUnsuspendContract { - string creator = 1 [ - (gogoproto.jsontag) = "creator" - ]; - string contractAddr = 2 [ - (gogoproto.jsontag) = "contract_address" - ]; -} - -message MsgUnsuspendContractResponse {} - -// this line is used by starport scaffolding # proto/tx/message \ No newline at end of file diff --git a/proto/mint/v1beta1/gov.proto b/proto/mint/v1beta1/gov.proto index 084b95196e..1f9c2133ee 100644 --- a/proto/mint/v1beta1/gov.proto +++ b/proto/mint/v1beta1/gov.proto @@ -6,8 +6,6 @@ import "mint/v1beta1/mint.proto"; option go_package = "github.com/sei-protocol/sei-chain/x/mint/types"; -// AddAssetMetadataProposal is a gov Content type for adding a new asset -// to the dex module's asset list. message UpdateMinterProposal { option (gogoproto.equal) = false; option (gogoproto.goproto_getters) = false; diff --git a/scripts/dump_app_state_for_height.sh b/scripts/dump_app_state_for_height.sh index 3107b29476..5d7d2b6477 100755 --- a/scripts/dump_app_state_for_height.sh +++ b/scripts/dump_app_state_for_height.sh @@ -28,7 +28,7 @@ fi cd $HOME sudo rm -r state_$HEIGHT mkdir state_$HEIGHT -for key in dex wasm accesscontrol oracle epoch mint acc bank crisis feegrant staking distribution slashing gov params ibc upgrade evidence transfer tokenfactory +for key in wasm accesscontrol oracle epoch mint acc bank crisis feegrant staking distribution slashing gov params ibc upgrade evidence transfer tokenfactory do $HOME/go/bin/iaviewer data $HOME/.sei/data/application.db "s/k:"$key"/" $HEIGHT > $HOME/state_$HEIGHT/$key.data $HOME/go/bin/iaviewer shape $HOME/.sei/data/application.db "s/k:"$key"/" $HEIGHT > $HOME/state_$HEIGHT/$key.shape diff --git a/scripts/upload_clearing_house_contract.sh b/scripts/upload_clearing_house_contract.sh deleted file mode 100755 index cfbe49e9b5..0000000000 --- a/scripts/upload_clearing_house_contract.sh +++ /dev/null @@ -1,18 +0,0 @@ -# ./scripts/initialize_local.sh to spawn chain locally, endpoint is default to localhost:9090 -# build the contract to wasm with `cargo build; docker run --rm -v "$(pwd)":/code --mount type=volume,source="$(basename "$(pwd)")_cache",target=/code/target --mount type=volume,source=registry_cache,target=/usr/local/cargo/registry cosmwasm/rust-optimizer:0.12.5` - -# upload the code -printf '00000000\n' | ./build/seid tx wasm store ../matrix-contract/clearing-house-contract/artifacts/clearing_house.wasm -y --from=alice --chain-id=sei --gas=3000000 --fees=100000usei --broadcast-mode=block -# replace addr here with an addr you have privateKey -printf '00000000\n' | ./build/seid tx wasm instantiate 1 '{"whitelist": ["sei1zywupnfk3t8lvtuzh540vls8mf53r5zuq98wkt"],"use_whitelist":false,"admin":"sei1zywupnfk3t8lvtuzh540vls8mf53r5zuq98wkt","limit_order_fee":{"decimal":"0.0001","negative":false},"market_order_fee":{"decimal":"0.0001","negative":false},"liquidation_order_fee":{"decimal":"0.0001","negative":false},"margin_ratio":{"decimal":"0.0625","negative":false},"max_leverage":{"decimal":"4","negative":false}}' -y --no-admin --chain-id=sei --gas=1500000 --fees=15000usei --broadcast-mode=block --label=dex --from=alice -# contract_address highly possible is the same, if not replace -printf '00000000\n' | ./build/seid tx dex register-contract sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m 1 -y --from=alice --chain-id=sei --fees=100000usei --gas=500000 --broadcast-mode=block -# register a pair -printf '00000000\n' | ./build/seid tx dex register-pairs ./x/dex/example/register-pair-tx.json -y --from=alice --chain-id=sei --fees=10000000usei --gas=500000 --broadcast-mode=block -sleep 5 -printf '00000000\n' | ./build/seid tx dex update-tick-size ./x/dex/example/update-tick-size-tx.json -y --from=alice --chain-id=sei --fees=10000000usei --gas=500000 --broadcast-mode=block -printf '00000000\n' | ./build/seid tx gov deposit 2 10000000usei -y --from=alice --chain-id=sei --fees=10000000usei --gas=500000 --broadcast-mode=block -printf '00000000\n' | ./build/seid tx gov vote 2 yes -y --from=alice --chain-id=sei --fees=10000000usei --gas=500000 --broadcast-mode=block -# order: (position_direction, price, quantity, price_denom, asset_denom, position_effect(open/close), order_type(limit, market,..), leverage) -# need to wait for vote period close to take effect, seem no early stop implemented for vote -# ./build/seid tx dex place-orders sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m Long,1.01,5,usdc,sei,Open,Limit,1 --amount=10000usei -y --from=alice --chain-id=sei --fees=10000usei --gas=50000000 --broadcast-mode=block \ No newline at end of file diff --git a/testutil/fuzzing/dex.go b/testutil/fuzzing/dex.go deleted file mode 100644 index 78070362a9..0000000000 --- a/testutil/fuzzing/dex.go +++ /dev/null @@ -1,228 +0,0 @@ -package fuzzing - -import ( - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -const BaselinePrice = 1234.56 - -var ValidAccountCorpus = []string{ - "sei1h9yjz89tl0dl6zu65dpxcqnxfhq60wxx8s5kag", - "sei1c2q6xm0x684rshrnlg898zm3vpwz92pcfhgmws", - "sei1ewxvf5a9wq9zk5nurtl6m9yfxpnhyp7s7uk5sl", - "sei1lllgxa294pshcsrsrteh7sj6ey0zqgty30sl8a", - "sei1vhn2p3xavts9swus27zz3n56tz98g3f6unavs2", - "sei1jpkqjfydghgrc23chmnj52xln0muz09j5huhkt", - "sei1k98zjg7scsmk6d4ye8hhrv3an6ppykvt660736", - "sei1wxpqjzdmtjm6gwg6555n0a0aqglrvnp3pqh9hs", - "sei1yuyyr3xg7jhk7pjkrp4j6h88t7gv35e29pfvmf", - "sei1vjgdad5v2euf98nj3pwg5d8agflr384k0eks43", -} - -var AccountCorpus = append([]string{ - "invalid", -}, ValidAccountCorpus...) - -var ContractCorpus = []string{ - "invalid", - "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m", - "sei1nc5tatafv6eyq7llkr2gv50ff9e22mnf70qgjlv737ktmt4eswrqms7u8a", -} - -var ( - MicroTick = sdk.MustNewDecFromStr("0.000001") - MilliTick = sdk.MustNewDecFromStr("0.001") - WholeTick = sdk.OneDec() - PairCorpus = []types.Pair{ - {}, - {PriceDenom: "SEI"}, - {AssetDenom: "ATOM"}, - { - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - { - PriceDenom: "SEI", - AssetDenom: "ATOM", - PriceTicksize: &MicroTick, - QuantityTicksize: &MicroTick, - }, - { - PriceDenom: "SEI", - AssetDenom: "ATOM", - PriceTicksize: &MilliTick, - QuantityTicksize: &MilliTick, - }, - { - PriceDenom: "SEI", - AssetDenom: "ATOM", - PriceTicksize: &WholeTick, - QuantityTicksize: &WholeTick, - }, - { - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - { - PriceDenom: "USDC", - AssetDenom: "ATOM", - PriceTicksize: &MicroTick, - QuantityTicksize: &MicroTick, - }, - { - PriceDenom: "USDC", - AssetDenom: "ATOM", - PriceTicksize: &MilliTick, - QuantityTicksize: &MilliTick, - }, - { - PriceDenom: "USDC", - AssetDenom: "ATOM", - PriceTicksize: &WholeTick, - QuantityTicksize: &WholeTick, - }, - } -) - -func GetAccount(i int) string { - ui := uint64(i) % uint64(len(AccountCorpus)) - return AccountCorpus[int(ui)] -} - -func GetValidAccount(i int) string { - ui := uint64(i) % uint64(len(ValidAccountCorpus)) - return ValidAccountCorpus[int(ui)] -} - -func GetContract(i int) string { - ui := uint64(i) % uint64(len(ContractCorpus)) - return ContractCorpus[int(ui)] -} - -func GetPair(i int) types.Pair { - ui := uint64(i) % uint64(len(PairCorpus)) - return PairCorpus[int(ui)] -} - -func GetPlacedOrders(direction types.PositionDirection, orderType types.OrderType, pair types.Pair, prices []byte, quantities []byte) []*types.Order { - // take the shorter slice's length - if len(prices) < len(quantities) { - quantities = quantities[:len(prices)] - } else { - prices = prices[:len(quantities)] - } - res := []*types.Order{} - for i, price := range prices { - var priceDec sdk.Dec - if direction == types.PositionDirection_LONG { - priceDec = sdk.MustNewDecFromStr(fmt.Sprintf("%f", BaselinePrice+float64(price))) - } else { - priceDec = sdk.MustNewDecFromStr(fmt.Sprintf("%f", BaselinePrice-float64(price))) - } - quantity := sdk.NewDec(int64(quantities[i])) - res = append(res, &types.Order{ - Id: uint64(i), - Status: types.OrderStatus_PLACED, - Price: priceDec, - Quantity: quantity, - PositionDirection: direction, - OrderType: orderType, - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - }) - } - return res -} - -func GetOrderBookEntries(buy bool, priceDenom string, assetDenom string, entryWeights []byte, allAccountIndices []byte, allWeights []byte) []types.OrderBookEntry { - res := []types.OrderBookEntry{} - totalPriceWeights := uint64(0) - for _, entryWeight := range entryWeights { - totalPriceWeights += uint64(entryWeight) - } - if totalPriceWeights == uint64(0) { - return res - } - sliceStartAccnt, sliceStartWeights := 0, 0 - cumWeights := uint64(0) - for i, entryWeight := range entryWeights { - var price sdk.Dec - if buy { - price = sdk.MustNewDecFromStr(fmt.Sprintf("%f", BaselinePrice-float64(i))) - } else { - price = sdk.MustNewDecFromStr(fmt.Sprintf("%f", BaselinePrice+float64(i))) - } - cumWeights += uint64(entryWeight) - nextSliceStartAccnt := int(cumWeights * uint64(len(allAccountIndices)) / totalPriceWeights) - nextSliceStartWeights := int(cumWeights * uint64(len(allWeights)) / totalPriceWeights) - entry := types.OrderEntry{ - Price: price, - Quantity: sdk.NewDec(int64(uint64((entryWeight)))), - PriceDenom: priceDenom, - AssetDenom: assetDenom, - Allocations: GetAllocations( - int64(uint64((entryWeight))), - allAccountIndices[sliceStartAccnt:nextSliceStartAccnt], - allWeights[sliceStartWeights:nextSliceStartWeights], - ), - } - if buy { - res = append(res, &types.LongBook{ - Price: price, - Entry: &entry, - }) - } else { - res = append(res, &types.ShortBook{ - Price: price, - Entry: &entry, - }) - } - sliceStartAccnt, sliceStartWeights = nextSliceStartAccnt, nextSliceStartWeights - } - return res -} - -func GetAllocations(totalQuantity int64, accountIndices []byte, weights []byte) []*types.Allocation { - // take the shorter slice's length - if len(accountIndices) < len(weights) { - weights = weights[:len(accountIndices)] - } else { - accountIndices = accountIndices[:len(weights)] - } - // dedupe and aggregate - aggregatedAccountsToWeights := map[string]uint64{} - totalWeight := uint64(0) - for i, accountIdx := range accountIndices { - account := GetValidAccount(int(accountIdx)) - weight := uint64(weights[i]) - if old, ok := aggregatedAccountsToWeights[account]; !ok { - aggregatedAccountsToWeights[account] = weight - } else { - aggregatedAccountsToWeights[account] = old + weight - } - totalWeight += weight - } - - quantityDec := sdk.NewDec(totalQuantity) - totalWeightDec := sdk.NewDec(int64(totalWeight)) - res := []*types.Allocation{} - orderID := 0 - for account, weight := range aggregatedAccountsToWeights { - var quantity sdk.Dec - if totalWeightDec.IsZero() { - quantity = sdk.ZeroDec() - } else { - quantity = quantityDec.Mul(sdk.NewDec(int64(weight))).Quo(totalWeightDec) - } - res = append(res, &types.Allocation{ - OrderId: uint64(orderID), - Account: account, - Quantity: quantity, - }) - orderID++ - } - return res -} diff --git a/testutil/keeper/dex.go b/testutil/keeper/dex.go deleted file mode 100644 index 5681676b7b..0000000000 --- a/testutil/keeper/dex.go +++ /dev/null @@ -1,196 +0,0 @@ -package keeper - -import ( - "context" - "testing" - - "github.com/cosmos/cosmos-sdk/codec" - "github.com/cosmos/cosmos-sdk/store" - storetypes "github.com/cosmos/cosmos-sdk/store/types" - sdk "github.com/cosmos/cosmos-sdk/types" - authkeeper "github.com/cosmos/cosmos-sdk/x/auth/keeper" - authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - bankkeeper "github.com/cosmos/cosmos-sdk/x/bank/keeper" - banktypes "github.com/cosmos/cosmos-sdk/x/bank/types" - paramskeeper "github.com/cosmos/cosmos-sdk/x/params/keeper" - typesparams "github.com/cosmos/cosmos-sdk/x/params/types" - "github.com/sei-protocol/sei-chain/app" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - epochkeeper "github.com/sei-protocol/sei-chain/x/epoch/keeper" - epochtypes "github.com/sei-protocol/sei-chain/x/epoch/types" - minttypes "github.com/sei-protocol/sei-chain/x/mint/types" - "github.com/stretchr/testify/require" - "github.com/tendermint/tendermint/libs/log" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" - tmdb "github.com/tendermint/tm-db" -) - -const ( - TestAccount = "sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx" - TestContract = "sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc" - TestAccount2 = "sei1vk2f6aps83xahv2sql4equx8fa95jgcnsdxkvr" - TestContract2 = "sei17p9rzwnnfxcjp32un9ug7yhhzgtkhvl9jfksztgw5uh69wac2pgsrtqewe" - TestPriceDenom = "usdc" - TestAssetDenom = "atom" -) - -var ( - TestTicksize = sdk.OneDec() - TestPair = types.Pair{ - PriceDenom: TestPriceDenom, - AssetDenom: TestAssetDenom, - PriceTicksize: &TestTicksize, - QuantityTicksize: &TestTicksize, - } -) - -func TestApp() *app.App { - return app.Setup(false, false) -} - -func DexKeeper(t testing.TB) (*keeper.Keeper, sdk.Context) { - storeKey := sdk.NewKVStoreKey(types.StoreKey) - keyAcc := sdk.NewKVStoreKey(authtypes.StoreKey) - keyBank := sdk.NewKVStoreKey(banktypes.StoreKey) - keyParams := sdk.NewKVStoreKey(typesparams.StoreKey) - tKeyParams := sdk.NewTransientStoreKey(typesparams.TStoreKey) - keyEpochs := sdk.NewKVStoreKey(epochtypes.StoreKey) - dexMemStoreKey := storetypes.NewMemoryStoreKey(types.MemStoreKey) - memStoreKey := storetypes.NewMemoryStoreKey(epochtypes.MemStoreKey) - - blackListAddrs := map[string]bool{} - - maccPerms := map[string][]string{ - types.ModuleName: nil, - minttypes.ModuleName: {authtypes.Minter}, - } - - db := tmdb.NewMemDB() - stateStore := store.NewCommitMultiStore(db) - stateStore.MountStoreWithDB(keyAcc, sdk.StoreTypeIAVL, db) - stateStore.MountStoreWithDB(keyBank, sdk.StoreTypeIAVL, db) - stateStore.MountStoreWithDB(storeKey, sdk.StoreTypeIAVL, db) - stateStore.MountStoreWithDB(memStoreKey, sdk.StoreTypeMemory, nil) - stateStore.MountStoreWithDB(dexMemStoreKey, sdk.StoreTypeMemory, nil) - stateStore.MountStoreWithDB(keyEpochs, sdk.StoreTypeIAVL, db) - stateStore.MountStoreWithDB(tKeyParams, sdk.StoreTypeTransient, db) - stateStore.MountStoreWithDB(keyParams, sdk.StoreTypeIAVL, db) - require.NoError(t, stateStore.LoadLatestVersion()) - - cdc := codec.NewProtoCodec(app.MakeEncodingConfig().InterfaceRegistry) - - paramsSubspace := typesparams.NewSubspace(cdc, - types.Amino, - storeKey, - memStoreKey, - "DexParams", - ) - paramsKeeper := paramskeeper.NewKeeper(cdc, codec.NewLegacyAmino(), keyParams, tKeyParams) - accountKeeper := authkeeper.NewAccountKeeper(cdc, keyAcc, paramsKeeper.Subspace(authtypes.ModuleName), authtypes.ProtoBaseAccount, maccPerms) - bankKeeper := bankkeeper.NewBaseKeeper(cdc, keyBank, accountKeeper, paramsKeeper.Subspace(banktypes.ModuleName), blackListAddrs) - epochKeeper := epochkeeper.NewKeeper(cdc, keyEpochs, memStoreKey, paramsKeeper.Subspace(epochtypes.ModuleName)) - k := keeper.NewKeeper( - cdc, - storeKey, - dexMemStoreKey, - paramsSubspace, - *epochKeeper, - bankKeeper, - accountKeeper, - ) - - ctx := sdk.NewContext(stateStore, tmproto.Header{}, false, log.NewNopLogger()) - k.CreateModuleAccount(ctx) - - // Initialize params - k.SetParams(ctx, types.DefaultParams()) - bankParams := banktypes.DefaultParams() - bankParams.SendEnabled = []*banktypes.SendEnabled{ - { - Denom: TestPriceDenom, - Enabled: true, - }, - } - bankKeeper.SetParams(ctx, bankParams) - - return k, ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(dexMemStoreKey))) -} - -func CreateAssetMetadata(keeper *keeper.Keeper, ctx sdk.Context) types.AssetMetadata { - ibcInfo := types.AssetIBCInfo{ - SourceChannel: "channel-1", - DstChannel: "channel-2", - SourceDenom: "uusdc", - SourceChainID: "axelar", - } - - denomUnit := banktypes.DenomUnit{ - Denom: "ibc/D189335C6E4A68B513C10AB227BF1C1D38C746766278BA3EEB4FB14124F1D858", - Exponent: 0, - Aliases: []string{"axlusdc", "usdc"}, - } - - var denomUnits []*banktypes.DenomUnit - denomUnits = append(denomUnits, &denomUnit) - - metadata := banktypes.Metadata{ - Description: "Circle's stablecoin on Axelar", - DenomUnits: denomUnits, - Base: "ibc/D189335C6E4A68B513C10AB227BF1C1D38C746766278BA3EEB4FB14124F1D858", - Name: "USD Coin", - Display: "axlusdc", - Symbol: "USDC", - } - - item := types.AssetMetadata{ - IbcInfo: &ibcInfo, - TypeAsset: "erc20", - Metadata: metadata, - } - - keeper.SetAssetMetadata(ctx, item) - - return item -} - -func SeedPriceSnapshot(ctx sdk.Context, k *keeper.Keeper, price string, timestamp uint64) { - priceSnapshot := types.Price{ - SnapshotTimestampInSeconds: timestamp, - Price: sdk.MustNewDecFromStr(price), - Pair: &TestPair, - } - k.SetPriceState(ctx, priceSnapshot, TestContract) -} - -func CreateNLongBook(keeper *keeper.Keeper, ctx sdk.Context, n int) []types.LongBook { - items := make([]types.LongBook, n) - for i := range items { - items[i].Entry = &types.OrderEntry{ - Price: sdk.NewDec(int64(i)), - Quantity: sdk.NewDec(int64(i)), - PriceDenom: TestPriceDenom, - AssetDenom: TestAssetDenom, - } - items[i].Price = sdk.NewDec(int64(i)) - keeper.SetLongBook(ctx, TestContract, items[i]) - } - return items -} - -func CreateNShortBook(keeper *keeper.Keeper, ctx sdk.Context, n int) []types.ShortBook { - items := make([]types.ShortBook, n) - for i := range items { - items[i].Entry = &types.OrderEntry{ - Price: sdk.NewDec(int64(i)), - Quantity: sdk.NewDec(int64(i)), - PriceDenom: TestPriceDenom, - AssetDenom: TestAssetDenom, - } - items[i].Price = sdk.NewDec(int64(i)) - keeper.SetShortBook(ctx, TestContract, items[i]) - } - return items -} diff --git a/testutil/keeper/epoch.go b/testutil/keeper/epoch.go index 0f55846008..57f91de84d 100644 --- a/testutil/keeper/epoch.go +++ b/testutil/keeper/epoch.go @@ -9,6 +9,7 @@ import ( storetypes "github.com/cosmos/cosmos-sdk/store/types" sdk "github.com/cosmos/cosmos-sdk/types" typesparams "github.com/cosmos/cosmos-sdk/x/params/types" + "github.com/sei-protocol/sei-chain/app" "github.com/sei-protocol/sei-chain/x/epoch/keeper" "github.com/sei-protocol/sei-chain/x/epoch/types" "github.com/stretchr/testify/require" @@ -17,6 +18,10 @@ import ( tmdb "github.com/tendermint/tm-db" ) +func TestApp() *app.App { + return app.Setup(false, false) +} + func EpochKeeper(t testing.TB) (*keeper.Keeper, sdk.Context) { storeKey := sdk.NewKVStoreKey(types.StoreKey) memStoreKey := storetypes.NewMemoryStoreKey(types.MemStoreKey) diff --git a/testutil/processblock/msgs/dex.go b/testutil/processblock/msgs/dex.go deleted file mode 100644 index 6a9e79991b..0000000000 --- a/testutil/processblock/msgs/dex.go +++ /dev/null @@ -1,101 +0,0 @@ -package msgs - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/utils" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" -) - -type Market struct { - contract string - priceDenom string - assetDenom string -} - -func NewMarket(contract string, priceDenom string, assetDenom string) *Market { - return &Market{ - contract: contract, - priceDenom: priceDenom, - assetDenom: assetDenom, - } -} - -func (m *Market) Register(admin sdk.AccAddress, deps []string, deposit uint64) []sdk.Msg { - pointOne := sdk.NewDecWithPrec(1, 1) - return []sdk.Msg{dextypes.NewMsgRegisterContract(admin.String(), 0, m.contract, true, utils.Map(deps, func(dep string) *dextypes.ContractDependencyInfo { - return &dextypes.ContractDependencyInfo{Dependency: dep} - }), deposit), dextypes.NewMsgRegisterPairs(admin.String(), []dextypes.BatchContractPair{{ - ContractAddr: m.contract, - Pairs: []*dextypes.Pair{{ - PriceDenom: m.priceDenom, - AssetDenom: m.assetDenom, - PriceTicksize: &pointOne, - QuantityTicksize: &pointOne, - }}, - }})} -} - -func (m *Market) LongLimitOrder(account sdk.AccAddress, price string, quantity string) *dextypes.MsgPlaceOrders { - o := m.commonOrder(account, price, quantity) - o.PositionDirection = dextypes.PositionDirection_LONG - o.OrderType = dextypes.OrderType_LIMIT - return dextypes.NewMsgPlaceOrders(account.String(), []*dextypes.Order{o}, m.contract, fundForOrder(o)) -} - -func (m *Market) ShortLimitOrder(account sdk.AccAddress, price string, quantity string) *dextypes.MsgPlaceOrders { - o := m.commonOrder(account, price, quantity) - o.PositionDirection = dextypes.PositionDirection_SHORT - o.OrderType = dextypes.OrderType_LIMIT - return dextypes.NewMsgPlaceOrders(account.String(), []*dextypes.Order{o}, m.contract, fundForOrder(o)) -} - -func (m *Market) LongMarketOrder(account sdk.AccAddress, price string, quantity string) *dextypes.MsgPlaceOrders { - o := m.commonOrder(account, price, quantity) - o.PositionDirection = dextypes.PositionDirection_LONG - o.OrderType = dextypes.OrderType_MARKET - return dextypes.NewMsgPlaceOrders(account.String(), []*dextypes.Order{o}, m.contract, fundForOrder(o)) -} - -func (m *Market) ShortMarketOrder(account sdk.AccAddress, price string, quantity string) *dextypes.MsgPlaceOrders { - o := m.commonOrder(account, price, quantity) - o.PositionDirection = dextypes.PositionDirection_SHORT - o.OrderType = dextypes.OrderType_MARKET - return dextypes.NewMsgPlaceOrders(account.String(), []*dextypes.Order{o}, m.contract, fundForOrder(o)) -} - -func (m *Market) CancelLongOrder(account sdk.AccAddress, price string, id uint64) *dextypes.MsgCancelOrders { - c := m.commonCancel(account, price, id) - c.PositionDirection = dextypes.PositionDirection_LONG - return dextypes.NewMsgCancelOrders(account.String(), []*dextypes.Cancellation{c}, m.contract) -} - -func (m *Market) CancelShortOrder(account sdk.AccAddress, price string, id uint64) *dextypes.MsgCancelOrders { - c := m.commonCancel(account, price, id) - c.PositionDirection = dextypes.PositionDirection_SHORT - return dextypes.NewMsgCancelOrders(account.String(), []*dextypes.Cancellation{c}, m.contract) -} - -func (m *Market) commonOrder(account sdk.AccAddress, price string, quantity string) *dextypes.Order { - return &dextypes.Order{ - Account: account.String(), - Price: sdk.MustNewDecFromStr(price), - Quantity: sdk.MustNewDecFromStr(quantity), - PriceDenom: m.priceDenom, - AssetDenom: m.assetDenom, - } -} - -func (m *Market) commonCancel(account sdk.AccAddress, price string, id uint64) *dextypes.Cancellation { - return &dextypes.Cancellation{ - Creator: account.String(), - Price: sdk.MustNewDecFromStr(price), - Id: id, - PriceDenom: m.priceDenom, - AssetDenom: m.assetDenom, - ContractAddr: m.contract, - } -} - -func fundForOrder(o *dextypes.Order) sdk.Coins { - return sdk.NewCoins(sdk.NewCoin("usei", o.Price.Mul(o.Quantity).RoundInt())) -} diff --git a/testutil/processblock/presets.go b/testutil/processblock/presets.go index 785046f28d..27cb58cb84 100644 --- a/testutil/processblock/presets.go +++ b/testutil/processblock/presets.go @@ -9,9 +9,6 @@ import ( authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" distrtypes "github.com/cosmos/cosmos-sdk/x/distribution/types" stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types" - "github.com/sei-protocol/sei-chain/testutil/processblock/msgs" - "github.com/sei-protocol/sei-chain/utils" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" minttypes "github.com/sei-protocol/sei-chain/x/mint/types" ) @@ -20,8 +17,6 @@ type Preset struct { SignableAccounts []sdk.AccAddress AllAccounts []sdk.AccAddress AllValidators []sdk.ValAddress - AllContracts []sdk.AccAddress - AllDexMarkets []*msgs.Market } // 3 unsignable accounts @@ -32,7 +27,6 @@ func CommonPreset(app *App) *Preset { fmt.Printf("Distribution module: %s\n", app.AccountKeeper.GetModuleAddress(distrtypes.ModuleName).String()) fmt.Printf("Staking bonded pool: %s\n", app.AccountKeeper.GetModuleAddress(stakingtypes.BondedPoolName).String()) fmt.Printf("Staking unbonded pool: %s\n", app.AccountKeeper.GetModuleAddress(stakingtypes.NotBondedPoolName).String()) - fmt.Printf("Dex module: %s\n", app.AccountKeeper.GetModuleAddress(dextypes.ModuleName).String()) fmt.Printf("Wasm module: %s\n", app.AccountKeeper.GetModuleAddress(wasm.ModuleName).String()) p := &Preset{ Admin: app.NewSignableAccount("admin"), @@ -55,37 +49,7 @@ func CommonPreset(app *App) *Preset { return p } -func DexPreset(app *App, numAccounts int, numMarkets int) *Preset { - p := CommonPreset(app) - for i := 0; i < numAccounts; i++ { - acc := app.NewSignableAccount(fmt.Sprintf("DexPreset%d", i)) - app.FundAccount(acc, 10000000) - p.AllAccounts = append(p.AllAccounts, acc) - p.SignableAccounts = append(p.SignableAccounts, acc) - fmt.Printf("DexPreset account: %s\n", acc.String()) - } - for i := 0; i < numMarkets; i++ { - contract := app.NewContract(p.Admin, "./mars.wasm") - market := msgs.NewMarket(contract.String(), "SEI", fmt.Sprintf("ATOM%d", i)) - p.AllContracts = append(p.AllContracts, contract) - p.AllDexMarkets = append(p.AllDexMarkets, market) - fmt.Printf("DexPreset contract: %s\n", contract.String()) - } - return p -} - // always with enough fee func (p *Preset) AdminSign(app *App, msgs ...sdk.Msg) signing.Tx { return app.Sign(p.Admin, 10000000, msgs...) } - -func (p *Preset) DoRegisterMarkets(app *App) { - block := utils.Map(p.AllDexMarkets, func(m *msgs.Market) signing.Tx { - return p.AdminSign(app, m.Register(p.Admin, []string{}, 20000000)...) - }) - for i, code := range app.RunBlock(block) { - if code != 0 { - panic(fmt.Sprintf("error code %d when registering the %d-th market", code, i)) - } - } -} diff --git a/testutil/processblock/verify/bank.go b/testutil/processblock/verify/bank.go index 580ee5b85d..2bd76fe9fd 100644 --- a/testutil/processblock/verify/bank.go +++ b/testutil/processblock/verify/bank.go @@ -7,7 +7,6 @@ import ( "github.com/cosmos/cosmos-sdk/x/auth/signing" banktypes "github.com/cosmos/cosmos-sdk/x/bank/types" "github.com/sei-protocol/sei-chain/testutil/processblock" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" "github.com/stretchr/testify/require" ) @@ -32,12 +31,6 @@ func Balance(t *testing.T, app *processblock.App, f BlockRunnable, txs []signing for _, output := range m.Outputs { updateMultipleExpectedBalanceChange(expectedChanges, output.Address, output.Coins, true) } - case *dextypes.MsgPlaceOrders: - updateMultipleExpectedBalanceChange(expectedChanges, m.Creator, m.Funds, false) - updateMultipleExpectedBalanceChange(expectedChanges, m.ContractAddr, m.Funds, true) - case *dextypes.MsgRegisterContract: - funds := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(int64(m.Contract.RentBalance)))) - updateMultipleExpectedBalanceChange(expectedChanges, m.Creator, funds, false) default: // TODO: add coverage for other balance-affecting messages to enable testing for those message types continue diff --git a/testutil/processblock/verify/dex.go b/testutil/processblock/verify/dex.go deleted file mode 100644 index cfc5a2779e..0000000000 --- a/testutil/processblock/verify/dex.go +++ /dev/null @@ -1,269 +0,0 @@ -package verify - -import ( - "sort" - "strings" - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/x/auth/signing" - "github.com/sei-protocol/sei-chain/testutil/processblock" - "github.com/sei-protocol/sei-chain/utils" - dexkeeper "github.com/sei-protocol/sei-chain/x/dex/keeper" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func DexOrders(t *testing.T, app *processblock.App, f BlockRunnable, txs []signing.Tx) BlockRunnable { - return func() []uint32 { - orderPlacementsByMarket := map[string][]*dextypes.Order{} - orderCancellationsByMarket := map[string][]*dextypes.Cancellation{} - markets := map[string]struct{}{} - for _, tx := range txs { - for _, msg := range tx.GetMsgs() { - switch m := msg.(type) { - case *dextypes.MsgPlaceOrders: - for _, o := range m.Orders { - id := strings.Join([]string{m.ContractAddr, o.PriceDenom, o.AssetDenom}, ",") - markets[id] = struct{}{} - if orders, ok := orderPlacementsByMarket[id]; ok { - o.Id = app.DexKeeper.GetNextOrderID(app.Ctx(), m.ContractAddr) + uint64(len(orders)) - orderPlacementsByMarket[id] = append(orders, o) - } else { - o.Id = app.DexKeeper.GetNextOrderID(app.Ctx(), m.ContractAddr) - orderPlacementsByMarket[id] = []*dextypes.Order{o} - } - } - case *dextypes.MsgCancelOrders: - for _, o := range m.Cancellations { - id := strings.Join([]string{m.ContractAddr, o.PriceDenom, o.AssetDenom}, ",") - markets[id] = struct{}{} - if cancels, ok := orderCancellationsByMarket[id]; ok { - orderCancellationsByMarket[id] = append(cancels, o) - } else { - orderCancellationsByMarket[id] = []*dextypes.Cancellation{o} - } - } - default: - continue - } - } - } - expectedLongBookByMarket := map[string]map[string]*dextypes.OrderEntry{} - expectedShortBookByMarket := map[string]map[string]*dextypes.OrderEntry{} - for market := range markets { - orderPlacements := []*dextypes.Order{} - if o, ok := orderPlacementsByMarket[market]; ok { - orderPlacements = o - } - orderCancellations := []*dextypes.Cancellation{} - if c, ok := orderCancellationsByMarket[market]; ok { - orderCancellations = c - } - parts := strings.Split(market, ",") - longBook, shortBook := expectedOrdersForMarket(app.Ctx(), &app.DexKeeper, orderPlacements, orderCancellations, parts[0], parts[1], parts[2]) - expectedLongBookByMarket[market] = longBook - expectedShortBookByMarket[market] = shortBook - } - - results := f() - - for market, longBook := range expectedLongBookByMarket { - parts := strings.Split(market, ",") - contract := parts[0] - priceDenom := parts[1] - assetDenom := parts[2] - require.Equal(t, len(longBook), len(app.DexKeeper.GetAllLongBookForPair(app.Ctx(), contract, priceDenom, assetDenom))) - for price, entry := range longBook { - actual, found := app.DexKeeper.GetLongOrderBookEntryByPrice(app.Ctx(), contract, sdk.MustNewDecFromStr(price), priceDenom, assetDenom) - require.True(t, found) - require.Equal(t, *entry, *(actual.GetOrderEntry())) - } - } - - for market, shortBook := range expectedShortBookByMarket { - parts := strings.Split(market, ",") - contract := parts[0] - priceDenom := parts[1] - assetDenom := parts[2] - require.Equal(t, len(shortBook), len(app.DexKeeper.GetAllShortBookForPair(app.Ctx(), contract, priceDenom, assetDenom))) - for price, entry := range shortBook { - actual, found := app.DexKeeper.GetShortOrderBookEntryByPrice(app.Ctx(), contract, sdk.MustNewDecFromStr(price), priceDenom, assetDenom) - require.True(t, found) - require.Equal(t, *entry, *(actual.GetOrderEntry())) - } - } - - return results - } -} - -// A slow but correct implementation of dex exchange logics that build the expected order book state based on the -// current state and the list of new orders/cancellations, based on dex exchange rules. -func expectedOrdersForMarket( - ctx sdk.Context, - keeper *dexkeeper.Keeper, - orderPlacements []*dextypes.Order, - orderCancellations []*dextypes.Cancellation, - contract string, - priceDenom string, - assetDenom string, -) (longEntries map[string]*dextypes.OrderEntry, shortEntries map[string]*dextypes.OrderEntry) { - longBook := toOrderBookMap(keeper.GetAllLongBookForPair(ctx, contract, priceDenom, assetDenom)) - shortBook := toOrderBookMap(keeper.GetAllShortBookForPair(ctx, contract, priceDenom, assetDenom)) - books := map[dextypes.PositionDirection]map[string]*dextypes.OrderEntry{ - dextypes.PositionDirection_LONG: longBook, - dextypes.PositionDirection_SHORT: shortBook, - } - // first, cancellation - cancelOrders(books, orderCancellations) - // then add new limit orders to book - addOrders(books, orderPlacements) - // then match market orders - matchOrders(getMarketOrderBookMap(orderPlacements, dextypes.PositionDirection_LONG), shortBook) - matchOrders(longBook, getMarketOrderBookMap(orderPlacements, dextypes.PositionDirection_SHORT)) - // finally match limit orders - matchOrders(longBook, shortBook) - return longBook, shortBook -} - -func cancelOrders( - books map[dextypes.PositionDirection]map[string]*dextypes.OrderEntry, - orderCancellations []*dextypes.Cancellation, -) { - for _, cancel := range orderCancellations { - book := books[cancel.PositionDirection] - if entry, ok := book[cancel.Price.String()]; ok { - entry.Allocations = removeMatched(entry.Allocations, func(a *dextypes.Allocation) bool { return a.OrderId == cancel.Id }) - updateEntryQuantity(entry) - if entry.Quantity.IsZero() { - delete(book, cancel.Price.String()) - } - } - } -} - -func addOrders( - books map[dextypes.PositionDirection]map[string]*dextypes.OrderEntry, - orderPlacements []*dextypes.Order, -) { - for _, o := range orderPlacements { - if o.OrderType != dextypes.OrderType_LIMIT { - continue - } - book := books[o.PositionDirection] - newAllocation := &dextypes.Allocation{ - Account: o.Account, - Quantity: o.Quantity, - OrderId: o.Id, - } - if entry, ok := book[o.Price.String()]; ok { - entry.Allocations = append(entry.Allocations, newAllocation) - updateEntryQuantity(entry) - } else { - book[o.Price.String()] = &dextypes.OrderEntry{ - Price: o.Price, - Quantity: o.Quantity, - PriceDenom: o.PriceDenom, - AssetDenom: o.AssetDenom, - Allocations: []*dextypes.Allocation{newAllocation}, - } - } - } -} - -func matchOrders( - longBook map[string]*dextypes.OrderEntry, - shortBook map[string]*dextypes.OrderEntry, -) { - buyPrices := sortedPrices(longBook, true) - sellPrices := sortedPrices(shortBook, false) - for i, j := 0, 0; i < len(buyPrices) && j < len(sellPrices) && buyPrices[i].GTE(sellPrices[j]); { - buyEntry := longBook[buyPrices[i].String()] - sellEntry := shortBook[sellPrices[j].String()] - if buyEntry.Quantity.GT(sellEntry.Quantity) { - takeLiquidity(longBook, buyPrices[i], sellEntry.Quantity) - takeLiquidity(shortBook, sellPrices[i], sellEntry.Quantity) - j++ - } else { - takeLiquidity(longBook, buyPrices[i], buyEntry.Quantity) - takeLiquidity(shortBook, sellPrices[i], buyEntry.Quantity) - i++ - } - } -} - -func toOrderBookMap(book []dextypes.OrderBookEntry) map[string]*dextypes.OrderEntry { - bookMap := map[string]*dextypes.OrderEntry{} - for _, e := range book { - bookMap[e.GetPrice().String()] = e.GetOrderEntry() - } - return bookMap -} - -func getMarketOrderBookMap(orderPlacements []*dextypes.Order, direction dextypes.PositionDirection) map[string]*dextypes.OrderEntry { - bookMap := map[string]*dextypes.OrderEntry{} - for _, o := range orderPlacements { - if o.OrderType != dextypes.OrderType_MARKET || o.PositionDirection != direction { - continue - } - bookMap[o.Price.String()] = orderToOrderEntry(o) - } - return bookMap -} - -func updateEntryQuantity(entry *dextypes.OrderEntry) { - entry.Quantity = utils.Reduce( - entry.Allocations, - func(a *dextypes.Allocation, q sdk.Dec) sdk.Dec { return q.Add(a.Quantity) }, - sdk.ZeroDec(), - ) -} - -func takeLiquidity(book map[string]*dextypes.OrderEntry, price sdk.Dec, quantity sdk.Dec) { - entry := book[price.String()] - if entry.Quantity.Equal(quantity) { - delete(book, price.String()) - return - } - if quantity.GT(entry.Quantity) { - panic("insufficient liquidity") - } - allocated := sdk.ZeroDec() - newAllocations := []*dextypes.Allocation{} - for _, a := range entry.Allocations { - switch { - case allocated.Equal(quantity): - newAllocations = append(newAllocations, a) - case allocated.Add(a.Quantity).GT(quantity): - a.Quantity = a.Quantity.Sub(quantity.Sub(allocated)) - newAllocations = append(newAllocations, a) - allocated = quantity - default: - allocated = allocated.Add(a.Quantity) - } - } - entry.Allocations = newAllocations - entry.Quantity = entry.Quantity.Sub(quantity) -} - -func sortedPrices(book map[string]*dextypes.OrderEntry, descending bool) []sdk.Dec { - prices := []sdk.Dec{} - for p := range book { - prices = append(prices, sdk.MustNewDecFromStr(p)) - } - if descending { - sort.Slice(prices, func(i, j int) bool { return prices[i].GT(prices[j]) }) - } else { - sort.Slice(prices, func(i, j int) bool { return prices[i].LT(prices[j]) }) - } - return prices -} - -func orderToOrderEntry(order *dextypes.Order) *dextypes.OrderEntry { - return &dextypes.OrderEntry{ - Price: order.Price, - Quantity: order.Quantity, - Allocations: []*dextypes.Allocation{{Quantity: order.Quantity}}, - } -} diff --git a/wasmbinding/bindings/msg.go b/wasmbinding/bindings/msg.go index 7e633640db..cb9fdff46f 100644 --- a/wasmbinding/bindings/msg.go +++ b/wasmbinding/bindings/msg.go @@ -3,7 +3,6 @@ package bindings import ( sdk "github.com/cosmos/cosmos-sdk/types" banktypes "github.com/cosmos/cosmos-sdk/x/bank/types" - "github.com/sei-protocol/sei-chain/x/dex/types" ) // / CreateDenom creates a new factory denom, of denomination: @@ -35,18 +34,6 @@ type BurnTokens struct { Amount sdk.Coin `json:"amount"` } -// Dex Module msgs -type PlaceOrders struct { - Orders []*types.Order `json:"orders"` - Funds sdk.Coins `json:"funds"` - ContractAddr string `json:"contract_address"` -} - -type CancelOrders struct { - Cancellations []*types.Cancellation `json:"cancellations"` - ContractAddr string `json:"contract_address"` -} - type CallEVM struct { Value *sdk.Int `json:"value"` To string `json:"to"` diff --git a/wasmbinding/encoder.go b/wasmbinding/encoder.go index 1e691b8d61..087e002796 100644 --- a/wasmbinding/encoder.go +++ b/wasmbinding/encoder.go @@ -7,14 +7,11 @@ import ( wasmvmtypes "github.com/CosmWasm/wasmvm/types" sdk "github.com/cosmos/cosmos-sdk/types" sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - dexwasm "github.com/sei-protocol/sei-chain/x/dex/client/wasm" evmwasm "github.com/sei-protocol/sei-chain/x/evm/client/wasm" tokenfactorywasm "github.com/sei-protocol/sei-chain/x/tokenfactory/client/wasm" ) type SeiWasmMessage struct { - PlaceOrders json.RawMessage `json:"place_orders,omitempty"` - CancelOrders json.RawMessage `json:"cancel_orders,omitempty"` CreateDenom json.RawMessage `json:"create_denom,omitempty"` MintTokens json.RawMessage `json:"mint_tokens,omitempty"` BurnTokens json.RawMessage `json:"burn_tokens,omitempty"` @@ -30,10 +27,6 @@ func CustomEncoder(sender sdk.AccAddress, msg json.RawMessage, info wasmvmtypes. return []sdk.Msg{}, sdkerrors.Wrap(err, "Error parsing Sei Wasm Message") } switch { - case parsedMessage.PlaceOrders != nil: - return dexwasm.EncodeDexPlaceOrders(parsedMessage.PlaceOrders, sender) - case parsedMessage.CancelOrders != nil: - return dexwasm.EncodeDexCancelOrders(parsedMessage.CancelOrders, sender) case parsedMessage.CreateDenom != nil: return tokenfactorywasm.EncodeTokenFactoryCreateDenom(parsedMessage.CreateDenom, sender) case parsedMessage.MintTokens != nil: diff --git a/wasmbinding/queries.go b/wasmbinding/queries.go index 122bb712b9..de60fed501 100644 --- a/wasmbinding/queries.go +++ b/wasmbinding/queries.go @@ -7,9 +7,6 @@ import ( sdk "github.com/cosmos/cosmos-sdk/types" "github.com/sei-protocol/sei-chain/utils/metrics" - dexwasm "github.com/sei-protocol/sei-chain/x/dex/client/wasm" - dexbindings "github.com/sei-protocol/sei-chain/x/dex/client/wasm/bindings" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" epochwasm "github.com/sei-protocol/sei-chain/x/epoch/client/wasm" epochbindings "github.com/sei-protocol/sei-chain/x/epoch/client/wasm/bindings" epochtypes "github.com/sei-protocol/sei-chain/x/epoch/types" @@ -25,17 +22,15 @@ import ( type QueryPlugin struct { oracleHandler oraclewasm.OracleWasmQueryHandler - dexHandler dexwasm.DexWasmQueryHandler epochHandler epochwasm.EpochWasmQueryHandler tokenfactoryHandler tokenfactorywasm.TokenFactoryWasmQueryHandler evmHandler evmwasm.EVMQueryHandler } // NewQueryPlugin returns a reference to a new QueryPlugin. -func NewQueryPlugin(oh *oraclewasm.OracleWasmQueryHandler, dh *dexwasm.DexWasmQueryHandler, eh *epochwasm.EpochWasmQueryHandler, th *tokenfactorywasm.TokenFactoryWasmQueryHandler, evmh *evmwasm.EVMQueryHandler) *QueryPlugin { +func NewQueryPlugin(oh *oraclewasm.OracleWasmQueryHandler, eh *epochwasm.EpochWasmQueryHandler, th *tokenfactorywasm.TokenFactoryWasmQueryHandler, evmh *evmwasm.EVMQueryHandler) *QueryPlugin { return &QueryPlugin{ oracleHandler: *oh, - dexHandler: *dh, epochHandler: *eh, tokenfactoryHandler: *th, evmHandler: *evmh, @@ -75,72 +70,6 @@ func (qp QueryPlugin) HandleOracleQuery(ctx sdk.Context, queryData json.RawMessa } } -func (qp QueryPlugin) HandleDexQuery(ctx sdk.Context, queryData json.RawMessage) ([]byte, error) { - var parsedQuery dexbindings.SeiDexQuery - if err := json.Unmarshal(queryData, &parsedQuery); err != nil { - return nil, dextypes.ErrParsingSeiDexQuery - } - switch { - case parsedQuery.DexTwaps != nil: - res, err := qp.dexHandler.GetDexTwap(ctx, parsedQuery.DexTwaps) - if err != nil { - return nil, err - } - bz, err := json.Marshal(res) - if err != nil { - return nil, dextypes.ErrEncodingDexTwaps - } - - return bz, nil - case parsedQuery.GetOrders != nil: - res, err := qp.dexHandler.GetOrders(ctx, parsedQuery.GetOrders) - if err != nil { - return nil, err - } - bz, err := json.Marshal(res) - if err != nil { - return nil, dextypes.ErrEncodingOrders - } - - return bz, nil - case parsedQuery.GetOrderByID != nil: - res, err := qp.dexHandler.GetOrderByID(ctx, parsedQuery.GetOrderByID) - if err != nil { - return nil, err - } - bz, err := json.Marshal(res) - if err != nil { - return nil, dextypes.ErrEncodingOrder - } - - return bz, nil - case parsedQuery.GetOrderSimulation != nil: - res, err := qp.dexHandler.GetOrderSimulation(ctx, parsedQuery.GetOrderSimulation) - if err != nil { - return nil, err - } - bz, err := json.Marshal(res) - if err != nil { - return nil, dextypes.ErrEncodingOrderSimulation - } - - return bz, nil - case parsedQuery.GetLatestPrice != nil: - res, err := qp.dexHandler.GetLatestPrice(ctx, parsedQuery.GetLatestPrice) - if err != nil { - return nil, err - } - bz, err := json.Marshal(res) - if err != nil { - return nil, dextypes.ErrEncodingLatestPrice - } - - return bz, nil - default: - return nil, dextypes.ErrUnknownSeiDexQuery - } -} - func (qp QueryPlugin) HandleEpochQuery(ctx sdk.Context, queryData json.RawMessage) ([]byte, error) { var parsedQuery epochbindings.SeiEpochQuery if err := json.Unmarshal(queryData, &parsedQuery); err != nil { diff --git a/wasmbinding/query_plugin.go b/wasmbinding/query_plugin.go index db21e94040..aa24663be5 100644 --- a/wasmbinding/query_plugin.go +++ b/wasmbinding/query_plugin.go @@ -10,7 +10,6 @@ import ( const ( OracleRoute = "oracle" - DexRoute = "dex" EpochRoute = "epoch" TokenFactoryRoute = "tokenfactory" EVMRoute = "evm" @@ -32,8 +31,6 @@ func CustomQuerier(qp *QueryPlugin) func(ctx sdk.Context, request json.RawMessag switch contractQuery.Route { case OracleRoute: return qp.HandleOracleQuery(ctx, contractQuery.QueryData) - case DexRoute: - return qp.HandleDexQuery(ctx, contractQuery.QueryData) case EpochRoute: return qp.HandleEpochQuery(ctx, contractQuery.QueryData) case TokenFactoryRoute: diff --git a/wasmbinding/test/encoder_test.go b/wasmbinding/test/encoder_test.go index 439c3a707b..0e55393cbc 100644 --- a/wasmbinding/test/encoder_test.go +++ b/wasmbinding/test/encoder_test.go @@ -6,9 +6,6 @@ import ( sdk "github.com/cosmos/cosmos-sdk/types" "github.com/sei-protocol/sei-chain/wasmbinding/bindings" - dexwasm "github.com/sei-protocol/sei-chain/x/dex/client/wasm" - "github.com/sei-protocol/sei-chain/x/dex/types" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" tokenfactorywasm "github.com/sei-protocol/sei-chain/x/tokenfactory/client/wasm" tokenfactorytypes "github.com/sei-protocol/sei-chain/x/tokenfactory/types" "github.com/stretchr/testify/require" @@ -19,71 +16,6 @@ const ( TEST_CREATOR = "sei1y3pxq5dp900czh0mkudhjdqjq5m8cpmmps8yjw" ) -func TestEncodePlaceOrder(t *testing.T) { - contractAddr, err := sdk.AccAddressFromBech32("sei1y3pxq5dp900czh0mkudhjdqjq5m8cpmmps8yjw") - require.NoError(t, err) - order := dextypes.Order{ - PositionDirection: dextypes.PositionDirection_LONG, - OrderType: dextypes.OrderType_LIMIT, - PriceDenom: "USDC", - AssetDenom: "SEI", - Price: sdk.MustNewDecFromStr("10"), - Quantity: sdk.OneDec(), - Data: "{\"position_effect\":\"OPEN\", \"leverage\":\"1\"}", - Nominal: sdk.ZeroDec(), - TriggerPrice: sdk.ZeroDec(), - TriggerStatus: false, - } - fund := sdk.NewCoin("usei", sdk.NewInt(1000000000)) - msg := bindings.PlaceOrders{ - Orders: []*dextypes.Order{&order}, - Funds: []sdk.Coin{fund}, - ContractAddr: TEST_TARGET_CONTRACT, - } - serializedMsg, _ := json.Marshal(msg) - - decodedMsgs, err := dexwasm.EncodeDexPlaceOrders(serializedMsg, contractAddr) - require.NoError(t, err) - require.Equal(t, 1, len(decodedMsgs)) - typedDecodedMsg, ok := decodedMsgs[0].(*dextypes.MsgPlaceOrders) - require.True(t, ok) - expectedMsg := dextypes.MsgPlaceOrders{ - Creator: TEST_CREATOR, - Orders: []*dextypes.Order{&order}, - ContractAddr: TEST_TARGET_CONTRACT, - Funds: []sdk.Coin{fund}, - } - require.Equal(t, expectedMsg, *typedDecodedMsg) -} - -func TestDecodeOrderCancellation(t *testing.T) { - contractAddr, err := sdk.AccAddressFromBech32("sei1y3pxq5dp900czh0mkudhjdqjq5m8cpmmps8yjw") - require.NoError(t, err) - msg := bindings.CancelOrders{ - Cancellations: []*types.Cancellation{ - {Id: 1}, - }, - ContractAddr: TEST_TARGET_CONTRACT, - } - serializedMsg, _ := json.Marshal(msg) - - decodedMsgs, err := dexwasm.EncodeDexCancelOrders(serializedMsg, contractAddr) - require.NoError(t, err) - require.Equal(t, 1, len(decodedMsgs)) - typedDecodedMsg, ok := decodedMsgs[0].(*dextypes.MsgCancelOrders) - require.True(t, ok) - expectedMsg := dextypes.MsgCancelOrders{ - Creator: TEST_CREATOR, - Cancellations: []*types.Cancellation{ - {Id: 1, Price: sdk.ZeroDec()}, - }, - ContractAddr: TEST_TARGET_CONTRACT, - } - require.Equal(t, expectedMsg.Creator, typedDecodedMsg.Creator) - require.Equal(t, *expectedMsg.Cancellations[0], *typedDecodedMsg.Cancellations[0]) - require.Equal(t, expectedMsg.ContractAddr, typedDecodedMsg.ContractAddr) -} - func TestEncodeCreateDenom(t *testing.T) { contractAddr, err := sdk.AccAddressFromBech32("sei1y3pxq5dp900czh0mkudhjdqjq5m8cpmmps8yjw") require.NoError(t, err) diff --git a/wasmbinding/test/query_test.go b/wasmbinding/test/query_test.go index c4dd219bba..d02a72f1c3 100644 --- a/wasmbinding/test/query_test.go +++ b/wasmbinding/test/query_test.go @@ -1,7 +1,6 @@ package wasmbinding import ( - "context" "encoding/json" "fmt" "testing" @@ -12,13 +11,7 @@ import ( "github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1" sdk "github.com/cosmos/cosmos-sdk/types" "github.com/sei-protocol/sei-chain/app" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" "github.com/sei-protocol/sei-chain/wasmbinding" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - dexwasm "github.com/sei-protocol/sei-chain/x/dex/client/wasm" - dexbinding "github.com/sei-protocol/sei-chain/x/dex/client/wasm/bindings" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" epochwasm "github.com/sei-protocol/sei-chain/x/epoch/client/wasm" epochbinding "github.com/sei-protocol/sei-chain/x/epoch/client/wasm/bindings" epochtypes "github.com/sei-protocol/sei-chain/x/epoch/types" @@ -40,11 +33,10 @@ func SetupWasmbindingTest(t *testing.T) (*app.TestWrapper, func(ctx sdk.Context, testWrapper := app.NewTestWrapper(t, tm, valPub, false) oh := oraclewasm.NewOracleWasmQueryHandler(&testWrapper.App.OracleKeeper) - dh := dexwasm.NewDexWasmQueryHandler(&testWrapper.App.DexKeeper) eh := epochwasm.NewEpochWasmQueryHandler(&testWrapper.App.EpochKeeper) th := tokenfactorywasm.NewTokenFactoryWasmQueryHandler(&testWrapper.App.TokenFactoryKeeper) evmh := evmwasm.NewEVMQueryHandler(&testWrapper.App.EvmKeeper) - qp := wasmbinding.NewQueryPlugin(oh, dh, eh, th, evmh) + qp := wasmbinding.NewQueryPlugin(oh, eh, th, evmh) return testWrapper, wasmbinding.CustomQuerier(qp) } @@ -62,17 +54,6 @@ func TestWasmUnknownQuery(t *testing.T) { require.Error(t, err) require.Equal(t, err, oracletypes.ErrUnknownSeiOracleQuery) - dex_req := dexbinding.SeiDexQuery{} - queryData, err = json.Marshal(dex_req) - require.NoError(t, err) - query = wasmbinding.SeiQueryWrapper{Route: wasmbinding.DexRoute, QueryData: queryData} - rawQuery, err = json.Marshal(query) - require.NoError(t, err) - - _, err = customQuerier(testWrapper.Ctx, rawQuery) - require.Error(t, err) - require.Equal(t, err, dextypes.ErrUnknownSeiDexQuery) - epoch_req := epochbinding.SeiEpochQuery{} queryData, err = json.Marshal(epoch_req) require.NoError(t, err) @@ -180,116 +161,6 @@ func TestWasmGetOracleTwapsErrorHandling(t *testing.T) { require.Equal(t, err, oracletypes.ErrInvalidTwapLookback) } -func TestWasmGetDexTwaps(t *testing.T) { - testWrapper, customQuerier := SetupWasmbindingTest(t) - - req := dexbinding.SeiDexQuery{DexTwaps: &dextypes.QueryGetTwapsRequest{ - ContractAddr: app.TestContract, - LookbackSeconds: 200, - }} - queryData, err := json.Marshal(req) - require.NoError(t, err) - query := wasmbinding.SeiQueryWrapper{Route: wasmbinding.DexRoute, QueryData: queryData} - - rawQuery, err := json.Marshal(query) - require.NoError(t, err) - - testWrapper.Ctx = testWrapper.Ctx.WithBlockHeight(11).WithBlockTime(time.Unix(3600, 0)) - testWrapper.App.DexKeeper.AddRegisteredPair( - testWrapper.Ctx, - app.TestContract, - dextypes.Pair{PriceDenom: "sei", AssetDenom: "atom"}, - ) - testWrapper.App.DexKeeper.SetPriceState(testWrapper.Ctx, dextypes.Price{ - SnapshotTimestampInSeconds: 3600, - Price: sdk.NewDec(20), - Pair: &dextypes.Pair{PriceDenom: "sei", AssetDenom: "atom"}, - }, app.TestContract) - testWrapper.App.OracleKeeper.SetBaseExchangeRate(testWrapper.Ctx, oracleutils.MicroAtomDenom, sdk.NewDec(12)) - testWrapper.Ctx = testWrapper.Ctx.WithBlockHeight(14).WithBlockTime(time.Unix(3700, 0)) - - res, err := customQuerier(testWrapper.Ctx, rawQuery) - require.NoError(t, err) - - var parsedRes dextypes.QueryGetTwapsResponse - err = json.Unmarshal(res, &parsedRes) - require.NoError(t, err) - require.Equal(t, 1, len(parsedRes.Twaps)) - twap := *parsedRes.Twaps[0] - require.Equal(t, "sei", twap.Pair.PriceDenom) - require.Equal(t, "atom", twap.Pair.AssetDenom) - require.Equal(t, sdk.NewDec(20), twap.Twap) -} - -func TestWasmDexGetOrderByIdErrorHandling(t *testing.T) { - testWrapper, customQuerier := SetupWasmbindingTest(t) - - req := dexbinding.SeiDexQuery{GetOrderByID: &dextypes.QueryGetOrderByIDRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - Id: 1, - }} - queryData, err := json.Marshal(req) - require.NoError(t, err) - query := wasmbinding.SeiQueryWrapper{Route: wasmbinding.DexRoute, QueryData: queryData} - - rawQuery, err := json.Marshal(query) - require.NoError(t, err) - - _, err = customQuerier(testWrapper.Ctx, rawQuery) - require.Error(t, err) - require.IsType(t, dextypes.ErrInvalidOrderID, err) -} - -func TestWasmGetOrderSimulation(t *testing.T) { - testWrapper, customQuerier := SetupWasmbindingTest(t) - - order := dextypes.Order{ - PositionDirection: dextypes.PositionDirection_LONG, - OrderType: dextypes.OrderType_LIMIT, - PriceDenom: "USDC", - AssetDenom: "SEI", - Price: sdk.MustNewDecFromStr("10"), - Quantity: sdk.OneDec(), - Data: "{\"position_effect\":\"OPEN\", \"leverage\":\"1\"}", - } - - req := dexbinding.SeiDexQuery{GetOrderSimulation: &dextypes.QueryOrderSimulationRequest{ - Order: &order, - }} - queryData, err := json.Marshal(req) - require.NoError(t, err) - query := wasmbinding.SeiQueryWrapper{Route: wasmbinding.DexRoute, QueryData: queryData} - - rawQuery, err := json.Marshal(query) - require.NoError(t, err) - - testWrapper.Ctx = testWrapper.Ctx.WithBlockHeight(11).WithBlockTime(time.Unix(3600, 0)) - testWrapper.Ctx = testWrapper.Ctx.WithContext(context.WithValue(testWrapper.Ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testWrapper.App.GetMemKey(dextypes.MemStoreKey)))) - testWrapper.App.DexKeeper.AddRegisteredPair( - testWrapper.Ctx, - app.TestContract, - dextypes.Pair{PriceDenom: "sei", AssetDenom: "atom"}, - ) - testWrapper.App.DexKeeper.SetPriceState(testWrapper.Ctx, dextypes.Price{ - SnapshotTimestampInSeconds: 3600, - Price: sdk.NewDec(20), - Pair: &dextypes.Pair{PriceDenom: "sei", AssetDenom: "atom"}, - }, app.TestContract) - testWrapper.App.OracleKeeper.SetBaseExchangeRate(testWrapper.Ctx, oracleutils.MicroAtomDenom, sdk.NewDec(12)) - testWrapper.Ctx = testWrapper.Ctx.WithBlockHeight(14).WithBlockTime(time.Unix(3700, 0)) - testWrapper.Ctx = testWrapper.Ctx.WithContext(context.WithValue(testWrapper.Ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testWrapper.App.GetMemKey(dextypes.MemStoreKey)))) - - res, err := customQuerier(testWrapper.Ctx, rawQuery) - require.NoError(t, err) - - var parsedRes dextypes.QueryOrderSimulationResponse - err = json.Unmarshal(res, &parsedRes) - require.NoError(t, err) - require.Equal(t, sdk.NewDec(0), *parsedRes.ExecutedQuantity) -} - func TestWasmGetEpoch(t *testing.T) { testWrapper, customQuerier := SetupWasmbindingTest(t) diff --git a/wasmbinding/wasm.go b/wasmbinding/wasm.go index 0d50fb0cb6..bc2d492f26 100644 --- a/wasmbinding/wasm.go +++ b/wasmbinding/wasm.go @@ -7,8 +7,6 @@ import ( codectypes "github.com/cosmos/cosmos-sdk/codec/types" aclkeeper "github.com/cosmos/cosmos-sdk/x/accesscontrol/keeper" authkeeper "github.com/cosmos/cosmos-sdk/x/auth/keeper" - dexwasm "github.com/sei-protocol/sei-chain/x/dex/client/wasm" - dexkeeper "github.com/sei-protocol/sei-chain/x/dex/keeper" epochwasm "github.com/sei-protocol/sei-chain/x/epoch/client/wasm" epochkeeper "github.com/sei-protocol/sei-chain/x/epoch/keeper" evmwasm "github.com/sei-protocol/sei-chain/x/evm/client/wasm" @@ -21,7 +19,6 @@ import ( func RegisterCustomPlugins( oracle *oraclekeeper.Keeper, - dex *dexkeeper.Keeper, epoch *epochkeeper.Keeper, tokenfactory *tokenfactorykeeper.Keeper, _ *authkeeper.AccountKeeper, @@ -34,12 +31,11 @@ func RegisterCustomPlugins( aclKeeper aclkeeper.Keeper, evmKeeper *evmkeeper.Keeper, ) []wasmkeeper.Option { - dexHandler := dexwasm.NewDexWasmQueryHandler(dex) oracleHandler := oraclewasm.NewOracleWasmQueryHandler(oracle) epochHandler := epochwasm.NewEpochWasmQueryHandler(epoch) tokenfactoryHandler := tokenfactorywasm.NewTokenFactoryWasmQueryHandler(tokenfactory) evmHandler := evmwasm.NewEVMQueryHandler(evmKeeper) - wasmQueryPlugin := NewQueryPlugin(oracleHandler, dexHandler, epochHandler, tokenfactoryHandler, evmHandler) + wasmQueryPlugin := NewQueryPlugin(oracleHandler, epochHandler, tokenfactoryHandler, evmHandler) queryPluginOpt := wasmkeeper.WithQueryPlugins(&wasmkeeper.QueryPlugins{ Custom: CustomQuerier(wasmQueryPlugin), diff --git a/x/dex/README.md b/x/dex/README.md deleted file mode 100644 index fd623e859d..0000000000 --- a/x/dex/README.md +++ /dev/null @@ -1,57 +0,0 @@ -## Abstract - -Provides fast order matching for CosmWasm contracts. - -## Contents -`dex` provides order placement/cancellation/settlement capabilities for registered contracts, as well as exchange price resulting from the order matching. The implementation of the exchange logic and store writes happen at the end of each block, based on in-memory data passed on by `dex` transactions in the same block. In other words, `DeliverTx` only adds data to memory (a custom data structure, not Cosmos's cache store), and -`EndBlock` uses those in-memory data to perform batched order matching. The `EndBlock` order matching process also involves calling `Sudo` endpoints defined on the registerd contracts, as long as those endpoints conform with the expected interface, so that the registered contracts can perform custom logic based on the exchange information. - -## Concepts -Contract Registration -A contract can be registered with `MsgRegisterContract` type. There are a few related concepts: -### Order-related Sudo Calls -For `dex` to perform order matching for a registered contract, it MUST define 3 `Sudo` endpoints: -- "bulk_order_placements": payload expected can be found in [x/dex/types/order_placement.go] -- "bulk_order_cancellations": payload expected can be found in [x/dex/types/order_cancellation.go] -- "settlement": payload expected can be found in [x/dex/types/settlement.go] -If any of the three endpoints is missing, or if the endpoint is ill-defined, `dex` will skip the contract's order matching. -### Asset Pair Registration -A contract may define one or more tradable pairs with `dex`. For example, a spot trading contract may define a pair with price denomination `USDC` and asset denomination `BTC`. The exact semantics for asset pair registration can be found in the `Governance` section below. A contract with no registered pair is valid - it simply won't have any trading activity in `dex`. -### Rent -A contract must deposit a certain amount of `usei` into `dex` upon registration or through subsequent top-ups. Those `usei`, also known as rent, will be consumed when the contract's `Sudo` endpoints are called based on the gas meter reading, and distributed to Sei validators. Note that if a `Sudo` endpoint fails, it would still charge rent for whatever the gas meter has already recorded before the failure happens. -### Contract Dependencies -A contract may dispatch messages to other contracts as part of its `Sudo` call responses. If that is the case, the contract must declare those other contracts as `Dependencies` in its registration. No circular dependency is allowed. `dex` will check if a dispatched message is against a declared dependency contract, and reject it if it's not declared. -## Batch Order Matching -Orders submitted via MsgPlaceOrders are aggregated at the end of a block and matched in batch. -### Sequence -TODO -### Clearing/Settlement Rules -TODO -## State - -## Governance - -Token pairs can be whitelisted with a contract address to the `dex` module via governance. The following is an example -proposal json to whitelist a token pair. - -```json - "dex": { - "params": { - "code_upload_access": { - "permission": "Everybody" - }, - "instantiate_default_permission": "Everybody" - } - }, -``` - -## Messages - -## Events - -## Parameters - -## Transactions - -## Queries - diff --git a/x/dex/ante.go b/x/dex/ante.go deleted file mode 100644 index 07e891f428..0000000000 --- a/x/dex/ante.go +++ /dev/null @@ -1,178 +0,0 @@ -package dex - -import ( - "errors" - "math/big" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkacltypes "github.com/cosmos/cosmos-sdk/types/accesscontrol" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/sei-protocol/sei-chain/x/dex/utils" -) - -// TickSizeMultipleDecorator check if the place order tx's price is multiple of -// tick size -type TickSizeMultipleDecorator struct { - dexKeeper keeper.Keeper -} - -// NewTickSizeMultipleDecorator returns new ticksize multiple check decorator instance -func NewTickSizeMultipleDecorator(dexKeeper keeper.Keeper) TickSizeMultipleDecorator { - return TickSizeMultipleDecorator{ - dexKeeper: dexKeeper, - } -} - -// AnteHandle is the interface called in RunTx() function, which CheckTx() calls with the runTxModeCheck mode -func (tsmd TickSizeMultipleDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (newCtx sdk.Context, err error) { - if ctx.IsReCheckTx() { - return next(ctx, tx, simulate) - } - if !simulate { - if ctx.IsCheckTx() { - err := tsmd.CheckTickSizeMultiple(ctx, tx.GetMsgs()) - if err != nil { - return ctx, err - } - } - } - return next(ctx, tx, simulate) -} - -// CheckTickSizeMultiple checks whether the msgs comply with ticksize -func (tsmd TickSizeMultipleDecorator) CheckTickSizeMultiple(ctx sdk.Context, msgs []sdk.Msg) error { - for _, msg := range msgs { - switch msg.(type) { //nolint:gocritic,gosimple // the linter is telling us we can make this faster, and this should be addressed later. - case *types.MsgPlaceOrders: - msgPlaceOrders := msg.(*types.MsgPlaceOrders) //nolint:gosimple // the linter is telling us we can make this faster, and this should be addressed later. - contractAddr := msgPlaceOrders.ContractAddr - for _, order := range msgPlaceOrders.Orders { - priceTickSize, found := tsmd.dexKeeper.GetPriceTickSizeForPair(ctx, contractAddr, - types.Pair{ - PriceDenom: order.PriceDenom, - AssetDenom: order.AssetDenom, - }) - if !found { - return sdkerrors.Wrapf(sdkerrors.ErrKeyNotFound, "the pair {price:%s,asset:%s} has no price ticksize configured", order.PriceDenom, order.AssetDenom) - } - if !IsDecimalMultipleOf(order.Price, priceTickSize) { - // Allow Market Orders with Price 0 - if !(IsMarketOrder(order) && order.Price.IsZero()) { - return sdkerrors.Wrapf(errors.New("ErrPriceNotMultipleOfTickSize"), "price needs to be non-zero and multiple of price tick size") - } - } - quantityTickSize, found := tsmd.dexKeeper.GetQuantityTickSizeForPair(ctx, contractAddr, - types.Pair{ - PriceDenom: order.PriceDenom, - AssetDenom: order.AssetDenom, - }) - if !found { - return sdkerrors.Wrapf(sdkerrors.ErrKeyNotFound, "the pair {price:%s,asset:%s} has no quantity ticksize configured", order.PriceDenom, order.AssetDenom) - } - if !IsDecimalMultipleOf(order.Quantity, quantityTickSize) { - return sdkerrors.Wrapf(errors.New("ErrQuantityNotMultipleOfTickSize"), "quantity needs to be non-zero and multiple of quantity tick size") - } - } - continue - default: - // e.g. liquidation order don't come with price so always pass this check - return nil - } - } - - return nil -} - -// Check whether order is market order type -func IsMarketOrder(order *types.Order) bool { - return order.OrderType == types.OrderType_MARKET || order.OrderType == types.OrderType_FOKMARKET || order.OrderType == types.OrderType_FOKMARKETBYVALUE -} - -// Check whether decimal a is multiple of decimal b -func IsDecimalMultipleOf(a, b sdk.Dec) bool { - if a.LT(b) { - return false - } - quotient := sdk.NewDecFromBigInt(a.Quo(b).RoundInt().BigInt()) - return quotient.Mul(b).Equal(a) -} - -const DexGasFeeUnit = "usei" - -type CheckDexGasDecorator struct { - dexKeeper keeper.Keeper - checkTxMemState *dexcache.MemState -} - -func NewCheckDexGasDecorator(dexKeeper keeper.Keeper, checkTxMemState *dexcache.MemState) CheckDexGasDecorator { - return CheckDexGasDecorator{ - dexKeeper: dexKeeper, - checkTxMemState: checkTxMemState, - } -} - -// for a TX that contains dex gas-incurring messages, check if it provides enough gas based on dex params -func (d CheckDexGasDecorator) AnteHandle(ctx sdk.Context, tx sdk.Tx, simulate bool, next sdk.AnteHandler) (newCtx sdk.Context, err error) { - if ctx.IsReCheckTx() { - return next(ctx, tx, simulate) - } - params := d.dexKeeper.GetParams(ctx) - dexGasRequired := uint64(0) - var memState *dexcache.MemState - if ctx.IsCheckTx() { - memState = d.checkTxMemState - } else { - memState = utils.GetMemState(ctx.Context()) - } - for _, msg := range tx.GetMsgs() { - switch m := msg.(type) { - case *types.MsgPlaceOrders: - numDependencies := len(memState.GetContractToDependencies(ctx, m.ContractAddr, d.dexKeeper.GetContractWithoutGasCharge)) - dexGasRequired += params.DefaultGasPerOrder * uint64(len(m.Orders)*numDependencies) - for _, order := range m.Orders { - dexGasRequired += params.DefaultGasPerOrderDataByte * uint64(len(order.Data)) - } - case *types.MsgCancelOrders: - numDependencies := len(memState.GetContractToDependencies(ctx, m.ContractAddr, d.dexKeeper.GetContractWithoutGasCharge)) - dexGasRequired += params.DefaultGasPerCancel * uint64(len(m.Cancellations)*numDependencies) - } - } - if dexGasRequired == 0 { - return next(ctx, tx, simulate) - } - dexFeeRequired := sdk.NewDecFromBigInt(new(big.Int).SetUint64(dexGasRequired)).Mul(params.SudoCallGasPrice).RoundInt() - feeTx, ok := tx.(sdk.FeeTx) - if !ok { - return ctx, sdkerrors.Wrap(sdkerrors.ErrTxDecode, "Tx must be a FeeTx") - } - for _, fee := range feeTx.GetFee() { - if fee.Denom == DexGasFeeUnit && fee.Amount.GTE(dexFeeRequired) { - return next(ctx, tx, simulate) - } - } - return ctx, sdkerrors.ErrInsufficientFee -} - -func (d CheckDexGasDecorator) AnteDeps(txDeps []sdkacltypes.AccessOperation, tx sdk.Tx, txIndex int, next sdk.AnteDepGenerator) (newTxDeps []sdkacltypes.AccessOperation, err error) { - deps := []sdkacltypes.AccessOperation{} - for _, msg := range tx.GetMsgs() { - // Error checking will be handled in AnteHandler - switch msg.(type) { - case *types.MsgPlaceOrders, *types.MsgCancelOrders: - deps = append(deps, []sdkacltypes.AccessOperation{ - // read the dex contract info - { - ResourceType: sdkacltypes.ResourceType_KV_DEX_CONTRACT, - AccessType: sdkacltypes.AccessType_READ, - IdentifierTemplate: "*", - }, - }...) - default: - continue - } - } - return next(append(txDeps, deps...), tx, txIndex) -} diff --git a/x/dex/ante_test.go b/x/dex/ante_test.go deleted file mode 100644 index 4d9ab4205c..0000000000 --- a/x/dex/ante_test.go +++ /dev/null @@ -1,283 +0,0 @@ -package dex_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/assert" - "github.com/stretchr/testify/require" -) - -type TestTx struct { - msgs []sdk.Msg - gas uint64 - fee sdk.Coins -} - -func (tx TestTx) GetMsgs() []sdk.Msg { - return tx.msgs -} - -func (tx TestTx) ValidateBasic() error { - return nil -} - -func (tx TestTx) GetGas() uint64 { - return tx.gas -} -func (tx TestTx) GetFee() sdk.Coins { - return tx.fee -} -func (tx TestTx) FeePayer() sdk.AccAddress { - return nil -} -func (tx TestTx) FeeGranter() sdk.AccAddress { - return nil -} - -func TestIsDecimalMultipleOf(t *testing.T) { - v1, _ := sdk.NewDecFromStr("2.4") - v2, _ := sdk.NewDecFromStr("1.2") - v3, _ := sdk.NewDecFromStr("2") - v4, _ := sdk.NewDecFromStr("100.5") - v5, _ := sdk.NewDecFromStr("0.5") - v6, _ := sdk.NewDecFromStr("1.5") - v7, _ := sdk.NewDecFromStr("1.01") - v8, _ := sdk.NewDecFromStr("3") - v9, _ := sdk.NewDecFromStr("5.4") - v10, _ := sdk.NewDecFromStr("0.3") - - assert.True(t, dex.IsDecimalMultipleOf(v1, v2)) - assert.True(t, !dex.IsDecimalMultipleOf(v2, v1)) - assert.True(t, !dex.IsDecimalMultipleOf(v3, v2)) - assert.True(t, dex.IsDecimalMultipleOf(v3, v5)) - assert.True(t, !dex.IsDecimalMultipleOf(v3, v6)) - assert.True(t, dex.IsDecimalMultipleOf(v4, v5)) - assert.True(t, !dex.IsDecimalMultipleOf(v2, v1)) - assert.True(t, dex.IsDecimalMultipleOf(v6, v5)) - assert.True(t, !dex.IsDecimalMultipleOf(v7, v3)) - assert.True(t, dex.IsDecimalMultipleOf(v8, v6)) - assert.True(t, dex.IsDecimalMultipleOf(v9, v10)) -} - -func TestCheckDexGasDecorator(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - decorator := dex.NewCheckDexGasDecorator(*keeper, dexcache.NewMemState(keeper.GetMemStoreKey())) - terminator := func(ctx sdk.Context, tx sdk.Tx, simulate bool) (newCtx sdk.Context, err error) { return ctx, nil } - tx := TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{}, {}}, keepertest.TestContract, sdk.NewCoins()), - types.NewMsgCancelOrders("someone", []*types.Cancellation{{}, {}, {}}, keepertest.TestContract), - }, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(27500))), - } - _, err := decorator.AnteHandle(ctx, tx, false, terminator) - require.Nil(t, err) - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{}, {}}, keepertest.TestContract, sdk.NewCoins()), - types.NewMsgCancelOrders("someone", []*types.Cancellation{{}, {}, {}}, keepertest.TestContract), - }, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(25499))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.NotNil(t, err) - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{}}, keepertest.TestContract, sdk.NewCoins()), - }, - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.NotNil(t, err) - tx = TestTx{ - msgs: []sdk.Msg{}, - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.Nil(t, err) - tx = TestTx{ - msgs: []sdk.Msg{types.NewMsgContractDepositRent(keepertest.TestContract, 10, keepertest.TestAccount)}, - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.Nil(t, err) - - // with data (insufficient fee) - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{Data: "data"}, {}}, keepertest.TestContract, sdk.NewCoins()), - }, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(11011))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.NotNil(t, err) - - // with data (sufficient fee) - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{Data: "data"}, {}}, keepertest.TestContract, sdk.NewCoins()), - }, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(11012))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.Nil(t, err) -} - -func TestTickSizeMultipleDecorator(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithIsCheckTx(true) - decorator := dex.NewTickSizeMultipleDecorator(*keeper) - terminator := func(ctx sdk.Context, tx sdk.Tx, simulate bool) (newCtx sdk.Context, err error) { return ctx, nil } - - keeper.AddRegisteredPair(ctx, "contract", keepertest.TestPair) - keeper.SetPriceTickSizeForPair(ctx, "contract", keepertest.TestPair, *keepertest.TestPair.PriceTicksize) - keeper.SetQuantityTickSizeForPair(ctx, "contract", keepertest.TestPair, *keepertest.TestPair.PriceTicksize) - - price, _ := sdk.NewDecFromStr("25") - quantity, _ := sdk.NewDecFromStr("5") - smallerVal, _ := sdk.NewDecFromStr("0.01") - - // Market order with price zero allowed - tx := TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{ - ContractAddr: "contract", - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - Price: sdk.ZeroDec(), - Quantity: quantity, - OrderType: types.OrderType_MARKET, - }}, "contract", sdk.NewCoins())}, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(27500))), - } - _, err := decorator.AnteHandle(ctx, tx, false, terminator) - require.Nil(t, err) - - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{ - ContractAddr: "contract", - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - Price: sdk.ZeroDec(), - Quantity: quantity, - OrderType: types.OrderType_FOKMARKET, - }}, "contract", sdk.NewCoins())}, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(27500))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.Nil(t, err) - - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{ - ContractAddr: "contract", - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - Price: sdk.ZeroDec(), - Quantity: quantity, - OrderType: types.OrderType_FOKMARKETBYVALUE, - }}, "contract", sdk.NewCoins())}, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(27500))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.Nil(t, err) - - // Non-market orders with price zero not allowed - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{ - ContractAddr: "contract", - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - Price: sdk.ZeroDec(), - Quantity: quantity, - OrderType: types.OrderType_LIMIT, - }}, "contract", sdk.NewCoins())}, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(27500))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.NotNil(t, err) - - // Non-zero Priced Market Order With Divisible Price - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{ - ContractAddr: "contract", - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - Price: price, - Quantity: quantity, - OrderType: types.OrderType_MARKET, - }}, "contract", sdk.NewCoins())}, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(27500))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.Nil(t, err) - - // Non-zero Priced Market Order Without Divisible Price - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{ - ContractAddr: "contract", - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - Price: smallerVal, - Quantity: quantity, - OrderType: types.OrderType_MARKET, - }}, "contract", sdk.NewCoins())}, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(27500))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.NotNil(t, err) - - // Limit Order With Divisible Price - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{ - ContractAddr: "contract", - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - Price: price, - Quantity: quantity, - OrderType: types.OrderType_LIMIT, - }}, "contract", sdk.NewCoins())}, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(27500))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.Nil(t, err) - - // Limit Orders without Divisible Price - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{ - ContractAddr: "contract", - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - Price: smallerVal, - Quantity: quantity, - OrderType: types.OrderType_LIMIT, - }}, "contract", sdk.NewCoins())}, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(27500))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.NotNil(t, err) - - // All order quantities must be divisible by quantity tick size - tx = TestTx{ - msgs: []sdk.Msg{ - types.NewMsgPlaceOrders("someone", []*types.Order{{ - ContractAddr: "contract", - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - Price: price, - Quantity: smallerVal, - OrderType: types.OrderType_LIMIT, - }}, "contract", sdk.NewCoins())}, - fee: sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(27500))), - } - _, err = decorator.AnteHandle(ctx, tx, false, terminator) - require.NotNil(t, err) -} diff --git a/x/dex/cache/cache.go b/x/dex/cache/cache.go deleted file mode 100644 index 915843d9ce..0000000000 --- a/x/dex/cache/cache.go +++ /dev/null @@ -1,318 +0,0 @@ -package dex - -import ( - "fmt" - "sync" - "time" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - - "github.com/sei-protocol/sei-chain/utils/datastructures" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -const SynchronizationTimeoutInSeconds = 5 - -type MemState struct { - storeKey sdk.StoreKey - - // TODO: all of these need to be in the memstore - contractsToProcessMtx *sync.RWMutex - contractsToDepsMtx *sync.Mutex -} - -func NewMemState(storeKey sdk.StoreKey) *MemState { - return &MemState{ - storeKey: storeKey, - contractsToDepsMtx: &sync.Mutex{}, - contractsToProcessMtx: &sync.RWMutex{}, - } -} - -func (s *MemState) GetAllBlockOrders(ctx sdk.Context, contractAddr types.ContractAddress) (list []*types.Order) { - s.SynchronizeAccess(ctx, contractAddr) - store := prefix.NewStore( - ctx.KVStore(s.storeKey), - types.MemOrderPrefix( - string(contractAddr), - ), - ) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.Order - if err := val.Unmarshal(iterator.Value()); err != nil { - panic(err) - } - list = append(list, &val) - } - return -} - -func (s *MemState) GetBlockOrders(ctx sdk.Context, contractAddr types.ContractAddress, pair types.Pair) *BlockOrders { - s.SynchronizeAccess(ctx, contractAddr) - return NewOrders( - prefix.NewStore( - ctx.KVStore(s.storeKey), - types.MemOrderPrefixForPair( - string(contractAddr), pair.PriceDenom, pair.AssetDenom, - ), - ), - ) -} - -func (s *MemState) GetBlockCancels(ctx sdk.Context, contractAddr types.ContractAddress, pair types.Pair) *BlockCancellations { - s.SynchronizeAccess(ctx, contractAddr) - return NewCancels( - prefix.NewStore( - ctx.KVStore(s.storeKey), - types.MemCancelPrefixForPair( - string(contractAddr), pair.PriceDenom, pair.AssetDenom, - ), - ), - ) -} - -func (s *MemState) GetDepositInfo(ctx sdk.Context, contractAddr types.ContractAddress) *DepositInfo { - s.SynchronizeAccess(ctx, contractAddr) - return NewDepositInfo( - prefix.NewStore( - ctx.KVStore(s.storeKey), - types.MemDepositPrefix(string(contractAddr)), - ), - ) -} - -func (s *MemState) GetContractToDependencies(ctx sdk.Context, contractAddress string, loader func(sdk.Context, string) (types.ContractInfoV2, error)) []string { - s.contractsToDepsMtx.Lock() - defer s.contractsToDepsMtx.Unlock() - - store := ctx.KVStore(s.storeKey) - - // GET from memstate - bz := store.Get(types.MemDownstreamContractsKey(contractAddress)) - if bz != nil { - var contracts types.DownsteamContracts - if err := contracts.Unmarshal(bz); err != nil { - panic(err) - } - return contracts.ContractAddrs - } - loadedDownstreams := GetAllDownstreamContracts(ctx, contractAddress, loader) - // if we have to get all downstreams, save them to memstate - downstreamContracts := types.DownsteamContracts{ - ContractAddrs: loadedDownstreams, - } - contractsBz, err := downstreamContracts.Marshal() - if err != nil { - panic(err) - } - store.Set(types.MemDownstreamContractsKey(contractAddress), contractsBz) - return loadedDownstreams -} - -func (s *MemState) ClearContractToDependencies(ctx sdk.Context) { - s.contractsToDepsMtx.Lock() - defer s.contractsToDepsMtx.Unlock() - DeepDelete(ctx.KVStore(s.storeKey), types.KeyPrefix(types.MemDownstreamContracts), func(_ []byte) bool { return true }) -} - -func (s *MemState) SetDownstreamsToProcess(ctx sdk.Context, contractAddress string, loader func(sdk.Context, string) (types.ContractInfoV2, error)) { - s.contractsToProcessMtx.Lock() - defer s.contractsToProcessMtx.Unlock() - contracts := s.GetContractToDependencies(ctx, contractAddress, loader) - store := ctx.KVStore(s.storeKey) - for _, contract := range contracts { - // Add each to memstate instead - simply set to 1 for some value indicating presence - store.Set(types.MemContractsToProcessKey(contract), []byte{1}) - } -} - -func (s *MemState) ContractsToProcessContains(ctx sdk.Context, contractAddress string) bool { - s.contractsToProcessMtx.RLock() - defer s.contractsToProcessMtx.RUnlock() - store := ctx.KVStore(s.storeKey) - return store.Has(types.MemContractsToProcessKey(contractAddress)) -} - -func (s *MemState) GetContractToProcessOrderedSlice(ctx sdk.Context) []string { - s.contractsToProcessMtx.RLock() - defer s.contractsToProcessMtx.RUnlock() - orderedContracts := []string{} - store := ctx.KVStore(s.storeKey) - iter := sdk.KVStorePrefixIterator(store, types.KeyPrefix(types.MemContractsToProcess)) - for ; iter.Valid(); iter.Next() { - // get key - key := iter.Key() - // because we know length prefix is 1 byte, and the rest of the key is ONLY the contract addr, this lets us get the contract address bytes - contractAddrBytes := key[len(types.KeyPrefix(types.MemContractsToProcess))+1:] - // parse contract address from key - contractAddr := sdk.AccAddress(contractAddrBytes).String() - orderedContracts = append(orderedContracts, contractAddr) - } - return orderedContracts -} - -func (s *MemState) Clear(ctx sdk.Context) { - s.contractsToProcessMtx.Lock() - defer s.contractsToProcessMtx.Unlock() - DeepDelete(ctx.KVStore(s.storeKey), types.KeyPrefix(types.MemOrderKey), func(_ []byte) bool { return true }) - DeepDelete(ctx.KVStore(s.storeKey), types.KeyPrefix(types.MemCancelKey), func(_ []byte) bool { return true }) - DeepDelete(ctx.KVStore(s.storeKey), types.KeyPrefix(types.MemDepositKey), func(_ []byte) bool { return true }) - DeepDelete(ctx.KVStore(s.storeKey), types.KeyPrefix(types.MemContractsToProcess), func(_ []byte) bool { return true }) -} - -func (s *MemState) ClearCancellationForPair(ctx sdk.Context, contractAddr types.ContractAddress, pair types.Pair) { - s.SynchronizeAccess(ctx, contractAddr) - DeepDelete(ctx.KVStore(s.storeKey), types.KeyPrefix(types.MemCancelKey), func(v []byte) bool { - var c types.Cancellation - if err := c.Unmarshal(v); err != nil { - panic(err) - } - return c.ContractAddr == string(contractAddr) && c.PriceDenom == pair.PriceDenom && c.AssetDenom == pair.AssetDenom - }) -} - -func (s *MemState) DeepCopy() *MemState { - return &MemState{ - storeKey: s.storeKey, - contractsToDepsMtx: s.contractsToDepsMtx, // passing by pointer - contractsToProcessMtx: s.contractsToProcessMtx, // passing by pointer - } -} - -func (s *MemState) DeepFilterAccount(ctx sdk.Context, account string) { - DeepDelete(ctx.KVStore(s.storeKey), types.KeyPrefix(types.MemOrderKey), func(v []byte) bool { - var o types.Order - if err := o.Unmarshal(v); err != nil { - panic(err) - } - return o.Account == account - }) - DeepDelete(ctx.KVStore(s.storeKey), types.KeyPrefix(types.MemCancelKey), func(v []byte) bool { - var c types.Cancellation - if err := c.Unmarshal(v); err != nil { - panic(err) - } - return c.Creator == account - }) - DeepDelete(ctx.KVStore(s.storeKey), types.KeyPrefix(types.MemDepositKey), func(v []byte) bool { - var d types.DepositInfoEntry - if err := d.Unmarshal(v); err != nil { - panic(err) - } - return d.Creator == account - }) -} - -func (s *MemState) SynchronizeAccess(ctx sdk.Context, contractAddr types.ContractAddress) { - executingContract := GetExecutingContract(ctx) - if executingContract == nil { - // not accessed by contract. no need to synchronize - return - } - targetContractAddr := string(contractAddr) - if executingContract.ContractAddr == targetContractAddr { - // access by the contract itself does not need synchronization - return - } - for _, dependency := range executingContract.Dependencies { - if dependency.Dependency != targetContractAddr { - continue - } - terminationSignals := GetTerminationSignals(ctx) - if terminationSignals == nil { - // synchronization should fail in the case of no termination signal to prevent race conditions. - panic("no termination signal map found in context") - } - targetChannel, ok := terminationSignals.Load(dependency.ImmediateElderSibling) - if !ok { - // synchronization should fail in the case of no termination signal to prevent race conditions. - panic(fmt.Sprintf("no termination signal channel for contract %s in context", dependency.ImmediateElderSibling)) - } - - select { - case <-targetChannel: - // since buffered channel can only be consumed once, we need to - // requeue so that it can unblock other goroutines that waits for - // the same channel. - targetChannel <- struct{}{} - case <-time.After(SynchronizationTimeoutInSeconds * time.Second): - // synchronization should fail in the case of timeout to prevent race conditions. - panic(fmt.Sprintf("timing out waiting for termination of %s", dependency.ImmediateElderSibling)) - } - - return - } - - // fail loudly so that the offending contract can be rolled back. - // eventually we will automatically de-register contracts that have to be rolled back - // so that this would not become a point of attack in terms of performance. - panic(fmt.Sprintf("Contract %s trying to access state of %s which is not a registered dependency", executingContract.ContractAddr, targetContractAddr)) -} - -func DeepDelete(kvStore sdk.KVStore, storePrefix []byte, matcher func([]byte) bool) { - store := prefix.NewStore( - kvStore, - storePrefix, - ) - // Getting all KVs first before applying `matcher` in case `matcher` contains - // store read/write logics. - // Wrapping getter into its own function to make sure iterator is always closed - // before `matcher` logic runs. - keyValuesGetter := func() ([][]byte, [][]byte) { - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - defer iterator.Close() - keys, values := [][]byte{}, [][]byte{} - for ; iterator.Valid(); iterator.Next() { - keys = append(keys, iterator.Key()) - values = append(values, iterator.Value()) - } - return keys, values - } - keys, values := keyValuesGetter() - for i, key := range keys { - if matcher(values[i]) { - store.Delete(key) - } - } -} - -// BFS traversal over a acyclic graph -// Includes the root contract itself. -func GetAllDownstreamContracts(ctx sdk.Context, contractAddress string, loader func(sdk.Context, string) (types.ContractInfoV2, error)) []string { - res := []string{contractAddress} - seen := datastructures.NewSyncSet(res) - downstreams := []*types.ContractInfoV2{} - populater := func(target *types.ContractInfoV2) { - for _, dep := range target.Dependencies { - if downstream, err := loader(ctx, dep.Dependency); err == nil && !seen.Contains(downstream.ContractAddr) { - if !downstream.Suspended { - downstreams = append(downstreams, &downstream) - seen.Add(downstream.ContractAddr) - } - } else { - // either getting the dependency returned an error, or there is a cycle in the graph. Either way - // is bad and should cause the triggering tx to fail - panic(fmt.Sprintf("getting dependency %s for %s returned an error, or there is a cycle in the dependency graph", dep.Dependency, target.ContractAddr)) - } - } - } - // init first layer downstreams - if contract, err := loader(ctx, contractAddress); err == nil { - populater(&contract) - } else { - return res - } - - for len(downstreams) > 0 { - downstream := downstreams[0] - res = append(res, downstream.ContractAddr) - populater(downstream) - downstreams = downstreams[1:] - } - return res -} diff --git a/x/dex/cache/cache_test.go b/x/dex/cache/cache_test.go deleted file mode 100644 index c6603e7914..0000000000 --- a/x/dex/cache/cache_test.go +++ /dev/null @@ -1,225 +0,0 @@ -package dex_test - -import ( - "context" - "testing" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/utils/datastructures" - dex "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/sei-protocol/sei-chain/x/store" - "github.com/stretchr/testify/require" -) - -const ( - TEST_CONTRACT = "test" -) - -func TestDeepCopy(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(keeper.GetMemStoreKey()) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - }) - stateTwo := stateOne.DeepCopy() - cachedCtx, _ := store.GetCachedContext(ctx) - stateTwo.GetBlockOrders(cachedCtx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 2, - Account: "test", - ContractAddr: TEST_CONTRACT, - }) - // old state must not be changed - require.Equal(t, 1, len(stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Get())) - // new state must be changed - require.Equal(t, 2, len(stateTwo.GetBlockOrders(cachedCtx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Get())) -} - -func TestDeepFilterAccounts(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(keeper.GetMemStoreKey()) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 2, - Account: "test2", - ContractAddr: TEST_CONTRACT, - }) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 1, - Creator: "test", - }) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 2, - Creator: "test2", - }) - stateOne.GetDepositInfo(ctx, types.ContractAddress(TEST_CONTRACT)).Add(&types.DepositInfoEntry{ - Creator: "test", - }) - stateOne.GetDepositInfo(ctx, types.ContractAddress(TEST_CONTRACT)).Add(&types.DepositInfoEntry{ - Creator: "test2", - }) - - stateOne.DeepFilterAccount(ctx, "test") - require.Equal(t, 1, len(stateOne.GetAllBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT)))) - require.Equal(t, 1, len(stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Get())) - require.Equal(t, 1, len(stateOne.GetDepositInfo(ctx, types.ContractAddress(TEST_CONTRACT)).Get())) -} - -func TestDeepDelete(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(keeper.GetMemStoreKey()) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - }) - dex.DeepDelete(ctx.KVStore(keeper.GetStoreKey()), types.KeyPrefix(types.MemOrderKey), func(_ []byte) bool { return true }) -} - -func TestClear(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(keeper.GetMemStoreKey()) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - }) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 2, - ContractAddr: TEST_CONTRACT, - }) - stateOne.Clear(ctx) - require.Equal(t, 0, len(stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Get())) - require.Equal(t, 0, len(stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Get())) -} - -func TestClearCancellationForPair(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(keeper.GetMemStoreKey()) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 1, - ContractAddr: TEST_CONTRACT, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 2, - ContractAddr: TEST_CONTRACT, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 3, - ContractAddr: TEST_CONTRACT, - PriceDenom: "USDC", - AssetDenom: "SEI", - }) - stateOne.ClearCancellationForPair(ctx, TEST_CONTRACT, types.Pair{ - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - require.Equal(t, 1, len(stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Get())) - require.Equal(t, uint64(3), stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Get()[0].Id) -} - -func TestSynchronization(t *testing.T) { - k, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(k.GetMemStoreKey()) - targetContract := types.ContractAddress(TEST_CONTRACT) - // no go context - require.NotPanics(t, func() { stateOne.SynchronizeAccess(ctx, targetContract) }) - // no executing contract - goCtx := context.Background() - ctx = ctx.WithContext(goCtx) - require.NotPanics(t, func() { stateOne.SynchronizeAccess(ctx, targetContract) }) - // executing contract same as target contract - executingContract := types.ContractInfoV2{ContractAddr: TEST_CONTRACT} - ctx = ctx.WithContext(context.WithValue(goCtx, dex.CtxKeyExecutingContract, executingContract)) - require.NotPanics(t, func() { stateOne.SynchronizeAccess(ctx, targetContract) }) - // executing contract attempting to access non-dependency - executingContract.ContractAddr = "executing" - ctx = ctx.WithContext(context.WithValue(goCtx, dex.CtxKeyExecutingContract, executingContract)) - require.Panics(t, func() { stateOne.SynchronizeAccess(ctx, targetContract) }) - // no termination map - executingContract.Dependencies = []*types.ContractDependencyInfo{ - {Dependency: TEST_CONTRACT, ImmediateElderSibling: "elder"}, - } - ctx = ctx.WithContext(context.WithValue(goCtx, dex.CtxKeyExecutingContract, executingContract)) - require.Panics(t, func() { stateOne.SynchronizeAccess(ctx, targetContract) }) - // no termination signal channel for sibling - terminationSignals := datastructures.NewTypedSyncMap[string, chan struct{}]() - goCtx = context.WithValue(goCtx, dex.CtxKeyExecutingContract, executingContract) - goCtx = context.WithValue(goCtx, dex.CtxKeyExecTermSignal, terminationSignals) - ctx = ctx.WithContext(goCtx) - require.Panics(t, func() { stateOne.SynchronizeAccess(ctx, targetContract) }) - // termination signal times out - siblingChan := make(chan struct{}, 1) - terminationSignals.Store("elder", siblingChan) - require.Panics(t, func() { stateOne.SynchronizeAccess(ctx, targetContract) }) - // termination signal sent - go func() { - siblingChan <- struct{}{} - }() - require.NotPanics(t, func() { stateOne.SynchronizeAccess(ctx, targetContract) }) - <-siblingChan // the channel should be re-populated -} - -func TestGetAllDownstreamContracts(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keeper.SetContract(ctx, &types.ContractInfoV2{ - ContractAddr: "sei1cnuw3f076wgdyahssdkd0g3nr96ckq8cwa2mh029fn5mgf2fmcmsae2elf", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "sei1ery8l6jquynn9a4cz2pff6khg8c68f7urt33l5n9dng2cwzz4c4q4hncrd", - }, - }, - }) - keeper.SetContract(ctx, &types.ContractInfoV2{ - ContractAddr: "sei1ery8l6jquynn9a4cz2pff6khg8c68f7urt33l5n9dng2cwzz4c4q4hncrd", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "sei1wl59k23zngj34l7d42y9yltask7rjlnxgccawc7ltrknp6n52fpsj6ctln", - }, { - Dependency: "sei1udfs22xpxle475m2nz7u47jfa3vngncdegmczwwdx00cmetypa3sman25q", - }, - }, - }) - keeper.SetContract(ctx, &types.ContractInfoV2{ - ContractAddr: "sei1wl59k23zngj34l7d42y9yltask7rjlnxgccawc7ltrknp6n52fpsj6ctln", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "sei1stwdtk6ja0705v8qmtukcp4vd422p5vy4jr5wdc4qk44c57k955qcannhd", - }, - }, - }) - keeper.SetContract(ctx, &types.ContractInfoV2{ - ContractAddr: "sei1stwdtk6ja0705v8qmtukcp4vd422p5vy4jr5wdc4qk44c57k955qcannhd", - }) - keeper.SetContract(ctx, &types.ContractInfoV2{ - ContractAddr: "sei1udfs22xpxle475m2nz7u47jfa3vngncdegmczwwdx00cmetypa3sman25q", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "sei14rse3e7rkc3qt7drmlulwlkrlzqvh7hv277zv05kyfuwl74udx5s9r7lm3", - }, - }, - Suspended: true, - }) - keeper.SetContract(ctx, &types.ContractInfoV2{ - ContractAddr: "sei14rse3e7rkc3qt7drmlulwlkrlzqvh7hv277zv05kyfuwl74udx5s9r7lm3", - }) - keeper.SetContract(ctx, &types.ContractInfoV2{ - ContractAddr: "sei182jzjwdyl5fw43yujnlljddgtrkr04dpd30ywp2yn724u7qhtaqsjev6mv", - }) - - require.Equal(t, []string{ - "sei1ery8l6jquynn9a4cz2pff6khg8c68f7urt33l5n9dng2cwzz4c4q4hncrd", - "sei1wl59k23zngj34l7d42y9yltask7rjlnxgccawc7ltrknp6n52fpsj6ctln", - "sei1stwdtk6ja0705v8qmtukcp4vd422p5vy4jr5wdc4qk44c57k955qcannhd", - }, dex.GetAllDownstreamContracts(ctx, "sei1ery8l6jquynn9a4cz2pff6khg8c68f7urt33l5n9dng2cwzz4c4q4hncrd", keeper.GetContractWithoutGasCharge)) -} diff --git a/x/dex/cache/cancel.go b/x/dex/cache/cancel.go deleted file mode 100644 index ec195a46d2..0000000000 --- a/x/dex/cache/cancel.go +++ /dev/null @@ -1,65 +0,0 @@ -package dex - -import ( - "encoding/binary" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -type BlockCancellations struct { - cancelStore *prefix.Store -} - -func NewCancels(cancelStore prefix.Store) *BlockCancellations { - return &BlockCancellations{cancelStore: &cancelStore} -} - -func (o *BlockCancellations) Has(cancel *types.Cancellation) bool { - keybz := make([]byte, 8) - binary.BigEndian.PutUint64(keybz, cancel.Id) - return o.cancelStore.Has(keybz) -} - -func (o *BlockCancellations) Get() (list []*types.Cancellation) { - iterator := sdk.KVStorePrefixIterator(o.cancelStore, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.Cancellation - if err := val.Unmarshal(iterator.Value()); err != nil { - panic(err) - } - list = append(list, &val) - } - - return -} - -func (o *BlockCancellations) GetIdsToCancel() (list []uint64) { - iterator := sdk.KVStorePrefixIterator(o.cancelStore, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.Cancellation - if err := val.Unmarshal(iterator.Value()); err != nil { - panic(err) - } - list = append(list, val.Id) - } - - return -} - -func (o *BlockCancellations) Add(newItem *types.Cancellation) { - keybz := make([]byte, 8) - binary.BigEndian.PutUint64(keybz, newItem.Id) - valbz, err := newItem.Marshal() - if err != nil { - panic(err) - } - o.cancelStore.Set(keybz, valbz) -} diff --git a/x/dex/cache/cancel_test.go b/x/dex/cache/cancel_test.go deleted file mode 100644 index 8f9d51d80f..0000000000 --- a/x/dex/cache/cancel_test.go +++ /dev/null @@ -1,76 +0,0 @@ -package dex_test - -import ( - "testing" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dex "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestCancelGetIdsToCancel(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(keeper.GetMemStoreKey()) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 1, - Creator: "abc", - ContractAddr: TEST_CONTRACT, - }) - ids := stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).GetIdsToCancel() - require.Equal(t, 1, len(ids)) - require.Equal(t, uint64(1), ids[0]) -} - -func TestCancelGetCancels(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(keeper.GetMemStoreKey()) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 1, - Creator: "abc", - ContractAddr: TEST_CONTRACT, - }) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 2, - Creator: "def", - ContractAddr: TEST_CONTRACT, - }) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 3, - Creator: "efg", - ContractAddr: TEST_CONTRACT, - }) - stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Cancellation{ - Id: 4, - Creator: "efg", - ContractAddr: TEST_CONTRACT, - }) - - cancels := stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Get() - require.Equal(t, 4, len(cancels)) - require.True(t, stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Has(&types.Cancellation{ - Id: 1, - Creator: "abc", - ContractAddr: TEST_CONTRACT, - })) - require.True(t, stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Has(&types.Cancellation{ - Id: 2, - Creator: "def", - ContractAddr: TEST_CONTRACT, - })) - require.True(t, stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Has(&types.Cancellation{ - Id: 3, - Creator: "efg", - ContractAddr: TEST_CONTRACT, - })) - require.True(t, stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Has(&types.Cancellation{ - Id: 4, - Creator: "efg", - ContractAddr: TEST_CONTRACT, - })) - require.False(t, stateOne.GetBlockCancels(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Has(&types.Cancellation{ - Id: 5, - Creator: "efg", - ContractAddr: TEST_CONTRACT, - })) -} diff --git a/x/dex/cache/context.go b/x/dex/cache/context.go deleted file mode 100644 index 8c427f577d..0000000000 --- a/x/dex/cache/context.go +++ /dev/null @@ -1,44 +0,0 @@ -package dex - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/utils/datastructures" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -type CtxKeyType string - -const ( - CtxKeyExecTermSignal = CtxKeyType("execution-termination-signals") - CtxKeyExecutingContract = CtxKeyType("executing-contract") -) - -func GetExecutingContract(ctx sdk.Context) *types.ContractInfoV2 { - if ctx.Context() == nil { - return nil - } - executingContract := ctx.Context().Value(CtxKeyExecutingContract) - if executingContract == nil { - return nil - } - contract, ok := executingContract.(types.ContractInfoV2) - if !ok { - return nil - } - return &contract -} - -func GetTerminationSignals(ctx sdk.Context) *datastructures.TypedSyncMap[string, chan struct{}] { - if ctx.Context() == nil { - return nil - } - signals := ctx.Context().Value(CtxKeyExecTermSignal) - if signals == nil { - return nil - } - typedSignals, ok := signals.(*datastructures.TypedSyncMap[string, chan struct{}]) - if !ok { - return nil - } - return typedSignals -} diff --git a/x/dex/cache/deposit.go b/x/dex/cache/deposit.go deleted file mode 100644 index 1df6b26228..0000000000 --- a/x/dex/cache/deposit.go +++ /dev/null @@ -1,51 +0,0 @@ -package dex - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -type DepositInfo struct { - store *prefix.Store -} - -func NewDepositInfo(store prefix.Store) *DepositInfo { - return &DepositInfo{store: &store} -} - -func (d *DepositInfo) Get() (list []*types.DepositInfoEntry) { - iterator := sdk.KVStorePrefixIterator(d.store, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.DepositInfoEntry - if err := val.Unmarshal(iterator.Value()); err != nil { - panic(err) - } - list = append(list, &val) - } - - return -} - -func (d *DepositInfo) Add(newItem *types.DepositInfoEntry) { - key := types.MemDepositSubprefix(newItem.Creator, newItem.Denom) - if val, err := newItem.Marshal(); err != nil { - panic(err) - } else if existing := d.store.Get(key); existing == nil { - d.store.Set(key, val) - } else { - existingItem := types.DepositInfoEntry{} - if err := existingItem.Unmarshal(existing); err != nil { - panic(err) - } - newItem.Amount = newItem.Amount.Add(existingItem.Amount) - newVal, err := newItem.Marshal() - if err != nil { - panic(err) - } - d.store.Set(key, newVal) - } -} diff --git a/x/dex/cache/deposit_test.go b/x/dex/cache/deposit_test.go deleted file mode 100644 index 364ffa3d1c..0000000000 --- a/x/dex/cache/deposit_test.go +++ /dev/null @@ -1,48 +0,0 @@ -package dex_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dex "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestDepositAdd(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - deposits := dex.NewMemState(keeper.GetMemStoreKey()).GetDepositInfo(ctx, types.ContractAddress(keepertest.TestContract)) - deposit := types.DepositInfoEntry{ - Creator: "abc", - Amount: sdk.MustNewDecFromStr("1.2"), - } - deposits.Add(&deposit) - depositsState := deposits.Get() - require.Equal(t, 1, len(depositsState)) - require.Equal(t, sdk.MustNewDecFromStr("1.2"), depositsState[0].Amount) - - deposit = types.DepositInfoEntry{ - Creator: "abc", - Amount: sdk.MustNewDecFromStr("1.3"), - } - deposits.Add(&deposit) - depositsState = deposits.Get() - require.Equal(t, 1, len(depositsState)) - require.Equal(t, sdk.MustNewDecFromStr("2.5"), depositsState[0].Amount) - - deposit = types.DepositInfoEntry{ - Creator: "def", - Amount: sdk.MustNewDecFromStr("1.1"), - } - deposits.Add(&deposit) - depositsState = deposits.Get() - require.Equal(t, 2, len(depositsState)) - if depositsState[0].Creator == "abc" { - require.Equal(t, sdk.MustNewDecFromStr("2.5"), depositsState[0].Amount) - require.Equal(t, sdk.MustNewDecFromStr("1.1"), depositsState[1].Amount) - } else { - require.Equal(t, sdk.MustNewDecFromStr("2.5"), depositsState[1].Amount) - require.Equal(t, sdk.MustNewDecFromStr("1.1"), depositsState[0].Amount) - } -} diff --git a/x/dex/cache/order.go b/x/dex/cache/order.go deleted file mode 100644 index 03fac3aece..0000000000 --- a/x/dex/cache/order.go +++ /dev/null @@ -1,142 +0,0 @@ -package dex - -import ( - "encoding/binary" - "sort" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -type BlockOrders struct { - orderStore *prefix.Store -} - -func NewOrders(orderStore prefix.Store) *BlockOrders { - return &BlockOrders{orderStore: &orderStore} -} - -func (o *BlockOrders) Add(newItem *types.Order) { - keybz := make([]byte, 8) - binary.BigEndian.PutUint64(keybz, newItem.Id) - valbz, err := newItem.Marshal() - if err != nil { - panic(err) - } - o.orderStore.Set(keybz, valbz) -} - -func (o *BlockOrders) GetByID(id uint64) *types.Order { - keybz := make([]byte, 8) - binary.BigEndian.PutUint64(keybz, id) - var val types.Order - if err := val.Unmarshal(o.orderStore.Get(keybz)); err != nil { - panic(err) - } - return &val -} - -func (o *BlockOrders) Get() (list []*types.Order) { - iterator := sdk.KVStorePrefixIterator(o.orderStore, []byte{}) - defer iterator.Close() - for ; iterator.Valid(); iterator.Next() { - var val types.Order - if err := val.Unmarshal(iterator.Value()); err != nil { - panic(err) - } - list = append(list, &val) - } - - return -} - -func (o *BlockOrders) MarkFailedToPlace(failedOrders []types.UnsuccessfulOrder) { - failedOrdersMap := map[uint64]types.UnsuccessfulOrder{} - for _, failedOrder := range failedOrders { - failedOrdersMap[failedOrder.ID] = failedOrder - } - - keys, vals := o.getKVsToSet(failedOrdersMap) - for i, key := range keys { - o.orderStore.Set(key, vals[i]) - } -} - -// getKVsToSet iterate through the kvstore and append the key,val items to a list. -// We should avoid writing or reading from the store directly within the iterator. -func (o *BlockOrders) getKVsToSet(failedOrdersMap map[uint64]types.UnsuccessfulOrder) ([][]byte, [][]byte) { - iterator := sdk.KVStorePrefixIterator(o.orderStore, []byte{}) - - defer iterator.Close() - - var keys [][]byte - var vals [][]byte - for ; iterator.Valid(); iterator.Next() { - var val types.Order - if err := val.Unmarshal(iterator.Value()); err != nil { - panic(err) - } - if failedOrder, ok := failedOrdersMap[val.Id]; ok { - val.Status = types.OrderStatus_FAILED_TO_PLACE - val.StatusDescription = failedOrder.Reason - } - bz, err := val.Marshal() - if err != nil { - panic(err) - } - keys = append(keys, iterator.Key()) - vals = append(vals, bz) - } - return keys, vals -} - -func (o *BlockOrders) GetSortedMarketOrders(direction types.PositionDirection) []*types.Order { - res := o.getOrdersByCriteria(types.OrderType_MARKET, direction) - res = append(res, o.getOrdersByCriteria(types.OrderType_FOKMARKET, direction)...) - res = append(res, o.getOrdersByCriteria(types.OrderType_FOKMARKETBYVALUE, direction)...) - sort.SliceStable(res, func(i, j int) bool { - // a price of 0 indicates that there is no worst price for the order, so it should - // always be ranked at the top. - if res[i].Price.IsZero() { - return true - } else if res[j].Price.IsZero() { - return false - } - switch direction { - case types.PositionDirection_LONG: - return res[i].Price.GT(res[j].Price) - case types.PositionDirection_SHORT: - return res[i].Price.LT(res[j].Price) - default: - panic("Unknown direction") - } - }) - return res -} - -func (o *BlockOrders) GetLimitOrders(direction types.PositionDirection) []*types.Order { - return o.getOrdersByCriteria(types.OrderType_LIMIT, direction) -} - -func (o *BlockOrders) getOrdersByCriteria(orderType types.OrderType, direction types.PositionDirection) []*types.Order { - res := []*types.Order{} - iterator := sdk.KVStorePrefixIterator(o.orderStore, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.Order - if err := val.Unmarshal(iterator.Value()); err != nil { - panic(err) - } - if val.OrderType != orderType || val.PositionDirection != direction { - continue - } - if val.Status == types.OrderStatus_FAILED_TO_PLACE { - continue - } - res = append(res, &val) - } - return res -} diff --git a/x/dex/cache/order_test.go b/x/dex/cache/order_test.go deleted file mode 100644 index b5ab037156..0000000000 --- a/x/dex/cache/order_test.go +++ /dev/null @@ -1,257 +0,0 @@ -package dex_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dex "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMarkFailedToPlace(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(keeper.GetMemStoreKey()) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - }) - unsuccessfulOrder := types.UnsuccessfulOrder{ - ID: 1, - Reason: "some reason", - } - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).MarkFailedToPlace([]types.UnsuccessfulOrder{unsuccessfulOrder}) - require.Equal(t, types.OrderStatus_FAILED_TO_PLACE, - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Get()[0].Status) - require.Equal(t, "some reason", - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Get()[0].StatusDescription) -} - -func TestGetByID(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(keeper.GetMemStoreKey()) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 1, - Account: "test1", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_LIMIT, - Price: sdk.MustNewDecFromStr("150"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 2, - Account: "test2", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_MARKET, - Price: sdk.MustNewDecFromStr("100"), - }) - - order1 := stateOne.GetBlockOrders( - ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).GetByID(uint64(1)) - order2 := stateOne.GetBlockOrders( - ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).GetByID(uint64(2)) - require.Equal(t, uint64(1), order1.Id) - require.Equal(t, uint64(2), order2.Id) - require.Equal(t, "test1", order1.Account) - require.Equal(t, "test2", order2.Account) - require.Equal(t, TEST_CONTRACT, order1.ContractAddr) - require.Equal(t, TEST_CONTRACT, order2.ContractAddr) - require.Equal(t, types.PositionDirection_LONG, order1.PositionDirection) - require.Equal(t, types.PositionDirection_SHORT, order2.PositionDirection) - require.Equal(t, types.OrderType_LIMIT, order1.OrderType) - require.Equal(t, types.OrderType_MARKET, order2.OrderType) - require.Equal(t, sdk.MustNewDecFromStr("150"), order1.Price) - require.Equal(t, sdk.MustNewDecFromStr("100"), order2.Price) -} - -func TestGetSortedMarketOrders(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - stateOne := dex.NewMemState(keeper.GetMemStoreKey()) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_MARKET, - Price: sdk.MustNewDecFromStr("150"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 2, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_MARKET, - Price: sdk.MustNewDecFromStr("100"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 3, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_MARKET, - Price: sdk.MustNewDecFromStr("0"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 4, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_MARKET, - Price: sdk.MustNewDecFromStr("100"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 5, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_MARKET, - Price: sdk.MustNewDecFromStr("80"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 6, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_MARKET, - Price: sdk.MustNewDecFromStr("0"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 7, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_LIMIT, - Price: sdk.MustNewDecFromStr("100"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 8, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_LIMIT, - Price: sdk.MustNewDecFromStr("100"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 9, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_FOKMARKET, - Price: sdk.MustNewDecFromStr("100"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 10, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_FOKMARKET, - Price: sdk.MustNewDecFromStr("0"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 11, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_FOKMARKET, - Price: sdk.MustNewDecFromStr("150"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 12, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_FOKMARKET, - Price: sdk.MustNewDecFromStr("0"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 13, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_FOKMARKET, - Price: sdk.MustNewDecFromStr("150"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 14, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_FOKMARKET, - Price: sdk.MustNewDecFromStr("100"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 15, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_FOKMARKETBYVALUE, - Price: sdk.MustNewDecFromStr("100"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 16, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_FOKMARKETBYVALUE, - Price: sdk.MustNewDecFromStr("0"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 17, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_FOKMARKETBYVALUE, - Price: sdk.MustNewDecFromStr("150"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 18, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_FOKMARKETBYVALUE, - Price: sdk.MustNewDecFromStr("0"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 19, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_FOKMARKETBYVALUE, - Price: sdk.MustNewDecFromStr("150"), - }) - stateOne.GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).Add(&types.Order{ - Id: 20, - Account: "test", - ContractAddr: TEST_CONTRACT, - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_FOKMARKETBYVALUE, - Price: sdk.MustNewDecFromStr("100"), - }) - - marketBuys := stateOne.GetBlockOrders( - ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).GetSortedMarketOrders(types.PositionDirection_LONG) - require.Equal(t, uint64(16), marketBuys[0].Id) - require.Equal(t, uint64(10), marketBuys[1].Id) - require.Equal(t, uint64(3), marketBuys[2].Id) - require.Equal(t, uint64(1), marketBuys[3].Id) - require.Equal(t, uint64(11), marketBuys[4].Id) - require.Equal(t, uint64(17), marketBuys[5].Id) - require.Equal(t, uint64(2), marketBuys[6].Id) - require.Equal(t, uint64(9), marketBuys[7].Id) - require.Equal(t, uint64(15), marketBuys[8].Id) - - marketSells := stateOne.GetBlockOrders( - ctx, types.ContractAddress(TEST_CONTRACT), keepertest.TestPair).GetSortedMarketOrders(types.PositionDirection_SHORT) - require.Equal(t, uint64(18), marketSells[0].Id) - require.Equal(t, uint64(12), marketSells[1].Id) - require.Equal(t, uint64(6), marketSells[2].Id) - require.Equal(t, uint64(5), marketSells[3].Id) - require.Equal(t, uint64(4), marketSells[4].Id) - require.Equal(t, uint64(14), marketSells[5].Id) - require.Equal(t, uint64(20), marketSells[6].Id) - require.Equal(t, uint64(13), marketSells[7].Id) - require.Equal(t, uint64(19), marketSells[8].Id) -} diff --git a/x/dex/client/cli/query/query.go b/x/dex/client/cli/query/query.go deleted file mode 100644 index 9270b81c36..0000000000 --- a/x/dex/client/cli/query/query.go +++ /dev/null @@ -1,48 +0,0 @@ -package query - -import ( - "fmt" - // "strings" - - "github.com/spf13/cobra" - - "github.com/cosmos/cosmos-sdk/client" - // "github.com/cosmos/cosmos-sdk/client/flags" - // sdk "github.com/cosmos/cosmos-sdk/types" - - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -// GetQueryCmd returns the cli query commands for this module -func GetQueryCmd() *cobra.Command { - // Group dex queries under a subcommand - cmd := &cobra.Command{ - Use: types.ModuleName, - Short: fmt.Sprintf("Querying commands for the %s module", types.ModuleName), - DisableFlagParsing: true, - SuggestionsMinimumDistance: 2, - RunE: client.ValidateCmd, - } - - cmd.AddCommand(CmdQueryParams()) - cmd.AddCommand(CmdListLongBook()) - cmd.AddCommand(CmdShowLongBook()) - cmd.AddCommand(CmdListShortBook()) - cmd.AddCommand(CmdShowShortBook()) - cmd.AddCommand(CmdGetPrice()) - cmd.AddCommand(CmdGetLatestPrice()) - cmd.AddCommand(CmdGetPrices()) - cmd.AddCommand(CmdGetTwaps()) - cmd.AddCommand(CmdGetAssetList()) - cmd.AddCommand(CmdGetAssetMetadata()) - cmd.AddCommand(CmdGetRegisteredPairs()) - cmd.AddCommand(CmdGetRegisteredContract()) - cmd.AddCommand(CmdGetOrders()) - cmd.AddCommand(CmdGetOrdersByID()) - cmd.AddCommand(CmdGetMatchResult()) - cmd.AddCommand(CmdGetOrderCount()) - - // this line is used by starport scaffolding # 1 - - return cmd -} diff --git a/x/dex/client/cli/query/query_asset_list.go b/x/dex/client/cli/query/query_asset_list.go deleted file mode 100644 index 7615cbfed4..0000000000 --- a/x/dex/client/cli/query/query_asset_list.go +++ /dev/null @@ -1,80 +0,0 @@ -package query - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdGetAssetList() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-asset-list", - Short: "Query Asset List", - Long: strings.TrimSpace(` - Returns the metadata for all assets. Dex asset metadata includes information such as IBC info (for IBC assets), the asset type, and standard token metadata from the bank module. - `), - Args: cobra.NoArgs, - RunE: func(cmd *cobra.Command, args []string) (err error) { - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryAssetListRequest{} - - res, err := queryClient.AssetList(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} - -func CmdGetAssetMetadata() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-asset-metadata [denom]", - Short: "Query Asset Metadata", - Long: strings.TrimSpace(` - Returns the metadata for a specific asset based on the passed in denom. Dex asset metadata includes information such as IBC info (for IBC assets), the asset type, and standard token metadata from the bank module. - `), - Args: cobra.ExactArgs(1), - RunE: func(cmd *cobra.Command, args []string) (err error) { - denom := args[0] - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryAssetMetadataRequest{ - Denom: denom, - } - - res, err := queryClient.AssetMetadata(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_get_latest_price.go b/x/dex/client/cli/query/query_get_latest_price.go deleted file mode 100644 index 52bbcb3f00..0000000000 --- a/x/dex/client/cli/query/query_get_latest_price.go +++ /dev/null @@ -1,53 +0,0 @@ -package query - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdGetLatestPrice() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-latest-price [contract-address] [price-denom] [asset-denom]", - Short: "Query getLatestPrice", - Long: strings.TrimSpace(` - Get the latest price from a dex specified by the contract-address. The price and asset denom are used to specify the dex pair for which to return the latest price. For the price at a specific timestamp use get-price instead or for all prices use get-prices. - `), - Args: cobra.ExactArgs(3), - RunE: func(cmd *cobra.Command, args []string) (err error) { - reqContractAddr := args[0] - reqPriceDenom := args[1] - reqAssetDenom := args[2] - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryGetLatestPriceRequest{ - ContractAddr: reqContractAddr, - PriceDenom: reqPriceDenom, - AssetDenom: reqAssetDenom, - } - - res, err := queryClient.GetLatestPrice(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_get_order_count.go b/x/dex/client/cli/query/query_get_order_count.go deleted file mode 100644 index 105fcbdaa1..0000000000 --- a/x/dex/client/cli/query/query_get_order_count.go +++ /dev/null @@ -1,52 +0,0 @@ -package query - -import ( - "context" - "fmt" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -func CmdGetOrderCount() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-order-count [contract] [price denom] [asset denom] [LONG|SHORT] [price]", - Short: "get number of orders at a price leve", - Args: cobra.ExactArgs(5), - RunE: func(cmd *cobra.Command, args []string) error { - clientCtx := client.GetClientContextFromCmd(cmd) - - queryClient := types.NewQueryClient(clientCtx) - - var direction types.PositionDirection - switch args[3] { - case "LONG": - direction = types.PositionDirection_LONG - case "SHORT": - direction = types.PositionDirection_SHORT - default: - return fmt.Errorf("unknown direction %s", args[3]) - } - price := sdk.MustNewDecFromStr(args[4]) - res, err := queryClient.GetOrderCount(context.Background(), &types.QueryGetOrderCountRequest{ - ContractAddr: args[0], - PriceDenom: args[1], - AssetDenom: args[2], - PositionDirection: direction, - Price: &price, - }) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_get_price.go b/x/dex/client/cli/query/query_get_price.go deleted file mode 100644 index 06c9d9dbd0..0000000000 --- a/x/dex/client/cli/query/query_get_price.go +++ /dev/null @@ -1,58 +0,0 @@ -package query - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdGetPrice() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-price [contract-address] [timestamp] [price-denom] [asset-denom]", - Short: "Query getPrice", - Long: strings.TrimSpace(` - Get the price for a pair from a dex specified by the contract-address. The price and asset denom are used to specify the dex pair for which to return the latest price. The timestamp is used to query the price for that specific timestamp. For the latest price use get-latest-price instead or for all prices use get-prices. - `), - Args: cobra.ExactArgs(4), - RunE: func(cmd *cobra.Command, args []string) (err error) { - reqContractAddr := args[0] - reqTimestamp, err := strconv.ParseUint(args[1], 10, 64) - if err != nil { - return err - } - reqPriceDenom := args[2] - reqAssetDenom := args[3] - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryGetPriceRequest{ - ContractAddr: reqContractAddr, - PriceDenom: reqPriceDenom, - AssetDenom: reqAssetDenom, - Timestamp: reqTimestamp, - } - - res, err := queryClient.GetPrice(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_get_prices.go b/x/dex/client/cli/query/query_get_prices.go deleted file mode 100644 index 7637379b02..0000000000 --- a/x/dex/client/cli/query/query_get_prices.go +++ /dev/null @@ -1,53 +0,0 @@ -package query - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdGetPrices() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-prices [contract-address] [price-denom] [asset-denom]", - Short: "Query getPrices", - Long: strings.TrimSpace(` - Get all the prices for a pair from a dex specified by the contract-address. The price and asset denom are used to specify the dex pair for which to return the latest price. For the latest price use get-latest-price instead or for a specific timestamp use get-price. - `), - Args: cobra.ExactArgs(3), - RunE: func(cmd *cobra.Command, args []string) (err error) { - reqContractAddr := args[0] - reqPriceDenom := args[1] - reqAssetDenom := args[2] - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryGetPricesRequest{ - ContractAddr: reqContractAddr, - PriceDenom: reqPriceDenom, - AssetDenom: reqAssetDenom, - } - - res, err := queryClient.GetPrices(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_get_twaps.go b/x/dex/client/cli/query/query_get_twaps.go deleted file mode 100644 index 798394b3be..0000000000 --- a/x/dex/client/cli/query/query_get_twaps.go +++ /dev/null @@ -1,53 +0,0 @@ -package query - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdGetTwaps() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-twaps [contract-address] [lookback]", - Short: "Query getPrice", - Long: strings.TrimSpace(` - Get the TWAPs (Time weighted average prices) for all registered dex pairs for a specific orderbook by [contract-address] with a specific lookback duration over which to compute the weighted average. - `), - Args: cobra.ExactArgs(2), - RunE: func(cmd *cobra.Command, args []string) (err error) { - reqContractAddr := args[0] - reqLookback, err := strconv.ParseUint(args[1], 10, 64) - if err != nil { - return err - } - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryGetTwapsRequest{ - ContractAddr: reqContractAddr, - LookbackSeconds: reqLookback, - } - - res, err := queryClient.GetTwaps(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_long_book.go b/x/dex/client/cli/query/query_long_book.go deleted file mode 100644 index bf735d9011..0000000000 --- a/x/dex/client/cli/query/query_long_book.go +++ /dev/null @@ -1,90 +0,0 @@ -package query - -import ( - "context" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -func CmdListLongBook() *cobra.Command { - cmd := &cobra.Command{ - Use: "list-long-book [contract address] [price denom] [asset denom]", - Short: "list all longBook", - Long: strings.TrimSpace(` - Lists all of a long book's information for a given contract address and pair specified by price denom and asset denom. - `), - Args: cobra.ExactArgs(3), - RunE: func(cmd *cobra.Command, args []string) error { - clientCtx := client.GetClientContextFromCmd(cmd) - - pageReq, err := client.ReadPageRequest(cmd.Flags()) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - reqPriceDenom := args[1] - reqAssetDenom := args[2] - - params := &types.QueryAllLongBookRequest{ - Pagination: pageReq, - ContractAddr: args[0], - PriceDenom: reqPriceDenom, - AssetDenom: reqAssetDenom, - } - - res, err := queryClient.LongBookAll(context.Background(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddPaginationFlagsToCmd(cmd, cmd.Use) - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} - -func CmdShowLongBook() *cobra.Command { - cmd := &cobra.Command{ - Use: "show-long-book [contract address] [price] [price denom] [asset denom]", - Short: "shows a longBook", - Long: strings.TrimSpace(` - Gets a long book's information at a specific price for a given contract address and pair specified by price denopm and asset denom. - `), - Args: cobra.ExactArgs(4), - RunE: func(cmd *cobra.Command, args []string) error { - clientCtx := client.GetClientContextFromCmd(cmd) - - queryClient := types.NewQueryClient(clientCtx) - contractAddr := args[0] - reqPriceDenom := args[2] - reqAssetDenom := args[3] - - params := &types.QueryGetLongBookRequest{ - Price: args[1], - ContractAddr: contractAddr, - PriceDenom: reqPriceDenom, - AssetDenom: reqAssetDenom, - } - res, err := queryClient.LongBook(context.Background(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_long_book_test.go b/x/dex/client/cli/query/query_long_book_test.go deleted file mode 100644 index cd878dc7b4..0000000000 --- a/x/dex/client/cli/query/query_long_book_test.go +++ /dev/null @@ -1,176 +0,0 @@ -package query_test - -import ( - "fmt" - "testing" - - "github.com/cosmos/cosmos-sdk/client/flags" - clitestutil "github.com/cosmos/cosmos-sdk/testutil/cli" - "github.com/stretchr/testify/require" - tmcli "github.com/tendermint/tendermint/libs/cli" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/testutil/network" - "github.com/sei-protocol/sei-chain/testutil/nullify" - "github.com/sei-protocol/sei-chain/x/dex/client/cli/query" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func networkWithLongBookObjects(t *testing.T, n int) (*network.Network, []types.LongBook) { - t.Helper() - cfg := network.DefaultConfig() - state := types.GenesisState{} - longBookList := []types.LongBook{} - require.NoError(t, cfg.Codec.UnmarshalJSON(cfg.GenesisState[types.ModuleName], &state)) - - for i := 0; i < n; i++ { - longBook := types.LongBook{ - Price: sdk.NewDec(int64(1 + i)), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(int64(1 + i)), - Quantity: sdk.NewDec(int64(i)), - Allocations: []*types.Allocation{{Account: "abc", Quantity: sdk.NewDec(int64(i)), OrderId: 1}}, - PriceDenom: TEST_PAIR().PriceDenom, - AssetDenom: TEST_PAIR().AssetDenom, - }, - } - nullify.Fill(&longBook) - longBookList = append(longBookList, longBook) - } - - contractInfo := types.ContractInfoV2{ - CodeId: uint64(1), - ContractAddr: "sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc", - } - contractState := []types.ContractState{ - { - LongBookList: longBookList, - ContractInfo: contractInfo, - }, - } - state.ContractState = contractState - buf, err := cfg.Codec.MarshalJSON(&state) - require.NoError(t, err) - cfg.GenesisState[types.ModuleName] = buf - return network.New(t, cfg), state.ContractState[0].LongBookList -} - -func TestShowLongBook(t *testing.T) { - net, objs := networkWithLongBookObjects(t, 2) - - ctx := net.Validators[0].ClientCtx - common := []string{ - fmt.Sprintf("--%s=json", tmcli.OutputFlag), - } - for _, tc := range []struct { - desc string - price string - args []string - err error - obj types.LongBook - }{ - { - desc: "found", - price: objs[1].Entry.Price.String(), - args: common, - obj: objs[1], - }, - { - desc: "not found", - price: "not_found", - args: common, - err: status.Error(codes.InvalidArgument, "not found"), - }, - } { - tc := tc - t.Run(tc.desc, func(t *testing.T) { - // the longbook orders are from genesis contract as created from networkWithLongBookObjects - args := []string{"sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc", tc.price, TEST_PAIR().PriceDenom, TEST_PAIR().AssetDenom} - args = append(args, tc.args...) - out, err := clitestutil.ExecTestCLICmd(ctx, query.CmdShowLongBook(), args) - if tc.err != nil { - stat, ok := status.FromError(tc.err) - require.True(t, ok) - require.ErrorIs(t, stat.Err(), tc.err) - } else { - require.NoError(t, err) - var resp types.QueryGetLongBookResponse - require.NoError(t, net.Config.Codec.UnmarshalJSON(out.Bytes(), &resp)) - require.NotNil(t, resp.LongBook) - require.Equal(t, - nullify.Fill(&tc.obj), - nullify.Fill(&resp.LongBook), - ) - } - }) - } -} - -func TestListLongBook(t *testing.T) { - net, objs := networkWithLongBookObjects(t, 5) - - ctx := net.Validators[0].ClientCtx - request := func(next []byte, offset, limit uint64, total bool) []string { - args := []string{ - "sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc", TEST_PAIR().PriceDenom, TEST_PAIR().AssetDenom, - fmt.Sprintf("--%s=json", tmcli.OutputFlag), - } - if next == nil { - args = append(args, fmt.Sprintf("--%s=%d", flags.FlagOffset, offset)) - } else { - args = append(args, fmt.Sprintf("--%s=%s", flags.FlagPageKey, next)) - } - args = append(args, fmt.Sprintf("--%s=%d", flags.FlagLimit, limit)) - if total { - args = append(args, fmt.Sprintf("--%s", flags.FlagCountTotal)) - } - return args - } - t.Run("ByOffset", func(t *testing.T) { - step := 2 - for i := 0; i < len(objs); i += step { - args := request(nil, uint64(i), uint64(step), false) - out, err := clitestutil.ExecTestCLICmd(ctx, query.CmdListLongBook(), args) - require.NoError(t, err) - var resp types.QueryAllLongBookResponse - require.NoError(t, net.Config.Codec.UnmarshalJSON(out.Bytes(), &resp)) - require.LessOrEqual(t, len(resp.LongBook), step) - require.Subset(t, - nullify.Fill(objs), - nullify.Fill(resp.LongBook), - ) - } - }) - t.Run("ByKey", func(t *testing.T) { - step := 2 - var next []byte - for i := 0; i < len(objs); i += step { - args := request(next, 0, uint64(step), false) - out, err := clitestutil.ExecTestCLICmd(ctx, query.CmdListLongBook(), args) - require.NoError(t, err) - var resp types.QueryAllLongBookResponse - require.NoError(t, net.Config.Codec.UnmarshalJSON(out.Bytes(), &resp)) - require.LessOrEqual(t, len(resp.LongBook), step) - require.Subset(t, - nullify.Fill(objs), - nullify.Fill(resp.LongBook), - ) - next = resp.Pagination.NextKey - } - }) - t.Run("Total", func(t *testing.T) { - args := request(nil, 0, uint64(len(objs)), true) - out, err := clitestutil.ExecTestCLICmd(ctx, query.CmdListLongBook(), args) - require.NoError(t, err) - var resp types.QueryAllLongBookResponse - require.NoError(t, net.Config.Codec.UnmarshalJSON(out.Bytes(), &resp)) - require.NoError(t, err) - require.Equal(t, len(objs), int(resp.Pagination.Total)) - require.ElementsMatch(t, - nullify.Fill(objs), - nullify.Fill(resp.LongBook), - ) - }) -} diff --git a/x/dex/client/cli/query/query_match_result.go b/x/dex/client/cli/query/query_match_result.go deleted file mode 100644 index c1a3fe194b..0000000000 --- a/x/dex/client/cli/query/query_match_result.go +++ /dev/null @@ -1,49 +0,0 @@ -package query - -import ( - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -func CmdGetMatchResult() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-match-result [contract-address]", - Short: "Query get match result by contract", - Long: strings.TrimSpace(` - Gets the match result information for an orderbook specified by the given contract address. The match result information includes the orders, settlements, and cancellations for the orderbook. - `), - Args: cobra.ExactArgs(1), - RunE: func(cmd *cobra.Command, args []string) (err error) { - contractAddr := args[0] - if err != nil { - return err - } - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryGetMatchResultRequest{ - ContractAddr: contractAddr, - } - - res, err := queryClient.GetMatchResult(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_orders.go b/x/dex/client/cli/query/query_orders.go deleted file mode 100644 index 1c054c8b19..0000000000 --- a/x/dex/client/cli/query/query_orders.go +++ /dev/null @@ -1,96 +0,0 @@ -package query - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdGetOrders() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-orders [contract-address] [account]", - Short: "Query get orders for account", - Long: strings.TrimSpace(` - Get all orders for an account and orderbook specified by contract address. - `), - Args: cobra.ExactArgs(2), - RunE: func(cmd *cobra.Command, args []string) (err error) { - reqContractAddr := args[0] - reqAccount := args[1] - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryGetOrdersRequest{ - ContractAddr: reqContractAddr, - Account: reqAccount, - } - - res, err := queryClient.GetOrders(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} - -func CmdGetOrdersByID() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-orders-by-id [contract-address] [price-denom] [asset-denom] [id]", - Short: "Query get order by ID", - Long: strings.TrimSpace(` - Get a specific order by ID for an account and orderbook specified by contract address. - `), - Args: cobra.ExactArgs(4), - RunE: func(cmd *cobra.Command, args []string) (err error) { - contractAddr := args[0] - priceDenom := args[1] - assetDenom := args[2] - orderID, err := strconv.ParseUint(args[3], 10, 64) - if err != nil { - return err - } - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryGetOrderByIDRequest{ - ContractAddr: contractAddr, - PriceDenom: priceDenom, - AssetDenom: assetDenom, - Id: orderID, - } - - res, err := queryClient.GetOrder(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_params.go b/x/dex/client/cli/query/query_params.go deleted file mode 100644 index 0528667404..0000000000 --- a/x/dex/client/cli/query/query_params.go +++ /dev/null @@ -1,34 +0,0 @@ -package query - -import ( - "context" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -func CmdQueryParams() *cobra.Command { - cmd := &cobra.Command{ - Use: "params", - Short: "shows the parameters of the module", - Args: cobra.NoArgs, - RunE: func(cmd *cobra.Command, args []string) error { - clientCtx := client.GetClientContextFromCmd(cmd) - - queryClient := types.NewQueryClient(clientCtx) - - res, err := queryClient.Params(context.Background(), &types.QueryParamsRequest{}) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_registered_contract.go b/x/dex/client/cli/query/query_registered_contract.go deleted file mode 100644 index f779c6fe31..0000000000 --- a/x/dex/client/cli/query/query_registered_contract.go +++ /dev/null @@ -1,48 +0,0 @@ -package query - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdGetRegisteredContract() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-registered-contract [contract address]", - Short: "Query Registered Contract", - Long: strings.TrimSpace(` - List the registered contract information specified by contract address. - `), - Args: cobra.ExactArgs(1), - RunE: func(cmd *cobra.Command, args []string) (err error) { - contractAddr := args[0] - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryRegisteredContractRequest{ - ContractAddr: contractAddr, - } - - res, err := queryClient.GetRegisteredContract(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_registered_pairs.go b/x/dex/client/cli/query/query_registered_pairs.go deleted file mode 100644 index 2b854976cd..0000000000 --- a/x/dex/client/cli/query/query_registered_pairs.go +++ /dev/null @@ -1,48 +0,0 @@ -package query - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdGetRegisteredPairs() *cobra.Command { - cmd := &cobra.Command{ - Use: "get-registered-pairs [contract address]", - Short: "Query Registered Pairs", - Long: strings.TrimSpace(` - List all of the registered pairs for an orderbook specified by contract address. - `), - Args: cobra.ExactArgs(1), - RunE: func(cmd *cobra.Command, args []string) (err error) { - contractAddr := args[0] - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryRegisteredPairsRequest{ - ContractAddr: contractAddr, - } - - res, err := queryClient.GetRegisteredPairs(cmd.Context(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_short_book.go b/x/dex/client/cli/query/query_short_book.go deleted file mode 100644 index b16e477ce7..0000000000 --- a/x/dex/client/cli/query/query_short_book.go +++ /dev/null @@ -1,92 +0,0 @@ -package query - -import ( - "context" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -func CmdListShortBook() *cobra.Command { - cmd := &cobra.Command{ - Use: "list-short-book [contract address] [price denom] [asset denom]", - Short: "list all shortBook", - Long: strings.TrimSpace(` - Lists all of a short book's information for a given contract address and pair specified by price denopm and asset denom. - `), - Args: cobra.ExactArgs(3), - RunE: func(cmd *cobra.Command, args []string) error { - clientCtx := client.GetClientContextFromCmd(cmd) - - pageReq, err := client.ReadPageRequest(cmd.Flags()) - if err != nil { - return err - } - - reqPriceDenom := args[1] - reqAssetDenom := args[2] - - queryClient := types.NewQueryClient(clientCtx) - - params := &types.QueryAllShortBookRequest{ - Pagination: pageReq, - ContractAddr: args[0], - PriceDenom: reqPriceDenom, - AssetDenom: reqAssetDenom, - } - - res, err := queryClient.ShortBookAll(context.Background(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddPaginationFlagsToCmd(cmd, cmd.Use) - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} - -func CmdShowShortBook() *cobra.Command { - cmd := &cobra.Command{ - Use: "show-short-book [contract address] [price] [price denom] [asset denom]", - Short: "shows a shortBook", - Long: strings.TrimSpace(` - Gets a short book's information at a specific price for a given contract address and pair specified by price denopm and asset denom. - `), - Args: cobra.ExactArgs(4), - RunE: func(cmd *cobra.Command, args []string) error { - clientCtx := client.GetClientContextFromCmd(cmd) - - queryClient := types.NewQueryClient(clientCtx) - - contractAddr := args[0] - reqPriceDenom := args[2] - reqAssetDenom := args[3] - - params := &types.QueryGetShortBookRequest{ - Price: args[1], - ContractAddr: contractAddr, - PriceDenom: reqPriceDenom, - AssetDenom: reqAssetDenom, - } - - res, err := queryClient.ShortBook(context.Background(), params) - if err != nil { - return err - } - - return clientCtx.PrintProto(res) - }, - } - - flags.AddQueryFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/query/query_short_book_test.go b/x/dex/client/cli/query/query_short_book_test.go deleted file mode 100644 index 1bfe5bbbb0..0000000000 --- a/x/dex/client/cli/query/query_short_book_test.go +++ /dev/null @@ -1,181 +0,0 @@ -package query_test - -import ( - "fmt" - "testing" - - "github.com/cosmos/cosmos-sdk/client/flags" - clitestutil "github.com/cosmos/cosmos-sdk/testutil/cli" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/testutil/network" - "github.com/sei-protocol/sei-chain/testutil/nullify" - "github.com/sei-protocol/sei-chain/x/dex/client/cli/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" - tmcli "github.com/tendermint/tendermint/libs/cli" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func TEST_PAIR() types.Pair { - return types.Pair{ - PriceDenom: "usdc", - AssetDenom: "atom", - } -} - -func networkWithShortBookObjects(t *testing.T, n int) (*network.Network, []types.ShortBook) { - t.Helper() - cfg := network.DefaultConfig() - state := types.GenesisState{} - shortBookList := []types.ShortBook{} - require.NoError(t, cfg.Codec.UnmarshalJSON(cfg.GenesisState[types.ModuleName], &state)) - - for i := 0; i < n; i++ { - shortBook := types.ShortBook{ - Price: sdk.NewDec(int64(1 + i)), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(int64(1 + i)), - Quantity: sdk.NewDec(int64(i)), - Allocations: []*types.Allocation{{Account: "abc", Quantity: sdk.NewDec(int64(i)), OrderId: 1}}, - PriceDenom: TEST_PAIR().PriceDenom, - AssetDenom: TEST_PAIR().AssetDenom, - }, - } - nullify.Fill(&shortBook) - shortBookList = append(shortBookList, shortBook) - } - - contractInfo := types.ContractInfoV2{ - CodeId: uint64(1), - ContractAddr: "sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc", - } - contractState := []types.ContractState{ - { - ShortBookList: shortBookList, - ContractInfo: contractInfo, - }, - } - state.ContractState = contractState - buf, err := cfg.Codec.MarshalJSON(&state) - require.NoError(t, err) - cfg.GenesisState[types.ModuleName] = buf - return network.New(t, cfg), state.ContractState[0].ShortBookList -} - -func TestShowShortBook(t *testing.T) { - net, objs := networkWithShortBookObjects(t, 2) - - ctx := net.Validators[0].ClientCtx - common := []string{ - fmt.Sprintf("--%s=json", tmcli.OutputFlag), - } - for _, tc := range []struct { - desc string - price string - args []string - err error - obj types.ShortBook - }{ - { - desc: "found", - price: objs[1].Entry.Price.String(), - args: common, - obj: objs[1], - }, - { - desc: "not found", - price: "not_found", - args: common, - err: status.Error(codes.InvalidArgument, "not found"), - }, - } { - tc := tc - t.Run(tc.desc, func(t *testing.T) { - args := []string{"sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc", tc.price, TEST_PAIR().PriceDenom, TEST_PAIR().AssetDenom} - args = append(args, tc.args...) - out, err := clitestutil.ExecTestCLICmd(ctx, query.CmdShowShortBook(), args) - if tc.err != nil { - stat, ok := status.FromError(tc.err) - require.True(t, ok) - require.ErrorIs(t, stat.Err(), tc.err) - } else { - require.NoError(t, err) - var resp types.QueryGetShortBookResponse - require.NoError(t, net.Config.Codec.UnmarshalJSON(out.Bytes(), &resp)) - require.NotNil(t, resp.ShortBook) - require.Equal(t, - nullify.Fill(&tc.obj), - nullify.Fill(&resp.ShortBook), - ) - } - }) - } -} - -func TestListShortBook(t *testing.T) { - net, objs := networkWithShortBookObjects(t, 5) - - ctx := net.Validators[0].ClientCtx - request := func(next []byte, offset, limit uint64, total bool) []string { - args := []string{ - "sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc", TEST_PAIR().PriceDenom, TEST_PAIR().AssetDenom, - fmt.Sprintf("--%s=json", tmcli.OutputFlag), - } - if next == nil { - args = append(args, fmt.Sprintf("--%s=%d", flags.FlagOffset, offset)) - } else { - args = append(args, fmt.Sprintf("--%s=%s", flags.FlagPageKey, next)) - } - args = append(args, fmt.Sprintf("--%s=%d", flags.FlagLimit, limit)) - if total { - args = append(args, fmt.Sprintf("--%s", flags.FlagCountTotal)) - } - return args - } - t.Run("ByOffset", func(t *testing.T) { - step := 2 - for i := 0; i < len(objs); i += step { - args := request(nil, uint64(i), uint64(step), false) - out, err := clitestutil.ExecTestCLICmd(ctx, query.CmdListShortBook(), args) - require.NoError(t, err) - var resp types.QueryAllShortBookResponse - require.NoError(t, net.Config.Codec.UnmarshalJSON(out.Bytes(), &resp)) - require.LessOrEqual(t, len(resp.ShortBook), step) - require.Subset(t, - nullify.Fill(objs), - nullify.Fill(resp.ShortBook), - ) - } - }) - t.Run("ByKey", func(t *testing.T) { - step := 2 - var next []byte - for i := 0; i < len(objs); i += step { - args := request(next, 0, uint64(step), false) - out, err := clitestutil.ExecTestCLICmd(ctx, query.CmdListShortBook(), args) - require.NoError(t, err) - var resp types.QueryAllShortBookResponse - require.NoError(t, net.Config.Codec.UnmarshalJSON(out.Bytes(), &resp)) - require.LessOrEqual(t, len(resp.ShortBook), step) - require.Subset(t, - nullify.Fill(objs), - nullify.Fill(resp.ShortBook), - ) - next = resp.Pagination.NextKey - } - }) - t.Run("Total", func(t *testing.T) { - args := request(nil, 0, uint64(len(objs)), true) - out, err := clitestutil.ExecTestCLICmd(ctx, query.CmdListShortBook(), args) - require.NoError(t, err) - var resp types.QueryAllShortBookResponse - require.NoError(t, net.Config.Codec.UnmarshalJSON(out.Bytes(), &resp)) - require.NoError(t, err) - require.Equal(t, len(objs), int(resp.Pagination.Total)) - require.ElementsMatch(t, - nullify.Fill(objs), - nullify.Fill(resp.ShortBook), - ) - }) -} diff --git a/x/dex/client/cli/tx/gov_tx.go b/x/dex/client/cli/tx/gov_tx.go deleted file mode 100644 index 92e2c018af..0000000000 --- a/x/dex/client/cli/tx/gov_tx.go +++ /dev/null @@ -1,60 +0,0 @@ -package tx - -import ( - "strings" - - "github.com/sei-protocol/sei-chain/x/dex/types" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/cosmos/cosmos-sdk/client/tx" - sdk "github.com/cosmos/cosmos-sdk/types" - govtypes "github.com/cosmos/cosmos-sdk/x/gov/types" - cutils "github.com/sei-protocol/sei-chain/x/dex/client/utils" - - "github.com/spf13/cobra" -) - -// NewAddAssetProposalTxCmd returns a CLI command handler for creating -// a add asset proposal governance transaction. -func NewAddAssetProposalTxCmd() *cobra.Command { - cmd := &cobra.Command{ - Use: "add-asset-proposal [proposal-file]", - Args: cobra.ExactArgs(1), - Short: "Submit an add asset proposal", - Long: strings.TrimSpace(` - Submit a proposal to add a list of assets and corresponding metadata to dex assets. - `), - RunE: func(cmd *cobra.Command, args []string) error { - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - proposal, err := cutils.ParseAddAssetMetadataProposalJSON(clientCtx.LegacyAmino, args[0]) - if err != nil { - return err - } - - // Convert proposal to RegisterPairsProposal Type - from := clientCtx.GetFromAddress() - - content := types.AddAssetMetadataProposal{Title: proposal.Title, Description: proposal.Description, AssetList: proposal.AssetList} - - deposit, err := sdk.ParseCoinsNormalized(proposal.Deposit) - if err != nil { - return err - } - - msg, err := govtypes.NewMsgSubmitProposal(&content, deposit, from) - if err != nil { - return err - } - - return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) - }, - } - - flags.AddTxFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/tx/tx.go b/x/dex/client/cli/tx/tx.go deleted file mode 100644 index 9c7ab93e8a..0000000000 --- a/x/dex/client/cli/tx/tx.go +++ /dev/null @@ -1,40 +0,0 @@ -package tx - -import ( - "fmt" - - "github.com/spf13/cobra" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -//nolint:deadcode,unused // I assume we'll use this later. -const ( - flagPacketTimeoutTimestamp = "packet-timeout-timestamp" - listSeparator = "," -) - -// GetTxCmd returns the transaction commands for this module -func GetTxCmd() *cobra.Command { - cmd := &cobra.Command{ - Use: types.ModuleName, - Short: fmt.Sprintf("%s transactions subcommands", types.ModuleName), - DisableFlagParsing: true, - SuggestionsMinimumDistance: 2, - RunE: client.ValidateCmd, - } - cmd.AddCommand(CmdPlaceOrders()) - cmd.AddCommand(CmdCancelOrders()) - cmd.AddCommand(CmdRegisterContract()) - cmd.AddCommand(CmdRegisterPairs()) - cmd.AddCommand(CmdUnregisterContract()) - cmd.AddCommand(CmdContractDepositRent()) - cmd.AddCommand(CmdUpdatePriceTickSize()) - cmd.AddCommand(CmdUpdateQuantityTickSize()) - cmd.AddCommand(NewAddAssetProposalTxCmd()) - cmd.AddCommand(CmdUnsuspendContract()) - // this line is used by starport scaffolding # 1 - - return cmd -} diff --git a/x/dex/client/cli/tx/tx_cancel_orders.go b/x/dex/client/cli/tx/tx_cancel_orders.go deleted file mode 100644 index 9ba16b5d5a..0000000000 --- a/x/dex/client/cli/tx/tx_cancel_orders.go +++ /dev/null @@ -1,75 +0,0 @@ -package tx - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/cosmos/cosmos-sdk/client/tx" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdCancelOrders() *cobra.Command { - cmd := &cobra.Command{ - Use: "cancel-orders [contract address] [cancellations...]", - Short: "Bulk cancel orders", - Long: strings.TrimSpace(` - Cancel orders placed on an orderbook specified by contract-address. Cancellations are represented as strings with the cancellation details separated by "?". Cancellation details format is OrderID?PositionDirection?Price?PriceDenom?AssetDenom. - - Example: "1234?LONG?1.01?USDC?ATOM" - `), - Args: cobra.MinimumNArgs(2), - RunE: func(cmd *cobra.Command, args []string) (err error) { - argContractAddr := args[0] - if err != nil { - return err - } - cancellations := []*types.Cancellation{} - for _, cancellation := range args[1:] { - newCancel := types.Cancellation{} - cancelDetails := strings.Split(cancellation, "?") - newCancel.Id, err = strconv.ParseUint(cancelDetails[0], 10, 64) - if err != nil { - return err - } - argPositionDir, err := types.GetPositionDirectionFromStr(cancelDetails[1]) - if err != nil { - return err - } - newCancel.PositionDirection = argPositionDir - argPrice, err := sdk.NewDecFromStr(cancelDetails[2]) - if err != nil { - return err - } - newCancel.Price = argPrice - newCancel.PriceDenom = cancelDetails[3] - newCancel.AssetDenom = cancelDetails[4] - cancellations = append(cancellations, &newCancel) - } - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - msg := types.NewMsgCancelOrders( - clientCtx.GetFromAddress().String(), - cancellations, - argContractAddr, - ) - if err := msg.ValidateBasic(); err != nil { - return err - } - return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) - }, - } - - flags.AddTxFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/tx/tx_contract_deposit_rent.go b/x/dex/client/cli/tx/tx_contract_deposit_rent.go deleted file mode 100644 index fd24176eb3..0000000000 --- a/x/dex/client/cli/tx/tx_contract_deposit_rent.go +++ /dev/null @@ -1,52 +0,0 @@ -package tx - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/cosmos/cosmos-sdk/client/tx" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cast" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdContractDepositRent() *cobra.Command { - cmd := &cobra.Command{ - Use: "contract-deposit-rent [contract address] [amount]", - Short: "Contract deposit rent", - Long: strings.TrimSpace(` - Deposit rent for an orderbook specified by contract-address. This rent allows the contract to be executed via dex hooks for calculating order updates and position settlement. - `), - Args: cobra.ExactArgs(2), - RunE: func(cmd *cobra.Command, args []string) (err error) { - argContractAddr := args[0] - argDeposit, err := cast.ToUint64E(args[1]) - if err != nil { - return err - } - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - msg := types.NewMsgContractDepositRent( - argContractAddr, - argDeposit, - clientCtx.GetFromAddress().String(), - ) - if err := msg.ValidateBasic(); err != nil { - return err - } - return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) - }, - } - - flags.AddTxFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/tx/tx_place_orders.go b/x/dex/client/cli/tx/tx_place_orders.go deleted file mode 100644 index 183a0efa21..0000000000 --- a/x/dex/client/cli/tx/tx_place_orders.go +++ /dev/null @@ -1,98 +0,0 @@ -package tx - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/cosmos/cosmos-sdk/client/tx" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -const ( - flagAmount = "amount" -) - -func CmdPlaceOrders() *cobra.Command { - cmd := &cobra.Command{ - Use: "place-orders [contract address] [orders...] --amount [coins,optional]", - Short: "Bulk place orders", - Long: strings.TrimSpace(` - Place orders on an orderbook specified by contract-address. Orders are represented as strings with the order details separated by "?". Cancellation details format is OrderDirection?Quantity?Price?PriceAsset?QuoteAsset?OrderType?OrderData?AdditionalParams. - More info here: https://docs.seinetwork.io/smart-contracts-and-local-development/dex-module-tutorial#placeorders - `), - Args: cobra.MinimumNArgs(2), - RunE: func(cmd *cobra.Command, args []string) (err error) { - argContractAddr := args[0] - orders := []*types.Order{} - for _, order := range args[1:] { - newOrder := types.Order{} - orderDetails := strings.Split(order, "?") - argPositionDir, err := types.GetPositionDirectionFromStr(orderDetails[0]) - if err != nil { - return err - } - newOrder.PositionDirection = argPositionDir - argPrice, err := sdk.NewDecFromStr(orderDetails[1]) - if err != nil { - return err - } - newOrder.Price = argPrice - argQuantity, err := sdk.NewDecFromStr(orderDetails[2]) - if err != nil { - return err - } - newOrder.Quantity = argQuantity - newOrder.PriceDenom = orderDetails[3] - newOrder.AssetDenom = orderDetails[4] - argOrderType, err := types.GetOrderTypeFromStr(orderDetails[5]) - if err != nil { - return err - } - newOrder.OrderType = argOrderType - newOrder.Data = orderDetails[6] - if newOrder.OrderType == types.OrderType_FOKMARKETBYVALUE { - argNominal, err := sdk.NewDecFromStr(orderDetails[7]) - if err != nil { - return err - } - newOrder.Nominal = argNominal - } - orders = append(orders, &newOrder) - } - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - amountStr, err := cmd.Flags().GetString(flagAmount) - if err != nil { - return err - } - - amount, err := sdk.ParseCoinsNormalized(amountStr) - if err != nil { - return err - } - - msg := types.NewMsgPlaceOrders( - clientCtx.GetFromAddress().String(), - orders, - argContractAddr, - amount, - ) - return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) - }, - } - - cmd.Flags().String(flagAmount, "", "Coins to send to the contract along with command") - flags.AddTxFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/tx/tx_register_contract.go b/x/dex/client/cli/tx/tx_register_contract.go deleted file mode 100644 index 312435ab94..0000000000 --- a/x/dex/client/cli/tx/tx_register_contract.go +++ /dev/null @@ -1,68 +0,0 @@ -package tx - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/cosmos/cosmos-sdk/client/tx" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cast" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdRegisterContract() *cobra.Command { - cmd := &cobra.Command{ - Use: "register-contract [contract address] [code id] [(deprecated)] [need order matching] [deposit] [dependency1,dependency2,...]", - Short: "Register exchange contract", - Long: strings.TrimSpace(` - Register a contract with the dex module for order matching hooks. The available order matching functions are BulkOrderPlacements, BulkOrderCancellations, Settlement. A deposit can also be specified as the initial rent to allocate for the execution of the order matching. - Other orderbooks that are dependencies can also be specified so that dex orderbook processing can be performed in the appropriate order. - `), - Args: cobra.MinimumNArgs(5), - RunE: func(cmd *cobra.Command, args []string) (err error) { - argContractAddr := args[0] - argCodeID, err := cast.ToUint64E(args[1]) - if err != nil { - return err - } - argNeedMatching, err := strconv.ParseBool(args[3]) - if err != nil { - return err - } - argDeposit, err := cast.ToUint64E(args[4]) - if err != nil { - return err - } - var dependencies []*types.ContractDependencyInfo - for _, dependency := range args[5:] { - dependencies = append(dependencies, &types.ContractDependencyInfo{Dependency: dependency}) - } - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - msg := types.NewMsgRegisterContract( - clientCtx.GetFromAddress().String(), - argCodeID, - argContractAddr, - argNeedMatching, - dependencies, - argDeposit, - ) - if err := msg.ValidateBasic(); err != nil { - return err - } - return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) - }, - } - - flags.AddTxFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/tx/tx_register_pairs.go b/x/dex/client/cli/tx/tx_register_pairs.go deleted file mode 100644 index 61411c52cc..0000000000 --- a/x/dex/client/cli/tx/tx_register_pairs.go +++ /dev/null @@ -1,54 +0,0 @@ -package tx - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/cosmos/cosmos-sdk/client/tx" - cutils "github.com/sei-protocol/sei-chain/x/dex/client/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdRegisterPairs() *cobra.Command { - cmd := &cobra.Command{ - Use: "register-pairs [register-pairs-file]", - Short: "Register pairs for a contract", - Long: strings.TrimSpace(` - This allows for registering new pairs with a json file representing the various pairs to be registered. The pairs are specified within the file using the contract address for the orderbook along with pair information. - `), - Args: cobra.ExactArgs(1), - RunE: func(cmd *cobra.Command, args []string) (err error) { - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - registerTx, err := cutils.ParseRegisterPairsTxJSON(clientCtx.LegacyAmino, args[0]) - if err != nil { - return err - } - - txBatchContractPair, err := registerTx.BatchContractPair.ToMultipleBatchContractPair() - if err != nil { - return err - } - - msg := types.NewMsgRegisterPairs( - clientCtx.GetFromAddress().String(), - txBatchContractPair, - ) - if err := msg.ValidateBasic(); err != nil { - return err - } - return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) - }, - } - - flags.AddTxFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/tx/tx_unregister_contract.go b/x/dex/client/cli/tx/tx_unregister_contract.go deleted file mode 100644 index 08c1876582..0000000000 --- a/x/dex/client/cli/tx/tx_unregister_contract.go +++ /dev/null @@ -1,46 +0,0 @@ -package tx - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/cosmos/cosmos-sdk/client/tx" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdUnregisterContract() *cobra.Command { - cmd := &cobra.Command{ - Use: "unregister-contract [contract address]", - Short: "Unregister exchange contract", - Long: strings.TrimSpace(` - Unregisters an exchange contract so it no longer receives the execution hooks or order matching hooks. - `), - Args: cobra.ExactArgs(1), - RunE: func(cmd *cobra.Command, args []string) (err error) { - argContractAddr := args[0] - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - msg := types.NewMsgUnregisterContract( - clientCtx.GetFromAddress().String(), - argContractAddr, - ) - if err := msg.ValidateBasic(); err != nil { - return err - } - return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) - }, - } - - flags.AddTxFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/tx/tx_unsuspend_contract.go b/x/dex/client/cli/tx/tx_unsuspend_contract.go deleted file mode 100644 index ce9203ca9f..0000000000 --- a/x/dex/client/cli/tx/tx_unsuspend_contract.go +++ /dev/null @@ -1,46 +0,0 @@ -package tx - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/cosmos/cosmos-sdk/client/tx" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdUnsuspendContract() *cobra.Command { - cmd := &cobra.Command{ - Use: "unsuspend-contract [contract address]", - Short: "Unsuspend exchange contract", - Long: strings.TrimSpace(` - Unsuspend an exchange contract which was suspended due to Sudo malfunctioning, at a cost to its rent. - `), - Args: cobra.ExactArgs(1), - RunE: func(cmd *cobra.Command, args []string) (err error) { - argContractAddr := args[0] - - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - - msg := types.NewMsgUnsuspendContract( - clientCtx.GetFromAddress().String(), - argContractAddr, - ) - if err := msg.ValidateBasic(); err != nil { - return err - } - return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) - }, - } - - flags.AddTxFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/tx/tx_update_price_tick_size.go b/x/dex/client/cli/tx/tx_update_price_tick_size.go deleted file mode 100644 index 44dfedfe84..0000000000 --- a/x/dex/client/cli/tx/tx_update_price_tick_size.go +++ /dev/null @@ -1,54 +0,0 @@ -package tx - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/cosmos/cosmos-sdk/client/tx" - cutils "github.com/sei-protocol/sei-chain/x/dex/client/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdUpdatePriceTickSize() *cobra.Command { - cmd := &cobra.Command{ - Use: "update-price-tick-size [update-price-tick-size-file]", - Short: "Update price tick size for a market", - Long: strings.TrimSpace(` - Updates the price tick size for a specific pair for an orderbook specified by contract address. The file contains a list of pair info, new tick size, and contract addresses to allow for updating multiple tick sizes in one transaction. - `), - Args: cobra.ExactArgs(1), - RunE: func(cmd *cobra.Command, args []string) (err error) { - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - tickTx, err := cutils.ParseUpdateTickSizeTxJSON(clientCtx.LegacyAmino, args[0]) - if err != nil { - return err - } - - txTick, err := tickTx.TickSizes.ToTickSizes() - if err != nil { - return err - } - - msg := types.NewMsgUpdatePriceTickSize( - clientCtx.GetFromAddress().String(), - txTick, - ) - if err := msg.ValidateBasic(); err != nil { - return err - } - return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) - }, - } - - flags.AddTxFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/cli/tx/tx_update_quantity_tick_size.go b/x/dex/client/cli/tx/tx_update_quantity_tick_size.go deleted file mode 100644 index 5e46f50a07..0000000000 --- a/x/dex/client/cli/tx/tx_update_quantity_tick_size.go +++ /dev/null @@ -1,54 +0,0 @@ -package tx - -import ( - "strconv" - "strings" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/client/flags" - "github.com/cosmos/cosmos-sdk/client/tx" - cutils "github.com/sei-protocol/sei-chain/x/dex/client/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/spf13/cobra" -) - -var _ = strconv.Itoa(0) - -func CmdUpdateQuantityTickSize() *cobra.Command { - cmd := &cobra.Command{ - Use: "update-quantity-tick-size [update-quantity-tick-size-file]", - Short: "Update quantity tick size for a market", - Long: strings.TrimSpace(` - Updates the quantity tick size for a specific pair for an orderbook specified by contract address. The file contains a list of pair info, new tick size, and contract addresses to allow for updating multiple tick sizes in one transaction. - `), - Args: cobra.ExactArgs(1), - RunE: func(cmd *cobra.Command, args []string) (err error) { - clientCtx, err := client.GetClientTxContext(cmd) - if err != nil { - return err - } - tickTx, err := cutils.ParseUpdateTickSizeTxJSON(clientCtx.LegacyAmino, args[0]) - if err != nil { - return err - } - - txTick, err := tickTx.TickSizes.ToTickSizes() - if err != nil { - return err - } - - msg := types.NewMsgUpdateQuantityTickSize( - clientCtx.GetFromAddress().String(), - txTick, - ) - if err := msg.ValidateBasic(); err != nil { - return err - } - return tx.GenerateOrBroadcastTxCLI(clientCtx, cmd.Flags(), msg) - }, - } - - flags.AddTxFlagsToCmd(cmd) - - return cmd -} diff --git a/x/dex/client/utils/utils.go b/x/dex/client/utils/utils.go deleted file mode 100644 index a151b652c1..0000000000 --- a/x/dex/client/utils/utils.go +++ /dev/null @@ -1,203 +0,0 @@ -package utils - -import ( - "errors" - "os" - - "github.com/cosmos/cosmos-sdk/codec" - sdk "github.com/cosmos/cosmos-sdk/types" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" -) - -type ( - PairJSON struct { - PriceDenom string `json:"price_denom" yaml:"price_denom"` - AssetDenom string `json:"asset_denom" yaml:"asset_denom"` - PriceTickSize string `json:"price_tick_size" yaml:"tick_size"` - QuantityTickSize string `json:"quantity_tick_size" yaml:"tick_size"` - } - - TickSizeJSON struct { - Pair PairJSON `json:"pair" yaml:"pair"` - TickSize sdk.Dec `json:"tick_size" yaml:"tick_size"` - ContractAddr string `json:"contract_addr" yaml:"contract_addr"` - } - - PairsJSON []PairJSON - TickSizesJSON []TickSizeJSON - AssetListJSON []dextypes.AssetMetadata - - // ParamChangeJSON defines a parameter change used in JSON input. This - // allows values to be specified in raw JSON instead of being string encoded. - BatchContractPairJSON struct { - ContractAddr string `json:"contract_addr" yaml:"contract_addr"` - Pairs PairsJSON `json:"pairs" yaml:"pairs"` - } - - MultipleBatchContractPairJSON []BatchContractPairJSON - - // RegisterPairsTxJSON defines a RegisterPairsTx - // to parse register pair tx's from a JSON file. - RegisterPairsTxJSON struct { - BatchContractPair MultipleBatchContractPairJSON `json:"batch_contract_pair" yaml:"batch_contract_pair"` - } - - UpdateTickSizeTxJSON struct { - TickSizes TickSizesJSON `json:"tick_size_list" yaml:"tick_size_list"` - } - - AddAssetMetadataProposalJSON struct { - Title string `json:"title" yaml:"title"` - Description string `json:"description" yaml:"description"` - AssetList AssetListJSON `json:"asset_list" yaml:"asset_list"` - Deposit string `json:"deposit" yaml:"deposit"` - } -) - -// TODO: ADD utils to convert Each type to dex/type (string to denom) -func NewPair(pair PairJSON) (dextypes.Pair, error) { - PriceDenom := pair.PriceDenom - AssetDenom := pair.AssetDenom - priceTicksize, err := sdk.NewDecFromStr(pair.PriceTickSize) - if err != nil { - return dextypes.Pair{}, errors.New("price ticksize: str to decimal conversion err") - } - if priceTicksize.LTE(sdk.ZeroDec()) { - return dextypes.Pair{}, errors.New("price ticksize: value cannot be zero or negative") - } - quantityTicksize, err := sdk.NewDecFromStr(pair.QuantityTickSize) - if err != nil { - return dextypes.Pair{}, errors.New("quantity ticksize: str to decimal conversion err") - } - if quantityTicksize.LTE(sdk.ZeroDec()) { - return dextypes.Pair{}, errors.New("quantity ticksize: value cannot be zero or negative") - } - return dextypes.Pair{PriceDenom: PriceDenom, AssetDenom: AssetDenom, PriceTicksize: &priceTicksize, QuantityTicksize: &quantityTicksize}, nil -} - -// ToParamChange converts a ParamChangeJSON object to ParamChange. -func (bcp BatchContractPairJSON) ToBatchContractPair() (dextypes.BatchContractPair, error) { - pairs := make([]*dextypes.Pair, len(bcp.Pairs)) - for i, p := range bcp.Pairs { - newPair, err := NewPair(p) - if err != nil { - return dextypes.BatchContractPair{}, nil - } - pairs[i] = &newPair - } - return dextypes.BatchContractPair{ContractAddr: bcp.ContractAddr, Pairs: pairs}, nil -} - -func (ts TickSizeJSON) ToTickSize() (dextypes.TickSize, error) { - // validate the tick size here - pair, err := NewPair(ts.Pair) - if err != nil { - return dextypes.TickSize{}, err - } - return dextypes.TickSize{ - Pair: &pair, - Ticksize: ts.TickSize, - ContractAddr: ts.ContractAddr, - }, nil -} - -// ToParamChanges converts a slice of ParamChangeJSON objects to a slice of -// ParamChange. -func (mbcp MultipleBatchContractPairJSON) ToMultipleBatchContractPair() ([]dextypes.BatchContractPair, error) { - res := make([]dextypes.BatchContractPair, len(mbcp)) - for i, bcp := range mbcp { - newBatch, err := bcp.ToBatchContractPair() - if err != nil { - return res, nil - } - res[i] = newBatch - } - return res, nil -} - -func (tss TickSizesJSON) ToTickSizes() ([]dextypes.TickSize, error) { - res := make([]dextypes.TickSize, len(tss)) - for i, ts := range tss { - ticksize, err := ts.ToTickSize() - if err != nil { - return res, nil - } - res[i] = ticksize - } - return res, nil -} - -// ParseRegisterPairsTxJSON reads and parses a RegisterPairsTxJSON from -// a file. -func ParseRegisterPairsTxJSON(cdc *codec.LegacyAmino, txFile string) (RegisterPairsTxJSON, error) { - registerTx := RegisterPairsTxJSON{} - - contents, err := os.ReadFile(txFile) - if err != nil { - return registerTx, err - } - - if err := cdc.UnmarshalJSON(contents, ®isterTx); err != nil { - return registerTx, err - } - - return registerTx, nil -} - -// ParseUpdateTickSizeTxJSON reads and parses a UpdateTickSizeTxJSON from -// a file. -func ParseUpdateTickSizeTxJSON(cdc *codec.LegacyAmino, txFile string) (UpdateTickSizeTxJSON, error) { - tickTx := UpdateTickSizeTxJSON{} - - contents, err := os.ReadFile(txFile) - if err != nil { - return tickTx, err - } - - if err := cdc.UnmarshalJSON(contents, &tickTx); err != nil { - return tickTx, err - } - - return tickTx, nil -} - -// ParseAddAssetMetadataProposalJSON reads and parses an AddAssetMetadataProposalJSON from -// a file. -func ParseAddAssetMetadataProposalJSON(cdc *codec.LegacyAmino, proposalFile string) (AddAssetMetadataProposalJSON, error) { - proposal := AddAssetMetadataProposalJSON{} - - contents, err := os.ReadFile(proposalFile) - if err != nil { - return proposal, err - } - - if err := cdc.UnmarshalJSON(contents, &proposal); err != nil { - return proposal, err - } - - // Verify base denoms specified in proposal are well formed - // Additionally verify that the asset "display" field is included in denom unit - for _, asset := range proposal.AssetList { - err := sdk.ValidateDenom(asset.Metadata.Base) - if err != nil { - return AddAssetMetadataProposalJSON{}, err - } - - // The display denom must have an associated DenomUnit field - display := asset.Metadata.Display - found := false - for _, denomUnit := range asset.Metadata.DenomUnits { - if denomUnit.Denom == display { - found = true - break - } - } - - if !found { - return AddAssetMetadataProposalJSON{}, errors.New("Display denom " + display + " has no associated DenomUnit in Metadata.") - } - - } - - return proposal, nil -} diff --git a/x/dex/client/wasm/bindings/queries.go b/x/dex/client/wasm/bindings/queries.go deleted file mode 100644 index 12fbe2a100..0000000000 --- a/x/dex/client/wasm/bindings/queries.go +++ /dev/null @@ -1,12 +0,0 @@ -package bindings - -import "github.com/sei-protocol/sei-chain/x/dex/types" - -type SeiDexQuery struct { - // queries the dex TWAPs - DexTwaps *types.QueryGetTwapsRequest `json:"dex_twaps,omitempty"` - GetOrders *types.QueryGetOrdersRequest `json:"get_orders,omitempty"` - GetOrderByID *types.QueryGetOrderByIDRequest `json:"get_order_by_id,omitempty"` - GetOrderSimulation *types.QueryOrderSimulationRequest `json:"order_simulation,omitempty"` - GetLatestPrice *types.QueryGetLatestPriceRequest `json:"get_latest_price,omitempty"` -} diff --git a/x/dex/client/wasm/encoder.go b/x/dex/client/wasm/encoder.go deleted file mode 100644 index 0a56156a4e..0000000000 --- a/x/dex/client/wasm/encoder.go +++ /dev/null @@ -1,36 +0,0 @@ -package wasm - -import ( - "encoding/json" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/wasmbinding/bindings" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func EncodeDexPlaceOrders(rawMsg json.RawMessage, sender sdk.AccAddress) ([]sdk.Msg, error) { - encodedPlaceOrdersMsg := bindings.PlaceOrders{} - if err := json.Unmarshal(rawMsg, &encodedPlaceOrdersMsg); err != nil { - return []sdk.Msg{}, types.ErrEncodeDexPlaceOrders - } - placeOrdersMsg := types.MsgPlaceOrders{ - Creator: sender.String(), - Orders: encodedPlaceOrdersMsg.Orders, - ContractAddr: encodedPlaceOrdersMsg.ContractAddr, - Funds: encodedPlaceOrdersMsg.Funds, - } - return []sdk.Msg{&placeOrdersMsg}, nil -} - -func EncodeDexCancelOrders(rawMsg json.RawMessage, sender sdk.AccAddress) ([]sdk.Msg, error) { - encodedCancelOrdersMsg := bindings.CancelOrders{} - if err := json.Unmarshal(rawMsg, &encodedCancelOrdersMsg); err != nil { - return []sdk.Msg{}, types.ErrEncodeDexCancelOrders - } - cancelOrdersMsg := types.MsgCancelOrders{ - Creator: sender.String(), - Cancellations: encodedCancelOrdersMsg.Cancellations, - ContractAddr: encodedCancelOrdersMsg.ContractAddr, - } - return []sdk.Msg{&cancelOrdersMsg}, nil -} diff --git a/x/dex/client/wasm/query.go b/x/dex/client/wasm/query.go deleted file mode 100644 index 41f86f1623..0000000000 --- a/x/dex/client/wasm/query.go +++ /dev/null @@ -1,48 +0,0 @@ -package wasm - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -type DexWasmQueryHandler struct { - dexKeeper keeper.Keeper -} - -func NewDexWasmQueryHandler(keeper *keeper.Keeper) *DexWasmQueryHandler { - return &DexWasmQueryHandler{ - dexKeeper: *keeper, - } -} - -func (handler DexWasmQueryHandler) GetDexTwap(ctx sdk.Context, req *types.QueryGetTwapsRequest) (*types.QueryGetTwapsResponse, error) { - c := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: &handler.dexKeeper} - return wrapper.GetTwaps(c, req) -} - -func (handler DexWasmQueryHandler) GetOrders(ctx sdk.Context, req *types.QueryGetOrdersRequest) (*types.QueryGetOrdersResponse, error) { - c := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: &handler.dexKeeper} - return wrapper.GetOrders(c, req) -} - -func (handler DexWasmQueryHandler) GetOrderByID(ctx sdk.Context, req *types.QueryGetOrderByIDRequest) (*types.QueryGetOrderByIDResponse, error) { - c := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: &handler.dexKeeper} - return wrapper.GetOrder(c, req) -} - -func (handler DexWasmQueryHandler) GetOrderSimulation(ctx sdk.Context, req *types.QueryOrderSimulationRequest) (*types.QueryOrderSimulationResponse, error) { - c := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: &handler.dexKeeper} - return wrapper.GetOrderSimulation(c, req) -} - -func (handler DexWasmQueryHandler) GetLatestPrice(ctx sdk.Context, req *types.QueryGetLatestPriceRequest) (*types.QueryGetLatestPriceResponse, error) { - c := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: &handler.dexKeeper} - return wrapper.GetLatestPrice(c, req) -} diff --git a/x/dex/contract/abci.go b/x/dex/contract/abci.go deleted file mode 100644 index 712c01c67c..0000000000 --- a/x/dex/contract/abci.go +++ /dev/null @@ -1,323 +0,0 @@ -package contract - -import ( - "context" - "errors" - "fmt" - "sync" - "time" - - "github.com/cosmos/cosmos-sdk/telemetry" - "github.com/cosmos/cosmos-sdk/utils/tracing" - "github.com/sei-protocol/sei-chain/utils/logging" - - sdk "github.com/cosmos/cosmos-sdk/types" - authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - bankkeeper "github.com/cosmos/cosmos-sdk/x/bank/keeper" - "github.com/sei-protocol/sei-chain/store/whitelist/multi" - seisync "github.com/sei-protocol/sei-chain/sync" - "github.com/sei-protocol/sei-chain/utils/datastructures" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - dexkeeperabci "github.com/sei-protocol/sei-chain/x/dex/keeper/abci" - dexkeeperutils "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/sei-protocol/sei-chain/x/store" - otrace "go.opentelemetry.io/otel/trace" -) - -const LogRunnerRunAfter = 10 * time.Second -const LogExecSigSendAfter = 2 * time.Second - -type environment struct { - validContractsInfo []types.ContractInfoV2 - failedContractAddressesToErrors *datastructures.TypedSyncMap[string, error] - outOfRentContractAddresses datastructures.SyncSet[string] - settlementsByContract *datastructures.TypedSyncMap[string, []*types.SettlementEntry] - executionTerminationSignals *datastructures.TypedSyncMap[string, chan struct{}] - registeredPairs *datastructures.TypedSyncMap[string, []types.Pair] - orderBooks *datastructures.TypedNestedSyncMap[string, types.PairString, *types.OrderBook] - - finalizeMsgMutex *sync.Mutex - eventManagerMutex *sync.Mutex -} - -func EndBlockerAtomic(ctx sdk.Context, keeper *keeper.Keeper, validContractsInfo []types.ContractInfoV2, tracingInfo *tracing.Info) ([]types.ContractInfoV2, []types.ContractInfoV2, map[string]string, sdk.Context, bool) { - tracer := tracingInfo.Tracer - spanCtx, span := tracingInfo.Start("DexEndBlockerAtomic") - defer span.End() - defer telemetry.MeasureSince(time.Now(), "dex", "end_blocker_atomic") - - env := newEnv(ctx, validContractsInfo, keeper) - cachedCtx, msCached := cacheContext(ctx, env) - memStateCopy := dexutils.GetMemState(cachedCtx.Context()).DeepCopy() - contractsToProcess := memStateCopy.GetContractToProcessOrderedSlice(cachedCtx) - preRunRents := keeper.GetRentsForContracts(cachedCtx, contractsToProcess) - - handleDeposits(spanCtx, cachedCtx, env, keeper, tracer) - - runner := NewParallelRunner(func(contract types.ContractInfoV2) { - OrderMatchingRunnable(spanCtx, cachedCtx, env, keeper, contract, tracer) - }, validContractsInfo, cachedCtx) - - _, err := logging.LogIfNotDoneAfter(ctx.Logger(), func() (struct{}, error) { - runner.Run() - return struct{}{}, nil - }, LogRunnerRunAfter, "runner run") - if err != nil { - // this should never happen - panic(err) - } - - handleSettlements(spanCtx, cachedCtx, env, keeper, tracer) - handleUnfulfilledMarketOrders(spanCtx, cachedCtx, env, keeper, tracer) - - telemetry.IncrCounter(float32(env.failedContractAddressesToErrors.Len()), "dex", "total_failed_contracts") - // No error is thrown for any contract. This should happen most of the time. - if env.failedContractAddressesToErrors.Len() == 0 { - postRunRents := keeper.GetRentsForContracts(cachedCtx, contractsToProcess) - TransferRentFromDexToCollector(cachedCtx, keeper.BankKeeper, preRunRents, postRunRents) - msCached.Write() - return env.validContractsInfo, []types.ContractInfoV2{}, map[string]string{}, ctx, true - } - - failedContractsToReasons := map[string]string{} - failedContractsPreRents := map[string]uint64{} - failedContractsPostRents := map[string]uint64{} - // persistent contract rent charges for failed contracts and discard everything else - env.failedContractAddressesToErrors.Range(func(failedContractAddress string, failedReason error) bool { - cachedContract, err := keeper.GetContract(cachedCtx, failedContractAddress) - if err != nil { - ctx.Logger().Error(fmt.Sprintf("error %s when getting updated contract %s to persist rent balance", err, failedContractAddress)) - return true - } - contract, err := keeper.GetContract(ctx, failedContractAddress) - if err != nil { - ctx.Logger().Error(fmt.Sprintf("error %s when getting contract %s to persist rent balance", err, failedContractAddress)) - return true - } - contract.RentBalance = cachedContract.RentBalance - failedContractsPreRents[failedContractAddress] = preRunRents[failedContractAddress] - failedContractsPostRents[failedContractAddress] = contract.RentBalance - err = keeper.SetContract(ctx, &contract) - if err != nil { - ctx.Logger().Error(fmt.Sprintf("error %s when persisting contract %s's rent balance", err, failedContractAddress)) - return true - } - failedContractsToReasons[failedContractAddress] = dexutils.GetTruncatedErrors(failedReason) - return true - }) - TransferRentFromDexToCollector(ctx, keeper.BankKeeper, failedContractsPreRents, failedContractsPostRents) - - // restore keeper in-memory state - newGoContext := context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, memStateCopy) - return filterNewValidContracts(ctx, env), getOutOfRentContracts(env), failedContractsToReasons, ctx.WithContext(newGoContext), false -} - -func newEnv(ctx sdk.Context, validContractsInfo []types.ContractInfoV2, keeper *keeper.Keeper) *environment { - settlementsByContract := datastructures.NewTypedSyncMap[string, []*types.SettlementEntry]() - executionTerminationSignals := datastructures.NewTypedSyncMap[string, chan struct{}]() - registeredPairs := datastructures.NewTypedSyncMap[string, []types.Pair]() - allContractAndPairs := map[string][]types.Pair{} - for _, contract := range validContractsInfo { - settlementsByContract.Store(contract.ContractAddr, []*types.SettlementEntry{}) - executionTerminationSignals.Store(contract.ContractAddr, make(chan struct{}, 1)) - contractPairs := keeper.GetAllRegisteredPairs(ctx, contract.ContractAddr) - registeredPairs.Store(contract.ContractAddr, contractPairs) - allContractAndPairs[contract.ContractAddr] = contractPairs - } - // Parallelize populating orderbooks for performance improvements - orderBooks := dexkeeperutils.PopulateAllOrderbooks(ctx, keeper, allContractAndPairs) - return &environment{ - validContractsInfo: validContractsInfo, - failedContractAddressesToErrors: datastructures.NewTypedSyncMap[string, error](), - outOfRentContractAddresses: datastructures.NewSyncSet([]string{}), - settlementsByContract: settlementsByContract, - executionTerminationSignals: executionTerminationSignals, - registeredPairs: registeredPairs, - orderBooks: orderBooks, - finalizeMsgMutex: &sync.Mutex{}, - eventManagerMutex: &sync.Mutex{}, - } -} - -func (e *environment) addError(contractAddr string, err error) { - if err == types.ErrInsufficientRent { - e.outOfRentContractAddresses.Add(contractAddr) - return - } - e.failedContractAddressesToErrors.Store(contractAddr, err) -} - -func cacheContext(ctx sdk.Context, env *environment) (sdk.Context, sdk.CacheMultiStore) { - cachedCtx, msCached := store.GetCachedContext(ctx) - goCtx := context.WithValue(cachedCtx.Context(), dexcache.CtxKeyExecTermSignal, env.executionTerminationSignals) - cachedCtx = cachedCtx.WithContext(goCtx) - return cachedCtx, msCached -} - -func decorateContextForContract(ctx sdk.Context, contractInfo types.ContractInfoV2) sdk.Context { - goCtx := context.WithValue(ctx.Context(), dexcache.CtxKeyExecutingContract, contractInfo) - whitelistedStore := multi.NewStore(ctx.MultiStore(), GetWhitelistMap(contractInfo.ContractAddr)) - newEventManager := sdk.NewEventManager() - return ctx.WithContext(goCtx).WithMultiStore(whitelistedStore).WithEventManager(newEventManager).WithGasMeter( - seisync.NewGasWrapper(sdk.NewInfiniteGasMeterWithMultiplier(ctx)), - ) -} - -func handleDeposits(spanCtx context.Context, ctx sdk.Context, env *environment, keeper *keeper.Keeper, tracer *otrace.Tracer) { - // Handle deposit sequentially since they mutate `bank` state which is shared by all contracts - _, span := (*tracer).Start(spanCtx, "handleDeposits") - defer span.End() - defer telemetry.MeasureSince(time.Now(), "dex", "handle_deposits") - keeperWrapper := dexkeeperabci.KeeperWrapper{Keeper: keeper} - for _, contract := range env.validContractsInfo { - if !dexutils.GetMemState(ctx.Context()).ContractsToProcessContains(ctx, contract.ContractAddr) { - continue - } - if !contract.NeedOrderMatching { - continue - } - if err := keeperWrapper.HandleEBDeposit(spanCtx, ctx, tracer, contract.ContractAddr); err != nil { - env.addError(contract.ContractAddr, err) - } - } -} - -func handleSettlements(ctx context.Context, sdkCtx sdk.Context, env *environment, keeper *keeper.Keeper, tracer *otrace.Tracer) { - _, span := (*tracer).Start(ctx, "DexEndBlockerHandleSettlements") - defer span.End() - defer telemetry.MeasureSince(time.Now(), "dex", "handle_settlements") - contractsNeedOrderMatching := datastructures.NewSyncSet([]string{}) - for _, contract := range env.validContractsInfo { - if contract.NeedOrderMatching { - contractsNeedOrderMatching.Add(contract.ContractAddr) - } - } - env.settlementsByContract.Range(func(contractAddr string, settlements []*types.SettlementEntry) bool { - if !contractsNeedOrderMatching.Contains(contractAddr) { - return true - } - if err := HandleSettlements(sdkCtx, contractAddr, keeper, settlements); err != nil { - sdkCtx.Logger().Error(fmt.Sprintf("Error handling settlements for %s", contractAddr)) - env.addError(contractAddr, err) - } - return true - }) -} - -func handleUnfulfilledMarketOrders(ctx context.Context, sdkCtx sdk.Context, env *environment, keeper *keeper.Keeper, tracer *otrace.Tracer) { - // Cancel unfilled market orders - defer telemetry.MeasureSince(time.Now(), "dex", "handle_unfulfilled_market_orders") - for _, contract := range env.validContractsInfo { - if !dexutils.GetMemState(sdkCtx.Context()).ContractsToProcessContains(sdkCtx, contract.ContractAddr) { - return - } - if contract.NeedOrderMatching { - registeredPairs, found := env.registeredPairs.Load(contract.ContractAddr) - if !found { - continue - } - if err := CancelUnfulfilledMarketOrders(ctx, sdkCtx, contract.ContractAddr, keeper, registeredPairs, tracer); err != nil { - sdkCtx.Logger().Error(fmt.Sprintf("Error cancelling unfulfilled market orders for %s", contract.ContractAddr)) - env.addError(contract.ContractAddr, err) - } - } - } -} - -func OrderMatchingRunnable(ctx context.Context, sdkContext sdk.Context, env *environment, keeper *keeper.Keeper, contractInfo types.ContractInfoV2, tracer *otrace.Tracer) { - defer func() { - if err := recover(); err != nil { - telemetry.IncrCounter(1, "recovered_panics") - msg := fmt.Sprintf("PANIC RECOVERED during order matching: %s", err) - sdkContext.Logger().Error(msg) - if env != nil { - env.addError(contractInfo.ContractAddr, errors.New(msg)) - } - } - }() - _, span := (*tracer).Start(ctx, "OrderMatchingRunnable") - defer span.End() - defer telemetry.MeasureSince(time.Now(), "dex", "order_matching_runnable") - defer func() { - if channel, ok := env.executionTerminationSignals.Load(contractInfo.ContractAddr); ok { - _, err := logging.LogIfNotDoneAfter(sdkContext.Logger(), func() (struct{}, error) { - channel <- struct{}{} - return struct{}{}, nil - }, LogExecSigSendAfter, fmt.Sprintf("send execution terminal signal for %s", contractInfo.ContractAddr)) - if err != nil { - // this should never happen - panic(err) - } - } - }() - if !dexutils.GetMemState(sdkContext.Context()).ContractsToProcessContains(sdkContext, contractInfo.ContractAddr) { - return - } - if !contractInfo.NeedOrderMatching { - return - } - parentSdkContext := sdkContext - sdkContext = decorateContextForContract(sdkContext, contractInfo) - sdkContext.Logger().Debug(fmt.Sprintf("End block for %s with balance of %d", contractInfo.ContractAddr, contractInfo.RentBalance)) - pairs, pairFound := env.registeredPairs.Load(contractInfo.ContractAddr) - orderBooks, found := env.orderBooks.Load(contractInfo.ContractAddr) - - if !pairFound || !found { - sdkContext.Logger().Error(fmt.Sprintf("No pair or order book for %s", contractInfo.ContractAddr)) - env.addError(contractInfo.ContractAddr, errors.New("no pair found (internal error)")) - } else if settlements, err := HandleExecutionForContract(ctx, sdkContext, contractInfo, keeper, pairs, orderBooks, tracer); err != nil { - sdkContext.Logger().Error(fmt.Sprintf("Error for EndBlock of %s", contractInfo.ContractAddr)) - env.addError(contractInfo.ContractAddr, err) - } else { - env.settlementsByContract.Store(contractInfo.ContractAddr, settlements) - } - - // ordering of events doesn't matter since events aren't part of consensus - env.eventManagerMutex.Lock() - defer env.eventManagerMutex.Unlock() - parentSdkContext.EventManager().EmitEvents(sdkContext.EventManager().Events()) -} - -func filterNewValidContracts(ctx sdk.Context, env *environment) []types.ContractInfoV2 { - newValidContracts := []types.ContractInfoV2{} - for _, contract := range env.validContractsInfo { - if _, ok := env.failedContractAddressesToErrors.Load(contract.ContractAddr); !ok && !env.outOfRentContractAddresses.Contains(contract.ContractAddr) { - newValidContracts = append(newValidContracts, contract) - } - } - env.failedContractAddressesToErrors.Range(func(failedContractAddress string, _ error) bool { - dexutils.GetMemState(ctx.Context()).DeepFilterAccount(ctx, failedContractAddress) - return true - }) - for _, outOfRentContractAddress := range env.outOfRentContractAddresses.ToOrderedSlice(datastructures.StringComparator) { - dexutils.GetMemState(ctx.Context()).DeepFilterAccount(ctx, outOfRentContractAddress) - } - return newValidContracts -} - -func getOutOfRentContracts(env *environment) []types.ContractInfoV2 { - outOfRentContracts := []types.ContractInfoV2{} - for _, contract := range env.validContractsInfo { - if env.outOfRentContractAddresses.Contains(contract.ContractAddr) { - outOfRentContracts = append(outOfRentContracts, contract) - } - } - return outOfRentContracts -} - -func TransferRentFromDexToCollector(ctx sdk.Context, bankKeeper bankkeeper.Keeper, preRents map[string]uint64, postRents map[string]uint64) { - total := uint64(0) - for addr, preRent := range preRents { - if postRent, ok := postRents[addr]; ok { - total += preRent - postRent - } else { - total += preRent - } - } - if err := bankKeeper.SendCoinsFromModuleToModule(ctx, types.ModuleName, authtypes.FeeCollectorName, sdk.NewCoins(sdk.NewCoin("usei", sdk.NewIntFromUint64(total)))); err != nil { - ctx.Logger().Error("sending coins from dex to fee collector failed due to %s", err) - } -} diff --git a/x/dex/contract/abci_test.go b/x/dex/contract/abci_test.go deleted file mode 100644 index 3d0b7650b4..0000000000 --- a/x/dex/contract/abci_test.go +++ /dev/null @@ -1,43 +0,0 @@ -package contract_test - -import ( - "context" - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/contract" - "github.com/sei-protocol/sei-chain/x/dex/types" - minttypes "github.com/sei-protocol/sei-chain/x/mint/types" - "github.com/stretchr/testify/require" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -func TestTransferRentFromDexToCollector(t *testing.T) { - preRents := map[string]uint64{"abc": 100, "def": 50} - postRents := map[string]uint64{"abc": 70} - - // expected total is (100 - 70) + 50 = 80 - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - bankkeeper := testApp.BankKeeper - err := bankkeeper.MintCoins(ctx, minttypes.ModuleName, sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(100)))) - require.Nil(t, err) - err = bankkeeper.SendCoinsFromModuleToModule(ctx, minttypes.ModuleName, types.ModuleName, sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(100)))) - require.Nil(t, err) - contract.TransferRentFromDexToCollector(ctx, bankkeeper, preRents, postRents) - dexBalance := bankkeeper.GetBalance(ctx, testApp.AccountKeeper.GetModuleAddress(types.ModuleName), "usei") - require.Equal(t, int64(20), dexBalance.Amount.Int64()) - collectorBalance := bankkeeper.GetBalance(ctx, testApp.AccountKeeper.GetModuleAddress(authtypes.FeeCollectorName), "usei") - require.Equal(t, int64(80), collectorBalance.Amount.Int64()) -} - -func TestOrderMatchingRunnablePanicHandler(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - require.NotPanics(t, func() { - contract.OrderMatchingRunnable(context.Background(), ctx, nil, nil, types.ContractInfoV2{}, nil) - }) -} diff --git a/x/dex/contract/dag.go b/x/dex/contract/dag.go deleted file mode 100644 index 761a9d7c2d..0000000000 --- a/x/dex/contract/dag.go +++ /dev/null @@ -1,78 +0,0 @@ -package contract - -import ( - "github.com/sei-protocol/sei-chain/utils/datastructures" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -type node struct { - contractAddr string - incomingNodes *datastructures.SyncSet[string] -} - -// Kahn's algorithm -func TopologicalSortContractInfo(contracts []types.ContractInfoV2) ([]types.ContractInfoV2, error) { - contractAddrToContractInfo := map[string]types.ContractInfoV2{} - for _, contract := range contracts { - contractAddrToContractInfo[contract.ContractAddr] = contract - } - - res := []types.ContractInfoV2{} - nodes := initNodes(contracts) - frontierNodes, nonFrontierNodes := splitNodesByFrontier(nodes) - for len(frontierNodes) > 0 { - for _, frontierNode := range frontierNodes { - if contract, ok := contractAddrToContractInfo[frontierNode.contractAddr]; ok { - res = append(res, contract) - } - for _, nonFrontierNode := range nonFrontierNodes { - nonFrontierNode.incomingNodes.Remove(frontierNode.contractAddr) - } - } - frontierNodes, nonFrontierNodes = splitNodesByFrontier(nonFrontierNodes) - } - if len(nonFrontierNodes) > 0 { - return []types.ContractInfoV2{}, types.ErrCircularContractDependency - } - return res, nil -} - -func initNodes(contracts []types.ContractInfoV2) map[string]node { - res := map[string]node{} - for _, contract := range contracts { - if _, ok := res[contract.ContractAddr]; !ok { - emptyIncomingNodes := datastructures.NewSyncSet([]string{}) - res[contract.ContractAddr] = node{ - contractAddr: contract.ContractAddr, - incomingNodes: &emptyIncomingNodes, - } - } - if contract.Dependencies == nil { - continue - } - for _, dependentContract := range contract.Dependencies { - dependentAddr := dependentContract.Dependency - if _, ok := res[dependentAddr]; !ok { - emptyIncomingNodes := datastructures.NewSyncSet([]string{}) - res[dependentAddr] = node{ - contractAddr: dependentAddr, - incomingNodes: &emptyIncomingNodes, - } - } - res[dependentAddr].incomingNodes.Add(contract.ContractAddr) - } - } - return res -} - -func splitNodesByFrontier(nodes map[string]node) (map[string]node, map[string]node) { - frontierNodes, nonFrontierNodes := map[string]node{}, map[string]node{} - for contractAddr, node := range nodes { - if node.incomingNodes.Size() == 0 { - frontierNodes[contractAddr] = node - } else { - nonFrontierNodes[contractAddr] = node - } - } - return frontierNodes, nonFrontierNodes -} diff --git a/x/dex/contract/dag_test.go b/x/dex/contract/dag_test.go deleted file mode 100644 index a5842ca218..0000000000 --- a/x/dex/contract/dag_test.go +++ /dev/null @@ -1,110 +0,0 @@ -package contract_test - -import ( - "testing" - - "github.com/sei-protocol/sei-chain/x/dex/contract" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -// A -> B -> C -func TestTopologicalSortContractInfoSimple(t *testing.T) { - a := types.ContractInfoV2{ - ContractAddr: "A", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "B", - }, - }, - } - b := types.ContractInfoV2{ - ContractAddr: "B", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "C", - }, - }, - } - c := types.ContractInfoV2{ - ContractAddr: "C", - } - res, err := contract.TopologicalSortContractInfo([]types.ContractInfoV2{b, c, a}) - require.Nil(t, err) - require.Equal(t, "A", res[0].ContractAddr) - require.Equal(t, "B", res[1].ContractAddr) - require.Equal(t, "C", res[2].ContractAddr) -} - -// A -> B, C -> D -func TestTopologicalSortContractInfoIsolated(t *testing.T) { - a := types.ContractInfoV2{ - ContractAddr: "A", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "B", - }, - }, - } - b := types.ContractInfoV2{ - ContractAddr: "B", - } - c := types.ContractInfoV2{ - ContractAddr: "C", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "D", - }, - }, - } - d := types.ContractInfoV2{ - ContractAddr: "D", - } - res, err := contract.TopologicalSortContractInfo([]types.ContractInfoV2{b, c, a, d}) - require.Nil(t, err) - aidx, bidx, cidx, didx := -1, -1, -1, -1 - for i, c := range res { - if c.ContractAddr == "A" { - aidx = i - } else if c.ContractAddr == "B" { - bidx = i - } else if c.ContractAddr == "C" { - cidx = i - } else if c.ContractAddr == "D" { - didx = i - } - } - require.True(t, aidx != -1 && aidx < bidx) - require.True(t, cidx != -1 && cidx < didx) -} - -// A -> B -> C -> A -func TestTopologicalSortContractInfoCircular(t *testing.T) { - a := types.ContractInfoV2{ - ContractAddr: "A", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "B", - }, - }, - } - b := types.ContractInfoV2{ - ContractAddr: "B", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "C", - }, - }, - } - c := types.ContractInfoV2{ - ContractAddr: "C", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "A", - }, - }, - } - res, err := contract.TopologicalSortContractInfo([]types.ContractInfoV2{b, c, a}) - require.NotNil(t, err) - require.Equal(t, 0, len(res)) -} diff --git a/x/dex/contract/execution.go b/x/dex/contract/execution.go deleted file mode 100644 index 2c1614f1e4..0000000000 --- a/x/dex/contract/execution.go +++ /dev/null @@ -1,219 +0,0 @@ -package contract - -import ( - "context" - "fmt" - "time" - - otrace "go.opentelemetry.io/otel/trace" - - "github.com/cosmos/cosmos-sdk/telemetry" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/store/whitelist/multi" - "github.com/sei-protocol/sei-chain/utils/datastructures" - "github.com/sei-protocol/sei-chain/x/dex/exchange" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - dexkeeperabci "github.com/sei-protocol/sei-chain/x/dex/keeper/abci" - dexkeeperutils "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "go.opentelemetry.io/otel/attribute" -) - -func CallPreExecutionHooks( - ctx context.Context, - sdkCtx sdk.Context, - contractAddr string, - dexkeeper *keeper.Keeper, - registeredPairs []types.Pair, - tracer *otrace.Tracer, -) error { - spanCtx, span := (*tracer).Start(ctx, "PreExecutionHooks") - defer span.End() - span.SetAttributes(attribute.String("contract", contractAddr)) - abciWrapper := dexkeeperabci.KeeperWrapper{Keeper: dexkeeper} - if err := abciWrapper.HandleEBCancelOrders(spanCtx, sdkCtx, tracer, contractAddr, registeredPairs); err != nil { - return err - } - return abciWrapper.HandleEBPlaceOrders(spanCtx, sdkCtx, tracer, contractAddr, registeredPairs) -} - -func ExecutePair( - ctx sdk.Context, - contractAddr string, - pair types.Pair, - dexkeeper *keeper.Keeper, - orderbook *types.OrderBook, -) []*types.SettlementEntry { - typedContractAddr := types.ContractAddress(contractAddr) - - // First cancel orders - cancelForPair(ctx, dexkeeper, typedContractAddr, pair) - // Add all limit orders to the orderbook - orders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, typedContractAddr, pair) - limitBuys := orders.GetLimitOrders(types.PositionDirection_LONG) - limitSells := orders.GetLimitOrders(types.PositionDirection_SHORT) - exchange.AddOutstandingLimitOrdersToOrderbook(ctx, dexkeeper, limitBuys, limitSells) - // Fill market orders - marketOrderOutcome := matchMarketOrderForPair(ctx, typedContractAddr, pair, orderbook) - // Fill limit orders - limitOrderOutcome := exchange.MatchLimitOrders(ctx, orderbook) - totalOutcome := marketOrderOutcome.Merge(&limitOrderOutcome) - - dexkeeperutils.SetPriceStateFromExecutionOutcome(ctx, dexkeeper, typedContractAddr, pair, totalOutcome) - - return totalOutcome.Settlements -} - -func cancelForPair( - ctx sdk.Context, - keeper *keeper.Keeper, - contractAddress types.ContractAddress, - pair types.Pair, -) { - cancels := dexutils.GetMemState(ctx.Context()).GetBlockCancels(ctx, contractAddress, pair) - exchange.CancelOrders(ctx, keeper, contractAddress, pair, cancels.Get()) -} - -func matchMarketOrderForPair( - ctx sdk.Context, - typedContractAddr types.ContractAddress, - pair types.Pair, - orderbook *types.OrderBook, -) exchange.ExecutionOutcome { - orders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, typedContractAddr, pair) - marketBuys := orders.GetSortedMarketOrders(types.PositionDirection_LONG) - marketSells := orders.GetSortedMarketOrders(types.PositionDirection_SHORT) - marketBuyOutcome := exchange.MatchMarketOrders( - ctx, - marketBuys, - orderbook.Shorts, - types.PositionDirection_LONG, - orders, - ) - marketSellOutcome := exchange.MatchMarketOrders( - ctx, - marketSells, - orderbook.Longs, - types.PositionDirection_SHORT, - orders, - ) - return marketBuyOutcome.Merge(&marketSellOutcome) -} - -func GetMatchResults( - ctx sdk.Context, - typedContractAddr types.ContractAddress, - pair types.Pair, -) ([]*types.Order, []*types.Cancellation) { - orderResults := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, typedContractAddr, pair).Get() - cancelResults := dexutils.GetMemState(ctx.Context()).GetBlockCancels(ctx, typedContractAddr, pair).Get() - return orderResults, cancelResults -} - -func GetOrderIDToSettledQuantities(settlements []*types.SettlementEntry) map[uint64]sdk.Dec { - res := map[uint64]sdk.Dec{} - for _, settlement := range settlements { - if _, ok := res[settlement.OrderId]; !ok { - res[settlement.OrderId] = sdk.ZeroDec() - } - res[settlement.OrderId] = res[settlement.OrderId].Add(settlement.Quantity) - } - return res -} - -func ExecutePairsInParallel(ctx sdk.Context, contractAddr string, dexkeeper *keeper.Keeper, registeredPairs []types.Pair, orderBooks *datastructures.TypedSyncMap[types.PairString, *types.OrderBook]) []*types.SettlementEntry { - typedContractAddr := types.ContractAddress(contractAddr) - orderResults := []*types.Order{} - cancelResults := []*types.Cancellation{} - settlements := []*types.SettlementEntry{} - - // mu := sync.Mutex{} - // wg := sync.WaitGroup{} - - for _, pair := range registeredPairs { - // wg.Add(1) - - pair := pair - pairCtx := ctx.WithMultiStore(multi.NewStore(ctx.MultiStore(), GetPerPairWhitelistMap(contractAddr, pair))).WithEventManager(sdk.NewEventManager()) - // go func() { - func() { - // defer wg.Done() - pairCopy := pair - pairStr := types.GetPairString(&pairCopy) - orderbook, found := orderBooks.Load(pairStr) - if !found { - panic(fmt.Sprintf("Orderbook not found for %s", pairCopy.String())) - } - pairSettlements := ExecutePair(pairCtx, contractAddr, pair, dexkeeper, orderbook) - orderIDToSettledQuantities := GetOrderIDToSettledQuantities(pairSettlements) - PrepareCancelUnfulfilledMarketOrders(pairCtx, typedContractAddr, pairCopy, orderIDToSettledQuantities) - - // mu.Lock() - // defer mu.Unlock() - orders, cancels := GetMatchResults(ctx, typedContractAddr, pairCopy) - orderResults = append(orderResults, orders...) - cancelResults = append(cancelResults, cancels...) - settlements = append(settlements, pairSettlements...) - // ordering of events doesn't matter since events aren't part of consensus - ctx.EventManager().EmitEvents(pairCtx.EventManager().Events()) - }() - } - // wg.Wait() - dexkeeper.SetMatchResult(ctx, contractAddr, types.NewMatchResult(orderResults, cancelResults, settlements)) - - return settlements -} - -func HandleExecutionForContract( - ctx context.Context, - sdkCtx sdk.Context, - contract types.ContractInfoV2, - dexkeeper *keeper.Keeper, - registeredPairs []types.Pair, - orderBooks *datastructures.TypedSyncMap[types.PairString, *types.OrderBook], - tracer *otrace.Tracer, -) ([]*types.SettlementEntry, error) { - executionStart := time.Now() - defer telemetry.ModuleMeasureSince(types.ModuleName, executionStart, "handle_execution_for_contract_ms") - contractAddr := contract.ContractAddr - - // Call contract hooks so that contracts can do internal bookkeeping - if err := CallPreExecutionHooks(ctx, sdkCtx, contractAddr, dexkeeper, registeredPairs, tracer); err != nil { - return []*types.SettlementEntry{}, err - } - settlements := ExecutePairsInParallel(sdkCtx, contractAddr, dexkeeper, registeredPairs, orderBooks) - defer EmitSettlementMetrics(settlements) - - return settlements, nil -} - -// Emit metrics for settlements -func EmitSettlementMetrics(settlements []*types.SettlementEntry) { - if len(settlements) > 0 { - telemetry.ModuleSetGauge( - types.ModuleName, - float32(len(settlements)), - "num_settlements", - ) - for _, s := range settlements { - telemetry.IncrCounter( - 1, - "num_settlements_order_type_"+s.GetOrderType(), - ) - telemetry.IncrCounter( - 1, - "num_settlements_position_direction"+s.GetPositionDirection(), - ) - telemetry.IncrCounter( - 1, - "num_settlements_asset_denom_"+s.GetAssetDenom(), - ) - telemetry.IncrCounter( - 1, - "num_settlements_price_denom_"+s.GetPriceDenom(), - ) - } - } -} diff --git a/x/dex/contract/execution_test.go b/x/dex/contract/execution_test.go deleted file mode 100644 index fea46b35ff..0000000000 --- a/x/dex/contract/execution_test.go +++ /dev/null @@ -1,373 +0,0 @@ -package contract_test - -import ( - "testing" - "time" - - "github.com/sei-protocol/sei-chain/utils/datastructures" - dexutil "github.com/sei-protocol/sei-chain/x/dex/utils" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/contract" - keeperutil "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TEST_PAIR() types.Pair { - return types.Pair{ - PriceDenom: "usdc", - AssetDenom: "atom", - } -} - -const ( - TEST_ACCOUNT = "test_account" - TEST_CONTRACT = "test" - TestTimestamp uint64 = 10000 - TestHeight uint64 = 1 -) - -func TestExecutePair(t *testing.T) { - pair := types.Pair{ - PriceDenom: "USDC", - AssetDenom: "ATOM", - } - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longBook := []types.OrderBookEntry{ - &types.LongBook{ - Price: sdk.NewDec(98), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(98), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "abc", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.LongBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "def", - Quantity: sdk.NewDec(3), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, l := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, keepertest.TestContract, l) - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(101), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(101), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 7, - Account: "abc", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.ShortBook{ - Price: sdk.NewDec(115), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(115), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 8, - Account: "def", - Quantity: sdk.NewDec(3), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, s := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, keepertest.TestContract, s) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress(keepertest.TestContract), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - - settlements := contract.ExecutePair( - ctx, - TEST_CONTRACT, - pair, - dexkeeper, - orderbook, - ) - require.Equal(t, len(settlements), 0) - - // add Market orders to the orderbook - dexutil.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), pair).Add( - &types.Order{ - Id: 1, - Account: TEST_ACCOUNT, - ContractAddr: TEST_CONTRACT, - Price: sdk.MustNewDecFromStr("97"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutil.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), pair).Add( - &types.Order{ - Id: 2, - Account: TEST_ACCOUNT, - ContractAddr: TEST_CONTRACT, - Price: sdk.MustNewDecFromStr("100"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutil.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), pair).Add( - &types.Order{ - Id: 3, - Account: TEST_ACCOUNT, - ContractAddr: TEST_CONTRACT, - Price: sdk.MustNewDecFromStr("200"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_MARKET, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - - settlements = contract.ExecutePair( - ctx, - TEST_CONTRACT, - pair, - dexkeeper, - orderbook, - ) - - require.Equal(t, 2, len(settlements)) - require.Equal(t, uint64(7), settlements[0].OrderId) - require.Equal(t, uint64(3), settlements[1].OrderId) - - // get match results - matches, cancels := contract.GetMatchResults( - ctx, - TEST_CONTRACT, - pair, - ) - require.Equal(t, 3, len(matches)) - require.Equal(t, 0, len(cancels)) -} - -func TestExecutePairInParallel(t *testing.T) { - pair := types.Pair{ - PriceDenom: "USDC", - AssetDenom: "ATOM", - } - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longBook := []types.OrderBookEntry{ - &types.LongBook{ - Price: sdk.NewDec(98), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(98), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "abc", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.LongBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "def", - Quantity: sdk.NewDec(3), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, l := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, TEST_CONTRACT, l) - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(101), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(101), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 7, - Account: "abc", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.ShortBook{ - Price: sdk.NewDec(115), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(115), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 8, - Account: "def", - Quantity: sdk.NewDec(3), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, s := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, TEST_CONTRACT, s) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress(TEST_CONTRACT), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - - // execute in parallel simple path - orderbooks := datastructures.NewTypedSyncMap[types.PairString, *types.OrderBook]() - orderbooks.Store(types.GetPairString(&pair), orderbook) - settlements := contract.ExecutePairsInParallel( - ctx, - TEST_CONTRACT, - dexkeeper, - []types.Pair{pair}, - orderbooks, - ) - - require.Equal(t, len(settlements), 0) - - // add Market orders to the orderbook - dexutil.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), pair).Add( - &types.Order{ - Id: 1, - Account: TEST_ACCOUNT, - ContractAddr: TEST_CONTRACT, - Price: sdk.MustNewDecFromStr("97"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutil.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), pair).Add( - &types.Order{ - Id: 2, - Account: TEST_ACCOUNT, - ContractAddr: TEST_CONTRACT, - Price: sdk.MustNewDecFromStr("100"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutil.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), pair).Add( - &types.Order{ - Id: 3, - Account: TEST_ACCOUNT, - ContractAddr: TEST_CONTRACT, - Price: sdk.MustNewDecFromStr("200"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_MARKET, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutil.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(TEST_CONTRACT), pair).Add( - &types.Order{ - Id: 11, - Account: TEST_ACCOUNT, - ContractAddr: TEST_CONTRACT, - Price: sdk.MustNewDecFromStr("20"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_MARKET, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - - settlements = contract.ExecutePairsInParallel( - ctx, - TEST_CONTRACT, - dexkeeper, - []types.Pair{pair}, - orderbooks, - ) - - require.Equal(t, 2, len(settlements)) - require.Equal(t, uint64(7), settlements[0].OrderId) - require.Equal(t, uint64(3), settlements[1].OrderId) -} - -func TestGetOrderIDToSettledQuantities(t *testing.T) { - settlements := []*types.SettlementEntry{ - { - OrderId: 1, - Quantity: sdk.MustNewDecFromStr("100"), - }, - { - OrderId: 2, - Quantity: sdk.MustNewDecFromStr("200"), - }, - } - - idMapping := contract.GetOrderIDToSettledQuantities(settlements) - - require.Equal(t, 2, len(idMapping)) - require.Equal(t, sdk.MustNewDecFromStr("100"), idMapping[1]) - require.Equal(t, sdk.MustNewDecFromStr("200"), idMapping[2]) -} - -func TestEmitSettlementMetrics(t *testing.T) { - settlements := []*types.SettlementEntry{ - { - OrderId: 1, - Quantity: sdk.MustNewDecFromStr("100"), - }, - { - OrderId: 2, - Quantity: sdk.MustNewDecFromStr("200"), - }, - } - - require.NotPanics(t, func() { contract.EmitSettlementMetrics(settlements) }) -} diff --git a/x/dex/contract/market_order.go b/x/dex/contract/market_order.go deleted file mode 100644 index 3901f83e85..0000000000 --- a/x/dex/contract/market_order.go +++ /dev/null @@ -1,68 +0,0 @@ -package contract - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - dexkeeperabci "github.com/sei-protocol/sei-chain/x/dex/keeper/abci" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "go.opentelemetry.io/otel/attribute" - otrace "go.opentelemetry.io/otel/trace" -) - -func PrepareCancelUnfulfilledMarketOrders( - ctx sdk.Context, - typedContractAddr types.ContractAddress, - pair types.Pair, - orderIDToSettledQuantities map[uint64]sdk.Dec, -) { - dexutils.GetMemState(ctx.Context()).ClearCancellationForPair(ctx, typedContractAddr, pair) - for _, marketOrderID := range getUnfulfilledPlacedMarketOrderIds(ctx, typedContractAddr, pair, orderIDToSettledQuantities) { - dexutils.GetMemState(ctx.Context()).GetBlockCancels(ctx, typedContractAddr, pair).Add(&types.Cancellation{ - Id: marketOrderID, - Initiator: types.CancellationInitiator_USER, - }) - } -} - -func getUnfulfilledPlacedMarketOrderIds( - ctx sdk.Context, - typedContractAddr types.ContractAddress, - pair types.Pair, - orderIDToSettledQuantities map[uint64]sdk.Dec, -) []uint64 { - res := []uint64{} - for _, order := range dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, typedContractAddr, pair).Get() { - if order.Status == types.OrderStatus_FAILED_TO_PLACE { - continue - } - if order.OrderType == types.OrderType_MARKET || order.OrderType == types.OrderType_FOKMARKET { - if settledQuantity, ok := orderIDToSettledQuantities[order.Id]; !ok || settledQuantity.LT(order.Quantity) { - res = append(res, order.Id) - } - } else if order.OrderType == types.OrderType_FOKMARKETBYVALUE { - // cancel market order by nominal if zero quantity is executed - if _, ok := orderIDToSettledQuantities[order.Id]; !ok { - res = append(res, order.Id) - } - } - } - return res -} - -func CancelUnfulfilledMarketOrders( - ctx context.Context, - sdkCtx sdk.Context, - contractAddr string, - dexkeeper *keeper.Keeper, - registeredPairs []types.Pair, - tracer *otrace.Tracer, -) error { - spanCtx, span := (*tracer).Start(ctx, "CancelUnfulfilledMarketOrders") - span.SetAttributes(attribute.String("contract", contractAddr)) - defer span.End() - abciWrapper := dexkeeperabci.KeeperWrapper{Keeper: dexkeeper} - return abciWrapper.HandleEBCancelOrders(spanCtx, sdkCtx, tracer, contractAddr, registeredPairs) -} diff --git a/x/dex/contract/runner.go b/x/dex/contract/runner.go deleted file mode 100644 index 6e3797f3f0..0000000000 --- a/x/dex/contract/runner.go +++ /dev/null @@ -1,178 +0,0 @@ -package contract - -import ( - "fmt" - "sync/atomic" - "time" - - "github.com/cosmos/cosmos-sdk/telemetry" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/utils/datastructures" - "github.com/sei-protocol/sei-chain/utils/logging" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -const LogAfter = 10 * time.Second - -type ParallelRunner struct { - runnable func(contract types.ContractInfoV2) - - contractAddrToInfo *datastructures.TypedSyncMap[types.ContractAddress, *types.ContractInfoV2] - readyContracts *datastructures.TypedSyncMap[types.ContractAddress, struct{}] - readyCnt int64 - inProgressCnt int64 - someContractFinished chan struct{} - done chan struct{} - sdkCtx sdk.Context -} - -func NewParallelRunner(runnable func(contract types.ContractInfoV2), contracts []types.ContractInfoV2, ctx sdk.Context) ParallelRunner { - contractAddrToInfo := datastructures.NewTypedSyncMap[types.ContractAddress, *types.ContractInfoV2]() - contractsFrontier := datastructures.NewTypedSyncMap[types.ContractAddress, struct{}]() - for _, contract := range contracts { - // runner will mutate ContractInfo fields - copyContract := contract - typedContractAddr := types.ContractAddress(contract.ContractAddr) - contractAddrToInfo.Store(typedContractAddr, ©Contract) - if copyContract.NumIncomingDependencies == 0 { - contractsFrontier.Store(typedContractAddr, struct{}{}) - } - } - return ParallelRunner{ - runnable: runnable, - contractAddrToInfo: contractAddrToInfo, - readyContracts: contractsFrontier, - readyCnt: int64(contractsFrontier.Len()), - inProgressCnt: 0, - someContractFinished: make(chan struct{}), - done: make(chan struct{}, 1), - sdkCtx: ctx, - } -} - -// We define "frontier contract" as a contract which: -// 1. Has not finished running yet, and -// 2. either: -// a. has no other contracts depending on it, or -// b. for which all contracts that depend on it have already finished. -// -// Consequently, the set of frontier contracts will mutate throughout the -// `Run` method, until all contracts finish their runs. -// The key principle here is that at any moment, we can have all frontier -// contracts running concurrently, since there must be no ancestral -// relationships among them due to the definition above. -// The simplest implementation would be: -// ``` -// while there is any contract left: -// -// run all frontier contracts concurrently -// wait for all runs to finish -// update the frontier set -// -// ``` -// We can illustrate why this implementation is not optimal with the following -// example: -// -// Suppose we have four contracts, where A depends on B, and C depends on -// D. The run for A, B, C, D takes 5s, 5s, 8s, 2s, respectively. -// With the implementation above, the first iteration would take 8s since -// it runs A and C, and the second iteration would take 5s since it runs -// B and D. However C doesn't actually need to wait for B to finish, and -// if C runs immediately after A finishes, the whole process would take -// max(5 + 5, 8 + 2) = 10s, which is 3s faster than the implementation -// above. -// -// So we can optimize the implementation to be: -// ``` -// while there is any contract left: -// -// run all frontier contracts concurrently -// wait for any existing run (could be from previous iteration) to finish -// update the frontier set -// -// ``` -// With the example above, the whole process would take 3 iterations: -// Iter 1 (A, C run): 5s since it finishes when A finishes -// Iter 2 (B run): 3s since it finishes when C finishes -// Iter 3 (D run): 2s since it finishes when B, D finish -// -// The following `Run` method implements the pseudocode above. -func (r *ParallelRunner) Run() { - if atomic.LoadInt64(&r.inProgressCnt) == 0 && atomic.LoadInt64(&r.readyCnt) == 0 { - return - } - // The ordering of the two conditions below matters, since readyCnt - // is updated before inProgressCnt. - for atomic.LoadInt64(&r.inProgressCnt) > 0 || atomic.LoadInt64(&r.readyCnt) > 0 { - // r.readyContracts represent all frontier contracts that have - // not started running yet. - r.readyContracts.Range(func(key types.ContractAddress, _ struct{}) bool { - atomic.AddInt64(&r.inProgressCnt, 1) - go r.wrapRunnable(key) - // Since the frontier contract has started running, we need - // to remove it from r.readyContracts so that it won't - // double-run. - r.readyContracts.Delete(key) - // The reason we use a separate readyCnt is because `sync.Map` - // doesn't provide an atomic way to get its length. - atomic.AddInt64(&r.readyCnt, -1) - return true - }) - // This corresponds to the "wait for any existing run (could be - // from previous iteration) to finish" part in the pseudocode above. - _, err := logging.LogIfNotDoneAfter(r.sdkCtx.Logger(), func() (struct{}, error) { - <-r.someContractFinished - return struct{}{}, nil - }, LogAfter, "dex_parallel_runner_wait") - if err != nil { - // this should never happen - panic(err) - } - } - - // make sure there is no orphaned goroutine blocked on channel send - r.done <- struct{}{} -} - -func (r *ParallelRunner) wrapRunnable(contractAddr types.ContractAddress) { - defer func() { - if err := recover(); err != nil { - telemetry.IncrCounter(1, "recovered_panics") - r.sdkCtx.Logger().Error(fmt.Sprintf("panic in parallel runner recovered: %s", err)) - } - - atomic.AddInt64(&r.inProgressCnt, -1) // this has to happen after any potential increment to readyCnt - select { - case r.someContractFinished <- struct{}{}: - case <-r.done: - // make sure other goroutines can also receive from 'done' - r.done <- struct{}{} - } - }() - - contractInfo, _ := r.contractAddrToInfo.Load(contractAddr) - r.runnable(*contractInfo) - - // Check if there is any contract that should be promoted to the frontier set. - if contractInfo.Dependencies != nil { - for _, dependency := range contractInfo.Dependencies { - dependentContract := dependency.Dependency - typedDependentContract := types.ContractAddress(dependentContract) - dependentInfo, ok := r.contractAddrToInfo.Load(typedDependentContract) - if !ok { - // If we cannot find the dependency in the contract address info, then it's not a valid contract in this round - r.sdkCtx.Logger().Error(fmt.Sprintf("Couldn't find dependency %s of contract %s in the contract address info", contractInfo.ContractAddr, dependentContract)) - continue - } - // It's okay to mutate ContractInfo here since it's a copy made in the runner's - // constructor. - newNumIncomingPaths := atomic.AddInt64(&dependentInfo.NumIncomingDependencies, -1) - // This corresponds to the "for which all contracts that depend on it have - // already finished." definition for frontier contract. - if newNumIncomingPaths == 0 { - r.readyContracts.Store(typedDependentContract, struct{}{}) - atomic.AddInt64(&r.readyCnt, 1) - } - } - } -} diff --git a/x/dex/contract/runner_test.go b/x/dex/contract/runner_test.go deleted file mode 100644 index bf7e8c1d70..0000000000 --- a/x/dex/contract/runner_test.go +++ /dev/null @@ -1,141 +0,0 @@ -package contract_test - -import ( - "sync" - "sync/atomic" - "testing" - "time" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/contract" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -var ( - counter int64 = 0 - dependencyCheck = sync.Map{} - testApp = keepertest.TestApp() - sdkCtx = testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) -) - -func noopRunnable(_ types.ContractInfoV2) { - atomic.AddInt64(&counter, 1) -} - -func idleRunnable(_ types.ContractInfoV2) { - time.Sleep(5 * time.Second) - atomic.AddInt64(&counter, 1) -} - -func panicRunnable(_ types.ContractInfoV2) { - panic("") -} - -func dependencyCheckRunnable(contractInfo types.ContractInfoV2) { - if contractInfo.ContractAddr == "C" { - _, hasA := dependencyCheck.Load("A") - _, hasB := dependencyCheck.Load("B") - if !hasA || !hasB { - return - } - } - dependencyCheck.Store(contractInfo.ContractAddr, struct{}{}) -} - -func TestRunnerSingleContract(t *testing.T) { - counter = 0 - contractInfo := types.ContractInfoV2{ - ContractAddr: "A", - NumIncomingDependencies: 0, - } - runner := contract.NewParallelRunner(noopRunnable, []types.ContractInfoV2{contractInfo}, sdkCtx) - runner.Run() - require.Equal(t, int64(1), counter) -} - -func TestRunnerParallelContract(t *testing.T) { - counter = 0 - contractInfoA := types.ContractInfoV2{ - ContractAddr: "A", - NumIncomingDependencies: 0, - } - contractInfoB := types.ContractInfoV2{ - ContractAddr: "B", - NumIncomingDependencies: 0, - } - runner := contract.NewParallelRunner(idleRunnable, []types.ContractInfoV2{contractInfoA, contractInfoB}, sdkCtx) - start := time.Now() - runner.Run() - end := time.Now() - duration := end.Sub(start) - require.Equal(t, int64(2), counter) - require.True(t, duration.Seconds() < 10) // would not be flaky unless it's running on really slow hardware -} - -func TestRunnerParallelContractWithDependency(t *testing.T) { - counter = 0 - contractInfoA := types.ContractInfoV2{ - ContractAddr: "A", - NumIncomingDependencies: 0, - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "C", - }, - }, - } - contractInfoB := types.ContractInfoV2{ - ContractAddr: "B", - NumIncomingDependencies: 0, - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "C", - }, - }, - } - contractInfoC := types.ContractInfoV2{ - ContractAddr: "C", - NumIncomingDependencies: 2, - } - runner := contract.NewParallelRunner(dependencyCheckRunnable, []types.ContractInfoV2{contractInfoC, contractInfoB, contractInfoA}, sdkCtx) - runner.Run() - _, hasC := dependencyCheck.Load("C") - require.True(t, hasC) -} - -func TestRunnerParallelContractWithInvalidDependency(t *testing.T) { - dependencyCheck = sync.Map{} - counter = 0 - contractInfoA := types.ContractInfoV2{ - ContractAddr: "A", - NumIncomingDependencies: 0, - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "C", - }, - }, - } - contractInfoB := types.ContractInfoV2{ - ContractAddr: "B", - NumIncomingDependencies: 0, - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "C", - }, - }, - } - runner := contract.NewParallelRunner(dependencyCheckRunnable, []types.ContractInfoV2{contractInfoB, contractInfoA}, sdkCtx) - runner.Run() - _, hasC := dependencyCheck.Load("C") - require.False(t, hasC) -} - -func TestRunnerPanicContract(t *testing.T) { - contractInfo := types.ContractInfoV2{ - ContractAddr: "A", - NumIncomingDependencies: 0, - } - runner := contract.NewParallelRunner(panicRunnable, []types.ContractInfoV2{contractInfo}, sdkCtx) - require.NotPanics(t, runner.Run) -} diff --git a/x/dex/contract/settlement.go b/x/dex/contract/settlement.go deleted file mode 100644 index e840388e4e..0000000000 --- a/x/dex/contract/settlement.go +++ /dev/null @@ -1,39 +0,0 @@ -package contract - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - dexkeeperutils "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func HandleSettlements( - ctx sdk.Context, - contractAddr string, - dexkeeper *keeper.Keeper, - settlements []*types.SettlementEntry, -) error { - return callSettlementHook(ctx, contractAddr, dexkeeper, settlements) -} - -func callSettlementHook( - ctx sdk.Context, - contractAddr string, - dexkeeper *keeper.Keeper, - settlementEntries []*types.SettlementEntry, -) error { - if len(settlementEntries) == 0 { - return nil - } - _, currentEpoch := dexkeeper.IsNewEpoch(ctx) - nativeSettlementMsg := types.SudoSettlementMsg{ - Settlement: types.Settlements{ - Epoch: int64(currentEpoch), - Entries: settlementEntries, - }, - } - if _, err := dexkeeperutils.CallContractSudo(ctx, dexkeeper, contractAddr, nativeSettlementMsg, dexkeeper.GetSettlementGasAllowance(ctx, len(settlementEntries))); err != nil { - return err - } - return nil -} diff --git a/x/dex/contract/whitelist.go b/x/dex/contract/whitelist.go deleted file mode 100644 index d6ab9a8a92..0000000000 --- a/x/dex/contract/whitelist.go +++ /dev/null @@ -1,91 +0,0 @@ -package contract - -import ( - wasmtypes "github.com/CosmWasm/wasmd/x/wasm/types" - storetypes "github.com/cosmos/cosmos-sdk/store/types" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/utils" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -var DexWhitelistedKeys = []string{ - types.LongBookKey, - types.ShortBookKey, - types.OrderKey, - types.AccountActiveOrdersKey, - types.CancelKey, - types.TwapKey, - types.PriceKey, - types.NextOrderIDKey, - types.MatchResultKey, - types.LongOrderCountKey, - types.ShortOrderCountKey, - keeper.ContractPrefixKey, -} - -var DexMemWhitelistedKeys = []string{ - types.MemOrderKey, - types.MemDepositKey, - types.MemCancelKey, -} - -var WasmWhitelistedKeys = []string{ - string(wasmtypes.ContractStorePrefix), -} - -func GetWhitelistMap(contractAddr string) map[string][]string { - res := map[string][]string{} - res[storetypes.NewKVStoreKey(types.StoreKey).Name()] = GetDexWhitelistedPrefixes(contractAddr) - res[storetypes.NewKVStoreKey(wasmtypes.StoreKey).Name()] = GetWasmWhitelistedPrefixes(contractAddr) - res[storetypes.NewKVStoreKey(types.MemStoreKey).Name()] = GetDexMemWhitelistedPrefixes(contractAddr) - return res -} - -func GetPerPairWhitelistMap(contractAddr string, pair types.Pair) map[string][]string { - res := map[string][]string{} - res[storetypes.NewKVStoreKey(types.StoreKey).Name()] = GetDexPerPairWhitelistedPrefixes(contractAddr, pair) - res[storetypes.NewKVStoreKey(types.MemStoreKey).Name()] = GetDexMemPerPairWhitelistedPrefixes(contractAddr, pair) - return res -} - -func GetDexWhitelistedPrefixes(contractAddr string) []string { - return utils.Map(DexWhitelistedKeys, func(key string) string { - return string(append( - types.KeyPrefix(key), types.AddressKeyPrefix(contractAddr)..., - )) - }) -} - -func GetDexMemWhitelistedPrefixes(contractAddr string) []string { - return utils.Map(DexMemWhitelistedKeys, func(key string) string { - return string(append( - types.KeyPrefix(key), types.AddressKeyPrefix(contractAddr)..., - )) - }) -} - -func GetWasmWhitelistedPrefixes(contractAddr string) []string { - addr, _ := sdk.AccAddressFromBech32(contractAddr) - return utils.Map(WasmWhitelistedKeys, func(key string) string { - return string(append( - []byte(key), addr..., - )) - }) -} - -func GetDexPerPairWhitelistedPrefixes(contractAddr string, pair types.Pair) []string { - return utils.Map(DexWhitelistedKeys, func(key string) string { - return string(append(append( - types.KeyPrefix(key), types.AddressKeyPrefix(contractAddr)..., - ), types.PairPrefix(pair.PriceDenom, pair.AssetDenom)...)) - }) -} - -func GetDexMemPerPairWhitelistedPrefixes(contractAddr string, pair types.Pair) []string { - return utils.Map(DexMemWhitelistedKeys, func(key string) string { - return string(append(append( - types.KeyPrefix(key), types.AddressKeyPrefix(contractAddr)..., - ), types.PairPrefix(pair.PriceDenom, pair.AssetDenom)...)) - }) -} diff --git a/x/dex/contract/whitelist_test.go b/x/dex/contract/whitelist_test.go deleted file mode 100644 index 79fb701741..0000000000 --- a/x/dex/contract/whitelist_test.go +++ /dev/null @@ -1,28 +0,0 @@ -package contract_test - -import ( - "encoding/hex" - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/contract" - "github.com/stretchr/testify/require" -) - -func TestGetWasmPrefixes(t *testing.T) { - wasmWhitelistedPrefixes := contract.GetWasmWhitelistedPrefixes("sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m") - - wasmPrefixBytes, _ := hex.DecodeString("03" + "ade4a5f5803a439835c636395a8d648dee57b2fc90d98dc17fa887159b69638b") - require.Equal(t, []byte(wasmWhitelistedPrefixes[0]), wasmPrefixBytes) -} - -func TestGetDexPrefixes(t *testing.T) { - dexWhitelistedPrefixes := contract.GetDexWhitelistedPrefixes("sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m") - addr, _ := sdk.AccAddressFromBech32("sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m") - - for i, dexKeys := range contract.DexWhitelistedKeys { - len := []byte{byte(32)} - prefix := append(append([]byte(dexKeys), len...), addr...) - require.Equal(t, string(prefix), dexWhitelistedPrefixes[i]) - } -} diff --git a/x/dex/example/add-asset-metadata-proposal.json b/x/dex/example/add-asset-metadata-proposal.json deleted file mode 100644 index 80365fad26..0000000000 --- a/x/dex/example/add-asset-metadata-proposal.json +++ /dev/null @@ -1,55 +0,0 @@ -{ - "title": "Add usdc asset to asset list", - "description": "gov proposal to update asset list", - "asset_list": [ - { - "ibc_info": { - "source_channel": "channel-1", - "dst_channel": "channel-2", - "source_denom": "uusdc", - "source_chain_id": "axelar" - }, - "type_asset": "erc20", - "metadata": { - "description": "Circle's stablecoin on Axelar", - "denom_units": [ - { - "denom": "ibc/D189335C6E4A68B513C10AB227BF1C1D38C746766278BA3EEB4FB14124F1D858", - "exponent": 0, - "aliases": ["uusdc"] - }, - { - "denom": "axlusdc", - "exponent": 6 - } - ], - "base": "ibc/D189335C6E4A68B513C10AB227BF1C1D38C746766278BA3EEB4FB14124F1D858", - "name": "USD Coin", - "display": "axlusdc", - "symbol": "USDC" - } - }, - { - "type_asset": "native", - "metadata": { - "description": "Native token of Sei Network", - "denom_units": [ - { - "denom": "usei", - "exponent": 0, - "aliases": ["usei"] - }, - { - "denom": "sei", - "exponent": 6 - } - ], - "base": "SEI", - "name": "sei", - "display": "usei", - "symbol": "SEI" - } - } - ], - "deposit": "500000usei" -} diff --git a/x/dex/example/register-pair-tx.json b/x/dex/example/register-pair-tx.json deleted file mode 100644 index 61d285599b..0000000000 --- a/x/dex/example/register-pair-tx.json +++ /dev/null @@ -1,15 +0,0 @@ -{ - "batch_contract_pair": [ - { - "contract_addr": "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m", - "pairs": [ - { - "price_denom": "usei", - "asset_denom": "uatom", - "price_tick_size": "0.0000001", - "quantity_tick_size": "0.0000001" - } - ] - } - ] -} \ No newline at end of file diff --git a/x/dex/example/update-tick-size-tx.json b/x/dex/example/update-tick-size-tx.json deleted file mode 100644 index 746e819d20..0000000000 --- a/x/dex/example/update-tick-size-tx.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "tick_size_list": [ - { - "pair": { - "price_denom": "uatom", - "asset_denom": "usei" - }, - "tick_size": "1.5", - "contract_addr": "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m" - } - ] -} \ No newline at end of file diff --git a/x/dex/exchange/cancel_order.go b/x/dex/exchange/cancel_order.go deleted file mode 100644 index c50d6be96d..0000000000 --- a/x/dex/exchange/cancel_order.go +++ /dev/null @@ -1,53 +0,0 @@ -package exchange - -import ( - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func CancelOrders( - ctx sdk.Context, keeper *keeper.Keeper, contract types.ContractAddress, pair types.Pair, - cancels []*types.Cancellation, -) { - for _, cancel := range cancels { - cancelOrder(ctx, keeper, cancel, contract, pair) - } -} - -func cancelOrder(ctx sdk.Context, keeper *keeper.Keeper, cancellation *types.Cancellation, contract types.ContractAddress, pair types.Pair) { - getter, setter, deleter := keeper.GetLongOrderBookEntryByPrice, keeper.SetLongOrderBookEntry, keeper.RemoveLongBookByPrice - if cancellation.PositionDirection == types.PositionDirection_SHORT { - getter, setter, deleter = keeper.GetShortOrderBookEntryByPrice, keeper.SetShortOrderBookEntry, keeper.RemoveShortBookByPrice - } - entry, found := getter(ctx, string(contract), cancellation.Price, pair.PriceDenom, pair.AssetDenom) - if !found { - return - } - newEntry := *entry.GetOrderEntry() - newAllocations := []*types.Allocation{} - newQuantity := sdk.ZeroDec() - for _, allocation := range newEntry.Allocations { - if allocation.OrderId != cancellation.Id { - newAllocations = append(newAllocations, allocation) - newQuantity = newQuantity.Add(allocation.Quantity) - } - } - numAllocationsRemoved := len(newEntry.Allocations) - len(newAllocations) - if numAllocationsRemoved > 0 { - err := keeper.DecreaseOrderCount(ctx, string(contract), pair.PriceDenom, pair.AssetDenom, cancellation.PositionDirection, entry.GetPrice(), uint64(numAllocationsRemoved)) - if err != nil { - ctx.Logger().Error(fmt.Sprintf("error decreasing order count: %s", err)) - } - } - if newQuantity.IsZero() { - deleter(ctx, string(contract), entry.GetPrice(), pair.PriceDenom, pair.AssetDenom) - return - } - newEntry.Quantity = newQuantity - newEntry.Allocations = newAllocations - entry.SetEntry(&newEntry) - setter(ctx, string(contract), entry) -} diff --git a/x/dex/exchange/cancel_order_test.go b/x/dex/exchange/cancel_order_test.go deleted file mode 100644 index 43701f9f65..0000000000 --- a/x/dex/exchange/cancel_order_test.go +++ /dev/null @@ -1,105 +0,0 @@ -package exchange_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/exchange" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/assert" - "github.com/stretchr/testify/require" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" -) - -func TestCancelOrder(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longBook := []types.OrderBookEntry{ - &types.LongBook{ - Price: sdk.NewDec(98), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(98), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "abc", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, s := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", s) - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(101), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(101), - Quantity: sdk.NewDec(12), - Allocations: []*types.Allocation{{ - OrderId: 7, - Account: "abc", - Quantity: sdk.NewDec(5), - }, { - OrderId: 8, - Account: "def", - Quantity: sdk.NewDec(7), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, s := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", s) - } - - // Allocations before cancellation contains id 5 - assert.Equal(t, (*longBook[0].GetOrderEntry()).Allocations, []*types.Allocation{{ - OrderId: 5, - Account: "abc", - Quantity: sdk.NewDec(5), - }}) - - // Cancel Long Id 5 - cancellation := types.Cancellation{ - Id: 5, - Creator: "abc", - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - PositionDirection: types.PositionDirection_LONG, - Price: sdk.NewDec(98), - } - // Cancel short Id 7 - cancellationShort := types.Cancellation{ - Id: 7, - Creator: "abc", - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - PositionDirection: types.PositionDirection_SHORT, - Price: sdk.NewDec(101), - } - cancels := []*types.Cancellation{&cancellation, &cancellationShort} - exchange.CancelOrders(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}, - cancels, - ) - - // No allocations after cancellation - _, found := dexkeeper.GetLongBookByPrice(ctx, "test", sdk.NewDec(98), "USDC", "ATOM") - require.False(t, found) - entry, found := dexkeeper.GetShortBookByPrice(ctx, "test", sdk.NewDec(101), "USDC", "ATOM") - require.True(t, found) - require.Equal(t, sdk.NewDec(7), entry.GetOrderEntry().Quantity) - require.Equal(t, []*types.Allocation{{ - OrderId: 8, - Account: "def", - Quantity: sdk.NewDec(7), - }}, entry.GetOrderEntry().Allocations) -} diff --git a/x/dex/exchange/helpers.go b/x/dex/exchange/helpers.go deleted file mode 100644 index eeb39a8eee..0000000000 --- a/x/dex/exchange/helpers.go +++ /dev/null @@ -1,24 +0,0 @@ -package exchange - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -type ExecutionOutcome struct { - TotalNotional sdk.Dec - TotalQuantity sdk.Dec - Settlements []*types.SettlementEntry - MinPrice sdk.Dec // deprecate? - MaxPrice sdk.Dec // deprecate? -} - -func (o *ExecutionOutcome) Merge(other *ExecutionOutcome) ExecutionOutcome { - return ExecutionOutcome{ - TotalNotional: o.TotalNotional.Add(other.TotalNotional), - TotalQuantity: o.TotalQuantity.Add(other.TotalQuantity), - Settlements: append(o.Settlements, other.Settlements...), - MinPrice: sdk.MinDec(o.MinPrice, other.MinPrice), - MaxPrice: sdk.MaxDec(o.MaxPrice, other.MaxPrice), - } -} diff --git a/x/dex/exchange/helpers_test.go b/x/dex/exchange/helpers_test.go deleted file mode 100644 index 3b271c3896..0000000000 --- a/x/dex/exchange/helpers_test.go +++ /dev/null @@ -1,64 +0,0 @@ -package exchange_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/exchange" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMergeExecutionOutcomes(t *testing.T) { - s1 := types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - } - - s2 := types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - } - - e1 := exchange.ExecutionOutcome{ - TotalNotional: sdk.MustNewDecFromStr("1"), - TotalQuantity: sdk.MustNewDecFromStr("2"), - Settlements: []*types.SettlementEntry{&s1, &s2, &s1}, - MinPrice: sdk.MustNewDecFromStr("1"), - MaxPrice: sdk.MustNewDecFromStr("4"), - } - - e2 := exchange.ExecutionOutcome{ - TotalNotional: sdk.MustNewDecFromStr("4"), - TotalQuantity: sdk.MustNewDecFromStr("4"), - Settlements: []*types.SettlementEntry{&s1, &s2}, - MinPrice: sdk.MustNewDecFromStr("0.5"), - MaxPrice: sdk.MustNewDecFromStr("3"), - } - - outcome := e1.Merge(&e2) - - require.Equal(t, outcome.TotalNotional, sdk.MustNewDecFromStr("5")) - require.Equal(t, outcome.TotalQuantity, sdk.MustNewDecFromStr("6")) - require.Equal(t, len(outcome.Settlements), 5) - require.Equal(t, outcome.MinPrice, sdk.MustNewDecFromStr("0.5")) - require.Equal(t, outcome.MaxPrice, sdk.MustNewDecFromStr("4")) -} diff --git a/x/dex/exchange/limit_order.go b/x/dex/exchange/limit_order.go deleted file mode 100644 index 65f249d029..0000000000 --- a/x/dex/exchange/limit_order.go +++ /dev/null @@ -1,103 +0,0 @@ -package exchange - -import ( - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func MatchLimitOrders( - ctx sdk.Context, - orderbook *types.OrderBook, -) ExecutionOutcome { - settlements := []*types.SettlementEntry{} - totalExecuted, totalPrice := sdk.ZeroDec(), sdk.ZeroDec() - minPrice, maxPrice := sdk.OneDec().Neg(), sdk.OneDec().Neg() - - for longEntry, shortEntry := orderbook.Longs.Next(ctx), orderbook.Shorts.Next(ctx); longEntry != nil && shortEntry != nil && longEntry.GetPrice().GTE(shortEntry.GetPrice()); longEntry, shortEntry = orderbook.Longs.Next(ctx), orderbook.Shorts.Next(ctx) { - var executed sdk.Dec - if longEntry.GetOrderEntry().Quantity.LT(shortEntry.GetOrderEntry().Quantity) { - executed = longEntry.GetOrderEntry().Quantity - } else { - executed = shortEntry.GetOrderEntry().Quantity - } - totalExecuted = totalExecuted.Add(executed).Add(executed) - totalPrice = totalPrice.Add( - executed.Mul( - longEntry.GetPrice().Add(shortEntry.GetPrice()), - ), - ) - if minPrice.IsNegative() || minPrice.GT(shortEntry.GetPrice()) { - minPrice = shortEntry.GetPrice() - } - maxPrice = sdk.MaxDec(maxPrice, longEntry.GetPrice()) - - newSettlements := SettleFromBook( - ctx, - orderbook, - executed, - longEntry.GetPrice(), - shortEntry.GetPrice(), - ) - settlements = append(settlements, newSettlements...) - } - - orderbook.Longs.Flush(ctx) - orderbook.Shorts.Flush(ctx) - return ExecutionOutcome{ - TotalNotional: totalPrice, - TotalQuantity: totalExecuted, - Settlements: settlements, - MinPrice: minPrice, - MaxPrice: maxPrice, - } -} - -func addOrderToOrderBookEntry( - ctx sdk.Context, keeper *keeper.Keeper, - order *types.Order, -) { - getter, setter := keeper.GetLongOrderBookEntryByPrice, keeper.SetLongOrderBookEntry - if order.PositionDirection == types.PositionDirection_SHORT { - getter, setter = keeper.GetShortOrderBookEntryByPrice, keeper.SetShortOrderBookEntry - } - entry, exist := getter(ctx, order.ContractAddr, order.Price, order.PriceDenom, order.AssetDenom) - orderEntry := entry.GetOrderEntry() - if !exist { - orderEntry = &types.OrderEntry{ - Price: order.Price, - PriceDenom: order.PriceDenom, - AssetDenom: order.AssetDenom, - Quantity: sdk.ZeroDec(), - } - } - orderEntry.Quantity = orderEntry.Quantity.Add(order.Quantity) - orderEntry.Allocations = append(orderEntry.Allocations, &types.Allocation{ - OrderId: order.Id, - Quantity: order.Quantity, - Account: order.Account, - }) - entry.SetPrice(order.Price) - entry.SetEntry(orderEntry) - setter(ctx, order.ContractAddr, entry) - - err := keeper.IncreaseOrderCount(ctx, order.ContractAddr, order.PriceDenom, order.AssetDenom, order.PositionDirection, order.Price, 1) - if err != nil { - ctx.Logger().Error(fmt.Sprintf("error increasing order count: %s", err)) - } -} - -func AddOutstandingLimitOrdersToOrderbook( - ctx sdk.Context, keeper *keeper.Keeper, - limitBuys []*types.Order, - limitSells []*types.Order, -) { - for _, order := range limitBuys { - addOrderToOrderBookEntry(ctx, keeper, order) - } - for _, order := range limitSells { - addOrderToOrderBookEntry(ctx, keeper, order) - } -} diff --git a/x/dex/exchange/limit_order_fuzz_test.go b/x/dex/exchange/limit_order_fuzz_test.go deleted file mode 100644 index 3e14f31848..0000000000 --- a/x/dex/exchange/limit_order_fuzz_test.go +++ /dev/null @@ -1,55 +0,0 @@ -package exchange_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/testutil/fuzzing" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/exchange" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - keeperutil "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" - "github.com/tendermint/tendermint/libs/log" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -var TestFuzzLimitCtx = sdk.NewContext(nil, tmproto.Header{}, false, log.NewNopLogger()) -var TestFuzzLimitKeeper keeper.Keeper - -func FuzzMatchLimitOrders(f *testing.F) { - TestFuzzLimitCtx = TestFuzzLimitCtx.WithBlockHeight(1).WithBlockTime(time.Now()) - f.Fuzz(fuzzTargetMatchLimitOrders) -} - -func fuzzTargetMatchLimitOrders( - t *testing.T, - buyPrices []byte, - sellPrices []byte, - buyQuantities []byte, - sellQuantities []byte, - buyEntryWeights []byte, - sellEntryWeights []byte, - buyAccountIndices []byte, - sellAccountIndices []byte, - buyAllocationWeights []byte, - sellAllocationWeights []byte, -) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(1).WithBlockTime(time.Now()) - buyEntries := fuzzing.GetOrderBookEntries(true, keepertest.TestPriceDenom, keepertest.TestAssetDenom, buyEntryWeights, buyAccountIndices, buyAllocationWeights) - for _, entry := range buyEntries { - dexkeeper.SetLongOrderBookEntry(ctx, keepertest.TestContract, entry) - } - sellEntries := fuzzing.GetOrderBookEntries(false, keepertest.TestPriceDenom, keepertest.TestAssetDenom, sellEntryWeights, sellAccountIndices, sellAllocationWeights) - for _, entry := range sellEntries { - dexkeeper.SetShortOrderBookEntry(ctx, keepertest.TestContract, entry) - } - buyOrders := fuzzing.GetPlacedOrders(types.PositionDirection_LONG, types.OrderType_LIMIT, keepertest.TestPair, buyPrices, buyQuantities) - sellOrders := fuzzing.GetPlacedOrders(types.PositionDirection_SHORT, types.OrderType_LIMIT, keepertest.TestPair, sellPrices, sellQuantities) - exchange.AddOutstandingLimitOrdersToOrderbook(ctx, dexkeeper, buyOrders, sellOrders) - orderBook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress(keepertest.TestContract), types.Pair{PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}) - require.NotPanics(t, func() { exchange.MatchLimitOrders(ctx, orderBook) }) -} diff --git a/x/dex/exchange/limit_order_test.go b/x/dex/exchange/limit_order_test.go deleted file mode 100644 index f904ab91c4..0000000000 --- a/x/dex/exchange/limit_order_test.go +++ /dev/null @@ -1,1165 +0,0 @@ -package exchange_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/exchange" - keeperutil "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/assert" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" -) - -func TEST_PAIR() types.Pair { - return types.Pair{ - PriceDenom: "usdc", - AssetDenom: "atom", - } -} - -func TestMatchSingleOrder(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - } - shortOrders := []*types.Order{ - { - Id: 2, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "def", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - } - longBook := []types.OrderBookEntry{} - shortBook := []types.OrderBookEntry{} - exchange.AddOutstandingLimitOrdersToOrderbook(ctx, dexkeeper, longOrders, shortOrders) - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - outcome := exchange.MatchLimitOrders( - ctx, orderbook, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - assert.Equal(t, totalPrice, sdk.NewDec(1000)) - assert.Equal(t, totalExecuted, sdk.NewDec(10)) - assert.Equal(t, outcome.MaxPrice, sdk.NewDec(100)) - assert.Equal(t, outcome.MinPrice, sdk.NewDec(100)) - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, len(longBook), 0) - assert.Equal(t, len(shortBook), 0) - assert.Equal(t, len(settlements), 2) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) -} - -func TestAddOrders(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "def", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - { - Id: 2, - Price: sdk.NewDec(95), - Quantity: sdk.NewDec(3), - Account: "def", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - } - shortOrders := []*types.Order{ - { - Id: 3, - Price: sdk.NewDec(105), - Quantity: sdk.NewDec(10), - Account: "ghi", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - { - Id: 4, - Price: sdk.NewDec(115), - Quantity: sdk.NewDec(2), - Account: "mno", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - } - longBook := []types.OrderBookEntry{ - &types.LongBook{ - Price: sdk.NewDec(98), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(98), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "abc", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.LongBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "def", - Quantity: sdk.NewDec(3), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(101), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(101), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 7, - Account: "abc", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.ShortBook{ - Price: sdk.NewDec(115), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(115), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 8, - Account: "def", - Quantity: sdk.NewDec(3), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, e := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", e) - } - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - exchange.AddOutstandingLimitOrdersToOrderbook(ctx, dexkeeper, longOrders, shortOrders) - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - outcome := exchange.MatchLimitOrders( - ctx, orderbook, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - assert.Equal(t, totalPrice, sdk.NewDec(0)) - assert.Equal(t, totalExecuted, sdk.NewDec(0)) - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, len(longBook), 3) - assert.Equal(t, longBook[0].GetPrice(), sdk.NewDec(95)) - assert.Equal(t, *longBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(95), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 2, - Account: "def", - Quantity: sdk.NewDec(3), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, longBook[1].GetPrice(), sdk.NewDec(98)) - assert.Equal(t, *longBook[1].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(98), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "abc", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, longBook[2].GetPrice(), sdk.NewDec(100)) - assert.Equal(t, *longBook[2].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(8), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "def", - Quantity: sdk.NewDec(3), - }, { - OrderId: 1, - Account: "def", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(shortBook), 3) - assert.Equal(t, shortBook[0].GetPrice(), sdk.NewDec(101)) - assert.Equal(t, *shortBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(101), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 7, - Account: "abc", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, shortBook[1].GetPrice(), sdk.NewDec(105)) - assert.Equal(t, *shortBook[1].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(105), - Quantity: sdk.NewDec(10), - Allocations: []*types.Allocation{{ - OrderId: 3, - Account: "ghi", - Quantity: sdk.NewDec(10), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, shortBook[2].GetPrice(), sdk.NewDec(115)) - assert.Equal(t, *shortBook[2].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(115), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 8, - Account: "def", - Quantity: sdk.NewDec(3), - }, { - OrderId: 4, - Account: "mno", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(settlements), 0) -} - -func TestMatchSingleOrderFromShortBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - } - shortOrders := []*types.Order{} - longBook := []types.OrderBookEntry{} - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 2, - Account: "def", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, e := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", e) - } - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - exchange.AddOutstandingLimitOrdersToOrderbook(ctx, dexkeeper, longOrders, shortOrders) - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - outcome := exchange.MatchLimitOrders( - ctx, orderbook, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - assert.Equal(t, totalPrice, sdk.NewDec(1000)) - assert.Equal(t, totalExecuted, sdk.NewDec(10)) - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, len(longBook), 0) - assert.Equal(t, len(shortBook), 0) - assert.Equal(t, len(settlements), 2) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) -} - -func TestMatchSingleOrderFromLongBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{} - shortOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "def", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - } - longBook := []types.OrderBookEntry{ - &types.LongBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 2, - Account: "abc", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - shortBook := []types.OrderBookEntry{} - for _, e := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", e) - } - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - exchange.AddOutstandingLimitOrdersToOrderbook(ctx, dexkeeper, longOrders, shortOrders) - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - outcome := exchange.MatchLimitOrders( - ctx, orderbook, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - assert.Equal(t, totalPrice, sdk.NewDec(1000)) - assert.Equal(t, totalExecuted, sdk.NewDec(10)) - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, len(longBook), 0) - assert.Equal(t, len(shortBook), 0) - assert.Equal(t, len(settlements), 2) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) -} - -func TestMatchSingleOrderFromMultipleShortBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - } - shortOrders := []*types.Order{} - longBook := []types.OrderBookEntry{} - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(90), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(90), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 2, - Account: "def", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.ShortBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(6), - Allocations: []*types.Allocation{{ - OrderId: 3, - Account: "def", - Quantity: sdk.NewDec(4), - }, { - OrderId: 4, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, e := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", e) - } - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - exchange.AddOutstandingLimitOrdersToOrderbook(ctx, dexkeeper, longOrders, shortOrders) - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - outcome := exchange.MatchLimitOrders( - ctx, orderbook, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - assert.Equal(t, totalPrice, sdk.NewDec(980)) - assert.Equal(t, totalExecuted, sdk.NewDec(10)) - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, len(longBook), 0) - assert.Equal(t, len(shortBook), 1) - assert.Equal(t, shortBook[0].GetPrice(), sdk.NewDec(100)) - assert.Equal(t, *shortBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 3, - Account: "def", - Quantity: sdk.NewDec(1), - }, { - OrderId: 4, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(settlements), 4) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(2), - ExecutionCostOrProceed: sdk.NewDec(95), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(2), - ExecutionCostOrProceed: sdk.NewDec(95), - ExpectedCostOrProceed: sdk.NewDec(90), - Account: "def", - OrderType: "Limit", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[2], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(3), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[3], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(3), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 3, - Timestamp: TestTimestamp, - Height: TestHeight, - }) -} - -func TestMatchSingleOrderFromMultipleLongBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{} - shortOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "def", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - } - longBook := []types.OrderBookEntry{ - &types.LongBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(6), - Allocations: []*types.Allocation{{ - OrderId: 2, - Account: "abc", - Quantity: sdk.NewDec(4), - }, { - OrderId: 3, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.LongBook{ - Price: sdk.NewDec(110), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(110), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 4, - Account: "abc", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - shortBook := []types.OrderBookEntry{} - for _, e := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", e) - } - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - exchange.AddOutstandingLimitOrdersToOrderbook(ctx, dexkeeper, longOrders, shortOrders) - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - outcome := exchange.MatchLimitOrders( - ctx, orderbook, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - assert.Equal(t, totalPrice, sdk.NewDec(1020)) - assert.Equal(t, totalExecuted, sdk.NewDec(10)) - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, len(longBook), 1) - assert.Equal(t, longBook[0].GetPrice(), sdk.NewDec(100)) - assert.Equal(t, *longBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 2, - Account: "abc", - Quantity: sdk.NewDec(1), - }, { - OrderId: 3, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(shortBook), 0) - assert.Equal(t, len(settlements), 4) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(2), - ExecutionCostOrProceed: sdk.NewDec(105), - ExpectedCostOrProceed: sdk.NewDec(110), - Account: "abc", - OrderType: "Limit", - OrderId: 4, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(2), - ExecutionCostOrProceed: sdk.NewDec(105), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[2], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(3), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[3], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(3), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) -} - -func TestMatchMultipleOrderFromMultipleShortBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - { - Id: 2, - Price: sdk.NewDec(104), - Quantity: sdk.NewDec(1), - Account: "jkl", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - { - Id: 3, - Price: sdk.NewDec(98), - Quantity: sdk.NewDec(2), - Account: "mno", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - } - shortOrders := []*types.Order{} - longBook := []types.OrderBookEntry{} - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(90), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(90), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 4, - Account: "def", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.ShortBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(6), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "def", - Quantity: sdk.NewDec(4), - }, { - OrderId: 6, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, e := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", e) - } - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - exchange.AddOutstandingLimitOrdersToOrderbook(ctx, dexkeeper, longOrders, shortOrders) - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - outcome := exchange.MatchLimitOrders( - ctx, orderbook, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - assert.Equal(t, totalPrice, sdk.NewDec(1184)) - assert.Equal(t, totalExecuted, sdk.NewDec(12)) - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, len(longBook), 1) - assert.Equal(t, longBook[0].GetPrice(), sdk.NewDec(98)) - assert.Equal(t, *longBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(98), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 3, - Account: "mno", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(shortBook), 1) - assert.Equal(t, shortBook[0].GetPrice(), sdk.NewDec(100)) - assert.Equal(t, *shortBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(settlements), 6) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(97), - ExpectedCostOrProceed: sdk.NewDec(104), - Account: "jkl", - OrderType: "Limit", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(97), - ExpectedCostOrProceed: sdk.NewDec(90), - Account: "def", - OrderType: "Limit", - OrderId: 4, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[2], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(95), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[3], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(95), - ExpectedCostOrProceed: sdk.NewDec(90), - Account: "def", - OrderType: "Limit", - OrderId: 4, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[4], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(4), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[5], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(4), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 5, - Timestamp: TestTimestamp, - Height: TestHeight, - }) -} - -func TestMatchMultipleOrderFromMultipleLongBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{} - shortOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - { - Id: 2, - Price: sdk.NewDec(96), - Quantity: sdk.NewDec(1), - Account: "jkl", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - { - Id: 3, - Price: sdk.NewDec(102), - Quantity: sdk.NewDec(2), - Account: "mno", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - }, - } - longBook := []types.OrderBookEntry{ - &types.LongBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(6), - Allocations: []*types.Allocation{{ - OrderId: 4, - Account: "abc", - Quantity: sdk.NewDec(4), - }, { - OrderId: 5, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.LongBook{ - Price: sdk.NewDec(110), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(110), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "abc", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - shortBook := []types.OrderBookEntry{} - for _, e := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", e) - } - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - exchange.AddOutstandingLimitOrdersToOrderbook(ctx, dexkeeper, longOrders, shortOrders) - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - outcome := exchange.MatchLimitOrders( - ctx, orderbook, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - minPrice := outcome.MinPrice - maxPrice := outcome.MaxPrice - assert.Equal(t, totalPrice, sdk.NewDec(1216)) - assert.Equal(t, totalExecuted, sdk.NewDec(12)) - assert.Equal(t, minPrice, sdk.NewDec(96)) - assert.Equal(t, maxPrice, sdk.NewDec(110)) - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, len(longBook), 1) - assert.Equal(t, longBook[0].GetPrice(), sdk.NewDec(100)) - assert.Equal(t, *longBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(shortBook), 1) - assert.Equal(t, shortBook[0].GetPrice(), sdk.NewDec(102)) - assert.Equal(t, *shortBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(102), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 3, - Account: "mno", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(settlements), 6) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(103), - ExpectedCostOrProceed: sdk.NewDec(110), - Account: "abc", - OrderType: "Limit", - OrderId: 6, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(103), - ExpectedCostOrProceed: sdk.NewDec(96), - Account: "jkl", - OrderType: "Limit", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[2], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(105), - ExpectedCostOrProceed: sdk.NewDec(110), - Account: "abc", - OrderType: "Limit", - OrderId: 6, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[3], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(105), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[4], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(4), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 4, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[5], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(4), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) -} diff --git a/x/dex/exchange/market_order.go b/x/dex/exchange/market_order.go deleted file mode 100644 index c557ded25d..0000000000 --- a/x/dex/exchange/market_order.go +++ /dev/null @@ -1,273 +0,0 @@ -package exchange - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - cache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func MatchMarketOrders( - ctx sdk.Context, - marketOrders []*types.Order, - orderBookEntries *types.CachedSortedOrderBookEntries, - direction types.PositionDirection, - blockOrders *cache.BlockOrders, -) ExecutionOutcome { - totalExecuted, totalPrice := sdk.ZeroDec(), sdk.ZeroDec() - minPrice, maxPrice := sdk.OneDec().Neg(), sdk.OneDec().Neg() - settlements := []*types.SettlementEntry{} - allTakerSettlements := []*types.SettlementEntry{} - for _, marketOrder := range marketOrders { - switch marketOrder.OrderType { - case types.OrderType_FOKMARKETBYVALUE: - settlements, allTakerSettlements = MatchByValueFOKMarketOrder( - ctx, marketOrder, orderBookEntries, direction, &totalExecuted, &totalPrice, &minPrice, &maxPrice, settlements, allTakerSettlements, blockOrders) - case types.OrderType_FOKMARKET: - settlements, allTakerSettlements = MatchFOKMarketOrder( - ctx, marketOrder, orderBookEntries, direction, &totalExecuted, &totalPrice, &minPrice, &maxPrice, settlements, allTakerSettlements, blockOrders) - default: - settlements, allTakerSettlements = MatchMarketOrder( - ctx, marketOrder, orderBookEntries, direction, &totalExecuted, &totalPrice, &minPrice, &maxPrice, settlements, allTakerSettlements, blockOrders) - } - } - - if totalExecuted.IsPositive() { - clearingPrice := totalPrice.Quo(totalExecuted) - for _, settlement := range allTakerSettlements { - settlement.ExecutionCostOrProceed = clearingPrice - } - minPrice, maxPrice = clearingPrice, clearingPrice - settlements = append(settlements, allTakerSettlements...) - } - return ExecutionOutcome{ - TotalNotional: totalPrice, - TotalQuantity: totalExecuted, - Settlements: settlements, - MinPrice: minPrice, - MaxPrice: maxPrice, - } -} - -func MatchMarketOrder( - ctx sdk.Context, - marketOrder *types.Order, - orderBookEntries *types.CachedSortedOrderBookEntries, - direction types.PositionDirection, - totalExecuted *sdk.Dec, - totalPrice *sdk.Dec, - minPrice *sdk.Dec, - maxPrice *sdk.Dec, - settlements []*types.SettlementEntry, - allTakerSettlements []*types.SettlementEntry, - blockOrders *cache.BlockOrders, -) ([]*types.SettlementEntry, []*types.SettlementEntry) { - remainingQuantity := marketOrder.Quantity - for entry := orderBookEntries.Next(ctx); entry != nil; entry = orderBookEntries.Next(ctx) { - // If price is zero, it means the order sender - // doesn't want to specify a worst price, so - // we don't need to perform price check for such orders - if !marketOrder.Price.IsZero() { - // Check if worst price can be matched against order book - if (direction == types.PositionDirection_LONG && marketOrder.Price.LT(entry.GetPrice())) || - (direction == types.PositionDirection_SHORT && marketOrder.Price.GT(entry.GetPrice())) { - break - } - } - var executed sdk.Dec - if remainingQuantity.LTE(entry.GetOrderEntry().Quantity) { - executed = remainingQuantity - } else { - executed = entry.GetOrderEntry().Quantity - } - remainingQuantity = remainingQuantity.Sub(executed) - *totalExecuted = totalExecuted.Add(executed) - *totalPrice = totalPrice.Add( - executed.Mul(entry.GetPrice()), - ) - if minPrice.IsNegative() || minPrice.GT(entry.GetPrice()) { - *minPrice = entry.GetPrice() - } - *maxPrice = sdk.MaxDec(*maxPrice, entry.GetPrice()) - - takerSettlements, makerSettlements := Settle( - ctx, - marketOrder, - executed, - orderBookEntries, - marketOrder.Price, - entry.GetPrice(), - ) - // update the status of order in the memState - UpdateOrderData(marketOrder, executed, blockOrders) - settlements = append(settlements, makerSettlements...) - // taker settlements' clearing price will need to be adjusted after all market order executions finish - allTakerSettlements = append(allTakerSettlements, takerSettlements...) - if remainingQuantity.IsZero() { - break - } - } - - orderBookEntries.Flush(ctx) - - return settlements, allTakerSettlements -} - -func MatchFOKMarketOrder( - ctx sdk.Context, - marketOrder *types.Order, - orderBookEntries *types.CachedSortedOrderBookEntries, - direction types.PositionDirection, - totalExecuted *sdk.Dec, - totalPrice *sdk.Dec, - minPrice *sdk.Dec, - maxPrice *sdk.Dec, - settlements []*types.SettlementEntry, - allTakerSettlements []*types.SettlementEntry, - blockOrders *cache.BlockOrders, -) ([]*types.SettlementEntry, []*types.SettlementEntry) { - // check if there is enough liquidity for fill-or-kill market order, if not skip them - remainingQuantity := marketOrder.Quantity - newSettlements, newTakerSettlements := []*types.SettlementEntry{}, []*types.SettlementEntry{} - orders, executedQuantities, entryPrices := []*types.Order{}, []sdk.Dec{}, []sdk.Dec{} - for entry := orderBookEntries.Next(ctx); entry != nil; entry = orderBookEntries.Next(ctx) { - if !marketOrder.Price.IsZero() { - if (direction == types.PositionDirection_LONG && marketOrder.Price.LT(entry.GetPrice())) || - (direction == types.PositionDirection_SHORT && marketOrder.Price.GT(entry.GetPrice())) { - break - } - } - - var executed sdk.Dec - if remainingQuantity.LTE(entry.GetOrderEntry().Quantity) { - executed = remainingQuantity - } else { - executed = entry.GetOrderEntry().Quantity - } - remainingQuantity = remainingQuantity.Sub(executed) - - takerSettlements, makerSettlements := Settle( - ctx, - marketOrder, - executed, - orderBookEntries, - marketOrder.Price, - entry.GetPrice(), - ) - newSettlements = append(newSettlements, makerSettlements...) - newTakerSettlements = append(newTakerSettlements, takerSettlements...) - orders = append(orders, marketOrder) - executedQuantities = append(executedQuantities, executed) - entryPrices = append(entryPrices, entry.GetPrice()) - - if remainingQuantity.IsZero() { - break - } - } - - if remainingQuantity.IsZero() { - orderBookEntries.Flush(ctx) - settlements = append(settlements, newSettlements...) - allTakerSettlements = append(allTakerSettlements, newTakerSettlements...) - for i, order := range orders { - UpdateOrderData(order, executedQuantities[i], blockOrders) - *totalExecuted = totalExecuted.Add(executedQuantities[i]) - *totalPrice = totalPrice.Add( - executedQuantities[i].Mul(entryPrices[i]), - ) - if minPrice.IsNegative() || minPrice.GT(entryPrices[i]) { - *minPrice = entryPrices[i] - } - *maxPrice = sdk.MaxDec(*maxPrice, entryPrices[i]) - } - } else { - orderBookEntries.Refresh(ctx) - } - - return settlements, allTakerSettlements -} - -func MatchByValueFOKMarketOrder( - ctx sdk.Context, - marketOrder *types.Order, - orderBookEntries *types.CachedSortedOrderBookEntries, - direction types.PositionDirection, - totalExecuted *sdk.Dec, - totalPrice *sdk.Dec, - minPrice *sdk.Dec, - maxPrice *sdk.Dec, - settlements []*types.SettlementEntry, - allTakerSettlements []*types.SettlementEntry, - blockOrders *cache.BlockOrders, -) ([]*types.SettlementEntry, []*types.SettlementEntry) { - remainingFund := marketOrder.Nominal - remainingQuantity := marketOrder.Quantity - newSettlements, newTakerSettlements := []*types.SettlementEntry{}, []*types.SettlementEntry{} - orders, executedQuantities, entryPrices := []*types.Order{}, []sdk.Dec{}, []sdk.Dec{} - for entry := orderBookEntries.Next(ctx); entry != nil; entry = orderBookEntries.Next(ctx) { - if !marketOrder.Price.IsZero() { - if (direction == types.PositionDirection_LONG && marketOrder.Price.LT(entry.GetPrice())) || - (direction == types.PositionDirection_SHORT && marketOrder.Price.GT(entry.GetPrice())) { - break - } - } - var executed sdk.Dec - if remainingFund.LTE(entry.GetOrderEntry().Quantity.Mul(entry.GetPrice())) { - executed = remainingFund.Quo(entry.GetPrice()) - remainingFund = sdk.ZeroDec() - } else { - executed = entry.GetOrderEntry().Quantity - remainingFund = remainingFund.Sub(executed.Mul(entry.GetPrice())) - } - remainingQuantity = remainingQuantity.Sub(executed) - - takerSettlements, makerSettlements := Settle( - ctx, - marketOrder, - executed, - orderBookEntries, - marketOrder.Price, - entry.GetPrice(), - ) - newSettlements = append(newSettlements, makerSettlements...) - newTakerSettlements = MergeByNominalTakerSettlements(append(newTakerSettlements, takerSettlements...)) - orders = append(orders, marketOrder) - executedQuantities = append(executedQuantities, executed) - entryPrices = append(entryPrices, entry.GetPrice()) - if remainingFund.IsZero() || remainingQuantity.LTE(sdk.ZeroDec()) { - break - } - } - - // settle orders only when all fund are used - if remainingFund.IsZero() && remainingQuantity.GTE(sdk.ZeroDec()) { - orderBookEntries.Flush(ctx) - settlements = append(settlements, newSettlements...) - allTakerSettlements = append(allTakerSettlements, newTakerSettlements...) - for i, order := range orders { - UpdateOrderData(order, executedQuantities[i], blockOrders) - *totalExecuted = totalExecuted.Add(executedQuantities[i]) - *totalPrice = totalPrice.Add( - executedQuantities[i].Mul(entryPrices[i]), - ) - if minPrice.IsNegative() || minPrice.GT(entryPrices[i]) { - *minPrice = entryPrices[i] - } - *maxPrice = sdk.MaxDec(*maxPrice, entryPrices[i]) - } - } else { - orderBookEntries.Refresh(ctx) - } - - return settlements, allTakerSettlements -} - -func MergeByNominalTakerSettlements(settlements []*types.SettlementEntry) []*types.SettlementEntry { - aggregatedSettlement := types.SettlementEntry{Quantity: sdk.ZeroDec()} - for _, settlement := range settlements { - quantity := settlement.Quantity.Add(aggregatedSettlement.Quantity) - aggregatedSettlement = *settlement - aggregatedSettlement.Quantity = quantity - } - - return []*types.SettlementEntry{&aggregatedSettlement} -} diff --git a/x/dex/exchange/market_order_fuzz_test.go b/x/dex/exchange/market_order_fuzz_test.go deleted file mode 100644 index 2cc64f4466..0000000000 --- a/x/dex/exchange/market_order_fuzz_test.go +++ /dev/null @@ -1,92 +0,0 @@ -package exchange_test - -import ( - "sort" - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/testutil/fuzzing" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/exchange" - keeperutil "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/stretchr/testify/require" - "github.com/tendermint/tendermint/libs/log" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -var TestFuzzMarketCtx = sdk.NewContext(nil, tmproto.Header{}, false, log.NewNopLogger()) - -func FuzzMatchMarketOrders(f *testing.F) { - f.Fuzz(fuzzTargetMatchMarketOrders) -} - -func fuzzTargetMatchMarketOrders( - t *testing.T, - takerLong bool, - orderSorted bool, - orderbookSorted bool, - prices []byte, - quantities []byte, - entryWeights []byte, - accountIndices []byte, - allocationWeights []byte, -) { - dexkeeper, TestFuzzMarketCtx := keepertest.DexKeeper(t) - TestFuzzMarketCtx = TestFuzzMarketCtx.WithBlockHeight(1).WithBlockTime(time.Now()) - blockOrders := dexutils.GetMemState(TestFuzzMarketCtx.Context()).GetBlockOrders(TestFuzzMarketCtx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := fuzzing.GetOrderBookEntries(!takerLong, keepertest.TestPriceDenom, keepertest.TestAssetDenom, entryWeights, accountIndices, allocationWeights) - for _, entry := range entries { - if takerLong { - dexkeeper.SetShortOrderBookEntry(TestFuzzMarketCtx, keepertest.TestContract, entry) - } else { - dexkeeper.SetLongOrderBookEntry(TestFuzzMarketCtx, keepertest.TestContract, entry) - } - } - var direction types.PositionDirection - if takerLong { - direction = types.PositionDirection_LONG - } else { - direction = types.PositionDirection_SHORT - } - orders := fuzzing.GetPlacedOrders(direction, types.OrderType_MARKET, keepertest.TestPair, prices, quantities) - for _, order := range orders { - blockOrders.Add(order) - } - - if orderSorted { - sort.Slice(orders, func(i, j int) bool { - // a price of 0 indicates that there is no worst price for the order, so it should - // always be ranked at the top. - if orders[i].Price.IsZero() { - return true - } else if orders[j].Price.IsZero() { - return false - } - switch direction { - case types.PositionDirection_LONG: - return orders[i].Price.GT(orders[j].Price) - case types.PositionDirection_SHORT: - return orders[i].Price.LT(orders[j].Price) - default: - panic("Unknown direction") - } - }) - } - if orderbookSorted { - sort.Slice(entries, func(i, j int) bool { - return entries[i].GetPrice().LT(entries[j].GetPrice()) - }) - } - - require.NotPanics(t, func() { - orderbook := keeperutil.PopulateOrderbook(TestFuzzMarketCtx, dexkeeper, types.ContractAddress(keepertest.TestContract), types.Pair{PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}) - book := orderbook.Longs - if takerLong { - book = orderbook.Shorts - } - exchange.MatchMarketOrders(TestFuzzMarketCtx, orders, book, direction, blockOrders) - }) -} diff --git a/x/dex/exchange/market_order_test.go b/x/dex/exchange/market_order_test.go deleted file mode 100644 index 86339654b8..0000000000 --- a/x/dex/exchange/market_order_test.go +++ /dev/null @@ -1,1175 +0,0 @@ -package exchange_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - dex "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/exchange" - keeperutil "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/stretchr/testify/assert" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" -) - -const ( - TestTimestamp uint64 = 10000 - TestHeight uint64 = 1 -) - -func TestMatchFoKMarketOrderFromShortBookNotEnoughLiquidity(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_FOKMARKET, - }, - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(4), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "def", - Quantity: sdk.NewDec(4), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - blockOrders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - blockOrders.Add(&types.Order{ - Id: 1, - Account: "abc", - ContractAddr: "test", - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_FOKMARKET, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }) - - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := orderbook.Shorts - outcome := exchange.MatchMarketOrders( - ctx, longOrders, entries, types.PositionDirection_LONG, blockOrders, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, totalPrice, sdk.ZeroDec()) - assert.Equal(t, totalExecuted, sdk.ZeroDec()) - assert.Equal(t, len(shortBook), 1) - assert.Equal(t, shortBook[0].GetPrice(), sdk.NewDec(100)) - assert.Equal(t, shortBook[0].GetOrderEntry().Quantity, sdk.NewDec(4)) - assert.Equal(t, len(settlements), 0) - assert.Equal(t, blockOrders.Get()[0].Quantity, sdk.NewDec(5)) - assert.Equal(t, blockOrders.Get()[0].Status, types.OrderStatus_PLACED) -} - -func TestMatchFoKMarketOrderFromShortBookHappyPath(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_FOKMARKET, - }, - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "def", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := orderbook.Shorts - blockOrders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - blockOrders.Add(&types.Order{ - Id: 1, - Account: "abc", - ContractAddr: "test", - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_FOKMARKET, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }) - outcome := exchange.MatchMarketOrders( - ctx, longOrders, entries, types.PositionDirection_LONG, blockOrders, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, totalPrice, sdk.NewDec(500)) - assert.Equal(t, totalExecuted, sdk.NewDec(5)) - assert.Equal(t, len(shortBook), 0) - assert.Equal(t, len(settlements), 2) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 5, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Fokmarket", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, blockOrders.Get()[0].Quantity, sdk.ZeroDec()) - assert.Equal(t, blockOrders.Get()[0].Status, types.OrderStatus_FULFILLED) -} - -func TestMatchByValueFOKMarketOrderFromShortBookNotEnoughLiquidity(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_FOKMARKETBYVALUE, - Nominal: sdk.NewDec(500), - }, - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(90), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(90), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 4, - Account: "def", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.ShortBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.MustNewDecFromStr("0.4"), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "def", - Quantity: sdk.MustNewDecFromStr("0.4"), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - blockOrders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - blockOrders.Add(longOrders[0]) - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := orderbook.Shorts - outcome := exchange.MatchMarketOrders( - ctx, longOrders, entries, types.PositionDirection_LONG, &dex.BlockOrders{}, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, totalPrice, sdk.ZeroDec()) - assert.Equal(t, totalExecuted, sdk.ZeroDec()) - assert.Equal(t, len(shortBook), 2) - assert.Equal(t, shortBook[0].GetPrice(), sdk.NewDec(90)) - assert.Equal(t, shortBook[0].GetOrderEntry().Price, sdk.NewDec(90)) - assert.Equal(t, shortBook[0].GetOrderEntry().Quantity, sdk.NewDec(5)) - assert.Equal(t, len(settlements), 0) - assert.Equal(t, blockOrders.Get()[0].Quantity, sdk.NewDec(5)) - assert.Equal(t, blockOrders.Get()[0].Status, types.OrderStatus_PLACED) -} - -func TestMatchByValueFOKMarketOrderFromShortBookHappyPath(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(6), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_FOKMARKETBYVALUE, - Nominal: sdk.NewDec(500), - }, - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(90), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(90), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 4, - Account: "def", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.ShortBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.MustNewDecFromStr("0.6"), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "def", - Quantity: sdk.MustNewDecFromStr("0.6"), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - blockOrders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - blockOrders.Add(longOrders[0]) - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := orderbook.Shorts - outcome := exchange.MatchMarketOrders( - ctx, longOrders, entries, types.PositionDirection_LONG, blockOrders, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, totalPrice, sdk.NewDec(500)) - assert.Equal(t, totalExecuted, sdk.MustNewDecFromStr("5.5")) - assert.Equal(t, len(shortBook), 1) - assert.Equal(t, len(settlements), 3) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(90), - ExpectedCostOrProceed: sdk.NewDec(90), - Account: "def", - OrderType: "Limit", - OrderId: 4, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.MustNewDecFromStr("0.5"), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 5, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, blockOrders.Get()[0].Quantity, sdk.MustNewDecFromStr("0.5")) - assert.Equal(t, blockOrders.Get()[0].Status, types.OrderStatus_FULFILLED) -} - -func TestMatchSingleMarketOrderFromShortBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_MARKET, - }, - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "def", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - blockOrders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - blockOrders.Add(longOrders[0]) - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := orderbook.Shorts - outcome := exchange.MatchMarketOrders( - ctx, longOrders, entries, types.PositionDirection_LONG, blockOrders, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, totalPrice, sdk.NewDec(500)) - assert.Equal(t, totalExecuted, sdk.NewDec(5)) - assert.Equal(t, len(shortBook), 0) - assert.Equal(t, len(settlements), 2) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 5, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Market", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, blockOrders.Get()[0].Quantity, sdk.ZeroDec()) - assert.Equal(t, blockOrders.Get()[0].Status, types.OrderStatus_FULFILLED) -} - -func TestMatchSingleMarketOrderFromLongBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - shortOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_MARKET, - }, - } - longBook := []types.OrderBookEntry{ - &types.LongBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "def", - Quantity: sdk.NewDec(5), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - blockOrders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - blockOrders.Add(shortOrders[0]) - for _, e := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", e) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := orderbook.Longs - outcome := exchange.MatchMarketOrders( - ctx, shortOrders, entries, types.PositionDirection_SHORT, blockOrders, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, totalPrice, sdk.NewDec(500)) - assert.Equal(t, totalExecuted, sdk.NewDec(5)) - assert.Equal(t, len(longBook), 0) - assert.Equal(t, len(settlements), 2) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 5, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(5), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Market", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, blockOrders.Get()[0].Quantity, sdk.ZeroDec()) - assert.Equal(t, blockOrders.Get()[0].Status, types.OrderStatus_FULFILLED) -} - -func TestMatchSingleMarketOrderFromMultipleShortBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_MARKET, - }, - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(90), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(90), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "def", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.ShortBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(6), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "def", - Quantity: sdk.NewDec(4), - }, { - OrderId: 7, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - blockOrders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - blockOrders.Add(longOrders[0]) - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := orderbook.Shorts - outcome := exchange.MatchMarketOrders( - ctx, longOrders, entries, types.PositionDirection_LONG, blockOrders, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, totalPrice, sdk.NewDec(480)) - assert.Equal(t, totalExecuted, sdk.NewDec(5)) - assert.Equal(t, len(shortBook), 1) - assert.Equal(t, shortBook[0].GetPrice(), sdk.NewDec(100)) - assert.Equal(t, *shortBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "def", - Quantity: sdk.NewDec(1), - }, { - OrderId: 7, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(settlements), 4) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(2), - ExecutionCostOrProceed: sdk.NewDec(90), - ExpectedCostOrProceed: sdk.NewDec(90), - Account: "def", - OrderType: "Limit", - OrderId: 5, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(3), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 6, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[2], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(2), - ExecutionCostOrProceed: sdk.NewDec(96), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Market", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[3], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(3), - ExecutionCostOrProceed: sdk.NewDec(96), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Market", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, blockOrders.Get()[0].Quantity, sdk.ZeroDec()) - assert.Equal(t, blockOrders.Get()[0].Status, types.OrderStatus_FULFILLED) -} - -func TestMatchSingleMarketOrderFromMultipleLongBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - shortOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "def", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_MARKET, - }, - } - longBook := []types.OrderBookEntry{ - &types.LongBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(6), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "abc", - Quantity: sdk.NewDec(4), - }, { - OrderId: 7, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.LongBook{ - Price: sdk.NewDec(110), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(110), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "abc", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - blockOrders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - blockOrders.Add(shortOrders[0]) - for _, e := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", e) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := orderbook.Longs - outcome := exchange.MatchMarketOrders( - ctx, shortOrders, entries, types.PositionDirection_SHORT, blockOrders, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, totalPrice, sdk.NewDec(520)) - assert.Equal(t, totalExecuted, sdk.NewDec(5)) - assert.Equal(t, len(longBook), 1) - assert.Equal(t, longBook[0].GetPrice(), sdk.NewDec(100)) - assert.Equal(t, *longBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(3), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "abc", - Quantity: sdk.NewDec(1), - }, { - OrderId: 7, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(settlements), 4) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(2), - ExecutionCostOrProceed: sdk.NewDec(110), - ExpectedCostOrProceed: sdk.NewDec(110), - Account: "abc", - OrderType: "Limit", - OrderId: 5, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(3), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 6, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[2], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(2), - ExecutionCostOrProceed: sdk.NewDec(104), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Market", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[3], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(3), - ExecutionCostOrProceed: sdk.NewDec(104), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Market", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, blockOrders.Get()[0].Quantity, sdk.ZeroDec()) - assert.Equal(t, blockOrders.Get()[0].Status, types.OrderStatus_FULFILLED) -} - -func TestMatchMultipleMarketOrderFromMultipleShortBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - longOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(104), - Quantity: sdk.NewDec(1), - Account: "jkl", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_MARKET, - }, - { - Id: 2, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_MARKET, - }, - { - Id: 3, - Price: sdk.NewDec(98), - Quantity: sdk.NewDec(2), - Account: "mno", - PositionDirection: types.PositionDirection_LONG, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_MARKET, - }, - } - shortBook := []types.OrderBookEntry{ - &types.ShortBook{ - Price: sdk.NewDec(90), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(90), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 4, - Account: "def", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.ShortBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(6), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "def", - Quantity: sdk.NewDec(4), - }, { - OrderId: 6, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - blockOrders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - blockOrders.Add(longOrders[0]) - blockOrders.Add(longOrders[1]) - blockOrders.Add(longOrders[2]) - for _, e := range shortBook { - dexkeeper.SetShortOrderBookEntry(ctx, "test", e) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := orderbook.Shorts - outcome := exchange.MatchMarketOrders( - ctx, longOrders, entries, types.PositionDirection_LONG, blockOrders, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - - shortBook = dexkeeper.GetAllShortBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, totalPrice, sdk.NewDec(580)) - assert.Equal(t, totalExecuted, sdk.NewDec(6)) - assert.Equal(t, len(shortBook), 1) - assert.Equal(t, shortBook[0].GetPrice(), sdk.NewDec(100)) - assert.Equal(t, *shortBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(settlements), 6) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(90), - ExpectedCostOrProceed: sdk.NewDec(90), - Account: "def", - OrderType: "Limit", - OrderId: 4, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(90), - ExpectedCostOrProceed: sdk.NewDec(90), - Account: "def", - OrderType: "Limit", - OrderId: 4, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[2], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(4), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "def", - OrderType: "Limit", - OrderId: 5, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[3], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.MustNewDecFromStr("96.666666666666666667"), - ExpectedCostOrProceed: sdk.NewDec(104), - Account: "jkl", - OrderType: "Market", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[4], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.MustNewDecFromStr("96.666666666666666667"), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Market", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[5], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(4), - ExecutionCostOrProceed: sdk.MustNewDecFromStr("96.666666666666666667"), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Market", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, blockOrders.Get()[0].Quantity, sdk.ZeroDec()) - assert.Equal(t, blockOrders.Get()[0].Status, types.OrderStatus_FULFILLED) - assert.Equal(t, blockOrders.Get()[1].Quantity, sdk.ZeroDec()) - assert.Equal(t, blockOrders.Get()[1].Status, types.OrderStatus_FULFILLED) - assert.Equal(t, blockOrders.Get()[2].Quantity, sdk.NewDec(2)) - assert.Equal(t, blockOrders.Get()[2].Status, types.OrderStatus_PLACED) -} - -func TestMatchMultipleMarketOrderFromMultipleLongBook(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(int64(TestHeight)).WithBlockTime(time.Unix(int64(TestTimestamp), 0)) - shortOrders := []*types.Order{ - { - Id: 1, - Price: sdk.NewDec(96), - Quantity: sdk.NewDec(1), - Account: "jkl", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_MARKET, - }, - { - Id: 2, - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(5), - Account: "abc", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_MARKET, - }, - { - Id: 3, - Price: sdk.NewDec(102), - Quantity: sdk.NewDec(2), - Account: "mno", - PositionDirection: types.PositionDirection_SHORT, - ContractAddr: "test", - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_MARKET, - }, - } - longBook := []types.OrderBookEntry{ - &types.LongBook{ - Price: sdk.NewDec(100), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(6), - Allocations: []*types.Allocation{{ - OrderId: 5, - Account: "abc", - Quantity: sdk.NewDec(4), - }, { - OrderId: 6, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - &types.LongBook{ - Price: sdk.NewDec(110), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(110), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 4, - Account: "abc", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - } - blockOrders := dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, "testAccount", types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - blockOrders.Add(shortOrders[0]) - blockOrders.Add(shortOrders[1]) - blockOrders.Add(shortOrders[2]) - for _, e := range longBook { - dexkeeper.SetLongOrderBookEntry(ctx, "test", e) - } - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress("test"), types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"}) - entries := orderbook.Longs - outcome := exchange.MatchMarketOrders( - ctx, shortOrders, entries, types.PositionDirection_SHORT, blockOrders, - ) - totalPrice := outcome.TotalNotional - totalExecuted := outcome.TotalQuantity - settlements := outcome.Settlements - minPrice := outcome.MinPrice - maxPrice := outcome.MaxPrice - - longBook = dexkeeper.GetAllLongBookForPair(ctx, "test", "USDC", "ATOM") - assert.Equal(t, totalPrice, sdk.NewDec(620)) - assert.Equal(t, totalExecuted, sdk.NewDec(6)) - assert.Equal(t, minPrice, sdk.MustNewDecFromStr("103.333333333333333333")) - assert.Equal(t, maxPrice, sdk.MustNewDecFromStr("103.333333333333333333")) - assert.Equal(t, len(longBook), 1) - assert.Equal(t, longBook[0].GetPrice(), sdk.NewDec(100)) - assert.Equal(t, *longBook[0].GetOrderEntry(), types.OrderEntry{ - Price: sdk.NewDec(100), - Quantity: sdk.NewDec(2), - Allocations: []*types.Allocation{{ - OrderId: 6, - Account: "ghi", - Quantity: sdk.NewDec(2), - }}, - PriceDenom: "USDC", - AssetDenom: "ATOM", - }) - assert.Equal(t, len(settlements), 6) - assert.Equal(t, *settlements[0], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(110), - ExpectedCostOrProceed: sdk.NewDec(110), - Account: "abc", - OrderType: "Limit", - OrderId: 4, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[1], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.NewDec(110), - ExpectedCostOrProceed: sdk.NewDec(110), - Account: "abc", - OrderType: "Limit", - OrderId: 4, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[2], types.SettlementEntry{ - PositionDirection: "Long", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(4), - ExecutionCostOrProceed: sdk.NewDec(100), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Limit", - OrderId: 5, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[3], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.MustNewDecFromStr("103.333333333333333333"), - ExpectedCostOrProceed: sdk.NewDec(96), - Account: "jkl", - OrderType: "Market", - OrderId: 1, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[4], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(1), - ExecutionCostOrProceed: sdk.MustNewDecFromStr("103.333333333333333333"), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Market", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, *settlements[5], types.SettlementEntry{ - PositionDirection: "Short", - PriceDenom: "USDC", - AssetDenom: "ATOM", - Quantity: sdk.NewDec(4), - ExecutionCostOrProceed: sdk.MustNewDecFromStr("103.333333333333333333"), - ExpectedCostOrProceed: sdk.NewDec(100), - Account: "abc", - OrderType: "Market", - OrderId: 2, - Timestamp: TestTimestamp, - Height: TestHeight, - }) - assert.Equal(t, blockOrders.Get()[0].Quantity, sdk.ZeroDec()) - assert.Equal(t, blockOrders.Get()[0].Status, types.OrderStatus_FULFILLED) - assert.Equal(t, blockOrders.Get()[1].Quantity, sdk.ZeroDec()) - assert.Equal(t, blockOrders.Get()[1].Status, types.OrderStatus_FULFILLED) - assert.Equal(t, blockOrders.Get()[2].Quantity, sdk.NewDec(2)) - assert.Equal(t, blockOrders.Get()[2].Status, types.OrderStatus_PLACED) -} diff --git a/x/dex/exchange/settlement.go b/x/dex/exchange/settlement.go deleted file mode 100644 index fe049808ed..0000000000 --- a/x/dex/exchange/settlement.go +++ /dev/null @@ -1,129 +0,0 @@ -package exchange - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - cache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -// this function helps to settle market orders -func Settle( - ctx sdk.Context, - takerOrder *types.Order, - quantityTaken sdk.Dec, - orderbook *types.CachedSortedOrderBookEntries, - worstPrice sdk.Dec, - makerPrice sdk.Dec, -) ([]*types.SettlementEntry, []*types.SettlementEntry) { - // settlement of one liquidity taker's order is allocated on a FIFO basis - takerSettlements := []*types.SettlementEntry{} - makerSettlements := []*types.SettlementEntry{} - if quantityTaken.IsZero() { - return takerSettlements, makerSettlements - } - newToSettle, _ := orderbook.SettleQuantity(ctx, quantityTaken) - for _, toSettle := range newToSettle { - takerSettlements = append(takerSettlements, types.NewSettlementEntry( - ctx, - takerOrder.Id, - takerOrder.Account, - takerOrder.PositionDirection, - takerOrder.PriceDenom, - takerOrder.AssetDenom, - toSettle.Amount, - worstPrice, - worstPrice, - takerOrder.OrderType, - )) - makerSettlements = append(makerSettlements, types.NewSettlementEntry( - ctx, - toSettle.OrderID, - toSettle.Account, - types.OppositePositionDirection[takerOrder.PositionDirection], - takerOrder.PriceDenom, - takerOrder.AssetDenom, - toSettle.Amount, - makerPrice, - makerPrice, - types.OrderType_LIMIT, - )) - } - - return takerSettlements, makerSettlements -} - -// this function update the order data in the memState -// to be noted that the order status will only reflect for market orders that are settled -func UpdateOrderData( - takerOrder *types.Order, - quantityTaken sdk.Dec, - blockOrders *cache.BlockOrders, -) { - // update order data in the memstate - orderStored := blockOrders.GetByID(takerOrder.Id) - orderStored.Quantity = orderStored.Quantity.Sub(quantityTaken) - if orderStored.OrderType == types.OrderType_FOKMARKET || orderStored.OrderType == types.OrderType_FOKMARKETBYVALUE || orderStored.Quantity.IsZero() { - orderStored.Status = types.OrderStatus_FULFILLED - } - blockOrders.Add(orderStored) -} - -func SettleFromBook( - ctx sdk.Context, - orderbook *types.OrderBook, - executedQuantity sdk.Dec, - longPrice sdk.Dec, - shortPrice sdk.Dec, -) []*types.SettlementEntry { - // settlement from within the order book is also allocated on a FIFO basis - settlements := []*types.SettlementEntry{} - if executedQuantity.IsZero() { - return settlements - } - newLongToSettle, _ := orderbook.Longs.SettleQuantity(ctx, executedQuantity) - newShortToSettle, _ := orderbook.Shorts.SettleQuantity(ctx, executedQuantity) - avgPrice := longPrice.Add(shortPrice).Quo(sdk.NewDec(2)) - longPtr, shortPtr := 0, 0 - for longPtr < len(newLongToSettle) && shortPtr < len(newShortToSettle) { - longToSettle := newLongToSettle[longPtr] - shortToSettle := newShortToSettle[shortPtr] - var quantity sdk.Dec - if longToSettle.Amount.LT(shortToSettle.Amount) { - quantity = longToSettle.Amount - } else { - quantity = shortToSettle.Amount - } - settlements = append(settlements, types.NewSettlementEntry( - ctx, - longToSettle.OrderID, - longToSettle.Account, - types.PositionDirection_LONG, - orderbook.Pair.PriceDenom, - orderbook.Pair.AssetDenom, - quantity, - avgPrice, - longPrice, - types.OrderType_LIMIT, - ), types.NewSettlementEntry( - ctx, - shortToSettle.OrderID, - shortToSettle.Account, - types.PositionDirection_SHORT, - orderbook.Pair.PriceDenom, - orderbook.Pair.AssetDenom, - quantity, - avgPrice, - shortPrice, - types.OrderType_LIMIT, - )) - newLongToSettle[longPtr] = types.ToSettle{Account: longToSettle.Account, Amount: longToSettle.Amount.Sub(quantity), OrderID: longToSettle.OrderID} - newShortToSettle[shortPtr] = types.ToSettle{Account: shortToSettle.Account, Amount: shortToSettle.Amount.Sub(quantity), OrderID: shortToSettle.OrderID} - if newLongToSettle[longPtr].Amount.IsZero() { - longPtr++ - } - if newShortToSettle[shortPtr].Amount.IsZero() { - shortPtr++ - } - } - return settlements -} diff --git a/x/dex/exchange/settlement_fuzz_test.go b/x/dex/exchange/settlement_fuzz_test.go deleted file mode 100644 index afa1df5fb5..0000000000 --- a/x/dex/exchange/settlement_fuzz_test.go +++ /dev/null @@ -1,118 +0,0 @@ -package exchange_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/testutil/fuzzing" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/exchange" - keeperutil "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" - "github.com/tendermint/tendermint/libs/log" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -var TestFuzzSettleCtx = sdk.NewContext(nil, tmproto.Header{}, false, log.NewNopLogger()) - -func FuzzSettleMarketOrder(f *testing.F) { - TestFuzzSettleCtx = TestFuzzSettleCtx.WithBlockHeight(1).WithBlockTime(time.Now()) - f.Fuzz(fuzzTargetMatchMarketOrders) -} - -func fuzzTargetSettle( - t *testing.T, - long bool, - prices []byte, - quantities []byte, - entryWeights []byte, - accountIndices []byte, - allocationWeights []byte, - priceI int64, - priceIsNil bool, - quantityI int64, - quantityIsNil bool, -) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(1).WithBlockTime(time.Now()) - entries := fuzzing.GetOrderBookEntries(!long, keepertest.TestPriceDenom, keepertest.TestAssetDenom, entryWeights, accountIndices, allocationWeights) - for _, entry := range entries { - if long { - dexkeeper.SetShortOrderBookEntry(ctx, keepertest.TestContract, entry) - } else { - dexkeeper.SetLongOrderBookEntry(ctx, keepertest.TestContract, entry) - } - } - var direction types.PositionDirection - if long { - direction = types.PositionDirection_LONG - } else { - direction = types.PositionDirection_SHORT - } - orders := fuzzing.GetPlacedOrders(direction, types.OrderType_MARKET, keepertest.TestPair, prices, quantities) - - price := fuzzing.FuzzDec(priceI, priceIsNil) - quantity := fuzzing.FuzzDec(quantityI, quantityIsNil) - - if len(entries) > len(orders) { - entries = entries[:len(orders)] - } else { - orders = orders[:len(entries)] - } - - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress(keepertest.TestContract), types.Pair{PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}) - book := orderbook.Longs - if long { - book = orderbook.Shorts - } - for i, entry := range entries { - require.NotPanics(t, func() { - exchange.Settle(ctx, orders[i], quantity, book, price, entry.GetPrice()) - }) - } -} - -func FuzzSettleLimitOrder(f *testing.F) { - TestFuzzSettleCtx = TestFuzzSettleCtx.WithBlockHeight(1).WithBlockTime(time.Now()) - f.Fuzz(fuzzTargetMatchMarketOrders) -} - -func fuzzTargetSettleFromBook( - t *testing.T, - buyEntryWeights []byte, - sellEntryWeights []byte, - buyAccountIndices []byte, - sellAccountIndices []byte, - buyAllocationWeights []byte, - sellAllocationWeights []byte, - quantityI int64, - quantityIsNil bool, -) { - dexkeeper, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(1).WithBlockTime(time.Now()) - buyEntries := fuzzing.GetOrderBookEntries(true, keepertest.TestPriceDenom, keepertest.TestAssetDenom, buyEntryWeights, buyAccountIndices, buyAllocationWeights) - for _, entry := range buyEntries { - dexkeeper.SetLongOrderBookEntry(ctx, keepertest.TestContract, entry) - } - sellEntries := fuzzing.GetOrderBookEntries(false, keepertest.TestPriceDenom, keepertest.TestAssetDenom, sellEntryWeights, sellAccountIndices, sellAllocationWeights) - for _, entry := range sellEntries { - dexkeeper.SetShortOrderBookEntry(ctx, keepertest.TestContract, entry) - } - - quantity := fuzzing.FuzzDec(quantityI, quantityIsNil) - - if len(buyEntries) > len(sellEntries) { - buyEntries = buyEntries[:len(sellEntries)] - } else { - sellEntries = sellEntries[:len(buyEntries)] - } - - orderbook := keeperutil.PopulateOrderbook(ctx, dexkeeper, types.ContractAddress(keepertest.TestContract), types.Pair{PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}) - for i, longEntry := range buyEntries { - require.NotPanics(t, func() { - exchange.SettleFromBook(ctx, orderbook, quantity, longEntry.GetPrice(), sellEntries[i].GetPrice()) - }) - } -} diff --git a/x/dex/genesis.go b/x/dex/genesis.go deleted file mode 100644 index d5ef5c729b..0000000000 --- a/x/dex/genesis.go +++ /dev/null @@ -1,85 +0,0 @@ -package dex - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -// InitGenesis initializes the dex module's state from a provided genesis -// state. -func InitGenesis(ctx sdk.Context, k keeper.Keeper, genState types.GenesisState) { - k.CreateModuleAccount(ctx) - - // Set all the longBook - for _, contractState := range genState.ContractState { - - contractInfo := contractState.ContractInfo - err := k.SetContract(ctx, &contractInfo) - if err != nil { - panic(err) - } - - for _, elem := range contractState.PairList { - k.AddRegisteredPair(ctx, contractState.ContractInfo.ContractAddr, elem) - } - - for _, elem := range contractState.LongBookList { - k.SetLongBook(ctx, contractState.ContractInfo.ContractAddr, elem) - } - - for _, elem := range contractState.ShortBookList { - k.SetShortBook(ctx, contractState.ContractInfo.ContractAddr, elem) - } - - for _, elem := range contractState.PriceList { - for _, priceElem := range elem.Prices { - k.SetPriceState(ctx, *priceElem, contractState.ContractInfo.ContractAddr) - } - } - - k.SetNextOrderID(ctx, contractState.ContractInfo.ContractAddr, contractState.NextOrderId) - - } - - // this line is used by starport scaffolding # genesis/module/init - k.SetParams(ctx, genState.Params) - - k.SetEpoch(ctx, genState.LastEpoch) -} - -// ExportGenesis returns the dex module's exported genesis. -func ExportGenesis(ctx sdk.Context, k keeper.Keeper) *types.GenesisState { - genesis := types.DefaultGenesis() - genesis.Params = k.GetParams(ctx) - - allContractInfo := k.GetAllContractInfo(ctx) - contractStates := make([]types.ContractState, len(allContractInfo)) - for i, contractInfo := range allContractInfo { - contractAddr := contractInfo.ContractAddr - registeredPairs := k.GetAllRegisteredPairs(ctx, contractAddr) - // Save all price info for contract, for all its pairs - contractPrices := []types.ContractPairPrices{} - for _, elem := range registeredPairs { - pairPrices := k.GetAllPrices(ctx, contractAddr, elem) - contractPrices = append(contractPrices, types.ContractPairPrices{ - PricePair: elem, - Prices: pairPrices, - }) - } - contractStates[i] = types.ContractState{ - ContractInfo: contractInfo, - LongBookList: k.GetAllLongBook(ctx, contractAddr), - ShortBookList: k.GetAllShortBook(ctx, contractAddr), - PairList: registeredPairs, - PriceList: contractPrices, - NextOrderId: k.GetNextOrderID(ctx, contractAddr), - } - } - genesis.ContractState = contractStates - - _, currentEpoch := k.IsNewEpoch(ctx) - genesis.LastEpoch = currentEpoch - - return genesis -} diff --git a/x/dex/genesis_test.go b/x/dex/genesis_test.go deleted file mode 100644 index 4cbf0cf215..0000000000 --- a/x/dex/genesis_test.go +++ /dev/null @@ -1,105 +0,0 @@ -package dex_test - -import ( - "testing" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" - - sdk "github.com/cosmos/cosmos-sdk/types" -) - -func TEST_PAIR() types.Pair { - return types.Pair{ - PriceDenom: "USDC", - AssetDenom: "ATOM", - } -} - -func TestGenesis(t *testing.T) { - contractList := []types.ContractState{} - contractDependencies := []*types.ContractDependencyInfo{ - { - Dependency: "dependency1", - }, - { - Dependency: "dependency2", - }, - } - - contractInfo := types.ContractInfoV2{ - CodeId: uint64(1), - ContractAddr: "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m", - Dependencies: contractDependencies, - } - - pairList := []types.Pair{ - { - PriceDenom: "USDC", - AssetDenom: "SEI", - PriceTicksize: &keepertest.TestTicksize, - QuantityTicksize: &keepertest.TestTicksize, - }, - } - - priceList := []types.ContractPairPrices{ - { - PricePair: pairList[0], - Prices: []*types.Price{ - { - SnapshotTimestampInSeconds: 2, - Pair: &(pairList[0]), - Price: sdk.MustNewDecFromStr("101"), - }, - }, - }, - } - - contractState := types.ContractState{ - LongBookList: []types.LongBook{ - { - Price: sdk.NewDec(1), - Entry: &types.OrderEntry{ - Price: sdk.ZeroDec(), - }, - }, - }, - ShortBookList: []types.ShortBook{ - { - Price: sdk.NewDec(1), - Entry: &types.OrderEntry{ - Price: sdk.ZeroDec(), - }, - }, - }, - ContractInfo: contractInfo, - PairList: pairList, - PriceList: priceList, - NextOrderId: 10, - } - contractList = append(contractList, contractState) - - genesisState := types.GenesisState{ - Params: types.DefaultParams(), - // this line is used by starport scaffolding # genesis/test/state - ContractState: contractList, - } - - k, ctx := keepertest.DexKeeper(t) - k.SetContract(ctx, &contractInfo) - dex.InitGenesis(ctx, *k, genesisState) - got := dex.ExportGenesis(ctx, *k) - require.NotNil(t, got) - - require.ElementsMatch(t, genesisState.ContractState[0].LongBookList, got.ContractState[0].LongBookList) - require.ElementsMatch(t, genesisState.ContractState[0].ShortBookList, got.ContractState[0].ShortBookList) - require.ElementsMatch(t, genesisState.ContractState[0].PairList, got.ContractState[0].PairList) - require.Equal(t, genesisState.ContractState[0].ContractInfo.CodeId, got.ContractState[0].ContractInfo.CodeId) - require.Equal(t, genesisState.ContractState[0].ContractInfo.ContractAddr, got.ContractState[0].ContractInfo.ContractAddr) - require.ElementsMatch(t, genesisState.ContractState[0].ContractInfo.Dependencies, got.ContractState[0].ContractInfo.Dependencies) - require.ElementsMatch(t, genesisState.ContractState[0].PriceList, got.ContractState[0].PriceList) - require.Equal(t, genesisState.ContractState[0].NextOrderId, got.ContractState[0].NextOrderId) - // this line is used by starport scaffolding # genesis/test/assert -} diff --git a/x/dex/gov.go b/x/dex/gov.go deleted file mode 100644 index 62fd392830..0000000000 --- a/x/dex/gov.go +++ /dev/null @@ -1,14 +0,0 @@ -package dex - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func HandleAddAssetMetadataProposal(ctx sdk.Context, k *keeper.Keeper, p *types.AddAssetMetadataProposal) error { - for _, asset := range p.AssetList { - k.SetAssetMetadata(ctx, asset) - } - return nil -} diff --git a/x/dex/handler.go b/x/dex/handler.go deleted file mode 100644 index 623062b500..0000000000 --- a/x/dex/handler.go +++ /dev/null @@ -1,67 +0,0 @@ -package dex - -import ( - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - govtypes "github.com/cosmos/cosmos-sdk/x/gov/types" - - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -// NewHandler ... -func NewHandler(k keeper.Keeper) sdk.Handler { - msgServer := msgserver.NewMsgServerImpl(k) - - return func(ctx sdk.Context, msg sdk.Msg) (*sdk.Result, error) { - ctx = ctx.WithEventManager(sdk.NewEventManager()) - - switch msg := msg.(type) { - case *types.MsgPlaceOrders: - res, err := msgServer.PlaceOrders(sdk.WrapSDKContext(ctx), msg) - return sdk.WrapServiceResult(ctx, res, err) - case *types.MsgCancelOrders: - res, err := msgServer.CancelOrders(sdk.WrapSDKContext(ctx), msg) - return sdk.WrapServiceResult(ctx, res, err) - case *types.MsgRegisterContract: - res, err := msgServer.RegisterContract(sdk.WrapSDKContext(ctx), msg) - return sdk.WrapServiceResult(ctx, res, err) - case *types.MsgRegisterPairs: - res, err := msgServer.RegisterPairs(sdk.WrapSDKContext(ctx), msg) - return sdk.WrapServiceResult(ctx, res, err) - case *types.MsgUpdatePriceTickSize: - res, err := msgServer.UpdatePriceTickSize(sdk.WrapSDKContext(ctx), msg) - return sdk.WrapServiceResult(ctx, res, err) - case *types.MsgUpdateQuantityTickSize: - res, err := msgServer.UpdateQuantityTickSize(sdk.WrapSDKContext(ctx), msg) - return sdk.WrapServiceResult(ctx, res, err) - case *types.MsgUnregisterContract: - res, err := msgServer.UnregisterContract(sdk.WrapSDKContext(ctx), msg) - return sdk.WrapServiceResult(ctx, res, err) - case *types.MsgContractDepositRent: - res, err := msgServer.ContractDepositRent(sdk.WrapSDKContext(ctx), msg) - return sdk.WrapServiceResult(ctx, res, err) - case *types.MsgUnsuspendContract: - res, err := msgServer.UnsuspendContract(sdk.WrapSDKContext(ctx), msg) - return sdk.WrapServiceResult(ctx, res, err) - // this line is used by starport scaffolding # 1 - default: - errMsg := fmt.Sprintf("unrecognized %s message type: %T", types.ModuleName, msg) - return nil, sdkerrors.Wrap(sdkerrors.ErrUnknownRequest, errMsg) - } - } -} - -func NewProposalHandler(k keeper.Keeper) govtypes.Handler { - return func(ctx sdk.Context, content govtypes.Content) error { - switch c := content.(type) { - case *types.AddAssetMetadataProposal: - return HandleAddAssetMetadataProposal(ctx, &k, c) - default: - return sdkerrors.Wrapf(sdkerrors.ErrUnknownRequest, "unrecognized dex proposal content type: %T", c) - } - } -} diff --git a/x/dex/keeper/abci/end_block_cancel_orders.go b/x/dex/keeper/abci/end_block_cancel_orders.go deleted file mode 100644 index 8c471124cd..0000000000 --- a/x/dex/keeper/abci/end_block_cancel_orders.go +++ /dev/null @@ -1,45 +0,0 @@ -package abci - -import ( - "context" - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "go.opentelemetry.io/otel/attribute" - otrace "go.opentelemetry.io/otel/trace" -) - -func (w KeeperWrapper) HandleEBCancelOrders(ctx context.Context, sdkCtx sdk.Context, tracer *otrace.Tracer, contractAddr string, registeredPairs []types.Pair) error { - _, span := (*tracer).Start(ctx, "SudoCancelOrders") - span.SetAttributes(attribute.String("contractAddr", contractAddr)) - - typedContractAddr := types.ContractAddress(contractAddr) - msg := w.getCancelSudoMsg(sdkCtx, typedContractAddr, registeredPairs) - if len(msg.OrderCancellations.IdsToCancel) == 0 { - return nil - } - userProvidedGas := w.GetParams(sdkCtx).DefaultGasPerCancel * uint64(len(msg.OrderCancellations.IdsToCancel)) - if _, err := utils.CallContractSudo(sdkCtx, w.Keeper, contractAddr, msg, userProvidedGas); err != nil { - sdkCtx.Logger().Error(fmt.Sprintf("Error during cancellation: %s", err.Error())) - return err - } - span.End() - return nil -} - -func (w KeeperWrapper) getCancelSudoMsg(sdkCtx sdk.Context, typedContractAddr types.ContractAddress, registeredPairs []types.Pair) types.SudoOrderCancellationMsg { - idsToCancel := []uint64{} - for _, pair := range registeredPairs { - for _, cancel := range dexutils.GetMemState(sdkCtx.Context()).GetBlockCancels(sdkCtx, typedContractAddr, pair).Get() { - idsToCancel = append(idsToCancel, cancel.Id) - } - } - return types.SudoOrderCancellationMsg{ - OrderCancellations: types.OrderCancellationMsgDetails{ - IdsToCancel: idsToCancel, - }, - } -} diff --git a/x/dex/keeper/abci/end_block_deposit.go b/x/dex/keeper/abci/end_block_deposit.go deleted file mode 100644 index c0216e4826..0000000000 --- a/x/dex/keeper/abci/end_block_deposit.go +++ /dev/null @@ -1,58 +0,0 @@ -package abci - -import ( - "context" - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" - seiutils "github.com/sei-protocol/sei-chain/utils" - "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "go.opentelemetry.io/otel/attribute" - otrace "go.opentelemetry.io/otel/trace" -) - -func (w KeeperWrapper) HandleEBDeposit(ctx context.Context, sdkCtx sdk.Context, tracer *otrace.Tracer, contractAddr string) error { - _, span := (*tracer).Start(ctx, "SudoDeposit") - span.SetAttributes(attribute.String("contractAddr", contractAddr)) - defer span.End() - - typedContractAddr := types.ContractAddress(contractAddr) - msg := w.GetDepositSudoMsg(sdkCtx, typedContractAddr) - if msg.IsEmpty() { - return nil - } - _, err := utils.CallContractSudo(sdkCtx, w.Keeper, contractAddr, msg, 0) // deposit - if err != nil { - sdkCtx.Logger().Error(fmt.Sprintf("Error during deposit: %s", err.Error())) - return err - } - - return nil -} - -func (w KeeperWrapper) GetDepositSudoMsg(ctx sdk.Context, typedContractAddr types.ContractAddress) types.SudoOrderPlacementMsg { - depositMemState := dexutils.GetMemState(ctx.Context()).GetDepositInfo(ctx, typedContractAddr).Get() - contractDepositInfo := seiutils.Map( - depositMemState, - func(d *types.DepositInfoEntry) types.ContractDepositInfo { return d.ToContractDepositInfo() }, - ) - escrowed := sdk.NewCoins() - for _, deposit := range depositMemState { - escrowed = escrowed.Add(sdk.NewCoin(deposit.Denom, deposit.Amount.TruncateInt())) - } - contractAddr, err := sdk.AccAddressFromBech32(string(typedContractAddr)) - if err != nil { - panic(err) - } - if err := w.BankKeeper.SendCoinsFromModuleToAccount(ctx, types.ModuleName, contractAddr, escrowed); err != nil { - panic(err) - } - return types.SudoOrderPlacementMsg{ - OrderPlacements: types.OrderPlacementMsgDetails{ - Orders: []types.Order{}, - Deposits: contractDepositInfo, - }, - } -} diff --git a/x/dex/keeper/abci/end_block_place_orders.go b/x/dex/keeper/abci/end_block_place_orders.go deleted file mode 100644 index 8ab95c6e3e..0000000000 --- a/x/dex/keeper/abci/end_block_place_orders.go +++ /dev/null @@ -1,83 +0,0 @@ -package abci - -import ( - "context" - "encoding/json" - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "go.opentelemetry.io/otel/attribute" - otrace "go.opentelemetry.io/otel/trace" -) - -// There is a limit on how many bytes can be passed to wasm VM in a single call, -// so we shouldn't bump this number unless there is an upgrade to wasm VM -const MaxOrdersPerSudoCall = 50000 - -func (w KeeperWrapper) HandleEBPlaceOrders(ctx context.Context, sdkCtx sdk.Context, tracer *otrace.Tracer, contractAddr string, registeredPairs []types.Pair) error { - _, span := (*tracer).Start(ctx, "SudoPlaceOrders") - span.SetAttributes(attribute.String("contractAddr", contractAddr)) - defer span.End() - - typedContractAddr := types.ContractAddress(contractAddr) - msgs := w.GetPlaceSudoMsg(sdkCtx, typedContractAddr, registeredPairs) - - responses := []types.SudoOrderPlacementResponse{} - - for _, msg := range msgs { - if msg.IsEmpty() { - continue - } - userProvidedGas := w.GetParams(sdkCtx).DefaultGasPerOrder * uint64(len(msg.OrderPlacements.Orders)) - data, err := utils.CallContractSudo(sdkCtx, w.Keeper, contractAddr, msg, userProvidedGas) - if err != nil { - sdkCtx.Logger().Error(fmt.Sprintf("Error during order placement: %s", err.Error())) - return err - } - response := types.SudoOrderPlacementResponse{} - if err := json.Unmarshal(data, &response); err != nil { - sdkCtx.Logger().Error("Failed to parse order placement response") - return err - } - if len(response.UnsuccessfulOrders) > 0 { - sdkCtx.Logger().Info(fmt.Sprintf("%s has %d unsuccessful order placements", contractAddr, len(response.UnsuccessfulOrders))) - } - responses = append(responses, response) - } - - for _, pair := range registeredPairs { - for _, response := range responses { - dexutils.GetMemState(sdkCtx.Context()).GetBlockOrders(sdkCtx, typedContractAddr, pair).MarkFailedToPlace(response.UnsuccessfulOrders) - } - } - return nil -} - -func (w KeeperWrapper) GetPlaceSudoMsg(ctx sdk.Context, typedContractAddr types.ContractAddress, registeredPairs []types.Pair) []types.SudoOrderPlacementMsg { - msgs := []types.SudoOrderPlacementMsg{} - contractOrderPlacements := []types.Order{} - for _, pair := range registeredPairs { - for _, order := range dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, typedContractAddr, pair).Get() { - contractOrderPlacements = append(contractOrderPlacements, *order) - if len(contractOrderPlacements) == MaxOrdersPerSudoCall { - msgs = append(msgs, types.SudoOrderPlacementMsg{ - OrderPlacements: types.OrderPlacementMsgDetails{ - Orders: contractOrderPlacements, - Deposits: []types.ContractDepositInfo{}, - }, - }) - contractOrderPlacements = []types.Order{} - } - } - } - msgs = append(msgs, types.SudoOrderPlacementMsg{ - OrderPlacements: types.OrderPlacementMsgDetails{ - Orders: contractOrderPlacements, - Deposits: []types.ContractDepositInfo{}, - }, - }) - return msgs -} diff --git a/x/dex/keeper/abci/end_block_place_orders_test.go b/x/dex/keeper/abci/end_block_place_orders_test.go deleted file mode 100644 index 556c3119cf..0000000000 --- a/x/dex/keeper/abci/end_block_place_orders_test.go +++ /dev/null @@ -1,67 +0,0 @@ -package abci_test - -import ( - "context" - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/keeper/abci" - "github.com/sei-protocol/sei-chain/x/dex/types" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - minttypes "github.com/sei-protocol/sei-chain/x/mint/types" - "github.com/stretchr/testify/require" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -func TestGetPlaceSudoMsg(t *testing.T) { - pair := types.Pair{PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom} - keeper, ctx := keepertest.DexKeeper(t) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, keepertest.TestContract, pair).Add( - &types.Order{ - Id: 1, - Price: sdk.OneDec(), - Quantity: sdk.OneDec(), - PriceDenom: "USDC", - AssetDenom: "ATOM", - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"OPEN\",\"leverage\":\"1\"}", - }, - ) - wrapper := abci.KeeperWrapper{Keeper: keeper} - msgs := wrapper.GetPlaceSudoMsg(ctx, keepertest.TestContract, []types.Pair{pair}) - require.Equal(t, 1, len(msgs)) -} - -func TestGetDepositSudoMsg(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - testAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - amounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(1000000))) - bankkeeper := testApp.BankKeeper - bankkeeper.MintCoins(ctx, minttypes.ModuleName, amounts) - err := bankkeeper.SendCoinsFromModuleToAccount(ctx, minttypes.ModuleName, testAccount, amounts) - require.Nil(t, err) - // this send would happen in msg server - err = bankkeeper.SendCoinsFromAccountToModule(ctx, testAccount, dextypes.ModuleName, amounts) - require.Nil(t, err) - keeper := testApp.DexKeeper - dexutils.GetMemState(ctx.Context()).GetDepositInfo(ctx, keepertest.TestContract).Add( - &types.DepositInfoEntry{ - Creator: testAccount.String(), - Denom: amounts[0].Denom, - Amount: sdk.NewDec(amounts[0].Amount.Int64()), - }, - ) - wrapper := abci.KeeperWrapper{Keeper: &keeper} - msgs := wrapper.GetDepositSudoMsg(ctx, keepertest.TestContract) - require.Equal(t, 1, len(msgs.OrderPlacements.Deposits)) - - contractAddr, _ := sdk.AccAddressFromBech32(keepertest.TestContract) - contractBalance := testApp.BankKeeper.GetBalance(ctx, contractAddr, "usei") - require.Equal(t, contractBalance.Amount.Int64(), int64(1000000)) -} diff --git a/x/dex/keeper/abci/keeper_wrapper.go b/x/dex/keeper/abci/keeper_wrapper.go deleted file mode 100644 index ee20698ad7..0000000000 --- a/x/dex/keeper/abci/keeper_wrapper.go +++ /dev/null @@ -1,9 +0,0 @@ -package abci - -import ( - "github.com/sei-protocol/sei-chain/x/dex/keeper" -) - -type KeeperWrapper struct { - *keeper.Keeper -} diff --git a/x/dex/keeper/asset_list.go b/x/dex/keeper/asset_list.go deleted file mode 100644 index d62b39ed0e..0000000000 --- a/x/dex/keeper/asset_list.go +++ /dev/null @@ -1,43 +0,0 @@ -package keeper - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k Keeper) SetAssetMetadata(ctx sdk.Context, assetMetadata types.AssetMetadata) { - store := ctx.KVStore(k.storeKey) - // Have one base denom for a canonical “display”. - // Even if asset exists already, overwrite the store with new metadata - // Asset list is decided through governance - b := k.Cdc.MustMarshal(&assetMetadata) - - store.Set(types.AssetListPrefix(assetMetadata.Metadata.Display), b) -} - -func (k Keeper) GetAssetMetadataByDenom(ctx sdk.Context, assetDenom string) (val types.AssetMetadata, found bool) { - store := ctx.KVStore(k.storeKey) - b := store.Get(types.AssetListPrefix(assetDenom)) - if b == nil { - return types.AssetMetadata{}, false - } - metadata := types.AssetMetadata{} - k.Cdc.MustUnmarshal(b, &metadata) - return metadata, true -} - -func (k Keeper) GetAllAssetMetadata(ctx sdk.Context) []types.AssetMetadata { - store := ctx.KVStore(k.storeKey) - iterator := sdk.KVStorePrefixIterator(store, types.KeyPrefix(types.AssetListKey)) - - list := []types.AssetMetadata{} - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.AssetMetadata - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, val) - } - - return list -} diff --git a/x/dex/keeper/asset_list_test.go b/x/dex/keeper/asset_list_test.go deleted file mode 100644 index 70348e6f36..0000000000 --- a/x/dex/keeper/asset_list_test.go +++ /dev/null @@ -1,35 +0,0 @@ -package keeper_test - -import ( - "testing" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/testutil/nullify" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestAssetListGet(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - item := keepertest.CreateAssetMetadata(keeper, ctx) - - var expected_asset_list []types.AssetMetadata - expected_asset_list = append(expected_asset_list, item) - - asset_list := keeper.GetAllAssetMetadata(ctx) - - // First test get all asset list - require.ElementsMatch(t, - nullify.Fill(expected_asset_list), - nullify.Fill(asset_list), - ) - - // Test not found asset Denom - _, found := keeper.GetAssetMetadataByDenom(ctx, "denomNotInAssetList123") - require.False(t, found) - - // Test get specific Denom - val, found := keeper.GetAssetMetadataByDenom(ctx, "axlusdc") - require.True(t, found) - require.Equal(t, item, val) -} diff --git a/x/dex/keeper/common.go b/x/dex/keeper/common.go deleted file mode 100644 index f5ba9b961c..0000000000 --- a/x/dex/keeper/common.go +++ /dev/null @@ -1,22 +0,0 @@ -package keeper - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" -) - -func (k Keeper) removeAllForPrefix(ctx sdk.Context, prefix []byte) { - store := ctx.KVStore(k.storeKey) - for _, key := range k.getAllKeysForPrefix(store, prefix) { - store.Delete(key) - } -} - -func (k Keeper) getAllKeysForPrefix(store sdk.KVStore, prefix []byte) [][]byte { - keys := [][]byte{} - iter := sdk.KVStorePrefixIterator(store, prefix) - defer iter.Close() - for ; iter.Valid(); iter.Next() { - keys = append(keys, iter.Key()) - } - return keys -} diff --git a/x/dex/keeper/contract.go b/x/dex/keeper/contract.go deleted file mode 100644 index dd25962546..0000000000 --- a/x/dex/keeper/contract.go +++ /dev/null @@ -1,244 +0,0 @@ -package keeper - -import ( - "errors" - "math" - "math/big" - "time" - - "github.com/cosmos/cosmos-sdk/store/prefix" - "github.com/cosmos/cosmos-sdk/telemetry" - sdk "github.com/cosmos/cosmos-sdk/types" - appparams "github.com/sei-protocol/sei-chain/app/params" - "github.com/sei-protocol/sei-chain/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -const ContractPrefixKey = "x-wasm-contract" - -func (k Keeper) SetContract(ctx sdk.Context, contract *types.ContractInfoV2) error { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - []byte(ContractPrefixKey), - ) - bz, err := contract.Marshal() - if err != nil { - return errors.New("failed to marshal contract info") - } - store.Set(types.ContractKey(contract.ContractAddr), bz) - return nil -} - -func (k Keeper) DeleteContract(ctx sdk.Context, contractAddr string) { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - []byte(ContractPrefixKey), - ) - key := types.ContractKey(contractAddr) - store.Delete(key) -} - -func (k Keeper) GetContract(ctx sdk.Context, contractAddr string) (types.ContractInfoV2, error) { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - []byte(ContractPrefixKey), - ) - key := types.ContractKey(contractAddr) - res := types.ContractInfoV2{} - if !store.Has(key) { - return res, types.ErrContractNotExists - } - if err := res.Unmarshal(store.Get(key)); err != nil { - return res, types.ErrParsingContractInfo - } - return res, nil -} - -func (k Keeper) GetContractWithoutGasCharge(ctx sdk.Context, contractAddr string) (types.ContractInfoV2, error) { - return k.GetContract(ctx.WithGasMeter(sdk.NewInfiniteGasMeterWithMultiplier(ctx)), contractAddr) -} - -func (k Keeper) GetContractGasLimit(ctx sdk.Context, contractAddr sdk.AccAddress) (uint64, error) { - bech32ContractAddr := contractAddr.String() - contract, err := k.GetContract(ctx, bech32ContractAddr) - if err != nil { - return 0, err - } - rentBalance := contract.RentBalance - gasPrice := k.GetParams(ctx).SudoCallGasPrice - if gasPrice.LTE(sdk.ZeroDec()) { - return 0, errors.New("invalid gas price: must be positive") - } - gasDec := sdk.NewDecFromBigInt(new(big.Int).SetUint64(rentBalance)).Quo(gasPrice) - if gasDec.GT(sdk.NewDecFromBigInt(new(big.Int).SetUint64(math.MaxUint64))) { - return math.MaxUint64, nil - } - return gasDec.TruncateInt().Uint64(), nil // round down -} - -func (k Keeper) GetAllContractInfo(ctx sdk.Context) []types.ContractInfoV2 { - store := prefix.NewStore(ctx.KVStore(k.storeKey), []byte(ContractPrefixKey)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - defer iterator.Close() - - list := []types.ContractInfoV2{} - for ; iterator.Valid(); iterator.Next() { - contract := types.ContractInfoV2{} - if err := contract.Unmarshal(iterator.Value()); err == nil { - list = append(list, contract) - } - } - - return list -} - -// Reduce `RentBalance` of a contract if `userProvidedGas` cannot cover `gasUsed` -func (k Keeper) ChargeRentForGas(ctx sdk.Context, contractAddr string, gasUsed uint64, gasAllowance uint64) error { - if gasUsed <= gasAllowance { - // Allowance can fully cover the consumed gas. Doing nothing - return nil - } - gasUsed -= gasAllowance - contract, err := k.GetContract(ctx, contractAddr) - if err != nil { - return err - } - params := k.GetParams(ctx) - gasFeeDec := sdk.NewDecFromBigInt(new(big.Int).SetUint64(gasUsed)).Mul(params.SudoCallGasPrice) - if gasFeeDec.GT(sdk.NewDecFromBigInt(new(big.Int).SetUint64(math.MaxUint64))) { - gasFeeDec = sdk.NewDecFromBigInt(new(big.Int).SetUint64(math.MaxUint64)) - } - gasFee := gasFeeDec.RoundInt().Uint64() - if gasFee > contract.RentBalance { - contract.RentBalance = 0 - if err := k.SetContract(ctx, &contract); err != nil { - return err - } - return types.ErrInsufficientRent - } - contract.RentBalance -= gasFee - return k.SetContract(ctx, &contract) -} - -func (k Keeper) GetRentsForContracts(ctx sdk.Context, contractAddrs []string) map[string]uint64 { - res := map[string]uint64{} - for _, contractAddr := range contractAddrs { - if contract, err := k.GetContract(ctx, contractAddr); err == nil { - res[contractAddr] = contract.RentBalance - } - } - return res -} - -// Unregistrate and refund the creator -func (k Keeper) DoUnregisterContractWithRefund(ctx sdk.Context, contract types.ContractInfoV2) error { - k.DoUnregisterContract(ctx, contract) - creatorAddr, _ := sdk.AccAddressFromBech32(contract.Creator) - return k.BankKeeper.SendCoins(ctx, k.AccountKeeper.GetModuleAddress(types.ModuleName), creatorAddr, sdk.NewCoins(sdk.NewCoin(appparams.BaseCoinUnit, sdk.NewIntFromBigInt(new(big.Int).SetUint64(contract.RentBalance))))) -} - -// Contract unregistration will remove all orderbook data stored for the contract -func (k Keeper) DoUnregisterContract(ctx sdk.Context, contract types.ContractInfoV2) { - k.DeleteContract(ctx, contract.ContractAddr) - k.ClearDependenciesForContract(ctx, contract) - k.RemoveAllLongBooksForContract(ctx, contract.ContractAddr) - k.RemoveAllShortBooksForContract(ctx, contract.ContractAddr) - k.RemoveAllPricesForContract(ctx, contract.ContractAddr) - k.DeleteMatchResultState(ctx, contract.ContractAddr) - k.DeleteNextOrderID(ctx, contract.ContractAddr) - k.DeleteAllRegisteredPairsForContract(ctx, contract.ContractAddr) -} - -func (k Keeper) SuspendContract(ctx sdk.Context, contractAddress string, reason string) error { - contract, err := k.GetContract(ctx, contractAddress) - if err != nil { - return err - } - contract.Suspended = true - contract.SuspensionReason = reason - return k.SetContract(ctx, &contract) -} - -func (k Keeper) ClearDependenciesForContract(ctx sdk.Context, removedContract types.ContractInfoV2) { - // handle upstreams - allContracts := k.GetAllContractInfo(ctx) - for _, c := range allContracts { - contract := c - dependsOnRemovedContract := false - for _, dep := range contract.Dependencies { - if dep.Dependency == removedContract.ContractAddr { - dependsOnRemovedContract = true - break - } - } - if !dependsOnRemovedContract { - continue - } - contract.Dependencies = utils.Filter(contract.Dependencies, func(dep *types.ContractDependencyInfo) bool { return dep.Dependency != removedContract.ContractAddr }) - _ = k.SetContract(ctx, &contract) - } - - // handle downstreams - allContractsMap := map[string]types.ContractInfoV2{} - for _, contract := range allContracts { - allContractsMap[contract.ContractAddr] = contract - } - for _, dep := range removedContract.Dependencies { - if dependedContract, ok := allContractsMap[dep.Dependency]; ok { - dependedContract.NumIncomingDependencies-- - _ = k.SetContract(ctx, &dependedContract) - } - - if dep.ImmediateElderSibling != "" { - if immediateElderSibling, ok := allContractsMap[dep.ImmediateElderSibling]; ok { - newDependencies := []*types.ContractDependencyInfo{} - for _, elderSiblingDep := range immediateElderSibling.Dependencies { - if elderSiblingDep.Dependency != dep.Dependency { - newDependencies = append(newDependencies, elderSiblingDep) - } else { - newDependencies = append(newDependencies, &types.ContractDependencyInfo{ - Dependency: elderSiblingDep.Dependency, - ImmediateElderSibling: elderSiblingDep.ImmediateElderSibling, - ImmediateYoungerSibling: dep.ImmediateYoungerSibling, - }) - } - } - immediateElderSibling.Dependencies = newDependencies - _ = k.SetContract(ctx, &immediateElderSibling) - } - } - - if dep.ImmediateYoungerSibling != "" { - if immediateYoungerSibling, ok := allContractsMap[dep.ImmediateYoungerSibling]; ok { - newDependencies := []*types.ContractDependencyInfo{} - for _, youngerSiblingDep := range immediateYoungerSibling.Dependencies { - if youngerSiblingDep.Dependency != dep.Dependency { - newDependencies = append(newDependencies, youngerSiblingDep) - } else { - newDependencies = append(newDependencies, &types.ContractDependencyInfo{ - Dependency: youngerSiblingDep.Dependency, - ImmediateElderSibling: dep.ImmediateElderSibling, - ImmediateYoungerSibling: youngerSiblingDep.ImmediateYoungerSibling, - }) - } - } - immediateYoungerSibling.Dependencies = newDependencies - _ = k.SetContract(ctx, &immediateYoungerSibling) - } - } - } -} - -func (k Keeper) GetAllProcessableContractInfo(ctx sdk.Context) []types.ContractInfoV2 { - // Do not process any contract that has zero rent balance, suspended, or not require matching - defer telemetry.MeasureSince(time.Now(), types.ModuleName, "get_all_contract_info") - allRegisteredContracts := k.GetAllContractInfo(ctx) - validContracts := utils.Filter(allRegisteredContracts, func(c types.ContractInfoV2) bool { - return c.NeedOrderMatching && !c.Suspended && c.RentBalance > k.GetMinProcessableRent(ctx) - }) - telemetry.SetGauge(float32(len(allRegisteredContracts)), types.ModuleName, "num_of_registered_contracts") - telemetry.SetGauge(float32(len(validContracts)), types.ModuleName, "num_of_valid_contracts") - telemetry.SetGauge(float32(len(allRegisteredContracts)-len(validContracts)), types.ModuleName, "num_of_zero_balance_contracts") - return validContracts -} diff --git a/x/dex/keeper/contract_test.go b/x/dex/keeper/contract_test.go deleted file mode 100644 index 8dae31c24f..0000000000 --- a/x/dex/keeper/contract_test.go +++ /dev/null @@ -1,368 +0,0 @@ -package keeper_test - -import ( - "math" - "testing" - - "github.com/cosmos/cosmos-sdk/store/prefix" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestChargeRentForGas(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keeper.SetParams(ctx, types.Params{SudoCallGasPrice: sdk.NewDecWithPrec(1, 1), PriceSnapshotRetention: 1}) - err := keeper.SetContract(ctx, &types.ContractInfoV2{ - Creator: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - CodeId: 1, - RentBalance: 1000000, - }) - require.Nil(t, err) - err = keeper.ChargeRentForGas(ctx, keepertest.TestContract, 5000000, 0) - require.Nil(t, err) - contract, err := keeper.GetContract(ctx, keepertest.TestContract) - require.Nil(t, err) - require.Equal(t, uint64(500000), contract.RentBalance) - err = keeper.ChargeRentForGas(ctx, keepertest.TestContract, 6000000, 0) - require.NotNil(t, err) - contract, err = keeper.GetContract(ctx, keepertest.TestContract) - require.Nil(t, err) - require.Equal(t, uint64(0), contract.RentBalance) - err = keeper.SetContract(ctx, &types.ContractInfoV2{ - Creator: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - CodeId: 1, - RentBalance: 1000000, - }) - require.Nil(t, err) - err = keeper.ChargeRentForGas(ctx, keepertest.TestContract, 5000000, 4000000) - require.Nil(t, err) - contract, err = keeper.GetContract(ctx, keepertest.TestContract) - require.Nil(t, err) - require.Equal(t, uint64(900000), contract.RentBalance) - err = keeper.ChargeRentForGas(ctx, keepertest.TestContract, 5000000, 6000000) - require.Nil(t, err) - contract, err = keeper.GetContract(ctx, keepertest.TestContract) - require.Nil(t, err) - require.Equal(t, uint64(900000), contract.RentBalance) - - // delete contract - keeper.DeleteContract(ctx, keepertest.TestContract) - _, err = keeper.GetContract(ctx, keepertest.TestContract) - require.NotNil(t, err) -} - -func TestGetContractInfo(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keeper.SetParams(ctx, types.Params{SudoCallGasPrice: sdk.NewDecWithPrec(1, 1), PriceSnapshotRetention: 1}) - keeper.SetContract(ctx, &types.ContractInfoV2{ - Creator: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - CodeId: 1, - RentBalance: 1000000, - }) - // Successfully get a contract - contract, err := keeper.GetContract(ctx, keepertest.TestContract) - require.Equal(t, uint64(1000000), contract.RentBalance) - require.Equal(t, uint64(1), contract.CodeId) - require.Equal(t, keepertest.TestAccount, contract.Creator) - - // Getting a non exist contract should throw error for contract not exist - _, err = keeper.GetContract(ctx, keepertest.TestContract2) - require.Error(t, err) - require.Equal(t, err, types.ErrContractNotExists) - - // Getting a corrupted record should throw error for unable to parse - store := prefix.NewStore( - ctx.KVStore(keeper.GetStoreKey()), - []byte("x-wasm-contract"), - ) - bz := []byte("bad_contract") - store.Set(types.ContractKey(keepertest.TestContract), bz) - _, err = keeper.GetContract(ctx, keepertest.TestContract) - require.Error(t, err) - require.Equal(t, err, types.ErrParsingContractInfo) -} - -func TestGetAllContractInfo(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keeper.SetParams(ctx, types.Params{SudoCallGasPrice: sdk.NewDecWithPrec(1, 1), PriceSnapshotRetention: 1}) - keeper.SetContract(ctx, &types.ContractInfoV2{ - Creator: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - CodeId: 1, - RentBalance: 1000000, - }) - keeper.SetContract(ctx, &types.ContractInfoV2{ - Creator: keepertest.TestAccount2, - ContractAddr: keepertest.TestContract2, - CodeId: 2, - RentBalance: 1000000, - }) - contracts := keeper.GetAllContractInfo(ctx) - require.Equal(t, uint64(1000000), contracts[0].RentBalance) - require.Equal(t, uint64(1000000), contracts[1].RentBalance) - require.Equal(t, uint64(1), contracts[0].CodeId) - require.Equal(t, uint64(2), contracts[1].CodeId) - require.Equal(t, keepertest.TestAccount, contracts[0].Creator) - require.Equal(t, keepertest.TestContract, contracts[0].ContractAddr) - require.Equal(t, keepertest.TestAccount2, contracts[1].Creator) - require.Equal(t, keepertest.TestContract2, contracts[1].ContractAddr) -} - -func TestGetContractGasLimit(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - contractAddr := sdk.MustAccAddressFromBech32("sei1suhgf5svhu4usrurvxzlgn54ksxmn8gljarjtxqnapv8kjnp4nrsgshtdj") - keeper.SetParams(ctx, types.Params{SudoCallGasPrice: sdk.NewDecWithPrec(1, 1), PriceSnapshotRetention: 1}) - keeper.SetContract(ctx, &types.ContractInfoV2{ - Creator: keepertest.TestAccount, - ContractAddr: "sei1suhgf5svhu4usrurvxzlgn54ksxmn8gljarjtxqnapv8kjnp4nrsgshtdj", - CodeId: 1, - RentBalance: 1000000, - }) - gasLimit, err := keeper.GetContractGasLimit(ctx, contractAddr) - require.Nil(t, err) - require.Equal(t, uint64(10000000), gasLimit) - - params := keeper.GetParams(ctx) - params.SudoCallGasPrice = sdk.NewDecWithPrec(1, 1) // 0.1 - keeper.SetParams(ctx, params) - keeper.SetContract(ctx, &types.ContractInfoV2{ - Creator: keepertest.TestAccount, - ContractAddr: "sei1suhgf5svhu4usrurvxzlgn54ksxmn8gljarjtxqnapv8kjnp4nrsgshtdj", - CodeId: 1, - RentBalance: math.MaxUint64, - }) - gasLimit, err = keeper.GetContractGasLimit(ctx, contractAddr) - require.Nil(t, err) - // max uint64 / 0.1 would cause overflow so we cap it at max - require.Equal(t, uint64(math.MaxUint64), gasLimit) -} - -func TestGetRentsForContracts(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - addr := "sei1suhgf5svhu4usrurvxzlgn54ksxmn8gljarjtxqnapv8kjnp4nrsgshtdj" - require.Equal(t, 0, len(keeper.GetRentsForContracts(ctx, []string{addr}))) - - keeper.SetContract(ctx, &types.ContractInfoV2{ - Creator: keepertest.TestAccount, - ContractAddr: addr, - CodeId: 1, - RentBalance: 100, - }) - require.Equal(t, map[string]uint64{addr: uint64(100)}, keeper.GetRentsForContracts(ctx, []string{addr})) -} - -func TestClearDependenciesForContract(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - - // no dependency whatsoever - contract := types.ContractInfoV2{ - ContractAddr: keepertest.TestContract, - } - keeper.SetContract(ctx, &contract) - require.NotPanics(t, func() { keeper.ClearDependenciesForContract(ctx, contract) }) - - // has upstreams - contract = types.ContractInfoV2{ - ContractAddr: keepertest.TestContract, - NumIncomingDependencies: 2, - } - keptContract := types.ContractInfoV2{ - ContractAddr: "sei1yum4v0v5l92jkxn8xpn9mjg7wuldk784ctg424ue8gqvdp88qzlqt6zc4h", - NumIncomingDependencies: 2, - } - upA := types.ContractInfoV2{ - ContractAddr: "sei105y5ssrsr8p8erkteagrguea6wcdgehlaamfup4lhrlm0y6eyhdsckcxdh", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: keepertest.TestContract, - ImmediateYoungerSibling: "sei1y8ghk8q8d2rswrf3gv7hv2lfsewu8tvp6ysnlkzspu7k0aqkthdqwdqvk0", - }, - { - Dependency: "sei1yum4v0v5l92jkxn8xpn9mjg7wuldk784ctg424ue8gqvdp88qzlqt6zc4h", - ImmediateYoungerSibling: "sei193dzcmy7lwuj4eda3zpwwt9ejal00xva0vawcvhgsyyp5cfh6jyqj2vsuv", - }, - }, - } - upB := types.ContractInfoV2{ - ContractAddr: "sei1y8ghk8q8d2rswrf3gv7hv2lfsewu8tvp6ysnlkzspu7k0aqkthdqwdqvk0", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: keepertest.TestContract, - ImmediateElderSibling: "sei105y5ssrsr8p8erkteagrguea6wcdgehlaamfup4lhrlm0y6eyhdsckcxdh", - }, - }, - } - upC := types.ContractInfoV2{ - ContractAddr: "sei193dzcmy7lwuj4eda3zpwwt9ejal00xva0vawcvhgsyyp5cfh6jyqj2vsuv", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "sei1yum4v0v5l92jkxn8xpn9mjg7wuldk784ctg424ue8gqvdp88qzlqt6zc4h", - ImmediateElderSibling: "sei105y5ssrsr8p8erkteagrguea6wcdgehlaamfup4lhrlm0y6eyhdsckcxdh", - }, - }, - } - keeper.SetContract(ctx, &contract) - keeper.SetContract(ctx, &keptContract) - keeper.SetContract(ctx, &upA) - keeper.SetContract(ctx, &upB) - keeper.SetContract(ctx, &upC) - require.NotPanics(t, func() { keeper.ClearDependenciesForContract(ctx, contract) }) - upA, err := keeper.GetContract(ctx, upA.ContractAddr) - require.Nil(t, err) - require.Equal(t, 1, len(upA.Dependencies)) - upB, err = keeper.GetContract(ctx, upB.ContractAddr) - require.Nil(t, err) - require.Equal(t, 0, len(upB.Dependencies)) - upC, err = keeper.GetContract(ctx, upC.ContractAddr) - require.Nil(t, err) - require.Equal(t, 1, len(upC.Dependencies)) - - // has downstreams - contract = types.ContractInfoV2{ - ContractAddr: keepertest.TestContract, - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "sei1ehyucudueas79h0zwufcnxtv7s2sfmwc6rt0v0hzczdgvyr3p56qhprg6n", - ImmediateElderSibling: "sei1uyprmp0lu8w8z8kwxp7mxanrtrgn4lp7j557pxe4v8sczzdzl7ysk832hh", - ImmediateYoungerSibling: "sei1yum4v0v5l92jkxn8xpn9mjg7wuldk784ctg424ue8gqvdp88qzlqt6zc4h", - }, { - Dependency: "sei1n23ymwg2y7m55x5vwf2qk0als9cr592q4uc5de08c6qmaeryet4qye4w77", - }, - }, - } - keptContractA := types.ContractInfoV2{ - ContractAddr: "sei1yum4v0v5l92jkxn8xpn9mjg7wuldk784ctg424ue8gqvdp88qzlqt6zc4h", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "sei1ehyucudueas79h0zwufcnxtv7s2sfmwc6rt0v0hzczdgvyr3p56qhprg6n", - ImmediateElderSibling: keepertest.TestContract, - }, - }, - } - keptContractB := types.ContractInfoV2{ - ContractAddr: "sei1uyprmp0lu8w8z8kwxp7mxanrtrgn4lp7j557pxe4v8sczzdzl7ysk832hh", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "sei1ehyucudueas79h0zwufcnxtv7s2sfmwc6rt0v0hzczdgvyr3p56qhprg6n", - ImmediateYoungerSibling: keepertest.TestContract, - }, - }, - } - downA := types.ContractInfoV2{ - ContractAddr: "sei1ehyucudueas79h0zwufcnxtv7s2sfmwc6rt0v0hzczdgvyr3p56qhprg6n", - NumIncomingDependencies: 3, - } - downB := types.ContractInfoV2{ - ContractAddr: "sei1n23ymwg2y7m55x5vwf2qk0als9cr592q4uc5de08c6qmaeryet4qye4w77", - NumIncomingDependencies: 1, - } - keeper.SetContract(ctx, &contract) - keeper.SetContract(ctx, &keptContractA) - keeper.SetContract(ctx, &keptContractB) - keeper.SetContract(ctx, &downA) - keeper.SetContract(ctx, &downB) - - require.NotPanics(t, func() { keeper.ClearDependenciesForContract(ctx, contract) }) - keptContractA, err = keeper.GetContract(ctx, keptContractA.ContractAddr) - require.Nil(t, err) - require.Equal(t, types.ContractInfoV2{ - ContractAddr: "sei1yum4v0v5l92jkxn8xpn9mjg7wuldk784ctg424ue8gqvdp88qzlqt6zc4h", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "sei1ehyucudueas79h0zwufcnxtv7s2sfmwc6rt0v0hzczdgvyr3p56qhprg6n", - ImmediateElderSibling: "sei1uyprmp0lu8w8z8kwxp7mxanrtrgn4lp7j557pxe4v8sczzdzl7ysk832hh", - }, - }, - }, keptContractA) - keptContractB, err = keeper.GetContract(ctx, keptContractB.ContractAddr) - require.Nil(t, err) - require.Equal(t, types.ContractInfoV2{ - ContractAddr: "sei1uyprmp0lu8w8z8kwxp7mxanrtrgn4lp7j557pxe4v8sczzdzl7ysk832hh", - Dependencies: []*types.ContractDependencyInfo{ - { - Dependency: "sei1ehyucudueas79h0zwufcnxtv7s2sfmwc6rt0v0hzczdgvyr3p56qhprg6n", - ImmediateYoungerSibling: "sei1yum4v0v5l92jkxn8xpn9mjg7wuldk784ctg424ue8gqvdp88qzlqt6zc4h", - }, - }, - }, keptContractB) - downA, err = keeper.GetContract(ctx, downA.ContractAddr) - require.Nil(t, err) - require.Equal(t, int64(2), downA.NumIncomingDependencies) - downB, err = keeper.GetContract(ctx, downB.ContractAddr) - require.Nil(t, err) - require.Equal(t, int64(0), downB.NumIncomingDependencies) -} - -func TestGetContractWithoutGasCharge(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - _ = keeper.SetContract(ctx, &types.ContractInfoV2{ - Creator: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - CodeId: 1, - RentBalance: 1000000, - }) - // regular gas meter case - ctx = ctx.WithGasMeter(sdk.NewGasMeterWithMultiplier(ctx, 10000)) - contract, err := keeper.GetContractWithoutGasCharge(ctx, keepertest.TestContract) - require.Nil(t, err) - require.Equal(t, keepertest.TestContract, contract.ContractAddr) - require.Equal(t, uint64(0), ctx.GasMeter().GasConsumed()) - require.Equal(t, uint64(10000), ctx.GasMeter().Limit()) - - // regular gas meter out of gas case - ctx = ctx.WithGasMeter(sdk.NewGasMeterWithMultiplier(ctx, 1)) - contract, err = keeper.GetContractWithoutGasCharge(ctx, keepertest.TestContract) - require.Nil(t, err) - require.Equal(t, keepertest.TestContract, contract.ContractAddr) - require.Equal(t, uint64(0), ctx.GasMeter().GasConsumed()) - require.Equal(t, uint64(1), ctx.GasMeter().Limit()) - - // infinite gas meter case - ctx = ctx.WithGasMeter(sdk.NewInfiniteGasMeterWithMultiplier(ctx)) - contract, err = keeper.GetContractWithoutGasCharge(ctx, keepertest.TestContract) - require.Nil(t, err) - require.Equal(t, keepertest.TestContract, contract.ContractAddr) - require.Equal(t, uint64(0), ctx.GasMeter().GasConsumed()) - require.Equal(t, uint64(0), ctx.GasMeter().Limit()) -} - -func TestGetAllProcessableContractInfo(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - require.Greater(t, keeper.GetMinProcessableRent(ctx), uint64(0)) - - goodContract := types.ContractInfoV2{ - ContractAddr: "sei1avny5w9rcj7lmqmse8kukg2edvq4adqk8vlf58", - NeedOrderMatching: true, - RentBalance: keeper.GetMinProcessableRent(ctx) + 1, - } - noMatchingContract := types.ContractInfoV2{ - ContractAddr: "sei1fww2a30qc4sh25crhugcclaq2supxkpxeyz9lr", - NeedOrderMatching: false, - RentBalance: keeper.GetMinProcessableRent(ctx) + 1, - } - suspendedContract := types.ContractInfoV2{ - ContractAddr: "sei1hh95z3a5vk560khjnnkd3en8r0hu063mw64jzd", - NeedOrderMatching: true, - RentBalance: keeper.GetMinProcessableRent(ctx) + 1, - Suspended: true, - } - outOfRentContract := types.ContractInfoV2{ - ContractAddr: "sei1v2ye9tnmzwx5983emm00j0c7tyxqu855ktxw5l", - NeedOrderMatching: true, - RentBalance: keeper.GetMinProcessableRent(ctx) - 1, - } - require.NoError(t, keeper.SetContract(ctx, &goodContract)) - require.NoError(t, keeper.SetContract(ctx, &noMatchingContract)) - require.NoError(t, keeper.SetContract(ctx, &suspendedContract)) - require.NoError(t, keeper.SetContract(ctx, &outOfRentContract)) - - processableContracts := keeper.GetAllProcessableContractInfo(ctx) - require.Equal(t, 1, len(processableContracts)) - require.Equal(t, "sei1avny5w9rcj7lmqmse8kukg2edvq4adqk8vlf58", processableContracts[0].ContractAddr) -} diff --git a/x/dex/keeper/epoch.go b/x/dex/keeper/epoch.go deleted file mode 100644 index 33f8012af4..0000000000 --- a/x/dex/keeper/epoch.go +++ /dev/null @@ -1,26 +0,0 @@ -package keeper - -import ( - "encoding/binary" - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" -) - -const EpochKey = "epoch" - -func (k Keeper) SetEpoch(ctx sdk.Context, epoch uint64) { - store := ctx.KVStore(k.storeKey) - bz := make([]byte, 8) - binary.BigEndian.PutUint64(bz, epoch) - store.Set([]byte(EpochKey), bz) - ctx.Logger().Info(fmt.Sprintf("Current epoch %d", epoch)) -} - -func (k Keeper) IsNewEpoch(ctx sdk.Context) (bool, uint64) { - store := ctx.KVStore(k.storeKey) - b := store.Get([]byte(EpochKey)) - lastEpoch := binary.BigEndian.Uint64(b) - currentEpoch := k.EpochKeeper.GetEpoch(ctx).CurrentEpoch - return currentEpoch > lastEpoch, currentEpoch -} diff --git a/x/dex/keeper/keeper.go b/x/dex/keeper/keeper.go deleted file mode 100644 index f89bf7ded1..0000000000 --- a/x/dex/keeper/keeper.go +++ /dev/null @@ -1,78 +0,0 @@ -package keeper - -import ( - "fmt" - - "github.com/tendermint/tendermint/libs/log" - - "github.com/CosmWasm/wasmd/x/wasm" - "github.com/cosmos/cosmos-sdk/codec" - sdk "github.com/cosmos/cosmos-sdk/types" - authkeeper "github.com/cosmos/cosmos-sdk/x/auth/keeper" - authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - bankkeeper "github.com/cosmos/cosmos-sdk/x/bank/keeper" - paramtypes "github.com/cosmos/cosmos-sdk/x/params/types" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/types" - epochkeeper "github.com/sei-protocol/sei-chain/x/epoch/keeper" -) - -type ( - Keeper struct { - Cdc codec.BinaryCodec - storeKey sdk.StoreKey - memKey sdk.StoreKey - Paramstore paramtypes.Subspace - AccountKeeper authkeeper.AccountKeeper - EpochKeeper epochkeeper.Keeper - BankKeeper bankkeeper.Keeper - WasmKeeper wasm.Keeper - MemState *dexcache.MemState - } -) - -func NewKeeper( - cdc codec.BinaryCodec, - storeKey, - memKey sdk.StoreKey, - ps paramtypes.Subspace, - epochKeeper epochkeeper.Keeper, - bankKeeper bankkeeper.Keeper, - accountKeeper authkeeper.AccountKeeper, -) *Keeper { - // set KeyTable if it has not already been set - if !ps.HasKeyTable() { - ps = ps.WithKeyTable(types.ParamKeyTable()) - } - return &Keeper{ - Cdc: cdc, - storeKey: storeKey, - memKey: memKey, - Paramstore: ps, - EpochKeeper: epochKeeper, - BankKeeper: bankKeeper, - AccountKeeper: accountKeeper, - MemState: dexcache.NewMemState(memKey), - } -} - -func (k Keeper) Logger(ctx sdk.Context) log.Logger { - return ctx.Logger().With("module", fmt.Sprintf("x/%s", types.ModuleName)) -} - -func (k Keeper) GetStoreKey() sdk.StoreKey { - return k.storeKey -} - -func (k Keeper) GetMemStoreKey() sdk.StoreKey { - return k.memKey -} - -func (k *Keeper) SetWasmKeeper(wasmKeeper *wasm.Keeper) { - k.WasmKeeper = *wasmKeeper -} - -func (k Keeper) CreateModuleAccount(ctx sdk.Context) { - moduleAcc := authtypes.NewEmptyModuleAccount(types.ModuleName, authtypes.Burner) - k.AccountKeeper.SetModuleAccount(ctx, moduleAcc) -} diff --git a/x/dex/keeper/long_book.go b/x/dex/keeper/long_book.go deleted file mode 100644 index d8f7e8c2fc..0000000000 --- a/x/dex/keeper/long_book.go +++ /dev/null @@ -1,184 +0,0 @@ -package keeper - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/types/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" -) - -// SetLongBook set a specific longBook in the store -func (k Keeper) SetLongBook(ctx sdk.Context, contractAddr string, longBook types.LongBook) { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - types.OrderBookPrefix( - true, contractAddr, longBook.Entry.PriceDenom, longBook.Entry.AssetDenom, - ), - ) - b := k.Cdc.MustMarshal(&longBook) - store.Set(GetKeyForLongBook(longBook), b) -} - -func (k Keeper) SetLongOrderBookEntry(ctx sdk.Context, contractAddr string, longBook types.OrderBookEntry) { - k.SetLongBook(ctx, contractAddr, *longBook.(*types.LongBook)) -} - -func (k Keeper) GetLongBookByPrice(ctx sdk.Context, contractAddr string, price sdk.Dec, priceDenom string, assetDenom string) (val types.LongBook, found bool) { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - types.OrderBookPrefix( - true, contractAddr, priceDenom, assetDenom, - ), - ) - b := store.Get(GetKeyForPrice(price)) - if b == nil { - return val, false - } - k.Cdc.MustUnmarshal(b, &val) - return val, true -} - -func (k Keeper) GetLongOrderBookEntryByPrice(ctx sdk.Context, contractAddr string, price sdk.Dec, priceDenom string, assetDenom string) (types.OrderBookEntry, bool) { - entry, found := k.GetLongBookByPrice(ctx, contractAddr, price, priceDenom, assetDenom) - return &entry, found -} - -func (k Keeper) RemoveLongBookByPrice(ctx sdk.Context, contractAddr string, price sdk.Dec, priceDenom string, assetDenom string) { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - types.OrderBookPrefix( - true, contractAddr, priceDenom, assetDenom, - ), - ) - store.Delete(GetKeyForPrice(price)) -} - -// GetAllLongBook returns all longBook -func (k Keeper) GetAllLongBook(ctx sdk.Context, contractAddr string) (list []types.LongBook) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.ContractKeyPrefix(types.LongBookKey, contractAddr)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.LongBook - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, val) - } - - return -} - -func (k Keeper) GetAllLongBookForPair(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string) (list []types.OrderBookEntry) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(true, contractAddr, priceDenom, assetDenom)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.LongBook - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, &val) - } - - return -} - -func (k Keeper) GetTopNLongBooksForPair(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, n int) (list []types.OrderBookEntry) { - if n == 0 { - return - } - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(true, contractAddr, priceDenom, assetDenom)) - iterator := sdk.KVStoreReversePrefixIterator(store, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.LongBook - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, &val) - if len(list) == n { - break - } - } - - return -} - -// Load the first (up to) N long book entries whose price are smaller than the specified limit -// in reverse sorted order. -// Parameters: -// -// n: the largest number of entries to load -// startExclusive: the price limit -func (k Keeper) GetTopNLongBooksForPairStarting(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, n int, startExclusive sdk.Dec) (list []types.OrderBookEntry) { - if n == 0 { - return - } - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(true, contractAddr, priceDenom, assetDenom)) - iterator := sdk.KVStoreReversePrefixIterator(store, []byte{}) - - defer iterator.Close() - - // Fast-forward - // TODO: add iterator interface that allows starting at a certain subkey under prefix - for ; iterator.Valid(); iterator.Next() { - key := dexutils.BytesToDec(iterator.Key()) - if key.LT(startExclusive) { - break - } - } - - for ; iterator.Valid(); iterator.Next() { - var val types.LongBook - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, &val) - if len(list) == n { - break - } - } - - return -} - -func (k Keeper) GetAllLongBookForPairPaginated(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, page *query.PageRequest) (list []types.LongBook, pageRes *query.PageResponse, err error) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(true, contractAddr, priceDenom, assetDenom)) - - pageRes, err = query.Paginate(store, page, func(key []byte, value []byte) error { - var longBook types.LongBook - if err := k.Cdc.Unmarshal(value, &longBook); err != nil { - return err - } - - list = append(list, longBook) - return nil - }) - - return -} - -func (k Keeper) GetLongAllocationForOrderID(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, price sdk.Dec, orderID uint64) (*types.Allocation, bool) { - orderBook, found := k.GetLongBookByPrice(ctx, contractAddr, price, priceDenom, assetDenom) - if !found { - return nil, false - } - for _, allocation := range orderBook.Entry.Allocations { - if allocation.OrderId == orderID { - return allocation, true - } - } - return nil, false -} - -func (k Keeper) RemoveAllLongBooksForContract(ctx sdk.Context, contractAddr string) { - k.removeAllForPrefix(ctx, types.OrderBookContractPrefix(true, contractAddr)) -} - -func GetKeyForLongBook(longBook types.LongBook) []byte { - return GetKeyForPrice(longBook.Entry.Price) -} - -func GetKeyForPrice(price sdk.Dec) []byte { - return dexutils.DecToBigEndian(price) -} diff --git a/x/dex/keeper/long_book_test.go b/x/dex/keeper/long_book_test.go deleted file mode 100644 index a515cf0b42..0000000000 --- a/x/dex/keeper/long_book_test.go +++ /dev/null @@ -1,92 +0,0 @@ -package keeper_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/testutil/nullify" - "github.com/sei-protocol/sei-chain/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestLongBookGet(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - items := keepertest.CreateNLongBook(keeper, ctx, 10) - for i, item := range items { - got, found := keeper.GetLongBookByPrice(ctx, keepertest.TestContract, sdk.NewDec(int64(i)), keepertest.TestPriceDenom, keepertest.TestAssetDenom) - require.True(t, found) - require.Equal(t, - nullify.Fill(&item), - nullify.Fill(&got), - ) - } -} - -func TestLongBookRemove(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - items := keepertest.CreateNLongBook(keeper, ctx, 10) - for i := range items { - keeper.RemoveLongBookByPrice(ctx, keepertest.TestContract, sdk.NewDec(int64(i)), keepertest.TestPriceDenom, keepertest.TestAssetDenom) - _, found := keeper.GetLongBookByPrice(ctx, keepertest.TestContract, sdk.NewDec(int64(i)), keepertest.TestPriceDenom, keepertest.TestAssetDenom) - require.False(t, found) - } -} - -func TestLongBookGetAll(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - items := keepertest.CreateNLongBook(keeper, ctx, 10) - require.ElementsMatch(t, - nullify.Fill(items), - nullify.Fill(keeper.GetAllLongBook(ctx, keepertest.TestContract)), - ) -} - -func TestGetTopNLongBooksForPair(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - prices := []string{"9.99", "0.001", "90.0", "10", "10.01", "9.9", "9.0", "1"} - for _, price := range prices { - keeper.SetLongBook(ctx, keepertest.TestContract, types.LongBook{ - Price: sdk.MustNewDecFromStr(price), - Entry: &types.OrderEntry{ - Price: sdk.MustNewDecFromStr(price), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - }) - } - expected := []sdk.Dec{ - sdk.MustNewDecFromStr("90.0"), - sdk.MustNewDecFromStr("10.01"), - sdk.MustNewDecFromStr("10"), - sdk.MustNewDecFromStr("9.99"), - sdk.MustNewDecFromStr("9.9"), - sdk.MustNewDecFromStr("9.0"), - sdk.MustNewDecFromStr("1"), - sdk.MustNewDecFromStr("0.001"), - } - loaded := keeper.GetTopNLongBooksForPair(ctx, keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom, 10) - require.Equal(t, expected, utils.Map(loaded, func(b types.OrderBookEntry) sdk.Dec { return b.GetPrice() })) -} - -func TestGetTopNLongBooksForPairStarting(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - prices := []string{"9.99", "0.001", "90.0", "10", "10.01", "9.9", "9.0", "1"} - for _, price := range prices { - keeper.SetLongBook(ctx, keepertest.TestContract, types.LongBook{ - Price: sdk.MustNewDecFromStr(price), - Entry: &types.OrderEntry{ - Price: sdk.MustNewDecFromStr(price), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - }) - } - expected := []sdk.Dec{ - sdk.MustNewDecFromStr("9.99"), - sdk.MustNewDecFromStr("9.9"), - } - loaded := keeper.GetTopNLongBooksForPairStarting(ctx, keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom, 2, sdk.MustNewDecFromStr("9.999")) - require.Equal(t, expected, utils.Map(loaded, func(b types.OrderBookEntry) sdk.Dec { return b.GetPrice() })) -} diff --git a/x/dex/keeper/match_result.go b/x/dex/keeper/match_result.go deleted file mode 100644 index 09424196cf..0000000000 --- a/x/dex/keeper/match_result.go +++ /dev/null @@ -1,45 +0,0 @@ -package keeper - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -const MatchResultKey = "match-result" - -func (k Keeper) SetMatchResult(ctx sdk.Context, contractAddr string, result *types.MatchResult) { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - types.MatchResultPrefix(contractAddr), - ) - height := ctx.BlockHeight() - result.Height = height - result.ContractAddr = contractAddr - bz, err := result.Marshal() - if err != nil { - panic(err) - } - store.Set([]byte(MatchResultKey), bz) -} - -func (k Keeper) GetMatchResultState(ctx sdk.Context, contractAddr string) (*types.MatchResult, bool) { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - types.MatchResultPrefix(contractAddr), - ) - bz := store.Get([]byte(MatchResultKey)) - result := types.MatchResult{} - if err := result.Unmarshal(bz); err != nil { - panic(err) - } - return &result, true -} - -func (k Keeper) DeleteMatchResultState(ctx sdk.Context, contractAddr string) { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - types.MatchResultPrefix(contractAddr), - ) - store.Delete([]byte(MatchResultKey)) -} diff --git a/x/dex/keeper/msgserver/msg_server.go b/x/dex/keeper/msgserver/msg_server.go deleted file mode 100644 index 8d459eeb02..0000000000 --- a/x/dex/keeper/msgserver/msg_server.go +++ /dev/null @@ -1,18 +0,0 @@ -package msgserver - -import ( - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -type msgServer struct { - keeper.Keeper -} - -// NewMsgServerImpl returns an implementation of the MsgServer interface -// for the provided Keeper. -func NewMsgServerImpl(keeper keeper.Keeper) types.MsgServer { - return &msgServer{Keeper: keeper} -} - -var _ types.MsgServer = msgServer{} diff --git a/x/dex/keeper/msgserver/msg_server_cancel_orders.go b/x/dex/keeper/msgserver/msg_server_cancel_orders.go deleted file mode 100644 index 8ca3a4a1db..0000000000 --- a/x/dex/keeper/msgserver/msg_server_cancel_orders.go +++ /dev/null @@ -1,12 +0,0 @@ -package msgserver - -import ( - "context" - - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k msgServer) CancelOrders(goCtx context.Context, msg *types.MsgCancelOrders) (*types.MsgCancelOrdersResponse, error) { - return nil, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated") -} diff --git a/x/dex/keeper/msgserver/msg_server_cancel_orders_test.go b/x/dex/keeper/msgserver/msg_server_cancel_orders_test.go deleted file mode 100644 index 88f88473c2..0000000000 --- a/x/dex/keeper/msgserver/msg_server_cancel_orders_test.go +++ /dev/null @@ -1,36 +0,0 @@ -package msgserver_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestCancelOrder(t *testing.T) { - // store a long limit order to the orderbook - keeper, ctx := keepertest.DexKeeper(t) - - // cancel order - msg := &types.MsgCancelOrders{ - Creator: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - Cancellations: []*types.Cancellation{ - { - Price: sdk.OneDec(), - PositionDirection: types.PositionDirection_LONG, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - Id: 1, - }, - }, - } - wctx := sdk.WrapSDKContext(ctx) - server := msgserver.NewMsgServerImpl(*keeper) - _, err := server.CancelOrders(wctx, msg) - require.EqualError(t, err, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated").Error()) -} diff --git a/x/dex/keeper/msgserver/msg_server_contract_deposit_rent.go b/x/dex/keeper/msgserver/msg_server_contract_deposit_rent.go deleted file mode 100644 index d1a4cf3299..0000000000 --- a/x/dex/keeper/msgserver/msg_server_contract_deposit_rent.go +++ /dev/null @@ -1,12 +0,0 @@ -package msgserver - -import ( - "context" - - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k msgServer) ContractDepositRent(goCtx context.Context, msg *types.MsgContractDepositRent) (*types.MsgContractDepositRentResponse, error) { - return nil, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated") -} diff --git a/x/dex/keeper/msgserver/msg_server_contract_deposit_rent_test.go b/x/dex/keeper/msgserver/msg_server_contract_deposit_rent_test.go deleted file mode 100644 index 894ba170ee..0000000000 --- a/x/dex/keeper/msgserver/msg_server_contract_deposit_rent_test.go +++ /dev/null @@ -1,34 +0,0 @@ -package msgserver_test - -import ( - "context" - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/stretchr/testify/require" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -func TestDepositRent(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - dexkeeper := testApp.DexKeeper - - depositAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - - handler := dex.NewHandler(dexkeeper) - _, err := handler(ctx, &types.MsgContractDepositRent{ - Sender: depositAccount.String(), - ContractAddr: TestContractA, - Amount: types.DefaultParams().MinRentDeposit, - }) - require.EqualError(t, err, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated").Error()) -} diff --git a/x/dex/keeper/msgserver/msg_server_place_orders.go b/x/dex/keeper/msgserver/msg_server_place_orders.go deleted file mode 100644 index ae7a707001..0000000000 --- a/x/dex/keeper/msgserver/msg_server_place_orders.go +++ /dev/null @@ -1,12 +0,0 @@ -package msgserver - -import ( - "context" - - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k msgServer) PlaceOrders(goCtx context.Context, msg *types.MsgPlaceOrders) (*types.MsgPlaceOrdersResponse, error) { - return nil, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated") -} diff --git a/x/dex/keeper/msgserver/msg_server_place_orders_fuzz_test.go b/x/dex/keeper/msgserver/msg_server_place_orders_fuzz_test.go deleted file mode 100644 index ec88e75db1..0000000000 --- a/x/dex/keeper/msgserver/msg_server_place_orders_fuzz_test.go +++ /dev/null @@ -1,65 +0,0 @@ -package msgserver_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - fuzzutils "github.com/sei-protocol/sei-chain/testutil/fuzzing" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func FuzzPlaceOrders(f *testing.F) { - f.Add(uint64(0), int32(0), 2, 2, int64(10), false, int64(2), false, keepertest.TestPriceDenom, keepertest.TestAssetDenom, int32(0), int32(0), "", "", false, int64(20)) - f.Fuzz(fuzzTargetPlaceOrders) -} - -func fuzzTargetPlaceOrders( - t *testing.T, - id uint64, - status int32, - accountIdx int, - contractIdx int, - priceI int64, - priceIsNil bool, - quantityI int64, - quantityIsNil bool, - priceDenom string, - assetDenom string, - orderType int32, - positionDirection int32, - data string, - statusDescription string, - fundIsNil bool, - fundAmount int64, -) { - keeper, ctx := keepertest.DexKeeper(t) - contract := fuzzutils.GetContract(contractIdx) - keeper.AddRegisteredPair(ctx, contract, keepertest.TestPair) - keeper.SetPriceTickSizeForPair(ctx, TestContract, keepertest.TestPair, *keepertest.TestPair.PriceTicksize) - keeper.SetQuantityTickSizeForPair(ctx, TestContract, keepertest.TestPair, *keepertest.TestPair.QuantityTicksize) - wctx := sdk.WrapSDKContext(ctx) - msg := &types.MsgPlaceOrders{ - Creator: fuzzutils.GetAccount(accountIdx), - ContractAddr: contract, - Orders: []*types.Order{ - { - Id: id, - Status: types.OrderStatus(status), - Price: fuzzutils.FuzzDec(priceI, priceIsNil), - Quantity: fuzzutils.FuzzDec(quantityI, quantityIsNil), - Data: data, - StatusDescription: statusDescription, - PositionDirection: types.PositionDirection(positionDirection), - OrderType: types.OrderType(orderType), - PriceDenom: priceDenom, - AssetDenom: assetDenom, - }, - }, - Funds: []sdk.Coin{fuzzutils.FuzzCoin(priceDenom, fundIsNil, fundAmount)}, - } - server := msgserver.NewMsgServerImpl(*keeper) - require.NotPanics(t, func() { server.PlaceOrders(wctx, msg) }) -} diff --git a/x/dex/keeper/msgserver/msg_server_place_orders_test.go b/x/dex/keeper/msgserver/msg_server_place_orders_test.go deleted file mode 100644 index d14e3e5329..0000000000 --- a/x/dex/keeper/msgserver/msg_server_place_orders_test.go +++ /dev/null @@ -1,49 +0,0 @@ -package msgserver_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -const ( - TestCreator = "sei1ewxvf5a9wq9zk5nurtl6m9yfxpnhyp7s7uk5sl" - TestContract = "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m" -) - -func TestPlaceOrder(t *testing.T) { - msg := &types.MsgPlaceOrders{ - Creator: TestCreator, - ContractAddr: TestContract, - Orders: []*types.Order{ - { - Price: sdk.MustNewDecFromStr("10"), - Quantity: sdk.MustNewDecFromStr("10"), - Data: "", - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_LIMIT, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - { - Price: sdk.MustNewDecFromStr("20"), - Quantity: sdk.MustNewDecFromStr("5"), - Data: "", - PositionDirection: types.PositionDirection_SHORT, - OrderType: types.OrderType_MARKET, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - }, - } - keeper, ctx := keepertest.DexKeeper(t) - wctx := sdk.WrapSDKContext(ctx) - server := msgserver.NewMsgServerImpl(*keeper) - _, err := server.PlaceOrders(wctx, msg) - require.EqualError(t, err, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated").Error()) -} diff --git a/x/dex/keeper/msgserver/msg_server_register_contract.go b/x/dex/keeper/msgserver/msg_server_register_contract.go deleted file mode 100644 index 77bec2bd47..0000000000 --- a/x/dex/keeper/msgserver/msg_server_register_contract.go +++ /dev/null @@ -1,12 +0,0 @@ -package msgserver - -import ( - "context" - - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k msgServer) RegisterContract(goCtx context.Context, msg *types.MsgRegisterContract) (*types.MsgRegisterContractResponse, error) { - return nil, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated") -} diff --git a/x/dex/keeper/msgserver/msg_server_register_contract_test.go b/x/dex/keeper/msgserver/msg_server_register_contract_test.go deleted file mode 100644 index c4bcc6e1cd..0000000000 --- a/x/dex/keeper/msgserver/msg_server_register_contract_test.go +++ /dev/null @@ -1,34 +0,0 @@ -package msgserver_test - -import ( - "context" - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/stretchr/testify/require" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -const ( - TestContractA = "sei1hrpna9v7vs3stzyd4z3xf00676kf78zpe2u5ksvljswn2vnjp3yslucc3n" -) - -func TestRegisterContract(t *testing.T) { - // Instantiate and get contract address - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - wctx := sdk.WrapSDKContext(ctx) - keeper := testApp.DexKeeper - - server := msgserver.NewMsgServerImpl(keeper) - _, err := server.RegisterContract(wctx, &types.MsgRegisterContract{}) - require.EqualError(t, err, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated").Error()) -} diff --git a/x/dex/keeper/msgserver/msg_server_register_pairs.go b/x/dex/keeper/msgserver/msg_server_register_pairs.go deleted file mode 100644 index 582521dd5d..0000000000 --- a/x/dex/keeper/msgserver/msg_server_register_pairs.go +++ /dev/null @@ -1,12 +0,0 @@ -package msgserver - -import ( - "context" - - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k msgServer) RegisterPairs(goCtx context.Context, msg *types.MsgRegisterPairs) (*types.MsgRegisterPairsResponse, error) { - return nil, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated") -} diff --git a/x/dex/keeper/msgserver/msg_server_register_pairs_test.go b/x/dex/keeper/msgserver/msg_server_register_pairs_test.go deleted file mode 100644 index bc4dc91983..0000000000 --- a/x/dex/keeper/msgserver/msg_server_register_pairs_test.go +++ /dev/null @@ -1,38 +0,0 @@ -package msgserver_test - -import ( - "context" - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/stretchr/testify/require" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -func TestRegisterPairs(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - wctx := sdk.WrapSDKContext(ctx) - keeper := testApp.DexKeeper - - server := msgserver.NewMsgServerImpl(keeper) - - batchContractPairs := []types.BatchContractPair{} - batchContractPairs = append(batchContractPairs, types.BatchContractPair{ - ContractAddr: TestContractA, - Pairs: []*types.Pair{&keepertest.TestPair}, - }) - _, err := server.RegisterPairs(wctx, &types.MsgRegisterPairs{ - Creator: keepertest.TestAccount, - Batchcontractpair: batchContractPairs, - }) - require.EqualError(t, err, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated").Error()) -} diff --git a/x/dex/keeper/msgserver/msg_server_unregister_contract.go b/x/dex/keeper/msgserver/msg_server_unregister_contract.go deleted file mode 100644 index c12650b854..0000000000 --- a/x/dex/keeper/msgserver/msg_server_unregister_contract.go +++ /dev/null @@ -1,12 +0,0 @@ -package msgserver - -import ( - "context" - - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k msgServer) UnregisterContract(goCtx context.Context, msg *types.MsgUnregisterContract) (*types.MsgUnregisterContractResponse, error) { - return nil, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated") -} diff --git a/x/dex/keeper/msgserver/msg_server_unregister_contract_test.go b/x/dex/keeper/msgserver/msg_server_unregister_contract_test.go deleted file mode 100644 index 2d91979a76..0000000000 --- a/x/dex/keeper/msgserver/msg_server_unregister_contract_test.go +++ /dev/null @@ -1,34 +0,0 @@ -package msgserver_test - -import ( - "context" - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/stretchr/testify/require" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -func TestUnregisterContractSetSiblings(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - keeper := testApp.DexKeeper - - testAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - - handler := dex.NewHandler(keeper) - - _, err := handler(ctx, &types.MsgUnregisterContract{ - Creator: testAccount.String(), - ContractAddr: TestContractA, - }) - require.EqualError(t, err, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated").Error()) -} diff --git a/x/dex/keeper/msgserver/msg_server_unsuspend_contract.go b/x/dex/keeper/msgserver/msg_server_unsuspend_contract.go deleted file mode 100644 index d1da8c2c58..0000000000 --- a/x/dex/keeper/msgserver/msg_server_unsuspend_contract.go +++ /dev/null @@ -1,12 +0,0 @@ -package msgserver - -import ( - "context" - - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k msgServer) UnsuspendContract(goCtx context.Context, msg *types.MsgUnsuspendContract) (*types.MsgUnsuspendContractResponse, error) { - return nil, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated") -} diff --git a/x/dex/keeper/msgserver/msg_server_unsuspend_contract_test.go b/x/dex/keeper/msgserver/msg_server_unsuspend_contract_test.go deleted file mode 100644 index a2ac0f3ace..0000000000 --- a/x/dex/keeper/msgserver/msg_server_unsuspend_contract_test.go +++ /dev/null @@ -1,23 +0,0 @@ -package msgserver_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestUnsuspendContract(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wctx := sdk.WrapSDKContext(ctx) - server := msgserver.NewMsgServerImpl(*keeper) - _, err := server.UnsuspendContract(wctx, &types.MsgUnsuspendContract{ - Creator: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - }) - require.EqualError(t, err, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated").Error()) -} diff --git a/x/dex/keeper/msgserver/msg_server_update_price_tick_size.go b/x/dex/keeper/msgserver/msg_server_update_price_tick_size.go deleted file mode 100644 index 6a09e1dc79..0000000000 --- a/x/dex/keeper/msgserver/msg_server_update_price_tick_size.go +++ /dev/null @@ -1,12 +0,0 @@ -package msgserver - -import ( - "context" - - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k msgServer) UpdatePriceTickSize(goCtx context.Context, msg *types.MsgUpdatePriceTickSize) (*types.MsgUpdateTickSizeResponse, error) { - return nil, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated") -} diff --git a/x/dex/keeper/msgserver/msg_server_update_price_tick_size_test.go b/x/dex/keeper/msgserver/msg_server_update_price_tick_size_test.go deleted file mode 100644 index 77ab54fae1..0000000000 --- a/x/dex/keeper/msgserver/msg_server_update_price_tick_size_test.go +++ /dev/null @@ -1,40 +0,0 @@ -package msgserver_test - -import ( - "context" - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/stretchr/testify/require" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -func TestUpdatePriceTickSize(t *testing.T) { - // Instantiate and get contract address - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - wctx := sdk.WrapSDKContext(ctx) - keeper := testApp.DexKeeper - server := msgserver.NewMsgServerImpl(keeper) - - // Test updated tick size - tickUpdates := []types.TickSize{} - tickUpdates = append(tickUpdates, types.TickSize{ - ContractAddr: TestContractA, - Pair: &keepertest.TestPair, - Ticksize: sdk.MustNewDecFromStr("0.1"), - }) - _, err := server.UpdatePriceTickSize(wctx, &types.MsgUpdatePriceTickSize{ - Creator: keepertest.TestAccount, - TickSizeList: tickUpdates, - }) - require.EqualError(t, err, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated").Error()) -} diff --git a/x/dex/keeper/msgserver/msg_server_update_quantity_tick_size.go b/x/dex/keeper/msgserver/msg_server_update_quantity_tick_size.go deleted file mode 100644 index f4e948a54d..0000000000 --- a/x/dex/keeper/msgserver/msg_server_update_quantity_tick_size.go +++ /dev/null @@ -1,12 +0,0 @@ -package msgserver - -import ( - "context" - - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k msgServer) UpdateQuantityTickSize(goCtx context.Context, msg *types.MsgUpdateQuantityTickSize) (*types.MsgUpdateTickSizeResponse, error) { - return nil, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated") -} diff --git a/x/dex/keeper/msgserver/msg_server_update_quantity_tick_size_test.go b/x/dex/keeper/msgserver/msg_server_update_quantity_tick_size_test.go deleted file mode 100644 index eccbf9e454..0000000000 --- a/x/dex/keeper/msgserver/msg_server_update_quantity_tick_size_test.go +++ /dev/null @@ -1,41 +0,0 @@ -package msgserver_test - -import ( - "context" - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/stretchr/testify/require" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" -) - -func TestUpdateQuantityTickSize(t *testing.T) { - // Instantiate and get contract address - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - wctx := sdk.WrapSDKContext(ctx) - keeper := testApp.DexKeeper - - server := msgserver.NewMsgServerImpl(keeper) - - // Test updated tick size - tickUpdates := []types.TickSize{} - tickUpdates = append(tickUpdates, types.TickSize{ - ContractAddr: TestContractA, - Pair: &keepertest.TestPair, - Ticksize: sdk.MustNewDecFromStr("0.1"), - }) - _, err := server.UpdateQuantityTickSize(wctx, &types.MsgUpdateQuantityTickSize{ - Creator: keepertest.TestAccount, - TickSizeList: tickUpdates, - }) - require.EqualError(t, err, sdkerrors.Wrapf(sdkerrors.ErrNotSupported, "deprecated").Error()) -} diff --git a/x/dex/keeper/msgserver/testdata/hackatom.wasm b/x/dex/keeper/msgserver/testdata/hackatom.wasm deleted file mode 100644 index 183eef304c9de413a24884ec6611ee0d13434fae..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 208805 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

}GU#h*Z)$o|;7eU!8k$7&m@*^f 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 D^F!=F diff --git a/x/dex/keeper/msgserver/validations.go b/x/dex/keeper/msgserver/validations.go deleted file mode 100644 index cdbbb06474..0000000000 --- a/x/dex/keeper/msgserver/validations.go +++ /dev/null @@ -1,40 +0,0 @@ -package msgserver - -import ( - "fmt" - "math" - - wasmkeeper "github.com/CosmWasm/wasmd/x/wasm/keeper" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -// Since cosmwasm would amplify gas limit by a multiplier for its internal gas metering, -// we want to make sure the amplified result doesn't exceed uint64 limit. -func (k msgServer) ValidateRentBalance(ctx sdk.Context, rentBalance uint64) error { - maxAllowedRent := k.maxAllowedRentBalance() - minAllowedRent := k.minAllowedRentBalance(ctx) - if rentBalance > maxAllowedRent || rentBalance < minAllowedRent { - return fmt.Errorf("rent balance %d is either bigger than the maximum allowed rent balance %d, or smaller than the minimal allowed balance %d", - rentBalance, maxAllowedRent, minAllowedRent) - } - return nil -} - -func (k msgServer) ValidateSuspension(ctx sdk.Context, contractAddress string) error { - contract, err := k.GetContract(ctx, contractAddress) - if err == nil && contract.Suspended { - return types.ErrContractSuspended - } - return nil -} - -func (k msgServer) maxAllowedRentBalance() uint64 { - // TODO: replace with a wasm keeper query once its gas registry is made public - return uint64(math.MaxUint64) / wasmkeeper.DefaultGasMultiplier -} - -func (k msgServer) minAllowedRentBalance(ctx sdk.Context) uint64 { - params := k.GetParams(ctx) - return params.MinRentDeposit -} diff --git a/x/dex/keeper/order_count.go b/x/dex/keeper/order_count.go deleted file mode 100644 index 5b72366cb6..0000000000 --- a/x/dex/keeper/order_count.go +++ /dev/null @@ -1,56 +0,0 @@ -package keeper - -import ( - "encoding/binary" - "fmt" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k Keeper) SetOrderCount(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, direction types.PositionDirection, price sdk.Dec, count uint64) error { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - types.OrderCountPrefix(contractAddr, priceDenom, assetDenom, direction == types.PositionDirection_LONG), - ) - key, err := price.Marshal() - if err != nil { - return err - } - value := make([]byte, 8) - binary.BigEndian.PutUint64(value, count) - store.Set(key, value) - return nil -} - -func (k Keeper) GetOrderCountState(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, direction types.PositionDirection, price sdk.Dec) uint64 { - store := prefix.NewStore( - ctx.KVStore(k.storeKey), - types.OrderCountPrefix(contractAddr, priceDenom, assetDenom, direction == types.PositionDirection_LONG), - ) - key, err := price.Marshal() - if err != nil { - ctx.Logger().Error(fmt.Sprintf("error marshal provided price %s due to %s", price.String(), err)) - return 0 - } - value := store.Get(key) - if value == nil { - return 0 - } - return binary.BigEndian.Uint64(value) -} - -func (k Keeper) DecreaseOrderCount(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, direction types.PositionDirection, price sdk.Dec, count uint64) error { - oldCount := k.GetOrderCountState(ctx, contractAddr, priceDenom, assetDenom, direction, price) - newCount := uint64(0) - if oldCount > count { - newCount = oldCount - count - } - return k.SetOrderCount(ctx, contractAddr, priceDenom, assetDenom, direction, price, newCount) -} - -func (k Keeper) IncreaseOrderCount(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, direction types.PositionDirection, price sdk.Dec, count uint64) error { - oldCount := k.GetOrderCountState(ctx, contractAddr, priceDenom, assetDenom, direction, price) - return k.SetOrderCount(ctx, contractAddr, priceDenom, assetDenom, direction, price, oldCount+count) -} diff --git a/x/dex/keeper/order_count_test.go b/x/dex/keeper/order_count_test.go deleted file mode 100644 index 1fe604933c..0000000000 --- a/x/dex/keeper/order_count_test.go +++ /dev/null @@ -1,35 +0,0 @@ -package keeper_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestGetSetOrderCount(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - for _, direction := range []types.PositionDirection{ - types.PositionDirection_LONG, - types.PositionDirection_SHORT, - } { - require.Equal(t, uint64(0), keeper.GetOrderCountState(ctx, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, direction, sdk.NewDec(1))) - require.Nil(t, keeper.SetOrderCount(ctx, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, direction, sdk.NewDec(1), 5)) - require.Equal(t, uint64(5), keeper.GetOrderCountState(ctx, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, direction, sdk.NewDec(1))) - } -} - -func TestIncreaseOrderCount(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keeper.IncreaseOrderCount(ctx, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(1), 10) - require.Equal(t, uint64(10), keeper.GetOrderCountState(ctx, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(1))) -} - -func TestDecreaseOrderCount(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - require.Nil(t, keeper.SetOrderCount(ctx, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(1), 10)) - keeper.DecreaseOrderCount(ctx, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(1), 5) - require.Equal(t, uint64(5), keeper.GetOrderCountState(ctx, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(1))) -} diff --git a/x/dex/keeper/order_placement.go b/x/dex/keeper/order_placement.go deleted file mode 100644 index b6d5fcec60..0000000000 --- a/x/dex/keeper/order_placement.go +++ /dev/null @@ -1,33 +0,0 @@ -package keeper - -import ( - "encoding/binary" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k Keeper) GetNextOrderID(ctx sdk.Context, contractAddr string) uint64 { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.NextOrderIDPrefix(contractAddr)) - byteKey := types.KeyPrefix(types.NextOrderIDKey) - bz := store.Get(byteKey) - if bz == nil { - return 0 - } - return binary.BigEndian.Uint64(bz) -} - -func (k Keeper) SetNextOrderID(ctx sdk.Context, contractAddr string, nextID uint64) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.NextOrderIDPrefix(contractAddr)) - byteKey := types.KeyPrefix(types.NextOrderIDKey) - bz := make([]byte, 8) - binary.BigEndian.PutUint64(bz, nextID) - store.Set(byteKey, bz) -} - -func (k Keeper) DeleteNextOrderID(ctx sdk.Context, contractAddr string) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.NextOrderIDPrefix(contractAddr)) - byteKey := types.KeyPrefix(types.NextOrderIDKey) - store.Delete(byteKey) -} diff --git a/x/dex/keeper/pair.go b/x/dex/keeper/pair.go deleted file mode 100644 index 914131cc92..0000000000 --- a/x/dex/keeper/pair.go +++ /dev/null @@ -1,56 +0,0 @@ -package keeper - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k Keeper) AddRegisteredPair(ctx sdk.Context, contractAddr string, pair types.Pair) bool { - // only add pairs that haven't been added before - if k.HasRegisteredPair(ctx, contractAddr, pair.PriceDenom, pair.AssetDenom) { - return false - } - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.RegisteredPairPrefix(contractAddr)) - store.Set(types.PairPrefix(pair.PriceDenom, pair.AssetDenom), k.Cdc.MustMarshal(&pair)) - return true -} - -func (k Keeper) HasRegisteredPair(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string) bool { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.RegisteredPairPrefix(contractAddr)) - return store.Has(types.PairPrefix(priceDenom, assetDenom)) -} - -func (k Keeper) GetRegisteredPair(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string) (types.Pair, bool) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.RegisteredPairPrefix(contractAddr)) - b := store.Get(types.PairPrefix(priceDenom, assetDenom)) - res := types.Pair{} - if b == nil { - return res, false - } - err := res.Unmarshal(b) - if err != nil { - panic(err) - } - return res, true -} - -func (k Keeper) GetAllRegisteredPairs(ctx sdk.Context, contractAddr string) []types.Pair { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.RegisteredPairPrefix(contractAddr)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - list := []types.Pair{} - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.Pair - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, val) - } - - return list -} - -func (k Keeper) DeleteAllRegisteredPairsForContract(ctx sdk.Context, contractAddr string) { - k.removeAllForPrefix(ctx, types.RegisteredPairPrefix(contractAddr)) -} diff --git a/x/dex/keeper/pair_test.go b/x/dex/keeper/pair_test.go deleted file mode 100644 index 8dcbe65d2b..0000000000 --- a/x/dex/keeper/pair_test.go +++ /dev/null @@ -1,41 +0,0 @@ -package keeper_test - -import ( - "testing" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/testutil/nullify" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestAddGetPair(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keeper.AddRegisteredPair(ctx, keepertest.TestContract, types.Pair{ - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - PriceTicksize: &keepertest.TestTicksize, - QuantityTicksize: &keepertest.TestTicksize, - }) - require.ElementsMatch(t, - nullify.Fill([]types.Pair{{ - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - PriceTicksize: &keepertest.TestTicksize, - QuantityTicksize: &keepertest.TestTicksize, - }}), - nullify.Fill(keeper.GetAllRegisteredPairs(ctx, keepertest.TestContract)), - ) - - pair, found := keeper.GetRegisteredPair(ctx, keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom) - require.True(t, found) - require.Equal(t, types.Pair{ - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - PriceTicksize: &keepertest.TestTicksize, - QuantityTicksize: &keepertest.TestTicksize, - }, pair) - hasPair := keeper.HasRegisteredPair(ctx, keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom) - require.True(t, hasPair) - -} diff --git a/x/dex/keeper/params.go b/x/dex/keeper/params.go deleted file mode 100644 index 2e4c77c023..0000000000 --- a/x/dex/keeper/params.go +++ /dev/null @@ -1,42 +0,0 @@ -package keeper - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -// GetParams get all parameters as types.Params -func (k Keeper) GetParams(ctx sdk.Context) types.Params { - params := types.Params{} - k.Paramstore.GetParamSet(ctx, ¶ms) - return params -} - -func (k Keeper) GetSettlementGasAllowance(ctx sdk.Context, numSettlements int) uint64 { - return k.GetParams(ctx).GasAllowancePerSettlement * uint64(numSettlements) -} - -func (k Keeper) GetMinProcessableRent(ctx sdk.Context) uint64 { - return k.GetParams(ctx).MinProcessableRent -} - -func (k Keeper) GetOrderBookEntriesPerLoad(ctx sdk.Context) uint64 { - return k.GetParams(ctx).OrderBookEntriesPerLoad -} - -func (k Keeper) GetContractUnsuspendCost(ctx sdk.Context) uint64 { - return k.GetParams(ctx).ContractUnsuspendCost -} - -func (k Keeper) GetMaxOrderPerPrice(ctx sdk.Context) uint64 { - return k.GetParams(ctx).MaxOrderPerPrice -} - -func (k Keeper) GetMaxPairsPerContract(ctx sdk.Context) uint64 { - return k.GetParams(ctx).MaxPairsPerContract -} - -// SetParams set the params -func (k Keeper) SetParams(ctx sdk.Context, params types.Params) { - k.Paramstore.SetParamSet(ctx, ¶ms) -} diff --git a/x/dex/keeper/params_test.go b/x/dex/keeper/params_test.go deleted file mode 100644 index 1bbab914e8..0000000000 --- a/x/dex/keeper/params_test.go +++ /dev/null @@ -1,24 +0,0 @@ -package keeper_test - -import ( - "testing" - - testkeeper "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestGetParams(t *testing.T) { - k, ctx := testkeeper.DexKeeper(t) - params := types.DefaultParams() - - k.SetParams(ctx, params) - - require.EqualValues(t, params, k.GetParams(ctx)) -} - -func TestGetSettlementGasAllowance(t *testing.T) { - k, ctx := testkeeper.DexKeeper(t) - gasAllowance := k.GetSettlementGasAllowance(ctx, 10) - require.Equal(t, uint64(10)*types.DefaultGasAllowancePerSettlement, gasAllowance) -} diff --git a/x/dex/keeper/price.go b/x/dex/keeper/price.go deleted file mode 100644 index d18cc1ce0f..0000000000 --- a/x/dex/keeper/price.go +++ /dev/null @@ -1,98 +0,0 @@ -package keeper - -import ( - "encoding/binary" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k Keeper) SetPriceState(ctx sdk.Context, price types.Price, contractAddr string) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.PricePrefix(contractAddr, price.Pair.PriceDenom, price.Pair.AssetDenom)) - b := k.Cdc.MustMarshal(&price) - store.Set(GetKeyForTs(price.SnapshotTimestampInSeconds), b) -} - -func (k Keeper) DeletePriceStateBefore(ctx sdk.Context, contractAddr string, timestamp uint64, pair types.Pair) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.PricePrefix(contractAddr, pair.PriceDenom, pair.AssetDenom)) - for _, key := range k.GetPriceKeysToDelete(store, timestamp) { - store.Delete(key) - } -} - -func (k Keeper) GetPriceKeysToDelete(store sdk.KVStore, timestamp uint64) [][]byte { - keys := [][]byte{} - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - defer iterator.Close() - - // Since timestamp is encoded in big endian, the first price being iterated has the smallest timestamp. - for ; iterator.Valid(); iterator.Next() { - priceKey := iterator.Key() - priceTs := binary.BigEndian.Uint64(priceKey) - if priceTs < timestamp { - keys = append(keys, priceKey) - } else { - break - } - } - return keys -} - -func (k Keeper) GetPriceState(ctx sdk.Context, contractAddr string, timestamp uint64, pair types.Pair) (types.Price, bool) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.PricePrefix(contractAddr, pair.PriceDenom, pair.AssetDenom)) - res := types.Price{} - key := GetKeyForTs(timestamp) - if !store.Has(key) { - res.Pair = &pair - return res, false - } - b := store.Get(key) - k.Cdc.MustUnmarshal(b, &res) - return res, true -} - -func (k Keeper) GetAllPrices(ctx sdk.Context, contractAddr string, pair types.Pair) (list []*types.Price) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.PricePrefix(contractAddr, pair.PriceDenom, pair.AssetDenom)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.Price - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, &val) - } - - return -} - -func (k Keeper) GetPricesForTwap(ctx sdk.Context, contractAddr string, pair types.Pair, lookback uint64) (list []*types.Price) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.PricePrefix(contractAddr, pair.PriceDenom, pair.AssetDenom)) - iterator := sdk.KVStoreReversePrefixIterator(store, []byte{}) - - defer iterator.Close() - - cutoff := uint64(ctx.BlockTime().Unix()) - lookback - for ; iterator.Valid(); iterator.Next() { - var val types.Price - k.Cdc.MustUnmarshal(iterator.Value(), &val) - // add to list before breaking since we want to include one older price if there is any - list = append(list, &val) - if val.SnapshotTimestampInSeconds < cutoff { - break - } - } - - return -} - -func (k Keeper) RemoveAllPricesForContract(ctx sdk.Context, contractAddr string) { - k.removeAllForPrefix(ctx, types.PriceContractPrefix(contractAddr)) -} - -func GetKeyForTs(ts uint64) []byte { - tsKey := make([]byte, 8) - binary.BigEndian.PutUint64(tsKey, ts) - return tsKey -} diff --git a/x/dex/keeper/price_test.go b/x/dex/keeper/price_test.go deleted file mode 100644 index fa519d47cd..0000000000 --- a/x/dex/keeper/price_test.go +++ /dev/null @@ -1,20 +0,0 @@ -package keeper_test - -import ( - "testing" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/stretchr/testify/require" -) - -func TestDeletePriceStateBefore(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keepertest.SeedPriceSnapshot(ctx, keeper, "100", 1) - keepertest.SeedPriceSnapshot(ctx, keeper, "101", 2) - keepertest.SeedPriceSnapshot(ctx, keeper, "99", 3) - keeper.DeletePriceStateBefore(ctx, keepertest.TestContract, 2, keepertest.TestPair) - prices := keeper.GetAllPrices(ctx, keepertest.TestContract, keepertest.TestPair) - require.Equal(t, 2, len(prices)) - require.Equal(t, uint64(2), prices[0].SnapshotTimestampInSeconds) - require.Equal(t, uint64(3), prices[1].SnapshotTimestampInSeconds) -} diff --git a/x/dex/keeper/query/grpc_query.go b/x/dex/keeper/query/grpc_query.go deleted file mode 100644 index 2cc5e787e2..0000000000 --- a/x/dex/keeper/query/grpc_query.go +++ /dev/null @@ -1,7 +0,0 @@ -package query - -import ( - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -var _ types.QueryServer = KeeperWrapper{} diff --git a/x/dex/keeper/query/grpc_query_asset_list.go b/x/dex/keeper/query/grpc_query_asset_list.go deleted file mode 100644 index fc7748be9a..0000000000 --- a/x/dex/keeper/query/grpc_query_asset_list.go +++ /dev/null @@ -1,36 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) AssetList(c context.Context, req *types.QueryAssetListRequest) (*types.QueryAssetListResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(c) - - allAssetMetadata := k.GetAllAssetMetadata(ctx) - - return &types.QueryAssetListResponse{AssetList: allAssetMetadata}, nil -} - -func (k KeeperWrapper) AssetMetadata(c context.Context, req *types.QueryAssetMetadataRequest) (*types.QueryAssetMetadataResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(c) - - assetMetadata, found := k.GetAssetMetadataByDenom(ctx, req.Denom) - if !found { - return nil, sdkerrors.ErrKeyNotFound - } - - return &types.QueryAssetMetadataResponse{Metadata: &assetMetadata}, nil -} diff --git a/x/dex/keeper/query/grpc_query_asset_list_test.go b/x/dex/keeper/query/grpc_query_asset_list_test.go deleted file mode 100644 index b2bd8a4a97..0000000000 --- a/x/dex/keeper/query/grpc_query_asset_list_test.go +++ /dev/null @@ -1,50 +0,0 @@ -package query_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestAssetListQuery(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wctx := sdk.WrapSDKContext(ctx) - item := keepertest.CreateAssetMetadata(keeper, ctx) - - var expectedAssetList []types.AssetMetadata - expectedAssetList = append(expectedAssetList, item) - - request := types.QueryAssetListRequest{} - expectedResponse := types.QueryAssetListResponse{ - AssetList: expectedAssetList, - } - wrapper := query.KeeperWrapper{Keeper: keeper} - t.Run("Asset list query", func(t *testing.T) { - response, err := wrapper.AssetList(wctx, &request) - require.NoError(t, err) - require.Equal(t, expectedResponse, *response) - }) -} - -func TestAssetMetadataQuery(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wctx := sdk.WrapSDKContext(ctx) - expectedMetadata := keepertest.CreateAssetMetadata(keeper, ctx) - - request := types.QueryAssetMetadataRequest{ - Denom: "axlusdc", - } - expectedResponse := types.QueryAssetMetadataResponse{ - Metadata: &expectedMetadata, - } - wrapper := query.KeeperWrapper{Keeper: keeper} - t.Run("Asset metadata query", func(t *testing.T) { - response, err := wrapper.AssetMetadata(wctx, &request) - require.NoError(t, err) - require.Equal(t, expectedResponse, *response) - }) -} diff --git a/x/dex/keeper/query/grpc_query_get_historical_prices.go b/x/dex/keeper/query/grpc_query_get_historical_prices.go deleted file mode 100644 index 9e6dc434f0..0000000000 --- a/x/dex/keeper/query/grpc_query_get_historical_prices.go +++ /dev/null @@ -1,119 +0,0 @@ -package query - -import ( - "context" - "sort" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -var ZeroPrice = sdk.ZeroDec() - -func (k KeeperWrapper) GetHistoricalPrices(goCtx context.Context, req *types.QueryGetHistoricalPricesRequest) (*types.QueryGetHistoricalPricesResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - - ctx := sdk.UnwrapSDKContext(goCtx) - - prices := k.GetAllPrices(ctx, req.ContractAddr, types.Pair{PriceDenom: req.PriceDenom, AssetDenom: req.AssetDenom}) - currentTimeStamp := uint64(ctx.BlockTime().Unix()) - beginTimestamp := currentTimeStamp - req.NumOfPeriods*req.PeriodLengthInSeconds - // sort descending - sort.Slice(prices, func(i, j int) bool { - return prices[i].SnapshotTimestampInSeconds > prices[j].SnapshotTimestampInSeconds - }) - validPrices := []*types.Price{} - for _, price := range prices { - // append early so that we include the latest price before beginTimestamp, since - // we need it to set the open price of the first period. - if price.SnapshotTimestampInSeconds < currentTimeStamp { - validPrices = append(validPrices, price) - } - if price.SnapshotTimestampInSeconds < beginTimestamp { - break - } - } - - candlesticks := make([]*types.PriceCandlestick, req.NumOfPeriods) - - // set timestamp - for i := range candlesticks { - candlesticks[i] = &types.PriceCandlestick{} - candlesticks[i].EndTimestamp = currentTimeStamp - uint64(i)*req.PeriodLengthInSeconds - candlesticks[i].BeginTimestamp = candlesticks[i].EndTimestamp - req.PeriodLengthInSeconds - } - - // set open - pricePtr := 0 - for i := range candlesticks { - for pricePtr < len(validPrices) && validPrices[pricePtr].SnapshotTimestampInSeconds > candlesticks[i].BeginTimestamp { - pricePtr++ - } - if pricePtr < len(validPrices) { - candlesticks[i].Open = &validPrices[pricePtr].Price - } else { - // this would happen if the earliest price point available is after the begin timestamp - candlesticks[i].Open = &ZeroPrice - } - } - - // set close - pricePtr = 0 - for i := range candlesticks { - for pricePtr < len(validPrices) && validPrices[pricePtr].SnapshotTimestampInSeconds >= candlesticks[i].EndTimestamp { - pricePtr++ - } - if pricePtr < len(validPrices) { - candlesticks[i].Close = &validPrices[pricePtr].Price - } else { - // this would happen if the earliest price point available is after the first end timestamp - candlesticks[i].Close = &ZeroPrice - } - } - - // set high - pricePtr = 0 - for i := range candlesticks { - // initialize to the open price - candlesticks[i].High = candlesticks[i].Open - set := false - for pricePtr < len(validPrices) { - price := validPrices[pricePtr] - if price.SnapshotTimestampInSeconds < candlesticks[i].BeginTimestamp || price.SnapshotTimestampInSeconds >= candlesticks[i].EndTimestamp { - break - } - if !set || price.Price.GT(*candlesticks[i].High) { - set = true - candlesticks[i].High = &price.Price - } - pricePtr++ - } - } - - // set low - pricePtr = 0 - for i := range candlesticks { - // initialize to the open price - candlesticks[i].Low = candlesticks[i].Open - set := false - for pricePtr < len(validPrices) { - price := validPrices[pricePtr] - if price.SnapshotTimestampInSeconds < candlesticks[i].BeginTimestamp || price.SnapshotTimestampInSeconds >= candlesticks[i].EndTimestamp { - break - } - if !set || price.Price.LT(*candlesticks[i].Low) { - set = true - candlesticks[i].Low = &price.Price - } - pricePtr++ - } - } - - return &types.QueryGetHistoricalPricesResponse{ - Prices: candlesticks, - }, nil -} diff --git a/x/dex/keeper/query/grpc_query_get_historical_prices_test.go b/x/dex/keeper/query/grpc_query_get_historical_prices_test.go deleted file mode 100644 index 29b62f9429..0000000000 --- a/x/dex/keeper/query/grpc_query_get_historical_prices_test.go +++ /dev/null @@ -1,185 +0,0 @@ -package query_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestEachPeriodOneDataPoint(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keepertest.SeedPriceSnapshot(ctx, keeper, "100", 1) - keepertest.SeedPriceSnapshot(ctx, keeper, "101", 2) - keepertest.SeedPriceSnapshot(ctx, keeper, "99", 3) // should not be included since end is exclusive - - ctx = ctx.WithBlockTime(time.Unix(3, 0)) - wctx := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: keeper} - resp, err := wrapper.GetHistoricalPrices(wctx, &types.QueryGetHistoricalPricesRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - PeriodLengthInSeconds: 1, - NumOfPeriods: 2, - }) - require.Nil(t, err) - require.Equal(t, 2, len(resp.Prices)) - require.Equal(t, uint64(2), resp.Prices[0].BeginTimestamp) - require.Equal(t, uint64(3), resp.Prices[0].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("101"), *resp.Prices[0].Open) - require.Equal(t, sdk.MustNewDecFromStr("101"), *resp.Prices[0].High) - require.Equal(t, sdk.MustNewDecFromStr("101"), *resp.Prices[0].Low) - require.Equal(t, sdk.MustNewDecFromStr("101"), *resp.Prices[0].Close) - require.Equal(t, uint64(1), resp.Prices[1].BeginTimestamp) - require.Equal(t, uint64(2), resp.Prices[1].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[1].Open) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[1].High) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[1].Low) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[1].Close) -} - -func TestEachPeriodMultipleDataPoints(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keepertest.SeedPriceSnapshot(ctx, keeper, "100", 1) - keepertest.SeedPriceSnapshot(ctx, keeper, "101", 2) - keepertest.SeedPriceSnapshot(ctx, keeper, "102", 3) - keepertest.SeedPriceSnapshot(ctx, keeper, "99", 4) - keepertest.SeedPriceSnapshot(ctx, keeper, "98", 5) // should not be included since end is exclusive - - ctx = ctx.WithBlockTime(time.Unix(5, 0)) - wctx := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: keeper} - resp, err := wrapper.GetHistoricalPrices(wctx, &types.QueryGetHistoricalPricesRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - PeriodLengthInSeconds: 2, - NumOfPeriods: 2, - }) - require.Nil(t, err) - require.Equal(t, 2, len(resp.Prices)) - require.Equal(t, uint64(3), resp.Prices[0].BeginTimestamp) - require.Equal(t, uint64(5), resp.Prices[0].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[0].Open) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[0].High) - require.Equal(t, sdk.MustNewDecFromStr("99"), *resp.Prices[0].Low) - require.Equal(t, sdk.MustNewDecFromStr("99"), *resp.Prices[0].Close) - require.Equal(t, uint64(1), resp.Prices[1].BeginTimestamp) - require.Equal(t, uint64(3), resp.Prices[1].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[1].Open) - require.Equal(t, sdk.MustNewDecFromStr("101"), *resp.Prices[1].High) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[1].Low) - require.Equal(t, sdk.MustNewDecFromStr("101"), *resp.Prices[1].Close) -} - -func TestMissingDataPoints(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keepertest.SeedPriceSnapshot(ctx, keeper, "100", 1) - keepertest.SeedPriceSnapshot(ctx, keeper, "102", 3) - keepertest.SeedPriceSnapshot(ctx, keeper, "98", 5) // should not be included since end is exclusive - - ctx = ctx.WithBlockTime(time.Unix(5, 0)) - wctx := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: keeper} - resp, err := wrapper.GetHistoricalPrices(wctx, &types.QueryGetHistoricalPricesRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - PeriodLengthInSeconds: 1, - NumOfPeriods: 4, - }) - require.Nil(t, err) - require.Equal(t, 4, len(resp.Prices)) - require.Equal(t, uint64(4), resp.Prices[0].BeginTimestamp) - require.Equal(t, uint64(5), resp.Prices[0].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[0].Open) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[0].High) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[0].Low) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[0].Close) - require.Equal(t, uint64(3), resp.Prices[1].BeginTimestamp) - require.Equal(t, uint64(4), resp.Prices[1].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[1].Open) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[1].High) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[1].Low) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[1].Close) - require.Equal(t, uint64(2), resp.Prices[2].BeginTimestamp) - require.Equal(t, uint64(3), resp.Prices[2].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[2].Open) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[2].High) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[2].Low) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[2].Close) - require.Equal(t, uint64(1), resp.Prices[3].BeginTimestamp) - require.Equal(t, uint64(2), resp.Prices[3].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[3].Open) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[3].High) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[3].Low) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[3].Close) -} - -func TestDataPointsNotEarlyEnoughFullBar(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keepertest.SeedPriceSnapshot(ctx, keeper, "100", 2) - keepertest.SeedPriceSnapshot(ctx, keeper, "102", 3) // should not be included since end is exclusive - - ctx = ctx.WithBlockTime(time.Unix(3, 0)) - wctx := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: keeper} - resp, err := wrapper.GetHistoricalPrices(wctx, &types.QueryGetHistoricalPricesRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - PeriodLengthInSeconds: 1, - NumOfPeriods: 2, - }) - require.Nil(t, err) - require.Equal(t, 2, len(resp.Prices)) - require.Equal(t, uint64(2), resp.Prices[0].BeginTimestamp) - require.Equal(t, uint64(3), resp.Prices[0].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[0].Open) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[0].High) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[0].Low) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[0].Close) - require.Equal(t, uint64(1), resp.Prices[1].BeginTimestamp) - require.Equal(t, uint64(2), resp.Prices[1].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("0"), *resp.Prices[1].Open) - require.Equal(t, sdk.MustNewDecFromStr("0"), *resp.Prices[1].High) - require.Equal(t, sdk.MustNewDecFromStr("0"), *resp.Prices[1].Low) - require.Equal(t, sdk.MustNewDecFromStr("0"), *resp.Prices[1].Close) -} - -func TestDataPointsNotEarlyEnoughPartialBar(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keepertest.SeedPriceSnapshot(ctx, keeper, "100", 2) - keepertest.SeedPriceSnapshot(ctx, keeper, "102", 3) - keepertest.SeedPriceSnapshot(ctx, keeper, "98", 5) // should not be included since end is exclusive - - ctx = ctx.WithBlockTime(time.Unix(5, 0)) - wctx := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: keeper} - resp, err := wrapper.GetHistoricalPrices(wctx, &types.QueryGetHistoricalPricesRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - PeriodLengthInSeconds: 2, - NumOfPeriods: 2, - }) - require.Nil(t, err) - require.Equal(t, 2, len(resp.Prices)) - require.Equal(t, uint64(3), resp.Prices[0].BeginTimestamp) - require.Equal(t, uint64(5), resp.Prices[0].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[0].Open) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[0].High) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[0].Low) - require.Equal(t, sdk.MustNewDecFromStr("102"), *resp.Prices[0].Close) - require.Equal(t, uint64(1), resp.Prices[1].BeginTimestamp) - require.Equal(t, uint64(3), resp.Prices[1].EndTimestamp) - require.Equal(t, sdk.MustNewDecFromStr("0"), *resp.Prices[1].Open) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[1].High) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[1].Low) - require.Equal(t, sdk.MustNewDecFromStr("100"), *resp.Prices[1].Close) -} diff --git a/x/dex/keeper/query/grpc_query_get_latest_price.go b/x/dex/keeper/query/grpc_query_get_latest_price.go deleted file mode 100644 index 18fa7b5c13..0000000000 --- a/x/dex/keeper/query/grpc_query_get_latest_price.go +++ /dev/null @@ -1,37 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) GetLatestPrice(goCtx context.Context, req *types.QueryGetLatestPriceRequest) (*types.QueryGetLatestPriceResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - - ctx := sdk.UnwrapSDKContext(goCtx) - prices := k.GetAllPrices(ctx, req.ContractAddr, types.Pair{PriceDenom: req.PriceDenom, AssetDenom: req.AssetDenom}) - - if len(prices) == 0 { - return &types.QueryGetLatestPriceResponse{ - Price: &types.Price{}, - }, nil - } - - latestPrice := prices[0] - - for _, price := range prices { - if price.SnapshotTimestampInSeconds > latestPrice.SnapshotTimestampInSeconds { - latestPrice = price - } - } - - return &types.QueryGetLatestPriceResponse{ - Price: latestPrice, - }, nil -} diff --git a/x/dex/keeper/query/grpc_query_get_latest_price_test.go b/x/dex/keeper/query/grpc_query_get_latest_price_test.go deleted file mode 100644 index 731ca63545..0000000000 --- a/x/dex/keeper/query/grpc_query_get_latest_price_test.go +++ /dev/null @@ -1,30 +0,0 @@ -package query_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestGetLatestPrice(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keepertest.SeedPriceSnapshot(ctx, keeper, "100", 1) - keepertest.SeedPriceSnapshot(ctx, keeper, "101", 2) - keepertest.SeedPriceSnapshot(ctx, keeper, "99", 3) - - ctx = ctx.WithBlockTime(time.Unix(4, 0)) - wctx := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: keeper} - resp, err := wrapper.GetLatestPrice(wctx, &types.QueryGetLatestPriceRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - }) - require.Nil(t, err) - require.Equal(t, sdk.MustNewDecFromStr("99"), resp.Price.Price) -} diff --git a/x/dex/keeper/query/grpc_query_get_market_summary.go b/x/dex/keeper/query/grpc_query_get_market_summary.go deleted file mode 100644 index 9d869207fc..0000000000 --- a/x/dex/keeper/query/grpc_query_get_market_summary.go +++ /dev/null @@ -1,49 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) GetMarketSummary(goCtx context.Context, req *types.QueryGetMarketSummaryRequest) (*types.QueryGetMarketSummaryResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - - ctx := sdk.UnwrapSDKContext(goCtx) - - prices := k.GetAllPrices(ctx, req.ContractAddr, types.Pair{PriceDenom: req.PriceDenom, AssetDenom: req.AssetDenom}) - cutoff := ctx.BlockTime().Unix() - int64(req.LookbackInSeconds) - maxPrice := sdk.ZeroDec() - minPrice := sdk.ZeroDec() - latestTimestamp := 0 - lastPrice := sdk.ZeroDec() - for _, price := range prices { - if price.SnapshotTimestampInSeconds < uint64(cutoff) { - continue - } - if maxPrice.IsZero() || price.Price.GT(maxPrice) { - maxPrice = price.Price - } - if minPrice.IsZero() || price.Price.LT(minPrice) { - minPrice = price.Price - } - if price.SnapshotTimestampInSeconds > uint64(latestTimestamp) { - latestTimestamp = int(price.SnapshotTimestampInSeconds) - lastPrice = price.Price - } - } - - zero := sdk.ZeroDec() - return &types.QueryGetMarketSummaryResponse{ - TotalVolume: &zero, // TODO: replace once we start tracking volume - TotalVolumeNotional: &zero, // TODO: replace once we start tracking volume - HighPrice: &maxPrice, - LowPrice: &minPrice, - LastPrice: &lastPrice, - }, nil -} diff --git a/x/dex/keeper/query/grpc_query_get_market_summary_test.go b/x/dex/keeper/query/grpc_query_get_market_summary_test.go deleted file mode 100644 index e5f77b40a3..0000000000 --- a/x/dex/keeper/query/grpc_query_get_market_summary_test.go +++ /dev/null @@ -1,33 +0,0 @@ -package query_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestGetMarketSummary(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keepertest.SeedPriceSnapshot(ctx, keeper, "100", 1) - keepertest.SeedPriceSnapshot(ctx, keeper, "101", 2) - keepertest.SeedPriceSnapshot(ctx, keeper, "99", 3) - - ctx = ctx.WithBlockTime(time.Unix(4, 0)) - wctx := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: keeper} - resp, err := wrapper.GetMarketSummary(wctx, &types.QueryGetMarketSummaryRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - LookbackInSeconds: 4, - }) - require.Nil(t, err) - require.Equal(t, sdk.MustNewDecFromStr("99"), *resp.LowPrice) - require.Equal(t, sdk.MustNewDecFromStr("99"), *resp.LastPrice) - require.Equal(t, sdk.MustNewDecFromStr("101"), *resp.HighPrice) -} diff --git a/x/dex/keeper/query/grpc_query_get_order_count.go b/x/dex/keeper/query/grpc_query_get_order_count.go deleted file mode 100644 index 3a70cb0feb..0000000000 --- a/x/dex/keeper/query/grpc_query_get_order_count.go +++ /dev/null @@ -1,19 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) GetOrderCount(c context.Context, req *types.QueryGetOrderCountRequest) (*types.QueryGetOrderCountResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(c) - - return &types.QueryGetOrderCountResponse{Count: k.GetOrderCountState(ctx, req.ContractAddr, req.PriceDenom, req.AssetDenom, req.PositionDirection, *req.Price)}, nil -} diff --git a/x/dex/keeper/query/grpc_query_get_order_count_test.go b/x/dex/keeper/query/grpc_query_get_order_count_test.go deleted file mode 100644 index 30fa1baf72..0000000000 --- a/x/dex/keeper/query/grpc_query_get_order_count_test.go +++ /dev/null @@ -1,29 +0,0 @@ -package query_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestGetOrderCount(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wrapper := query.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - keeper.SetOrderCount(ctx, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(1), 5) - price := sdk.NewDec(1) - query := types.QueryGetOrderCountRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - PositionDirection: types.PositionDirection_LONG, - Price: &price, - } - resp, err := wrapper.GetOrderCount(wctx, &query) - require.Nil(t, err) - require.Equal(t, uint64(5), resp.Count) -} diff --git a/x/dex/keeper/query/grpc_query_get_price.go b/x/dex/keeper/query/grpc_query_get_price.go deleted file mode 100644 index f58d38645a..0000000000 --- a/x/dex/keeper/query/grpc_query_get_price.go +++ /dev/null @@ -1,25 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) GetPrice(goCtx context.Context, req *types.QueryGetPriceRequest) (*types.QueryGetPriceResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - - ctx := sdk.UnwrapSDKContext(goCtx) - - price, found := k.GetPriceState(ctx, req.ContractAddr, req.Timestamp, types.Pair{PriceDenom: req.PriceDenom, AssetDenom: req.AssetDenom}) - - return &types.QueryGetPriceResponse{ - Price: &price, - Found: found, - }, nil -} diff --git a/x/dex/keeper/query/grpc_query_get_price_test.go b/x/dex/keeper/query/grpc_query_get_price_test.go deleted file mode 100644 index c46d15f7ec..0000000000 --- a/x/dex/keeper/query/grpc_query_get_price_test.go +++ /dev/null @@ -1,32 +0,0 @@ -package query_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestGetPrice(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keepertest.SeedPriceSnapshot(ctx, keeper, "100", 1) - keepertest.SeedPriceSnapshot(ctx, keeper, "101", 2) - keepertest.SeedPriceSnapshot(ctx, keeper, "99", 3) - - ctx = ctx.WithBlockTime(time.Unix(4, 0)) - wctx := sdk.WrapSDKContext(ctx) - wrapper := query.KeeperWrapper{Keeper: keeper} - resp, err := wrapper.GetPrice(wctx, &types.QueryGetPriceRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - Timestamp: 2, - }) - require.Nil(t, err) - require.Equal(t, true, resp.Found) - require.Equal(t, sdk.MustNewDecFromStr("101"), resp.Price.Price) -} diff --git a/x/dex/keeper/query/grpc_query_get_prices.go b/x/dex/keeper/query/grpc_query_get_prices.go deleted file mode 100644 index d4b8c619e7..0000000000 --- a/x/dex/keeper/query/grpc_query_get_prices.go +++ /dev/null @@ -1,24 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) GetPrices(goCtx context.Context, req *types.QueryGetPricesRequest) (*types.QueryGetPricesResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - - ctx := sdk.UnwrapSDKContext(goCtx) - - prices := k.GetAllPrices(ctx, req.ContractAddr, types.Pair{PriceDenom: req.PriceDenom, AssetDenom: req.AssetDenom}) - - return &types.QueryGetPricesResponse{ - Prices: prices, - }, nil -} diff --git a/x/dex/keeper/query/grpc_query_get_twaps.go b/x/dex/keeper/query/grpc_query_get_twaps.go deleted file mode 100644 index b166672855..0000000000 --- a/x/dex/keeper/query/grpc_query_get_twaps.go +++ /dev/null @@ -1,57 +0,0 @@ -package query - -import ( - "context" - - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func (k KeeperWrapper) GetTwaps(goCtx context.Context, req *types.QueryGetTwapsRequest) (*types.QueryGetTwapsResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(goCtx) - allRegisteredPairs := k.GetAllRegisteredPairs(ctx, req.ContractAddr) - twaps := []*types.Twap{} - for _, pair := range allRegisteredPairs { - prices := k.GetPricesForTwap(ctx, req.ContractAddr, pair, req.LookbackSeconds) - twaps = append(twaps, &types.Twap{ - Pair: &pair, //nolint:gosec,exportloopref // USING THE POINTER HERE COULD BE BAD, LET'S CHECK IT. - Twap: calculateTwap(ctx, prices, req.LookbackSeconds), - LookbackSeconds: req.LookbackSeconds, - }) - } - - return &types.QueryGetTwapsResponse{ - Twaps: twaps, - }, nil -} - -func calculateTwap(ctx sdk.Context, prices []*types.Price, lookback uint64) sdk.Dec { - if len(prices) == 0 { - return sdk.ZeroDec() - } - weightedPriceSum := sdk.ZeroDec() - lastTimestamp := ctx.BlockTime().Unix() - for _, price := range prices { - if uint64(ctx.BlockTime().Unix())-price.SnapshotTimestampInSeconds > lookback { - weight := lastTimestamp - ctx.BlockTime().Unix() + int64(lookback) - weightedPriceSum = weightedPriceSum.Add(price.Price.MulInt64(weight)) - break - } - weightedPriceSum = weightedPriceSum.Add( - price.Price.MulInt64(lastTimestamp - int64(price.SnapshotTimestampInSeconds)), - ) - lastTimestamp = int64(price.SnapshotTimestampInSeconds) - } - // not possible for division by 0 here since prices have unique timestamps - totalTimeSpan := ctx.BlockTime().Unix() - int64(prices[len(prices)-1].SnapshotTimestampInSeconds) - if totalTimeSpan > int64(lookback) { - totalTimeSpan = int64(lookback) - } - return weightedPriceSum.QuoInt64(totalTimeSpan) -} diff --git a/x/dex/keeper/query/grpc_query_get_twaps_test.go b/x/dex/keeper/query/grpc_query_get_twaps_test.go deleted file mode 100644 index a039442058..0000000000 --- a/x/dex/keeper/query/grpc_query_get_twaps_test.go +++ /dev/null @@ -1,143 +0,0 @@ -package query_test - -import ( - "testing" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -const GENESIS_TIME uint64 = 3600 - -func TestGetTwapsNoPriceSnapshot(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keeper.AddRegisteredPair(ctx, keepertest.TestContract, keepertest.TestPair) - wctx := sdk.WrapSDKContext(ctx) - var lookback uint64 = 10 - request := types.QueryGetTwapsRequest{ - ContractAddr: keepertest.TestContract, - LookbackSeconds: lookback, - } - expectedResponse := types.QueryGetTwapsResponse{ - Twaps: []*types.Twap{ - { - Pair: &keepertest.TestPair, - Twap: sdk.ZeroDec(), - LookbackSeconds: lookback, - }, - }, - } - wrapper := query.KeeperWrapper{Keeper: keeper} - t.Run("No snapshot", func(t *testing.T) { - response, err := wrapper.GetTwaps(wctx, &request) - require.NoError(t, err) - require.Equal(t, expectedResponse, *response) - }) -} - -func TestGetTwapsOnePriceSnapshot(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keeper.AddRegisteredPair(ctx, keepertest.TestContract, keepertest.TestPair) - ctx = ctx.WithBlockTime(time.Unix(int64(GENESIS_TIME)+5, 0)) - wctx := sdk.WrapSDKContext(ctx) - - snapshotPrice := sdk.MustNewDecFromStr("100.00") - keeper.SetPriceState(ctx, types.Price{ - SnapshotTimestampInSeconds: GENESIS_TIME, - Price: snapshotPrice, - Pair: &keepertest.TestPair, - }, keepertest.TestContract) - - var lookback uint64 = 10 - request := types.QueryGetTwapsRequest{ - ContractAddr: keepertest.TestContract, - LookbackSeconds: lookback, - } - expectedResponse := types.QueryGetTwapsResponse{ - Twaps: []*types.Twap{ - { - Pair: &keepertest.TestPair, - Twap: snapshotPrice, - LookbackSeconds: lookback, - }, - }, - } - wrapper := query.KeeperWrapper{Keeper: keeper} - t.Run("One snapshot", func(t *testing.T) { - response, err := wrapper.GetTwaps(wctx, &request) - require.NoError(t, err) - require.Equal(t, expectedResponse, *response) - }) - - lookback = 4 - request = types.QueryGetTwapsRequest{ - ContractAddr: keepertest.TestContract, - LookbackSeconds: lookback, - } - expectedResponse = types.QueryGetTwapsResponse{ - Twaps: []*types.Twap{ - { - Pair: &keepertest.TestPair, - Twap: snapshotPrice, - LookbackSeconds: lookback, - }, - }, - } - t.Run("One old snapshot", func(t *testing.T) { - response, err := wrapper.GetTwaps(wctx, &request) - require.NoError(t, err) - require.Equal(t, expectedResponse, *response) - }) -} - -func TestGetTwapsMultipleSnapshots(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - keeper.AddRegisteredPair(ctx, keepertest.TestContract, keepertest.TestPair) - ctx = ctx.WithBlockTime(time.Unix(int64(GENESIS_TIME)+20, 0)) - wctx := sdk.WrapSDKContext(ctx) - - snapshotPrices := []sdk.Dec{ - sdk.MustNewDecFromStr("100.00"), - sdk.MustNewDecFromStr("98.50"), - sdk.MustNewDecFromStr("101.00"), - } - timestampDeltas := []uint64{0, 10, 15} - for i := range snapshotPrices { - keeper.SetPriceState(ctx, types.Price{ - SnapshotTimestampInSeconds: GENESIS_TIME + timestampDeltas[i], - Price: snapshotPrices[i], - Pair: &keepertest.TestPair, - }, keepertest.TestContract) - } - - var lookback uint64 = 20 - request := types.QueryGetTwapsRequest{ - ContractAddr: keepertest.TestContract, - LookbackSeconds: lookback, - } - expectedTwap := snapshotPrices[0].MulInt64(10).Add( - snapshotPrices[1].MulInt64(15 - 10), - ).Add( - snapshotPrices[2].MulInt64(20 - 15), - ).QuoInt64(20) - require.Equal(t, sdk.MustNewDecFromStr("99.875"), expectedTwap) - expectedResponse := types.QueryGetTwapsResponse{ - Twaps: []*types.Twap{ - { - Pair: &keepertest.TestPair, - Twap: expectedTwap, - LookbackSeconds: lookback, - }, - }, - } - wrapper := query.KeeperWrapper{Keeper: keeper} - t.Run("Multiple snapshots", func(t *testing.T) { - response, err := wrapper.GetTwaps(wctx, &request) - require.NoError(t, err) - require.Equal(t, expectedResponse, *response) - }) -} diff --git a/x/dex/keeper/query/grpc_query_long_book.go b/x/dex/keeper/query/grpc_query_long_book.go deleted file mode 100644 index d855059f22..0000000000 --- a/x/dex/keeper/query/grpc_query_long_book.go +++ /dev/null @@ -1,50 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) LongBookAll(c context.Context, req *types.QueryAllLongBookRequest) (*types.QueryAllLongBookResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - - ctx := sdk.UnwrapSDKContext(c) - - longBooks, pageRes, err := k.GetAllLongBookForPairPaginated( - ctx, - req.ContractAddr, - req.PriceDenom, - req.AssetDenom, - req.Pagination, - ) - if err != nil { - return nil, status.Error(codes.Internal, err.Error()) - } - - return &types.QueryAllLongBookResponse{LongBook: longBooks, Pagination: pageRes}, nil -} - -func (k KeeperWrapper) LongBook(c context.Context, req *types.QueryGetLongBookRequest) (*types.QueryGetLongBookResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - - ctx := sdk.UnwrapSDKContext(c) - price, err := sdk.NewDecFromStr(req.Price) - if err != nil { - return nil, err - } - longBook, found := k.GetLongBookByPrice(ctx, req.ContractAddr, price, req.PriceDenom, req.AssetDenom) - if !found { - return nil, sdkerrors.ErrKeyNotFound - } - - return &types.QueryGetLongBookResponse{LongBook: longBook}, nil -} diff --git a/x/dex/keeper/query/grpc_query_long_book_test.go b/x/dex/keeper/query/grpc_query_long_book_test.go deleted file mode 100644 index ac29f39911..0000000000 --- a/x/dex/keeper/query/grpc_query_long_book_test.go +++ /dev/null @@ -1,123 +0,0 @@ -package query_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/cosmos/cosmos-sdk/types/query" - "github.com/stretchr/testify/require" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/testutil/nullify" - keeperquery "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func TestLongBookQuerySingle(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wrapper := keeperquery.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - msgs := keepertest.CreateNLongBook(keeper, ctx, 2) - for _, tc := range []struct { - desc string - request *types.QueryGetLongBookRequest - response *types.QueryGetLongBookResponse - err error - }{ - { - desc: "First", - request: &types.QueryGetLongBookRequest{Price: msgs[0].Price.String(), ContractAddr: keepertest.TestContract, PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}, - response: &types.QueryGetLongBookResponse{LongBook: msgs[0]}, - }, - { - desc: "Second", - request: &types.QueryGetLongBookRequest{Price: msgs[1].Price.String(), ContractAddr: keepertest.TestContract, PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}, - response: &types.QueryGetLongBookResponse{LongBook: msgs[1]}, - }, - { - desc: "KeyNotFound", - request: &types.QueryGetLongBookRequest{Price: "100000", ContractAddr: keepertest.TestContract, PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}, - err: sdkerrors.ErrKeyNotFound, - }, - { - desc: "InvalidRequest", - err: status.Error(codes.InvalidArgument, "invalid request"), - }, - } { - t.Run(tc.desc, func(t *testing.T) { - response, err := wrapper.LongBook(wctx, tc.request) - if tc.err != nil { - require.ErrorIs(t, err, tc.err) - } else { - require.NoError(t, err) - require.Equal(t, - nullify.Fill(tc.response), - nullify.Fill(response), - ) - } - }) - } -} - -func TestLongBookQueryPaginated(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wrapper := keeperquery.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - msgs := keepertest.CreateNLongBook(keeper, ctx, 5) - - request := func(next []byte, offset, limit uint64, total bool) *types.QueryAllLongBookRequest { - return &types.QueryAllLongBookRequest{ - Pagination: &query.PageRequest{ - Key: next, - Offset: offset, - Limit: limit, - CountTotal: total, - }, - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - } - } - t.Run("ByOffset", func(t *testing.T) { - step := 2 - for i := 0; i < len(msgs); i += step { - resp, err := wrapper.LongBookAll(wctx, request(nil, uint64(i), uint64(step), false)) - require.NoError(t, err) - require.LessOrEqual(t, len(resp.LongBook), step) - require.Subset(t, - nullify.Fill(msgs), - nullify.Fill(resp.LongBook), - ) - } - }) - t.Run("ByKey", func(t *testing.T) { - step := 2 - var next []byte - for i := 0; i < len(msgs); i += step { - resp, err := wrapper.LongBookAll(wctx, request(next, 0, uint64(step), false)) - require.NoError(t, err) - require.LessOrEqual(t, len(resp.LongBook), step) - require.Subset(t, - nullify.Fill(msgs), - nullify.Fill(resp.LongBook), - ) - next = resp.Pagination.NextKey - } - }) - t.Run("Total", func(t *testing.T) { - resp, err := wrapper.LongBookAll(wctx, request(nil, 0, 0, true)) - require.NoError(t, err) - require.Equal(t, len(msgs), int(resp.Pagination.Total)) - require.ElementsMatch(t, - nullify.Fill(msgs), - nullify.Fill(resp.LongBook), - ) - }) - t.Run("InvalidRequest", func(t *testing.T) { - _, err := wrapper.LongBookAll(wctx, nil) - require.ErrorIs(t, err, status.Error(codes.InvalidArgument, "invalid request")) - }) -} diff --git a/x/dex/keeper/query/grpc_query_match_result.go b/x/dex/keeper/query/grpc_query_match_result.go deleted file mode 100644 index 95226904e6..0000000000 --- a/x/dex/keeper/query/grpc_query_match_result.go +++ /dev/null @@ -1,24 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) GetMatchResult(c context.Context, req *types.QueryGetMatchResultRequest) (*types.QueryGetMatchResultResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(c) - - result, found := k.GetMatchResultState(ctx, req.ContractAddr) - if !found { - return nil, status.Error(codes.NotFound, "result not found") - } - - return &types.QueryGetMatchResultResponse{Result: result}, nil -} diff --git a/x/dex/keeper/query/grpc_query_order.go b/x/dex/keeper/query/grpc_query_order.go deleted file mode 100644 index 556c640a6d..0000000000 --- a/x/dex/keeper/query/grpc_query_order.go +++ /dev/null @@ -1,112 +0,0 @@ -package query - -import ( - "context" - - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -// To be deprecated once offchain query is built -func (k KeeperWrapper) GetOrder(c context.Context, req *types.QueryGetOrderByIDRequest) (*types.QueryGetOrderByIDResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(c) - longBooks := k.GetAllLongBook(ctx, req.ContractAddr) - for _, longBook := range longBooks { - for _, allocation := range longBook.Entry.Allocations { - if allocation.OrderId == req.Id { - return &types.QueryGetOrderByIDResponse{ - Order: &types.Order{ - Id: req.Id, - Price: longBook.Price, - Quantity: allocation.Quantity, - PriceDenom: longBook.Entry.PriceDenom, - AssetDenom: longBook.Entry.AssetDenom, - OrderType: types.OrderType_LIMIT, - Status: types.OrderStatus_PLACED, - ContractAddr: req.ContractAddr, - PositionDirection: types.PositionDirection_LONG, - Account: allocation.Account, - }, - }, nil - } - } - } - shortBooks := k.GetAllShortBook(ctx, req.ContractAddr) - for _, shortBook := range shortBooks { - for _, allocation := range shortBook.Entry.Allocations { - if allocation.OrderId == req.Id { - return &types.QueryGetOrderByIDResponse{ - Order: &types.Order{ - Id: req.Id, - Price: shortBook.Price, - Quantity: allocation.Quantity, - PriceDenom: shortBook.Entry.PriceDenom, - AssetDenom: shortBook.Entry.AssetDenom, - OrderType: types.OrderType_LIMIT, - Status: types.OrderStatus_PLACED, - ContractAddr: req.ContractAddr, - PositionDirection: types.PositionDirection_SHORT, - Account: allocation.Account, - }, - }, nil - } - } - } - - return &types.QueryGetOrderByIDResponse{}, types.ErrInvalidOrderID -} - -// To be deprecated once offchain query is built -func (k KeeperWrapper) GetOrders(c context.Context, req *types.QueryGetOrdersRequest) (*types.QueryGetOrdersResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(c) - orders := []*types.Order{} - longBooks := k.GetAllLongBook(ctx, req.ContractAddr) - for _, longBook := range longBooks { - for _, allocation := range longBook.Entry.Allocations { - if allocation.Account == req.Account { - orders = append(orders, &types.Order{ - Id: allocation.OrderId, - Price: longBook.Price, - Quantity: allocation.Quantity, - PriceDenom: longBook.Entry.PriceDenom, - AssetDenom: longBook.Entry.AssetDenom, - OrderType: types.OrderType_LIMIT, - Status: types.OrderStatus_PLACED, - ContractAddr: req.ContractAddr, - PositionDirection: types.PositionDirection_LONG, - Account: allocation.Account, - }) - } - } - } - shortBooks := k.GetAllShortBook(ctx, req.ContractAddr) - for _, shortBook := range shortBooks { - for _, allocation := range shortBook.Entry.Allocations { - if allocation.Account == req.Account { - orders = append(orders, &types.Order{ - Id: allocation.OrderId, - Price: shortBook.Price, - Quantity: allocation.Quantity, - PriceDenom: shortBook.Entry.PriceDenom, - AssetDenom: shortBook.Entry.AssetDenom, - OrderType: types.OrderType_LIMIT, - Status: types.OrderStatus_PLACED, - ContractAddr: req.ContractAddr, - PositionDirection: types.PositionDirection_SHORT, - Account: allocation.Account, - }) - } - } - } - - return &types.QueryGetOrdersResponse{Orders: orders}, nil -} diff --git a/x/dex/keeper/query/grpc_query_order_simulation.go b/x/dex/keeper/query/grpc_query_order_simulation.go deleted file mode 100644 index e16308c956..0000000000 --- a/x/dex/keeper/query/grpc_query_order_simulation.go +++ /dev/null @@ -1,120 +0,0 @@ -package query - -import ( - "context" - "sort" - - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" -) - -type priceQuantity struct { - price sdk.Dec - quantity sdk.Dec -} - -// Note that this simulation is only accurate if it's called as part of the main Sei process (e.g. in Begin/EndBlock, transaction handler -// or contract querier), because it needs to access dex's in-memory state. -func (k KeeperWrapper) GetOrderSimulation(c context.Context, req *types.QueryOrderSimulationRequest) (*types.QueryOrderSimulationResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(c) - matchedPriceQuantities := k.getMatchedPriceQuantities(ctx, req) - executedQuantity := sdk.ZeroDec() - for _, pq := range matchedPriceQuantities { - if executedQuantity.Add(pq.quantity).GTE(req.Order.Quantity) { - executedQuantity = req.Order.Quantity - break - } - executedQuantity = executedQuantity.Add(pq.quantity) - } - return &types.QueryOrderSimulationResponse{ - ExecutedQuantity: &executedQuantity, - }, nil -} - -func (k KeeperWrapper) getMatchedPriceQuantities(ctx sdk.Context, req *types.QueryOrderSimulationRequest) []priceQuantity { - orderDirection := req.Order.PositionDirection - // get existing liquidity - eligibleOrderBookPriceToQuantity := map[string]sdk.Dec{} - if orderDirection == types.PositionDirection_SHORT { - for _, lb := range k.GetAllLongBookForPair(ctx, req.ContractAddr, req.Order.PriceDenom, req.Order.AssetDenom) { - if req.Order.Price.IsZero() || req.Order.Price.LTE(lb.GetPrice()) { - eligibleOrderBookPriceToQuantity[lb.GetPrice().String()] = lb.GetOrderEntry().Quantity - } - } - } else { - for _, sb := range k.GetAllShortBookForPair(ctx, req.ContractAddr, req.Order.PriceDenom, req.Order.AssetDenom) { - if req.Order.Price.IsZero() || req.Order.Price.GTE(sb.GetPrice()) { - eligibleOrderBookPriceToQuantity[sb.GetPrice().String()] = sb.GetOrderEntry().Quantity - } - } - } - - // exclude liquidity to be cancelled - pair := types.Pair{PriceDenom: req.Order.PriceDenom, AssetDenom: req.Order.AssetDenom} - for _, cancel := range dexutils.GetMemState(ctx.Context()).GetBlockCancels(ctx, types.ContractAddress(req.ContractAddr), pair).Get() { - var cancelledAllocation *types.Allocation - var found bool - if cancel.PositionDirection == types.PositionDirection_LONG { - cancelledAllocation, found = k.GetLongAllocationForOrderID(ctx, req.ContractAddr, cancel.PriceDenom, cancel.AssetDenom, cancel.Price, cancel.Id) - } else { - cancelledAllocation, found = k.GetShortAllocationForOrderID(ctx, req.ContractAddr, cancel.PriceDenom, cancel.AssetDenom, cancel.Price, cancel.Id) - } - if !found { - continue - } - if q, ok := eligibleOrderBookPriceToQuantity[cancel.Price.String()]; ok { - eligibleOrderBookPriceToQuantity[cancel.Price.String()] = q.Sub(cancelledAllocation.Quantity) - } - } - - priceQuantities := []priceQuantity{} - for price, quantity := range eligibleOrderBookPriceToQuantity { - if quantity.IsPositive() { - priceQuantities = append(priceQuantities, priceQuantity{price: sdk.MustNewDecFromStr(price), quantity: quantity}) - } - } - sort.Slice(priceQuantities, func(i int, j int) bool { - if orderDirection == types.PositionDirection_SHORT { - // short order corresponds to long book which needs to be in descending order - return priceQuantities[i].price.GT(priceQuantities[j].price) - } - // long order corresponds to long book which needs to be in ascending order - return priceQuantities[i].price.LT(priceQuantities[j].price) - }) - - // exclude liquidity to be taken - ptr := 0 - for _, order := range dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(req.ContractAddr), pair).GetSortedMarketOrders(orderDirection) { - // If existing market order has price zero, it means it doesn't specify a worst price and will always have precedence over the simulated - // order - if !order.Price.IsZero() { - // If the simulated order doesn't specify a worst price, no existing order with a worst price will take liquidity from it - if req.Order.Price.IsZero() { - break - } - if orderDirection == types.PositionDirection_LONG && order.Price.LT(req.Order.Price) { - break - } - if orderDirection == types.PositionDirection_SHORT && order.Price.GT(req.Order.Price) { - break - } - } - remainingQuantity := order.Quantity - for ptr < len(priceQuantities) { - if remainingQuantity.LTE(priceQuantities[ptr].quantity) { - priceQuantities[ptr].quantity = priceQuantities[ptr].quantity.Sub(remainingQuantity) - break - } - remainingQuantity = remainingQuantity.Sub(priceQuantities[ptr].quantity) - ptr++ - } - } - return priceQuantities[ptr:] -} diff --git a/x/dex/keeper/query/grpc_query_order_simulation_test.go b/x/dex/keeper/query/grpc_query_order_simulation_test.go deleted file mode 100644 index 07bfb2ccb1..0000000000 --- a/x/dex/keeper/query/grpc_query_order_simulation_test.go +++ /dev/null @@ -1,101 +0,0 @@ -package query_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/stretchr/testify/require" -) - -func TestGetOrderSimulation(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wrapper := query.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - - testOrder := types.Order{ - Account: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - Price: sdk.MustNewDecFromStr("10"), - Quantity: sdk.MustNewDecFromStr("5"), - PositionDirection: types.PositionDirection_LONG, - } - - // no liquidity - res, err := wrapper.GetOrderSimulation(wctx, &types.QueryOrderSimulationRequest{Order: &testOrder, ContractAddr: keepertest.TestContract}) - require.Nil(t, err) - require.Equal(t, sdk.ZeroDec(), *res.ExecutedQuantity) - - // partial liquidity on orderbook - keeper.SetShortBook(ctx, keepertest.TestContract, types.ShortBook{ - Price: sdk.MustNewDecFromStr("9"), - Entry: &types.OrderEntry{ - Price: sdk.MustNewDecFromStr("9"), - Quantity: sdk.MustNewDecFromStr("2"), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - }) - res, err = wrapper.GetOrderSimulation(wctx, &types.QueryOrderSimulationRequest{Order: &testOrder, ContractAddr: keepertest.TestContract}) - require.Nil(t, err) - require.Equal(t, sdk.MustNewDecFromStr("2"), *res.ExecutedQuantity) - - // full liquidity on orderbook - keeper.SetShortBook(ctx, keepertest.TestContract, types.ShortBook{ - Price: sdk.MustNewDecFromStr("8"), - Entry: &types.OrderEntry{ - Price: sdk.MustNewDecFromStr("8"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - }) - res, err = wrapper.GetOrderSimulation(wctx, &types.QueryOrderSimulationRequest{Order: &testOrder, ContractAddr: keepertest.TestContract}) - require.Nil(t, err) - require.Equal(t, sdk.MustNewDecFromStr("3"), *res.ExecutedQuantity) - - // liquidity taken by cancel - keeper.SetShortBook(ctx, keepertest.TestContract, types.ShortBook{ - Price: sdk.MustNewDecFromStr("9"), - Entry: &types.OrderEntry{ - Price: sdk.MustNewDecFromStr("9"), - Quantity: sdk.MustNewDecFromStr("2"), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - Allocations: []*types.Allocation{ - { - Account: keepertest.TestAccount, - Quantity: sdk.MustNewDecFromStr("2"), - OrderId: 1, - }, - }, - }, - }) - dexutils.GetMemState(ctx.Context()).GetBlockCancels(ctx, types.ContractAddress(keepertest.TestContract), keepertest.TestPair).Add( - &types.Cancellation{Id: 1, Price: sdk.MustNewDecFromStr("9"), PositionDirection: types.PositionDirection_SHORT, PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}, - ) - res, err = wrapper.GetOrderSimulation(wctx, &types.QueryOrderSimulationRequest{Order: &testOrder, ContractAddr: keepertest.TestContract}) - require.Nil(t, err) - require.Equal(t, sdk.OneDec(), *res.ExecutedQuantity) - - // liquidity taken by earlier market orders - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(keepertest.TestContract), keepertest.TestPair).Add( - &types.Order{ - Account: keepertest.TestAccount, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - Price: sdk.MustNewDecFromStr("11"), - Quantity: sdk.MustNewDecFromStr("2"), - PositionDirection: types.PositionDirection_LONG, - OrderType: types.OrderType_MARKET, - }, - ) - res, err = wrapper.GetOrderSimulation(wctx, &types.QueryOrderSimulationRequest{Order: &testOrder, ContractAddr: keepertest.TestContract}) - require.Nil(t, err) - require.Equal(t, sdk.ZeroDec(), *res.ExecutedQuantity) -} diff --git a/x/dex/keeper/query/grpc_query_order_test.go b/x/dex/keeper/query/grpc_query_order_test.go deleted file mode 100644 index 32025934a0..0000000000 --- a/x/dex/keeper/query/grpc_query_order_test.go +++ /dev/null @@ -1,75 +0,0 @@ -package query_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestGetOrderById(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wrapper := query.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - // active order - keeper.SetLongBook(ctx, keepertest.TestContract, types.LongBook{ - Price: sdk.OneDec(), - Entry: &types.OrderEntry{ - Price: sdk.OneDec(), - Quantity: sdk.MustNewDecFromStr("2"), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - Allocations: []*types.Allocation{ - { - Account: keepertest.TestAccount, - OrderId: 1, - Quantity: sdk.MustNewDecFromStr("2"), - }, - }, - }, - }) - query := types.QueryGetOrderByIDRequest{ - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - Id: 1, - } - resp, err := wrapper.GetOrder(wctx, &query) - require.Nil(t, err) - require.Equal(t, uint64(1), resp.Order.Id) - require.Equal(t, types.OrderStatus_PLACED, resp.Order.Status) -} - -func TestGetOrders(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wrapper := query.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - // active order - keeper.SetLongBook(ctx, keepertest.TestContract, types.LongBook{ - Price: sdk.OneDec(), - Entry: &types.OrderEntry{ - Price: sdk.OneDec(), - Quantity: sdk.MustNewDecFromStr("2"), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - Allocations: []*types.Allocation{ - { - Account: keepertest.TestAccount, - OrderId: 1, - Quantity: sdk.MustNewDecFromStr("2"), - }, - }, - }, - }) - - query := types.QueryGetOrdersRequest{ - ContractAddr: keepertest.TestContract, - Account: keepertest.TestAccount, - } - resp, err := wrapper.GetOrders(wctx, &query) - require.Nil(t, err) - require.Equal(t, 1, len(resp.Orders)) -} diff --git a/x/dex/keeper/query/grpc_query_params.go b/x/dex/keeper/query/grpc_query_params.go deleted file mode 100644 index 2b7772ef26..0000000000 --- a/x/dex/keeper/query/grpc_query_params.go +++ /dev/null @@ -1,19 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) Params(c context.Context, req *types.QueryParamsRequest) (*types.QueryParamsResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(c) - - return &types.QueryParamsResponse{Params: k.GetParams(ctx)}, nil -} diff --git a/x/dex/keeper/query/grpc_query_params_test.go b/x/dex/keeper/query/grpc_query_params_test.go deleted file mode 100644 index ff1eecdbe8..0000000000 --- a/x/dex/keeper/query/grpc_query_params_test.go +++ /dev/null @@ -1,23 +0,0 @@ -package query_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - testkeeper "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestParamsQuery(t *testing.T) { - keeper, ctx := testkeeper.DexKeeper(t) - wrapper := query.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - params := types.DefaultParams() - keeper.SetParams(ctx, params) - - response, err := wrapper.Params(wctx, &types.QueryParamsRequest{}) - require.NoError(t, err) - require.Equal(t, &types.QueryParamsResponse{Params: params}, response) -} diff --git a/x/dex/keeper/query/grpc_query_registered_contract.go b/x/dex/keeper/query/grpc_query_registered_contract.go deleted file mode 100644 index 63e870e862..0000000000 --- a/x/dex/keeper/query/grpc_query_registered_contract.go +++ /dev/null @@ -1,24 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) GetRegisteredContract(c context.Context, req *types.QueryRegisteredContractRequest) (*types.QueryRegisteredContractResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(c) - - contractInfo, err := k.GetContract(ctx, req.ContractAddr) - if err != nil { - return nil, err - } - - return &types.QueryRegisteredContractResponse{ContractInfo: &contractInfo}, nil -} diff --git a/x/dex/keeper/query/grpc_query_registered_contract_test.go b/x/dex/keeper/query/grpc_query_registered_contract_test.go deleted file mode 100644 index 15a6f751a3..0000000000 --- a/x/dex/keeper/query/grpc_query_registered_contract_test.go +++ /dev/null @@ -1,42 +0,0 @@ -package query_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestRegisteredContractQuery(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wrapper := query.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - expectedContractInfo := types.ContractInfoV2{ - Creator: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - CodeId: 1, - RentBalance: 1000000, - } - err := keeper.SetContract(ctx, &types.ContractInfoV2{ - Creator: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - CodeId: 1, - RentBalance: 1000000, - }) - require.NoError(t, err) - - request := types.QueryRegisteredContractRequest{ - ContractAddr: keepertest.TestContract, - } - expectedResponse := types.QueryRegisteredContractResponse{ - ContractInfo: &expectedContractInfo, - } - t.Run("Registered Contract query", func(t *testing.T) { - response, err := wrapper.GetRegisteredContract(wctx, &request) - require.NoError(t, err) - require.Equal(t, expectedResponse, *response) - }) -} diff --git a/x/dex/keeper/query/grpc_query_registered_pairs.go b/x/dex/keeper/query/grpc_query_registered_pairs.go deleted file mode 100644 index e32f681634..0000000000 --- a/x/dex/keeper/query/grpc_query_registered_pairs.go +++ /dev/null @@ -1,21 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) GetRegisteredPairs(c context.Context, req *types.QueryRegisteredPairsRequest) (*types.QueryRegisteredPairsResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - ctx := sdk.UnwrapSDKContext(c) - - registeredPairs := k.GetAllRegisteredPairs(ctx, req.ContractAddr) - - return &types.QueryRegisteredPairsResponse{Pairs: registeredPairs}, nil -} diff --git a/x/dex/keeper/query/grpc_query_registered_pairs_test.go b/x/dex/keeper/query/grpc_query_registered_pairs_test.go deleted file mode 100644 index 2b6007a4a0..0000000000 --- a/x/dex/keeper/query/grpc_query_registered_pairs_test.go +++ /dev/null @@ -1,39 +0,0 @@ -package query_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestRegisteredPairsQuery(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wrapper := query.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - expectedPair := types.Pair{ - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - PriceTicksize: &keepertest.TestTicksize, - QuantityTicksize: &keepertest.TestTicksize, - } - keeper.AddRegisteredPair(ctx, keepertest.TestContract, expectedPair) - - var expectedRegisteredPairs []types.Pair - expectedRegisteredPairs = append(expectedRegisteredPairs, expectedPair) - - request := types.QueryRegisteredPairsRequest{ - ContractAddr: keepertest.TestContract, - } - expectedResponse := types.QueryRegisteredPairsResponse{ - Pairs: expectedRegisteredPairs, - } - t.Run("Registered Pairs query", func(t *testing.T) { - response, err := wrapper.GetRegisteredPairs(wctx, &request) - require.NoError(t, err) - require.Equal(t, expectedResponse, *response) - }) -} diff --git a/x/dex/keeper/query/grpc_query_short_book.go b/x/dex/keeper/query/grpc_query_short_book.go deleted file mode 100644 index 21855a20b7..0000000000 --- a/x/dex/keeper/query/grpc_query_short_book.go +++ /dev/null @@ -1,46 +0,0 @@ -package query - -import ( - "context" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/sei-protocol/sei-chain/x/dex/types" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" -) - -func (k KeeperWrapper) ShortBookAll(c context.Context, req *types.QueryAllShortBookRequest) (*types.QueryAllShortBookResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - - ctx := sdk.UnwrapSDKContext(c) - - shortBooks, pageRes, err := k.GetAllShortBookForPairPaginated( - ctx, req.ContractAddr, req.PriceDenom, req.AssetDenom, req.Pagination, - ) - if err != nil { - return nil, status.Error(codes.Internal, err.Error()) - } - - return &types.QueryAllShortBookResponse{ShortBook: shortBooks, Pagination: pageRes}, nil -} - -func (k KeeperWrapper) ShortBook(c context.Context, req *types.QueryGetShortBookRequest) (*types.QueryGetShortBookResponse, error) { - if req == nil { - return nil, status.Error(codes.InvalidArgument, "invalid request") - } - - ctx := sdk.UnwrapSDKContext(c) - price, err := sdk.NewDecFromStr(req.Price) - if err != nil { - return nil, err - } - shortBook, found := k.GetShortBookByPrice(ctx, req.ContractAddr, price, req.PriceDenom, req.AssetDenom) - if !found { - return nil, sdkerrors.ErrKeyNotFound - } - - return &types.QueryGetShortBookResponse{ShortBook: shortBook}, nil -} diff --git a/x/dex/keeper/query/grpc_query_short_book_test.go b/x/dex/keeper/query/grpc_query_short_book_test.go deleted file mode 100644 index df919d7fc7..0000000000 --- a/x/dex/keeper/query/grpc_query_short_book_test.go +++ /dev/null @@ -1,123 +0,0 @@ -package query_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" - "github.com/cosmos/cosmos-sdk/types/query" - "github.com/stretchr/testify/require" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/status" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/testutil/nullify" - keeperquery "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func TestShortBookQuerySingle(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wrapper := keeperquery.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - msgs := keepertest.CreateNShortBook(keeper, ctx, 2) - for _, tc := range []struct { - desc string - request *types.QueryGetShortBookRequest - response *types.QueryGetShortBookResponse - err error - }{ - { - desc: "First", - request: &types.QueryGetShortBookRequest{Price: msgs[0].Price.String(), ContractAddr: keepertest.TestContract, PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}, - response: &types.QueryGetShortBookResponse{ShortBook: msgs[0]}, - }, - { - desc: "Second", - request: &types.QueryGetShortBookRequest{Price: msgs[1].Price.String(), ContractAddr: keepertest.TestContract, PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}, - response: &types.QueryGetShortBookResponse{ShortBook: msgs[1]}, - }, - { - desc: "KeyNotFound", - request: &types.QueryGetShortBookRequest{Price: "10000", ContractAddr: keepertest.TestContract, PriceDenom: keepertest.TestPriceDenom, AssetDenom: keepertest.TestAssetDenom}, - err: sdkerrors.ErrKeyNotFound, - }, - { - desc: "InvalidRequest", - err: status.Error(codes.InvalidArgument, "invalid request"), - }, - } { - t.Run(tc.desc, func(t *testing.T) { - response, err := wrapper.ShortBook(wctx, tc.request) - if tc.err != nil { - require.ErrorIs(t, err, tc.err) - } else { - require.NoError(t, err) - require.Equal(t, - nullify.Fill(tc.response), - nullify.Fill(response), - ) - } - }) - } -} - -func TestShortBookQueryPaginated(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - wrapper := keeperquery.KeeperWrapper{Keeper: keeper} - wctx := sdk.WrapSDKContext(ctx) - msgs := keepertest.CreateNShortBook(keeper, ctx, 5) - - request := func(next []byte, offset, limit uint64, total bool) *types.QueryAllShortBookRequest { - return &types.QueryAllShortBookRequest{ - Pagination: &query.PageRequest{ - Key: next, - Offset: offset, - Limit: limit, - CountTotal: total, - }, - ContractAddr: keepertest.TestContract, - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - } - } - t.Run("ByOffset", func(t *testing.T) { - step := 2 - for i := 0; i < len(msgs); i += step { - resp, err := wrapper.ShortBookAll(wctx, request(nil, uint64(i), uint64(step), false)) - require.NoError(t, err) - require.LessOrEqual(t, len(resp.ShortBook), step) - require.Subset(t, - nullify.Fill(msgs), - nullify.Fill(resp.ShortBook), - ) - } - }) - t.Run("ByKey", func(t *testing.T) { - step := 2 - var next []byte - for i := 0; i < len(msgs); i += step { - resp, err := wrapper.ShortBookAll(wctx, request(next, 0, uint64(step), false)) - require.NoError(t, err) - require.LessOrEqual(t, len(resp.ShortBook), step) - require.Subset(t, - nullify.Fill(msgs), - nullify.Fill(resp.ShortBook), - ) - next = resp.Pagination.NextKey - } - }) - t.Run("Total", func(t *testing.T) { - resp, err := wrapper.ShortBookAll(wctx, request(nil, 0, 0, true)) - require.NoError(t, err) - require.Equal(t, len(msgs), int(resp.Pagination.Total)) - require.ElementsMatch(t, - nullify.Fill(msgs), - nullify.Fill(resp.ShortBook), - ) - }) - t.Run("InvalidRequest", func(t *testing.T) { - _, err := wrapper.ShortBookAll(wctx, nil) - require.ErrorIs(t, err, status.Error(codes.InvalidArgument, "invalid request")) - }) -} diff --git a/x/dex/keeper/query/keeper_wrapper.go b/x/dex/keeper/query/keeper_wrapper.go deleted file mode 100644 index e1fcfdd04c..0000000000 --- a/x/dex/keeper/query/keeper_wrapper.go +++ /dev/null @@ -1,9 +0,0 @@ -package query - -import ( - "github.com/sei-protocol/sei-chain/x/dex/keeper" -) - -type KeeperWrapper struct { - *keeper.Keeper -} diff --git a/x/dex/keeper/short_book.go b/x/dex/keeper/short_book.go deleted file mode 100644 index 3e5763401b..0000000000 --- a/x/dex/keeper/short_book.go +++ /dev/null @@ -1,165 +0,0 @@ -package keeper - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/types/query" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" -) - -// SetShortBook set a specific shortBook in the store -func (k Keeper) SetShortBook(ctx sdk.Context, contractAddr string, shortBook types.ShortBook) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(false, contractAddr, shortBook.Entry.PriceDenom, shortBook.Entry.AssetDenom)) - b := k.Cdc.MustMarshal(&shortBook) - store.Set(GetKeyForShortBook(shortBook), b) -} - -func (k Keeper) SetShortOrderBookEntry(ctx sdk.Context, contractAddr string, shortBook types.OrderBookEntry) { - k.SetShortBook(ctx, contractAddr, *shortBook.(*types.ShortBook)) -} - -func (k Keeper) GetShortBookByPrice(ctx sdk.Context, contractAddr string, price sdk.Dec, priceDenom string, assetDenom string) (val types.ShortBook, found bool) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(false, contractAddr, priceDenom, assetDenom)) - b := store.Get(GetKeyForPrice(price)) - if b == nil { - return val, false - } - k.Cdc.MustUnmarshal(b, &val) - return val, true -} - -func (k Keeper) GetShortOrderBookEntryByPrice(ctx sdk.Context, contractAddr string, price sdk.Dec, priceDenom string, assetDenom string) (types.OrderBookEntry, bool) { - entry, found := k.GetShortBookByPrice(ctx, contractAddr, price, priceDenom, assetDenom) - return &entry, found -} - -func (k Keeper) RemoveShortBookByPrice(ctx sdk.Context, contractAddr string, price sdk.Dec, priceDenom string, assetDenom string) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(false, contractAddr, priceDenom, assetDenom)) - store.Delete(GetKeyForPrice(price)) -} - -// GetAllShortBook returns all shortBook -func (k Keeper) GetAllShortBook(ctx sdk.Context, contractAddr string) (list []types.ShortBook) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.ContractKeyPrefix(types.ShortBookKey, contractAddr)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.ShortBook - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, val) - } - - return -} - -func (k Keeper) GetAllShortBookForPair(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string) (list []types.OrderBookEntry) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(false, contractAddr, priceDenom, assetDenom)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.ShortBook - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, &val) - } - - return -} - -func (k Keeper) GetTopNShortBooksForPair(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, n int) (list []types.OrderBookEntry) { - if n == 0 { - return - } - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(false, contractAddr, priceDenom, assetDenom)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - var val types.ShortBook - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, &val) - if len(list) == n { - break - } - } - - return -} - -// Load the first (up to) N short book entries whose price are larger than the specified limit -// in sorted order. -// Parameters: -// -// n: the largest number of entries to load -// startExclusive: the price limit -func (k Keeper) GetTopNShortBooksForPairStarting(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, n int, startExclusive sdk.Dec) (list []types.OrderBookEntry) { - if n == 0 { - return - } - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(false, contractAddr, priceDenom, assetDenom)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - defer iterator.Close() - - // Fast-forward - // TODO: add iterator interface that allows starting at a certain subkey under prefix - for ; iterator.Valid(); iterator.Next() { - key := dexutils.BytesToDec(iterator.Key()) - if key.GT(startExclusive) { - break - } - } - - for ; iterator.Valid(); iterator.Next() { - var val types.ShortBook - k.Cdc.MustUnmarshal(iterator.Value(), &val) - list = append(list, &val) - if len(list) == n { - break - } - } - - return -} - -func (k Keeper) GetAllShortBookForPairPaginated(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, page *query.PageRequest) (list []types.ShortBook, pageRes *query.PageResponse, err error) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderBookPrefix(false, contractAddr, priceDenom, assetDenom)) - - pageRes, err = query.Paginate(store, page, func(key []byte, value []byte) error { - var shortBook types.ShortBook - if err := k.Cdc.Unmarshal(value, &shortBook); err != nil { - return err - } - - list = append(list, shortBook) - return nil - }) - - return -} - -func (k Keeper) GetShortAllocationForOrderID(ctx sdk.Context, contractAddr string, priceDenom string, assetDenom string, price sdk.Dec, orderID uint64) (*types.Allocation, bool) { - orderBook, found := k.GetShortBookByPrice(ctx, contractAddr, price, priceDenom, assetDenom) - if !found { - return nil, false - } - for _, allocation := range orderBook.Entry.Allocations { - if allocation.OrderId == orderID { - return allocation, true - } - } - return nil, false -} - -func (k Keeper) RemoveAllShortBooksForContract(ctx sdk.Context, contractAddr string) { - k.removeAllForPrefix(ctx, types.OrderBookContractPrefix(false, contractAddr)) -} - -func GetKeyForShortBook(shortBook types.ShortBook) []byte { - return GetKeyForPrice(shortBook.Entry.Price) -} diff --git a/x/dex/keeper/short_book_test.go b/x/dex/keeper/short_book_test.go deleted file mode 100644 index 62e709dfde..0000000000 --- a/x/dex/keeper/short_book_test.go +++ /dev/null @@ -1,92 +0,0 @@ -package keeper_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/testutil/nullify" - "github.com/sei-protocol/sei-chain/utils" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestShortBookGet(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - items := keepertest.CreateNShortBook(keeper, ctx, 10) - for i, item := range items { - got, found := keeper.GetShortBookByPrice(ctx, keepertest.TestContract, sdk.NewDec(int64(i)), keepertest.TestPriceDenom, keepertest.TestAssetDenom) - require.True(t, found) - require.Equal(t, - nullify.Fill(&item), - nullify.Fill(&got), - ) - } -} - -func TestShortBookRemove(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - items := keepertest.CreateNShortBook(keeper, ctx, 10) - for i := range items { - keeper.RemoveShortBookByPrice(ctx, keepertest.TestContract, sdk.NewDec(int64(i)), keepertest.TestPriceDenom, keepertest.TestAssetDenom) - _, found := keeper.GetShortBookByPrice(ctx, keepertest.TestContract, sdk.NewDec(int64(i)), keepertest.TestPriceDenom, keepertest.TestAssetDenom) - require.False(t, found) - } -} - -func TestShortBookGetAll(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - items := keepertest.CreateNShortBook(keeper, ctx, 10) - require.ElementsMatch(t, - nullify.Fill(items), - nullify.Fill(keeper.GetAllShortBook(ctx, keepertest.TestContract)), - ) -} - -func TestGetTopNShortBooksForPair(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - prices := []string{"9.99", "0.001", "90.0", "10", "10.01", "9.9", "9.0", "1"} - for _, price := range prices { - keeper.SetShortBook(ctx, keepertest.TestContract, types.ShortBook{ - Price: sdk.MustNewDecFromStr(price), - Entry: &types.OrderEntry{ - Price: sdk.MustNewDecFromStr(price), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - }) - } - expected := []sdk.Dec{ - sdk.MustNewDecFromStr("0.001"), - sdk.MustNewDecFromStr("1"), - sdk.MustNewDecFromStr("9.0"), - sdk.MustNewDecFromStr("9.9"), - sdk.MustNewDecFromStr("9.99"), - sdk.MustNewDecFromStr("10"), - sdk.MustNewDecFromStr("10.01"), - sdk.MustNewDecFromStr("90.0"), - } - loaded := keeper.GetTopNShortBooksForPair(ctx, keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom, 10) - require.Equal(t, expected, utils.Map(loaded, func(b types.OrderBookEntry) sdk.Dec { return b.GetPrice() })) -} - -func TestGetTopNShortBooksForPairStarting(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - prices := []string{"9.99", "0.001", "90.0", "10", "10.01", "9.9", "9.0", "1"} - for _, price := range prices { - keeper.SetShortBook(ctx, keepertest.TestContract, types.ShortBook{ - Price: sdk.MustNewDecFromStr(price), - Entry: &types.OrderEntry{ - Price: sdk.MustNewDecFromStr(price), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - }, - }) - } - expected := []sdk.Dec{ - sdk.MustNewDecFromStr("9.0"), - sdk.MustNewDecFromStr("9.9"), - } - loaded := keeper.GetTopNShortBooksForPairStarting(ctx, keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom, 2, sdk.MustNewDecFromStr("1")) - require.Equal(t, expected, utils.Map(loaded, func(b types.OrderBookEntry) sdk.Dec { return b.GetPrice() })) -} diff --git a/x/dex/keeper/tick.go b/x/dex/keeper/tick.go deleted file mode 100644 index d892952669..0000000000 --- a/x/dex/keeper/tick.go +++ /dev/null @@ -1,60 +0,0 @@ -package keeper - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -// contract_addr, pair -> tick size -func (k Keeper) SetPriceTickSizeForPair(ctx sdk.Context, contractAddr string, pair types.Pair, ticksize sdk.Dec) error { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.RegisteredPairPrefix(contractAddr)) - - pair, found := k.GetRegisteredPair(ctx, contractAddr, pair.PriceDenom, pair.AssetDenom) - if !found { - return types.ErrPairNotRegistered - } - pair.PriceTicksize = &ticksize - store.Set(types.PairPrefix(pair.PriceDenom, pair.AssetDenom), k.Cdc.MustMarshal(&pair)) - - ctx.EventManager().EmitEvent(sdk.NewEvent( - types.EventTypeSetPriceTickSize, - sdk.NewAttribute(types.AttributeKeyContractAddress, contractAddr), - )) - return nil -} - -func (k Keeper) GetPriceTickSizeForPair(ctx sdk.Context, contractAddr string, pair types.Pair) (sdk.Dec, bool) { - pair, found := k.GetRegisteredPair(ctx, contractAddr, pair.PriceDenom, pair.AssetDenom) - if !found { - return sdk.ZeroDec(), false - } - return *pair.PriceTicksize, true -} - -// contract_addr, pair -> tick size -func (k Keeper) SetQuantityTickSizeForPair(ctx sdk.Context, contractAddr string, pair types.Pair, ticksize sdk.Dec) error { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.RegisteredPairPrefix(contractAddr)) - - pair, found := k.GetRegisteredPair(ctx, contractAddr, pair.PriceDenom, pair.AssetDenom) - if !found { - return types.ErrPairNotRegistered - } - pair.QuantityTicksize = &ticksize - store.Set(types.PairPrefix(pair.PriceDenom, pair.AssetDenom), k.Cdc.MustMarshal(&pair)) - - ctx.EventManager().EmitEvent(sdk.NewEvent( - types.EventTypeSetQuantityTickSize, - sdk.NewAttribute(types.AttributeKeyContractAddress, contractAddr), - )) - return nil -} - -func (k Keeper) GetQuantityTickSizeForPair(ctx sdk.Context, contractAddr string, pair types.Pair) (sdk.Dec, bool) { - pair, found := k.GetRegisteredPair(ctx, contractAddr, pair.PriceDenom, pair.AssetDenom) - if !found { - return sdk.ZeroDec(), false - } - return *pair.QuantityTicksize, true -} diff --git a/x/dex/keeper/tick_test.go b/x/dex/keeper/tick_test.go deleted file mode 100644 index 80abe43e9c..0000000000 --- a/x/dex/keeper/tick_test.go +++ /dev/null @@ -1,42 +0,0 @@ -package keeper_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/stretchr/testify/assert" - "github.com/stretchr/testify/require" -) - -func TestPriceTickSizeGet(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - // TEST_PAIR = atom/usdc pair - contractAddr := "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m" - ticksize, found := keeper.GetPriceTickSizeForPair(ctx, contractAddr, keepertest.TestPair) - assert.Equal(t, ticksize, sdk.ZeroDec()) - assert.False(t, found) - - keeper.AddRegisteredPair(ctx, contractAddr, keepertest.TestPair) - err := keeper.SetPriceTickSizeForPair(ctx, contractAddr, keepertest.TestPair, sdk.NewDec(2)) - require.NoError(t, err) - ticksize, found = keeper.GetPriceTickSizeForPair(ctx, contractAddr, keepertest.TestPair) - assert.Equal(t, ticksize, sdk.NewDec(2)) - assert.True(t, found) -} - -func TestQuantityTickSizeGet(t *testing.T) { - keeper, ctx := keepertest.DexKeeper(t) - // TEST_PAIR = atom/usdc pair - contractAddr := "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m" - ticksize, found := keeper.GetQuantityTickSizeForPair(ctx, contractAddr, keepertest.TestPair) - assert.Equal(t, ticksize, sdk.ZeroDec()) - assert.False(t, found) - - keeper.AddRegisteredPair(ctx, contractAddr, keepertest.TestPair) - err := keeper.SetQuantityTickSizeForPair(ctx, contractAddr, keepertest.TestPair, sdk.NewDec(2)) - require.NoError(t, err) - ticksize, found = keeper.GetQuantityTickSizeForPair(ctx, contractAddr, keepertest.TestPair) - assert.Equal(t, ticksize, sdk.NewDec(2)) - assert.True(t, found) -} diff --git a/x/dex/keeper/utils/order_book.go b/x/dex/keeper/utils/order_book.go deleted file mode 100644 index c232ac27fc..0000000000 --- a/x/dex/keeper/utils/order_book.go +++ /dev/null @@ -1,89 +0,0 @@ -package utils - -import ( - "fmt" - "sync" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/utils/datastructures" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func PopulateOrderbook( - ctx sdk.Context, - keeper *keeper.Keeper, - contractAddr types.ContractAddress, - pair types.Pair, -) *types.OrderBook { - // TODO update to param - loadCnt := int(keeper.GetOrderBookEntriesPerLoad(ctx)) - longLoader := func(lctx sdk.Context, startExclusive sdk.Dec, withLimit bool) []types.OrderBookEntry { - if !withLimit { - return keeper.GetTopNLongBooksForPair(lctx, string(contractAddr), pair.PriceDenom, pair.AssetDenom, loadCnt) - } - return keeper.GetTopNLongBooksForPairStarting(lctx, string(contractAddr), pair.PriceDenom, pair.AssetDenom, loadCnt, startExclusive) - } - shortLoader := func(lctx sdk.Context, startExclusive sdk.Dec, withLimit bool) []types.OrderBookEntry { - if !withLimit { - return keeper.GetTopNShortBooksForPair(lctx, string(contractAddr), pair.PriceDenom, pair.AssetDenom, loadCnt) - } - return keeper.GetTopNShortBooksForPairStarting(lctx, string(contractAddr), pair.PriceDenom, pair.AssetDenom, loadCnt, startExclusive) - } - longSetter := func(lctx sdk.Context, o types.OrderBookEntry) { - keeper.SetLongOrderBookEntry(lctx, string(contractAddr), o) - err := keeper.SetOrderCount(lctx, string(contractAddr), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_LONG, o.GetPrice(), uint64(len(o.GetOrderEntry().GetAllocations()))) - if err != nil { - ctx.Logger().Error(fmt.Sprintf("error setting order count: %s", err)) - } - } - shortSetter := func(lctx sdk.Context, o types.OrderBookEntry) { - keeper.SetShortOrderBookEntry(lctx, string(contractAddr), o) - err := keeper.SetOrderCount(lctx, string(contractAddr), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_SHORT, o.GetPrice(), uint64(len(o.GetOrderEntry().GetAllocations()))) - if err != nil { - ctx.Logger().Error(fmt.Sprintf("error setting order count: %s", err)) - } - } - longDeleter := func(lctx sdk.Context, o types.OrderBookEntry) { - keeper.RemoveLongBookByPrice(lctx, string(contractAddr), o.GetPrice(), pair.PriceDenom, pair.AssetDenom) - err := keeper.SetOrderCount(lctx, string(contractAddr), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_LONG, o.GetPrice(), 0) - if err != nil { - ctx.Logger().Error(fmt.Sprintf("error setting order count: %s", err)) - } - } - shortDeleter := func(lctx sdk.Context, o types.OrderBookEntry) { - keeper.RemoveShortBookByPrice(lctx, string(contractAddr), o.GetPrice(), pair.PriceDenom, pair.AssetDenom) - err := keeper.SetOrderCount(lctx, string(contractAddr), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_SHORT, o.GetPrice(), 0) - if err != nil { - ctx.Logger().Error(fmt.Sprintf("error setting order count: %s", err)) - } - } - return &types.OrderBook{ - Contract: contractAddr, - Pair: pair, - Longs: types.NewCachedSortedOrderBookEntries(longLoader, longSetter, longDeleter), - Shorts: types.NewCachedSortedOrderBookEntries(shortLoader, shortSetter, shortDeleter), - } -} - -func PopulateAllOrderbooks( - ctx sdk.Context, - keeper *keeper.Keeper, - contractsAndPairs map[string][]types.Pair, -) *datastructures.TypedNestedSyncMap[string, types.PairString, *types.OrderBook] { - var orderBooks = datastructures.NewTypedNestedSyncMap[string, types.PairString, *types.OrderBook]() - wg := sync.WaitGroup{} - for contractAddr, pairs := range contractsAndPairs { - orderBooks.Store(contractAddr, datastructures.NewTypedSyncMap[types.PairString, *types.OrderBook]()) - for _, pair := range pairs { - wg.Add(1) - go func(contractAddr string, pair types.Pair) { - defer wg.Done() - orderBook := PopulateOrderbook(ctx, keeper, types.ContractAddress(contractAddr), pair) - orderBooks.StoreNested(contractAddr, types.GetPairString(&pair), orderBook) - }(contractAddr, pair) - } - } - wg.Wait() - return orderBooks -} diff --git a/x/dex/keeper/utils/price.go b/x/dex/keeper/utils/price.go deleted file mode 100644 index 9552c2fb77..0000000000 --- a/x/dex/keeper/utils/price.go +++ /dev/null @@ -1,28 +0,0 @@ -package utils - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/exchange" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func SetPriceStateFromExecutionOutcome( - ctx sdk.Context, - keeper *keeper.Keeper, - contractAddr types.ContractAddress, - pair types.Pair, - outcome exchange.ExecutionOutcome, -) { - if outcome.TotalQuantity.IsZero() { - return - } - - avgPrice := outcome.TotalNotional.Quo(outcome.TotalQuantity) - priceState := types.Price{ - Pair: &pair, - Price: avgPrice, - SnapshotTimestampInSeconds: uint64(ctx.BlockTime().Unix()), - } - keeper.SetPriceState(ctx, priceState, string(contractAddr)) -} diff --git a/x/dex/keeper/utils/wasm.go b/x/dex/keeper/utils/wasm.go deleted file mode 100644 index 8cc3354550..0000000000 --- a/x/dex/keeper/utils/wasm.go +++ /dev/null @@ -1,116 +0,0 @@ -package utils - -import ( - "encoding/json" - "fmt" - "strings" - "time" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/utils" - "github.com/sei-protocol/sei-chain/utils/logging" - "github.com/sei-protocol/sei-chain/utils/metrics" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -const ErrWasmModuleInstCPUFeatureLiteral = "Error instantiating module: CpuFeature" -const SudoGasEventKey = "sudo-gas" -const LogAfter = 5 * time.Second - -func getMsgType(msg interface{}) string { - switch msg.(type) { - case types.SudoSettlementMsg: - return "settlement" - case types.SudoOrderPlacementMsg: - return "bulk_order_placements" - case types.SudoOrderCancellationMsg: - return "bulk_order_cancellations" - default: - return "unknown" - } -} - -func sudo(sdkCtx sdk.Context, k *keeper.Keeper, contractAddress sdk.AccAddress, wasmMsg []byte, msgType string) ([]byte, uint64, error) { - defer utils.PanicHandler(func(err any) { - utils.MetricsPanicCallback(err, sdkCtx, fmt.Sprintf("%s|%s", contractAddress, msgType)) - })() - - // Measure the time it takes to execute the contract in WASM - defer metrics.MeasureSudoExecutionDuration(time.Now(), msgType) - // set up a tmp context to prevent race condition in reading gas consumed - // Note that the limit will effectively serve as a soft limit since it's - // possible for the actual computation to go above the specified limit, but - // the associated contract would be charged corresponding rent. - gasLimit, err := k.GetContractGasLimit(sdkCtx, contractAddress) - if err != nil { - return nil, 0, err - } - tmpCtx := sdkCtx.WithGasMeter(sdk.NewGasMeterWithMultiplier(sdkCtx, gasLimit)) - data, err := sudoWithoutOutOfGasPanic(tmpCtx, k, contractAddress, wasmMsg, msgType) - gasConsumed := tmpCtx.GasMeter().GasConsumed() - sdkCtx.EventManager().EmitEvent( - sdk.NewEvent( - SudoGasEventKey, - sdk.NewAttribute("consumed", fmt.Sprintf("%d", gasConsumed)), - sdk.NewAttribute("type", msgType), - sdk.NewAttribute("contract", contractAddress.String()), - sdk.NewAttribute("height", fmt.Sprintf("%d", sdkCtx.BlockHeight())), - ), - ) - if gasConsumed > 0 { - sdkCtx.GasMeter().ConsumeGas(gasConsumed, "sudo") - } - if hasErrInstantiatingWasmModuleDueToCPUFeature(err) { - panic(utils.DecorateHardFailError(err)) - } - return data, gasConsumed, err -} - -func sudoWithoutOutOfGasPanic(ctx sdk.Context, k *keeper.Keeper, contractAddress []byte, wasmMsg []byte, logName string) ([]byte, error) { - defer func() { - if err := recover(); err != nil { - // only propagate panic if the error is NOT out of gas - if _, ok := err.(sdk.ErrorOutOfGas); !ok { - panic(err) - } - ctx.Logger().Error(fmt.Sprintf("%s %s is out of gas", sdk.AccAddress(contractAddress).String(), logName)) - } - }() - return logging.LogIfNotDoneAfter(ctx.Logger(), func() ([]byte, error) { - return k.WasmKeeper.Sudo(ctx, contractAddress, wasmMsg) - }, LogAfter, fmt.Sprintf("wasm_sudo_%s", logName)) -} - -func hasErrInstantiatingWasmModuleDueToCPUFeature(err error) bool { - if err == nil { - return false - } - return strings.Contains(err.Error(), ErrWasmModuleInstCPUFeatureLiteral) -} - -func CallContractSudo(sdkCtx sdk.Context, k *keeper.Keeper, contractAddr string, msg interface{}, gasAllowance uint64) ([]byte, error) { - contractAddress, err := sdk.AccAddressFromBech32(contractAddr) - if err != nil { - sdkCtx.Logger().Error(err.Error()) - return []byte{}, err - } - wasmMsg, err := json.Marshal(msg) - if err != nil { - sdkCtx.Logger().Error(err.Error()) - return []byte{}, err - } - msgType := getMsgType(msg) - data, gasUsed, suderr := sudo(sdkCtx, k, contractAddress, wasmMsg, msgType) - if err := k.ChargeRentForGas(sdkCtx, contractAddr, gasUsed, gasAllowance); err != nil { - metrics.IncrementSudoFailCount(msgType) - sdkCtx.Logger().Error(err.Error()) - return []byte{}, err - } - if suderr != nil { - metrics.IncrementSudoFailCount(msgType) - sdkCtx.Logger().Error(suderr.Error()) - return []byte{}, suderr - } - return data, nil -} diff --git a/x/dex/migrations/v10_to_v11.go b/x/dex/migrations/v10_to_v11.go deleted file mode 100644 index 4f35a5e68a..0000000000 --- a/x/dex/migrations/v10_to_v11.go +++ /dev/null @@ -1,45 +0,0 @@ -package migrations - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -var DexPrefixes = []string{ - types.LongBookKey, - types.ShortBookKey, - "TriggerBook-value-", - types.OrderKey, - types.TwapKey, - types.RegisteredPairKey, - types.OrderKey, - types.CancelKey, - types.AccountActiveOrdersKey, - types.NextOrderIDKey, - types.MatchResultKey, - types.MemOrderKey, - types.MemCancelKey, - types.MemDepositKey, - types.PriceKey, - "SettlementEntry-", - "NextSettlementID-", -} - -func V10ToV11(ctx sdk.Context, dexkeeper keeper.Keeper) error { - dexkeeper.CreateModuleAccount(ctx) - - // this will nuke all old prefixes data in the store - for _, prefixKey := range DexPrefixes { - store := prefix.NewStore(ctx.KVStore(dexkeeper.GetStoreKey()), []byte(prefixKey)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - defer iterator.Close() - for ; iterator.Valid(); iterator.Next() { - store.Delete(iterator.Key()) - } - } - - return nil -} diff --git a/x/dex/migrations/v10_to_v11_test.go b/x/dex/migrations/v10_to_v11_test.go deleted file mode 100644 index 775c20928e..0000000000 --- a/x/dex/migrations/v10_to_v11_test.go +++ /dev/null @@ -1,60 +0,0 @@ -package migrations_test - -import ( - "testing" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMigrate10to11(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - // write old contract - store := ctx.KVStore(dexkeeper.GetStoreKey()) - value := []byte("test_value") - store.Set(types.ContractKeyPrefix(types.LongBookKey, keepertest.TestContract), value) - store.Set(types.OrderBookPrefix(false, keepertest.TestContract, "USDC", "ATOM"), value) - store.Set(TriggerOrderBookPrefix(keepertest.TestContract, "USDC", "ATOM"), value) - store.Set(types.PricePrefix(keepertest.TestContract, "USDC", "ATOM"), value) - store.Set(migrations.SettlementEntryPrefix(keepertest.TestContract, "USDC", "ATOM"), value) - store.Set(types.RegisteredPairPrefix(keepertest.TestContract), value) - store.Set(types.OrderPrefix(keepertest.TestContract), value) - store.Set(types.NextOrderIDPrefix(keepertest.TestContract), value) - store.Set(migrations.NextSettlementIDPrefix(keepertest.TestContract, "USDC", "ATOM"), value) - store.Set(types.MatchResultPrefix(keepertest.TestContract), value) - store.Set(types.MemOrderPrefixForPair(keepertest.TestContract, "USDC", "ATOM"), value) - store.Set(types.MemCancelPrefixForPair(keepertest.TestContract, "USDC", "ATOM"), value) - store.Set(types.MemOrderPrefix(keepertest.TestContract), value) - store.Set(types.MemCancelPrefix(keepertest.TestContract), value) - store.Set(types.MemDepositPrefix(keepertest.TestContract), value) - - err := migrations.V10ToV11(ctx, *dexkeeper) - require.NoError(t, err) - - require.False(t, store.Has(types.ContractKeyPrefix(types.LongBookKey, keepertest.TestContract))) - require.False(t, store.Has(types.OrderBookPrefix(false, keepertest.TestContract, "USDC", "ATOM"))) - require.False(t, store.Has(TriggerOrderBookPrefix(keepertest.TestContract, "USDC", "ATOM"))) - require.False(t, store.Has(types.PricePrefix(keepertest.TestContract, "USDC", "ATOM"))) - require.False(t, store.Has(migrations.SettlementEntryPrefix(keepertest.TestContract, "USDC", "ATOM"))) - require.False(t, store.Has(types.RegisteredPairPrefix(keepertest.TestContract))) - require.False(t, store.Has(types.OrderPrefix(keepertest.TestContract))) - require.False(t, store.Has(types.NextOrderIDPrefix(keepertest.TestContract))) - require.False(t, store.Has(migrations.NextSettlementIDPrefix(keepertest.TestContract, "USDC", "ATOM"))) - require.False(t, store.Has(types.MatchResultPrefix(keepertest.TestContract))) - require.False(t, store.Has(types.MemOrderPrefixForPair(keepertest.TestContract, "USDC", "ATOM"))) - require.False(t, store.Has(types.MemCancelPrefixForPair(keepertest.TestContract, "USDC", "ATOM"))) - require.False(t, store.Has(types.MemOrderPrefix(keepertest.TestContract))) - require.False(t, store.Has(types.MemCancelPrefix(keepertest.TestContract))) - require.False(t, store.Has(types.MemDepositPrefix(keepertest.TestContract))) -} - -func TriggerOrderBookPrefix(contractAddr string, priceDenom string, assetDenom string) []byte { - prefix := types.KeyPrefix("TriggerBook-value-") - - return append( - append(prefix, types.AddressKeyPrefix(contractAddr)...), - types.PairPrefix(priceDenom, assetDenom)..., - ) -} diff --git a/x/dex/migrations/v11_to_v12.go b/x/dex/migrations/v11_to_v12.go deleted file mode 100644 index 66c68a44a0..0000000000 --- a/x/dex/migrations/v11_to_v12.go +++ /dev/null @@ -1,13 +0,0 @@ -package migrations - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func V11ToV12(ctx sdk.Context, dexkeeper keeper.Keeper) error { - defaultParams := types.DefaultParams() - dexkeeper.SetParams(ctx, defaultParams) - return nil -} diff --git a/x/dex/migrations/v11_to_v12_test.go b/x/dex/migrations/v11_to_v12_test.go deleted file mode 100644 index bf0baf6ca9..0000000000 --- a/x/dex/migrations/v11_to_v12_test.go +++ /dev/null @@ -1,31 +0,0 @@ -package migrations_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMigrate11to12(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - // write old params - defaultParams := types.Params{ - PriceSnapshotRetention: 1, - SudoCallGasPrice: sdk.OneDec(), - BeginBlockGasLimit: 1, - EndBlockGasLimit: 1, - DefaultGasPerOrder: 1, - DefaultGasPerCancel: 1, - } - dexkeeper.SetParams(ctx, defaultParams) - - // migrate to default params - err := migrations.V11ToV12(ctx, *dexkeeper) - require.NoError(t, err) - params := dexkeeper.GetParams(ctx) - require.Equal(t, params, types.DefaultParams()) -} diff --git a/x/dex/migrations/v12_to_v13.go b/x/dex/migrations/v12_to_v13.go deleted file mode 100644 index 9bd5891f79..0000000000 --- a/x/dex/migrations/v12_to_v13.go +++ /dev/null @@ -1,15 +0,0 @@ -package migrations - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func V12ToV13(ctx sdk.Context, dexkeeper keeper.Keeper) error { - // This isn't the cleanest migration since it could potentially revert any dex params we have changed - // but we haven't, so we'll just do this. - defaultParams := types.DefaultParams() - dexkeeper.SetParams(ctx, defaultParams) - return nil -} diff --git a/x/dex/migrations/v12_to_v13_test.go b/x/dex/migrations/v12_to_v13_test.go deleted file mode 100644 index fd70a50ce8..0000000000 --- a/x/dex/migrations/v12_to_v13_test.go +++ /dev/null @@ -1,32 +0,0 @@ -package migrations_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMigrate12to13(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - // write old params - prevParams := types.Params{ - PriceSnapshotRetention: 1, - SudoCallGasPrice: sdk.OneDec(), - BeginBlockGasLimit: 1, - EndBlockGasLimit: 1, - DefaultGasPerOrder: 1, - DefaultGasPerCancel: 1, - } - dexkeeper.SetParams(ctx, prevParams) - - // migrate to default params - err := migrations.V12ToV13(ctx, *dexkeeper) - require.NoError(t, err) - params := dexkeeper.GetParams(ctx) - require.Equal(t, params.GasAllowancePerSettlement, uint64(types.DefaultGasAllowancePerSettlement)) - require.Equal(t, params.MinProcessableRent, uint64(types.DefaultMinProcessableRent)) -} diff --git a/x/dex/migrations/v13_to_v14.go b/x/dex/migrations/v13_to_v14.go deleted file mode 100644 index 062cc35c80..0000000000 --- a/x/dex/migrations/v13_to_v14.go +++ /dev/null @@ -1,69 +0,0 @@ -package migrations - -import ( - "fmt" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/utils" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func V13ToV14(ctx sdk.Context, dexkeeper keeper.Keeper) error { - setDefaultParams(ctx, dexkeeper) - - for _, contractAddr := range getAllContractAddresses(ctx, dexkeeper) { - convertOrderBookEntryKeysForContract(ctx, dexkeeper, contractAddr) - } - return nil -} - -func setDefaultParams(ctx sdk.Context, dexkeeper keeper.Keeper) { - // This isn't the cleanest migration since it could potentially revert any dex params we have changed - // but we haven't, so we'll just do this. - defaultParams := types.DefaultParams() - dexkeeper.SetParams(ctx, defaultParams) -} - -func getAllContractAddresses(ctx sdk.Context, dexkeeper keeper.Keeper) []string { - contracts := dexkeeper.GetAllContractInfo(ctx) - return utils.Map(contracts, func(c types.ContractInfoV2) string { return c.ContractAddr }) -} - -func convertOrderBookEntryKeysForContract(ctx sdk.Context, dexkeeper keeper.Keeper, contractAddr string) { - ctx.Logger().Info(fmt.Sprintf("converting order book entry keys for contract %s", contractAddr)) - store := prefix.NewStore(ctx.KVStore(dexkeeper.GetStoreKey()), types.ContractKeyPrefix(types.LongBookKey, contractAddr)) - iterator := sdk.KVStorePrefixIterator(store, []byte{}) - - keyToVal := map[string][]byte{} - for ; iterator.Valid(); iterator.Next() { - keyToVal[string(iterator.Key())] = iterator.Value() - } - iterator.Close() - - for key, v := range keyToVal { - store.Delete([]byte(key)) - var val types.LongBook - dexkeeper.Cdc.MustUnmarshal(v, &val) - newKey := append(types.PairPrefix(val.Entry.PriceDenom, val.Entry.AssetDenom), keeper.GetKeyForPrice(val.Price)...) - store.Set(newKey, v) - } - - store = prefix.NewStore(ctx.KVStore(dexkeeper.GetStoreKey()), types.ContractKeyPrefix(types.ShortBookKey, contractAddr)) - iterator = sdk.KVStorePrefixIterator(store, []byte{}) - - keyToVal = map[string][]byte{} - for ; iterator.Valid(); iterator.Next() { - keyToVal[string(iterator.Key())] = iterator.Value() - } - iterator.Close() - - for key, v := range keyToVal { - store.Delete([]byte(key)) - var val types.ShortBook - dexkeeper.Cdc.MustUnmarshal(v, &val) - newKey := append(types.PairPrefix(val.Entry.PriceDenom, val.Entry.AssetDenom), keeper.GetKeyForPrice(val.Price)...) - store.Set(newKey, v) - } -} diff --git a/x/dex/migrations/v13_to_v14_test.go b/x/dex/migrations/v13_to_v14_test.go deleted file mode 100644 index b9937b3e3f..0000000000 --- a/x/dex/migrations/v13_to_v14_test.go +++ /dev/null @@ -1,79 +0,0 @@ -package migrations_test - -import ( - "testing" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/stretchr/testify/require" -) - -func TestMigrate13to14(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - // write old params - prevParams := types.Params{ - PriceSnapshotRetention: 1, - SudoCallGasPrice: sdk.OneDec(), - BeginBlockGasLimit: 1, - EndBlockGasLimit: 1, - DefaultGasPerOrder: 1, - DefaultGasPerCancel: 1, - GasAllowancePerSettlement: 1, - MinProcessableRent: 1, - } - dexkeeper.SetParams(ctx, prevParams) - - dexkeeper.SetContract(ctx, &types.ContractInfoV2{ContractAddr: keepertest.TestContract}) - longStore := prefix.NewStore(ctx.KVStore(dexkeeper.GetStoreKey()), types.OrderBookPrefix( - true, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, - )) - longEntry := types.LongBook{ - Price: sdk.MustNewDecFromStr("10.123"), - Entry: &types.OrderEntry{ - Price: sdk.MustNewDecFromStr("10.123"), - Quantity: sdk.MustNewDecFromStr("5"), - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - }, - } - longEntryKey, err := longEntry.GetPrice().Marshal() - require.Nil(t, err) - longStore.Set(longEntryKey, dexkeeper.Cdc.MustMarshal(&longEntry)) - - shortStore := prefix.NewStore(ctx.KVStore(dexkeeper.GetStoreKey()), types.OrderBookPrefix( - false, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom, - )) - shortEntry := types.ShortBook{ - Price: sdk.MustNewDecFromStr("12.456"), - Entry: &types.OrderEntry{ - Price: sdk.MustNewDecFromStr("12.456"), - Quantity: sdk.MustNewDecFromStr("4"), - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - }, - } - shortEntryKey, err := shortEntry.GetPrice().Marshal() - require.Nil(t, err) - shortStore.Set(shortEntryKey, dexkeeper.Cdc.MustMarshal(&shortEntry)) - - // migrate to default params - err = migrations.V13ToV14(ctx, *dexkeeper) - require.NoError(t, err) - params := dexkeeper.GetParams(ctx) - require.Equal(t, params.OrderBookEntriesPerLoad, uint64(types.DefaultOrderBookEntriesPerLoad)) - - require.Nil(t, longStore.Get(longEntryKey)) - require.Nil(t, shortStore.Get(shortEntryKey)) - var loadedLongEntry types.LongBook - dexkeeper.Cdc.MustUnmarshal(longStore.Get(utils.DecToBigEndian(longEntry.Price)), &loadedLongEntry) - require.Equal(t, longEntry.Price, loadedLongEntry.Price) - require.Equal(t, *longEntry.Entry, *loadedLongEntry.Entry) - var loadedShortEntry types.ShortBook - dexkeeper.Cdc.MustUnmarshal(shortStore.Get(utils.DecToBigEndian(shortEntry.Price)), &loadedShortEntry) - require.Equal(t, shortEntry.Price, loadedShortEntry.Price) - require.Equal(t, *shortEntry.Entry, *loadedShortEntry.Entry) -} diff --git a/x/dex/migrations/v14_to_v15.go b/x/dex/migrations/v14_to_v15.go deleted file mode 100644 index 158990fb1e..0000000000 --- a/x/dex/migrations/v14_to_v15.go +++ /dev/null @@ -1,15 +0,0 @@ -package migrations - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func V14ToV15(ctx sdk.Context, dexkeeper keeper.Keeper) error { - // This isn't the cleanest migration since it could potentially revert any dex params we have changed - // but we haven't, so we'll just do this. - defaultParams := types.DefaultParams() - dexkeeper.SetParams(ctx, defaultParams) - return nil -} diff --git a/x/dex/migrations/v14_to_v15_test.go b/x/dex/migrations/v14_to_v15_test.go deleted file mode 100644 index f6d76f1c72..0000000000 --- a/x/dex/migrations/v14_to_v15_test.go +++ /dev/null @@ -1,26 +0,0 @@ -package migrations_test - -import ( - "testing" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMigrate14to15(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - // write old params - prevParams := types.DefaultParams() - prevParams.MaxOrderPerPrice = 0 - prevParams.MaxPairsPerContract = 0 - dexkeeper.SetParams(ctx, prevParams) - - // migrate to default params - err := migrations.V14ToV15(ctx, *dexkeeper) - require.NoError(t, err) - params := dexkeeper.GetParams(ctx) - require.Equal(t, params.MaxOrderPerPrice, uint64(types.DefaultMaxOrderPerPrice)) - require.Equal(t, params.MaxPairsPerContract, uint64(types.DefaultMaxPairsPerContract)) -} diff --git a/x/dex/migrations/v15_to_v16.go b/x/dex/migrations/v15_to_v16.go deleted file mode 100644 index 3e5f9eb394..0000000000 --- a/x/dex/migrations/v15_to_v16.go +++ /dev/null @@ -1,15 +0,0 @@ -package migrations - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func V15ToV16(ctx sdk.Context, dexkeeper keeper.Keeper) error { - // This isn't the cleanest migration since it could potentially revert any dex params we have changed - // but we haven't, so we'll just do this. - defaultParams := types.DefaultParams() - dexkeeper.SetParams(ctx, defaultParams) - return nil -} diff --git a/x/dex/migrations/v15_to_v16_test.go b/x/dex/migrations/v15_to_v16_test.go deleted file mode 100644 index 48fa655ff6..0000000000 --- a/x/dex/migrations/v15_to_v16_test.go +++ /dev/null @@ -1,24 +0,0 @@ -package migrations_test - -import ( - "testing" - - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMigrate15to16(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - // write old params - prevParams := types.DefaultParams() - prevParams.DefaultGasPerOrderDataByte = 0 - dexkeeper.SetParams(ctx, prevParams) - - // migrate to default params - err := migrations.V15ToV16(ctx, *dexkeeper) - require.NoError(t, err) - params := dexkeeper.GetParams(ctx) - require.Equal(t, params.DefaultGasPerOrderDataByte, uint64(30)) -} diff --git a/x/dex/migrations/v16_to_v17.go b/x/dex/migrations/v16_to_v17.go deleted file mode 100644 index 7066db5845..0000000000 --- a/x/dex/migrations/v16_to_v17.go +++ /dev/null @@ -1,110 +0,0 @@ -package migrations - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/goutils" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -const OldPairSeparator = '|' - -func OldPairPrefix(priceDenom string, assetDenom string) []byte { - return goutils.ImmutableAppend(goutils.ImmutableAppend([]byte(priceDenom), OldPairSeparator), []byte(assetDenom)...) -} - -func V16ToV17(ctx sdk.Context, dexkeeper keeper.Keeper) error { - rootStore := ctx.KVStore(dexkeeper.GetStoreKey()) - - handler := func(oldPref []byte, newPref []byte) { - store := prefix.NewStore(rootStore, oldPref) - kv := map[string][]byte{} - iter := store.Iterator(nil, nil) - defer iter.Close() - for ; iter.Valid(); iter.Next() { - kv[string(iter.Key())] = iter.Value() - } - for k, v := range kv { - kbz := []byte(k) - store.Delete(kbz) - rootStore.Set(goutils.ImmutableAppend(newPref, kbz...), v) - } - } - - for _, c := range dexkeeper.GetAllContractInfo(ctx) { - for _, p := range dexkeeper.GetAllRegisteredPairs(ctx, c.ContractAddr) { - // long order book - handler( - goutils.ImmutableAppend( - types.OrderBookContractPrefix(true, c.ContractAddr), - OldPairPrefix(p.PriceDenom, p.AssetDenom)..., - ), - types.OrderBookPrefix(true, c.ContractAddr, p.PriceDenom, p.AssetDenom), - ) - - // short order book - handler( - goutils.ImmutableAppend( - types.OrderBookContractPrefix(false, c.ContractAddr), - OldPairPrefix(p.PriceDenom, p.AssetDenom)..., - ), - types.OrderBookPrefix(false, c.ContractAddr, p.PriceDenom, p.AssetDenom), - ) - - // price - handler( - goutils.ImmutableAppend( - types.PriceContractPrefix(c.ContractAddr), - OldPairPrefix(p.PriceDenom, p.AssetDenom)..., - ), - types.PricePrefix(c.ContractAddr, p.PriceDenom, p.AssetDenom), - ) - - // order count (long) - handler( - goutils.ImmutableAppend( - goutils.ImmutableAppend(types.KeyPrefix(types.LongOrderCountKey), types.AddressKeyPrefix(c.ContractAddr)...), - OldPairPrefix(p.PriceDenom, p.AssetDenom)..., - ), - types.OrderCountPrefix(c.ContractAddr, p.PriceDenom, p.AssetDenom, true), - ) - - // order count (short) - handler( - goutils.ImmutableAppend( - goutils.ImmutableAppend(types.KeyPrefix(types.ShortOrderCountKey), types.AddressKeyPrefix(c.ContractAddr)...), - OldPairPrefix(p.PriceDenom, p.AssetDenom)..., - ), - types.OrderCountPrefix(c.ContractAddr, p.PriceDenom, p.AssetDenom, false), - ) - - // registered pair - k := goutils.ImmutableAppend(types.RegisteredPairPrefix(c.ContractAddr), OldPairPrefix(p.PriceDenom, p.AssetDenom)...) - pair := rootStore.Get(k) - rootStore.Delete(k) - rootStore.Set( - goutils.ImmutableAppend(types.RegisteredPairPrefix(c.ContractAddr), types.PairPrefix(p.PriceDenom, p.AssetDenom)...), - pair, - ) - } - } - - // asset list - pref := types.KeyPrefix(types.AssetListKey) - store := prefix.NewStore(rootStore, pref) - kv := map[string][]byte{} - iter := store.Iterator(nil, nil) - for ; iter.Valid(); iter.Next() { - kv[string(iter.Key())] = iter.Value() - } - iter.Close() - for k, v := range kv { - kbz := []byte(k) - store.Delete(kbz) - denom := string(kbz) - newKbz := types.AssetListPrefix(denom) - rootStore.Set(newKbz, v) - } - return nil -} diff --git a/x/dex/migrations/v16_to_v17_test.go b/x/dex/migrations/v16_to_v17_test.go deleted file mode 100644 index ac6c7ad0d1..0000000000 --- a/x/dex/migrations/v16_to_v17_test.go +++ /dev/null @@ -1,89 +0,0 @@ -package migrations_test - -import ( - "testing" - - "github.com/sei-protocol/goutils" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMigrate16to17(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - store := ctx.KVStore(dexkeeper.GetStoreKey()) - dexkeeper.SetContract(ctx, &types.ContractInfoV2{ContractAddr: keepertest.TestContract}) - // add registered pair using the old key - pair := types.Pair{PriceDenom: keepertest.TestPair.PriceDenom, AssetDenom: keepertest.TestPair.AssetDenom} - store.Set( - goutils.ImmutableAppend( - types.RegisteredPairPrefix(keepertest.TestContract), - migrations.OldPairPrefix(keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom)..., - ), - dexkeeper.Cdc.MustMarshal(&pair), - ) - - value := []byte("test_value") - store.Set(goutils.ImmutableAppend( - types.OrderBookContractPrefix(true, keepertest.TestContract), - migrations.OldPairPrefix(pair.PriceDenom, pair.AssetDenom)..., - ), value) - store.Set(goutils.ImmutableAppend( - types.OrderBookContractPrefix(false, keepertest.TestContract), - migrations.OldPairPrefix(pair.PriceDenom, pair.AssetDenom)..., - ), value) - store.Set(goutils.ImmutableAppend( - types.PriceContractPrefix(keepertest.TestContract), - migrations.OldPairPrefix(pair.PriceDenom, pair.AssetDenom)..., - ), value) - store.Set(goutils.ImmutableAppend( - goutils.ImmutableAppend(types.KeyPrefix(types.LongOrderCountKey), types.AddressKeyPrefix(keepertest.TestContract)...), - migrations.OldPairPrefix(pair.PriceDenom, pair.AssetDenom)..., - ), value) - store.Set(goutils.ImmutableAppend( - goutils.ImmutableAppend(types.KeyPrefix(types.ShortOrderCountKey), types.AddressKeyPrefix(keepertest.TestContract)...), - migrations.OldPairPrefix(pair.PriceDenom, pair.AssetDenom)..., - ), value) - store.Set(goutils.ImmutableAppend(types.KeyPrefix(types.AssetListKey), []byte(pair.PriceDenom)...), value) - - err := migrations.V16ToV17(ctx, *dexkeeper) - require.NoError(t, err) - - require.False(t, store.Has(goutils.ImmutableAppend( - types.OrderBookContractPrefix(true, keepertest.TestContract), - migrations.OldPairPrefix(pair.PriceDenom, pair.AssetDenom)..., - ))) - require.False(t, store.Has(goutils.ImmutableAppend( - types.OrderBookContractPrefix(false, keepertest.TestContract), - migrations.OldPairPrefix(pair.PriceDenom, pair.AssetDenom)..., - ))) - require.False(t, store.Has(goutils.ImmutableAppend( - types.PriceContractPrefix(keepertest.TestContract), - migrations.OldPairPrefix(pair.PriceDenom, pair.AssetDenom)..., - ))) - require.False(t, store.Has(goutils.ImmutableAppend( - goutils.ImmutableAppend(types.KeyPrefix(types.LongOrderCountKey), types.AddressKeyPrefix(keepertest.TestContract)...), - migrations.OldPairPrefix(pair.PriceDenom, pair.AssetDenom)..., - ))) - require.False(t, store.Has(goutils.ImmutableAppend( - goutils.ImmutableAppend(types.KeyPrefix(types.ShortOrderCountKey), types.AddressKeyPrefix(keepertest.TestContract)...), - migrations.OldPairPrefix(pair.PriceDenom, pair.AssetDenom)..., - ))) - require.False(t, store.Has(goutils.ImmutableAppend(types.KeyPrefix(types.AssetListKey), []byte(pair.PriceDenom)...))) - require.False(t, store.Has(goutils.ImmutableAppend( - types.RegisteredPairPrefix(keepertest.TestContract), - migrations.OldPairPrefix(keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom)..., - ))) - - require.True(t, store.Has(types.OrderBookPrefix(true, keepertest.TestContract, pair.PriceDenom, pair.AssetDenom))) - require.True(t, store.Has(types.OrderBookPrefix(false, keepertest.TestContract, pair.PriceDenom, pair.AssetDenom))) - require.True(t, store.Has(types.PricePrefix(keepertest.TestContract, pair.PriceDenom, pair.AssetDenom))) - require.True(t, store.Has(types.OrderCountPrefix(keepertest.TestContract, pair.PriceDenom, pair.AssetDenom, true))) - require.True(t, store.Has(types.OrderCountPrefix(keepertest.TestContract, pair.PriceDenom, pair.AssetDenom, false))) - require.True(t, store.Has(types.AssetListPrefix(pair.PriceDenom))) - require.True(t, store.Has(goutils.ImmutableAppend( - types.RegisteredPairPrefix(keepertest.TestContract), - types.PairPrefix(keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom)..., - ))) -} diff --git a/x/dex/migrations/v17_to_v18.go b/x/dex/migrations/v17_to_v18.go deleted file mode 100644 index 7e6448bac9..0000000000 --- a/x/dex/migrations/v17_to_v18.go +++ /dev/null @@ -1,33 +0,0 @@ -package migrations - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func V17ToV18(ctx sdk.Context, dexkeeper keeper.Keeper) error { - // iterate over all contracts and unregister them - for _, c := range dexkeeper.GetAllContractInfo(ctx) { - if err := dexkeeper.DoUnregisterContractWithRefund(ctx, c); err != nil { - return err - } - } - // get module address - dexAddr := dexkeeper.AccountKeeper.GetModuleAddress(dextypes.ModuleName) - // send usei to the feecollector - useiCoins := dexkeeper.BankKeeper.GetBalance(ctx, dexAddr, sdk.MustGetBaseDenom()) - if err := dexkeeper.BankKeeper.SendCoinsFromModuleToModule(ctx, dextypes.ModuleName, authtypes.FeeCollectorName, sdk.NewCoins(useiCoins)); err != nil { - return err - } - // get bank balances remaining for module - balances := dexkeeper.BankKeeper.GetAllBalances(ctx, dexAddr) - // update accountkeeper to give dex burner perms - dexkeeper.CreateModuleAccount(ctx) - // burn all remaining module balances - need burner perms - if err := dexkeeper.BankKeeper.BurnCoins(ctx, dextypes.ModuleName, balances); err != nil { - return err - } - return nil -} diff --git a/x/dex/migrations/v17_to_v18_test.go b/x/dex/migrations/v17_to_v18_test.go deleted file mode 100644 index cec6d67bb5..0000000000 --- a/x/dex/migrations/v17_to_v18_test.go +++ /dev/null @@ -1,62 +0,0 @@ -package migrations_test - -import ( - "testing" - "time" - - "github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1" - sdk "github.com/cosmos/cosmos-sdk/types" - authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - "github.com/sei-protocol/sei-chain/app" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMigrate17to18(t *testing.T) { - tm := time.Now().UTC() - valPub := secp256k1.GenPrivKey().PubKey() - - testWrapper := app.NewTestWrapper(t, tm, valPub, false) - - testAddr := sdk.MustAccAddressFromBech32(keepertest.TestAccount) - - testWrapper.FundAcc(testAddr, sdk.NewCoins(sdk.NewCoin(sdk.MustGetBaseDenom(), sdk.NewInt(100000)))) - testWrapper.FundAcc(testAddr, sdk.NewCoins(sdk.NewCoin("ueth", sdk.NewInt(100)))) - - dexkeeper, ctx := testWrapper.App.DexKeeper, testWrapper.Ctx - bal := dexkeeper.BankKeeper.GetBalance(ctx, testAddr, sdk.MustGetBaseDenom()) - require.Equal(t, int64(100000), bal.Amount.Int64()) - // add contract rent - rentAmt := int64(10000) - err := dexkeeper.BankKeeper.SendCoins(ctx, testAddr, dexkeeper.AccountKeeper.GetModuleAddress(types.ModuleName), sdk.NewCoins(sdk.NewCoin(sdk.MustGetBaseDenom(), sdk.NewInt(rentAmt)))) - require.NoError(t, err) - - contract := &types.ContractInfoV2{ContractAddr: keepertest.TestContract, Creator: keepertest.TestAccount, RentBalance: uint64(rentAmt)} - err = dexkeeper.SetContract(ctx, contract) - require.NoError(t, err) - // add some balance to the module just bc - err = dexkeeper.BankKeeper.SendCoins(ctx, testAddr, dexkeeper.AccountKeeper.GetModuleAddress(types.ModuleName), sdk.NewCoins(sdk.NewCoin("ueth", sdk.NewInt(10)), sdk.NewCoin(sdk.MustGetBaseDenom(), sdk.NewInt(1000)))) - require.NoError(t, err) - - supplyUseiInitial := dexkeeper.BankKeeper.GetSupply(ctx, sdk.MustGetBaseDenom()) - - // do migration - err = migrations.V17ToV18(ctx, dexkeeper) - require.NoError(t, err) - - // user refunded rent now has 99000usei and 90ueth - bals := dexkeeper.BankKeeper.GetAllBalances(ctx, testAddr) - require.Equal(t, sdk.NewCoins(sdk.NewCoin("ueth", sdk.NewInt(90)), sdk.NewCoin(sdk.MustGetBaseDenom(), sdk.NewInt(99000))), bals) - // feecollector gets 1000usei - bals = dexkeeper.BankKeeper.GetAllBalances(ctx, dexkeeper.AccountKeeper.GetModuleAddress(authtypes.FeeCollectorName)) - require.Equal(t, sdk.NewCoins(sdk.NewCoin(sdk.MustGetBaseDenom(), sdk.NewInt(1000))), bals) - // ueth supply decreased due to burn - supply := dexkeeper.BankKeeper.GetSupply(ctx, "ueth") - require.Equal(t, sdk.NewInt(90), supply.Amount) - // usei supply unchanged - supplyUseiFinal := dexkeeper.BankKeeper.GetSupply(ctx, sdk.MustGetBaseDenom()) - require.Equal(t, supplyUseiInitial, supplyUseiFinal) - -} diff --git a/x/dex/migrations/v2_to_v3.go b/x/dex/migrations/v2_to_v3.go deleted file mode 100644 index de789df984..0000000000 --- a/x/dex/migrations/v2_to_v3.go +++ /dev/null @@ -1,35 +0,0 @@ -package migrations - -import ( - "github.com/cosmos/cosmos-sdk/codec" - sdk "github.com/cosmos/cosmos-sdk/types" -) - -/** - * No `dex` state exists in any public chain at the time this data type update happened. - * Any new chain (including local ones) should be based on a Sei version newer than this update - * and therefore doesn't need this migration - */ -func DataTypeUpdate(ctx sdk.Context, storeKey sdk.StoreKey, _ codec.BinaryCodec) error { - ClearStore(ctx, storeKey) - return nil -} - -/** - * CAUTION: this function clears up the entire `dex` module store, so it should only ever - * be used outside of a production setting. - */ -func ClearStore(ctx sdk.Context, storeKey sdk.StoreKey) { - for i := 0; i < 256; i++ { - clearStoreForByte(ctx, storeKey, byte(i)) - } -} - -func clearStoreForByte(ctx sdk.Context, storeKey sdk.StoreKey, b byte) { - store := ctx.KVStore(storeKey) - iterator := sdk.KVStorePrefixIterator(store, []byte{b}) - defer iterator.Close() - for ; iterator.Valid(); iterator.Next() { - store.Delete(iterator.Key()) - } -} diff --git a/x/dex/migrations/v3_to_v4.go b/x/dex/migrations/v3_to_v4.go deleted file mode 100644 index b7b9217fc7..0000000000 --- a/x/dex/migrations/v3_to_v4.go +++ /dev/null @@ -1,21 +0,0 @@ -package migrations - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - paramtypes "github.com/cosmos/cosmos-sdk/x/params/types" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func PriceSnapshotUpdate(ctx sdk.Context, paramStore paramtypes.Subspace) error { - err := migratePriceSnapshotParam(ctx, paramStore) - return err -} - -func migratePriceSnapshotParam(ctx sdk.Context, paramStore paramtypes.Subspace) error { - defaultParams := types.Params{ - PriceSnapshotRetention: types.DefaultPriceSnapshotRetention, - SudoCallGasPrice: types.DefaultSudoCallGasPrice, - } - paramStore.SetParamSet(ctx, &defaultParams) - return nil -} diff --git a/x/dex/migrations/v3_to_v4_test.go b/x/dex/migrations/v3_to_v4_test.go deleted file mode 100644 index 18712ba897..0000000000 --- a/x/dex/migrations/v3_to_v4_test.go +++ /dev/null @@ -1,48 +0,0 @@ -package migrations_test - -import ( - "testing" - - "github.com/cosmos/cosmos-sdk/codec" - codectypes "github.com/cosmos/cosmos-sdk/codec/types" - "github.com/cosmos/cosmos-sdk/store" - storetypes "github.com/cosmos/cosmos-sdk/store/types" - sdk "github.com/cosmos/cosmos-sdk/types" - typesparams "github.com/cosmos/cosmos-sdk/x/params/types" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" - "github.com/tendermint/tendermint/libs/log" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" - tmdb "github.com/tendermint/tm-db" -) - -func TestMigrate3to4(t *testing.T) { - storeKey := sdk.NewKVStoreKey(types.StoreKey) - memStoreKey := storetypes.NewMemoryStoreKey(types.MemStoreKey) - - db := tmdb.NewMemDB() - stateStore := store.NewCommitMultiStore(db) - stateStore.MountStoreWithDB(storeKey, sdk.StoreTypeIAVL, db) - stateStore.MountStoreWithDB(memStoreKey, sdk.StoreTypeMemory, nil) - require.NoError(t, stateStore.LoadLatestVersion()) - - registry := codectypes.NewInterfaceRegistry() - cdc := codec.NewProtoCodec(registry) - - paramsSubspace := typesparams.NewSubspace(cdc, - types.Amino, - storeKey, - memStoreKey, - "DexParams", - ) - ctx := sdk.NewContext(stateStore, tmproto.Header{}, false, log.NewNopLogger()) - if !paramsSubspace.HasKeyTable() { - paramsSubspace = paramsSubspace.WithKeyTable(types.ParamKeyTable()) - } - migrations.PriceSnapshotUpdate(ctx, paramsSubspace) - - params := types.Params{} - paramsSubspace.GetParamSet(ctx, ¶ms) - require.Equal(t, uint64(types.DefaultPriceSnapshotRetention), params.PriceSnapshotRetention) -} diff --git a/x/dex/migrations/v4_to_v5.go b/x/dex/migrations/v4_to_v5.go deleted file mode 100644 index 8e40d7da3a..0000000000 --- a/x/dex/migrations/v4_to_v5.go +++ /dev/null @@ -1,28 +0,0 @@ -package migrations - -import ( - "encoding/binary" - - sdk "github.com/cosmos/cosmos-sdk/types" - paramtypes "github.com/cosmos/cosmos-sdk/x/params/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" -) - -/** - * No `dex` state exists in any public chain at the time this data type update happened. - * Any new chain (including local ones) should be based on a Sei version newer than this update - * and therefore doesn't need this migration - */ -func V4ToV5(ctx sdk.Context, storeKey sdk.StoreKey, paramStore paramtypes.Subspace) error { - ClearStore(ctx, storeKey) - if err := migratePriceSnapshotParam(ctx, paramStore); err != nil { - return err - } - - // initialize epoch to 0 - store := ctx.KVStore(storeKey) - bz := make([]byte, 8) - binary.BigEndian.PutUint64(bz, 0) - store.Set([]byte(keeper.EpochKey), bz) - return nil -} diff --git a/x/dex/migrations/v4_to_v5_test.go b/x/dex/migrations/v4_to_v5_test.go deleted file mode 100644 index 78eaa9c0ea..0000000000 --- a/x/dex/migrations/v4_to_v5_test.go +++ /dev/null @@ -1,59 +0,0 @@ -package migrations_test - -import ( - "encoding/binary" - "testing" - - "github.com/cosmos/cosmos-sdk/codec" - codectypes "github.com/cosmos/cosmos-sdk/codec/types" - "github.com/cosmos/cosmos-sdk/store" - storetypes "github.com/cosmos/cosmos-sdk/store/types" - sdk "github.com/cosmos/cosmos-sdk/types" - typesparams "github.com/cosmos/cosmos-sdk/x/params/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" - "github.com/tendermint/tendermint/libs/log" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" - tmdb "github.com/tendermint/tm-db" -) - -func TestMigrate4to5(t *testing.T) { - storeKey := sdk.NewKVStoreKey(types.StoreKey) - memStoreKey := storetypes.NewMemoryStoreKey(types.MemStoreKey) - - db := tmdb.NewMemDB() - stateStore := store.NewCommitMultiStore(db) - stateStore.MountStoreWithDB(storeKey, sdk.StoreTypeIAVL, db) - stateStore.MountStoreWithDB(memStoreKey, sdk.StoreTypeMemory, nil) - require.NoError(t, stateStore.LoadLatestVersion()) - - registry := codectypes.NewInterfaceRegistry() - cdc := codec.NewProtoCodec(registry) - - paramsSubspace := typesparams.NewSubspace(cdc, - types.Amino, - storeKey, - memStoreKey, - "DexParams", - ) - ctx := sdk.NewContext(stateStore, tmproto.Header{}, false, log.NewNopLogger()) - if !paramsSubspace.HasKeyTable() { - paramsSubspace = paramsSubspace.WithKeyTable(types.ParamKeyTable()) - } - store := ctx.KVStore(storeKey) - store.Set([]byte("garbage key"), []byte("garbage value")) - require.True(t, store.Has([]byte("garbage key"))) - err := migrations.V4ToV5(ctx, storeKey, paramsSubspace) - require.Nil(t, err) - require.False(t, store.Has([]byte("garbage key"))) - - params := types.Params{} - paramsSubspace.GetParamSet(ctx, ¶ms) - require.Equal(t, uint64(types.DefaultPriceSnapshotRetention), params.PriceSnapshotRetention) - - epochBytes := store.Get([]byte(keeper.EpochKey)) - epoch := binary.BigEndian.Uint64(epochBytes) - require.Equal(t, uint64(0), epoch) -} diff --git a/x/dex/migrations/v5_to_v6.go b/x/dex/migrations/v5_to_v6.go deleted file mode 100644 index 870bc82e70..0000000000 --- a/x/dex/migrations/v5_to_v6.go +++ /dev/null @@ -1,57 +0,0 @@ -package migrations - -import ( - "errors" - "fmt" - - "github.com/cosmos/cosmos-sdk/codec" - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -// This migration updates contract info to match the new data format -func V5ToV6(ctx sdk.Context, storeKey sdk.StoreKey, _ codec.BinaryCodec) error { - for i := 0; i < 256; i++ { - if err := updateContractInfoForBytePrefix(ctx, storeKey, byte(i)); err != nil { - return err - } - } - return nil -} - -// assuming no dependency exists at the time of this migration -func updateContractInfoForBytePrefix(ctx sdk.Context, storeKey sdk.StoreKey, b byte) error { - store := prefix.NewStore( - ctx.KVStore(storeKey), - []byte(keeper.ContractPrefixKey), - ) - iterator := sdk.KVStorePrefixIterator(store, []byte{b}) - defer iterator.Close() - for ; iterator.Valid(); iterator.Next() { - oldContractInfoBytes := iterator.Value() - oldContractInfo := types.LegacyContractInfo{} - if err := oldContractInfo.Unmarshal(oldContractInfoBytes); err != nil { - ctx.Logger().Error(fmt.Sprintf("Failed to unmarshal contract info for %s", iterator.Key())) - return err - } - if oldContractInfo.DependentContractAddrs != nil { - ctx.Logger().Error(fmt.Sprintf("Contract info of %s has dependencies!", iterator.Key())) - return errors.New("contract has unexpected dependencies") - } - newContractInfo := types.ContractInfo{ - CodeId: oldContractInfo.CodeId, - ContractAddr: oldContractInfo.ContractAddr, - NeedHook: oldContractInfo.NeedHook, - NeedOrderMatching: oldContractInfo.NeedOrderMatching, - } - bz, err := newContractInfo.Marshal() - if err != nil { - ctx.Logger().Error(fmt.Sprintf("Failed to marshal contract info for %s", iterator.Key())) - return err - } - store.Set([]byte(newContractInfo.ContractAddr), bz) - } - return nil -} diff --git a/x/dex/migrations/v5_to_v6_test.go b/x/dex/migrations/v5_to_v6_test.go deleted file mode 100644 index 3035ec0c16..0000000000 --- a/x/dex/migrations/v5_to_v6_test.go +++ /dev/null @@ -1,79 +0,0 @@ -package migrations_test - -import ( - "testing" - - "github.com/cosmos/cosmos-sdk/codec" - codectypes "github.com/cosmos/cosmos-sdk/codec/types" - "github.com/cosmos/cosmos-sdk/store" - "github.com/cosmos/cosmos-sdk/store/prefix" - storetypes "github.com/cosmos/cosmos-sdk/store/types" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" - "github.com/tendermint/tendermint/libs/log" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" - tmdb "github.com/tendermint/tm-db" -) - -func TestMigrate5to6(t *testing.T) { - storeKey := sdk.NewKVStoreKey(types.StoreKey) - memStoreKey := storetypes.NewMemoryStoreKey(types.MemStoreKey) - - db := tmdb.NewMemDB() - stateStore := store.NewCommitMultiStore(db) - stateStore.MountStoreWithDB(storeKey, sdk.StoreTypeIAVL, db) - stateStore.MountStoreWithDB(memStoreKey, sdk.StoreTypeMemory, nil) - require.NoError(t, stateStore.LoadLatestVersion()) - - registry := codectypes.NewInterfaceRegistry() - cdc := codec.NewProtoCodec(registry) - ctx := sdk.NewContext(stateStore, tmproto.Header{}, false, log.NewNopLogger()) - store := prefix.NewStore( - ctx.KVStore(storeKey), - []byte(keeper.ContractPrefixKey), - ) - - oldContractA := types.LegacyContractInfo{ - CodeId: 1, - ContractAddr: "abc", - NeedHook: true, - NeedOrderMatching: false, - } - oldContractB := types.LegacyContractInfo{ - CodeId: 2, - ContractAddr: "def", - NeedHook: false, - NeedOrderMatching: true, - } - bzA, _ := oldContractA.Marshal() - bzB, _ := oldContractB.Marshal() - store.Set([]byte("abc"), bzA) - store.Set([]byte("def"), bzB) - - err := migrations.V5ToV6(ctx, storeKey, cdc) - require.Nil(t, err) - - newBzA := store.Get([]byte("abc")) - newBzB := store.Get([]byte("def")) - newContractA := types.ContractInfo{} - newContractB := types.ContractInfo{} - err = newContractA.Unmarshal(newBzA) - require.Nil(t, err) - err = newContractB.Unmarshal(newBzB) - require.Nil(t, err) - require.Equal(t, types.ContractInfo{ - CodeId: 1, - ContractAddr: "abc", - NeedHook: true, - NeedOrderMatching: false, - }, newContractA) - require.Equal(t, types.ContractInfo{ - CodeId: 2, - ContractAddr: "def", - NeedHook: false, - NeedOrderMatching: true, - }, newContractB) -} diff --git a/x/dex/migrations/v6_to_v7.go b/x/dex/migrations/v6_to_v7.go deleted file mode 100644 index c7df17849f..0000000000 --- a/x/dex/migrations/v6_to_v7.go +++ /dev/null @@ -1,84 +0,0 @@ -package migrations - -import ( - "encoding/binary" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func V6ToV7(ctx sdk.Context, storeKey sdk.StoreKey) error { - backfillOrderIDPerContract(ctx, storeKey) - reformatPriceState(ctx, storeKey) - return nil -} - -// this function backfills contract order ID according to the old global order ID -func backfillOrderIDPerContract(ctx sdk.Context, storeKey sdk.StoreKey) { - oldStore := prefix.NewStore( - ctx.KVStore(storeKey), - []byte{}, - ) - oldKey := types.KeyPrefix(types.NextOrderIDKey) - oldIDBytes := oldStore.Get(oldKey) - if oldIDBytes == nil { - // nothing to backfill - return - } - oldID := binary.BigEndian.Uint64(oldIDBytes) - - contractStore := prefix.NewStore(ctx.KVStore(storeKey), []byte(keeper.ContractPrefixKey)) - iterator := sdk.KVStorePrefixIterator(contractStore, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - contract := types.ContractInfo{} - if err := contract.Unmarshal(iterator.Value()); err == nil { - if contract.NeedOrderMatching { - newIDStore := prefix.NewStore(ctx.KVStore(storeKey), types.NextOrderIDPrefix(contract.ContractAddr)) - byteKey := types.KeyPrefix(types.NextOrderIDKey) - bz := make([]byte, 8) - binary.BigEndian.PutUint64(bz, oldID) - newIDStore.Set(byteKey, bz) - } - } - } -} - -func reformatPriceState(ctx sdk.Context, storeKey sdk.StoreKey) { - contractStore := prefix.NewStore(ctx.KVStore(storeKey), []byte(keeper.ContractPrefixKey)) - iterator := sdk.KVStorePrefixIterator(contractStore, []byte{}) - - defer iterator.Close() - - for ; iterator.Valid(); iterator.Next() { - contract := types.ContractInfo{} - if err := contract.Unmarshal(iterator.Value()); err == nil { - pairStore := prefix.NewStore(ctx.KVStore(storeKey), types.RegisteredPairPrefix(contract.ContractAddr)) - pairIterator := sdk.KVStorePrefixIterator(pairStore, []byte{}) - for ; pairIterator.Valid(); pairIterator.Next() { - pair := types.Pair{} - if err := pair.Unmarshal(pairIterator.Value()); err == nil { - oldPriceStore := prefix.NewStore(ctx.KVStore(storeKey), append( - append( - append(types.KeyPrefix(types.PriceKey), types.KeyPrefix(contract.ContractAddr)...), - types.KeyPrefix(pair.PriceDenom)..., - ), - types.KeyPrefix(pair.AssetDenom)..., - )) - newPriceStore := prefix.NewStore(ctx.KVStore(storeKey), types.PricePrefix(contract.ContractAddr, pair.PriceDenom, pair.AssetDenom)) - oldPriceIterator := sdk.KVStorePrefixIterator(oldPriceStore, []byte{}) - for ; oldPriceIterator.Valid(); oldPriceIterator.Next() { - newPriceStore.Set(oldPriceIterator.Key(), oldPriceIterator.Value()) - } - oldPriceIterator.Close() - } - } - - pairIterator.Close() - } - } -} diff --git a/x/dex/migrations/v6_to_v7_test.go b/x/dex/migrations/v6_to_v7_test.go deleted file mode 100644 index e00f9adbce..0000000000 --- a/x/dex/migrations/v6_to_v7_test.go +++ /dev/null @@ -1,89 +0,0 @@ -package migrations_test - -import ( - "encoding/binary" - "testing" - - "github.com/cosmos/cosmos-sdk/store" - "github.com/cosmos/cosmos-sdk/store/prefix" - storetypes "github.com/cosmos/cosmos-sdk/store/types" - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" - "github.com/tendermint/tendermint/libs/log" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" - tmdb "github.com/tendermint/tm-db" -) - -func TestMigrate6to7(t *testing.T) { - storeKey := sdk.NewKVStoreKey(types.StoreKey) - memStoreKey := storetypes.NewMemoryStoreKey(types.MemStoreKey) - - db := tmdb.NewMemDB() - stateStore := store.NewCommitMultiStore(db) - stateStore.MountStoreWithDB(storeKey, sdk.StoreTypeIAVL, db) - stateStore.MountStoreWithDB(memStoreKey, sdk.StoreTypeMemory, nil) - require.NoError(t, stateStore.LoadLatestVersion()) - - ctx := sdk.NewContext(stateStore, tmproto.Header{}, false, log.NewNopLogger()) - - // write old order ID - store := prefix.NewStore(ctx.KVStore(storeKey), []byte{}) - oldID := make([]byte, 8) - binary.BigEndian.PutUint64(oldID, 10) - store.Set(types.KeyPrefix(types.NextOrderIDKey), oldID) - - // write old price state - store = prefix.NewStore(ctx.KVStore(storeKey), append( - append( - append(types.KeyPrefix(types.PriceKey), types.KeyPrefix(keepertest.TestContract)...), - types.KeyPrefix(keepertest.TestPriceDenom)..., - ), - types.KeyPrefix(keepertest.TestAssetDenom)...), - ) - - price := types.Price{ - SnapshotTimestampInSeconds: 5, - Price: sdk.MustNewDecFromStr("123.4"), - Pair: &keepertest.TestPair, - } - priceBytes, _ := price.Marshal() - store.Set(keeper.GetKeyForTs(price.SnapshotTimestampInSeconds), priceBytes) - - // register contract / pair - store = prefix.NewStore( - ctx.KVStore(storeKey), - []byte(keeper.ContractPrefixKey), - ) - contract := types.ContractInfo{ - CodeId: 1, - ContractAddr: keepertest.TestContract, - NeedOrderMatching: true, - } - contractBytes, _ := contract.Marshal() - store.Set([]byte(contract.ContractAddr), contractBytes) - - store = prefix.NewStore(ctx.KVStore(storeKey), types.RegisteredPairPrefix(keepertest.TestContract)) - keyBytes := make([]byte, 8) - binary.BigEndian.PutUint64(keyBytes, 0) - pairBytes, _ := keepertest.TestPair.Marshal() - store.Set(keyBytes, pairBytes) - - err := migrations.V6ToV7(ctx, storeKey) - require.Nil(t, err) - - store = prefix.NewStore(ctx.KVStore(storeKey), types.NextOrderIDPrefix(keepertest.TestContract)) - byteKey := types.KeyPrefix(types.NextOrderIDKey) - bz := store.Get(byteKey) - require.Equal(t, uint64(10), binary.BigEndian.Uint64(bz)) - - store = prefix.NewStore(ctx.KVStore(storeKey), types.PricePrefix(keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom)) - key := keeper.GetKeyForTs(5) - priceRes := types.Price{} - b := store.Get(key) - _ = priceRes.Unmarshal(b) - require.Equal(t, price, priceRes) -} diff --git a/x/dex/migrations/v7_to_v8.go b/x/dex/migrations/v7_to_v8.go deleted file mode 100644 index 26914ff4d2..0000000000 --- a/x/dex/migrations/v7_to_v8.go +++ /dev/null @@ -1,101 +0,0 @@ -package migrations - -import ( - "encoding/binary" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func V7ToV8(ctx sdk.Context, storeKey sdk.StoreKey) error { - return flattenSettlements(ctx, storeKey) -} - -func flattenSettlements(ctx sdk.Context, storeKey sdk.StoreKey) error { - contractStore := prefix.NewStore(ctx.KVStore(storeKey), []byte(keeper.ContractPrefixKey)) - iterator := sdk.KVStorePrefixIterator(contractStore, []byte{}) - - defer iterator.Close() - for ; iterator.Valid(); iterator.Next() { - contract := types.ContractInfo{} - if err := contract.Unmarshal(iterator.Value()); err != nil { - return err - } - pairStore := prefix.NewStore(ctx.KVStore(storeKey), types.RegisteredPairPrefix(contract.ContractAddr)) - pairIterator := sdk.KVStorePrefixIterator(pairStore, []byte{}) - for ; pairIterator.Valid(); pairIterator.Next() { - pair := types.Pair{} - if err := pair.Unmarshal(pairIterator.Value()); err != nil { - pairIterator.Close() - return err - } - settlementStore := prefix.NewStore( - ctx.KVStore(storeKey), - SettlementEntryPrefix(contract.ContractAddr, pair.PriceDenom, pair.AssetDenom), - ) - settlementIterator := sdk.KVStorePrefixIterator(settlementStore, []byte{}) - - oldKeys := [][]byte{} - newKeys := [][]byte{} - newVals := [][]byte{} - for ; settlementIterator.Valid(); settlementIterator.Next() { - var val types.Settlements - if err := val.Unmarshal(settlementIterator.Value()); err != nil { - pairIterator.Close() - settlementIterator.Close() - return err - } - for i, settlementEntry := range val.Entries { - settlementBytes, err := settlementEntry.Marshal() - if err != nil { - pairIterator.Close() - settlementIterator.Close() - return err - } - newKeys = append(newKeys, types.GetSettlementKey(settlementEntry.OrderId, settlementEntry.Account, uint64(i))) - newVals = append(newVals, settlementBytes) - } - - if len(val.Entries) > 0 { - settlementIDStore := prefix.NewStore( - ctx.KVStore(storeKey), - NextSettlementIDPrefix(contract.ContractAddr, pair.PriceDenom, pair.AssetDenom), - ) - key := make([]byte, 8) - binary.BigEndian.PutUint64(key, val.Entries[0].OrderId) - value := make([]byte, 8) - binary.BigEndian.PutUint64(value, uint64(len(val.Entries))) - settlementIDStore.Set(key, value) - } - oldKeys = append(oldKeys, settlementIterator.Key()) - } - - settlementIterator.Close() - - for _, oldKey := range oldKeys { - settlementStore.Delete(oldKey) - } - for i, newKey := range newKeys { - settlementStore.Set(newKey, newVals[i]) - } - } - pairIterator.Close() - } - return nil -} - -func SettlementEntryPrefix(contractAddr string, priceDenom string, assetDenom string) []byte { - return append( - append(types.KeyPrefix("SettlementEntry-"), types.AddressKeyPrefix(contractAddr)...), - types.PairPrefix(priceDenom, assetDenom)..., - ) -} - -func NextSettlementIDPrefix(contractAddr string, priceDenom string, assetDenom string) []byte { - return append( - append(types.KeyPrefix("NextSettlementID-"), types.AddressKeyPrefix(contractAddr)...), - types.PairPrefix(priceDenom, assetDenom)..., - ) -} diff --git a/x/dex/migrations/v7_to_v8_test.go b/x/dex/migrations/v7_to_v8_test.go deleted file mode 100644 index 5960ff7e79..0000000000 --- a/x/dex/migrations/v7_to_v8_test.go +++ /dev/null @@ -1,98 +0,0 @@ -package migrations_test - -import ( - "encoding/binary" - "testing" - - "github.com/cosmos/cosmos-sdk/store" - "github.com/cosmos/cosmos-sdk/store/prefix" - storetypes "github.com/cosmos/cosmos-sdk/store/types" - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" - "github.com/tendermint/tendermint/libs/log" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" - tmdb "github.com/tendermint/tm-db" -) - -func TestMigrate7to8(t *testing.T) { - storeKey := sdk.NewKVStoreKey(types.StoreKey) - memStoreKey := storetypes.NewMemoryStoreKey(types.MemStoreKey) - - db := tmdb.NewMemDB() - stateStore := store.NewCommitMultiStore(db) - stateStore.MountStoreWithDB(storeKey, sdk.StoreTypeIAVL, db) - stateStore.MountStoreWithDB(memStoreKey, sdk.StoreTypeMemory, nil) - require.NoError(t, stateStore.LoadLatestVersion()) - - ctx := sdk.NewContext(stateStore, tmproto.Header{}, false, log.NewNopLogger()) - - // write old settlements - store := prefix.NewStore( - ctx.KVStore(storeKey), - migrations.SettlementEntryPrefix(keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom), - ) - settlements := types.Settlements{ - Entries: []*types.SettlementEntry{ - { - Account: keepertest.TestAccount, - OrderId: 1, - Quantity: sdk.MustNewDecFromStr("0.3"), - }, - { - Account: keepertest.TestAccount, - OrderId: 1, - Quantity: sdk.MustNewDecFromStr("0.7"), - }, - }, - } - bz, _ := settlements.Marshal() - store.Set(types.GetSettlementOrderIDPrefix(1, keepertest.TestAccount), bz) - - // register contract / pair - store = prefix.NewStore( - ctx.KVStore(storeKey), - []byte(keeper.ContractPrefixKey), - ) - contract := types.ContractInfo{ - CodeId: 1, - ContractAddr: keepertest.TestContract, - NeedOrderMatching: true, - } - contractBytes, _ := contract.Marshal() - store.Set([]byte(contract.ContractAddr), contractBytes) - - store = prefix.NewStore(ctx.KVStore(storeKey), types.RegisteredPairPrefix(keepertest.TestContract)) - keyBytes := make([]byte, 8) - binary.BigEndian.PutUint64(keyBytes, 0) - pairBytes, _ := keepertest.TestPair.Marshal() - store.Set(keyBytes, pairBytes) - - err := migrations.V7ToV8(ctx, storeKey) - require.Nil(t, err) - - store = prefix.NewStore( - ctx.KVStore(storeKey), - migrations.SettlementEntryPrefix(keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom), - ) - settlementEntry1Key := types.GetSettlementKey(1, keepertest.TestAccount, 0) - settlementEntry1 := types.SettlementEntry{} - settlementEntry1Bytes := store.Get(settlementEntry1Key) - _ = settlementEntry1.Unmarshal(settlementEntry1Bytes) - require.Equal(t, sdk.MustNewDecFromStr("0.3"), settlementEntry1.Quantity) - settlementEntry2Key := types.GetSettlementKey(1, keepertest.TestAccount, 1) - settlementEntry2 := types.SettlementEntry{} - settlementEntry2Bytes := store.Get(settlementEntry2Key) - _ = settlementEntry2.Unmarshal(settlementEntry2Bytes) - require.Equal(t, sdk.MustNewDecFromStr("0.7"), settlementEntry2.Quantity) - - require.False(t, store.Has(types.GetSettlementOrderIDPrefix(1, keepertest.TestAccount))) - - store = prefix.NewStore(ctx.KVStore(storeKey), migrations.NextSettlementIDPrefix(keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom)) - key := make([]byte, 8) - binary.BigEndian.PutUint64(key, uint64(1)) - require.Equal(t, uint64(2), binary.BigEndian.Uint64(store.Get(key))) -} diff --git a/x/dex/migrations/v8_to_v9.go b/x/dex/migrations/v8_to_v9.go deleted file mode 100644 index cb0e6095d3..0000000000 --- a/x/dex/migrations/v8_to_v9.go +++ /dev/null @@ -1,38 +0,0 @@ -package migrations - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -func V8ToV9(ctx sdk.Context, dexkeeper keeper.Keeper) error { - dexkeeper.CreateModuleAccount(ctx) - - contractStore := prefix.NewStore(ctx.KVStore(dexkeeper.GetStoreKey()), []byte(keeper.ContractPrefixKey)) - iterator := sdk.KVStorePrefixIterator(contractStore, []byte{}) - - defer iterator.Close() - for ; iterator.Valid(); iterator.Next() { - contract := types.ContractInfo{} - if err := contract.Unmarshal(iterator.Value()); err != nil { - return err - } - contractV2 := types.ContractInfoV2{ - CodeId: contract.CodeId, - ContractAddr: contract.ContractAddr, - NeedHook: contract.NeedHook, - NeedOrderMatching: contract.NeedOrderMatching, - Dependencies: contract.Dependencies, - NumIncomingDependencies: contract.NumIncomingDependencies, - } - bz, err := contractV2.Marshal() - if err != nil { - return err - } - contractStore.Set(iterator.Key(), bz) - } - - return nil -} diff --git a/x/dex/migrations/v8_to_v9_test.go b/x/dex/migrations/v8_to_v9_test.go deleted file mode 100644 index c1b87b3d6c..0000000000 --- a/x/dex/migrations/v8_to_v9_test.go +++ /dev/null @@ -1,42 +0,0 @@ -package migrations_test - -import ( - "testing" - - "github.com/cosmos/cosmos-sdk/store/prefix" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMigrate8to9(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - // write old contract - store := prefix.NewStore( - ctx.KVStore(dexkeeper.GetStoreKey()), - []byte(keeper.ContractPrefixKey), - ) - contract := types.ContractInfo{ - CodeId: 1, - ContractAddr: keepertest.TestContract, - NeedOrderMatching: true, - } - contractBytes, _ := contract.Marshal() - store.Set(types.ContractKey(contract.ContractAddr), contractBytes) - - err := migrations.V8ToV9(ctx, *dexkeeper) - require.NoError(t, err) - - contractV2, err := dexkeeper.GetContract(ctx, keepertest.TestContract) - require.NoError(t, err) - require.Equal(t, types.ContractInfoV2{ - CodeId: 1, - ContractAddr: keepertest.TestContract, - NeedOrderMatching: true, - }, contractV2) - - moduleAccount := dexkeeper.AccountKeeper.GetModuleAccount(ctx, types.ModuleName) - require.NotNil(t, moduleAccount) -} diff --git a/x/dex/migrations/v9_to_v10.go b/x/dex/migrations/v9_to_v10.go deleted file mode 100644 index c8484d9b17..0000000000 --- a/x/dex/migrations/v9_to_v10.go +++ /dev/null @@ -1,91 +0,0 @@ -package migrations - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -const PriceTickSizeKey = "ticks" -const QuantityTickSizeKey = "quantityticks" -const RegisteredPairCount = "rpcnt" - -// This migration deprecates the tick size store keys and registered pair count store keys. -// It also refactors the registered pair store to use pair denoms for key construction -// instead of index based key construction. -func V9ToV10(ctx sdk.Context, dexkeeper keeper.Keeper) error { - dexkeeper.CreateModuleAccount(ctx) - store := ctx.KVStore(dexkeeper.GetStoreKey()) - - rpIterator := sdk.KVStorePrefixIterator(store, []byte(types.RegisteredPairKey)) - - rpcntByte := []byte(RegisteredPairCount) - defer rpIterator.Close() - for ; rpIterator.Valid(); rpIterator.Next() { - // need to skip anything that has rpcnt in the key prefix - if string(rpIterator.Key()[:len(rpcntByte)]) == RegisteredPairCount { - continue - } - var registeredPair types.Pair - b := rpIterator.Value() - err := registeredPair.Unmarshal(b) - if err != nil { - return err - } - // this key is the contractAddress + index - rpKey := rpIterator.Key() - // remove first 2 bytes for prefix and last 8 bytes since that is the index - rpContractKey := rpKey[2 : len(rpKey)-8] - // get pair prefix used for indexing - pairPrefix := types.PairPrefix(registeredPair.PriceDenom, registeredPair.AssetDenom) - - // set the price and quantity ticks from the appropriate store - priceTickStore := prefix.NewStore(store, append([]byte(PriceTickSizeKey), rpContractKey...)) - priceTickSize := sdk.Dec{} - b = priceTickStore.Get(pairPrefix) - err = priceTickSize.Unmarshal(b) - if err != nil { - return err - } - registeredPair.PriceTicksize = &priceTickSize - - quantityTickStore := prefix.NewStore(store, append([]byte(QuantityTickSizeKey), rpContractKey...)) - quantityTickSize := sdk.Dec{} - b = quantityTickStore.Get(pairPrefix) - err = quantityTickSize.Unmarshal(b) - if err != nil { - return err - } - registeredPair.QuantityTicksize = &quantityTickSize - - // delete the old store value - rpStore := prefix.NewStore(store, append([]byte(types.RegisteredPairKey), rpContractKey...)) - rpStore.Delete(rpKey) - // updated registered pair, now we need to set it to the correct store value - writeBytes := dexkeeper.Cdc.MustMarshal(®isteredPair) - rpStore.Set(pairPrefix, writeBytes) - } - - // delete rpcnt - rpcIterator := sdk.KVStorePrefixIterator(store, []byte(RegisteredPairCount)) - defer rpcIterator.Close() - for ; rpcIterator.Valid(); rpcIterator.Next() { - store.Delete(rpcIterator.Key()) - } - - // delete price Ticks - priceTickIterator := sdk.KVStorePrefixIterator(store, []byte(PriceTickSizeKey)) - defer priceTickIterator.Close() - for ; priceTickIterator.Valid(); priceTickIterator.Next() { - store.Delete(priceTickIterator.Key()) - } - - // delete quantityTicks - quantityTickIterator := sdk.KVStorePrefixIterator(store, []byte(QuantityTickSizeKey)) - defer quantityTickIterator.Close() - for ; quantityTickIterator.Valid(); quantityTickIterator.Next() { - store.Delete(quantityTickIterator.Key()) - } - return nil -} diff --git a/x/dex/migrations/v9_to_v10_test.go b/x/dex/migrations/v9_to_v10_test.go deleted file mode 100644 index 27f6406a85..0000000000 --- a/x/dex/migrations/v9_to_v10_test.go +++ /dev/null @@ -1,94 +0,0 @@ -package migrations_test - -import ( - "encoding/binary" - "testing" - - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - sdkaddress "github.com/cosmos/cosmos-sdk/types/address" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMigrate9to10(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - // write old contract - dexStore := ctx.KVStore(dexkeeper.GetStoreKey()) - rpStore := prefix.NewStore( - dexStore, - []byte(types.RegisteredPairKey), - ) - priceTickSize := sdk.MustNewDecFromStr("0.0001") - quantityTickSize := sdk.MustNewDecFromStr("0.0001") - pair := types.Pair{ - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - PriceTicksize: &priceTickSize, - QuantityTicksize: &quantityTickSize, - } - pairPrefix := types.PairPrefix(keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom) - - pairBytes := dexkeeper.Cdc.MustMarshal(&pair) - countBytes := make([]byte, 8) - binary.BigEndian.PutUint64(countBytes, 1) - // simulate legacy store where registered pairs are indexed by auto increment count - address, _ := sdk.AccAddressFromBech32(keepertest.TestContract) - address = sdkaddress.MustLengthPrefix(address) - rpStore.Set(append(address, countBytes...), pairBytes) - - bytes := rpStore.Get(append(address, countBytes...)) - require.Equal(t, pairBytes, bytes) - - // set count, ticksize, and quantity size - newCountBytes := make([]byte, 8) - binary.BigEndian.PutUint64(newCountBytes, 2) - dexStore.Set( - append([]byte(migrations.RegisteredPairCount), address...), - newCountBytes, - ) - - tickBytes, _ := sdk.MustNewDecFromStr("0.0002").Marshal() - dexStore.Set( - append(append([]byte(migrations.PriceTickSizeKey), address...), pairPrefix...), - tickBytes, - ) - - dexStore.Set( - append(append([]byte(migrations.QuantityTickSizeKey), address...), pairPrefix...), - tickBytes, - ) - - err := migrations.V9ToV10(ctx, *dexkeeper) - require.NoError(t, err) - - pair, found := dexkeeper.GetRegisteredPair(ctx, keepertest.TestContract, keepertest.TestPair.PriceDenom, keepertest.TestPair.AssetDenom) - require.True(t, found) - newTickSize := sdk.MustNewDecFromStr("0.0002") - require.Equal(t, types.Pair{ - PriceDenom: keepertest.TestPair.PriceDenom, - AssetDenom: keepertest.TestPair.AssetDenom, - PriceTicksize: &newTickSize, - QuantityTicksize: &newTickSize, - }, pair) - - // verify old/deprecated keeper store data is removed - require.False( - t, - dexStore.Has(append(address, countBytes...)), - ) - require.False( - t, - dexStore.Has(append([]byte(migrations.RegisteredPairCount), address...)), - ) - require.False( - t, - dexStore.Has(append(append([]byte(migrations.PriceTickSizeKey), address...), pairPrefix...)), - ) - require.False( - t, - dexStore.Has(append(append([]byte(migrations.QuantityTickSizeKey), address...), pairPrefix...)), - ) -} diff --git a/x/dex/module.go b/x/dex/module.go deleted file mode 100644 index 966699406e..0000000000 --- a/x/dex/module.go +++ /dev/null @@ -1,362 +0,0 @@ -package dex - -import ( - "context" - "encoding/json" - "fmt" - "sync" - "time" - - "github.com/CosmWasm/wasmd/x/wasm" - "github.com/cosmos/cosmos-sdk/store/prefix" - "github.com/cosmos/cosmos-sdk/telemetry" - "github.com/gorilla/mux" - "github.com/grpc-ecosystem/grpc-gateway/runtime" - "github.com/spf13/cobra" - abci "github.com/tendermint/tendermint/abci/types" - - "github.com/cosmos/cosmos-sdk/client" - "github.com/cosmos/cosmos-sdk/codec" - cdctypes "github.com/cosmos/cosmos-sdk/codec/types" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/types/module" - "github.com/cosmos/cosmos-sdk/utils/tracing" - "github.com/sei-protocol/sei-chain/utils" - "github.com/sei-protocol/sei-chain/utils/datastructures" - "github.com/sei-protocol/sei-chain/x/dex/client/cli/query" - "github.com/sei-protocol/sei-chain/x/dex/client/cli/tx" - "github.com/sei-protocol/sei-chain/x/dex/contract" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - dexkeeperabci "github.com/sei-protocol/sei-chain/x/dex/keeper/abci" - "github.com/sei-protocol/sei-chain/x/dex/keeper/msgserver" - dexkeeperquery "github.com/sei-protocol/sei-chain/x/dex/keeper/query" - "github.com/sei-protocol/sei-chain/x/dex/migrations" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - "github.com/sei-protocol/sei-chain/x/store" -) - -var ( - _ module.AppModule = AppModule{} - _ module.AppModuleBasic = AppModuleBasic{} -) - -// ---------------------------------------------------------------------------- -// AppModuleBasic -// ---------------------------------------------------------------------------- - -// AppModuleBasic implements the AppModuleBasic interface for the capability module. -type AppModuleBasic struct { - cdc codec.BinaryCodec -} - -func NewAppModuleBasic(cdc codec.BinaryCodec) AppModuleBasic { - return AppModuleBasic{cdc: cdc} -} - -// Name returns the capability module's name. -func (AppModuleBasic) Name() string { - return types.ModuleName -} - -func (AppModuleBasic) RegisterCodec(cdc *codec.LegacyAmino) { - types.RegisterCodec(cdc) -} - -func (AppModuleBasic) RegisterLegacyAminoCodec(cdc *codec.LegacyAmino) { - types.RegisterCodec(cdc) -} - -// RegisterInterfaces registers the module's interface types -func (a AppModuleBasic) RegisterInterfaces(reg cdctypes.InterfaceRegistry) { - types.RegisterInterfaces(reg) -} - -// DefaultGenesis returns the capability module's default genesis state. -func (AppModuleBasic) DefaultGenesis(cdc codec.JSONCodec) json.RawMessage { - return cdc.MustMarshalJSON(types.DefaultGenesis()) -} - -// ValidateGenesis performs genesis state validation for the capability module. -func (AppModuleBasic) ValidateGenesis(cdc codec.JSONCodec, _ client.TxEncodingConfig, bz json.RawMessage) error { - var genState types.GenesisState - if err := cdc.UnmarshalJSON(bz, &genState); err != nil { - return fmt.Errorf("failed to unmarshal %s genesis state: %w", types.ModuleName, err) - } - return genState.Validate() -} - -// RegisterRESTRoutes registers the capability module's REST service handlers. -func (AppModuleBasic) RegisterRESTRoutes(_ client.Context, _ *mux.Router) { -} - -// RegisterGRPCGatewayRoutes registers the gRPC Gateway routes for the module. -func (AppModuleBasic) RegisterGRPCGatewayRoutes(clientCtx client.Context, mux *runtime.ServeMux) { - types.RegisterQueryHandlerClient(context.Background(), mux, types.NewQueryClient(clientCtx)) //nolint:errcheck // this is inside a module, and the method doesn't return error. Leave it alone. -} - -// GetTxCmd returns the capability module's root tx command. -func (a AppModuleBasic) GetTxCmd() *cobra.Command { - return tx.GetTxCmd() -} - -// GetQueryCmd returns the capability module's root query command. -func (AppModuleBasic) GetQueryCmd() *cobra.Command { - return query.GetQueryCmd() -} - -// ---------------------------------------------------------------------------- -// AppModule -// ---------------------------------------------------------------------------- - -// AppModule implements the AppModule interface for the capability module. -type AppModule struct { - AppModuleBasic - - keeper keeper.Keeper - accountKeeper types.AccountKeeper - bankKeeper types.BankKeeper - wasmKeeper wasm.Keeper - - abciWrapper dexkeeperabci.KeeperWrapper - - tracingInfo *tracing.Info -} - -func NewAppModule( - cdc codec.Codec, - keeper keeper.Keeper, - accountKeeper types.AccountKeeper, - bankKeeper types.BankKeeper, - wasmKeeper wasm.Keeper, - tracingInfo *tracing.Info, -) AppModule { - return AppModule{ - AppModuleBasic: NewAppModuleBasic(cdc), - keeper: keeper, - accountKeeper: accountKeeper, - bankKeeper: bankKeeper, - wasmKeeper: wasmKeeper, - abciWrapper: dexkeeperabci.KeeperWrapper{Keeper: &keeper}, - tracingInfo: tracingInfo, - } -} - -// Name returns the capability module's name. -func (am AppModule) Name() string { - return am.AppModuleBasic.Name() -} - -// Route returns the capability module's message routing key. -func (am AppModule) Route() sdk.Route { - return sdk.NewRoute(types.RouterKey, NewHandler(am.keeper)) -} - -// QuerierRoute returns the capability module's query routing key. -func (AppModule) QuerierRoute() string { return types.QuerierRoute } - -// LegacyQuerierHandler returns the capability module's Querier. -func (am AppModule) LegacyQuerierHandler(_ *codec.LegacyAmino) sdk.Querier { - return nil -} - -// RegisterServices registers a GRPC query service to respond to the -// module-specific GRPC queries. -func (am AppModule) RegisterServices(cfg module.Configurator) { - types.RegisterMsgServer(cfg.MsgServer(), msgserver.NewMsgServerImpl(am.keeper)) - types.RegisterQueryServer(cfg.QueryServer(), dexkeeperquery.KeeperWrapper{Keeper: &am.keeper}) - - _ = cfg.RegisterMigration(types.ModuleName, 1, func(ctx sdk.Context) error { return nil }) - _ = cfg.RegisterMigration(types.ModuleName, 2, func(ctx sdk.Context) error { - return migrations.DataTypeUpdate(ctx, am.keeper.GetStoreKey(), am.keeper.Cdc) - }) - _ = cfg.RegisterMigration(types.ModuleName, 3, func(ctx sdk.Context) error { - return migrations.PriceSnapshotUpdate(ctx, am.keeper.Paramstore) - }) - _ = cfg.RegisterMigration(types.ModuleName, 4, func(ctx sdk.Context) error { - return migrations.V4ToV5(ctx, am.keeper.GetStoreKey(), am.keeper.Paramstore) - }) - _ = cfg.RegisterMigration(types.ModuleName, 5, func(ctx sdk.Context) error { - return migrations.V5ToV6(ctx, am.keeper.GetStoreKey(), am.keeper.Cdc) - }) - _ = cfg.RegisterMigration(types.ModuleName, 6, func(ctx sdk.Context) error { - return migrations.V6ToV7(ctx, am.keeper.GetStoreKey()) - }) - _ = cfg.RegisterMigration(types.ModuleName, 7, func(ctx sdk.Context) error { - return migrations.V7ToV8(ctx, am.keeper.GetStoreKey()) - }) - _ = cfg.RegisterMigration(types.ModuleName, 8, func(ctx sdk.Context) error { - return migrations.V8ToV9(ctx, am.keeper) - }) - _ = cfg.RegisterMigration(types.ModuleName, 9, func(ctx sdk.Context) error { - return migrations.V9ToV10(ctx, am.keeper) - }) - _ = cfg.RegisterMigration(types.ModuleName, 10, func(ctx sdk.Context) error { - return migrations.V10ToV11(ctx, am.keeper) - }) - _ = cfg.RegisterMigration(types.ModuleName, 11, func(ctx sdk.Context) error { - return migrations.V11ToV12(ctx, am.keeper) - }) - _ = cfg.RegisterMigration(types.ModuleName, 12, func(ctx sdk.Context) error { - return migrations.V12ToV13(ctx, am.keeper) - }) - _ = cfg.RegisterMigration(types.ModuleName, 13, func(ctx sdk.Context) error { - return migrations.V13ToV14(ctx, am.keeper) - }) - _ = cfg.RegisterMigration(types.ModuleName, 14, func(ctx sdk.Context) error { - return migrations.V14ToV15(ctx, am.keeper) - }) - _ = cfg.RegisterMigration(types.ModuleName, 15, func(ctx sdk.Context) error { - return migrations.V15ToV16(ctx, am.keeper) - }) - _ = cfg.RegisterMigration(types.ModuleName, 16, func(ctx sdk.Context) error { - return nil - }) - _ = cfg.RegisterMigration(types.ModuleName, 17, func(ctx sdk.Context) error { - return migrations.V17ToV18(ctx, am.keeper) - }) -} - -// RegisterInvariants registers the capability module's invariants. -func (am AppModule) RegisterInvariants(_ sdk.InvariantRegistry) {} - -// InitGenesis performs the capability module's genesis initialization It returns -// no validator updates. -func (am AppModule) InitGenesis(ctx sdk.Context, cdc codec.JSONCodec, gs json.RawMessage) []abci.ValidatorUpdate { - var genState types.GenesisState - // Initialize global index to index in genesis state - cdc.MustUnmarshalJSON(gs, &genState) - - InitGenesis(ctx, am.keeper, genState) - - return []abci.ValidatorUpdate{} -} - -// ExportGenesis returns the capability module's exported genesis state as raw JSON bytes. -func (am AppModule) ExportGenesis(ctx sdk.Context, cdc codec.JSONCodec) json.RawMessage { - genState := ExportGenesis(ctx, am.keeper) - return cdc.MustMarshalJSON(genState) -} - -// ConsensusVersion implements ConsensusVersion. -func (AppModule) ConsensusVersion() uint64 { return 18 } - -// BeginBlock executes all ABCI BeginBlock logic respective to the capability module. -func (am AppModule) BeginBlock(ctx sdk.Context, _ abci.RequestBeginBlock) { - defer func() { - _, span := am.tracingInfo.Start("DexBeginBlockRollback") - defer span.End() - }() - - dexutils.GetMemState(ctx.Context()).Clear(ctx) - isNewEpoch, currentEpoch := am.keeper.IsNewEpoch(ctx) - if isNewEpoch { - am.keeper.SetEpoch(ctx, currentEpoch) - } - cachedCtx, cachedStore := store.GetCachedContext(ctx) - priceRetention := am.keeper.GetParams(ctx).PriceSnapshotRetention - cutOffTime := uint64(ctx.BlockTime().Unix()) - priceRetention - wg := sync.WaitGroup{} - mutex := sync.Mutex{} - allContracts := am.keeper.GetAllProcessableContractInfo(ctx) - allPricesToDelete := make(map[string][]*types.PriceStore, len(allContracts)) - - // Parallelize the logic to find all prices to delete - for _, contract := range allContracts { - wg.Add(1) - go func(contract types.ContractInfoV2) { - priceKeysToDelete := am.getPriceToDelete(cachedCtx, contract, cutOffTime) - mutex.Lock() - allPricesToDelete[contract.ContractAddr] = priceKeysToDelete - mutex.Unlock() - wg.Done() - }(contract) - } - wg.Wait() - - // Execute the deletion in order - for _, contract := range allContracts { - if priceStores, found := allPricesToDelete[contract.ContractAddr]; found { - for _, priceStore := range priceStores { - for _, key := range priceStore.PriceKeys { - priceStore.Store.Delete(key) - } - } - } - } - // only write if all contracts have been processed - cachedStore.Write() -} - -func (am AppModule) getPriceToDelete( - ctx sdk.Context, - contract types.ContractInfoV2, - timestamp uint64, -) []*types.PriceStore { - var result []*types.PriceStore - if contract.NeedOrderMatching { - for _, pair := range am.keeper.GetAllRegisteredPairs(ctx, contract.ContractAddr) { - store := prefix.NewStore(ctx.KVStore(am.keeper.GetStoreKey()), types.PricePrefix(contract.ContractAddr, pair.PriceDenom, pair.AssetDenom)) - keysToDelete := am.keeper.GetPriceKeysToDelete(store, timestamp) - result = append(result, &types.PriceStore{ - Store: store, - PriceKeys: keysToDelete, - }) - } - } - return result -} - -// EndBlock executes all ABCI EndBlock logic respective to the capability module. It -// returns no validator updates. -func (am AppModule) EndBlock(ctx sdk.Context, _ abci.RequestEndBlock) (ret []abci.ValidatorUpdate) { - defer func() { - if err := recover(); err != nil { - telemetry.IncrCounter(1, "recovered_panics") - ctx.Logger().Error(fmt.Sprintf("panic in endblock recovered: %s", err)) - } - }() - _, span := am.tracingInfo.Start("DexEndBlock") - defer span.End() - defer dexutils.GetMemState(ctx.Context()).Clear(ctx) - - validContractsInfo := am.keeper.GetAllProcessableContractInfo(ctx) - // Each iteration is atomic. If an iteration finishes without any error, it will return, - // otherwise it will rollback any state change, filter out contracts that cause the error, - // and proceed to the next iteration. The loop is guaranteed to finish since - // `validContractAddresses` will always decrease in size every iteration. - iterCounter := len(validContractsInfo) - endBlockerStartTime := time.Now() - for len(validContractsInfo) > 0 { - newValidContractsInfo, newOutOfRentContractsInfo, failedContractToReasons, ctx, ok := contract.EndBlockerAtomic(ctx, &am.keeper, validContractsInfo, am.tracingInfo) - if ok { - break - } - telemetry.IncrCounter(float32(len(newOutOfRentContractsInfo)), am.Name(), "total_out_of_rent_contracts") - keptContractAddrs := datastructures.NewSyncSet(utils.Map(newValidContractsInfo, func(c types.ContractInfoV2) string { return c.ContractAddr })) - keptContractAddrs.AddAll(utils.Map(newOutOfRentContractsInfo, func(c types.ContractInfoV2) string { return c.ContractAddr })) - for failedContract, reason := range failedContractToReasons { - ctx.Logger().Info(fmt.Sprintf("Suspending invalid contract %s", failedContract)) - err := am.keeper.SuspendContract(ctx, failedContract, reason) - if err != nil { - ctx.Logger().Error(fmt.Sprintf("failed to suspend invalid contract %s: %s", failedContract, err)) - } - telemetry.IncrCounter(float32(1), am.Name(), "total_suspended_contracts") - } - validContractsInfo = am.keeper.GetAllProcessableContractInfo(ctx) // reload contract info to get updated dependencies due to unregister above - if len(failedContractToReasons) != 0 { - dexutils.GetMemState(ctx.Context()).ClearContractToDependencies(ctx) - } - // technically we don't really need this if `EndBlockerAtomic` guarantees that `validContractsInfo` size will - // always shrink if not `ok`, but just in case, we decided to have an explicit termination criteria here to - // prevent the chain from being stuck. - iterCounter-- - if iterCounter == 0 { - ctx.Logger().Error("All contracts failed in dex EndBlock. Doing nothing.") - break - } - } - telemetry.MeasureSince(endBlockerStartTime, am.Name(), "total_end_blocker_atomic") - - return []abci.ValidatorUpdate{} -} diff --git a/x/dex/module_simulation.go b/x/dex/module_simulation.go deleted file mode 100644 index c7b9f2942c..0000000000 --- a/x/dex/module_simulation.go +++ /dev/null @@ -1,91 +0,0 @@ -package dex - -import ( - "math/rand" - - "github.com/cosmos/cosmos-sdk/baseapp" - simappparams "github.com/cosmos/cosmos-sdk/simapp/params" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/types/module" - simtypes "github.com/cosmos/cosmos-sdk/types/simulation" - "github.com/cosmos/cosmos-sdk/x/simulation" - "github.com/sei-protocol/sei-chain/testutil/sample" - dexsimulation "github.com/sei-protocol/sei-chain/x/dex/simulation" - "github.com/sei-protocol/sei-chain/x/dex/types" -) - -// avoid unused import issue -var ( - _ = sample.AccAddress - _ = dexsimulation.FindAccount - _ = simappparams.StakePerAccount - _ = simulation.MsgEntryKind - _ = baseapp.Paramspace -) - -//nolint:deadcode,unused,gosec // Assume this will be used later, and gosec is nolint because there are no hard-coded credentials here. -const ( - opWeightMsgLimitBuy = "op_weight_msg_create_chain" - // TODO: Determine the simulation weight value - defaultWeightMsgLimitBuy int = 100 - - opWeightMsgLimitSell = "op_weight_msg_create_chain" - // TODO: Determine the simulation weight value - defaultWeightMsgLimitSell int = 100 - - opWeightMsgMarketBuy = "op_weight_msg_create_chain" - // TODO: Determine the simulation weight value - defaultWeightMsgMarketBuy int = 100 - - opWeightMsgMarketSell = "op_weight_msg_create_chain" - // TODO: Determine the simulation weight value - defaultWeightMsgMarketSell int = 100 - - opWeightMsgCancelBuy = "op_weight_msg_create_chain" - // TODO: Determine the simulation weight value - defaultWeightMsgCancelBuy int = 100 - - opWeightMsgCancelSell = "op_weight_msg_create_chain" - // TODO: Determine the simulation weight value - defaultWeightMsgCancelSell int = 100 - - opWeightMsgCancelAll = "op_weight_msg_create_chain" - // TODO: Determine the simulation weight value - defaultWeightMsgCancelAll int = 100 - - // this line is used by starport scaffolding # simapp/module/const -) - -// GenerateGenesisState creates a randomized GenState of the module -func (AppModule) GenerateGenesisState(simState *module.SimulationState) { - accs := make([]string, len(simState.Accounts)) - for i, acc := range simState.Accounts { - accs[i] = acc.Address.String() - } - dexGenesis := types.GenesisState{ - // this line is used by starport scaffolding # simapp/module/genesisState - } - simState.GenState[types.ModuleName] = simState.Cdc.MustMarshalJSON(&dexGenesis) -} - -// ProposalContents doesn't return any content functions for governance proposals -func (AppModule) ProposalContents(_ module.SimulationState) []simtypes.WeightedProposalContent { - return nil -} - -// RandomizedParams creates randomized param changes for the simulator -func (am AppModule) RandomizedParams(_ *rand.Rand) []simtypes.ParamChange { - return []simtypes.ParamChange{} -} - -// RegisterStoreDecoder registers a decoder -func (am AppModule) RegisterStoreDecoder(_ sdk.StoreDecoderRegistry) {} - -// WeightedOperations returns the all the gov module operations with their respective weights. -func (am AppModule) WeightedOperations(_ module.SimulationState) []simtypes.WeightedOperation { - operations := make([]simtypes.WeightedOperation, 0) - - // this line is used by starport scaffolding # simapp/module/operation - - return operations -} diff --git a/x/dex/module_test.go b/x/dex/module_test.go deleted file mode 100644 index cea426c10e..0000000000 --- a/x/dex/module_test.go +++ /dev/null @@ -1,835 +0,0 @@ -package dex_test - -import ( - "context" - "io/ioutil" - "testing" - "time" - - wasmkeeper "github.com/CosmWasm/wasmd/x/wasm/keeper" - wasmtypes "github.com/CosmWasm/wasmd/x/wasm/types" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/utils/tracing" - authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - "github.com/sei-protocol/sei-chain/x/dex/contract" - "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" - minttypes "github.com/sei-protocol/sei-chain/x/mint/types" - "github.com/stretchr/testify/require" - abci "github.com/tendermint/tendermint/abci/types" - tmproto "github.com/tendermint/tendermint/proto/tendermint/types" - "go.opentelemetry.io/otel" - "go.opentelemetry.io/otel/trace" -) - -const ( - GOOD_CONTRACT_INSTANTIATE = `{"whitelist": ["sei1h9yjz89tl0dl6zu65dpxcqnxfhq60wxx8s5kag"], - "use_whitelist":false,"admin":"sei1h9yjz89tl0dl6zu65dpxcqnxfhq60wxx8s5kag", - "limit_order_fee":{"decimal":"0.0001","negative":false}, - "market_order_fee":{"decimal":"0.0001","negative":false}, - "liquidation_order_fee":{"decimal":"0.0001","negative":false}, - "margin_ratio":{"decimal":"0.0625","negative":false}, - "max_leverage":{"decimal":"4","negative":false}, - "default_base":"USDC", - "native_token":"USDC","denoms": ["SEI","ATOM","USDC","SOL","ETH","OSMO","AVAX","BTC"], - "full_denom_mapping": [["usei","SEI","0.000001"],["uatom","ATOM","0.000001"],["uusdc","USDC","0.000001"]], - "funding_payment_lookback":3600,"spot_market_contract":"sei1h9yjz89tl0dl6zu65dpxcqnxfhq60wxx8s5kag", - "supported_collateral_denoms": ["USDC"], - "supported_multicollateral_denoms": ["ATOM"], - "oracle_denom_mapping": [["usei","SEI","1"],["uatom","ATOM","1"],["uusdc","USDC","1"],["ueth","ETH","1"]], - "multicollateral_whitelist": ["sei1h9yjz89tl0dl6zu65dpxcqnxfhq60wxx8s5kag"], - "multicollateral_whitelist_enable": true, - "funding_payment_pairs": [["USDC","ETH"]], - "default_margin_ratios":{ - "initial":"0.3", - "partial":"0.25", - "maintenance":"0.06" - }}` -) - -func TestEndBlockMarketOrder(t *testing.T) { - testApp := keepertest.TestApp() - dexkeeper := testApp.DexKeeper - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(dexkeeper.GetMemStoreKey()))) - pair := types.Pair{PriceDenom: "SEI", AssetDenom: "ATOM"} - - testAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - amounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(10000000)), sdk.NewCoin("uusdc", sdk.NewInt(10000000))) - bankkeeper := testApp.BankKeeper - bankkeeper.MintCoins(ctx, minttypes.ModuleName, amounts) - bankkeeper.SendCoinsFromModuleToAccount(ctx, minttypes.ModuleName, testAccount, amounts) - dexAmounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(5000000)), sdk.NewCoin("uusdc", sdk.NewInt(10000000))) - bankkeeper.SendCoinsFromAccountToModule(ctx, testAccount, types.ModuleName, dexAmounts) - wasm, err := ioutil.ReadFile("./testdata/mars.wasm") - if err != nil { - panic(err) - } - wasmKeeper := testApp.WasmKeeper - contractKeeper := wasmkeeper.NewDefaultPermissionKeeper(&wasmKeeper) - var perm *wasmtypes.AccessConfig - codeId, err := contractKeeper.Create(ctx, testAccount, wasm, perm) - if err != nil { - panic(err) - } - contractAddr, _, err := contractKeeper.Instantiate(ctx, codeId, testAccount, testAccount, []byte(GOOD_CONTRACT_INSTANTIATE), "test", - sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(100000)))) - if err != nil { - panic(err) - } - err = dexkeeper.SetContract(ctx, &types.ContractInfoV2{CodeId: 123, ContractAddr: contractAddr.String(), NeedHook: false, NeedOrderMatching: true, RentBalance: 100000000}) - if err != nil { - panic(err) - } - dexkeeper.AddRegisteredPair(ctx, contractAddr.String(), pair) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 1, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("1"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 2, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("2"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetDepositInfo(ctx, types.ContractAddress(contractAddr.String())).Add( - &types.DepositInfoEntry{ - Creator: testAccount.String(), - Denom: "uusdc", - Amount: sdk.MustNewDecFromStr("2000000"), - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, contractAddr.String(), dexkeeper.GetContractWithoutGasCharge) - - ctx = ctx.WithBlockHeight(1) - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - _, found := dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("1"), pair.PriceDenom, pair.AssetDenom) - // Long book should be populated - require.True(t, found) - - dexutils.GetMemState(ctx.Context()).Clear(ctx) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 3, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("1"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_MARKET, - PositionDirection: types.PositionDirection_SHORT, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, contractAddr.String(), dexkeeper.GetContractWithoutGasCharge) - - ctx = ctx.WithBlockHeight(2) - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - - // Long book should be removed since it's executed - // No state change should've been persisted for bad contract - _, found = dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("2"), pair.PriceDenom, pair.AssetDenom) - // Long book should be populated - require.False(t, found) - _, found = dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("1"), pair.PriceDenom, pair.AssetDenom) - require.True(t, found) - - matchResults, _ := dexkeeper.GetMatchResultState(ctx, contractAddr.String()) - require.Equal(t, 1, len(matchResults.Orders)) - require.Equal(t, 2, len(matchResults.Settlements)) - - dexutils.GetMemState(ctx.Context()).Clear(ctx) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 4, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("1000000"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_MARKET, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, contractAddr.String(), dexkeeper.GetContractWithoutGasCharge) - - ctx = ctx.WithBlockHeight(3) - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - - matchResults, _ = dexkeeper.GetMatchResultState(ctx, contractAddr.String()) - require.Equal(t, 1, len(matchResults.Orders)) - require.Equal(t, 0, len(matchResults.Settlements)) -} - -func TestEndBlockLimitOrder(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - dexkeeper := testApp.DexKeeper - pair := types.Pair{PriceDenom: "SEI", AssetDenom: "ATOM"} - - testAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - amounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(10000000)), sdk.NewCoin("uusdc", sdk.NewInt(10000000))) - bankkeeper := testApp.BankKeeper - bankkeeper.MintCoins(ctx, minttypes.ModuleName, amounts) - bankkeeper.SendCoinsFromModuleToAccount(ctx, minttypes.ModuleName, testAccount, amounts) - dexAmounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(5000000)), sdk.NewCoin("uusdc", sdk.NewInt(10000000))) - bankkeeper.SendCoinsFromAccountToModule(ctx, testAccount, types.ModuleName, dexAmounts) - wasm, err := ioutil.ReadFile("./testdata/mars.wasm") - if err != nil { - panic(err) - } - wasmKeeper := testApp.WasmKeeper - contractKeeper := wasmkeeper.NewDefaultPermissionKeeper(&wasmKeeper) - var perm *wasmtypes.AccessConfig - codeId, err := contractKeeper.Create(ctx, testAccount, wasm, perm) - if err != nil { - panic(err) - } - contractAddr, _, err := contractKeeper.Instantiate(ctx, codeId, testAccount, testAccount, []byte(GOOD_CONTRACT_INSTANTIATE), "test", - sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(100000)))) - if err != nil { - panic(err) - } - - dexkeeper.SetContract(ctx, &types.ContractInfoV2{CodeId: 123, ContractAddr: contractAddr.String(), NeedHook: false, NeedOrderMatching: true, RentBalance: 100000000}) - dexkeeper.AddRegisteredPair(ctx, contractAddr.String(), pair) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 1, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("1"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 2, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("2"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 3, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("3"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_SHORT, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetDepositInfo(ctx, types.ContractAddress(contractAddr.String())).Add( - &types.DepositInfoEntry{ - Creator: testAccount.String(), - Denom: "uusdc", - Amount: sdk.MustNewDecFromStr("2000000"), - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, contractAddr.String(), dexkeeper.GetContractWithoutGasCharge) - - ctx = ctx.WithBlockHeight(1) - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - _, found := dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("1"), pair.PriceDenom, pair.AssetDenom) - require.True(t, found) - _, found = dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("2"), pair.PriceDenom, pair.AssetDenom) - require.True(t, found) - _, found = dexkeeper.GetShortBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("3"), pair.PriceDenom, pair.AssetDenom) - require.True(t, found) - - dexutils.GetMemState(ctx.Context()).Clear(ctx) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 4, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("2"), - Quantity: sdk.MustNewDecFromStr("2"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_SHORT, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 5, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("3"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, contractAddr.String(), dexkeeper.GetContractWithoutGasCharge) - - ctx = ctx.WithBlockHeight(2) - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - - _, found = dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("2"), pair.PriceDenom, pair.AssetDenom) - require.False(t, found) - _, found = dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("1"), pair.PriceDenom, pair.AssetDenom) - require.True(t, found) - _, found = dexkeeper.GetShortBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("3"), pair.PriceDenom, pair.AssetDenom) - require.True(t, found) - _, found = dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("3"), pair.PriceDenom, pair.AssetDenom) - require.False(t, found) - - matchResults, _ := dexkeeper.GetMatchResultState(ctx, contractAddr.String()) - require.Equal(t, 2, len(matchResults.Orders)) - require.Equal(t, 4, len(matchResults.Settlements)) - - dexutils.GetMemState(ctx.Context()).Clear(ctx) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 6, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("1000000"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, contractAddr.String(), dexkeeper.GetContractWithoutGasCharge) - - ctx = ctx.WithBlockHeight(3) - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - - _, found = dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("1"), pair.PriceDenom, pair.AssetDenom) - require.True(t, found) - _, found = dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("1000000"), pair.PriceDenom, pair.AssetDenom) - require.False(t, found) - _, found = dexkeeper.GetShortBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("3"), pair.PriceDenom, pair.AssetDenom) - require.False(t, found) - - matchResults, _ = dexkeeper.GetMatchResultState(ctx, contractAddr.String()) - require.Equal(t, 1, len(matchResults.Orders)) - require.Equal(t, 2, len(matchResults.Settlements)) -} - -func TestEndBlockRollback(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - dexkeeper := testApp.DexKeeper - pair := TEST_PAIR() - // register contract and pair - dexkeeper.SetContract(ctx, &types.ContractInfoV2{CodeId: 123, ContractAddr: keepertest.TestContract, NeedHook: false, NeedOrderMatching: true, RentBalance: 100000000}) - dexkeeper.AddRegisteredPair(ctx, keepertest.TestContract, pair) - // place one order to a nonexistent contract - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(keepertest.TestContract), pair).Add( - &types.Order{ - Id: 1, - Account: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - Price: sdk.MustNewDecFromStr("1"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, keepertest.TestContract, dexkeeper.GetContractWithoutGasCharge) - ctx = ctx.WithBlockHeight(1) - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - // No state change should've been persisted - matchResult, _ := dexkeeper.GetMatchResultState(ctx, keepertest.TestContract) - require.Equal(t, &types.MatchResult{}, matchResult) - // contract should be suspended - contract, err := dexkeeper.GetContract(ctx, keepertest.TestContract) - require.Nil(t, err) - require.True(t, contract.Suspended) -} - -func TestEndBlockPartialRollback(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - // BAD CONTRACT - dexkeeper := testApp.DexKeeper - pair := TEST_PAIR() - // register contract and pair - dexkeeper.SetContract(ctx, &types.ContractInfoV2{CodeId: 123, ContractAddr: keepertest.TestContract, NeedHook: false, NeedOrderMatching: true, RentBalance: 100000000}) - dexkeeper.AddRegisteredPair(ctx, keepertest.TestContract, pair) - // place one order to a nonexistent contract - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(keepertest.TestContract), pair).Add( - &types.Order{ - Id: 1, - Account: keepertest.TestAccount, - ContractAddr: keepertest.TestContract, - Price: sdk.MustNewDecFromStr("1"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, keepertest.TestContract, dexkeeper.GetContractWithoutGasCharge) - // GOOD CONTRACT - testAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - amounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(1000000)), sdk.NewCoin("uusdc", sdk.NewInt(1000000))) - bankkeeper := testApp.BankKeeper - bankkeeper.MintCoins(ctx, minttypes.ModuleName, amounts) - bankkeeper.SendCoinsFromModuleToAccount(ctx, minttypes.ModuleName, testAccount, amounts) - dexAmounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(500000)), sdk.NewCoin("uusdc", sdk.NewInt(1000000))) - bankkeeper.SendCoinsFromAccountToModule(ctx, testAccount, types.ModuleName, dexAmounts) - wasm, err := ioutil.ReadFile("./testdata/mars.wasm") - if err != nil { - panic(err) - } - wasmKeeper := testApp.WasmKeeper - contractKeeper := wasmkeeper.NewDefaultPermissionKeeper(&wasmKeeper) - var perm *wasmtypes.AccessConfig - codeId, err := contractKeeper.Create(ctx, testAccount, wasm, perm) - if err != nil { - panic(err) - } - contractAddr, _, err := contractKeeper.Instantiate(ctx, codeId, testAccount, testAccount, []byte(GOOD_CONTRACT_INSTANTIATE), "test", - sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(100000)))) - if err != nil { - panic(err) - } - dexkeeper.SetContract(ctx, &types.ContractInfoV2{CodeId: 123, ContractAddr: contractAddr.String(), NeedHook: false, NeedOrderMatching: true, RentBalance: 100000000}) - dexkeeper.AddRegisteredPair(ctx, contractAddr.String(), pair) - // place one order to the good contract - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 2, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("0.0001"), - Quantity: sdk.MustNewDecFromStr("0.0001"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetDepositInfo(ctx, types.ContractAddress(contractAddr.String())).Add( - &types.DepositInfoEntry{ - Creator: testAccount.String(), - Denom: "uusdc", - Amount: sdk.MustNewDecFromStr("10000"), - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, contractAddr.String(), dexkeeper.GetContractWithoutGasCharge) - - ctx = ctx.WithBlockHeight(1) - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - // No state change should've been persisted for bad contract - matchResult, _ := dexkeeper.GetMatchResultState(ctx, keepertest.TestContract) - require.Equal(t, &types.MatchResult{}, matchResult) - // bad contract should be suspended - contract, err := dexkeeper.GetContract(ctx, keepertest.TestContract) - require.Nil(t, err) - require.True(t, contract.Suspended) - // state change should've been persisted for good contract - matchResult, _ = dexkeeper.GetMatchResultState(ctx, contractAddr.String()) - require.Equal(t, 1, len(matchResult.Orders)) - _, found := dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("0.0001"), pair.PriceDenom, pair.AssetDenom) - require.True(t, found) -} - -func TestBeginBlock(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - dexkeeper := testApp.DexKeeper - - testAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - amounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(10000000))) - bankkeeper := testApp.BankKeeper - bankkeeper.MintCoins(ctx, minttypes.ModuleName, amounts) - bankkeeper.SendCoinsFromModuleToAccount(ctx, minttypes.ModuleName, testAccount, amounts) - wasm, err := ioutil.ReadFile("./testdata/mars.wasm") - if err != nil { - panic(err) - } - wasmKeeper := testApp.WasmKeeper - contractKeeper := wasmkeeper.NewDefaultPermissionKeeper(&wasmKeeper) - var perm *wasmtypes.AccessConfig - codeId, err := contractKeeper.Create(ctx, testAccount, wasm, perm) - if err != nil { - panic(err) - } - contractAddr, _, err := contractKeeper.Instantiate(ctx, codeId, testAccount, testAccount, []byte(GOOD_CONTRACT_INSTANTIATE), "test", - sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(100000)))) - if err != nil { - panic(err) - } - dexkeeper.SetContract(ctx, &types.ContractInfoV2{CodeId: 123, ContractAddr: contractAddr.String(), NeedHook: false, NeedOrderMatching: true, RentBalance: 100000000}) - - // right now just make sure it doesn't crash since it doesn't register any state to be checked against - testApp.BeginBlocker(ctx, abci.RequestBeginBlock{}) -} - -// Note that once the bug that causes EndBlock to panic is fixed, this test will need to be -// updated to trigger the next bug that causes panics, if any. -func TestEndBlockPanicHandling(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - dexkeeper := testApp.DexKeeper - pair := types.Pair{PriceDenom: "SEI", AssetDenom: "ATOM"} - - testAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - amounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(10000000))) - bankkeeper := testApp.BankKeeper - bankkeeper.MintCoins(ctx, minttypes.ModuleName, amounts) - bankkeeper.SendCoinsFromModuleToAccount(ctx, minttypes.ModuleName, testAccount, amounts) - dexAmounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(5000000))) - bankkeeper.SendCoinsFromAccountToModule(ctx, testAccount, types.ModuleName, dexAmounts) - wasm, err := ioutil.ReadFile("./testdata/mars.wasm") - if err != nil { - panic(err) - } - wasmKeeper := testApp.WasmKeeper - contractKeeper := wasmkeeper.NewDefaultPermissionKeeper(&wasmKeeper) - var perm *wasmtypes.AccessConfig - codeId, err := contractKeeper.Create(ctx, testAccount, wasm, perm) - if err != nil { - panic(err) - } - contractAddr, _, err := contractKeeper.Instantiate(ctx, codeId, testAccount, testAccount, []byte(GOOD_CONTRACT_INSTANTIATE), "test", - sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(100000)))) - if err != nil { - panic(err) - } - dexkeeper.SetContract(ctx, &types.ContractInfoV2{CodeId: 123, ContractAddr: contractAddr.String(), NeedHook: false, NeedOrderMatching: true, RentBalance: 100000000}) - dexkeeper.AddRegisteredPair(ctx, contractAddr.String(), pair) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 1, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.Dec{}, - Quantity: sdk.Dec{}, - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetDepositInfo(ctx, types.ContractAddress(contractAddr.String())).Add( - &types.DepositInfoEntry{ - Creator: testAccount.String(), - Denom: "usei", - Amount: sdk.MustNewDecFromStr("2000000"), - }, - ) - - require.NotPanics(t, func() { testApp.EndBlocker(ctx, abci.RequestEndBlock{}) }) - _, found := dexkeeper.GetLongBookByPrice(ctx, contractAddr.String(), sdk.MustNewDecFromStr("1"), pair.PriceDenom, pair.AssetDenom) - require.False(t, found) -} - -func TestEndBlockRollbackWithRentCharge(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - dexkeeper := testApp.DexKeeper - pair := TEST_PAIR() - // GOOD CONTRACT - testAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - amounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(1000000)), sdk.NewCoin("uusdc", sdk.NewInt(1000000))) - bankkeeper := testApp.BankKeeper - bankkeeper.MintCoins(ctx, minttypes.ModuleName, amounts) - bankkeeper.SendCoinsFromModuleToAccount(ctx, minttypes.ModuleName, testAccount, amounts) - dexAmounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(500000)), sdk.NewCoin("uusdc", sdk.NewInt(1000000))) - bankkeeper.SendCoinsFromAccountToModule(ctx, testAccount, types.ModuleName, dexAmounts) - wasm, err := ioutil.ReadFile("./testdata/mars.wasm") - if err != nil { - panic(err) - } - wasmKeeper := testApp.WasmKeeper - contractKeeper := wasmkeeper.NewDefaultPermissionKeeper(&wasmKeeper) - var perm *wasmtypes.AccessConfig - codeId, err := contractKeeper.Create(ctx, testAccount, wasm, perm) - if err != nil { - panic(err) - } - contractAddr, _, err := contractKeeper.Instantiate(ctx, codeId, testAccount, testAccount, []byte(GOOD_CONTRACT_INSTANTIATE), "test", - sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(100000)))) - if err != nil { - panic(err) - } - dexkeeper.SetContract(ctx, &types.ContractInfoV2{CodeId: 123, ContractAddr: contractAddr.String(), NeedHook: false, NeedOrderMatching: true, RentBalance: 1}) - dexkeeper.AddRegisteredPair(ctx, contractAddr.String(), pair) - // place one order to a nonexistent contract - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 2, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("0.0001"), - Quantity: sdk.MustNewDecFromStr("0.0001"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetDepositInfo(ctx, types.ContractAddress(contractAddr.String())).Add( - &types.DepositInfoEntry{ - Creator: testAccount.String(), - Denom: "uusdc", - Amount: sdk.MustNewDecFromStr("10000"), - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, contractAddr.String(), dexkeeper.GetContractWithoutGasCharge) - // overwrite params for testing - params := dexkeeper.GetParams(ctx) - params.MinProcessableRent = 0 - dexkeeper.SetParams(ctx, params) - - ctx = ctx.WithBlockHeight(1) - creatorBalanceBefore := bankkeeper.GetBalance(ctx, testAccount, "usei") - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - // no state change should've been persisted for good contract because it should've run out of gas - matchResult, _ := dexkeeper.GetMatchResultState(ctx, contractAddr.String()) - require.Equal(t, 0, len(matchResult.Orders)) - // rent should still be charged even if the contract failed - c, err := dexkeeper.GetContract(ctx, contractAddr.String()) - require.Nil(t, err) - require.True(t, c.Suspended) // bad contract is suspended not because of out-of-rent but because of execution error - require.Equal(t, uint64(0), c.RentBalance) // rent balance should be drained - require.Equal(t, int64(1), dexkeeper.BankKeeper.GetBalance( - ctx, - dexkeeper.AccountKeeper.GetModuleAddress(authtypes.FeeCollectorName), - "usei", - ).Amount.Int64()) // bad contract rent should be sent to fee collector - creatorBalanceAfter := bankkeeper.GetBalance(ctx, testAccount, "usei") - require.Equal(t, creatorBalanceBefore, creatorBalanceAfter) -} - -func TestEndBlockContractWithoutPair(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - dexkeeper := testApp.DexKeeper - - testAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - amounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(10000000)), sdk.NewCoin("uusdc", sdk.NewInt(10000000))) - bankkeeper := testApp.BankKeeper - bankkeeper.MintCoins(ctx, minttypes.ModuleName, amounts) - bankkeeper.SendCoinsFromModuleToAccount(ctx, minttypes.ModuleName, testAccount, amounts) - dexAmounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(5000000)), sdk.NewCoin("uusdc", sdk.NewInt(10000000))) - bankkeeper.SendCoinsFromAccountToModule(ctx, testAccount, types.ModuleName, dexAmounts) - wasm, err := ioutil.ReadFile("./testdata/mars.wasm") - if err != nil { - panic(err) - } - wasmKeeper := testApp.WasmKeeper - contractKeeper := wasmkeeper.NewDefaultPermissionKeeper(&wasmKeeper) - var perm *wasmtypes.AccessConfig - codeId, err := contractKeeper.Create(ctx, testAccount, wasm, perm) - if err != nil { - panic(err) - } - contractAddr, _, err := contractKeeper.Instantiate(ctx, codeId, testAccount, testAccount, []byte(GOOD_CONTRACT_INSTANTIATE), "test", - sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(100000)))) - if err != nil { - panic(err) - } - - // no pair registered - contractInfo := types.ContractInfoV2{CodeId: 123, ContractAddr: contractAddr.String(), NeedHook: false, NeedOrderMatching: true, RentBalance: 100000000} - dexkeeper.SetContract(ctx, &contractInfo) - - tp := trace.NewNoopTracerProvider() - otel.SetTracerProvider(trace.NewNoopTracerProvider()) - tr := tp.Tracer("component-main") - ti := tracing.Info{ - Tracer: &tr, - } - _, _, _, _, success := contract.EndBlockerAtomic(ctx, &testApp.DexKeeper, []types.ContractInfoV2{contractInfo}, &ti) - require.True(t, success) - - contractInfo, err = dexkeeper.GetContract(ctx, contractInfo.ContractAddr) - require.Nil(t, err) - require.False(t, contractInfo.Suspended) -} - -func TestOrderCountUpdate(t *testing.T) { - testApp := keepertest.TestApp() - ctx := testApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(testApp.GetMemKey(types.MemStoreKey)))) - dexkeeper := testApp.DexKeeper - pair := types.Pair{PriceDenom: "SEI", AssetDenom: "ATOM"} - - testAccount, _ := sdk.AccAddressFromBech32("sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx") - amounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(10000000)), sdk.NewCoin("uusdc", sdk.NewInt(10000000))) - bankkeeper := testApp.BankKeeper - bankkeeper.MintCoins(ctx, minttypes.ModuleName, amounts) - bankkeeper.SendCoinsFromModuleToAccount(ctx, minttypes.ModuleName, testAccount, amounts) - dexAmounts := sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(5000000)), sdk.NewCoin("uusdc", sdk.NewInt(10000000))) - bankkeeper.SendCoinsFromAccountToModule(ctx, testAccount, types.ModuleName, dexAmounts) - wasm, err := ioutil.ReadFile("./testdata/mars.wasm") - if err != nil { - panic(err) - } - wasmKeeper := testApp.WasmKeeper - contractKeeper := wasmkeeper.NewDefaultPermissionKeeper(&wasmKeeper) - var perm *wasmtypes.AccessConfig - codeId, err := contractKeeper.Create(ctx, testAccount, wasm, perm) - if err != nil { - panic(err) - } - contractAddr, _, err := contractKeeper.Instantiate(ctx, codeId, testAccount, testAccount, []byte(GOOD_CONTRACT_INSTANTIATE), "test", - sdk.NewCoins(sdk.NewCoin("usei", sdk.NewInt(100000)))) - if err != nil { - panic(err) - } - - dexkeeper.SetContract(ctx, &types.ContractInfoV2{CodeId: 123, ContractAddr: contractAddr.String(), NeedHook: false, NeedOrderMatching: true, RentBalance: 100000000}) - dexkeeper.AddRegisteredPair(ctx, contractAddr.String(), pair) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 1, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("1"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 2, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("2"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 3, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("3"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_SHORT, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetDepositInfo(ctx, types.ContractAddress(contractAddr.String())).Add( - &types.DepositInfoEntry{ - Creator: testAccount.String(), - Denom: "uusdc", - Amount: sdk.MustNewDecFromStr("2000000"), - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, contractAddr.String(), dexkeeper.GetContractWithoutGasCharge) - - ctx = ctx.WithBlockHeight(1) - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - require.Equal(t, uint64(1), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(1))) - require.Equal(t, uint64(0), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_SHORT, sdk.NewDec(1))) - require.Equal(t, uint64(1), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(2))) - require.Equal(t, uint64(0), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_SHORT, sdk.NewDec(2))) - require.Equal(t, uint64(0), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(3))) - require.Equal(t, uint64(1), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_SHORT, sdk.NewDec(3))) - - dexutils.GetMemState(ctx.Context()).Clear(ctx) - dexutils.GetMemState(ctx.Context()).GetBlockOrders(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Order{ - Id: 4, - Account: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("1"), - Quantity: sdk.MustNewDecFromStr("1"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - OrderType: types.OrderType_LIMIT, - PositionDirection: types.PositionDirection_LONG, - Data: "{\"position_effect\":\"Open\",\"leverage\":\"1\"}", - }, - ) - dexutils.GetMemState(ctx.Context()).GetBlockCancels(ctx, types.ContractAddress(contractAddr.String()), pair).Add( - &types.Cancellation{ - Id: 2, - Creator: testAccount.String(), - ContractAddr: contractAddr.String(), - Price: sdk.MustNewDecFromStr("2"), - PriceDenom: pair.PriceDenom, - AssetDenom: pair.AssetDenom, - PositionDirection: types.PositionDirection_LONG, - }, - ) - dexutils.GetMemState(ctx.Context()).SetDownstreamsToProcess(ctx, contractAddr.String(), dexkeeper.GetContractWithoutGasCharge) - ctx = ctx.WithBlockHeight(2) - testApp.EndBlocker(ctx, abci.RequestEndBlock{}) - require.Equal(t, uint64(2), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(1))) - require.Equal(t, uint64(0), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_SHORT, sdk.NewDec(1))) - require.Equal(t, uint64(0), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(2))) - require.Equal(t, uint64(0), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_SHORT, sdk.NewDec(2))) - require.Equal(t, uint64(0), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_LONG, sdk.NewDec(3))) - require.Equal(t, uint64(1), dexkeeper.GetOrderCountState(ctx, contractAddr.String(), pair.PriceDenom, pair.AssetDenom, types.PositionDirection_SHORT, sdk.NewDec(3))) -} diff --git a/x/dex/simulation/simap.go b/x/dex/simulation/simap.go deleted file mode 100644 index 92c437c0d1..0000000000 --- a/x/dex/simulation/simap.go +++ /dev/null @@ -1,15 +0,0 @@ -package simulation - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - simtypes "github.com/cosmos/cosmos-sdk/types/simulation" -) - -// FindAccount find a specific address from an account list -func FindAccount(accs []simtypes.Account, address string) (simtypes.Account, bool) { - creator, err := sdk.AccAddressFromBech32(address) - if err != nil { - panic(err) - } - return simtypes.FindAccount(accs, creator) -} diff --git a/x/dex/spec/README.md b/x/dex/spec/README.md deleted file mode 100644 index 36f46e3bd3..0000000000 --- a/x/dex/spec/README.md +++ /dev/null @@ -1,56 +0,0 @@ -## Abstract -`dex` module is responsible for matching orders for registered contracts. - -## Concepts -### Frequent Batch Auction -The traditional implementation of exchange logic would look something like the following: -1. User A sends an order placement transaction -2. User B sends another order placement transaction -3. User A's transaction is processed by matching it against the order book state and settle accordingly -4. User B's transaction is processed similarly - -Sei's `dex` module takes a different approach: -1. User A sends an order placement transaction -2. User B sends another order placement transaction -3. User A's transaction is processed by simply adding the order to an in-memory queue, without matching -4. User B's transaction is processed similarly -5. At the end of the block that contains both transactions, the in-memory queue as a whole will be matched against the order book state - -Step 5 is where the majority of `dex`'s logic takes place. Specifically it consists of the follow stages for each market: -1. Cancel orders for transactions in the current block -2. Add new limit orders to the order book -3. Match market orders in the current block against the order book -4. Market limit orders in the current block against the order book - -### Contract Registration -Since `dex` only provides order matching logic, product logic specific to individual protocols still needs to be defined in CosmWasm contracts. As such, `dex` offers a way to inform the protocol contracts about order placement and matching results. `dex` achieves this by requiring contracts that want to leverage `dex`'s order matching logic to explicitly register via a special transaction type `MsgRegisterContract`. - -## State (KV Store) -The following prefixes are persisted in disk: -- "LongBook-value-": order book state on the long side where each entry represents a price level and can contain multiple orders at that same price. -- "ShortBook-value-": similar to the above but on the short side. -- "x-wasm-contract": contract registration information. -- "MatchResult-": match results of the most recent block. - -The following prefixes are only used intrablock and are cleared before committing the block, since they serve no purpose beyond the scope of its enclosing block and flushing them to disk would be computationally expensive: -- "MemOrder-": orders added by transactions in the current block and will be matched against the order book states at the end of the block. -- "MemCancel-": cancellations added by transactions in the current block and will update the order book states at the end of the block. - -## Hooks -A registered contract can define the following `sudo` hooks that will be called by the `dex` module at appropriate times: -- BulkOrderPlacements: informs the contract about order placements -- BulkOrderCancellations: informs the contract about order cancellations -- Settlement: informs the contract about matched orders and the settlement prices - -There are two more utility hooks that a contract can define for housekeeping purposes (e.g. recalculate TWAPs): -- NewBlock -- FinalizeBlock (note that this is distinct from ABCI++'s FinalizeBlock) - -## Transactions -- MsgPlaceOrders - place one or more orders against a registered contract -- MsgCancelOrders - cancel one or more orders against a registered contract -- MsgRegisterContract - register or reregister a CosmWasm contract with `dex` - - -## Spam Prevention -Conventionally, spamming to a blockchain is mainly mitigated through charging gas based on the resource a transaction consumes. With `dex`'s unique design though, the bulk of resource comsumption happens at the end of a block, which cannot be quantified precisely beforehand. Thus the `dex` module charges transaction messages of type MsgPlaceOrders and MsgCancelOrders based on a flat rate per order/cancel. This amount is guaranteed to well cover any `dex`-level computation, and any exceeded usage must have come from registered contract's logic being expensive and will be charged against the contract, which is required to post a rent sum upon registration. \ No newline at end of file diff --git a/x/dex/testdata/clearing_house.wasm b/x/dex/testdata/clearing_house.wasm deleted file mode 100644 index 358f884871f18c96d332d2a9ee1c3ccd333a57e8..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 833624 zcmeFa3z%hBRqwlA`%$&`u3FVy-Cg}ivi42`)tEjs8j~jGFTUc_)dOm`kYqdA^d5u<{)#b}}e<|ulj2cgA)eLUce8Z{_jt2r1YLc|E+nfv>X zG1uB_S69En%kO$RUuw@a*L;jQ=6KC9$DAv={DxP?Q540$o;>TaWbfWcf8xEDrF)gm z_{&es|H>f0r5wxRp=}R5wf5e^zv!}#XIODPtF2qS6^chusKJ|9FKE*$-Es@{t3GbI zETU}YIo;48FM&m6)Tb4mR>IQc_Pm@mByjXjRVX0PRWVndb!2~)MLBCKQDGXM97H`@ z5~(#5#v7jFy~)ocv+3?@Zfafr@>gAdW0Wb~x#H!QUcdYDE255`x;*{h^;g}vJBsu; zWiMa(s+)F?3*YdH%dd%ARn=>D-+ZH29bA6J71v*S)8$uRb;ae>x8~+7j|#84=Biil z=0ER_V%7ArSHAj{mtRxo^4{?xi>FzW%E3e~ovtFwVYy_bY(p`b)2U z^~?9{eoeGmEzRt{;+wzqTc7*9i8}LD=F2a?@fBB2ylP#s`{l3x0Uu58x>xVM{xz4r z;>ydfx(0YZ*ZOQL(?7^-<$p=_&x-k2{Mij+3O_&XO!o>|JCiO6K~>v|c5^?k{+owv#^p)JJmq8EKNvF~HRc zqi(mNcn}W;N!+4VyUo}fWu!^cOS&!vKE}JSK+%L=k{Q}*N8Vw8n^8o-gbYyM>R$gk zQ4vR3*6T%`c-0#Ii&n)w0TD-_GL1W#szebDw!7IhK*h<>YKA{iJQXF;)KttYS{9JB zlj#WTtesxFHc3?_j(zA!Jk^V)H1$b`9B;Z40g!sszbu)XOC!dULQoot#zjfJr=gTO z_K&eKxoRZJ=HobzqmITLwLwxA+kA97%Ai?)nqdr3o&RI_Et>1ZkYJoAqchceH*UAu zoz3wxVncO2Xi;@_+-k)soeRomhU%@PH8s^*lXc>28&s+4L2=>!;t(=IREJQuOkw>nT2c>7@vr%P-x1%@t|f zyY$j4cVB+(r7yqyhTUm0^_L8(jC;SD%pOX9FZuQ-T3^U+&0cuUg%>@M%znPL{l_zs zv+s!C8PC2oJDB}k_J3z@%YGrdJNw1#m$G}Zd$V88ekFVU2h$IXFhir(Iz%)a^uZ~V_U-F(Aq^zL7i&m^BsE+Kh;I{WQ^WZ)?8w^MudyQyBiJEcu3 zD*gU+*4}&|o&9p_Z__`p9&XEiB%6I8eJuS%`e^#e*6cfz&!kVLx5b}JKcCKiI{laQ zFS0+#{viFC?5T8Lc6;`PboLF|{_OSHec4ZCAISbZd$am|XLiYZtpDeI`|QtVZ^?c> z`_=62**lc=K=%GjQ2knV&QE8vcain}p;c3ygQ&ut$!Nnr#1K=9D|?iqJ_?lyRP3QNGdR*a-jx4E*GyJ zszR=;vRE3%j3F-jdn)jAr5wyED;sB(i`1Z##XX}W06FiC3&=%bj@B2GoE8jojUl7} zHi)YcH1L{KcvZ^_z-J(373yku9B4zbO-MlIf`ha$2C32Mf7&v_jVEw!4noe!HH70HAd!-1V8=Fg-`T%8v2M@TAf{jL_DmC7((Id9tlzR!9PT zv3{SZNGU2GACpp4?u!HdqVkK){QdD#ZzReGt-BmEHr>5{Y{kp*GUl9PrHW`P>T^@P z2F$HNzjUXjd;P&0{hL`co6oIUJ#UO=!`n5O@2?Ten`+REG6O0W9i-J1*sLVk{naWy z=DxUW-Du=%;Dg9OzAMm*NE>o0R-}rSNO4s~6-J5%)2_iB{Z&9&zKMtikC})Nj}7vQ z#m0ng(`&$lG1(mM8qD_RG?03d9sQGKX8QRF%MAMCzIF}z{Xt!0*Pz$$*H6cSW4cjh z*I=qYUDwz(==P@?Po2JTL72C8ztecvYH-G`LDpb~U4yi5^zTz<-4xBEU{ z{T1h{UkjEDq&0C6_l+9@oDoQ_(I2MIDajs8=n3n;-htLBd(fC<6a>&+@za3vE#8C) zX@M!xivYYU4zv6Ai7xJbI$hkmau;`3UEDv>#eGkwi+8Qu#eG#54@`9N?x)kmp_RLM zch$v%6I~qkE~KqaO&c7opg!2>SQ;wK(BZ1%k4$v@&{wbHhga_Sp{nCYCptdzbddT; zql*Uh9jUr_+}=A$K2~LZv61;?mAOBugz{o?M-qtlO^wV0Rp#B6SuxF9STTK-)b>Gd z*jPz=J51DDtmEFjEK~NLiOqt9*c{Picd3Z;PiAF2Oq=SdNVZ1ZGQN&MlbR|&9_<;W zyD&@Aa^?c$lWEOtsm#tvA{Sje%;*7066b#}D=epJTkMos{s}TLXt43tT#)T3Bdouu zjLwT zqPa-Vi-eP6X>-(jnDrm7sV1%#YFxES>{m=4aI*lGWCD;}KWdj-8J>aJ3mC{h#n87# zxfk;~bEB->Ruxp|fKtwYldOF1p7N>qy0ZHs#u7$rQ}n5<+*`(lI@maBQ*fIVyn2{Y zzoi~DUAw47a!T#LkV4OU5ym28ZHfIgE9u*JPTw->>@4=*Q*`bbrR5o~zL5DC00J0j zv`Y)oMMcVg=(2gr_WXVjR0g`LrNv*OcKj9O#t zzjl-rt(PLtf&_F*nqZ+7v7S{!u|eBVYwVg(S&rVn#o5#pxXkb;8$;4OJB7#P=)z?@ z|4(8Wv!jPfnHh|bNPO)xgw+?5zQ}Vi=`xg-iTVOU$$ufSxged9E|A=;woyk$B0F#0 zCl?eWF*>owBe5Pe6me_@iAm)0BZPXYza%bJo&*vpNjPKZZ_F4EHpY1HYd*&J<6{o< zn4&m^PScu6r8SFmYZPXaRC6{{SF+4z8fH^!)Mry%Z3ZB>Zba zz<)AH#ih(+4^24c_dklm1*ovCeTK?K3p_xHxx?IJ}-i0oOF{iIwwI8?}T}~ z#!)Df?D`?vu1NBqhz&9D&;mG5b|BA5ZyI$>mu^XmA$4TBP?!ml);5`u<)4r3#Sk>` zri<$6U%f=J?zvzuD>|AA1Ppb{c*!6DZtGE*3m6R&hc-`X(cY3os+Ve>+YHs7X+T|@ z<)uDECG;{(fs!!9#BSx*owc@eBNniqeY>@$#3;XyMYN^+{>*~**%3L9V_Fsyg; z1qm9nZ(WTrCz}P0riGbSikShAI2!m_ka*JQtX>>uGRrN@cnCPTj>B>fh3g<=vF!aKEKQ8 zK0%-(p(Ho7a74yP$huf|QMow?V<|V8Ji|6}g*w}`Am&$=B|l@`(8@m>bOUQ3-gM#p z){RS}4q`r);Z<}r5EJv&GitC69_sf9%Qj;S&k~;#O60C42b}n)@6q|_TjlX+aWq;as@Uy z7>C98iTUKee1&}S;$!p4=Z@l&&W$4ceQs|aMfU&Y>5;v75PL6WUvJpOc9lP*RkZPJ zfNZE<%wL|Rlo<$Vy%U)>b|Ta9PGnj(b|TZV-ib`h#!h5fK3Z)nrR5{z?W1(O-IO-B zn#7bF%j`^UD9*B0xEVy!`%8BIyNd6T2*bJImCVHr)CFMEA`FKc8Tgr4w{??Wi-l$oHp4ZU!$nBEz`RtQc?wjiP2ei`Mr z(YpwTzi*07RjB|dPp{>NIk-~rZAtE=^_wNF%OlZJ?k3p&7~ou+-5G10!I0GVf%x3y zZb(i;ImoX_nZM9f{wB3R@5|e9Js~Xndk7B-@`a266dRRYB%IwmY7b)D4y&dJ?*qGI zNqL94)kUan6yC5U=Q0&uYfZ7HkPB2ivNY@zF__u8_jNn>-Fn*{`wtvEv~Tb2!zl(c zb#ZnJKP8fMKJqp8NzcQJ^fnen<-G1VJQ3-3Qf<8(j$pYJKt zo5~wm>anobroQV{+x!rolr2%5oH@E1|GRhw(Br zg7~i)8W~oFMr1_@lW;WF3=Mf8XpoTa*xA43p0cx4-hACCS}K2#%?Jh*?WweJC802{ zKzAX;N7wQK{+z)VE*RFk+9 zn`jC0RAPHEx)l~03N$1{?ucaX@yP>v(`v8WSA^!(5e4$8oVhQ6E5k{m7 z@;5h>d?9_vIFijr8^dQ!7{hE7wjmX8vKW;7f*Zs0?kEAHt^8jQAeeL75a2gQ%`L(` zPv02s2^u);WwZ7^4ukmjQ-u8FEwj(*G-(JvQKs_|4-U{`-J*`9>V^wqCGQbX0hUFkNvL|w?%Q~ zXwOV9iK>6{v6|Pg+OyJ50~AC*Q(+Ott{;7zbpdrh8eMQbKVRZU`pb4x`SCppHZD~y zq5;#m?15@FXRv;JH&`6QY;&TW&ywXWt?hJ>ihl+kO^ z7I4wc16-w2$x*pReObVaQbkPs4BHJ5HDNQxd~)Tg*8=!<4cfx29*2|WldbaHd|FUf zDzb?h=S5e$&2goKiXa?j_z75mnbRFPMJ}eur~{0nw!7e4K7De)2egu!8nw!^*xID~ z76>I(bhbtr=B)gtrJS>v7NxP1Z$u-VI!f8*Roga8i>ilZ&V5&>){wa6mdP?2+xbxLeLM!X5l)G)|7;4{+#6}w2sf`tI^GCZW5&61tOG25RBczM zhy}SjwnjJ08?iNd4P;@)u?hiygV24L)8Qoc$M+HyJ5(@Rf{4s%gyN3j8W%GRk>hb9v}iznK+8Z0hQU77!z-Y7{hT_ z!RnA2pC(#8@_OYd0A|gAz#0%wR?Waat~dh`* z!7HFpEzpzg{WLcHT)2w$Y-XXnAZWDxBV$Kv1(`N-fCuUVpX#OB8TO4vr$;bowRY5% z3^R2_Ni%`OQUe3&kGt#_O=));BR+(zz(!&7&4UGQsf0}MhcNqdMq_bBV}d=SX7rqoe;*aqUNEqNsEx&C-NHvIyBh&Fvz} z^1tmr6qTL)J&D2-yUjQEH{VR(qxDy)^IpB_sSaUxZfMFUmKh<7T((zKoRl9i(sG{! z_!D>As`{l)$6AwRPRAEJ9UF~N>symZ%a1L|OX)>JE2bSfRiO{>PpME5mzfn8&)ANf zb?&n#sbkOw(El`1{G)-MMnN z?0c$MDh8fHlg@YwBA@jX43h7Bihr}W7oB(PEM9*H`KY>74Qhci$`t^lh31xY$8dIM zJe-m_s8_>*XU>q>6$2abS7d^Wvl)fbLKb8wj)K~Rcx!<=YPL@cMrHu3Fov43f;ikZ zZep{Vz)Yn7T4sc365CWZx`GGmKABAGq{ouH5?NBO-RDD=hFUqCmIq`UF$d5GJBSnu zKiXG2fR>9CIJb7Mo{Bg*-^IyxMzdoNf3`2>?+XfRhYJ*7z!7PRYuG6h8Gn-!MLn0O z;?(rh3`fflCP8F8%!(Ij@`shopdFUBiJXf;jTz&=?A&CNqLR~+LlDAjsQ1UJ*F~Zn zuO8aMDj2&qq|GHVSp-v}P4VXf^AxUQ|>QoL1iqgvIzii24jJAm~v2Mb(OqTvz? zcQ_6XO_Vq^0p}IFn*r-Ay&(HYh^bh5lVAv8jJ9|aj?6B~To*%a<|VZX<}^^aJmZ%} zii}a2g^sv!N@RZ75cd<@XvRm4g0x}LTx+(QO%4R+h>$NLxb6Jxf=?BSxq*o^pBKS_ z32XeA)P!`P*!L(*vPs&?+@UqLvaRw5CrR-I%&p$pTHPI8n}%_PokekU&9Ve3)Odp9 z&B_R&Y?1=Yxf$yf1L4*)lJ$H0lLmsRdt2e{Z5+n9rAiCv#`pVZux$$eR59v0g6>m?HRmIL!~%!VEm!E8D|ae%t(?^Z#6#4p;F%rs*WFpZt@$ zT94}PyN%K7_ok=1op#G@jg1#`_|w`hIuHTAzqpu^0o;$g49IIj1Hw^L7c$_eWApE<7cXD3mo zzZrcZkx&$K{1|aNq`&$GdR*1$u|Mh+Ah=oPcU5MpQD!`v{+U{#O_ctCO1F<$nn`T7 z{Xvxua@5gC|FdQLLKednHb3(^%1p1^BBgC{1WpMns_nULGR<7Vx;zSqUZRXD&svf9O6Z4vGEPko)Zne zEz+8~!^75SR?TajEo%2D0_-32#bpHO1)XZ~d$tOaH?SBuOae_Nj~0UY-x2V|7Nb^g zNttNRVlvyj)Z@`;FT$i<=*qYK8Q=;PC(v-ripb{%wvJgW#p3}DacY<0rt)@x4EYhD zEBO~UoBh?w|2}wKj)!Q@{xnf-BW7YBb5vAXS=f~X*;LB31WA2X2{tV$BHc15y6=|j z^wx1c+(gReq&HkU9u~_>)2ucfYsD5e9WBMn7lZ3XAJud`vhsA)*{3=kjf!9I=|B%svu*~l}OU=OyeoJ6qtYMmcMT-F>NWF;IeIpUkS$c9f;vSF@2 z-!mCJn046@1TYoW2N}((L2BezCH1;FFBW=IJ{Oorgcm{c@B%S|YLe0-(h~6TwcW>JJ&aPHllQTS21#Bxcj?CT3mmR|u=tciVigE-or#5UCyUU{bM`=g~yS z;%Y=*$F`H^NqJP|nq7lU#grVYW?b_X`UKK2V>jy;sW``Dp zZg@v=T3FoDHfGr~cv9AWt#`?icdox7%-Lp4=#B1|RBsL4o3N${6eE^6F~yh?Hu~5Q z=mSnM`>3K1gq=v)X#|Sr?fFCZfDBiA*^X9d<|ov1We0q1V9~Ch!vdQbEI7Qha>uL{ z+;(d9>jaB9-(eA(2`|QE+lSa4f@R7*49A}%H9j=lH07v0)3>}U+Su8;G+~F!YkSt|~Oin~hU)2f3KWaES-C;Y!VaqFbWOD&i zPr4M7;5OgtvL)Rv?V!kOUWF6kmXgG6#HxsQw?M77FxqDBE0gX{A1|I{uVL-Tre70}%U&8^n6D+e~GF7zS!V%oai6g+1bu(Vz+&q^Lz zw2h`M+Pki|Goaqd{4Uh21nLc*>s_thg_bQ^p5?vOUNt%Wk)_DnkU|D;M5%!QX&jc| zPjc6dM=FjTY7}bv=!NUaCAZd7F?J^WTDj(zExFHjR^CQGCr*w1f&IgG?lf_W0t;J*>1`IeUCR|S)v(g+nkcpoXl@19`C@q-;fN=#w)Yd7K z|GueYdbuk(P=2zb`cHsP(tdrU>6o;?f*<*hVvGvBqjI>xJC##c*byJrPUWez?%5$w zmE{g)xIzIPeWpUTHRht|>##gP!3$y-ZTOXCvEu#G+~Vn-_p@oX^KaHrXyJ|Gr{G{Z zK?|bp=)&Q&n`AOrnV_a)_mWYkA~9#Ll^xF5lgD#78x&Zh%h`)jYeX1f!V;J;oCaEV zFa*%G0z$rs<9e5Y;bktGolyfK|5TF3dNKc~#+c=1dEsvzGk*iiHF`rmln^nQG0k|x z0l(vhjYBbWw9!kcvphn8)S`#CxiM7_Yeg15?$DOIi_PM#+{GZb%c`p4x{5}+mN74S zHQ~9KT!AVBo0n-bbuoDv`B2T2c-*#|E*omQ$wElXu4CKej~H~rw`|jRv~L;v)e$VF zZD?zd>yLh}70xB*DBV>|yNVOt8bG<>*7d2Dur4cR43q8?5+;?R38^4~EGM7TVc62E zE;T?_nEW#V6L#ki24Q!usQ2y|O4w4DwAB*DBo0O4t@*}s(Js?*?dz)7eQ#xxq2VV{cYgRLGcD7`(F92Ear98kX3FMcQp$I0)-r!sLs*&StwUZhfu zA9Dp-o`o%#Yz}!$hRQKCg&=rJV%Sr-?1XQPSWb}MH)g=U)EMwDeSHUfyKZoE$LaDJ z_IcJ{aofqxwN!>5Uskk&drx6ke0x$*_(3tTQj}DnA_AAVDInrXORVO2k#7Fy?;VQx zy%0ALed2xON4`kug1G#Dd5cl@6aksG7>vsgD5pgZ4kCOsjS5pHz5$;bIjj=`YVmOb z$7DxDwpd4!M-x4?v~FqkkcJ*idLbpOo@lG0Mp|g*RY5d$9@H548)^)6IYEua^VTw? zsUt`aYj|n?C&)6Bj0V49L{#p#l4RP>u_OE@Ev#lXt{FgblLb^(7_F)PpS~e%zE{}A z=!DDn{ySjuw>Fskt^eMc{Py>q8k2wd=`wlU(TSLR+`~73$@hbfr^n=V%@Z>D-#sf? z*qdoH`~aaXUH0Q-o{eTh$XOyTj-bqgl<^H7MAmGr^-UXOb@&UZDw=Lq z>vfA!omDiQcDz_nk?_;E3f|46b+4q5+`^f>y!nSHvNhVLgGS^KiONy~pI@d3Keon` zVZ40BQbBO5;xs3t>N>dMt47KXE1tzx8<_=HX64=W`6r5PN#4SVryUB7wkiUcFiziZ zC4E;s-lXDsGYU~XEMlwb$pac7^88RN*_xGyD3}sTNBu*(%u4aHRquyGJS}^Q+JQS% z^*+!lE5l`3{)0#0u!6_`6l;HkvzdDFF}>(%^8qW^uAZ>$Fha7?j5MQ5ChYiLrr2n$ zX;`*fXV?1qJK59+NtFq=DYGArNJGkhlwe7*JHp*iy zVFy*Gv4Bg-aKXFL-(k&e^qN?+t2_^D)_nWZGLChwhyof-=v9+p?eeyX>1ne^@w(3{ z@N^YK;tnW0Ukq70APn8{Zu8f#ybv}65Qw=U<}}?8SPygB=gCUHuuh(9=npsOM`rB?VZB|<6!ZDjvTc-HpIPxVk?_&7m-@E+H3_13Y~~p+U%P; z#5Pe-oQkp$SpjK~BN}W{`w~|wUb$KcG*gmKAeVXK)fuy}v2_r+~>9(C{ zI9P^#8w*TkgGS%#d0{kFiLDB|+G;!wc2PElovD07z$Nm+xK}Th;S$+3W&JHCFBl?Z z7Ly%AimA9fNJq&W^O}aE?YMJ9dciHB~xq&QjN^Auem}==WXmaFrDA z{o3heY8qPK(9b4?n--?~{VGbd!xYj&CW_<)?9J7Vap5sMk{F+~lRQ&y`bfP_m2cPw zTiMN%bcz*W=j8Eb4(&*@^=k6y@mi0-I_ib>oo*2I~OcWn(M9|zQ31eXGt_5>TFg*f-|flum}Gd?dPb^?50f}n&{V=?3FrLZr)B1{ z#qL_T#B=H;Y~HB^?ZXO*PVn`(^hOa&UPYbAoPZ3JoTG7Wmh4qGOVXuP=hQQ|c4{~J z9tv){XEal{!#VC^h8s8O0wS|6Xvj$mhk>H%)Fw0C)AfA9!zl;&^Ei@xTFBe@c$ zajk4FvdHM;5Q1$^xlcL}4)PzLhEvB>5a|~|d21x-Ors&vA)=u28YBWJc$8os^W4~p zf2R1www-BBjtO1l%vQeQjRSD!PY@~5HthL$Z|=-(bXe4cV6IYiD+O-Onzs8^?LH2d zPH*A%I+s#*SDv6lps;3vI$gN9z(Q&QyT5|a{FN8eJ}(mDEkxVVlq}|p_`#@t0Y5OY z9j0iQw!KP6Q0Y*8M(xy0TL@8RZ6Dg65I?5)(XaF#uM`(eh`|kUxX5{Aru~flVcUZqwG0ZN-L}9dC=62+^*SRCnNO z$)7abKi^zj>GQev38;AkuBQIU$A4eNtg3X3(d03Sb!UXeL1dC zKd3EkQ+r(&1X}lWp)ZaRcN@NkE>;LPIdo;!iEY4amnSwH?PX?+*OxuYULwqGfa+dsmgqsi?mER+4K z-^i2R-f21c9#4V;uZYq7A7@_6Cvk5m9A7RBH*7#m=7voY1a`0w)JJ7?qQA^c;RmZT z7WZR3=)G%zdG(+G05g%+U!LopS3ob%KMz zU$e&RryZ4n#n*Q%GKOqm_=_@pi>`@tE zJs-IVp!BxNc8bl#5tF?76Uj~Z3A}(umi7SxZYk3OQY4eV1fhv4rFXvAAx?2JS>*lTK}Aovq6proUb;z zUcS~wr3)iy{p=ykByy=>)WqofF2Zt!wSZz;!QRtMfmLfhOcO7pD)pk}FUIlbSPBr0 z=*Vh}L)>{`02vW~!e|_eG9`04CBd{-7lI4p5nU`V))R_tK!Vbm&SVCVS5Kk227S`B zFhRaFrjspGcwUI|o?9>nFbrh||W*fBYs?)^%cZ^RH``jvqa#|KpgK+9|Kj6Sf z(x-u8Op=UI6H+q}Prx^4NX`tT!t5N2RG3D^kBru7QG}^tOvp?qI@XpD4R|`0UH$an z>6{EaaIwX+ASoqe);J^`-(8j$h`#et_bY>>doqyVcQQy;IV7tc5uSvGCyCiCRUInTgDN3e-8qFK!uoqM>{!9AW&)yk zlt`AaZnzBH|88)di{8XAu}XFT1hHfKUgwyqf{~dj>e^pzNxo?N6=n-$VAhTj*{B6f$ySYR!T?GBl7k0&x3KB-#|ZD&w1y0*C? zwv*9dqQ*7^Cya*FjfSk!&q99)VakATf8w$*5#)dKk-42gRipu^OfBNJ=Fu@=?eI z#O0b-T{bGmSkWdcnO_;f-jr)zXJiz57#TVdThX9z*D4q7Xamy=SGj@#PMfY3DAOVo z1ys@sbZV`nwKA(Ceg%P9AW@<4AIjAyn=IrvQ>%#p^&9bId)vhoc6hqdELL?;X_n?a z6;{6?f+qDzJqO3qCz^Hx{U}9Zl5H6Rg5VwvOp#z<7+yqpQY3~27n4F6)B(LnOlGF@ zR95#~nC7oURYl^qMyy1YKyp!K4Q!$T+D=>?rAkR033NxHW40#&7BI=ewv6p#1HNJz z3oBd2!w*`JkL0Cbk>yJk(k$7u4^pkjBoDcoQf&X^xD-!E!V`NE?m3l2Q_I>UmyPW5 ziy!8d6_J@KwyeVA9@a`=favw`Aj0qmjWkq~Cnn;7mz7sxLgdL0=}w64p@bx!k&%0W zM%;z6jRuf+;bO&JQ{JT|OG)J2r@t+E=H8w~LS)s4CWwTPbTXmWvX#;di~oex(mu-6 z7mQ`25CN&n1DZ#Rm9C%V+z8^Z;YW+zk7g$tz+GgwZPtFYk1!FMyN5L)2U893;bbX) zmw8GKrdY;lc_`J*rnpi0)!hNu!xkj5j^9=Me+K^-M+?eIN}t-V2J!PLQf*ciS~fE? zJ2RNLSwPL%YP2u+SJysGWhW@o^8VD8VxQl4C@Ke9))>qhbC=`;soY8CJ7PpinzQNM z=@88@rU^CVyBE+D!mY8^Y&^^A?Kf zU2FtT@8X-4;X;BM?1KWkI58Ib&sIx$!E9bIcs7S{^{p>kf!0kuq^5G3>TglmPQi@3 zCoiDr5fxZ-oW5`#r(<;YxAux+SreaA6MgTac=pA7uak2~t8B7$1eHLOxY)wkfK}s( z`Pglz)N8R;Zbb{Zao6BkY}w;meO72r zqV3_NQtmw5FFr8so|a!U-gFw4crwxR?)2Q`2@70Dno=M{H9T(hE*Ol|FcmA3eX{0& zMOEA8x_*o6dT(J2f}p7yiV0xA3Hk)x;qNnP8`^bH5FqbPB~l%$VPeqO&#Z>l&PQtS zexj-iCB$`lw<5+xE&bJhP|B2I5AHKf~;i&tRdL^&$VQKC9#peU#7k zhz()st1`ydse=W%6Aa5RLKS16G1`XriO2X&&IjCY;iCymK%-~$jL8P8!<)ciyy32l zibr7*uNN4Ux2N@-k!Qo3_lvD&1ty2KB_fDT@H#<0@P-59NRVps-k=)mRfA*7LA=WS z;kANn1p|a$(O&+%O9hU^6mEay_0X>&D&qr+n-BR_ji(| z=fu&s#olZDTgf@`&j_ZoxJts92~(&TdTMjnVM%pZ9kwY(=OhZ-I@7|oip^|r@bnC= zW-KtHvU(&N7^$oh5J|Vs^!8ZK6&5WAuLEk>J9&(xor_OPPO}uJd0Dw)p5@60Nb0T= z8ry+)*Im-7;)3=8xt6JqYJ3N2=bPM*gO|KG%aa&+#a2&h+vh)clJAd(ZJP1`$#8WB z-!Cl|y(65)#p#~Bmt;}9esDO$8I>aldl7D^p0F38{_s>h=iHPplBC5pTaKp1b9L){ zT72`l>Bao`(f*&-0Nmqrmy*O8-l<=%7kEN-zvbNYK8;Q6ZHH@2hS_>r!BuW|BFrQg zXWW7ui|845pyR~Af|S&GES5#Q2)cY*2}3x4Beu2vko{zM{X}@J@3ne`eTi4#o=|ve zvkKp-EZs-se8!S9FzzWRGU&j79>d7caR#8qy{rn6;9iXf=;bL+) zm6^JjFfQ9J_p#aBEG8dG*?{Eb!|8CS--lA)3w$a#i* z2hBm$?la1b2Vs~9THd_9;E!r9G;u?BJw zIs6Y&Nf6^V3qH`f&Tm)zhQp^D#suHi0N-;1e5*WG@*55x^3vcV#?J7EMmPMO;SnC+ zaQL_|#o+s<0N-;0e1%+o4)V9)jC!^__$TI)Q)2eEtAXPXV=YUuuZH0<(Clc@;eaJDw7DBG@x9T+Wy$+^0^Qh3`ye$Y-BQ|ekye}8d29XMV8ZqN(W6;x?=q;L<%7AO#iwwAGDCRJ z@4^bw%?_vQQmr*ItB$`k?b(Hs*xc4ar4D5Vh1J%v%^=P4Fw95K{7!h`XBiGYt<$st zF{>}*tP*l{MrFv4WsO#GE~%JCQZ4_u(3WCar*R_f*z0tFaXWIvcw&0(9_V@!s#4A-_##y)Q%Q&;es^+I~s*ls) zT=p;1=;9d0xk=+(U5`_jFEY-)W%)S!D~_}OZ)KdTR~{!DzCOe#e7?P z@zW3n-YV~{eK36QOWV^{;t}1`-zpD=mxpxBoW;MKlhY(|2`H)0E8gYFS(0z@q{`ms z$v(+gBSIabAPjx>{C zyCd_c$pt-aNgg3;@lNqu`!ZV<)SYU9h0KU%1Q4B7JHMxqA+F)AWmbgk(kRn#$q z9GS2X0t-1b2adjbq*{kUEqQiq&LccK)s2Yf*WrikcUe@e?TyWA60NUo?CaML@)HT) z6{fk9QTp6rk;BQ3ZnB?6GF;jyH;>UA-xVZjZm6hyg5;c6lXJ>kLXpU5D!YCE&SVeEPk7^ zhA4THuSsDayOT!2C9ILQrQ`XW$r7wa?Q&b>B#n%L}mvhG<%P9s(a}8uJp1H7rydq z8@&X-)M2sB2p8@5Pe!+xk$>Fima_}OX3t5sv9k~JD&ipj{aBP2E~v8&dJBQgnj5xy z|2#I;)B1usA|k2_>M{k5D$0Ht@lV<|$b0WBL4 z7K6eV2oUmE$i`)P2-7N>C6ODq2^U}ORs;Y+8TQJqrL*`4`(T2_k9cTN#45tdIn;{D z2v_rI26S;(_*{j}0)2piAUX_jc0nELCR|YG_{%(4jh#>U=r{-mFZQJqh2^A|u=Zn0 zuhbq}lM zZ^PxWB0KJ@BH0x7Qb%^!Fck4#4L+Q(^MjodkT`Yhd)ef0^wM(Fg2!$kJc}xPqbsba zxPL3^4m|G)7UowkK+LyEyj!{gbpoV#pz zo`d0HQApectv;+2(t)#!wg(ty9H@0D#7cmKaDbD$68?chANTlD{u1905*7krKvRKh z{^OScHK(=EfTl8F23ZJ|y&xhF1{0=7Fxi-M1VQBZ*)|ShvW-4WL1O{oG~J;?GY!b9 z7^&tbU_ku|qMQsOJ5g3m%LJPdiRK&wgu!A2LR3w}Fy_Iw4!YO_Vnw0b!n{3WnF?ly zSo3(FMMHfoO}gQR*7PXV_^2p3-&_&#qh>f+bQlCe6Bvk0Jex=IQi8rP^;>l@}AMvDS@L^BNd&CUs<`~^tMR( z0XYt|Rn86sP%6vk{haIFi$uikX>od$aL+2r4Z9~pQ&zT*2f2Y@eSpISr2mzao4nUV z_K!XU!7#-h;biDCk$ApK#O)MfO(W9F{~UVQ>UWfyz<`LfdnTbU98B0j6f5E8)GU+` z+sh#7*Dk=ZLxr3Cf(rr~B}U)&xPK!pF!%r~?BG zfec09MxW6DKU8VAmWB=W55XkAes$=Eux8!>~L| z!Q`q5gfD3zEjQVo-C}a1?*m`!4*aYAs*>fjY(`v|GQu{h76q9;a1}JA}_+tms0-sOA_Q4UW5IOTfroZws@S8wWu-Z!iqCER=a!@Q#uN zw|f~-Q=Fcqp54LWXG0TR`Catf1r?6eGVL@ml$^B>l4+W0N_nO-H~CCkRKE0yUPuz3 zWvMA)mfAunk+`IP`+)Yz9&{VhYthTy2t7AAWJs ze8Pt9`Z4g%>B;~`7?XqG(7DQ2JclFTtB78+`6Od&{ORTx$F6RUQHo`SY~a*XDoHcG z<+ssG`O$n5|8-To5IYDEIg#zwP{ zXSw_aT2?kveE*cZqKZg)v^VRl$0+&WNV!Kf+myVc1M$^R#?!`_Hh<8 znd^A)Zei<{avvk|#0#1=0-<8{3T?eb<=SmjpqX5KIbOztv7~1$Dyw%(oQ9xu6^lj^ z7Bfi{OHw2Kc#`=~Ze?n+R@H$TjEL}l#FedB6qMk1F7xDwQEP_z>DryoK?3pUkWf|$ zgL66bz-iZKIh=ii^ZPZRkJ#aE&wkkb<0`6{EUcICi^WIdUg(jk5T;h0`FNFypR>;V zqGk486LSN?(fB0GkU0|l#-dt!~zr2ayIbBXd0!tHN!HI?AL(i8C`471|ZL4 z&>USFi;Cn+GGGFnN4**Yebg%xmDy5nq;3pjHY#I;-u~E0&kyo>-4IJ?H2$TSE}`)+ z>zBo^Coqfir<8*?Am1l8V9A!>s>Fkqz#QVFzfnJgC$1H--pC;E?Yc|Y{P}=WB(@9H z`w2m!dI&Dnh{EAQ!KA$biq@FOpC(wR4Ad_UlFUyaKG?2K+Z<}6vVf*M{E0&t_9mrZ zr@1tmpaf*lp*DlZVRKp;=Rcha5pt6L=)WF{wnWjnk;}63&CO@lhCkPQUb9sG!uXl^ zz-(#fTZw3RF!kjdGW=aqBxuw7_}$62&As6)(!CjQ^6GHgaQFLWG(BKW1{Xyvv@-;W zpw{aA-pm8w*;^Z-GOO52TS;a0)7I!ff@roSE=b_ymhR4$`>j;T2lnoj z>0zsDhMj*X<;k3UaF-1r$$vQ262`NwtXl|}=9Q4P0T_*u;v3?cu3)Fh5s4M4%?daz zs7DxzO^djQ?3Fex5Iz9CeA7bPz#R|1z{q+DezC~5zQGfvL5^CP*qZ4yo-FvHnL+SH zr#IpP4-3BN(0z9td~xgz3!}n!wGc;mYggL22%`%77orJw$_NpWJ>m*x${V;qw4|;o zo-QslQAY>^`1<1F*eI|wp#cSq%|#fK4@EpyaSgkZpusbrtTNft6mG;CipqwJw4#vY zvPk|Fs7xpgbmr(a1A94k%}oFQ3wCWV|C_*2ZXS8@bOdTKlnD%kEq07NIE3GteK-72wH#G zf;aawnL>nc@bZK;i-QU=cjmLZ6EsB*JAK0D(b9J208+rw`b;G3%ySalN;bR~Fda4Yx+W!4)qwhFct5gM4J|__%HK+;2hXyZh%+H2?Jawxd^|je zSS7@*EoJsTI^g43i5=1Qd#sXM>P8XW)(jmCXRHlU=7z$XutIMHI4p*HF}9?IuH>;R z&vqJ%WV$`LJoIC~=Uyk>k+aR=n%x<{R!o$MEHF#-v7YVzbT9O#;T+^wzH7FsvhpBX zA#cCO1OTMPf4Cr9`5U#@2hFig#J^td`vr_rD0K#z0&iNaQ73;K4=>AjcQVprEeRyM%&$MGr+G@A;QxJzh<6A7}aKD}Za(OP+Kto+1>mt!<+z74Ld2c7teCP>rBd z3B9z$GnKo~kZ7n5G{{>yp6rAeG5Cra!_RUyMUj2-Pv*ZPbJF&?w7vnaXUo{6W$uQH zbXR)aa#6S3ZMKY&ua>!wEwqe}`Zz7~PGS~LY%!_;2bB0(o7BEMs~TdrEVynP4Djh1 z>{Gc+nLYg|$c->8zMCe$9WiKf)e&8%m@i__e1oaF)4F`qp+jJR%VK?#DrIwpFLR?3 zgkTw-){k4Dnu(Md#6dqa8M#URoW9?t;xo%YTXPYU&zA*9Gj^5V%+BPyWngK^QTu$D z4Xr>p@MWeu^7f@<@#Fr83^EL4Mc&J-j5W%kKj}zgHrPNkkB0+}6>nKUoIYkyKQoCL zljqO!CfF6IBbI;E4W+X3eu9@eWZ81ZnUs|=#(G2fW!ecR!xlSMCg@3{aK*bB_vQD4 zSsI2Vxg$__qP4e1x{<&xIpnXeiA8gGxVNNF!uN;4C2zLbU}$KTP|bG!Q(#*6L~43T z9F)llfoTXw43Y-44_ij9sJ*WhU{z1z>V3p+Na8%HXC%!?zl@=hI6NIzllhlZ!e3!o z9xBjBa{N}nOAvBMlxrD8TecPHR|CPyVO!J$wKteQ|0|~gP_bjg#u+2v;$GR^iB@<< zvgEwL!VL6HCd(f|sn9<&v3z+q!}4y%mv@k?mUl6MrHZX*Q4OCn(ZjT{pu2rE(|EGw zT{DB_-As?KpCIOc=yu(2Rm}SG?h;I@cDZ>RkG9y1M-!uAj=W>%;w|?8tNU0qjLO#3 z5*}eX+bbWq=TL<4#|2IJVm@*&4__q5tiN}rRh$Y6vxDgEi1YjWFjxAHN4&>mAvR>t zCEW5nf6Hh(-10nq5BmYpMToa9QZ{3=tdg=_moc~>WF#Un5lvDjQW)utOQWd^vb|*_ zef8z1o_Y!b;;(L;j*yS)mdGh zrkGX7sZ}+mPl$N4=hrDY+r_%tj#Gzc=^1{hp4o*n_OG7NlLkZ~)|kS94d3B}Si*P@ zBd^Tt%(SOIb!!p$l~R=Lf%B0|b<4+pk!gCLbe6CwN&1dDuINbQ+vs?v^cfF1sL
  • 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 z zTpj6*h-gu9OH?Fo30qpy>;p#3uwbWET!q9a`C$ShAHEa7NB|oL_5^bfn8_q(*mJ&Oz3u z87L)Tq)wp7Ss}GWXrLB8@y|}FF!>6j`RK0f{(a3MKfXh7K|U=JAJ*}}Xc!e_xS2}K z4ZYZHQi*0U3yWZ^IEA^TS8pw*)7kc%TrJ9=5${##Z+58L;HAX_5sm|t-%cfKu#7?} z#n%WkrsXJDfk%pO)UU^n6u;TKZWg38sL@rJGWTZ3ThxlQG{ExR3gAw%NR{lD@<_POZhL5h<7Qed8=QWGdYl6PR@4-m3Q^b-k4#nfk zuxPWmICNzA?+I5010SMoV|iMtL;fIvR$;Cu@rc?H1dfmtAK@a0f+HfuZ(QVnu;NmB zuhSi{Vqj8!4!A~&XCVYZdR0$G*h=dP;IbSX;D_-QB6TPZ{N{kZj9N_bK`>0#=o{9k z^HuAkYgpGJv%|Mxw}3yQQO~vcnAnq@1=*7=*8kAg$68>=je=I~ZZ3bajgwO}Sldxf z)o>ayq<+~6i6f%YZ4ZA}5i8m%-%Q;3TUinho_NuXR-Dsa-11r#$t7aCE4#$Eo#iQI z<4T;Y)*6NS2y#@!R<&sSEcens4RwFFUG|XQs=zhnG%t0Bloh;^hWen3m@AJ%S;iIO z7D zZ@V@a-!zfUtm$q7>tHU^=QkNUMD&lU?f58l*cfRnw&$#VP_;v-HRK|u&!7DukqY=T zy_BRHu@IAnHLS>gqj=e!uL0n=fQL$>IOEc;k~W|M#$xSsTMH%hZ3{wruyNKLa!yEW z9EJ17in+#%XbnICwTYfm+v4&TH@qCn2mh0A70tg{eEzfW$$H_ut@FZpoAP#@AlW)n z{H^Ce`pd7$TjfG=S}VRUg+&_0rA1re)pt}Y#Mh)&pj9S4yriZkvNw~|6~}9Z$I|dZ zM-C}u!hI*AsEPU~Fu`mX3kh8@lf$TkCG;5dt%)MLcyQ691?SW zw1BjRBoiqf)%ertc1{_bI(?8+SS~tc;+e=!Wf0&vp2#}6jz_hYj^n3059#nJB$dOn z9jd?=4e({7S{%slJrc$?4k)BM>NL=!K}gb&;&$_dTtx<&$X_m0!XbZ|6JS~pec|MLKJSZSCVUZC<^De`Q{^V z<8F$H{J`DK$1gU!~XR)MG9TB7{$!R)MF6KS?XvLmltcX0d zh0Z!_iDoI)rC*$F6sIxNid^Y|SQf7m-y4}Mnj7TZIZpp^)8kH`ucqD zVpMBmdGN4CS!q5tdE1;u_f9238Wr`E5tDgJRLI%gRNjB^t4bWi+{w_E@uq5qLv6hh zG*eNqMx6kxAqo}}LxcnZ2PdyE1ie^`VT@kU$d%E^?Gv84eeGcw96XKecmM;CTtOKF z6C1&d%~8c?B+UL1l8yeU6)>5PDx6c@;nz^Zs=)6-C6)!M5`xd;GPAGN=Ub|1bA+i! zs_PM2#CnR84Ve8Sk#nFcV4+d8KaW}yr>k?*DGf%VSLjv${v$u7u@WSW@hYDIVenzU zb-c=FK+%MYMzso>@bkcW3y89?Y*4ZiyYs~}FoKg3H)aP{% zC@cCspfRlmuX#Z5|MzB}rA|0NFXUr#0S-$w$|8f=$q`baMD3q)F2bN@c1uOwJ?x#! z;5&Q>$r*F@HokSh;>|=qMw!U&VtI+MJ0|Wt=ba%=VY};eEvFaabRDM<-&N}B#OVe~ z;lQhOBd5&QI(-+X(BXCZZk5uq8XqJCp#DLr-^MAFewFUx^jwhVALI05oIcL!)i`~E z)5*vUu$xot3q5&Q4RCY-JA>mFnJYM)8X)s3$I}BC6;z!zj|S2^dQ;+XY$T^K%3a*E>7r*$|*De08llx6aPr#QVDr4Mt; zFhyB+_Nd}0#+^D6I(|e)LdWmXk$v_c5ae)HvVcnwECQ1%-aB5Y671$DI9YtPsuK zLaX07`<3JQhq;o%-V)(`G_MHg; z(U>wW)Ac&8?wW)7v2QW>aNt@+<71o&yXoY4YvVxCf>W8TAN~jET&ByGW@mCOGLG-p z_-=7fu04D z%UoAE_`tx6-S)-?`Ih~jA$~g?Q-EusDIojl;_9FL6WM%+m{5xAao$-|T#K_%HXtEi zZ~I1r5WY>SWH=xX&W6?lBOu%*?R%`a)MQQfSO3Trbqmin{m^{y;J_EmWZE9znyAEEv2^^YWzz! zC2@U+kMi^WJF^2=ie41ow$P)lV<}hmrtW0`k@CSm=HKh&Y&H3MgQL+Or75vBO}5L_ z#I|keK#wZkKKx(%x7bk5Ryt-Ihh;7LRupZ%Ely8xIvS^FzkFAmp5l~*4Z2rrH7x6u z7Z%d$kE^m!TF$wTHt%AY*l4#3S6M?k(XA}X!#RB$NhIJydzSmxI?`+GebGD|r-wkI zqy*5@S`VRWT;`Ni6FNoH$8rr%1!>q6N@VfgsPY`A563AAF0yPO1Drk@rAp`Vo;XD> z=I{;l-0M7dx9n2J9j9cM)hSa<{&<|8<<$9J$MSc>=cb0rxp7fPl5U*Sk>Nb8Zn2)HU{BSUQuP#sF{+kP zE9R_ACzY5W)e#*U0#*u?1{8+SCx1g?_EQ~$VX1ux5l^Ij_XvJnnRITM@O>i!igLDVxV|^Nyf~O9Krj2l9I~fSGeJewjZg0ugg7%h7 z-DZ0O*S{6*?XZfL*CRC|`n#L+CQGzJSXwuOa}n$KBza8UiVrBxpk<1EH2*a$lj+~! z;)?Xn|BMx6ZIkkn_My&!Rq<(o;0W&n?q3YeDtomDY9Sd@0~&aZ%){~2KyBQ~hr?eR zSm~gXG`JM$S@gnAF0m0IgVn2Hvp(M9!=vKm!W&k-Jt(#d!I)P{|Ay zNAsDIa}{a+2CiLf{?141csUDP>r3|T{2UI9Uk(=er&wF~^s!`b+hT)7kZ!`uJE)OI zi~u~!S*-ebST1rvnxaJ*QMIcr=orVjAqTI*Vdd)i0pYOemKVDX`@{*n4McUrX9H2y zlYIZC>Ji$bCKWBnOe;ZOo8RIj{z=_c;xdHpc1p5ixbt&m*y?+7G!YlY-e z6rYVV>4ijMR|&lpmI+KHYtTLb8A=4X7$K2Qpo}Hq9pwB4a0InlyA{OIdba$n7!myH z1@6U-#28#G@yQ|niks?B_6YcTWH+S1lobJsL?M zlX)Zi8N`{snro52x<@Gi&fG-ZYJjRHggT(AFR25n&3S-oR!ps}1FBxmeH<{zloF0| zMJCq@K*);8wX_7stB%MEQ>98*G=t~OBt*y7GOVK3<-am}C)Wy8&5CQ#C$>=Ipqx+u zz__J%r56C>kg(x@<=Ot3P>4l-2Vl6^4@dpO!nLR#prFTs7pn_uZ$7y`-Yk9tq>WGE zdx3Ra17Pu2ZyEjuAD$|tCOErRV#*24hYk@E!&39LL^e5|Uh9vY_C0DCF2%1;ZOBdP zcaq|$!qX&@fJd`fKqI8LRNR-`F-U_Xb=#lYvDX?%=7?msg8Cr!M{rra%G{)=Xj z5y@`uZtUr9F0$tcW=qcUp?r`w9Qd3nkW*y0-%lF;F2CR1&>!_A@UQL=AY5SMKgq3$ z{X-e}wH%POKgq+^{`hvn*4O~;Vk_^SX#DuzhIl;pt0I^1%^D3A)V`*zk=*+r-At{G zV77Tl_$+N#Rs&s3q}UP|@DBt}4gL7`j$*CF%pc4)ipPr+ zXR(OS3#M!rju+y@JkzithMLgW-rbm7OLBUSUt$}Q7vGf)w!Mtv*r4j^WEkOqAy_U- zEuq?F#dSzqYFf33Juh0?twT-<$>K={h!I^2UVL3Me6&noJ-HTTO3zqoYcMU_%kT@o z&w;_R3iVpq1?;a?RH3g{ZrW5U@~cv-gkMvC^muAJ~a>cy$P~g`az+LaX zO0hP|RaUdBPyBVMkxHdMgj}15oeK50LyABNUwJ)!i+K`_kkOEH; zVrN#IacQ_Z#KQeI*(WfasKqk)0ZklT=~p$W zoogEpHikjlL*Hk`IewM&F2~TqnlqRLCMejWifWYam;T!{{2xf~Pp<7Yi|q>EH-P(q z!5YO*NdXfD8$cfc7xdYERoMo;-a8v*jl#-EBv#&$9ffbBUqLR(iqoD*0yNvHf>X2; z-;kb5!HHS{+Ye>M@mc};KzkIKTZdQ{Yq%%|&}!Hu7+&VJ9^6`F!(Wea{VfcP$uIp8 z`VL71Nqj};Z~h+%3!u!x&lDtt4(_7VyF}mVMnx0NtqD2MM!F5A0->f`>l#fiH`yPO zJF86f2f1(N^~XomA9t}?iE^x{yVt8j89(cf4F7+!ajuwuM`e+uxi!gLxCTP)zfQG} z4F5p4oh?r;a`IO;jyRdr@PXwz{3V^7El)0T@=GeYWRoo(ezBDvPEaBq4ip#<2O*3T zfp~uS94CJGBsKBFr^}OBPW}jQl4)LiEE&-`z4_9x5S$8H(x177ii|wYs}HpkK(($ z|2|l{*%+j>5i>Q!(&fo%e6)ruFWN9_kco7qPGAHMV(H*kbi46UDNq=YEf^WPV??dU zJ-%-_I^@`PCL4hCoRNgZAjO$#EnPiGUmMuw;~2p7Vzk$=4eC3DZGOhx643ZtuXk*F z!G=+TOk^~5j&n(Dd&Vfz0Na)_CdanB2gv5f+b)KvbWNf4)g#*(^Y~p`iCjAZF5&Sr z($@L-6N@rWv*>Iz0kDQw@Z=%98u;OYUg8A)8wv`3%Ju-gu3Q{JTnoIljax5DR9Bf> zsgcXc94nDQ$fU9cVzXFAS(!vHeOMQQR$DPk7&89O#Hg-gsA8<>FJ}nhG6jYrBu=6; zbqe-L`2)B_Em^Qj8CE%!_vvtx^x2t2aE#f|_>1|+?Xl#{jb^m?D?65Azo@aHAhX

    *_{r(2hH|=zL)8(i(Y_Nl} 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˔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

    ox_qM>W2bHDgNrF3IV>(9I8@YBU&p) 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

      m==mJaZymj_IQpvn59|3X&q2lY2Y{Wr!mp{q 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 F{|`2uo0k9p diff --git a/x/dex/types/alias.go b/x/dex/types/alias.go deleted file mode 100644 index e506036314..0000000000 --- a/x/dex/types/alias.go +++ /dev/null @@ -1,24 +0,0 @@ -package types - -import ( - "fmt" - "strings" -) - -type ( - ContractAddress string - PairString string -) - -const PairDelim = "|" - -func GetPairString(pair *Pair) PairString { - return PairString( - fmt.Sprintf("%s%s%s", pair.PriceDenom, PairDelim, pair.AssetDenom), - ) -} - -func GetPriceAssetString(pairString PairString) (string, string) { - output := strings.Split(string(pairString), "|") - return output[0], output[1] -} diff --git a/x/dex/types/alias_test.go b/x/dex/types/alias_test.go deleted file mode 100644 index 76736bb99c..0000000000 --- a/x/dex/types/alias_test.go +++ /dev/null @@ -1,20 +0,0 @@ -package types_test - -import ( - "testing" - - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestGetPairString(t *testing.T) { - pair := types.Pair{PriceDenom: "USDC", AssetDenom: "ATOM"} - expected := types.PairString("USDC|ATOM") - require.Equal(t, expected, types.GetPairString(&pair)) -} - -func TestGetPriceAssetString(t *testing.T) { - priceDenom, assetDenom := types.GetPriceAssetString(types.PairString("USDC|ATOM")) - require.Equal(t, "USDC", priceDenom) - require.Equal(t, "ATOM", assetDenom) -} diff --git a/x/dex/types/asset_list.pb.go b/x/dex/types/asset_list.pb.go deleted file mode 100644 index 4ae77c2d83..0000000000 --- a/x/dex/types/asset_list.pb.go +++ /dev/null @@ -1,768 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/asset_list.proto - -package types - -import ( - fmt "fmt" - types "github.com/cosmos/cosmos-sdk/x/bank/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type AssetIBCInfo struct { - SourceChannel string `protobuf:"bytes,1,opt,name=sourceChannel,proto3" json:"source_channel"` - DstChannel string `protobuf:"bytes,2,opt,name=dstChannel,proto3" json:"dst_channel"` - SourceDenom string `protobuf:"bytes,3,opt,name=sourceDenom,proto3" json:"source_denom"` - SourceChainID string `protobuf:"bytes,4,opt,name=sourceChainID,proto3" json:"source_chain_id"` -} - -func (m *AssetIBCInfo) Reset() { *m = AssetIBCInfo{} } -func (m *AssetIBCInfo) String() string { return proto.CompactTextString(m) } -func (*AssetIBCInfo) ProtoMessage() {} -func (*AssetIBCInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_65992190d1b6a2ed, []int{0} -} -func (m *AssetIBCInfo) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *AssetIBCInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_AssetIBCInfo.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *AssetIBCInfo) XXX_Merge(src proto.Message) { - xxx_messageInfo_AssetIBCInfo.Merge(m, src) -} -func (m *AssetIBCInfo) XXX_Size() int { - return m.Size() -} -func (m *AssetIBCInfo) XXX_DiscardUnknown() { - xxx_messageInfo_AssetIBCInfo.DiscardUnknown(m) -} - -var xxx_messageInfo_AssetIBCInfo proto.InternalMessageInfo - -func (m *AssetIBCInfo) GetSourceChannel() string { - if m != nil { - return m.SourceChannel - } - return "" -} - -func (m *AssetIBCInfo) GetDstChannel() string { - if m != nil { - return m.DstChannel - } - return "" -} - -func (m *AssetIBCInfo) GetSourceDenom() string { - if m != nil { - return m.SourceDenom - } - return "" -} - -func (m *AssetIBCInfo) GetSourceChainID() string { - if m != nil { - return m.SourceChainID - } - return "" -} - -type AssetMetadata struct { - IbcInfo *AssetIBCInfo `protobuf:"bytes,1,opt,name=ibcInfo,proto3" json:"ibc_info"` - TypeAsset string `protobuf:"bytes,2,opt,name=type_asset,json=typeAsset,proto3" json:"type_asset"` - Metadata types.Metadata `protobuf:"bytes,3,opt,name=metadata,proto3" json:"metadata"` -} - -func (m *AssetMetadata) Reset() { *m = AssetMetadata{} } -func (m *AssetMetadata) String() string { return proto.CompactTextString(m) } -func (*AssetMetadata) ProtoMessage() {} -func (*AssetMetadata) Descriptor() ([]byte, []int) { - return fileDescriptor_65992190d1b6a2ed, []int{1} -} -func (m *AssetMetadata) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *AssetMetadata) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_AssetMetadata.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *AssetMetadata) XXX_Merge(src proto.Message) { - xxx_messageInfo_AssetMetadata.Merge(m, src) -} -func (m *AssetMetadata) XXX_Size() int { - return m.Size() -} -func (m *AssetMetadata) XXX_DiscardUnknown() { - xxx_messageInfo_AssetMetadata.DiscardUnknown(m) -} - -var xxx_messageInfo_AssetMetadata proto.InternalMessageInfo - -func (m *AssetMetadata) GetIbcInfo() *AssetIBCInfo { - if m != nil { - return m.IbcInfo - } - return nil -} - -func (m *AssetMetadata) GetTypeAsset() string { - if m != nil { - return m.TypeAsset - } - return "" -} - -func (m *AssetMetadata) GetMetadata() types.Metadata { - if m != nil { - return m.Metadata - } - return types.Metadata{} -} - -func init() { - proto.RegisterType((*AssetIBCInfo)(nil), "seiprotocol.seichain.dex.AssetIBCInfo") - proto.RegisterType((*AssetMetadata)(nil), "seiprotocol.seichain.dex.AssetMetadata") -} - -func init() { proto.RegisterFile("dex/asset_list.proto", fileDescriptor_65992190d1b6a2ed) } - -var fileDescriptor_65992190d1b6a2ed = []byte{ - // 404 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x74, 0x52, 0x31, 0xcf, 0xd3, 0x30, - 0x10, 0x4d, 0x00, 0xc1, 0xf7, 0x39, 0xfd, 0xda, 0xca, 0x74, 0x88, 0x2a, 0x91, 0xa0, 0x0e, 0x88, - 0xa5, 0xb6, 0x5a, 0x16, 0x18, 0x49, 0x2b, 0xa1, 0x0a, 0xc1, 0x90, 0x91, 0x25, 0x72, 0x1c, 0xb7, - 0xb5, 0x68, 0xec, 0xaa, 0x76, 0x51, 0xf9, 0x17, 0xfc, 0xac, 0x8e, 0x1d, 0x91, 0x90, 0x22, 0xd4, - 0x2e, 0x28, 0xbf, 0x02, 0xd9, 0x49, 0x4a, 0x3a, 0xb0, 0x3d, 0xdf, 0xdd, 0xbb, 0x7b, 0xef, 0xce, - 0x60, 0x90, 0xb1, 0x03, 0x26, 0x4a, 0x31, 0x9d, 0x6c, 0xb8, 0xd2, 0x68, 0xbb, 0x93, 0x5a, 0x42, - 0x5f, 0x31, 0x6e, 0x11, 0x95, 0x1b, 0xa4, 0x18, 0xa7, 0x6b, 0xc2, 0x05, 0xca, 0xd8, 0x61, 0x18, - 0x50, 0xa9, 0x72, 0xa9, 0x70, 0x4a, 0xc4, 0x57, 0xfc, 0x6d, 0x92, 0x32, 0x4d, 0x26, 0xf6, 0x51, - 0x31, 0x87, 0x83, 0x95, 0x5c, 0x49, 0x0b, 0xb1, 0x41, 0x55, 0x74, 0xf4, 0xc7, 0x05, 0x9d, 0xf7, - 0x66, 0xc8, 0x22, 0x9a, 0x2d, 0xc4, 0x52, 0xc2, 0xb7, 0xe0, 0x41, 0xc9, 0xfd, 0x8e, 0xb2, 0xd9, - 0x9a, 0x08, 0xc1, 0x36, 0xbe, 0xfb, 0xd2, 0x7d, 0x7d, 0x1f, 0xc1, 0xb2, 0x08, 0xbb, 0x55, 0x22, - 0xa1, 0x55, 0x26, 0xbe, 0x2d, 0x84, 0x18, 0x80, 0x4c, 0xe9, 0x86, 0xf6, 0xc8, 0xd2, 0x7a, 0x65, - 0x11, 0x7a, 0x99, 0xd2, 0x57, 0x4e, 0xab, 0x04, 0x4e, 0x81, 0x57, 0x75, 0x98, 0x33, 0x21, 0x73, - 0xff, 0xb1, 0x65, 0xf4, 0xcb, 0x22, 0xec, 0xd4, 0x83, 0x32, 0x13, 0x8f, 0xdb, 0x45, 0xf0, 0x5d, - 0x4b, 0x1e, 0x17, 0x8b, 0xb9, 0xff, 0xc4, 0xb2, 0x9e, 0x97, 0x45, 0xd8, 0xfb, 0x27, 0x8f, 0x8b, - 0x84, 0x67, 0xf1, 0x6d, 0xe5, 0xe8, 0x97, 0x0b, 0x1e, 0xac, 0xd5, 0x4f, 0x4c, 0x93, 0x8c, 0x68, - 0x02, 0x3f, 0x83, 0x67, 0x3c, 0xa5, 0xc6, 0xb6, 0x75, 0xe9, 0x4d, 0x5f, 0xa1, 0xff, 0xad, 0x17, - 0xb5, 0x97, 0x14, 0x75, 0xca, 0x22, 0xbc, 0xe3, 0x29, 0x4d, 0xb8, 0x58, 0xca, 0xb8, 0x69, 0x02, - 0xc7, 0x00, 0xe8, 0xef, 0x5b, 0x96, 0xd8, 0xab, 0xd5, 0x1b, 0xe8, 0x96, 0x45, 0xd8, 0x8a, 0xc6, - 0xf7, 0x06, 0xdb, 0x66, 0xf0, 0x23, 0xb8, 0xcb, 0x6b, 0x29, 0xd6, 0xbc, 0x37, 0x7d, 0x81, 0xaa, - 0x23, 0x22, 0x7b, 0xb7, 0xfa, 0x88, 0xa8, 0xd1, 0x1b, 0xf5, 0x8f, 0x45, 0xe8, 0x98, 0xd1, 0x0d, - 0x2d, 0xbe, 0xa2, 0xe8, 0xc3, 0xf1, 0x1c, 0xb8, 0xa7, 0x73, 0xe0, 0xfe, 0x3e, 0x07, 0xee, 0x8f, - 0x4b, 0xe0, 0x9c, 0x2e, 0x81, 0xf3, 0xf3, 0x12, 0x38, 0x5f, 0xc6, 0x2b, 0xae, 0xd7, 0xfb, 0x14, - 0x51, 0x99, 0x63, 0xc5, 0xf8, 0xb8, 0xf1, 0x67, 0x1f, 0xd6, 0x20, 0x3e, 0x60, 0xf3, 0xd9, 0x8c, - 0x32, 0x95, 0x3e, 0xb5, 0xf9, 0x37, 0x7f, 0x03, 0x00, 0x00, 0xff, 0xff, 0xa7, 0xaa, 0x78, 0x83, - 0x80, 0x02, 0x00, 0x00, -} - -func (m *AssetIBCInfo) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *AssetIBCInfo) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *AssetIBCInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.SourceChainID) > 0 { - i -= len(m.SourceChainID) - copy(dAtA[i:], m.SourceChainID) - i = encodeVarintAssetList(dAtA, i, uint64(len(m.SourceChainID))) - i-- - dAtA[i] = 0x22 - } - if len(m.SourceDenom) > 0 { - i -= len(m.SourceDenom) - copy(dAtA[i:], m.SourceDenom) - i = encodeVarintAssetList(dAtA, i, uint64(len(m.SourceDenom))) - i-- - dAtA[i] = 0x1a - } - if len(m.DstChannel) > 0 { - i -= len(m.DstChannel) - copy(dAtA[i:], m.DstChannel) - i = encodeVarintAssetList(dAtA, i, uint64(len(m.DstChannel))) - i-- - dAtA[i] = 0x12 - } - if len(m.SourceChannel) > 0 { - i -= len(m.SourceChannel) - copy(dAtA[i:], m.SourceChannel) - i = encodeVarintAssetList(dAtA, i, uint64(len(m.SourceChannel))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *AssetMetadata) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *AssetMetadata) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *AssetMetadata) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - { - size, err := m.Metadata.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintAssetList(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - if len(m.TypeAsset) > 0 { - i -= len(m.TypeAsset) - copy(dAtA[i:], m.TypeAsset) - i = encodeVarintAssetList(dAtA, i, uint64(len(m.TypeAsset))) - i-- - dAtA[i] = 0x12 - } - if m.IbcInfo != nil { - { - size, err := m.IbcInfo.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintAssetList(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func encodeVarintAssetList(dAtA []byte, offset int, v uint64) int { - offset -= sovAssetList(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *AssetIBCInfo) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.SourceChannel) - if l > 0 { - n += 1 + l + sovAssetList(uint64(l)) - } - l = len(m.DstChannel) - if l > 0 { - n += 1 + l + sovAssetList(uint64(l)) - } - l = len(m.SourceDenom) - if l > 0 { - n += 1 + l + sovAssetList(uint64(l)) - } - l = len(m.SourceChainID) - if l > 0 { - n += 1 + l + sovAssetList(uint64(l)) - } - return n -} - -func (m *AssetMetadata) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.IbcInfo != nil { - l = m.IbcInfo.Size() - n += 1 + l + sovAssetList(uint64(l)) - } - l = len(m.TypeAsset) - if l > 0 { - n += 1 + l + sovAssetList(uint64(l)) - } - l = m.Metadata.Size() - n += 1 + l + sovAssetList(uint64(l)) - return n -} - -func sovAssetList(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozAssetList(x uint64) (n int) { - return sovAssetList(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *AssetIBCInfo) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowAssetList - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: AssetIBCInfo: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: AssetIBCInfo: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field SourceChannel", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowAssetList - } - 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 ErrInvalidLengthAssetList - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthAssetList - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.SourceChannel = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field DstChannel", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowAssetList - } - 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 ErrInvalidLengthAssetList - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthAssetList - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.DstChannel = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field SourceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowAssetList - } - 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 ErrInvalidLengthAssetList - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthAssetList - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.SourceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field SourceChainID", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowAssetList - } - 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 ErrInvalidLengthAssetList - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthAssetList - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.SourceChainID = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipAssetList(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthAssetList - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *AssetMetadata) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowAssetList - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: AssetMetadata: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: AssetMetadata: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field IbcInfo", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowAssetList - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthAssetList - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthAssetList - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.IbcInfo == nil { - m.IbcInfo = &AssetIBCInfo{} - } - if err := m.IbcInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field TypeAsset", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowAssetList - } - 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 ErrInvalidLengthAssetList - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthAssetList - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.TypeAsset = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Metadata", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowAssetList - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthAssetList - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthAssetList - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Metadata.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipAssetList(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthAssetList - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipAssetList(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowAssetList - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowAssetList - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowAssetList - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthAssetList - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupAssetList - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthAssetList - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthAssetList = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowAssetList = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupAssetList = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/codec.go b/x/dex/types/codec.go deleted file mode 100644 index 1dcfae37c3..0000000000 --- a/x/dex/types/codec.go +++ /dev/null @@ -1,71 +0,0 @@ -package types - -import ( - "github.com/cosmos/cosmos-sdk/codec" - cdctypes "github.com/cosmos/cosmos-sdk/codec/types" - cryptocodec "github.com/cosmos/cosmos-sdk/crypto/codec" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/types/msgservice" - govtypes "github.com/cosmos/cosmos-sdk/x/gov/types" -) - -func RegisterCodec(cdc *codec.LegacyAmino) { - cdc.RegisterConcrete(&MsgPlaceOrders{}, "dex/MsgPlaceOrders", nil) - cdc.RegisterConcrete(&MsgCancelOrders{}, "dex/MsgCancelOrders", nil) - cdc.RegisterConcrete(&MsgRegisterContract{}, "dex/MsgRegisterContract", nil) - cdc.RegisterConcrete(&MsgRegisterPairs{}, "dex/MsgRegisterPairs", nil) - cdc.RegisterConcrete(&MsgUpdatePriceTickSize{}, "dex/MsgUpdatePriceTickSize", nil) - cdc.RegisterConcrete(&MsgUpdateQuantityTickSize{}, "dex/MsgUpdateQuantityTickSize", nil) - cdc.RegisterConcrete(&AddAssetMetadataProposal{}, "dex/AddAssetMetadataProposal", nil) - cdc.RegisterConcrete(&MsgUnregisterContract{}, "dex/MsgUnregisterContract", nil) - cdc.RegisterConcrete(&MsgContractDepositRent{}, "dex/MsgContractDepositRent", nil) - cdc.RegisterConcrete(&MsgUnsuspendContract{}, "dex/MsgUnsuspendContract", nil) - // this line is used by starport scaffolding # 2 -} - -func RegisterInterfaces(registry cdctypes.InterfaceRegistry) { - registry.RegisterImplementations((*sdk.Msg)(nil), - &MsgPlaceOrders{}, - ) - registry.RegisterImplementations((*sdk.Msg)(nil), - &MsgCancelOrders{}, - ) - registry.RegisterImplementations((*sdk.Msg)(nil), - &MsgRegisterContract{}, - ) - registry.RegisterImplementations((*sdk.Msg)(nil), - &MsgRegisterPairs{}, - ) - registry.RegisterImplementations((*sdk.Msg)(nil), - &MsgUpdatePriceTickSize{}, - ) - registry.RegisterImplementations((*sdk.Msg)(nil), - &MsgUpdateQuantityTickSize{}, - ) - registry.RegisterImplementations((*govtypes.Content)(nil), - &AddAssetMetadataProposal{}, - ) - registry.RegisterImplementations((*sdk.Msg)(nil), - &MsgUnregisterContract{}, - ) - registry.RegisterImplementations((*sdk.Msg)(nil), - &MsgContractDepositRent{}, - ) - registry.RegisterImplementations((*sdk.Msg)(nil), - &MsgUnsuspendContract{}, - ) - // this line is used by starport scaffolding # 3 - - msgservice.RegisterMsgServiceDesc(registry, &_Msg_serviceDesc) -} - -var ( - Amino = codec.NewLegacyAmino() - ModuleCdc = codec.NewProtoCodec(cdctypes.NewInterfaceRegistry()) -) - -func init() { - RegisterCodec(Amino) - cryptocodec.RegisterCrypto(Amino) - Amino.Seal() -} diff --git a/x/dex/types/contract.pb.go b/x/dex/types/contract.pb.go deleted file mode 100644 index 7014291577..0000000000 --- a/x/dex/types/contract.pb.go +++ /dev/null @@ -1,1902 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/contract.proto - -package types - -import ( - fmt "fmt" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type ContractInfo struct { - CodeId uint64 `protobuf:"varint,1,opt,name=codeId,proto3" json:"codeId,omitempty"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contractAddr,omitempty"` - NeedHook bool `protobuf:"varint,3,opt,name=needHook,proto3" json:"needHook,omitempty"` - NeedOrderMatching bool `protobuf:"varint,4,opt,name=needOrderMatching,proto3" json:"needOrderMatching,omitempty"` - Dependencies []*ContractDependencyInfo `protobuf:"bytes,5,rep,name=dependencies,proto3" json:"dependencies,omitempty"` - NumIncomingDependencies int64 `protobuf:"varint,6,opt,name=numIncomingDependencies,proto3" json:"numIncomingDependencies,omitempty"` -} - -func (m *ContractInfo) Reset() { *m = ContractInfo{} } -func (m *ContractInfo) String() string { return proto.CompactTextString(m) } -func (*ContractInfo) ProtoMessage() {} -func (*ContractInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_ee35557664974a8a, []int{0} -} -func (m *ContractInfo) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *ContractInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_ContractInfo.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *ContractInfo) XXX_Merge(src proto.Message) { - xxx_messageInfo_ContractInfo.Merge(m, src) -} -func (m *ContractInfo) XXX_Size() int { - return m.Size() -} -func (m *ContractInfo) XXX_DiscardUnknown() { - xxx_messageInfo_ContractInfo.DiscardUnknown(m) -} - -var xxx_messageInfo_ContractInfo proto.InternalMessageInfo - -func (m *ContractInfo) GetCodeId() uint64 { - if m != nil { - return m.CodeId - } - return 0 -} - -func (m *ContractInfo) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *ContractInfo) GetNeedHook() bool { - if m != nil { - return m.NeedHook - } - return false -} - -func (m *ContractInfo) GetNeedOrderMatching() bool { - if m != nil { - return m.NeedOrderMatching - } - return false -} - -func (m *ContractInfo) GetDependencies() []*ContractDependencyInfo { - if m != nil { - return m.Dependencies - } - return nil -} - -func (m *ContractInfo) GetNumIncomingDependencies() int64 { - if m != nil { - return m.NumIncomingDependencies - } - return 0 -} - -type ContractInfoV2 struct { - CodeId uint64 `protobuf:"varint,1,opt,name=codeId,proto3" json:"codeId,omitempty"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contractAddr,omitempty"` - NeedHook bool `protobuf:"varint,3,opt,name=needHook,proto3" json:"needHook,omitempty"` - NeedOrderMatching bool `protobuf:"varint,4,opt,name=needOrderMatching,proto3" json:"needOrderMatching,omitempty"` - Dependencies []*ContractDependencyInfo `protobuf:"bytes,5,rep,name=dependencies,proto3" json:"dependencies,omitempty"` - NumIncomingDependencies int64 `protobuf:"varint,6,opt,name=numIncomingDependencies,proto3" json:"numIncomingDependencies,omitempty"` - Creator string `protobuf:"bytes,7,opt,name=creator,proto3" json:"creator,omitempty"` - RentBalance uint64 `protobuf:"varint,8,opt,name=rentBalance,proto3" json:"rentBalance,omitempty"` - Suspended bool `protobuf:"varint,9,opt,name=suspended,proto3" json:"suspended,omitempty"` - SuspensionReason string `protobuf:"bytes,10,opt,name=suspensionReason,proto3" json:"suspensionReason,omitempty"` -} - -func (m *ContractInfoV2) Reset() { *m = ContractInfoV2{} } -func (m *ContractInfoV2) String() string { return proto.CompactTextString(m) } -func (*ContractInfoV2) ProtoMessage() {} -func (*ContractInfoV2) Descriptor() ([]byte, []int) { - return fileDescriptor_ee35557664974a8a, []int{1} -} -func (m *ContractInfoV2) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *ContractInfoV2) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_ContractInfoV2.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *ContractInfoV2) XXX_Merge(src proto.Message) { - xxx_messageInfo_ContractInfoV2.Merge(m, src) -} -func (m *ContractInfoV2) XXX_Size() int { - return m.Size() -} -func (m *ContractInfoV2) XXX_DiscardUnknown() { - xxx_messageInfo_ContractInfoV2.DiscardUnknown(m) -} - -var xxx_messageInfo_ContractInfoV2 proto.InternalMessageInfo - -func (m *ContractInfoV2) GetCodeId() uint64 { - if m != nil { - return m.CodeId - } - return 0 -} - -func (m *ContractInfoV2) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *ContractInfoV2) GetNeedHook() bool { - if m != nil { - return m.NeedHook - } - return false -} - -func (m *ContractInfoV2) GetNeedOrderMatching() bool { - if m != nil { - return m.NeedOrderMatching - } - return false -} - -func (m *ContractInfoV2) GetDependencies() []*ContractDependencyInfo { - if m != nil { - return m.Dependencies - } - return nil -} - -func (m *ContractInfoV2) GetNumIncomingDependencies() int64 { - if m != nil { - return m.NumIncomingDependencies - } - return 0 -} - -func (m *ContractInfoV2) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *ContractInfoV2) GetRentBalance() uint64 { - if m != nil { - return m.RentBalance - } - return 0 -} - -func (m *ContractInfoV2) GetSuspended() bool { - if m != nil { - return m.Suspended - } - return false -} - -func (m *ContractInfoV2) GetSuspensionReason() string { - if m != nil { - return m.SuspensionReason - } - return "" -} - -// suppose A is first registered and depends on X, then B is added and depends on X, -// and then C is added and depends on X, then A is the elder sibling to B and B is -// the younger sibling to A, and B is the elder sibling to C and C is the younger to B -type ContractDependencyInfo struct { - Dependency string `protobuf:"bytes,1,opt,name=dependency,proto3" json:"dependency,omitempty"` - ImmediateElderSibling string `protobuf:"bytes,2,opt,name=immediateElderSibling,proto3" json:"immediateElderSibling,omitempty"` - ImmediateYoungerSibling string `protobuf:"bytes,3,opt,name=immediateYoungerSibling,proto3" json:"immediateYoungerSibling,omitempty"` -} - -func (m *ContractDependencyInfo) Reset() { *m = ContractDependencyInfo{} } -func (m *ContractDependencyInfo) String() string { return proto.CompactTextString(m) } -func (*ContractDependencyInfo) ProtoMessage() {} -func (*ContractDependencyInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_ee35557664974a8a, []int{2} -} -func (m *ContractDependencyInfo) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *ContractDependencyInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_ContractDependencyInfo.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *ContractDependencyInfo) XXX_Merge(src proto.Message) { - xxx_messageInfo_ContractDependencyInfo.Merge(m, src) -} -func (m *ContractDependencyInfo) XXX_Size() int { - return m.Size() -} -func (m *ContractDependencyInfo) XXX_DiscardUnknown() { - xxx_messageInfo_ContractDependencyInfo.DiscardUnknown(m) -} - -var xxx_messageInfo_ContractDependencyInfo proto.InternalMessageInfo - -func (m *ContractDependencyInfo) GetDependency() string { - if m != nil { - return m.Dependency - } - return "" -} - -func (m *ContractDependencyInfo) GetImmediateElderSibling() string { - if m != nil { - return m.ImmediateElderSibling - } - return "" -} - -func (m *ContractDependencyInfo) GetImmediateYoungerSibling() string { - if m != nil { - return m.ImmediateYoungerSibling - } - return "" -} - -type LegacyContractInfo struct { - CodeId uint64 `protobuf:"varint,1,opt,name=codeId,proto3" json:"codeId,omitempty"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contractAddr,omitempty"` - NeedHook bool `protobuf:"varint,3,opt,name=needHook,proto3" json:"needHook,omitempty"` - NeedOrderMatching bool `protobuf:"varint,4,opt,name=needOrderMatching,proto3" json:"needOrderMatching,omitempty"` - DependentContractAddrs []string `protobuf:"bytes,5,rep,name=dependentContractAddrs,proto3" json:"dependentContractAddrs,omitempty"` -} - -func (m *LegacyContractInfo) Reset() { *m = LegacyContractInfo{} } -func (m *LegacyContractInfo) String() string { return proto.CompactTextString(m) } -func (*LegacyContractInfo) ProtoMessage() {} -func (*LegacyContractInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_ee35557664974a8a, []int{3} -} -func (m *LegacyContractInfo) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *LegacyContractInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_LegacyContractInfo.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *LegacyContractInfo) XXX_Merge(src proto.Message) { - xxx_messageInfo_LegacyContractInfo.Merge(m, src) -} -func (m *LegacyContractInfo) XXX_Size() int { - return m.Size() -} -func (m *LegacyContractInfo) XXX_DiscardUnknown() { - xxx_messageInfo_LegacyContractInfo.DiscardUnknown(m) -} - -var xxx_messageInfo_LegacyContractInfo proto.InternalMessageInfo - -func (m *LegacyContractInfo) GetCodeId() uint64 { - if m != nil { - return m.CodeId - } - return 0 -} - -func (m *LegacyContractInfo) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *LegacyContractInfo) GetNeedHook() bool { - if m != nil { - return m.NeedHook - } - return false -} - -func (m *LegacyContractInfo) GetNeedOrderMatching() bool { - if m != nil { - return m.NeedOrderMatching - } - return false -} - -func (m *LegacyContractInfo) GetDependentContractAddrs() []string { - if m != nil { - return m.DependentContractAddrs - } - return nil -} - -type DownsteamContracts struct { - ContractAddrs []string `protobuf:"bytes,1,rep,name=contractAddrs,proto3" json:"contractAddrs,omitempty"` -} - -func (m *DownsteamContracts) Reset() { *m = DownsteamContracts{} } -func (m *DownsteamContracts) String() string { return proto.CompactTextString(m) } -func (*DownsteamContracts) ProtoMessage() {} -func (*DownsteamContracts) Descriptor() ([]byte, []int) { - return fileDescriptor_ee35557664974a8a, []int{4} -} -func (m *DownsteamContracts) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *DownsteamContracts) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_DownsteamContracts.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *DownsteamContracts) XXX_Merge(src proto.Message) { - xxx_messageInfo_DownsteamContracts.Merge(m, src) -} -func (m *DownsteamContracts) XXX_Size() int { - return m.Size() -} -func (m *DownsteamContracts) XXX_DiscardUnknown() { - xxx_messageInfo_DownsteamContracts.DiscardUnknown(m) -} - -var xxx_messageInfo_DownsteamContracts proto.InternalMessageInfo - -func (m *DownsteamContracts) GetContractAddrs() []string { - if m != nil { - return m.ContractAddrs - } - return nil -} - -func init() { - proto.RegisterType((*ContractInfo)(nil), "seiprotocol.seichain.dex.ContractInfo") - proto.RegisterType((*ContractInfoV2)(nil), "seiprotocol.seichain.dex.ContractInfoV2") - proto.RegisterType((*ContractDependencyInfo)(nil), "seiprotocol.seichain.dex.ContractDependencyInfo") - proto.RegisterType((*LegacyContractInfo)(nil), "seiprotocol.seichain.dex.LegacyContractInfo") - proto.RegisterType((*DownsteamContracts)(nil), "seiprotocol.seichain.dex.DownsteamContracts") -} - -func init() { proto.RegisterFile("dex/contract.proto", fileDescriptor_ee35557664974a8a) } - -var fileDescriptor_ee35557664974a8a = []byte{ - // 481 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xec, 0x54, 0x41, 0x8b, 0x13, 0x31, - 0x14, 0x6e, 0xb6, 0x6b, 0xb7, 0x7d, 0x5b, 0x45, 0x03, 0xd6, 0x20, 0x32, 0x0c, 0x83, 0x87, 0x22, - 0xee, 0x54, 0x56, 0x11, 0xf1, 0xe6, 0x6e, 0x45, 0x0b, 0x8a, 0x30, 0x8a, 0xa0, 0xb7, 0x34, 0x79, - 0x4e, 0x83, 0x9d, 0xa4, 0x4c, 0x52, 0x6c, 0xff, 0x85, 0x3f, 0xc2, 0x83, 0x07, 0x7f, 0x88, 0xc7, - 0xc5, 0x93, 0x47, 0x69, 0xff, 0x88, 0x4c, 0xba, 0xd3, 0x9d, 0xb2, 0xed, 0xdd, 0x83, 0xb7, 0xbc, - 0xef, 0x4b, 0xbe, 0xc7, 0xf7, 0xbd, 0x37, 0x03, 0x54, 0xe2, 0xac, 0x27, 0x8c, 0x76, 0x39, 0x17, - 0x2e, 0x9e, 0xe4, 0xc6, 0x19, 0xca, 0x2c, 0x2a, 0x7f, 0x12, 0x66, 0x1c, 0x5b, 0x54, 0x62, 0xc4, - 0x95, 0x8e, 0x25, 0xce, 0xa2, 0x6f, 0x7b, 0xd0, 0x3e, 0x3d, 0xbf, 0x3c, 0xd0, 0x9f, 0x0c, 0xed, - 0x40, 0x43, 0x18, 0x89, 0x03, 0xc9, 0x48, 0x48, 0xba, 0xfb, 0xc9, 0x79, 0x45, 0x23, 0x68, 0x97, - 0xa2, 0xcf, 0xa4, 0xcc, 0xd9, 0x5e, 0x48, 0xba, 0xad, 0x64, 0x03, 0xa3, 0xb7, 0xa1, 0xa9, 0x11, - 0xe5, 0x4b, 0x63, 0x3e, 0xb3, 0x7a, 0x48, 0xba, 0xcd, 0x64, 0x5d, 0xd3, 0xfb, 0x70, 0xa3, 0x38, - 0xbf, 0xc9, 0x25, 0xe6, 0xaf, 0xb9, 0x13, 0x23, 0xa5, 0x53, 0xb6, 0xef, 0x2f, 0x5d, 0x26, 0xe8, - 0x3b, 0x68, 0x4b, 0x9c, 0xa0, 0x96, 0xa8, 0x85, 0x42, 0xcb, 0xae, 0x84, 0xf5, 0xee, 0xe1, 0xf1, - 0x83, 0x78, 0x97, 0x8f, 0xb8, 0xf4, 0xd0, 0x2f, 0x5f, 0xcd, 0x0b, 0x37, 0xc9, 0x86, 0x0a, 0x7d, - 0x02, 0xb7, 0xf4, 0x34, 0x1b, 0x68, 0x61, 0x32, 0xa5, 0xd3, 0x7e, 0xb5, 0x41, 0x23, 0x24, 0xdd, - 0x7a, 0xb2, 0x8b, 0x8e, 0x7e, 0xd4, 0xe1, 0x5a, 0x35, 0xa6, 0xf7, 0xc7, 0xff, 0x83, 0xda, 0x46, - 0x53, 0x06, 0x07, 0x22, 0x47, 0xee, 0x4c, 0xce, 0x0e, 0xbc, 0xf1, 0xb2, 0xa4, 0x21, 0x1c, 0xe6, - 0xa8, 0xdd, 0x09, 0x1f, 0x73, 0x2d, 0x90, 0x35, 0x7d, 0x68, 0x55, 0x88, 0xde, 0x81, 0x96, 0x9d, - 0x5a, 0x2f, 0x26, 0x59, 0xcb, 0x3b, 0xbe, 0x00, 0xe8, 0x3d, 0xb8, 0xbe, 0x2a, 0xac, 0x32, 0x3a, - 0x41, 0x6e, 0x8d, 0x66, 0xe0, 0x5b, 0x5c, 0xc2, 0xa3, 0xef, 0x04, 0x3a, 0xdb, 0x8d, 0xd2, 0x00, - 0x60, 0x6d, 0x75, 0xee, 0x47, 0xd7, 0x4a, 0x2a, 0x08, 0x7d, 0x04, 0x37, 0x55, 0x96, 0xa1, 0x54, - 0xdc, 0xe1, 0xf3, 0xb1, 0xc4, 0xfc, 0xad, 0x1a, 0x8e, 0x8b, 0x11, 0xac, 0xe6, 0xb8, 0x9d, 0x2c, - 0x02, 0x5b, 0x13, 0x1f, 0xcc, 0x54, 0xa7, 0x17, 0xef, 0xea, 0xfe, 0xdd, 0x2e, 0x3a, 0xfa, 0x45, - 0x80, 0xbe, 0xc2, 0x94, 0x8b, 0xf9, 0x3f, 0xf8, 0x19, 0x3e, 0x86, 0x4e, 0x19, 0x8d, 0x3b, 0xad, - 0xb4, 0x58, 0xed, 0x59, 0x2b, 0xd9, 0xc1, 0x46, 0x4f, 0x81, 0xf6, 0xcd, 0x17, 0x6d, 0x1d, 0xf2, - 0xac, 0x64, 0x2c, 0xbd, 0x0b, 0x57, 0xc5, 0x86, 0x08, 0xf1, 0x22, 0x9b, 0xe0, 0xc9, 0x8b, 0x9f, - 0x8b, 0x80, 0x9c, 0x2d, 0x02, 0xf2, 0x67, 0x11, 0x90, 0xaf, 0xcb, 0xa0, 0x76, 0xb6, 0x0c, 0x6a, - 0xbf, 0x97, 0x41, 0xed, 0xe3, 0x51, 0xaa, 0xdc, 0x68, 0x3a, 0x8c, 0x85, 0xc9, 0x7a, 0x16, 0xd5, - 0x51, 0xb9, 0xe0, 0xbe, 0xf0, 0x1b, 0xde, 0x9b, 0xf5, 0x8a, 0xbf, 0x9f, 0x9b, 0x4f, 0xd0, 0x0e, - 0x1b, 0x9e, 0x7f, 0xf8, 0x37, 0x00, 0x00, 0xff, 0xff, 0x37, 0xae, 0xf3, 0x6f, 0x11, 0x05, 0x00, - 0x00, -} - -func (m *ContractInfo) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *ContractInfo) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *ContractInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.NumIncomingDependencies != 0 { - i = encodeVarintContract(dAtA, i, uint64(m.NumIncomingDependencies)) - i-- - dAtA[i] = 0x30 - } - if len(m.Dependencies) > 0 { - for iNdEx := len(m.Dependencies) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Dependencies[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintContract(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x2a - } - } - if m.NeedOrderMatching { - i-- - if m.NeedOrderMatching { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x20 - } - if m.NeedHook { - i-- - if m.NeedHook { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x18 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintContract(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if m.CodeId != 0 { - i = encodeVarintContract(dAtA, i, uint64(m.CodeId)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func (m *ContractInfoV2) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *ContractInfoV2) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *ContractInfoV2) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.SuspensionReason) > 0 { - i -= len(m.SuspensionReason) - copy(dAtA[i:], m.SuspensionReason) - i = encodeVarintContract(dAtA, i, uint64(len(m.SuspensionReason))) - i-- - dAtA[i] = 0x52 - } - if m.Suspended { - i-- - if m.Suspended { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x48 - } - if m.RentBalance != 0 { - i = encodeVarintContract(dAtA, i, uint64(m.RentBalance)) - i-- - dAtA[i] = 0x40 - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintContract(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0x3a - } - if m.NumIncomingDependencies != 0 { - i = encodeVarintContract(dAtA, i, uint64(m.NumIncomingDependencies)) - i-- - dAtA[i] = 0x30 - } - if len(m.Dependencies) > 0 { - for iNdEx := len(m.Dependencies) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Dependencies[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintContract(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x2a - } - } - if m.NeedOrderMatching { - i-- - if m.NeedOrderMatching { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x20 - } - if m.NeedHook { - i-- - if m.NeedHook { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x18 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintContract(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if m.CodeId != 0 { - i = encodeVarintContract(dAtA, i, uint64(m.CodeId)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func (m *ContractDependencyInfo) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *ContractDependencyInfo) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *ContractDependencyInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ImmediateYoungerSibling) > 0 { - i -= len(m.ImmediateYoungerSibling) - copy(dAtA[i:], m.ImmediateYoungerSibling) - i = encodeVarintContract(dAtA, i, uint64(len(m.ImmediateYoungerSibling))) - i-- - dAtA[i] = 0x1a - } - if len(m.ImmediateElderSibling) > 0 { - i -= len(m.ImmediateElderSibling) - copy(dAtA[i:], m.ImmediateElderSibling) - i = encodeVarintContract(dAtA, i, uint64(len(m.ImmediateElderSibling))) - i-- - dAtA[i] = 0x12 - } - if len(m.Dependency) > 0 { - i -= len(m.Dependency) - copy(dAtA[i:], m.Dependency) - i = encodeVarintContract(dAtA, i, uint64(len(m.Dependency))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *LegacyContractInfo) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *LegacyContractInfo) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *LegacyContractInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.DependentContractAddrs) > 0 { - for iNdEx := len(m.DependentContractAddrs) - 1; iNdEx >= 0; iNdEx-- { - i -= len(m.DependentContractAddrs[iNdEx]) - copy(dAtA[i:], m.DependentContractAddrs[iNdEx]) - i = encodeVarintContract(dAtA, i, uint64(len(m.DependentContractAddrs[iNdEx]))) - i-- - dAtA[i] = 0x2a - } - } - if m.NeedOrderMatching { - i-- - if m.NeedOrderMatching { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x20 - } - if m.NeedHook { - i-- - if m.NeedHook { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x18 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintContract(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if m.CodeId != 0 { - i = encodeVarintContract(dAtA, i, uint64(m.CodeId)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func (m *DownsteamContracts) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *DownsteamContracts) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *DownsteamContracts) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddrs) > 0 { - for iNdEx := len(m.ContractAddrs) - 1; iNdEx >= 0; iNdEx-- { - i -= len(m.ContractAddrs[iNdEx]) - copy(dAtA[i:], m.ContractAddrs[iNdEx]) - i = encodeVarintContract(dAtA, i, uint64(len(m.ContractAddrs[iNdEx]))) - i-- - dAtA[i] = 0xa - } - } - return len(dAtA) - i, nil -} - -func encodeVarintContract(dAtA []byte, offset int, v uint64) int { - offset -= sovContract(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *ContractInfo) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.CodeId != 0 { - n += 1 + sovContract(uint64(m.CodeId)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovContract(uint64(l)) - } - if m.NeedHook { - n += 2 - } - if m.NeedOrderMatching { - n += 2 - } - if len(m.Dependencies) > 0 { - for _, e := range m.Dependencies { - l = e.Size() - n += 1 + l + sovContract(uint64(l)) - } - } - if m.NumIncomingDependencies != 0 { - n += 1 + sovContract(uint64(m.NumIncomingDependencies)) - } - return n -} - -func (m *ContractInfoV2) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.CodeId != 0 { - n += 1 + sovContract(uint64(m.CodeId)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovContract(uint64(l)) - } - if m.NeedHook { - n += 2 - } - if m.NeedOrderMatching { - n += 2 - } - if len(m.Dependencies) > 0 { - for _, e := range m.Dependencies { - l = e.Size() - n += 1 + l + sovContract(uint64(l)) - } - } - if m.NumIncomingDependencies != 0 { - n += 1 + sovContract(uint64(m.NumIncomingDependencies)) - } - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovContract(uint64(l)) - } - if m.RentBalance != 0 { - n += 1 + sovContract(uint64(m.RentBalance)) - } - if m.Suspended { - n += 2 - } - l = len(m.SuspensionReason) - if l > 0 { - n += 1 + l + sovContract(uint64(l)) - } - return n -} - -func (m *ContractDependencyInfo) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Dependency) - if l > 0 { - n += 1 + l + sovContract(uint64(l)) - } - l = len(m.ImmediateElderSibling) - if l > 0 { - n += 1 + l + sovContract(uint64(l)) - } - l = len(m.ImmediateYoungerSibling) - if l > 0 { - n += 1 + l + sovContract(uint64(l)) - } - return n -} - -func (m *LegacyContractInfo) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.CodeId != 0 { - n += 1 + sovContract(uint64(m.CodeId)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovContract(uint64(l)) - } - if m.NeedHook { - n += 2 - } - if m.NeedOrderMatching { - n += 2 - } - if len(m.DependentContractAddrs) > 0 { - for _, s := range m.DependentContractAddrs { - l = len(s) - n += 1 + l + sovContract(uint64(l)) - } - } - return n -} - -func (m *DownsteamContracts) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.ContractAddrs) > 0 { - for _, s := range m.ContractAddrs { - l = len(s) - n += 1 + l + sovContract(uint64(l)) - } - } - return n -} - -func sovContract(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozContract(x uint64) (n int) { - return sovContract(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *ContractInfo) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: ContractInfo: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: ContractInfo: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field CodeId", wireType) - } - m.CodeId = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.CodeId |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - 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 ErrInvalidLengthContract - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NeedHook", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.NeedHook = bool(v != 0) - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NeedOrderMatching", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.NeedOrderMatching = bool(v != 0) - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Dependencies", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthContract - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Dependencies = append(m.Dependencies, &ContractDependencyInfo{}) - if err := m.Dependencies[len(m.Dependencies)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 6: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NumIncomingDependencies", wireType) - } - m.NumIncomingDependencies = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.NumIncomingDependencies |= int64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipContract(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthContract - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *ContractInfoV2) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: ContractInfoV2: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: ContractInfoV2: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field CodeId", wireType) - } - m.CodeId = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.CodeId |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - 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 ErrInvalidLengthContract - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NeedHook", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.NeedHook = bool(v != 0) - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NeedOrderMatching", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.NeedOrderMatching = bool(v != 0) - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Dependencies", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthContract - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Dependencies = append(m.Dependencies, &ContractDependencyInfo{}) - if err := m.Dependencies[len(m.Dependencies)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 6: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NumIncomingDependencies", wireType) - } - m.NumIncomingDependencies = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.NumIncomingDependencies |= int64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 7: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - 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 ErrInvalidLengthContract - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 8: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field RentBalance", wireType) - } - m.RentBalance = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.RentBalance |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 9: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Suspended", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.Suspended = bool(v != 0) - case 10: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field SuspensionReason", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - 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 ErrInvalidLengthContract - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.SuspensionReason = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipContract(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthContract - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *ContractDependencyInfo) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: ContractDependencyInfo: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: ContractDependencyInfo: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Dependency", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - 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 ErrInvalidLengthContract - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Dependency = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ImmediateElderSibling", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - 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 ErrInvalidLengthContract - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ImmediateElderSibling = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ImmediateYoungerSibling", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - 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 ErrInvalidLengthContract - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ImmediateYoungerSibling = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipContract(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthContract - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *LegacyContractInfo) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: LegacyContractInfo: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: LegacyContractInfo: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field CodeId", wireType) - } - m.CodeId = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.CodeId |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - 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 ErrInvalidLengthContract - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NeedHook", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.NeedHook = bool(v != 0) - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NeedOrderMatching", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.NeedOrderMatching = bool(v != 0) - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field DependentContractAddrs", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - 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 ErrInvalidLengthContract - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.DependentContractAddrs = append(m.DependentContractAddrs, string(dAtA[iNdEx:postIndex])) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipContract(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthContract - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *DownsteamContracts) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: DownsteamContracts: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: DownsteamContracts: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddrs", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowContract - } - 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 ErrInvalidLengthContract - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthContract - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddrs = append(m.ContractAddrs, string(dAtA[iNdEx:postIndex])) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipContract(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthContract - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipContract(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowContract - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowContract - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowContract - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthContract - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupContract - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthContract - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthContract = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowContract = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupContract = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/deposit.go b/x/dex/types/deposit.go deleted file mode 100644 index 3479571adb..0000000000 --- a/x/dex/types/deposit.go +++ /dev/null @@ -1,19 +0,0 @@ -package types - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" -) - -type ContractDepositInfo struct { - Account string `json:"account"` - Denom string `json:"denom"` - Amount sdk.Dec `json:"amount"` -} - -func (d *DepositInfoEntry) ToContractDepositInfo() ContractDepositInfo { - return ContractDepositInfo{ - Account: d.Creator, - Denom: d.Denom, - Amount: d.Amount, - } -} diff --git a/x/dex/types/deposit.pb.go b/x/dex/types/deposit.pb.go deleted file mode 100644 index fbdaff23c5..0000000000 --- a/x/dex/types/deposit.pb.go +++ /dev/null @@ -1,422 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/deposit.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type DepositInfoEntry struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator"` - Denom string `protobuf:"bytes,2,opt,name=denom,proto3" json:"denom"` - Amount github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,3,opt,name=amount,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"amount" yaml:"amount"` -} - -func (m *DepositInfoEntry) Reset() { *m = DepositInfoEntry{} } -func (m *DepositInfoEntry) String() string { return proto.CompactTextString(m) } -func (*DepositInfoEntry) ProtoMessage() {} -func (*DepositInfoEntry) Descriptor() ([]byte, []int) { - return fileDescriptor_93caea15661b640e, []int{0} -} -func (m *DepositInfoEntry) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *DepositInfoEntry) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_DepositInfoEntry.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *DepositInfoEntry) XXX_Merge(src proto.Message) { - xxx_messageInfo_DepositInfoEntry.Merge(m, src) -} -func (m *DepositInfoEntry) XXX_Size() int { - return m.Size() -} -func (m *DepositInfoEntry) XXX_DiscardUnknown() { - xxx_messageInfo_DepositInfoEntry.DiscardUnknown(m) -} - -var xxx_messageInfo_DepositInfoEntry proto.InternalMessageInfo - -func (m *DepositInfoEntry) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *DepositInfoEntry) GetDenom() string { - if m != nil { - return m.Denom - } - return "" -} - -func init() { - proto.RegisterType((*DepositInfoEntry)(nil), "seiprotocol.seichain.dex.DepositInfoEntry") -} - -func init() { proto.RegisterFile("dex/deposit.proto", fileDescriptor_93caea15661b640e) } - -var fileDescriptor_93caea15661b640e = []byte{ - // 273 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x4c, 0x50, 0x3f, 0x4b, 0xfb, 0x40, - 0x18, 0xce, 0xfd, 0x7e, 0x58, 0x69, 0x44, 0xd0, 0xe0, 0x10, 0x1c, 0xee, 0x24, 0xa0, 0xb8, 0x24, - 0x19, 0xdc, 0x1c, 0x4b, 0x45, 0xba, 0x66, 0x74, 0x4b, 0x2f, 0xaf, 0xe9, 0x61, 0x93, 0x37, 0xe4, - 0xae, 0x90, 0x7c, 0x0b, 0xbf, 0x90, 0x7b, 0xc7, 0x8e, 0xe2, 0x70, 0x48, 0xb2, 0x65, 0xf4, 0x13, - 0x48, 0xef, 0x12, 0x70, 0x7a, 0x9f, 0x7f, 0x77, 0x0f, 0x3c, 0xee, 0x65, 0x06, 0x4d, 0x9c, 0x41, - 0x85, 0x52, 0xa8, 0xa8, 0xaa, 0x51, 0xa1, 0xe7, 0x4b, 0x10, 0x06, 0x71, 0xdc, 0x46, 0x12, 0x04, - 0xdf, 0xa4, 0xa2, 0x8c, 0x32, 0x68, 0xae, 0xaf, 0x72, 0xcc, 0xd1, 0x58, 0xf1, 0x11, 0xd9, 0x7c, - 0xf0, 0x41, 0xdc, 0x8b, 0xa5, 0xfd, 0x61, 0x55, 0xbe, 0xe2, 0x53, 0xa9, 0xea, 0xd6, 0xbb, 0x75, - 0x4f, 0x79, 0x0d, 0xa9, 0xc2, 0xda, 0x27, 0x37, 0xe4, 0x7e, 0xbe, 0x38, 0x1b, 0x34, 0x9b, 0xa4, - 0x64, 0x02, 0x1e, 0x73, 0x4f, 0x32, 0x28, 0xb1, 0xf0, 0xff, 0x99, 0xd0, 0x7c, 0xd0, 0xcc, 0x0a, - 0x89, 0x3d, 0x5e, 0xea, 0xce, 0xd2, 0x02, 0x77, 0xa5, 0xf2, 0xff, 0x9b, 0xc4, 0x6a, 0xaf, 0x99, - 0xf3, 0xa5, 0xd9, 0x5d, 0x2e, 0xd4, 0x66, 0xb7, 0x8e, 0x38, 0x16, 0x31, 0x47, 0x59, 0xa0, 0x1c, - 0x4f, 0x28, 0xb3, 0xb7, 0x58, 0xb5, 0x15, 0xc8, 0x68, 0x09, 0x7c, 0xd0, 0x6c, 0x7c, 0xff, 0xa3, - 0xd9, 0x79, 0x9b, 0x16, 0xdb, 0xc7, 0xc0, 0xf2, 0x20, 0x19, 0x8d, 0xc5, 0xf3, 0xbe, 0xa3, 0xe4, - 0xd0, 0x51, 0xf2, 0xdd, 0x51, 0xf2, 0xde, 0x53, 0xe7, 0xd0, 0x53, 0xe7, 0xb3, 0xa7, 0xce, 0x4b, - 0xf8, 0xa7, 0x44, 0x82, 0x08, 0xa7, 0x55, 0x0c, 0x31, 0xb3, 0xc4, 0xc7, 0xf1, 0x1a, 0xdb, 0xb7, - 0x9e, 0x19, 0xff, 0xe1, 0x37, 0x00, 0x00, 0xff, 0xff, 0x06, 0xf6, 0x98, 0x0a, 0x54, 0x01, 0x00, - 0x00, -} - -func (m *DepositInfoEntry) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *DepositInfoEntry) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *DepositInfoEntry) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - { - size := m.Amount.Size() - i -= size - if _, err := m.Amount.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintDeposit(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - if len(m.Denom) > 0 { - i -= len(m.Denom) - copy(dAtA[i:], m.Denom) - i = encodeVarintDeposit(dAtA, i, uint64(len(m.Denom))) - i-- - dAtA[i] = 0x12 - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintDeposit(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func encodeVarintDeposit(dAtA []byte, offset int, v uint64) int { - offset -= sovDeposit(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *DepositInfoEntry) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovDeposit(uint64(l)) - } - l = len(m.Denom) - if l > 0 { - n += 1 + l + sovDeposit(uint64(l)) - } - l = m.Amount.Size() - n += 1 + l + sovDeposit(uint64(l)) - return n -} - -func sovDeposit(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozDeposit(x uint64) (n int) { - return sovDeposit(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *DepositInfoEntry) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowDeposit - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: DepositInfoEntry: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: DepositInfoEntry: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowDeposit - } - 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 ErrInvalidLengthDeposit - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthDeposit - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Denom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowDeposit - } - 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 ErrInvalidLengthDeposit - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthDeposit - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Denom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Amount", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowDeposit - } - 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 ErrInvalidLengthDeposit - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthDeposit - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Amount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipDeposit(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthDeposit - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipDeposit(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowDeposit - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowDeposit - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowDeposit - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthDeposit - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupDeposit - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthDeposit - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthDeposit = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowDeposit = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupDeposit = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/enums.go b/x/dex/types/enums.go deleted file mode 100644 index 0ac28ea0ee..0000000000 --- a/x/dex/types/enums.go +++ /dev/null @@ -1,29 +0,0 @@ -package types - -import ( - "fmt" - "strings" -) - -func GetPositionEffectFromStr(str string) (PositionEffect, error) { - val, err := getEnumFromStr(str, PositionEffect_value) - return PositionEffect(val), err -} - -func GetPositionDirectionFromStr(str string) (PositionDirection, error) { - val, err := getEnumFromStr(str, PositionDirection_value) - return PositionDirection(val), err -} - -func GetOrderTypeFromStr(str string) (OrderType, error) { - val, err := getEnumFromStr(str, OrderType_value) - return OrderType(val), err -} - -func getEnumFromStr(str string, enumMap map[string]int32) (int32, error) { - upperStr := strings.ToUpper(str) - if val, ok := enumMap[upperStr]; ok { - return val, nil - } - return 0, fmt.Errorf("unknown enum literal: %s", str) -} diff --git a/x/dex/types/enums.pb.go b/x/dex/types/enums.pb.go deleted file mode 100644 index 97464194ae..0000000000 --- a/x/dex/types/enums.pb.go +++ /dev/null @@ -1,235 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/enums.proto - -package types - -import ( - fmt "fmt" - proto "github.com/gogo/protobuf/proto" - math "math" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type PositionDirection int32 - -const ( - PositionDirection_LONG PositionDirection = 0 - PositionDirection_SHORT PositionDirection = 1 -) - -var PositionDirection_name = map[int32]string{ - 0: "LONG", - 1: "SHORT", -} - -var PositionDirection_value = map[string]int32{ - "LONG": 0, - "SHORT": 1, -} - -func (x PositionDirection) String() string { - return proto.EnumName(PositionDirection_name, int32(x)) -} - -func (PositionDirection) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_b8c5bb23c6eb0b88, []int{0} -} - -type PositionEffect int32 - -const ( - PositionEffect_OPEN PositionEffect = 0 - PositionEffect_CLOSE PositionEffect = 1 -) - -var PositionEffect_name = map[int32]string{ - 0: "OPEN", - 1: "CLOSE", -} - -var PositionEffect_value = map[string]int32{ - "OPEN": 0, - "CLOSE": 1, -} - -func (x PositionEffect) String() string { - return proto.EnumName(PositionEffect_name, int32(x)) -} - -func (PositionEffect) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_b8c5bb23c6eb0b88, []int{1} -} - -type OrderType int32 - -const ( - OrderType_LIMIT OrderType = 0 - OrderType_MARKET OrderType = 1 - OrderType_FOKMARKET OrderType = 3 - OrderType_FOKMARKETBYVALUE OrderType = 4 - OrderType_STOPLOSS OrderType = 5 - OrderType_STOPLIMIT OrderType = 6 -) - -var OrderType_name = map[int32]string{ - 0: "LIMIT", - 1: "MARKET", - 3: "FOKMARKET", - 4: "FOKMARKETBYVALUE", - 5: "STOPLOSS", - 6: "STOPLIMIT", -} - -var OrderType_value = map[string]int32{ - "LIMIT": 0, - "MARKET": 1, - "FOKMARKET": 3, - "FOKMARKETBYVALUE": 4, - "STOPLOSS": 5, - "STOPLIMIT": 6, -} - -func (x OrderType) String() string { - return proto.EnumName(OrderType_name, int32(x)) -} - -func (OrderType) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_b8c5bb23c6eb0b88, []int{2} -} - -type Unit int32 - -const ( - Unit_STANDARD Unit = 0 - Unit_MILLI Unit = 1 - Unit_MICRO Unit = 2 - Unit_NANO Unit = 3 -) - -var Unit_name = map[int32]string{ - 0: "STANDARD", - 1: "MILLI", - 2: "MICRO", - 3: "NANO", -} - -var Unit_value = map[string]int32{ - "STANDARD": 0, - "MILLI": 1, - "MICRO": 2, - "NANO": 3, -} - -func (x Unit) String() string { - return proto.EnumName(Unit_name, int32(x)) -} - -func (Unit) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_b8c5bb23c6eb0b88, []int{3} -} - -type OrderStatus int32 - -const ( - OrderStatus_PLACED OrderStatus = 0 - OrderStatus_FAILED_TO_PLACE OrderStatus = 1 - OrderStatus_CANCELLED OrderStatus = 2 - OrderStatus_FULFILLED OrderStatus = 3 -) - -var OrderStatus_name = map[int32]string{ - 0: "PLACED", - 1: "FAILED_TO_PLACE", - 2: "CANCELLED", - 3: "FULFILLED", -} - -var OrderStatus_value = map[string]int32{ - "PLACED": 0, - "FAILED_TO_PLACE": 1, - "CANCELLED": 2, - "FULFILLED": 3, -} - -func (x OrderStatus) String() string { - return proto.EnumName(OrderStatus_name, int32(x)) -} - -func (OrderStatus) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_b8c5bb23c6eb0b88, []int{4} -} - -type CancellationInitiator int32 - -const ( - CancellationInitiator_USER CancellationInitiator = 0 - CancellationInitiator_LIQUIDATED CancellationInitiator = 1 -) - -var CancellationInitiator_name = map[int32]string{ - 0: "USER", - 1: "LIQUIDATED", -} - -var CancellationInitiator_value = map[string]int32{ - "USER": 0, - "LIQUIDATED": 1, -} - -func (x CancellationInitiator) String() string { - return proto.EnumName(CancellationInitiator_name, int32(x)) -} - -func (CancellationInitiator) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_b8c5bb23c6eb0b88, []int{5} -} - -func init() { - proto.RegisterEnum("seiprotocol.seichain.dex.PositionDirection", PositionDirection_name, PositionDirection_value) - proto.RegisterEnum("seiprotocol.seichain.dex.PositionEffect", PositionEffect_name, PositionEffect_value) - proto.RegisterEnum("seiprotocol.seichain.dex.OrderType", OrderType_name, OrderType_value) - proto.RegisterEnum("seiprotocol.seichain.dex.Unit", Unit_name, Unit_value) - proto.RegisterEnum("seiprotocol.seichain.dex.OrderStatus", OrderStatus_name, OrderStatus_value) - proto.RegisterEnum("seiprotocol.seichain.dex.CancellationInitiator", CancellationInitiator_name, CancellationInitiator_value) -} - -func init() { proto.RegisterFile("dex/enums.proto", fileDescriptor_b8c5bb23c6eb0b88) } - -var fileDescriptor_b8c5bb23c6eb0b88 = []byte{ - // 394 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x3c, 0x91, 0xdf, 0x6e, 0xd3, 0x30, - 0x18, 0xc5, 0xe3, 0xb5, 0xab, 0xd6, 0x0f, 0xd8, 0x8c, 0x01, 0x89, 0xab, 0xdc, 0x21, 0xa1, 0x48, - 0x6b, 0x84, 0xe0, 0x05, 0xbc, 0xc4, 0x1d, 0xd6, 0xdc, 0x38, 0xe4, 0x0f, 0x12, 0xdc, 0x4c, 0x59, - 0xe2, 0x31, 0x4b, 0x5d, 0x52, 0x25, 0xae, 0xd4, 0xbd, 0x05, 0x8f, 0xc5, 0xe5, 0x2e, 0xb9, 0x44, - 0xed, 0x8b, 0x20, 0x3b, 0x8c, 0xbb, 0x73, 0x3e, 0x9f, 0xcf, 0xfe, 0xc9, 0x07, 0xce, 0x1a, 0xb5, - 0x0b, 0x55, 0xbb, 0xbd, 0x1f, 0x16, 0x9b, 0xbe, 0x33, 0x1d, 0x79, 0x3b, 0x28, 0xed, 0x54, 0xdd, - 0xad, 0x17, 0x83, 0xd2, 0xf5, 0x5d, 0xa5, 0xdb, 0x45, 0xa3, 0x76, 0xc1, 0x7b, 0x78, 0x99, 0x76, - 0x83, 0x36, 0xba, 0x6b, 0x63, 0xdd, 0xab, 0xda, 0x0a, 0x72, 0x02, 0x53, 0x21, 0x93, 0x4b, 0xec, - 0x91, 0x39, 0x1c, 0xe7, 0x9f, 0x65, 0x56, 0x60, 0x14, 0xbc, 0x83, 0xd3, 0xa7, 0x24, 0xbb, 0xbd, - 0x55, 0xb5, 0xb1, 0x31, 0x99, 0xb2, 0x64, 0x8c, 0x45, 0x42, 0xe6, 0x0c, 0xa3, 0xa0, 0x81, 0xb9, - 0xec, 0x1b, 0xd5, 0x17, 0x0f, 0x1b, 0x65, 0xe7, 0x82, 0xaf, 0x78, 0x81, 0x3d, 0x02, 0x30, 0x5b, - 0xd1, 0xec, 0x8a, 0x15, 0x18, 0x91, 0x17, 0x30, 0x5f, 0xca, 0xab, 0x7f, 0x76, 0x42, 0x5e, 0x03, - 0xfe, 0x6f, 0x2f, 0xbe, 0x7d, 0xa5, 0xa2, 0x64, 0x78, 0x4a, 0x9e, 0xc3, 0x49, 0x5e, 0xc8, 0x54, - 0xc8, 0x3c, 0xc7, 0xc7, 0x76, 0xc5, 0x39, 0x77, 0xdb, 0x2c, 0xf8, 0x04, 0xd3, 0xb2, 0xd5, 0x66, - 0x0c, 0xd1, 0x24, 0xa6, 0x59, 0x3c, 0x62, 0xac, 0xb8, 0x10, 0x1c, 0xa3, 0x51, 0x46, 0x99, 0xc4, - 0x47, 0x16, 0x33, 0xa1, 0x89, 0xc4, 0x93, 0x40, 0xc0, 0x33, 0xc7, 0x96, 0x9b, 0xca, 0x6c, 0x07, - 0x8b, 0x94, 0x0a, 0x1a, 0x31, 0xbb, 0xfa, 0x0a, 0xce, 0x96, 0x94, 0x0b, 0x16, 0x5f, 0x17, 0xf2, - 0xda, 0x4d, 0x47, 0xce, 0x88, 0x26, 0x11, 0x13, 0x82, 0xc5, 0xf8, 0xc8, 0x61, 0x97, 0x62, 0xc9, - 0x9d, 0x9d, 0x04, 0x1f, 0xe0, 0x4d, 0x54, 0xb5, 0xb5, 0x5a, 0xaf, 0x2b, 0xfb, 0x29, 0xbc, 0xd5, - 0x46, 0x57, 0xa6, 0xeb, 0xed, 0x83, 0x65, 0xce, 0x32, 0xec, 0x91, 0x53, 0x00, 0xc1, 0xbf, 0x94, - 0x3c, 0xa6, 0x05, 0x8b, 0x31, 0xba, 0xb8, 0xfc, 0xb5, 0xf7, 0xd1, 0xe3, 0xde, 0x47, 0x7f, 0xf6, - 0x3e, 0xfa, 0x79, 0xf0, 0xbd, 0xc7, 0x83, 0xef, 0xfd, 0x3e, 0xf8, 0xde, 0xf7, 0xf3, 0x1f, 0xda, - 0xdc, 0x6d, 0x6f, 0x16, 0x75, 0x77, 0x1f, 0x0e, 0x4a, 0x9f, 0x3f, 0xb5, 0xe5, 0x8c, 0xab, 0x2b, - 0xdc, 0x85, 0xb6, 0x56, 0xf3, 0xb0, 0x51, 0xc3, 0xcd, 0xcc, 0x9d, 0x7f, 0xfc, 0x1b, 0x00, 0x00, - 0xff, 0xff, 0x40, 0x7d, 0x48, 0x4c, 0xea, 0x01, 0x00, 0x00, -} diff --git a/x/dex/types/enums_test.go b/x/dex/types/enums_test.go deleted file mode 100644 index 1f8d1515be..0000000000 --- a/x/dex/types/enums_test.go +++ /dev/null @@ -1,53 +0,0 @@ -package types_test - -import ( - "testing" - - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestGetPositionEffectFromStr(t *testing.T) { - effect := "Close" - expected := types.PositionEffect_CLOSE - actual, err := types.GetPositionEffectFromStr(effect) - - require.Nil(t, err) - require.Equal(t, expected, actual) - - // unidentified effect - effect = "invalid_effect" - _, err = types.GetPositionEffectFromStr(effect) - - require.NotNil(t, err) -} - -func TestGetPositionDirectionFromStr(t *testing.T) { - direction := "Long" - expected := types.PositionDirection_LONG - actual, err := types.GetPositionDirectionFromStr(direction) - - require.Nil(t, err) - require.Equal(t, expected, actual) - - // unidentified direction - direction = "invalid_direction" - _, err = types.GetPositionEffectFromStr(direction) - - require.NotNil(t, err) -} - -func TestGetOrderTypeFromStr(t *testing.T) { - orderType := "Market" - expected := types.OrderType_MARKET - actual, err := types.GetOrderTypeFromStr(orderType) - - require.Nil(t, err) - require.Equal(t, expected, actual) - - // unidentified direction - orderType = "invalid" - _, err = types.GetPositionEffectFromStr(orderType) - - require.NotNil(t, err) -} diff --git a/x/dex/types/errors.go b/x/dex/types/errors.go deleted file mode 100644 index ecdd0253de..0000000000 --- a/x/dex/types/errors.go +++ /dev/null @@ -1,28 +0,0 @@ -package types - -// DONTCOVER - -import ( - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" -) - -// x/dex module sentinel errors -var ( - ErrEncodeDexPlaceOrders = sdkerrors.Register(ModuleName, 2, "Error while encoding dex order placement msg in wasmd") - ErrEncodeDexCancelOrders = sdkerrors.Register(ModuleName, 3, "Error while encoding dex order cancellation msg in wasmd") - ErrParsingSeiDexQuery = sdkerrors.Register(ModuleName, 4, "Error parsing SeiDexQuery") - ErrEncodingDexTwaps = sdkerrors.Register(ModuleName, 6, "Error encoding dex twaps as JSON") - ErrEncodingOrders = sdkerrors.Register(ModuleName, 8, "Error encoding orders as JSON") - ErrEncodingOrder = sdkerrors.Register(ModuleName, 10, "Error encoding order as JSON") - ErrEncodingOrderSimulation = sdkerrors.Register(ModuleName, 12, "Error encoding order simulation as JSON") - ErrInvalidOrderID = sdkerrors.Register(ModuleName, 13, "Error order id not found") - ErrEncodingLatestPrice = sdkerrors.Register(ModuleName, 14, "Error encoding latest price as JSON") - ErrUnknownSeiDexQuery = sdkerrors.Register(ModuleName, 15, "Error unknown sei dex query") - ErrPairNotRegistered = sdkerrors.Register(ModuleName, 16, "pair is not registered") - ErrContractNotExists = sdkerrors.Register(ModuleName, 17, "Error finding contract info") - ErrParsingContractInfo = sdkerrors.Register(ModuleName, 18, "Error parsing contract info") - ErrInsufficientRent = sdkerrors.Register(ModuleName, 19, "Error contract does not have sufficient fee") - ErrCircularContractDependency = sdkerrors.Register(ModuleName, 1103, "circular contract dependency detected") - ErrContractSuspended = sdkerrors.Register(ModuleName, 1104, "contract suspended") - ErrContractNotSuspended = sdkerrors.Register(ModuleName, 1105, "contract not suspended") -) diff --git a/x/dex/types/events.go b/x/dex/types/events.go deleted file mode 100644 index a4a34ae5d6..0000000000 --- a/x/dex/types/events.go +++ /dev/null @@ -1,21 +0,0 @@ -package types - -const ( - EventTypePlaceOrder = "place_order" - EventTypeCancelOrder = "cancel_order" - EventTypeDepositRent = "deposit_rent" - EventTypeRegisterContract = "register_contract" - EventTypeUnregisterContract = "unregister_contract" - EventTypeRegisterPair = "register_pair" - EventTypeSetQuantityTickSize = "set_quantity_tick_size" - EventTypeSetPriceTickSize = "set_price_tick_size" - - AttributeKeyOrderID = "order_id" - AttributeKeyCancellationID = "cancellation_id" - AttributeKeyContractAddress = "contract_address" - AttributeKeyRentBalance = "rent_balance" - AttributeKeyPriceDenom = "price_denom" - AttributeKeyAssetDenom = "asset_denom" - - AttributeValueCategory = ModuleName -) diff --git a/x/dex/types/expected_keepers.go b/x/dex/types/expected_keepers.go deleted file mode 100644 index 6aa6e97781..0000000000 --- a/x/dex/types/expected_keepers.go +++ /dev/null @@ -1,18 +0,0 @@ -package types - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/x/auth/types" -) - -// AccountKeeper defines the expected account keeper used for simulations (noalias) -type AccountKeeper interface { - GetAccount(ctx sdk.Context, addr sdk.AccAddress) types.AccountI - // Methods imported from account should be defined here -} - -// BankKeeper defines the expected interface needed to retrieve account balances. -type BankKeeper interface { - SpendableCoins(ctx sdk.Context, addr sdk.AccAddress) sdk.Coins - // Methods imported from bank should be defined here -} diff --git a/x/dex/types/genesis.go b/x/dex/types/genesis.go deleted file mode 100644 index 9c8f79642e..0000000000 --- a/x/dex/types/genesis.go +++ /dev/null @@ -1,75 +0,0 @@ -package types - -import ( - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" -) - -// DefaultGenesis returns the default Capability genesis state -func DefaultGenesis() *GenesisState { - return &GenesisState{ - Params: DefaultParams(), - ContractState: []ContractState{}, - } -} - -// Validate performs basic genesis state validation returning an error upon any -// failure. -func (gs GenesisState) Validate() error { - paramErr := gs.Params.Validate() - if paramErr != nil { - return paramErr - } - for _, cs := range gs.ContractState { - csErr := cs.Validate() - if csErr != nil { - return csErr - } - } - return nil -} - -func (cs ContractState) Validate() error { - if len(cs.ContractInfo.ContractAddr) == 0 { - return fmt.Errorf("empty contract addr") - } - if _, err := sdk.AccAddressFromBech32(cs.ContractInfo.ContractAddr); err != nil { - return fmt.Errorf("contract address is invalid") - } - // Check for duplicated price in a single market - // Can only be a one price per pair per contract - type MarketPrice struct { - priceDenom string - assetDenom string - price uint64 - } - - // Check for duplication in longbook - longBookPriceMap := make(map[MarketPrice]struct{}) - for _, elem := range cs.LongBookList { - priceElem := MarketPrice{ - priceDenom: elem.Entry.PriceDenom, - assetDenom: elem.Entry.AssetDenom, - price: elem.Price.BigInt().Uint64(), - } - if _, ok := longBookPriceMap[priceElem]; ok { - return fmt.Errorf("duplicated price for longBook") - } - longBookPriceMap[priceElem] = struct{}{} - } - // Check for duplication in shortbook - shortBookPriceMap := make(map[MarketPrice]struct{}) - for _, elem := range cs.ShortBookList { - priceElem := MarketPrice{ - priceDenom: elem.Entry.PriceDenom, - assetDenom: elem.Entry.AssetDenom, - price: elem.Price.BigInt().Uint64(), - } - if _, ok := shortBookPriceMap[priceElem]; ok { - return fmt.Errorf("duplicated price for shortBook") - } - shortBookPriceMap[priceElem] = struct{}{} - } - return nil -} diff --git a/x/dex/types/genesis.pb.go b/x/dex/types/genesis.pb.go deleted file mode 100644 index 4bd5241f6b..0000000000 --- a/x/dex/types/genesis.pb.go +++ /dev/null @@ -1,1188 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/genesis.proto - -package types - -import ( - fmt "fmt" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -// GenesisState defines the dex module's genesis state. -type GenesisState struct { - Params Params `protobuf:"bytes,1,opt,name=params,proto3" json:"params"` - ContractState []ContractState `protobuf:"bytes,2,rep,name=contractState,proto3" json:"contractState"` - LastEpoch uint64 `protobuf:"varint,3,opt,name=lastEpoch,proto3" json:"lastEpoch,omitempty"` -} - -func (m *GenesisState) Reset() { *m = GenesisState{} } -func (m *GenesisState) String() string { return proto.CompactTextString(m) } -func (*GenesisState) ProtoMessage() {} -func (*GenesisState) Descriptor() ([]byte, []int) { - return fileDescriptor_a803aaabd08db59d, []int{0} -} -func (m *GenesisState) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *GenesisState) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_GenesisState.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *GenesisState) XXX_Merge(src proto.Message) { - xxx_messageInfo_GenesisState.Merge(m, src) -} -func (m *GenesisState) XXX_Size() int { - return m.Size() -} -func (m *GenesisState) XXX_DiscardUnknown() { - xxx_messageInfo_GenesisState.DiscardUnknown(m) -} - -var xxx_messageInfo_GenesisState proto.InternalMessageInfo - -func (m *GenesisState) GetParams() Params { - if m != nil { - return m.Params - } - return Params{} -} - -func (m *GenesisState) GetContractState() []ContractState { - if m != nil { - return m.ContractState - } - return nil -} - -func (m *GenesisState) GetLastEpoch() uint64 { - if m != nil { - return m.LastEpoch - } - return 0 -} - -type ContractState struct { - ContractInfo ContractInfoV2 `protobuf:"bytes,1,opt,name=contractInfo,proto3" json:"contractInfo"` - LongBookList []LongBook `protobuf:"bytes,2,rep,name=longBookList,proto3" json:"longBookList"` - ShortBookList []ShortBook `protobuf:"bytes,3,rep,name=shortBookList,proto3" json:"shortBookList"` - TriggeredOrdersList []Order `protobuf:"bytes,4,rep,name=triggeredOrdersList,proto3" json:"triggeredOrdersList"` - PairList []Pair `protobuf:"bytes,5,rep,name=pairList,proto3" json:"pairList"` - PriceList []ContractPairPrices `protobuf:"bytes,6,rep,name=priceList,proto3" json:"priceList"` - NextOrderId uint64 `protobuf:"varint,7,opt,name=nextOrderId,proto3" json:"nextOrderId,omitempty"` -} - -func (m *ContractState) Reset() { *m = ContractState{} } -func (m *ContractState) String() string { return proto.CompactTextString(m) } -func (*ContractState) ProtoMessage() {} -func (*ContractState) Descriptor() ([]byte, []int) { - return fileDescriptor_a803aaabd08db59d, []int{1} -} -func (m *ContractState) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *ContractState) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_ContractState.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *ContractState) XXX_Merge(src proto.Message) { - xxx_messageInfo_ContractState.Merge(m, src) -} -func (m *ContractState) XXX_Size() int { - return m.Size() -} -func (m *ContractState) XXX_DiscardUnknown() { - xxx_messageInfo_ContractState.DiscardUnknown(m) -} - -var xxx_messageInfo_ContractState proto.InternalMessageInfo - -func (m *ContractState) GetContractInfo() ContractInfoV2 { - if m != nil { - return m.ContractInfo - } - return ContractInfoV2{} -} - -func (m *ContractState) GetLongBookList() []LongBook { - if m != nil { - return m.LongBookList - } - return nil -} - -func (m *ContractState) GetShortBookList() []ShortBook { - if m != nil { - return m.ShortBookList - } - return nil -} - -func (m *ContractState) GetTriggeredOrdersList() []Order { - if m != nil { - return m.TriggeredOrdersList - } - return nil -} - -func (m *ContractState) GetPairList() []Pair { - if m != nil { - return m.PairList - } - return nil -} - -func (m *ContractState) GetPriceList() []ContractPairPrices { - if m != nil { - return m.PriceList - } - return nil -} - -func (m *ContractState) GetNextOrderId() uint64 { - if m != nil { - return m.NextOrderId - } - return 0 -} - -type ContractPairPrices struct { - PricePair Pair `protobuf:"bytes,1,opt,name=pricePair,proto3" json:"pricePair"` - Prices []*Price `protobuf:"bytes,2,rep,name=prices,proto3" json:"prices,omitempty"` -} - -func (m *ContractPairPrices) Reset() { *m = ContractPairPrices{} } -func (m *ContractPairPrices) String() string { return proto.CompactTextString(m) } -func (*ContractPairPrices) ProtoMessage() {} -func (*ContractPairPrices) Descriptor() ([]byte, []int) { - return fileDescriptor_a803aaabd08db59d, []int{2} -} -func (m *ContractPairPrices) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *ContractPairPrices) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_ContractPairPrices.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *ContractPairPrices) XXX_Merge(src proto.Message) { - xxx_messageInfo_ContractPairPrices.Merge(m, src) -} -func (m *ContractPairPrices) XXX_Size() int { - return m.Size() -} -func (m *ContractPairPrices) XXX_DiscardUnknown() { - xxx_messageInfo_ContractPairPrices.DiscardUnknown(m) -} - -var xxx_messageInfo_ContractPairPrices proto.InternalMessageInfo - -func (m *ContractPairPrices) GetPricePair() Pair { - if m != nil { - return m.PricePair - } - return Pair{} -} - -func (m *ContractPairPrices) GetPrices() []*Price { - if m != nil { - return m.Prices - } - return nil -} - -func init() { - proto.RegisterType((*GenesisState)(nil), "seiprotocol.seichain.dex.GenesisState") - proto.RegisterType((*ContractState)(nil), "seiprotocol.seichain.dex.ContractState") - proto.RegisterType((*ContractPairPrices)(nil), "seiprotocol.seichain.dex.ContractPairPrices") -} - -func init() { proto.RegisterFile("dex/genesis.proto", fileDescriptor_a803aaabd08db59d) } - -var fileDescriptor_a803aaabd08db59d = []byte{ - // 497 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x93, 0x4f, 0x6f, 0xd3, 0x30, - 0x18, 0xc6, 0x1b, 0x5a, 0x0a, 0x73, 0x5b, 0xfe, 0x78, 0x3b, 0x44, 0x15, 0xca, 0xa2, 0x72, 0xa0, - 0x07, 0x96, 0x48, 0xe5, 0xc0, 0x0d, 0xa1, 0x22, 0x34, 0x4d, 0xaa, 0xb4, 0xaa, 0x95, 0x40, 0xe2, - 0x82, 0xd2, 0xc4, 0xa4, 0xd6, 0xba, 0xbc, 0x91, 0x6d, 0xa4, 0xf2, 0x2d, 0xd8, 0x47, 0xe2, 0xb6, - 0xe3, 0x8e, 0x9c, 0x10, 0x6a, 0xbf, 0x08, 0xf2, 0x1b, 0x7b, 0x4d, 0x04, 0x59, 0xb9, 0xc5, 0x8f, - 0x9f, 0xf7, 0xe7, 0xf7, 0xb5, 0x9f, 0x90, 0xa7, 0x09, 0x5b, 0x87, 0x29, 0xcb, 0x98, 0xe4, 0x32, - 0xc8, 0x05, 0x28, 0xa0, 0xae, 0x64, 0x1c, 0xbf, 0x62, 0x58, 0x05, 0x92, 0xf1, 0x78, 0x19, 0xf1, - 0x2c, 0x48, 0xd8, 0xba, 0x7f, 0x94, 0x42, 0x0a, 0xb8, 0x15, 0xea, 0xaf, 0xc2, 0xdf, 0x7f, 0xa2, - 0x11, 0x79, 0x24, 0xa2, 0x4b, 0x43, 0xe8, 0x1f, 0x6a, 0x65, 0x05, 0x59, 0xfa, 0x79, 0x01, 0x70, - 0x61, 0xc4, 0x23, 0x2d, 0xca, 0x25, 0x08, 0x55, 0x56, 0x1f, 0x6b, 0x15, 0x44, 0xc2, 0x84, 0x11, - 0xa8, 0x16, 0x62, 0xc8, 0x94, 0x88, 0x62, 0x65, 0xb4, 0x47, 0xc5, 0x09, 0x5c, 0x94, 0x8b, 0x72, - 0xc1, 0x63, 0x56, 0x08, 0x83, 0x1f, 0x0e, 0xe9, 0x9e, 0x16, 0x43, 0xcc, 0x55, 0xa4, 0x18, 0x7d, - 0x43, 0xda, 0x45, 0x47, 0xae, 0xe3, 0x3b, 0xc3, 0xce, 0xc8, 0x0f, 0xea, 0x86, 0x0a, 0xa6, 0xe8, - 0x1b, 0xb7, 0xae, 0x7f, 0x1d, 0x37, 0x66, 0xa6, 0x8a, 0xce, 0x49, 0xcf, 0xf6, 0x80, 0x40, 0xf7, - 0x9e, 0xdf, 0x1c, 0x76, 0x46, 0x2f, 0xea, 0x31, 0xef, 0xca, 0x76, 0x43, 0xab, 0x32, 0xe8, 0x33, - 0x72, 0xb0, 0x8a, 0xa4, 0x7a, 0x9f, 0x43, 0xbc, 0x74, 0x9b, 0xbe, 0x33, 0x6c, 0xcd, 0x76, 0xc2, - 0xe0, 0xaa, 0x45, 0x7a, 0x15, 0x08, 0x9d, 0x91, 0xae, 0x05, 0x9c, 0x65, 0x5f, 0xc0, 0x8c, 0x32, - 0xdc, 0xdf, 0x83, 0x76, 0x7f, 0x18, 0x99, 0x26, 0x2a, 0x0c, 0x3a, 0x21, 0x5d, 0xfd, 0x30, 0x63, - 0x80, 0x8b, 0x09, 0x97, 0xca, 0xcc, 0x35, 0xa8, 0x67, 0x4e, 0x8c, 0xdb, 0xd2, 0xca, 0xd5, 0xf4, - 0x9c, 0xf4, 0xf0, 0x45, 0x6f, 0x71, 0x4d, 0xc4, 0x3d, 0xaf, 0xc7, 0xcd, 0xad, 0xdd, 0x5e, 0x51, - 0xa5, 0x9e, 0x7e, 0x24, 0x87, 0x4a, 0xf0, 0x34, 0x65, 0x82, 0x25, 0xe7, 0x3a, 0x15, 0x12, 0xb1, - 0x2d, 0xc4, 0x1e, 0xd7, 0x63, 0xd1, 0x6b, 0x90, 0xff, 0x22, 0xd0, 0xb7, 0xe4, 0xa1, 0x0e, 0x10, - 0xd2, 0xee, 0x23, 0xcd, 0xbb, 0x2b, 0x12, 0xdc, 0xc2, 0x6e, 0xab, 0xe8, 0x94, 0x1c, 0x60, 0xe4, - 0x10, 0xd1, 0x46, 0xc4, 0xcb, 0xfd, 0x4f, 0xa1, 0x51, 0x53, 0x5d, 0x66, 0x13, 0xb6, 0x83, 0x50, - 0x9f, 0x74, 0x32, 0xb6, 0x56, 0xd8, 0xe5, 0x59, 0xe2, 0x3e, 0xc0, 0x44, 0x94, 0xa5, 0xc1, 0x95, - 0x43, 0xe8, 0xdf, 0x24, 0x3a, 0x36, 0xad, 0x68, 0xc9, 0xa4, 0xe2, 0xff, 0xa6, 0xd9, 0x95, 0xd1, - 0xd7, 0xa4, 0x8d, 0x0b, 0x69, 0x22, 0x70, 0xc7, 0xe5, 0xe2, 0xa9, 0x33, 0x63, 0x1f, 0x9f, 0x5e, - 0x6f, 0x3c, 0xe7, 0x66, 0xe3, 0x39, 0xbf, 0x37, 0x9e, 0xf3, 0x7d, 0xeb, 0x35, 0x6e, 0xb6, 0x5e, - 0xe3, 0xe7, 0xd6, 0x6b, 0x7c, 0x3a, 0x49, 0xb9, 0x5a, 0x7e, 0x5d, 0x04, 0x31, 0x5c, 0x86, 0x92, - 0xf1, 0x13, 0x4b, 0xc3, 0x05, 0xe2, 0xc2, 0x75, 0xa8, 0x7f, 0x5d, 0xf5, 0x2d, 0x67, 0x72, 0xd1, - 0xc6, 0xfd, 0x57, 0x7f, 0x02, 0x00, 0x00, 0xff, 0xff, 0x8f, 0x4d, 0x7c, 0x7f, 0x83, 0x04, 0x00, - 0x00, -} - -func (m *GenesisState) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *GenesisState) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *GenesisState) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.LastEpoch != 0 { - i = encodeVarintGenesis(dAtA, i, uint64(m.LastEpoch)) - i-- - dAtA[i] = 0x18 - } - if len(m.ContractState) > 0 { - for iNdEx := len(m.ContractState) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.ContractState[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - } - { - size, err := m.Params.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - return len(dAtA) - i, nil -} - -func (m *ContractState) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *ContractState) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *ContractState) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.NextOrderId != 0 { - i = encodeVarintGenesis(dAtA, i, uint64(m.NextOrderId)) - i-- - dAtA[i] = 0x38 - } - if len(m.PriceList) > 0 { - for iNdEx := len(m.PriceList) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.PriceList[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x32 - } - } - if len(m.PairList) > 0 { - for iNdEx := len(m.PairList) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.PairList[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x2a - } - } - if len(m.TriggeredOrdersList) > 0 { - for iNdEx := len(m.TriggeredOrdersList) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.TriggeredOrdersList[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x22 - } - } - if len(m.ShortBookList) > 0 { - for iNdEx := len(m.ShortBookList) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.ShortBookList[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - } - } - if len(m.LongBookList) > 0 { - for iNdEx := len(m.LongBookList) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.LongBookList[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - } - { - size, err := m.ContractInfo.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - return len(dAtA) - i, nil -} - -func (m *ContractPairPrices) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *ContractPairPrices) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *ContractPairPrices) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Prices) > 0 { - for iNdEx := len(m.Prices) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Prices[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - } - { - size, err := m.PricePair.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - return len(dAtA) - i, nil -} - -func encodeVarintGenesis(dAtA []byte, offset int, v uint64) int { - offset -= sovGenesis(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *GenesisState) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = m.Params.Size() - n += 1 + l + sovGenesis(uint64(l)) - if len(m.ContractState) > 0 { - for _, e := range m.ContractState { - l = e.Size() - n += 1 + l + sovGenesis(uint64(l)) - } - } - if m.LastEpoch != 0 { - n += 1 + sovGenesis(uint64(m.LastEpoch)) - } - return n -} - -func (m *ContractState) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = m.ContractInfo.Size() - n += 1 + l + sovGenesis(uint64(l)) - if len(m.LongBookList) > 0 { - for _, e := range m.LongBookList { - l = e.Size() - n += 1 + l + sovGenesis(uint64(l)) - } - } - if len(m.ShortBookList) > 0 { - for _, e := range m.ShortBookList { - l = e.Size() - n += 1 + l + sovGenesis(uint64(l)) - } - } - if len(m.TriggeredOrdersList) > 0 { - for _, e := range m.TriggeredOrdersList { - l = e.Size() - n += 1 + l + sovGenesis(uint64(l)) - } - } - if len(m.PairList) > 0 { - for _, e := range m.PairList { - l = e.Size() - n += 1 + l + sovGenesis(uint64(l)) - } - } - if len(m.PriceList) > 0 { - for _, e := range m.PriceList { - l = e.Size() - n += 1 + l + sovGenesis(uint64(l)) - } - } - if m.NextOrderId != 0 { - n += 1 + sovGenesis(uint64(m.NextOrderId)) - } - return n -} - -func (m *ContractPairPrices) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = m.PricePair.Size() - n += 1 + l + sovGenesis(uint64(l)) - if len(m.Prices) > 0 { - for _, e := range m.Prices { - l = e.Size() - n += 1 + l + sovGenesis(uint64(l)) - } - } - return n -} - -func sovGenesis(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozGenesis(x uint64) (n int) { - return sovGenesis(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *GenesisState) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: GenesisState: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: GenesisState: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Params", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenesis - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGenesis - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Params.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractState", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenesis - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGenesis - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractState = append(m.ContractState, ContractState{}) - if err := m.ContractState[len(m.ContractState)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field LastEpoch", wireType) - } - m.LastEpoch = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.LastEpoch |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipGenesis(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthGenesis - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *ContractState) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: ContractState: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: ContractState: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractInfo", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenesis - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGenesis - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.ContractInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field LongBookList", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenesis - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGenesis - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.LongBookList = append(m.LongBookList, LongBook{}) - if err := m.LongBookList[len(m.LongBookList)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ShortBookList", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenesis - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGenesis - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ShortBookList = append(m.ShortBookList, ShortBook{}) - if err := m.ShortBookList[len(m.ShortBookList)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field TriggeredOrdersList", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenesis - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGenesis - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.TriggeredOrdersList = append(m.TriggeredOrdersList, Order{}) - if err := m.TriggeredOrdersList[len(m.TriggeredOrdersList)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PairList", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenesis - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGenesis - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PairList = append(m.PairList, Pair{}) - if err := m.PairList[len(m.PairList)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 6: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceList", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenesis - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGenesis - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceList = append(m.PriceList, ContractPairPrices{}) - if err := m.PriceList[len(m.PriceList)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 7: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NextOrderId", wireType) - } - m.NextOrderId = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.NextOrderId |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipGenesis(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthGenesis - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *ContractPairPrices) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: ContractPairPrices: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: ContractPairPrices: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PricePair", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenesis - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGenesis - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.PricePair.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Prices", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGenesis - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGenesis - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGenesis - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Prices = append(m.Prices, &Price{}) - if err := m.Prices[len(m.Prices)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipGenesis(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthGenesis - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipGenesis(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowGenesis - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowGenesis - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowGenesis - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthGenesis - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupGenesis - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthGenesis - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthGenesis = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowGenesis = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupGenesis = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/genesis_test.go b/x/dex/types/genesis_test.go deleted file mode 100644 index 49384da41c..0000000000 --- a/x/dex/types/genesis_test.go +++ /dev/null @@ -1,228 +0,0 @@ -package types_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestGenesisState_Validate(t *testing.T) { - for _, tc := range []struct { - desc string - genState *types.GenesisState - valid bool - }{ - { - desc: "default is valid", - genState: types.DefaultGenesis(), - valid: true, - }, - { - desc: "valid genesis state", - genState: &types.GenesisState{ - Params: types.DefaultParams(), - ContractState: []types.ContractState{ - { - LongBookList: []types.LongBook{ - { - Price: sdk.NewDec(0), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - { - Price: sdk.NewDec(1), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - }, - ShortBookList: []types.ShortBook{ - { - Price: sdk.NewDec(0), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - { - Price: sdk.NewDec(1), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - }, - ContractInfo: types.ContractInfoV2{ - CodeId: uint64(1), - ContractAddr: "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m", - }, - }, - }, - // this line is used by starport scaffolding # types/genesis/validField - }, - valid: true, - }, - { - desc: "same price multiple markets", - genState: &types.GenesisState{ - Params: types.DefaultParams(), - ContractState: []types.ContractState{ - { - LongBookList: []types.LongBook{ - { - Price: sdk.NewDec(0), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - { - Price: sdk.NewDec(0), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "USDC", - AssetDenom: "ATOM", - }, - }, - }, - ShortBookList: []types.ShortBook{ - { - Price: sdk.NewDec(0), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - { - Price: sdk.NewDec(1), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - }, - ContractInfo: types.ContractInfoV2{ - CodeId: uint64(1), - ContractAddr: "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m", - }, - }, - }, - // this line is used by starport scaffolding # types/genesis/validField - }, - valid: true, - }, - { - desc: "duplicated longBook", - genState: &types.GenesisState{ - Params: types.DefaultParams(), - ContractState: []types.ContractState{ - { - LongBookList: []types.LongBook{ - { - Price: sdk.NewDec(0), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - { - Price: sdk.NewDec(0), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - }, - ContractInfo: types.ContractInfoV2{ - CodeId: uint64(1), - ContractAddr: "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m", - }, - }, - }, - }, - valid: false, - }, - { - desc: "duplicated shortBook", - genState: &types.GenesisState{ - Params: types.DefaultParams(), - ContractState: []types.ContractState{ - { - ShortBookList: []types.ShortBook{ - { - Price: sdk.NewDec(0), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - { - Price: sdk.NewDec(0), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - }, - ContractInfo: types.ContractInfoV2{ - CodeId: uint64(1), - ContractAddr: "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m", - }, - }, - }, - }, - valid: false, - }, - { - desc: "invalid contract addr", - genState: &types.GenesisState{ - Params: types.DefaultParams(), - ContractState: []types.ContractState{ - { - ShortBookList: []types.ShortBook{ - { - Price: sdk.NewDec(0), - Entry: &types.OrderEntry{ - Price: sdk.NewDec(0), - PriceDenom: "SEI", - AssetDenom: "ATOM", - }, - }, - }, - ContractInfo: types.ContractInfoV2{ - CodeId: uint64(1), - ContractAddr: "invalid", - }, - }, - }, - }, - valid: false, - }, - // this line is used by starport scaffolding # types/genesis/testcase - } { - t.Run(tc.desc, func(t *testing.T) { - err := tc.genState.Validate() - if tc.valid { - require.NoError(t, err) - } else { - require.Error(t, err) - } - }) - } -} diff --git a/x/dex/types/gov.go b/x/dex/types/gov.go deleted file mode 100644 index 72cd85c4c8..0000000000 --- a/x/dex/types/gov.go +++ /dev/null @@ -1,57 +0,0 @@ -package types - -import ( - "fmt" - "strings" - - sdk "github.com/cosmos/cosmos-sdk/types" - govtypes "github.com/cosmos/cosmos-sdk/x/gov/types" -) - -const ( - ProposalTypeAddAssetMetadata = "AddAssetMetadata" -) - -func init() { - // for routing - govtypes.RegisterProposalType(ProposalTypeAddAssetMetadata) - // for marshal and unmarshal - govtypes.RegisterProposalTypeCodec(&AddAssetMetadataProposal{}, "dex/AddAssetMetadataProposal") -} - -func (p *AddAssetMetadataProposal) GetTitle() string { return p.Title } - -func (p *AddAssetMetadataProposal) GetDescription() string { return p.Description } - -func (p *AddAssetMetadataProposal) ProposalRoute() string { return RouterKey } - -func (p *AddAssetMetadataProposal) ProposalType() string { - return ProposalTypeAddAssetMetadata -} - -func (p *AddAssetMetadataProposal) ValidateBasic() error { - // Verify base denoms specified in proposal are well formed - for _, asset := range p.AssetList { - err := sdk.ValidateDenom(asset.Metadata.Base) - if err != nil { - return err - } - } - - err := govtypes.ValidateAbstract(p) - return err -} - -func (p AddAssetMetadataProposal) String() string { - assetRecords := "" - for _, asset := range p.AssetList { - assetRecords += asset.String() - } - var b strings.Builder - b.WriteString(fmt.Sprintf(`Add Asset Metadata Proposal: - Title: %s - Description: %s - Records: %s -`, p.Title, p.Description, assetRecords)) - return b.String() -} diff --git a/x/dex/types/gov.pb.go b/x/dex/types/gov.pb.go deleted file mode 100644 index cbfe56b153..0000000000 --- a/x/dex/types/gov.pb.go +++ /dev/null @@ -1,418 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/gov.proto - -package types - -import ( - fmt "fmt" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -// AddAssetMetadataProposal is a gov Content type for adding a new asset -// to the dex module's asset list. -type AddAssetMetadataProposal struct { - Title string `protobuf:"bytes,1,opt,name=title,proto3" json:"title,omitempty" yaml:"title"` - Description string `protobuf:"bytes,2,opt,name=description,proto3" json:"description,omitempty" yaml:"description"` - AssetList []AssetMetadata `protobuf:"bytes,3,rep,name=assetList,proto3" json:"assetList" yaml:"asset_list"` -} - -func (m *AddAssetMetadataProposal) Reset() { *m = AddAssetMetadataProposal{} } -func (*AddAssetMetadataProposal) ProtoMessage() {} -func (*AddAssetMetadataProposal) Descriptor() ([]byte, []int) { - return fileDescriptor_dab07ca1a96062d0, []int{0} -} -func (m *AddAssetMetadataProposal) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *AddAssetMetadataProposal) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_AddAssetMetadataProposal.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *AddAssetMetadataProposal) XXX_Merge(src proto.Message) { - xxx_messageInfo_AddAssetMetadataProposal.Merge(m, src) -} -func (m *AddAssetMetadataProposal) XXX_Size() int { - return m.Size() -} -func (m *AddAssetMetadataProposal) XXX_DiscardUnknown() { - xxx_messageInfo_AddAssetMetadataProposal.DiscardUnknown(m) -} - -var xxx_messageInfo_AddAssetMetadataProposal proto.InternalMessageInfo - -func init() { - proto.RegisterType((*AddAssetMetadataProposal)(nil), "seiprotocol.seichain.dex.AddAssetMetadataProposal") -} - -func init() { proto.RegisterFile("dex/gov.proto", fileDescriptor_dab07ca1a96062d0) } - -var fileDescriptor_dab07ca1a96062d0 = []byte{ - // 307 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0xe2, 0x4d, 0x49, 0xad, 0xd0, - 0x4f, 0xcf, 0x2f, 0xd3, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, 0x92, 0x28, 0x4e, 0xcd, 0x04, 0xb3, - 0x92, 0xf3, 0x73, 0xf4, 0x8a, 0x53, 0x33, 0x93, 0x33, 0x12, 0x33, 0xf3, 0xf4, 0x52, 0x52, 0x2b, - 0xa4, 0x44, 0xd2, 0xf3, 0xd3, 0xf3, 0xc1, 0x52, 0xfa, 0x20, 0x16, 0x44, 0xbd, 0x94, 0x08, 0x48, - 0x7b, 0x62, 0x71, 0x71, 0x6a, 0x49, 0x7c, 0x4e, 0x66, 0x71, 0x09, 0x44, 0x54, 0xe9, 0x0d, 0x23, - 0x97, 0x84, 0x63, 0x4a, 0x8a, 0x23, 0x48, 0xdc, 0x37, 0xb5, 0x24, 0x31, 0x25, 0xb1, 0x24, 0x31, - 0xa0, 0x28, 0xbf, 0x20, 0xbf, 0x38, 0x31, 0x47, 0x48, 0x8d, 0x8b, 0xb5, 0x24, 0xb3, 0x24, 0x27, - 0x55, 0x82, 0x51, 0x81, 0x51, 0x83, 0xd3, 0x49, 0xe0, 0xd3, 0x3d, 0x79, 0x9e, 0xca, 0xc4, 0xdc, - 0x1c, 0x2b, 0x25, 0xb0, 0xb0, 0x52, 0x10, 0x44, 0x5a, 0xc8, 0x82, 0x8b, 0x3b, 0x25, 0xb5, 0x38, - 0xb9, 0x28, 0xb3, 0xa0, 0x24, 0x33, 0x3f, 0x4f, 0x82, 0x09, 0xac, 0x5a, 0xec, 0xd3, 0x3d, 0x79, - 0x21, 0x88, 0x6a, 0x24, 0x49, 0xa5, 0x20, 0x64, 0xa5, 0x42, 0x09, 0x5c, 0x9c, 0x60, 0x27, 0xf9, - 0x64, 0x16, 0x97, 0x48, 0x30, 0x2b, 0x30, 0x6b, 0x70, 0x1b, 0xa9, 0xeb, 0xe1, 0xf2, 0x98, 0x1e, - 0x8a, 0x2b, 0x9d, 0x24, 0x4f, 0xdc, 0x93, 0x67, 0xf8, 0x74, 0x4f, 0x5e, 0x10, 0x62, 0x09, 0xc2, - 0x6b, 0x4a, 0x41, 0x08, 0x43, 0xad, 0x78, 0x3a, 0x16, 0xc8, 0x33, 0xcc, 0x58, 0x20, 0xcf, 0xf0, - 0x62, 0x81, 0x3c, 0x83, 0x93, 0xfb, 0x89, 0x47, 0x72, 0x8c, 0x17, 0x1e, 0xc9, 0x31, 0x3e, 0x78, - 0x24, 0xc7, 0x38, 0xe1, 0xb1, 0x1c, 0xc3, 0x85, 0xc7, 0x72, 0x0c, 0x37, 0x1e, 0xcb, 0x31, 0x44, - 0xe9, 0xa6, 0x67, 0x96, 0x64, 0x94, 0x26, 0xe9, 0x25, 0xe7, 0xe7, 0xea, 0x17, 0xa7, 0x66, 0xea, - 0xc2, 0x5c, 0x00, 0xe6, 0x80, 0x9d, 0xa0, 0x5f, 0xa1, 0x0f, 0x0a, 0xc2, 0x92, 0xca, 0x82, 0xd4, - 0xe2, 0x24, 0x36, 0xb0, 0xbc, 0x31, 0x20, 0x00, 0x00, 0xff, 0xff, 0xce, 0xe9, 0x08, 0x1a, 0x95, - 0x01, 0x00, 0x00, -} - -func (m *AddAssetMetadataProposal) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *AddAssetMetadataProposal) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *AddAssetMetadataProposal) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.AssetList) > 0 { - for iNdEx := len(m.AssetList) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.AssetList[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGov(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - } - } - if len(m.Description) > 0 { - i -= len(m.Description) - copy(dAtA[i:], m.Description) - i = encodeVarintGov(dAtA, i, uint64(len(m.Description))) - i-- - dAtA[i] = 0x12 - } - if len(m.Title) > 0 { - i -= len(m.Title) - copy(dAtA[i:], m.Title) - i = encodeVarintGov(dAtA, i, uint64(len(m.Title))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func encodeVarintGov(dAtA []byte, offset int, v uint64) int { - offset -= sovGov(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *AddAssetMetadataProposal) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Title) - if l > 0 { - n += 1 + l + sovGov(uint64(l)) - } - l = len(m.Description) - if l > 0 { - n += 1 + l + sovGov(uint64(l)) - } - if len(m.AssetList) > 0 { - for _, e := range m.AssetList { - l = e.Size() - n += 1 + l + sovGov(uint64(l)) - } - } - return n -} - -func sovGov(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozGov(x uint64) (n int) { - return sovGov(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *AddAssetMetadataProposal) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGov - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: AddAssetMetadataProposal: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: AddAssetMetadataProposal: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Title", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGov - } - 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 ErrInvalidLengthGov - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthGov - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Title = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Description", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGov - } - 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 ErrInvalidLengthGov - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthGov - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Description = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetList", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowGov - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthGov - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthGov - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetList = append(m.AssetList, AssetMetadata{}) - if err := m.AssetList[len(m.AssetList)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipGov(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthGov - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipGov(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowGov - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowGov - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowGov - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthGov - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupGov - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthGov - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthGov = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowGov = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupGov = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/keys.go b/x/dex/types/keys.go deleted file mode 100644 index c56c1be907..0000000000 --- a/x/dex/types/keys.go +++ /dev/null @@ -1,190 +0,0 @@ -package types - -import ( - "encoding/binary" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/types/address" -) - -const ( - // ModuleName defines the module name - ModuleName = "dex" - - // StoreKey defines the primary module store key - StoreKey = ModuleName - - // RouterKey is the message route for slashing - RouterKey = ModuleName - - // QuerierRoute defines the module's query routing key - QuerierRoute = ModuleName - - // MemStoreKey defines the in-memory store key - MemStoreKey = "mem_dex" -) - -func KeyPrefix(p string) []byte { - return []byte(p) -} - -func AddressKeyPrefix(contractAddr string) []byte { - addr, _ := sdk.AccAddressFromBech32(contractAddr) - return address.MustLengthPrefix(addr) -} - -func ContractKeyPrefix(p string, contractAddr string) []byte { - return append([]byte(p), AddressKeyPrefix(contractAddr)...) -} - -func DenomPrefix(denom string) []byte { - length := uint16(len(denom)) - bz := make([]byte, 2) - binary.BigEndian.PutUint16(bz, length) - return append(bz, []byte(denom)...) -} - -func PairPrefix(priceDenom string, assetDenom string) []byte { - return append(DenomPrefix(priceDenom), DenomPrefix(assetDenom)...) -} - -func OrderBookPrefix(long bool, contractAddr string, priceDenom string, assetDenom string) []byte { - return append( - OrderBookContractPrefix(long, contractAddr), - PairPrefix(priceDenom, assetDenom)..., - ) -} - -func OrderBookContractPrefix(long bool, contractAddr string) []byte { - var prefix []byte - if long { - prefix = KeyPrefix(LongBookKey) - } else { - prefix = KeyPrefix(ShortBookKey) - } - return append(prefix, AddressKeyPrefix(contractAddr)...) -} - -// `Price` constant + contract + price denom + asset denom -func PricePrefix(contractAddr string, priceDenom string, assetDenom string) []byte { - return append( - PriceContractPrefix(contractAddr), - PairPrefix(priceDenom, assetDenom)..., - ) -} - -func PriceContractPrefix(contractAddr string) []byte { - return append(KeyPrefix(PriceKey), AddressKeyPrefix(contractAddr)...) -} - -func RegisteredPairPrefix(contractAddr string) []byte { - return append(KeyPrefix(RegisteredPairKey), AddressKeyPrefix(contractAddr)...) -} - -func OrderPrefix(contractAddr string) []byte { - return append(KeyPrefix(OrderKey), AddressKeyPrefix(contractAddr)...) -} - -func AssetListPrefix(assetDenom string) []byte { - return append(KeyPrefix(AssetListKey), DenomPrefix(assetDenom)...) -} - -func NextOrderIDPrefix(contractAddr string) []byte { - return append(KeyPrefix(NextOrderIDKey), AddressKeyPrefix(contractAddr)...) -} - -func MatchResultPrefix(contractAddr string) []byte { - return append(KeyPrefix(MatchResultKey), AddressKeyPrefix(contractAddr)...) -} - -func GetSettlementOrderIDPrefix(orderID uint64, account string) []byte { - accountBytes := append([]byte(account), []byte("|")...) - orderIDBytes := make([]byte, 8) - binary.BigEndian.PutUint64(orderIDBytes, orderID) - return append(accountBytes, orderIDBytes...) -} - -func GetSettlementKey(orderID uint64, account string, settlementID uint64) []byte { - settlementIDBytes := make([]byte, 8) - binary.BigEndian.PutUint64(settlementIDBytes, settlementID) - return append(GetSettlementOrderIDPrefix(orderID, account), settlementIDBytes...) -} - -func MemOrderPrefixForPair(contractAddr string, priceDenom string, assetDenom string) []byte { - return append( - append(KeyPrefix(MemOrderKey), AddressKeyPrefix(contractAddr)...), - PairPrefix(priceDenom, assetDenom)..., - ) -} - -func MemCancelPrefixForPair(contractAddr string, priceDenom string, assetDenom string) []byte { - return append( - append(KeyPrefix(MemCancelKey), AddressKeyPrefix(contractAddr)...), - PairPrefix(priceDenom, assetDenom)..., - ) -} - -func MemOrderPrefix(contractAddr string) []byte { - return append(KeyPrefix(MemOrderKey), AddressKeyPrefix(contractAddr)...) -} - -func MemCancelPrefix(contractAddr string) []byte { - return append(KeyPrefix(MemCancelKey), AddressKeyPrefix(contractAddr)...) -} - -func MemDepositPrefix(contractAddr string) []byte { - return append(KeyPrefix(MemDepositKey), AddressKeyPrefix(contractAddr)...) -} - -func MemDepositSubprefix(creator, denom string) []byte { - return append([]byte(creator), DenomPrefix(denom)...) -} - -func MemContractsToProcessKey(contractAddr string) []byte { - return append(KeyPrefix(MemContractsToProcess), AddressKeyPrefix(contractAddr)...) -} - -func MemDownstreamContractsKey(contractAddr string) []byte { - return append(KeyPrefix(MemDownstreamContracts), AddressKeyPrefix(contractAddr)...) -} - -func ContractKey(contractAddr string) []byte { - return AddressKeyPrefix(contractAddr) -} - -func OrderCountPrefix(contractAddr string, priceDenom string, assetDenom string, long bool) []byte { - var prefix []byte - if long { - prefix = KeyPrefix(LongOrderCountKey) - } else { - prefix = KeyPrefix(ShortOrderCountKey) - } - return append(prefix, append(AddressKeyPrefix(contractAddr), PairPrefix(priceDenom, assetDenom)...)...) -} - -const ( - LongBookKey = "LongBook-value-" - - ShortBookKey = "ShortBook-value-" - - OrderKey = "order" - AccountActiveOrdersKey = "account-active-orders" - CancelKey = "cancel" - - TwapKey = "TWAP-" - PriceKey = "Price-" - SettlementEntryKey = "SettlementEntry-" - NextSettlementIDKey = "NextSettlementID-" - NextOrderIDKey = "noid" - RegisteredPairKey = "rp" - AssetListKey = "AssetList-" - MatchResultKey = "MatchResult-" - LongOrderCountKey = "loc-" - ShortOrderCountKey = "soc-" - - MemOrderKey = "MemOrder-" - MemDepositKey = "MemDeposit-" - MemCancelKey = "MemCancel-" - MemContractsToProcess = "MemContractsToProcess-" - MemDownstreamContracts = "MemDownstreamContracts-" -) diff --git a/x/dex/types/keys_test.go b/x/dex/types/keys_test.go deleted file mode 100644 index a635435ba0..0000000000 --- a/x/dex/types/keys_test.go +++ /dev/null @@ -1,29 +0,0 @@ -package types_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/cosmos/cosmos-sdk/types/address" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestOrderPrefix(t *testing.T) { - testContract := "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m" - addr, _ := sdk.AccAddressFromBech32(testContract) - addr = address.MustLengthPrefix(addr) - expected := append([]byte(types.OrderKey), addr...) - require.Equal(t, expected, types.OrderPrefix(testContract)) -} - -func TestPricePrefix(t *testing.T) { - testContract := "sei14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sh9m79m" - testPriceDenom := "SEI" - testAssetDenom := "ATOM" - address := types.AddressKeyPrefix(testContract) - priceContractBytes := append([]byte(types.PriceKey), address...) - pairBytes := types.PairPrefix(testPriceDenom, testAssetDenom) - expectedKey := append(priceContractBytes, pairBytes...) - require.Equal(t, expectedKey, types.PricePrefix(testContract, testPriceDenom, testAssetDenom)) -} diff --git a/x/dex/types/long_book.pb.go b/x/dex/types/long_book.pb.go deleted file mode 100644 index 2f5167c994..0000000000 --- a/x/dex/types/long_book.pb.go +++ /dev/null @@ -1,380 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/long_book.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type LongBook struct { - Price github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,1,opt,name=price,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"price" yaml:"price"` - Entry *OrderEntry `protobuf:"bytes,2,opt,name=entry,proto3" json:"entry"` -} - -func (m *LongBook) Reset() { *m = LongBook{} } -func (m *LongBook) String() string { return proto.CompactTextString(m) } -func (*LongBook) ProtoMessage() {} -func (*LongBook) Descriptor() ([]byte, []int) { - return fileDescriptor_daa9d9e2359557c9, []int{0} -} -func (m *LongBook) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *LongBook) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_LongBook.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *LongBook) XXX_Merge(src proto.Message) { - xxx_messageInfo_LongBook.Merge(m, src) -} -func (m *LongBook) XXX_Size() int { - return m.Size() -} -func (m *LongBook) XXX_DiscardUnknown() { - xxx_messageInfo_LongBook.DiscardUnknown(m) -} - -var xxx_messageInfo_LongBook proto.InternalMessageInfo - -func (m *LongBook) GetEntry() *OrderEntry { - if m != nil { - return m.Entry - } - return nil -} - -func init() { - proto.RegisterType((*LongBook)(nil), "seiprotocol.seichain.dex.LongBook") -} - -func init() { proto.RegisterFile("dex/long_book.proto", fileDescriptor_daa9d9e2359557c9) } - -var fileDescriptor_daa9d9e2359557c9 = []byte{ - // 278 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x12, 0x4e, 0x49, 0xad, 0xd0, - 0xcf, 0xc9, 0xcf, 0x4b, 0x8f, 0x4f, 0xca, 0xcf, 0xcf, 0xd6, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, - 0x92, 0x28, 0x4e, 0xcd, 0x04, 0xb3, 0x92, 0xf3, 0x73, 0xf4, 0x8a, 0x53, 0x33, 0x93, 0x33, 0x12, - 0x33, 0xf3, 0xf4, 0x52, 0x52, 0x2b, 0xa4, 0x44, 0x41, 0xca, 0xf3, 0x8b, 0x52, 0x52, 0x8b, 0xe2, - 0x53, 0xf3, 0x4a, 0x8a, 0x2a, 0x21, 0x1a, 0xa4, 0x44, 0xd2, 0xf3, 0xd3, 0xf3, 0xc1, 0x4c, 0x7d, - 0x10, 0x0b, 0x22, 0xaa, 0xb4, 0x81, 0x91, 0x8b, 0xc3, 0x27, 0x3f, 0x2f, 0xdd, 0x29, 0x3f, 0x3f, - 0x5b, 0x28, 0x96, 0x8b, 0xb5, 0xa0, 0x28, 0x33, 0x39, 0x55, 0x82, 0x51, 0x81, 0x51, 0x83, 0xd3, - 0xc9, 0xfd, 0xc4, 0x3d, 0x79, 0x86, 0x5b, 0xf7, 0xe4, 0xd5, 0xd2, 0x33, 0x4b, 0x32, 0x4a, 0x93, - 0xf4, 0x92, 0xf3, 0x73, 0xf5, 0x93, 0xf3, 0x8b, 0x73, 0xf3, 0x8b, 0xa1, 0x94, 0x6e, 0x71, 0x4a, - 0xb6, 0x7e, 0x49, 0x65, 0x41, 0x6a, 0xb1, 0x9e, 0x4b, 0x6a, 0xf2, 0xab, 0x7b, 0xf2, 0x10, 0xed, - 0x9f, 0xee, 0xc9, 0xf3, 0x54, 0x26, 0xe6, 0xe6, 0x58, 0x29, 0x81, 0xb9, 0x4a, 0x41, 0x10, 0x61, - 0x21, 0x57, 0x2e, 0x56, 0xb0, 0x83, 0x24, 0x98, 0x14, 0x18, 0x35, 0xb8, 0x8d, 0x54, 0xf4, 0x70, - 0x79, 0x41, 0xcf, 0x1f, 0xe4, 0x7a, 0x57, 0x90, 0x5a, 0x27, 0x4e, 0x90, 0xb1, 0x60, 0x6d, 0x41, - 0x10, 0xca, 0xc9, 0xfd, 0xc4, 0x23, 0x39, 0xc6, 0x0b, 0x8f, 0xe4, 0x18, 0x1f, 0x3c, 0x92, 0x63, - 0x9c, 0xf0, 0x58, 0x8e, 0xe1, 0xc2, 0x63, 0x39, 0x86, 0x1b, 0x8f, 0xe5, 0x18, 0xa2, 0x74, 0x91, - 0x1c, 0x5a, 0x9c, 0x9a, 0xa9, 0x0b, 0x33, 0x1c, 0xcc, 0x01, 0x9b, 0xae, 0x5f, 0xa1, 0x0f, 0x0a, - 0x1d, 0xb0, 0x9b, 0x93, 0xd8, 0xc0, 0xf2, 0xc6, 0x80, 0x00, 0x00, 0x00, 0xff, 0xff, 0x3e, 0xf1, - 0xb1, 0x25, 0x60, 0x01, 0x00, 0x00, -} - -func (m *LongBook) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *LongBook) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *LongBook) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Entry != nil { - { - size, err := m.Entry.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintLongBook(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - { - size := m.Price.Size() - i -= size - if _, err := m.Price.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintLongBook(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - return len(dAtA) - i, nil -} - -func encodeVarintLongBook(dAtA []byte, offset int, v uint64) int { - offset -= sovLongBook(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *LongBook) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = m.Price.Size() - n += 1 + l + sovLongBook(uint64(l)) - if m.Entry != nil { - l = m.Entry.Size() - n += 1 + l + sovLongBook(uint64(l)) - } - return n -} - -func sovLongBook(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozLongBook(x uint64) (n int) { - return sovLongBook(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *LongBook) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowLongBook - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: LongBook: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: LongBook: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowLongBook - } - 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 ErrInvalidLengthLongBook - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthLongBook - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Price.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Entry", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowLongBook - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthLongBook - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthLongBook - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Entry == nil { - m.Entry = &OrderEntry{} - } - if err := m.Entry.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipLongBook(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthLongBook - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipLongBook(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowLongBook - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowLongBook - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowLongBook - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthLongBook - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupLongBook - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthLongBook - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthLongBook = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowLongBook = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupLongBook = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/match_result.go b/x/dex/types/match_result.go deleted file mode 100644 index d77c3767d4..0000000000 --- a/x/dex/types/match_result.go +++ /dev/null @@ -1,28 +0,0 @@ -package types - -import ( - "sort" -) - -func NewMatchResult( - orders []*Order, - cancellations []*Cancellation, - settlements []*SettlementEntry, -) *MatchResult { - // Note that we use string comparator since it is more robust. E.g. in the case that 2 orders match - // on the same orderId, we will then sort on the next field - sort.SliceStable(orders, func(i, j int) bool { - return orders[i].String() < orders[j].String() - }) - sort.SliceStable(cancellations, func(i, j int) bool { - return cancellations[i].String() < cancellations[j].String() - }) - sort.SliceStable(settlements, func(i, j int) bool { - return settlements[i].String() < settlements[j].String() - }) - return &MatchResult{ - Orders: orders, - Cancellations: cancellations, - Settlements: settlements, - } -} diff --git a/x/dex/types/match_result.pb.go b/x/dex/types/match_result.pb.go deleted file mode 100644 index 82966f2898..0000000000 --- a/x/dex/types/match_result.pb.go +++ /dev/null @@ -1,548 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/match_result.proto - -package types - -import ( - fmt "fmt" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type MatchResult struct { - Height int64 `protobuf:"varint,1,opt,name=height,proto3" json:"height"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contract_address"` - Orders []*Order `protobuf:"bytes,3,rep,name=orders,proto3" json:"orders"` - Settlements []*SettlementEntry `protobuf:"bytes,4,rep,name=settlements,proto3" json:"settlements"` - Cancellations []*Cancellation `protobuf:"bytes,5,rep,name=cancellations,proto3" json:"cancellations"` -} - -func (m *MatchResult) Reset() { *m = MatchResult{} } -func (m *MatchResult) String() string { return proto.CompactTextString(m) } -func (*MatchResult) ProtoMessage() {} -func (*MatchResult) Descriptor() ([]byte, []int) { - return fileDescriptor_9225b122096d4ce7, []int{0} -} -func (m *MatchResult) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MatchResult) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MatchResult.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MatchResult) XXX_Merge(src proto.Message) { - xxx_messageInfo_MatchResult.Merge(m, src) -} -func (m *MatchResult) XXX_Size() int { - return m.Size() -} -func (m *MatchResult) XXX_DiscardUnknown() { - xxx_messageInfo_MatchResult.DiscardUnknown(m) -} - -var xxx_messageInfo_MatchResult proto.InternalMessageInfo - -func (m *MatchResult) GetHeight() int64 { - if m != nil { - return m.Height - } - return 0 -} - -func (m *MatchResult) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *MatchResult) GetOrders() []*Order { - if m != nil { - return m.Orders - } - return nil -} - -func (m *MatchResult) GetSettlements() []*SettlementEntry { - if m != nil { - return m.Settlements - } - return nil -} - -func (m *MatchResult) GetCancellations() []*Cancellation { - if m != nil { - return m.Cancellations - } - return nil -} - -func init() { - proto.RegisterType((*MatchResult)(nil), "seiprotocol.seichain.dex.MatchResult") -} - -func init() { proto.RegisterFile("dex/match_result.proto", fileDescriptor_9225b122096d4ce7) } - -var fileDescriptor_9225b122096d4ce7 = []byte{ - // 345 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x74, 0x91, 0xc1, 0x6a, 0xfa, 0x40, - 0x10, 0xc6, 0x8d, 0xfe, 0xff, 0x42, 0xd7, 0x16, 0xdb, 0x20, 0x25, 0x78, 0x48, 0xc4, 0x43, 0xb1, - 0x07, 0x13, 0x68, 0x2f, 0xbd, 0x36, 0x52, 0x7a, 0x2a, 0x85, 0xf4, 0x56, 0x0a, 0x12, 0x77, 0x87, - 0x64, 0x21, 0x66, 0x65, 0x77, 0x04, 0x7d, 0x8b, 0x3e, 0x56, 0x8f, 0x1e, 0x7b, 0x0a, 0x45, 0x6f, - 0xb9, 0xf4, 0x15, 0xca, 0x6e, 0xb4, 0xd5, 0x83, 0xa7, 0x99, 0xf9, 0xf2, 0xcd, 0xef, 0xcb, 0xb0, - 0xe4, 0x92, 0xc1, 0x22, 0x98, 0xc6, 0x48, 0xd3, 0xb1, 0x04, 0x35, 0xcf, 0xd0, 0x9f, 0x49, 0x81, - 0xc2, 0x76, 0x14, 0x70, 0xd3, 0x51, 0x91, 0xf9, 0x0a, 0x38, 0x4d, 0x63, 0x9e, 0xfb, 0x0c, 0x16, - 0xdd, 0xb6, 0xde, 0x10, 0x92, 0x81, 0xac, 0xac, 0xdd, 0x8e, 0x16, 0x14, 0x20, 0x66, 0x30, 0x85, - 0x1c, 0x77, 0x6a, 0x22, 0x12, 0x61, 0xda, 0x40, 0x77, 0x95, 0xda, 0xff, 0xae, 0x93, 0xd6, 0x93, - 0x4e, 0x8b, 0x4c, 0x98, 0xdd, 0x27, 0xcd, 0x14, 0x78, 0x92, 0xa2, 0x63, 0xf5, 0xac, 0x41, 0x23, - 0x24, 0x65, 0xe1, 0x6d, 0x95, 0x68, 0x5b, 0xed, 0x3b, 0x72, 0x4a, 0x45, 0x8e, 0x32, 0xa6, 0x78, - 0xcf, 0x98, 0x74, 0xea, 0x3d, 0x6b, 0x70, 0x12, 0x76, 0xca, 0xc2, 0x3b, 0xdf, 0xe9, 0xe3, 0x98, - 0x31, 0x09, 0x4a, 0x45, 0x07, 0x4e, 0x7b, 0x44, 0x9a, 0xe6, 0x47, 0x95, 0xd3, 0xe8, 0x35, 0x06, - 0xad, 0x1b, 0xcf, 0x3f, 0x76, 0x95, 0xff, 0xac, 0x7d, 0x55, 0x7c, 0xb5, 0x12, 0x6d, 0xab, 0xfd, - 0x46, 0x5a, 0x7f, 0xc7, 0x29, 0xe7, 0x9f, 0x21, 0x5d, 0x1f, 0x27, 0xbd, 0xfc, 0x9a, 0x1f, 0x72, - 0x94, 0xcb, 0xb0, 0x5d, 0x16, 0xde, 0x3e, 0x21, 0xda, 0x1f, 0xec, 0x31, 0x39, 0xa3, 0x71, 0x4e, - 0x21, 0xcb, 0x62, 0xe4, 0x22, 0x57, 0xce, 0x7f, 0xc3, 0xbf, 0x3a, 0xce, 0x1f, 0xed, 0xd9, 0xc3, - 0x8b, 0xb2, 0xf0, 0x0e, 0x01, 0xd1, 0xe1, 0x18, 0x3e, 0x7e, 0xac, 0x5d, 0x6b, 0xb5, 0x76, 0xad, - 0xaf, 0xb5, 0x6b, 0xbd, 0x6f, 0xdc, 0xda, 0x6a, 0xe3, 0xd6, 0x3e, 0x37, 0x6e, 0xed, 0x75, 0x98, - 0x70, 0x4c, 0xe7, 0x13, 0x9f, 0x8a, 0x69, 0xa0, 0x80, 0x0f, 0x77, 0x71, 0x66, 0x30, 0x79, 0xc1, - 0x22, 0xd0, 0x6f, 0x8b, 0xcb, 0x19, 0xa8, 0x49, 0xd3, 0x7c, 0xbf, 0xfd, 0x09, 0x00, 0x00, 0xff, - 0xff, 0x40, 0xd8, 0xfe, 0x79, 0x32, 0x02, 0x00, 0x00, -} - -func (m *MatchResult) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MatchResult) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MatchResult) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Cancellations) > 0 { - for iNdEx := len(m.Cancellations) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Cancellations[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintMatchResult(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x2a - } - } - if len(m.Settlements) > 0 { - for iNdEx := len(m.Settlements) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Settlements[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintMatchResult(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x22 - } - } - if len(m.Orders) > 0 { - for iNdEx := len(m.Orders) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Orders[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintMatchResult(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - } - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintMatchResult(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if m.Height != 0 { - i = encodeVarintMatchResult(dAtA, i, uint64(m.Height)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func encodeVarintMatchResult(dAtA []byte, offset int, v uint64) int { - offset -= sovMatchResult(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *MatchResult) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Height != 0 { - n += 1 + sovMatchResult(uint64(m.Height)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovMatchResult(uint64(l)) - } - if len(m.Orders) > 0 { - for _, e := range m.Orders { - l = e.Size() - n += 1 + l + sovMatchResult(uint64(l)) - } - } - if len(m.Settlements) > 0 { - for _, e := range m.Settlements { - l = e.Size() - n += 1 + l + sovMatchResult(uint64(l)) - } - } - if len(m.Cancellations) > 0 { - for _, e := range m.Cancellations { - l = e.Size() - n += 1 + l + sovMatchResult(uint64(l)) - } - } - return n -} - -func sovMatchResult(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozMatchResult(x uint64) (n int) { - return sovMatchResult(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *MatchResult) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowMatchResult - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MatchResult: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MatchResult: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Height", wireType) - } - m.Height = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowMatchResult - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Height |= int64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowMatchResult - } - 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 ErrInvalidLengthMatchResult - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthMatchResult - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Orders", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowMatchResult - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthMatchResult - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthMatchResult - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Orders = append(m.Orders, &Order{}) - if err := m.Orders[len(m.Orders)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Settlements", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowMatchResult - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthMatchResult - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthMatchResult - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Settlements = append(m.Settlements, &SettlementEntry{}) - if err := m.Settlements[len(m.Settlements)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Cancellations", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowMatchResult - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthMatchResult - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthMatchResult - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Cancellations = append(m.Cancellations, &Cancellation{}) - if err := m.Cancellations[len(m.Cancellations)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipMatchResult(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthMatchResult - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipMatchResult(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowMatchResult - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowMatchResult - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowMatchResult - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthMatchResult - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupMatchResult - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthMatchResult - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthMatchResult = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowMatchResult = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupMatchResult = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/match_result_test.go b/x/dex/types/match_result_test.go deleted file mode 100644 index 79da33ec30..0000000000 --- a/x/dex/types/match_result_test.go +++ /dev/null @@ -1,54 +0,0 @@ -package types_test - -import ( - "testing" - - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestMatchResultSorted(t *testing.T) { - // Test stable sorting - order1 := &types.Order{ - Id: 1, - } - order2 := &types.Order{ - Id: 1, - } - order3 := &types.Order{ - Id: 2, - } - - // Test sort on different field - cancellation1 := &types.Cancellation{ - Id: 1, - AssetDenom: "a", - } - cancellation2 := &types.Cancellation{ - Id: 1, - AssetDenom: "b", - } - - // Test sort on string - settlement1 := &types.SettlementEntry{ - Account: "a", - } - settlement2 := &types.SettlementEntry{ - Account: "b", - } - - orders := []*types.Order{order3, order1, order2} - cancellations := []*types.Cancellation{cancellation2, cancellation1} - settlements := []*types.SettlementEntry{settlement2, settlement1} - - matchResult := types.NewMatchResult(orders, cancellations, settlements) - expectedOrders := []*types.Order{order1, order2, order3} - expectedCancellations := []*types.Cancellation{cancellation1, cancellation2} - expectedSettlements := []*types.SettlementEntry{settlement1, settlement2} - require.Equal(t, expectedOrders, matchResult.Orders) - // Check actual elements, since slice match above don't seem to capture if the orders point to different objects - require.True(t, order1 == matchResult.Orders[0]) - require.True(t, order2 == matchResult.Orders[1]) - require.Equal(t, expectedCancellations, matchResult.Cancellations) - require.Equal(t, expectedSettlements, matchResult.Settlements) -} diff --git a/x/dex/types/message_cancel_orders.go b/x/dex/types/message_cancel_orders.go deleted file mode 100644 index e211e6b2c8..0000000000 --- a/x/dex/types/message_cancel_orders.go +++ /dev/null @@ -1,72 +0,0 @@ -package types - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" -) - -const TypeMsgCancelOrders = "cancel_orders" - -var _ sdk.Msg = &MsgCancelOrders{} - -func NewMsgCancelOrders( - creator string, - cancellations []*Cancellation, - contractAddr string, -) *MsgCancelOrders { - return &MsgCancelOrders{ - Creator: creator, - Cancellations: cancellations, - ContractAddr: contractAddr, - } -} - -func (msg *MsgCancelOrders) Route() string { - return RouterKey -} - -func (msg *MsgCancelOrders) Type() string { - return TypeMsgCancelOrders -} - -func (msg *MsgCancelOrders) GetSigners() []sdk.AccAddress { - creator, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - panic(err) - } - return []sdk.AccAddress{creator} -} - -func (msg *MsgCancelOrders) GetSignBytes() []byte { - bz := ModuleCdc.MustMarshalJSON(msg) - return sdk.MustSortJSON(bz) -} - -func (msg *MsgCancelOrders) ValidateBasic() error { - _, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) - } - - _, err = sdk.AccAddressFromBech32(msg.ContractAddr) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid contract address (%s)", err) - } - - for _, cancellation := range msg.Cancellations { - if cancellation.Price.IsNil() { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid cancellation price (%s)", err) - } - if cancellation.Price.IsNegative() { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid cancellation price (cannot be negative) (%s)", err) - } - if len(cancellation.AssetDenom) == 0 || sdk.ValidateDenom(cancellation.AssetDenom) != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid cancellation, asset denom is empty or invalid (%s)", err) - } - if len(cancellation.PriceDenom) == 0 || sdk.ValidateDenom(cancellation.PriceDenom) != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid cancellation, price denom is empty or invalid (%s)", err) - } - } - - return nil -} diff --git a/x/dex/types/message_cancel_orders_test.go b/x/dex/types/message_cancel_orders_test.go deleted file mode 100644 index 1dff4ec30c..0000000000 --- a/x/dex/types/message_cancel_orders_test.go +++ /dev/null @@ -1,42 +0,0 @@ -package types_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestValidateMsgCancelOrder(t *testing.T) { - msg := &types.MsgCancelOrders{ - Creator: "sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx", - ContractAddr: "sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc", - Cancellations: []*types.Cancellation{{ - Price: sdk.OneDec().Neg(), - AssetDenom: "denom1", - PriceDenom: "denom2", - }}, - } - require.Error(t, msg.ValidateBasic()) - msg = &types.MsgCancelOrders{ - Creator: "sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx", - ContractAddr: "sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc", - Cancellations: []*types.Cancellation{{ - Price: sdk.OneDec(), - AssetDenom: "invalid denom", - PriceDenom: "denom2", - }}, - } - require.Error(t, msg.ValidateBasic()) - msg = &types.MsgCancelOrders{ - Creator: "sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx", - ContractAddr: "sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc", - Cancellations: []*types.Cancellation{{ - Price: sdk.OneDec(), - AssetDenom: "denom1", - PriceDenom: "invalid denom", - }}, - } - require.Error(t, msg.ValidateBasic()) -} diff --git a/x/dex/types/message_contract_deposit_rent.go b/x/dex/types/message_contract_deposit_rent.go deleted file mode 100644 index 7b94c93bfc..0000000000 --- a/x/dex/types/message_contract_deposit_rent.go +++ /dev/null @@ -1,56 +0,0 @@ -package types - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" -) - -const TypeMsgContractDepositRent = "contract_deposit_rent" - -var _ sdk.Msg = &MsgContractDepositRent{} - -func NewMsgContractDepositRent( - contractAddr string, - amount uint64, - sender string, -) *MsgContractDepositRent { - return &MsgContractDepositRent{ - Sender: sender, - ContractAddr: contractAddr, - Amount: amount, - } -} - -func (msg *MsgContractDepositRent) Route() string { - return RouterKey -} - -func (msg *MsgContractDepositRent) Type() string { - return TypeMsgContractDepositRent -} - -func (msg *MsgContractDepositRent) GetSigners() []sdk.AccAddress { - creator, err := sdk.AccAddressFromBech32(msg.Sender) - if err != nil { - panic(err) - } - return []sdk.AccAddress{creator} -} - -func (msg *MsgContractDepositRent) GetSignBytes() []byte { - bz := ModuleCdc.MustMarshalJSON(msg) - return sdk.MustSortJSON(bz) -} - -func (msg *MsgContractDepositRent) ValidateBasic() error { - _, err := sdk.AccAddressFromBech32(msg.Sender) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) - } - - _, err = sdk.AccAddressFromBech32(msg.ContractAddr) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid contract address (%s)", err) - } - return nil -} diff --git a/x/dex/types/message_place_orders.go b/x/dex/types/message_place_orders.go deleted file mode 100644 index 839dad45a3..0000000000 --- a/x/dex/types/message_place_orders.go +++ /dev/null @@ -1,85 +0,0 @@ -package types - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" -) - -const TypeMsgPlaceOrders = "place_orders" - -var _ sdk.Msg = &MsgPlaceOrders{} - -func NewMsgPlaceOrders( - creator string, - orders []*Order, - contractAddr string, - fund sdk.Coins, -) *MsgPlaceOrders { - return &MsgPlaceOrders{ - Creator: creator, - Orders: orders, - ContractAddr: contractAddr, - Funds: fund, - } -} - -func (msg *MsgPlaceOrders) Route() string { - return RouterKey -} - -func (msg *MsgPlaceOrders) Type() string { - return TypeMsgPlaceOrders -} - -func (msg *MsgPlaceOrders) GetSigners() []sdk.AccAddress { - creator, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - panic(err) - } - return []sdk.AccAddress{creator} -} - -func (msg *MsgPlaceOrders) GetSignBytes() []byte { - bz := ModuleCdc.MustMarshalJSON(msg) - return sdk.MustSortJSON(bz) -} - -// perform statelss check on basic property of msg like sig verification -func (msg *MsgPlaceOrders) ValidateBasic() error { - _, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) - } - - _, err = sdk.AccAddressFromBech32(msg.ContractAddr) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid contract address (%s)", err) - } - - if len(msg.Orders) == 0 { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "at least one order needs to be placed (%s)", err) - } - - for _, order := range msg.Orders { - if order.Quantity.IsNil() || order.Quantity.IsNegative() { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid order quantity (%s)", err) - } - if order.Price.IsNil() || order.Price.IsNegative() { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid order price (%s)", err) - } - if len(order.AssetDenom) == 0 || sdk.ValidateDenom(order.AssetDenom) != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid order, asset denom is empty or invalid (%s)", err) - } - if len(order.PriceDenom) == 0 || sdk.ValidateDenom(order.PriceDenom) != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "invalid order, price denom is empty or invalid (%s)", err) - } - if order.OrderType == OrderType_FOKMARKETBYVALUE || order.OrderType == OrderType_FOKMARKET { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "FOK orders are temporarily disabled") - } - if order.OrderType == OrderType_STOPLIMIT || order.OrderType == OrderType_STOPLOSS { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "stop loss/limit order (%s) are not supported yet", err) - } - } - - return nil -} diff --git a/x/dex/types/message_place_orders_test.go b/x/dex/types/message_place_orders_test.go deleted file mode 100644 index 470de9cd13..0000000000 --- a/x/dex/types/message_place_orders_test.go +++ /dev/null @@ -1,102 +0,0 @@ -package types_test - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - "testing" - - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestValidateMsgPlaceOrder(t *testing.T) { - TEST_CONTRACT := "sei1ghd753shjuwexxywmgs4xz7x2q732vcnkm6h2pyv9s6ah3hylvrqladqwc" - msg := &types.MsgPlaceOrders{ - Creator: "sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx", - ContractAddr: TEST_CONTRACT, - Orders: []*types.Order{ - { - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - Quantity: sdk.OneDec(), - Price: sdk.OneDec(), - AssetDenom: "denom1", - PriceDenom: "denom2", - }, - }, - } - require.NoError(t, msg.ValidateBasic()) - - // Empty orders - msg = &types.MsgPlaceOrders{ - Creator: "sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx", - ContractAddr: TEST_CONTRACT, - Orders: []*types.Order{}, - } - require.Error(t, msg.ValidateBasic()) - - // Test various invalid orders field - msg = &types.MsgPlaceOrders{ - Creator: "sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx", - ContractAddr: TEST_CONTRACT, - Orders: []*types.Order{ - { - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - Quantity: sdk.OneDec().Neg(), - Price: sdk.OneDec(), - AssetDenom: "denom1", - PriceDenom: "denom2", - }, - }, - } - require.Error(t, msg.ValidateBasic()) - msg = &types.MsgPlaceOrders{ - Creator: "sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx", - ContractAddr: TEST_CONTRACT, - Orders: []*types.Order{ - { - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - Quantity: sdk.OneDec(), - AssetDenom: "denom1", - PriceDenom: "denom2", - }, - }, - } - require.Error(t, msg.ValidateBasic()) - msg = &types.MsgPlaceOrders{ - Creator: "sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx", - ContractAddr: TEST_CONTRACT, - Orders: []*types.Order{ - { - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - Quantity: sdk.OneDec(), - Price: sdk.OneDec(), - AssetDenom: "invalid denom", - PriceDenom: "denom2", - }, - }, - } - require.Error(t, msg.ValidateBasic()) - msg = &types.MsgPlaceOrders{ - Creator: "sei1yezq49upxhunjjhudql2fnj5dgvcwjj87pn2wx", - ContractAddr: TEST_CONTRACT, - Orders: []*types.Order{ - { - Id: 1, - Account: "test", - ContractAddr: TEST_CONTRACT, - Quantity: sdk.OneDec().Neg(), - Price: sdk.OneDec(), - AssetDenom: "denom1", - PriceDenom: "invalid denom", - }, - }, - } - require.Error(t, msg.ValidateBasic()) -} diff --git a/x/dex/types/message_register_contract.go b/x/dex/types/message_register_contract.go deleted file mode 100644 index 2ac7240eaa..0000000000 --- a/x/dex/types/message_register_contract.go +++ /dev/null @@ -1,75 +0,0 @@ -package types - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" -) - -const TypeMsgRegisterContract = "register_contract" - -var _ sdk.Msg = &MsgRegisterContract{} - -func NewMsgRegisterContract( - creator string, - codeID uint64, - contractAddr string, - needOrderMatching bool, - dependencies []*ContractDependencyInfo, - deposit uint64, -) *MsgRegisterContract { - return &MsgRegisterContract{ - Creator: creator, - Contract: &ContractInfoV2{ - CodeId: codeID, - ContractAddr: contractAddr, - NeedOrderMatching: needOrderMatching, - Dependencies: dependencies, - Creator: creator, - RentBalance: deposit, - }, - } -} - -func (msg *MsgRegisterContract) Route() string { - return RouterKey -} - -func (msg *MsgRegisterContract) Type() string { - return TypeMsgRegisterContract -} - -func (msg *MsgRegisterContract) GetSigners() []sdk.AccAddress { - creator, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - panic(err) - } - return []sdk.AccAddress{creator} -} - -func (msg *MsgRegisterContract) GetSignBytes() []byte { - bz := ModuleCdc.MustMarshalJSON(msg) - return sdk.MustSortJSON(bz) -} - -func (msg *MsgRegisterContract) ValidateBasic() error { - _, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) - } - - _, err = sdk.AccAddressFromBech32(msg.Contract.ContractAddr) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid contract address (%s)", err) - } - - for _, dependency := range msg.Contract.Dependencies { - contractAddress := dependency.Dependency - - _, err = sdk.AccAddressFromBech32(contractAddress) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid dependency contract address (%s)", err) - } - } - - return nil -} diff --git a/x/dex/types/message_register_pairs.go b/x/dex/types/message_register_pairs.go deleted file mode 100644 index 47fb42af18..0000000000 --- a/x/dex/types/message_register_pairs.go +++ /dev/null @@ -1,83 +0,0 @@ -package types - -import ( - "errors" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" -) - -const TypeMsgRegisterPairs = "register_pairs" - -var _ sdk.Msg = &MsgRegisterPairs{} - -func NewMsgRegisterPairs( - creator string, - contractPairs []BatchContractPair, -) *MsgRegisterPairs { - return &MsgRegisterPairs{ - Creator: creator, - Batchcontractpair: contractPairs, - } -} - -func (msg *MsgRegisterPairs) Route() string { - return RouterKey -} - -func (msg *MsgRegisterPairs) Type() string { - return TypeMsgRegisterPairs -} - -func (msg *MsgRegisterPairs) GetSigners() []sdk.AccAddress { - creator, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - panic(err) - } - return []sdk.AccAddress{creator} -} - -func (msg *MsgRegisterPairs) GetSignBytes() []byte { - bz := ModuleCdc.MustMarshalJSON(msg) - return sdk.MustSortJSON(bz) -} - -func (msg *MsgRegisterPairs) ValidateBasic() error { - if msg.Creator == "" { - return errors.New("creator address is empty") - } - - _, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) - } - - if len(msg.Batchcontractpair) == 0 { - return errors.New("no data provided in register pairs transaction") - } - - for _, batchContractPair := range msg.Batchcontractpair { - contractAddress := batchContractPair.ContractAddr - - if contractAddress == "" { - return errors.New("contract address is empty") - } - - _, err = sdk.AccAddressFromBech32(contractAddress) - if err != nil { - return errors.New("contract address format is not bech32") - } - - if len(batchContractPair.Pairs) == 0 { - return errors.New("no pairs provided in register pairs transaction") - } - - for _, pair := range batchContractPair.Pairs { - if pair == nil { - return errors.New("empty pair info") - } - } - } - - return nil -} diff --git a/x/dex/types/message_unregister_contract.go b/x/dex/types/message_unregister_contract.go deleted file mode 100644 index 667805c667..0000000000 --- a/x/dex/types/message_unregister_contract.go +++ /dev/null @@ -1,55 +0,0 @@ -package types - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" -) - -const TypeMsgUnregisterContract = "unregister_contract" - -var _ sdk.Msg = &MsgUnregisterContract{} - -func NewMsgUnregisterContract( - creator string, - contractAddr string, -) *MsgUnregisterContract { - return &MsgUnregisterContract{ - Creator: creator, - ContractAddr: contractAddr, - } -} - -func (msg *MsgUnregisterContract) Route() string { - return RouterKey -} - -func (msg *MsgUnregisterContract) Type() string { - return TypeMsgUnregisterContract -} - -func (msg *MsgUnregisterContract) GetSigners() []sdk.AccAddress { - creator, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - panic(err) - } - return []sdk.AccAddress{creator} -} - -func (msg *MsgUnregisterContract) GetSignBytes() []byte { - bz := ModuleCdc.MustMarshalJSON(msg) - return sdk.MustSortJSON(bz) -} - -func (msg *MsgUnregisterContract) ValidateBasic() error { - _, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) - } - - _, err = sdk.AccAddressFromBech32(msg.ContractAddr) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid contract address (%s)", err) - } - - return nil -} diff --git a/x/dex/types/message_unsuspend_contract.go b/x/dex/types/message_unsuspend_contract.go deleted file mode 100644 index 75581625e0..0000000000 --- a/x/dex/types/message_unsuspend_contract.go +++ /dev/null @@ -1,55 +0,0 @@ -package types - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" -) - -const TypeMsgUnsuspendContract = "unsuspend_contract" - -var _ sdk.Msg = &MsgUnsuspendContract{} - -func NewMsgUnsuspendContract( - creator string, - contractAddr string, -) *MsgUnsuspendContract { - return &MsgUnsuspendContract{ - Creator: creator, - ContractAddr: contractAddr, - } -} - -func (msg *MsgUnsuspendContract) Route() string { - return RouterKey -} - -func (msg *MsgUnsuspendContract) Type() string { - return TypeMsgUnsuspendContract -} - -func (msg *MsgUnsuspendContract) GetSigners() []sdk.AccAddress { - creator, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - panic(err) - } - return []sdk.AccAddress{creator} -} - -func (msg *MsgUnsuspendContract) GetSignBytes() []byte { - bz := ModuleCdc.MustMarshalJSON(msg) - return sdk.MustSortJSON(bz) -} - -func (msg *MsgUnsuspendContract) ValidateBasic() error { - _, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) - } - - _, err = sdk.AccAddressFromBech32(msg.ContractAddr) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid contract address (%s)", err) - } - - return nil -} diff --git a/x/dex/types/message_update_price_tick_size.go b/x/dex/types/message_update_price_tick_size.go deleted file mode 100644 index 1594bcffbe..0000000000 --- a/x/dex/types/message_update_price_tick_size.go +++ /dev/null @@ -1,69 +0,0 @@ -package types - -import ( - "errors" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" -) - -const TypeMsgUpdatePriceTickSize = "update_price_tick_size" - -var _ sdk.Msg = &MsgUpdatePriceTickSize{} - -func NewMsgUpdatePriceTickSize( - creator string, - tickSizeList []TickSize, -) *MsgUpdatePriceTickSize { - return &MsgUpdatePriceTickSize{ - Creator: creator, - TickSizeList: tickSizeList, - } -} - -func (msg *MsgUpdatePriceTickSize) Route() string { - return RouterKey -} - -func (msg *MsgUpdatePriceTickSize) Type() string { - return TypeMsgUpdatePriceTickSize -} - -func (msg *MsgUpdatePriceTickSize) GetSigners() []sdk.AccAddress { - creator, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - panic(err) - } - return []sdk.AccAddress{creator} -} - -func (msg *MsgUpdatePriceTickSize) GetSignBytes() []byte { - bz := ModuleCdc.MustMarshalJSON(msg) - return sdk.MustSortJSON(bz) -} - -func (msg *MsgUpdatePriceTickSize) ValidateBasic() error { - _, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) - } - - if len(msg.TickSizeList) == 0 { - return errors.New("no data provided in update price tick size transaction") - } - - for _, tickSize := range msg.TickSizeList { - contractAddress := tickSize.ContractAddr - - _, err = sdk.AccAddressFromBech32(contractAddress) - if err != nil { - return errors.New("contract address format is not bech32") - } - - if tickSize.Pair == nil { - return errors.New("empty pair info") - } - } - - return nil -} diff --git a/x/dex/types/message_update_quantity_tick_size.go b/x/dex/types/message_update_quantity_tick_size.go deleted file mode 100644 index 7beafec5dc..0000000000 --- a/x/dex/types/message_update_quantity_tick_size.go +++ /dev/null @@ -1,69 +0,0 @@ -package types - -import ( - "errors" - - sdk "github.com/cosmos/cosmos-sdk/types" - sdkerrors "github.com/cosmos/cosmos-sdk/types/errors" -) - -const TypeMsgUpdateQuantityTickSize = "update_quantity_tick_size" - -var _ sdk.Msg = &MsgUpdateQuantityTickSize{} - -func NewMsgUpdateQuantityTickSize( - creator string, - tickSizeList []TickSize, -) *MsgUpdateQuantityTickSize { - return &MsgUpdateQuantityTickSize{ - Creator: creator, - TickSizeList: tickSizeList, - } -} - -func (msg *MsgUpdateQuantityTickSize) Route() string { - return RouterKey -} - -func (msg *MsgUpdateQuantityTickSize) Type() string { - return TypeMsgUpdateQuantityTickSize -} - -func (msg *MsgUpdateQuantityTickSize) GetSigners() []sdk.AccAddress { - creator, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - panic(err) - } - return []sdk.AccAddress{creator} -} - -func (msg *MsgUpdateQuantityTickSize) GetSignBytes() []byte { - bz := ModuleCdc.MustMarshalJSON(msg) - return sdk.MustSortJSON(bz) -} - -func (msg *MsgUpdateQuantityTickSize) ValidateBasic() error { - _, err := sdk.AccAddressFromBech32(msg.Creator) - if err != nil { - return sdkerrors.Wrapf(sdkerrors.ErrInvalidAddress, "invalid creator address (%s)", err) - } - - if len(msg.TickSizeList) == 0 { - return errors.New("no data provided in update quantity tick size transaction") - } - - for _, tickSize := range msg.TickSizeList { - contractAddress := tickSize.ContractAddr - - _, err = sdk.AccAddressFromBech32(contractAddress) - if err != nil { - return errors.New("contract address format is not bech32") - } - - if tickSize.Pair == nil { - return errors.New("empty pair info") - } - } - - return nil -} diff --git a/x/dex/types/order.pb.go b/x/dex/types/order.pb.go deleted file mode 100644 index 69c89707db..0000000000 --- a/x/dex/types/order.pb.go +++ /dev/null @@ -1,1680 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/order.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type Order struct { - Id uint64 `protobuf:"varint,1,opt,name=id,proto3" json:"id"` - Status OrderStatus `protobuf:"varint,2,opt,name=status,proto3,enum=seiprotocol.seichain.dex.OrderStatus" json:"status"` - Account string `protobuf:"bytes,3,opt,name=account,proto3" json:"account"` - ContractAddr string `protobuf:"bytes,4,opt,name=contractAddr,proto3" json:"contract_address"` - Price github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,5,opt,name=price,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"price" yaml:"price"` - Quantity github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,6,opt,name=quantity,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"quantity" yaml:"quantity"` - PriceDenom string `protobuf:"bytes,7,opt,name=priceDenom,proto3" json:"price_denom"` - AssetDenom string `protobuf:"bytes,8,opt,name=assetDenom,proto3" json:"asset_denom"` - OrderType OrderType `protobuf:"varint,9,opt,name=orderType,proto3,enum=seiprotocol.seichain.dex.OrderType" json:"order_type"` - PositionDirection PositionDirection `protobuf:"varint,10,opt,name=positionDirection,proto3,enum=seiprotocol.seichain.dex.PositionDirection" json:"position_direction"` - Data string `protobuf:"bytes,11,opt,name=data,proto3" json:"data"` - StatusDescription string `protobuf:"bytes,12,opt,name=statusDescription,proto3" json:"status_description"` - Nominal github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,13,opt,name=nominal,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"nominal" yaml:"nominal"` - TriggerPrice github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,14,opt,name=triggerPrice,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"trigger_price" yaml:"trigger_price"` - TriggerStatus bool `protobuf:"varint,15,opt,name=triggerStatus,proto3" json:"trigger_status"` -} - -func (m *Order) Reset() { *m = Order{} } -func (m *Order) String() string { return proto.CompactTextString(m) } -func (*Order) ProtoMessage() {} -func (*Order) Descriptor() ([]byte, []int) { - return fileDescriptor_c2d5fab85368797d, []int{0} -} -func (m *Order) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *Order) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_Order.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *Order) XXX_Merge(src proto.Message) { - xxx_messageInfo_Order.Merge(m, src) -} -func (m *Order) XXX_Size() int { - return m.Size() -} -func (m *Order) XXX_DiscardUnknown() { - xxx_messageInfo_Order.DiscardUnknown(m) -} - -var xxx_messageInfo_Order proto.InternalMessageInfo - -func (m *Order) GetId() uint64 { - if m != nil { - return m.Id - } - return 0 -} - -func (m *Order) GetStatus() OrderStatus { - if m != nil { - return m.Status - } - return OrderStatus_PLACED -} - -func (m *Order) GetAccount() string { - if m != nil { - return m.Account - } - return "" -} - -func (m *Order) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *Order) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *Order) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -func (m *Order) GetOrderType() OrderType { - if m != nil { - return m.OrderType - } - return OrderType_LIMIT -} - -func (m *Order) GetPositionDirection() PositionDirection { - if m != nil { - return m.PositionDirection - } - return PositionDirection_LONG -} - -func (m *Order) GetData() string { - if m != nil { - return m.Data - } - return "" -} - -func (m *Order) GetStatusDescription() string { - if m != nil { - return m.StatusDescription - } - return "" -} - -func (m *Order) GetTriggerStatus() bool { - if m != nil { - return m.TriggerStatus - } - return false -} - -type Cancellation struct { - Id uint64 `protobuf:"varint,1,opt,name=id,proto3" json:"id"` - Initiator CancellationInitiator `protobuf:"varint,2,opt,name=initiator,proto3,enum=seiprotocol.seichain.dex.CancellationInitiator" json:"initiator"` - Creator string `protobuf:"bytes,3,opt,name=creator,proto3" json:"creator"` - ContractAddr string `protobuf:"bytes,4,opt,name=contractAddr,proto3" json:"contract_address"` - PriceDenom string `protobuf:"bytes,5,opt,name=priceDenom,proto3" json:"price_denom"` - AssetDenom string `protobuf:"bytes,6,opt,name=assetDenom,proto3" json:"asset_denom"` - PositionDirection PositionDirection `protobuf:"varint,7,opt,name=positionDirection,proto3,enum=seiprotocol.seichain.dex.PositionDirection" json:"position_direction"` - Price github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,8,opt,name=price,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"price" yaml:"price"` -} - -func (m *Cancellation) Reset() { *m = Cancellation{} } -func (m *Cancellation) String() string { return proto.CompactTextString(m) } -func (*Cancellation) ProtoMessage() {} -func (*Cancellation) Descriptor() ([]byte, []int) { - return fileDescriptor_c2d5fab85368797d, []int{1} -} -func (m *Cancellation) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *Cancellation) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_Cancellation.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *Cancellation) XXX_Merge(src proto.Message) { - xxx_messageInfo_Cancellation.Merge(m, src) -} -func (m *Cancellation) XXX_Size() int { - return m.Size() -} -func (m *Cancellation) XXX_DiscardUnknown() { - xxx_messageInfo_Cancellation.DiscardUnknown(m) -} - -var xxx_messageInfo_Cancellation proto.InternalMessageInfo - -func (m *Cancellation) GetId() uint64 { - if m != nil { - return m.Id - } - return 0 -} - -func (m *Cancellation) GetInitiator() CancellationInitiator { - if m != nil { - return m.Initiator - } - return CancellationInitiator_USER -} - -func (m *Cancellation) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *Cancellation) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *Cancellation) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *Cancellation) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -func (m *Cancellation) GetPositionDirection() PositionDirection { - if m != nil { - return m.PositionDirection - } - return PositionDirection_LONG -} - -type ActiveOrders struct { - Ids []uint64 `protobuf:"varint,1,rep,packed,name=ids,proto3" json:"ids"` -} - -func (m *ActiveOrders) Reset() { *m = ActiveOrders{} } -func (m *ActiveOrders) String() string { return proto.CompactTextString(m) } -func (*ActiveOrders) ProtoMessage() {} -func (*ActiveOrders) Descriptor() ([]byte, []int) { - return fileDescriptor_c2d5fab85368797d, []int{2} -} -func (m *ActiveOrders) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *ActiveOrders) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_ActiveOrders.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *ActiveOrders) XXX_Merge(src proto.Message) { - xxx_messageInfo_ActiveOrders.Merge(m, src) -} -func (m *ActiveOrders) XXX_Size() int { - return m.Size() -} -func (m *ActiveOrders) XXX_DiscardUnknown() { - xxx_messageInfo_ActiveOrders.DiscardUnknown(m) -} - -var xxx_messageInfo_ActiveOrders proto.InternalMessageInfo - -func (m *ActiveOrders) GetIds() []uint64 { - if m != nil { - return m.Ids - } - return nil -} - -func init() { - proto.RegisterType((*Order)(nil), "seiprotocol.seichain.dex.Order") - proto.RegisterType((*Cancellation)(nil), "seiprotocol.seichain.dex.Cancellation") - proto.RegisterType((*ActiveOrders)(nil), "seiprotocol.seichain.dex.ActiveOrders") -} - -func init() { proto.RegisterFile("dex/order.proto", fileDescriptor_c2d5fab85368797d) } - -var fileDescriptor_c2d5fab85368797d = []byte{ - // 737 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x55, 0xcd, 0x6a, 0xdb, 0x4c, - 0x14, 0xb5, 0x1c, 0xff, 0x4e, 0x1c, 0xfb, 0xcb, 0x10, 0x82, 0xbe, 0x50, 0x2c, 0xa3, 0xd2, 0xe2, - 0x50, 0x62, 0x41, 0xbb, 0x09, 0xa5, 0x9b, 0xa8, 0x86, 0x50, 0x4a, 0x68, 0x3a, 0x2d, 0x14, 0x4a, - 0x8b, 0x51, 0x34, 0x83, 0x33, 0xd4, 0xd6, 0x38, 0x9a, 0x71, 0x89, 0xe9, 0x4b, 0xf4, 0x05, 0xfa, - 0x3e, 0xd9, 0x35, 0xcb, 0xd2, 0x85, 0x28, 0xc9, 0x4e, 0xcb, 0x3c, 0x41, 0xd1, 0x95, 0x26, 0xb6, - 0xf3, 0x43, 0xea, 0x45, 0x36, 0xd6, 0x9d, 0x73, 0xcf, 0x39, 0x57, 0x9a, 0x99, 0x7b, 0x8d, 0x1a, - 0x94, 0x1d, 0x3b, 0x22, 0xa4, 0x2c, 0xec, 0x8c, 0x42, 0xa1, 0x04, 0x36, 0x25, 0xe3, 0x10, 0xf9, - 0x62, 0xd0, 0x91, 0x8c, 0xfb, 0x87, 0x1e, 0x0f, 0x3a, 0x94, 0x1d, 0x6f, 0xac, 0xf5, 0x45, 0x5f, - 0x40, 0xca, 0x49, 0xa2, 0x94, 0xbf, 0x01, 0x06, 0x2c, 0x18, 0x0f, 0x65, 0x0a, 0xd8, 0x3f, 0x2b, - 0xa8, 0xf8, 0x26, 0x31, 0xc4, 0x1b, 0x28, 0xcf, 0xa9, 0x69, 0xb4, 0x8c, 0x76, 0xc1, 0x45, 0x27, - 0x91, 0x65, 0xc4, 0x91, 0x95, 0xe7, 0x94, 0xe4, 0x39, 0xc5, 0x7b, 0xa8, 0x24, 0x95, 0xa7, 0xc6, - 0xd2, 0xcc, 0xb7, 0x8c, 0x76, 0xfd, 0xe9, 0xa3, 0xce, 0x6d, 0x75, 0x3b, 0x60, 0xf6, 0x0e, 0xc8, - 0x6e, 0x3d, 0xb3, 0xc9, 0xc4, 0x24, 0x7b, 0xe2, 0x4d, 0x54, 0xf6, 0x7c, 0x5f, 0x8c, 0x03, 0x65, - 0x2e, 0xb5, 0x8c, 0x76, 0xd5, 0x6d, 0x64, 0x44, 0x0d, 0x13, 0x1d, 0xe0, 0x17, 0xa8, 0xe6, 0x8b, - 0x40, 0x85, 0x9e, 0xaf, 0x76, 0x28, 0x0d, 0xcd, 0x02, 0xf0, 0xcd, 0x8c, 0xff, 0x9f, 0xce, 0xf5, - 0x3c, 0x4a, 0x43, 0x26, 0x25, 0x99, 0x63, 0xe3, 0xcf, 0xa8, 0x38, 0x0a, 0xb9, 0xcf, 0xcc, 0x22, - 0xc8, 0x76, 0x4f, 0x22, 0x2b, 0xf7, 0x3b, 0xb2, 0x1e, 0xf7, 0xb9, 0x3a, 0x1c, 0x1f, 0x74, 0x7c, - 0x31, 0x74, 0x7c, 0x21, 0x87, 0x42, 0x66, 0x8f, 0x2d, 0x49, 0xbf, 0x38, 0x6a, 0x32, 0x62, 0xb2, - 0xd3, 0x65, 0x7e, 0x1c, 0x59, 0xa9, 0xfc, 0x22, 0xb2, 0x6a, 0x13, 0x6f, 0x38, 0x78, 0x6e, 0xc3, - 0xd2, 0x26, 0x29, 0x8c, 0x39, 0xaa, 0x1c, 0x8d, 0xbd, 0x40, 0x71, 0x35, 0x31, 0x4b, 0x50, 0x61, - 0x6f, 0xe1, 0x0a, 0x97, 0x0e, 0x17, 0x91, 0xd5, 0x48, 0x8b, 0x68, 0xc4, 0x26, 0x97, 0x49, 0xec, - 0x20, 0x04, 0x35, 0xbb, 0x2c, 0x10, 0x43, 0xb3, 0x9c, 0xee, 0x5a, 0x1c, 0x59, 0xcb, 0x80, 0xf6, - 0x68, 0x02, 0x93, 0x19, 0x4a, 0x22, 0xf0, 0xa4, 0x64, 0x2a, 0x15, 0x54, 0xa6, 0x02, 0x40, 0xb5, - 0x60, 0x4a, 0xc1, 0x6f, 0x51, 0x15, 0x6e, 0xd6, 0xfb, 0xc9, 0x88, 0x99, 0x55, 0x38, 0xe6, 0x87, - 0x77, 0x1c, 0x73, 0x42, 0x75, 0xeb, 0x71, 0x64, 0x21, 0x50, 0xf6, 0x92, 0xef, 0x22, 0x53, 0x17, - 0x7c, 0x84, 0x56, 0x47, 0x42, 0x72, 0xc5, 0x45, 0xd0, 0xe5, 0x21, 0xf3, 0x93, 0xc0, 0x44, 0x60, - 0xfd, 0xe4, 0x76, 0xeb, 0xfd, 0xab, 0x12, 0x77, 0x3d, 0x8e, 0x2c, 0xac, 0x9d, 0x7a, 0x54, 0xe3, - 0xe4, 0xba, 0x3b, 0x7e, 0x80, 0x0a, 0xd4, 0x53, 0x9e, 0xb9, 0x0c, 0x1f, 0x5c, 0x89, 0x23, 0x0b, - 0xd6, 0x04, 0x7e, 0x71, 0x17, 0xad, 0xa6, 0x57, 0xb0, 0xcb, 0xa4, 0x1f, 0xf2, 0x11, 0xbc, 0x50, - 0x0d, 0xa8, 0x50, 0x23, 0x4d, 0xf6, 0xe8, 0x34, 0x4b, 0xae, 0x0b, 0x30, 0x43, 0xe5, 0x40, 0x0c, - 0x79, 0xe0, 0x0d, 0xcc, 0x15, 0xd0, 0xbe, 0x5e, 0xf8, 0xd4, 0xb5, 0xc1, 0x45, 0x64, 0xd5, 0xd3, - 0x43, 0xcf, 0x00, 0x9b, 0xe8, 0x14, 0xfe, 0x86, 0x6a, 0x2a, 0xe4, 0xfd, 0x3e, 0x0b, 0xf7, 0xe1, - 0x0e, 0xd7, 0xa1, 0xd6, 0x87, 0x85, 0x6b, 0xad, 0x64, 0x2e, 0x3d, 0x7d, 0x97, 0xd7, 0xd2, 0x8a, - 0x73, 0xb0, 0x4d, 0xe6, 0x8a, 0xe1, 0x6d, 0xa4, 0x65, 0x69, 0x2f, 0x9b, 0x8d, 0x96, 0xd1, 0xae, - 0xb8, 0x38, 0x8e, 0xac, 0xba, 0x16, 0x66, 0x5d, 0x3d, 0x4f, 0xb4, 0x7f, 0x14, 0x50, 0xed, 0xa5, - 0x17, 0xf8, 0x6c, 0x30, 0xf0, 0x60, 0xbb, 0xd6, 0x67, 0x06, 0x4b, 0x69, 0x66, 0xa8, 0x7c, 0x42, - 0x55, 0x1e, 0x70, 0xc5, 0x3d, 0x25, 0xc2, 0x6c, 0xae, 0x38, 0xb7, 0xdf, 0x8a, 0x59, 0xcb, 0x57, - 0x5a, 0xe6, 0xae, 0xc4, 0x91, 0x35, 0x75, 0x21, 0xd3, 0x30, 0x99, 0x31, 0x7e, 0xc8, 0xc0, 0xfb, - 0xca, 0x8c, 0xc9, 0x60, 0xa2, 0x03, 0xbc, 0x7d, 0xe3, 0x8c, 0x59, 0xfb, 0x87, 0xf9, 0x32, 0xdf, - 0x95, 0xc5, 0x45, 0xbb, 0xb2, 0x74, 0x77, 0x57, 0xde, 0xd8, 0x42, 0xe5, 0x7b, 0x6d, 0xa1, 0xcb, - 0xa1, 0x59, 0xb9, 0x8f, 0xa1, 0x69, 0x6f, 0xa2, 0xda, 0x8e, 0xaf, 0xf8, 0x57, 0x06, 0x23, 0x44, - 0xe2, 0xff, 0xd1, 0x12, 0xa7, 0xd2, 0x34, 0x5a, 0x4b, 0xed, 0x82, 0x5b, 0x8e, 0x23, 0x2b, 0x59, - 0x92, 0xe4, 0xc7, 0xdd, 0x3d, 0x39, 0x6b, 0x1a, 0xa7, 0x67, 0x4d, 0xe3, 0xcf, 0x59, 0xd3, 0xf8, - 0x7e, 0xde, 0xcc, 0x9d, 0x9e, 0x37, 0x73, 0xbf, 0xce, 0x9b, 0xb9, 0x8f, 0x5b, 0x33, 0x2f, 0x23, - 0x19, 0xdf, 0xd2, 0xdb, 0x00, 0x0b, 0xd8, 0x07, 0xe7, 0xd8, 0x49, 0xfe, 0xeb, 0xe0, 0xbd, 0x0e, - 0x4a, 0x90, 0x7f, 0xf6, 0x37, 0x00, 0x00, 0xff, 0xff, 0xa3, 0x4e, 0x8b, 0xbe, 0x40, 0x07, 0x00, - 0x00, -} - -func (m *Order) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *Order) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *Order) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.TriggerStatus { - i-- - if m.TriggerStatus { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x78 - } - { - size := m.TriggerPrice.Size() - i -= size - if _, err := m.TriggerPrice.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintOrder(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x72 - { - size := m.Nominal.Size() - i -= size - if _, err := m.Nominal.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintOrder(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x6a - if len(m.StatusDescription) > 0 { - i -= len(m.StatusDescription) - copy(dAtA[i:], m.StatusDescription) - i = encodeVarintOrder(dAtA, i, uint64(len(m.StatusDescription))) - i-- - dAtA[i] = 0x62 - } - if len(m.Data) > 0 { - i -= len(m.Data) - copy(dAtA[i:], m.Data) - i = encodeVarintOrder(dAtA, i, uint64(len(m.Data))) - i-- - dAtA[i] = 0x5a - } - if m.PositionDirection != 0 { - i = encodeVarintOrder(dAtA, i, uint64(m.PositionDirection)) - i-- - dAtA[i] = 0x50 - } - if m.OrderType != 0 { - i = encodeVarintOrder(dAtA, i, uint64(m.OrderType)) - i-- - dAtA[i] = 0x48 - } - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintOrder(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x42 - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintOrder(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x3a - } - { - size := m.Quantity.Size() - i -= size - if _, err := m.Quantity.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintOrder(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x32 - { - size := m.Price.Size() - i -= size - if _, err := m.Price.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintOrder(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x2a - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintOrder(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x22 - } - if len(m.Account) > 0 { - i -= len(m.Account) - copy(dAtA[i:], m.Account) - i = encodeVarintOrder(dAtA, i, uint64(len(m.Account))) - i-- - dAtA[i] = 0x1a - } - if m.Status != 0 { - i = encodeVarintOrder(dAtA, i, uint64(m.Status)) - i-- - dAtA[i] = 0x10 - } - if m.Id != 0 { - i = encodeVarintOrder(dAtA, i, uint64(m.Id)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func (m *Cancellation) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *Cancellation) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *Cancellation) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - { - size := m.Price.Size() - i -= size - if _, err := m.Price.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintOrder(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x42 - if m.PositionDirection != 0 { - i = encodeVarintOrder(dAtA, i, uint64(m.PositionDirection)) - i-- - dAtA[i] = 0x38 - } - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintOrder(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x32 - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintOrder(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x2a - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintOrder(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x22 - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintOrder(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0x1a - } - if m.Initiator != 0 { - i = encodeVarintOrder(dAtA, i, uint64(m.Initiator)) - i-- - dAtA[i] = 0x10 - } - if m.Id != 0 { - i = encodeVarintOrder(dAtA, i, uint64(m.Id)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func (m *ActiveOrders) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *ActiveOrders) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *ActiveOrders) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Ids) > 0 { - dAtA2 := make([]byte, len(m.Ids)*10) - var j1 int - for _, num := range m.Ids { - for num >= 1<<7 { - dAtA2[j1] = uint8(uint64(num)&0x7f | 0x80) - num >>= 7 - j1++ - } - dAtA2[j1] = uint8(num) - j1++ - } - i -= j1 - copy(dAtA[i:], dAtA2[:j1]) - i = encodeVarintOrder(dAtA, i, uint64(j1)) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func encodeVarintOrder(dAtA []byte, offset int, v uint64) int { - offset -= sovOrder(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *Order) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Id != 0 { - n += 1 + sovOrder(uint64(m.Id)) - } - if m.Status != 0 { - n += 1 + sovOrder(uint64(m.Status)) - } - l = len(m.Account) - if l > 0 { - n += 1 + l + sovOrder(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovOrder(uint64(l)) - } - l = m.Price.Size() - n += 1 + l + sovOrder(uint64(l)) - l = m.Quantity.Size() - n += 1 + l + sovOrder(uint64(l)) - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovOrder(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovOrder(uint64(l)) - } - if m.OrderType != 0 { - n += 1 + sovOrder(uint64(m.OrderType)) - } - if m.PositionDirection != 0 { - n += 1 + sovOrder(uint64(m.PositionDirection)) - } - l = len(m.Data) - if l > 0 { - n += 1 + l + sovOrder(uint64(l)) - } - l = len(m.StatusDescription) - if l > 0 { - n += 1 + l + sovOrder(uint64(l)) - } - l = m.Nominal.Size() - n += 1 + l + sovOrder(uint64(l)) - l = m.TriggerPrice.Size() - n += 1 + l + sovOrder(uint64(l)) - if m.TriggerStatus { - n += 2 - } - return n -} - -func (m *Cancellation) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Id != 0 { - n += 1 + sovOrder(uint64(m.Id)) - } - if m.Initiator != 0 { - n += 1 + sovOrder(uint64(m.Initiator)) - } - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovOrder(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovOrder(uint64(l)) - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovOrder(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovOrder(uint64(l)) - } - if m.PositionDirection != 0 { - n += 1 + sovOrder(uint64(m.PositionDirection)) - } - l = m.Price.Size() - n += 1 + l + sovOrder(uint64(l)) - return n -} - -func (m *ActiveOrders) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.Ids) > 0 { - l = 0 - for _, e := range m.Ids { - l += sovOrder(uint64(e)) - } - n += 1 + sovOrder(uint64(l)) + l - } - return n -} - -func sovOrder(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozOrder(x uint64) (n int) { - return sovOrder(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *Order) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: Order: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: Order: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Id", wireType) - } - m.Id = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Id |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType) - } - m.Status = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Status |= OrderStatus(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Account", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Account = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Price.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 6: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Quantity", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Quantity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 7: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 8: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 9: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field OrderType", wireType) - } - m.OrderType = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.OrderType |= OrderType(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 10: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field PositionDirection", wireType) - } - m.PositionDirection = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.PositionDirection |= PositionDirection(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 11: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Data", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Data = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 12: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field StatusDescription", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.StatusDescription = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 13: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Nominal", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Nominal.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 14: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field TriggerPrice", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.TriggerPrice.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 15: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field TriggerStatus", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.TriggerStatus = bool(v != 0) - default: - iNdEx = preIndex - skippy, err := skipOrder(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthOrder - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *Cancellation) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: Cancellation: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: Cancellation: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Id", wireType) - } - m.Id = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Id |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Initiator", wireType) - } - m.Initiator = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Initiator |= CancellationInitiator(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 6: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 7: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field PositionDirection", wireType) - } - m.PositionDirection = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.PositionDirection |= PositionDirection(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 8: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - 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 ErrInvalidLengthOrder - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Price.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipOrder(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthOrder - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *ActiveOrders) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: ActiveOrders: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: ActiveOrders: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType == 0 { - var v uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.Ids = append(m.Ids, v) - } else if wireType == 2 { - var packedLen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - packedLen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if packedLen < 0 { - return ErrInvalidLengthOrder - } - postIndex := iNdEx + packedLen - if postIndex < 0 { - return ErrInvalidLengthOrder - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var elementCount int - var count int - for _, integer := range dAtA[iNdEx:postIndex] { - if integer < 128 { - count++ - } - } - elementCount = count - if elementCount != 0 && len(m.Ids) == 0 { - m.Ids = make([]uint64, 0, elementCount) - } - for iNdEx < postIndex { - var v uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrder - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.Ids = append(m.Ids, v) - } - } else { - return fmt.Errorf("proto: wrong wireType = %d for field Ids", wireType) - } - default: - iNdEx = preIndex - skippy, err := skipOrder(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthOrder - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipOrder(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowOrder - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowOrder - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowOrder - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthOrder - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupOrder - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthOrder - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthOrder = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowOrder = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupOrder = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/order_cancellation.go b/x/dex/types/order_cancellation.go deleted file mode 100644 index 7067b98f67..0000000000 --- a/x/dex/types/order_cancellation.go +++ /dev/null @@ -1,9 +0,0 @@ -package types - -type SudoOrderCancellationMsg struct { - OrderCancellations OrderCancellationMsgDetails `json:"bulk_order_cancellations"` -} - -type OrderCancellationMsgDetails struct { - IdsToCancel []uint64 `json:"ids"` -} diff --git a/x/dex/types/order_entry.pb.go b/x/dex/types/order_entry.pb.go deleted file mode 100644 index dafbc63fca..0000000000 --- a/x/dex/types/order_entry.pb.go +++ /dev/null @@ -1,790 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/order_entry.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type OrderEntry struct { - Price github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,1,opt,name=price,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"price" yaml:"price"` - Quantity github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,2,opt,name=quantity,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"quantity" yaml:"quantity"` - Allocations []*Allocation `protobuf:"bytes,3,rep,name=allocations,proto3" json:"allocations"` - PriceDenom string `protobuf:"bytes,4,opt,name=priceDenom,proto3" json:"price_denom"` - AssetDenom string `protobuf:"bytes,5,opt,name=assetDenom,proto3" json:"asset_denom"` -} - -func (m *OrderEntry) Reset() { *m = OrderEntry{} } -func (m *OrderEntry) String() string { return proto.CompactTextString(m) } -func (*OrderEntry) ProtoMessage() {} -func (*OrderEntry) Descriptor() ([]byte, []int) { - return fileDescriptor_25878922effe12c2, []int{0} -} -func (m *OrderEntry) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *OrderEntry) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_OrderEntry.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *OrderEntry) XXX_Merge(src proto.Message) { - xxx_messageInfo_OrderEntry.Merge(m, src) -} -func (m *OrderEntry) XXX_Size() int { - return m.Size() -} -func (m *OrderEntry) XXX_DiscardUnknown() { - xxx_messageInfo_OrderEntry.DiscardUnknown(m) -} - -var xxx_messageInfo_OrderEntry proto.InternalMessageInfo - -func (m *OrderEntry) GetAllocations() []*Allocation { - if m != nil { - return m.Allocations - } - return nil -} - -func (m *OrderEntry) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *OrderEntry) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -type Allocation struct { - OrderId uint64 `protobuf:"varint,1,opt,name=orderId,proto3" json:"order_id"` - Quantity github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,2,opt,name=quantity,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"quantity" yaml:"quantity"` - Account string `protobuf:"bytes,3,opt,name=account,proto3" json:"account"` -} - -func (m *Allocation) Reset() { *m = Allocation{} } -func (m *Allocation) String() string { return proto.CompactTextString(m) } -func (*Allocation) ProtoMessage() {} -func (*Allocation) Descriptor() ([]byte, []int) { - return fileDescriptor_25878922effe12c2, []int{1} -} -func (m *Allocation) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *Allocation) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_Allocation.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *Allocation) XXX_Merge(src proto.Message) { - xxx_messageInfo_Allocation.Merge(m, src) -} -func (m *Allocation) XXX_Size() int { - return m.Size() -} -func (m *Allocation) XXX_DiscardUnknown() { - xxx_messageInfo_Allocation.DiscardUnknown(m) -} - -var xxx_messageInfo_Allocation proto.InternalMessageInfo - -func (m *Allocation) GetOrderId() uint64 { - if m != nil { - return m.OrderId - } - return 0 -} - -func (m *Allocation) GetAccount() string { - if m != nil { - return m.Account - } - return "" -} - -func init() { - proto.RegisterType((*OrderEntry)(nil), "seiprotocol.seichain.dex.OrderEntry") - proto.RegisterType((*Allocation)(nil), "seiprotocol.seichain.dex.Allocation") -} - -func init() { proto.RegisterFile("dex/order_entry.proto", fileDescriptor_25878922effe12c2) } - -var fileDescriptor_25878922effe12c2 = []byte{ - // 395 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x52, 0xb1, 0x6a, 0xe3, 0x40, - 0x10, 0x95, 0x4e, 0xf6, 0xf9, 0x6e, 0x6d, 0x30, 0x88, 0x3b, 0x10, 0x29, 0x24, 0x23, 0x12, 0xe3, - 0xc6, 0x12, 0x24, 0x5d, 0xba, 0x08, 0x07, 0x93, 0x22, 0x04, 0xd4, 0x04, 0x02, 0xc1, 0xc8, 0xab, - 0xc5, 0x5e, 0x22, 0x69, 0x1d, 0xed, 0x1a, 0xac, 0xbf, 0x48, 0x7e, 0x2a, 0xb8, 0x74, 0x19, 0x52, - 0x88, 0x60, 0x77, 0x2e, 0xfd, 0x05, 0x61, 0x47, 0x91, 0xad, 0x26, 0x45, 0x9a, 0x54, 0x9a, 0x79, - 0x33, 0x6f, 0xde, 0xec, 0x3c, 0xa1, 0xff, 0x21, 0x59, 0xb8, 0x2c, 0x0d, 0x49, 0x3a, 0x22, 0x89, - 0x48, 0x33, 0x67, 0x96, 0x32, 0xc1, 0x74, 0x83, 0x13, 0x0a, 0x11, 0x66, 0x91, 0xc3, 0x09, 0xc5, - 0xd3, 0x80, 0x26, 0x4e, 0x48, 0x16, 0x47, 0xff, 0x26, 0x6c, 0xc2, 0xa0, 0xe4, 0xca, 0xa8, 0xe8, - 0xb7, 0x9f, 0x35, 0x84, 0x6e, 0xe4, 0x94, 0x4b, 0x39, 0x44, 0xbf, 0x47, 0xf5, 0x59, 0x4a, 0x31, - 0x31, 0xd4, 0x8e, 0xda, 0xfb, 0xeb, 0x0d, 0x97, 0xb9, 0xa5, 0xbc, 0xe5, 0x56, 0x77, 0x42, 0xc5, - 0x74, 0x3e, 0x76, 0x30, 0x8b, 0x5d, 0xcc, 0x78, 0xcc, 0xf8, 0xe7, 0xa7, 0xcf, 0xc3, 0x07, 0x57, - 0x64, 0x33, 0xc2, 0x9d, 0x01, 0xc1, 0xdb, 0xdc, 0x2a, 0xe8, 0xbb, 0xdc, 0x6a, 0x65, 0x41, 0x1c, - 0x9d, 0xdb, 0x90, 0xda, 0x7e, 0x01, 0xeb, 0x14, 0xfd, 0x79, 0x9c, 0x07, 0x89, 0xa0, 0x22, 0x33, - 0x7e, 0x81, 0xc2, 0xf5, 0xb7, 0x15, 0xf6, 0x13, 0x76, 0xb9, 0xd5, 0x2e, 0x44, 0x4a, 0xc4, 0xf6, - 0xf7, 0x45, 0xfd, 0x16, 0x35, 0x83, 0x28, 0x62, 0x38, 0x10, 0x94, 0x25, 0xdc, 0xd0, 0x3a, 0x5a, - 0xaf, 0x79, 0x7a, 0xec, 0x7c, 0x75, 0x1e, 0xe7, 0x62, 0xdf, 0xec, 0xb5, 0xb7, 0xb9, 0x55, 0x25, - 0xfb, 0xd5, 0x44, 0x77, 0x11, 0x82, 0xc7, 0x0c, 0x48, 0xc2, 0x62, 0xa3, 0x06, 0xaf, 0x00, 0x06, - 0xa0, 0xa3, 0x50, 0xc2, 0x7e, 0xa5, 0x45, 0x12, 0x02, 0xce, 0x89, 0x28, 0x08, 0xf5, 0x03, 0x01, - 0xd0, 0x92, 0x70, 0x68, 0xb1, 0x5f, 0x54, 0x84, 0x0e, 0xeb, 0xe8, 0x5d, 0xd4, 0x00, 0x9f, 0xaf, - 0x42, 0x70, 0xa5, 0xe6, 0xb5, 0xe4, 0x15, 0x0a, 0xeb, 0x69, 0xe8, 0x97, 0xc5, 0x9f, 0x3c, 0xee, - 0x09, 0x6a, 0x04, 0x18, 0xb3, 0x79, 0x22, 0x0c, 0x0d, 0x94, 0x9a, 0xdb, 0xdc, 0x2a, 0x21, 0xbf, - 0x0c, 0xbc, 0xe1, 0x72, 0x6d, 0xaa, 0xab, 0xb5, 0xa9, 0xbe, 0xaf, 0x4d, 0xf5, 0x69, 0x63, 0x2a, - 0xab, 0x8d, 0xa9, 0xbc, 0x6e, 0x4c, 0xe5, 0xae, 0x5f, 0xd9, 0x88, 0x13, 0xda, 0x2f, 0x3d, 0x81, - 0x04, 0x4c, 0x71, 0x17, 0xae, 0xfc, 0xc3, 0x61, 0xb9, 0xf1, 0x6f, 0xa8, 0x9f, 0x7d, 0x04, 0x00, - 0x00, 0xff, 0xff, 0x59, 0x65, 0xd6, 0x5e, 0xf5, 0x02, 0x00, 0x00, -} - -func (m *OrderEntry) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *OrderEntry) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *OrderEntry) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintOrderEntry(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x2a - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintOrderEntry(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x22 - } - if len(m.Allocations) > 0 { - for iNdEx := len(m.Allocations) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Allocations[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintOrderEntry(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - } - } - { - size := m.Quantity.Size() - i -= size - if _, err := m.Quantity.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintOrderEntry(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - { - size := m.Price.Size() - i -= size - if _, err := m.Price.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintOrderEntry(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - return len(dAtA) - i, nil -} - -func (m *Allocation) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *Allocation) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *Allocation) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Account) > 0 { - i -= len(m.Account) - copy(dAtA[i:], m.Account) - i = encodeVarintOrderEntry(dAtA, i, uint64(len(m.Account))) - i-- - dAtA[i] = 0x1a - } - { - size := m.Quantity.Size() - i -= size - if _, err := m.Quantity.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintOrderEntry(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - if m.OrderId != 0 { - i = encodeVarintOrderEntry(dAtA, i, uint64(m.OrderId)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func encodeVarintOrderEntry(dAtA []byte, offset int, v uint64) int { - offset -= sovOrderEntry(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *OrderEntry) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = m.Price.Size() - n += 1 + l + sovOrderEntry(uint64(l)) - l = m.Quantity.Size() - n += 1 + l + sovOrderEntry(uint64(l)) - if len(m.Allocations) > 0 { - for _, e := range m.Allocations { - l = e.Size() - n += 1 + l + sovOrderEntry(uint64(l)) - } - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovOrderEntry(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovOrderEntry(uint64(l)) - } - return n -} - -func (m *Allocation) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.OrderId != 0 { - n += 1 + sovOrderEntry(uint64(m.OrderId)) - } - l = m.Quantity.Size() - n += 1 + l + sovOrderEntry(uint64(l)) - l = len(m.Account) - if l > 0 { - n += 1 + l + sovOrderEntry(uint64(l)) - } - return n -} - -func sovOrderEntry(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozOrderEntry(x uint64) (n int) { - return sovOrderEntry(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *OrderEntry) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrderEntry - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: OrderEntry: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: OrderEntry: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrderEntry - } - 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 ErrInvalidLengthOrderEntry - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrderEntry - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Price.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Quantity", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrderEntry - } - 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 ErrInvalidLengthOrderEntry - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrderEntry - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Quantity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Allocations", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrderEntry - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthOrderEntry - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthOrderEntry - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Allocations = append(m.Allocations, &Allocation{}) - if err := m.Allocations[len(m.Allocations)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrderEntry - } - 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 ErrInvalidLengthOrderEntry - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrderEntry - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrderEntry - } - 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 ErrInvalidLengthOrderEntry - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrderEntry - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipOrderEntry(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthOrderEntry - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *Allocation) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrderEntry - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: Allocation: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: Allocation: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field OrderId", wireType) - } - m.OrderId = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrderEntry - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.OrderId |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Quantity", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrderEntry - } - 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 ErrInvalidLengthOrderEntry - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrderEntry - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Quantity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Account", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowOrderEntry - } - 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 ErrInvalidLengthOrderEntry - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthOrderEntry - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Account = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipOrderEntry(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthOrderEntry - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipOrderEntry(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowOrderEntry - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowOrderEntry - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowOrderEntry - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthOrderEntry - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupOrderEntry - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthOrderEntry - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthOrderEntry = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowOrderEntry = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupOrderEntry = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/order_placement.go b/x/dex/types/order_placement.go deleted file mode 100644 index 1104e1e016..0000000000 --- a/x/dex/types/order_placement.go +++ /dev/null @@ -1,31 +0,0 @@ -package types - -import ( - "fmt" -) - -type SudoOrderPlacementMsg struct { - OrderPlacements OrderPlacementMsgDetails `json:"bulk_order_placements"` -} - -type OrderPlacementMsgDetails struct { - Orders []Order `json:"orders"` - Deposits []ContractDepositInfo `json:"deposits"` -} - -func (m *SudoOrderPlacementMsg) IsEmpty() bool { - return len(m.OrderPlacements.Deposits) == 0 && len(m.OrderPlacements.Orders) == 0 -} - -type SudoOrderPlacementResponse struct { - UnsuccessfulOrders []UnsuccessfulOrder `json:"unsuccessful_orders"` -} - -type UnsuccessfulOrder struct { - ID uint64 `json:"id"` - Reason string `json:"reason"` -} - -func (r SudoOrderPlacementResponse) String() string { - return fmt.Sprintf("Unsuccessful orders count: %d", len(r.UnsuccessfulOrders)) -} diff --git a/x/dex/types/orders.go b/x/dex/types/orders.go deleted file mode 100644 index 54c0eaf77b..0000000000 --- a/x/dex/types/orders.go +++ /dev/null @@ -1,244 +0,0 @@ -package types - -import ( - "github.com/cosmos/cosmos-sdk/store/prefix" - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/utils" -) - -type OrderBook struct { - Contract ContractAddress - Pair Pair - Longs *CachedSortedOrderBookEntries - Shorts *CachedSortedOrderBookEntries -} - -// entries are always sorted by prices in ascending order, regardless of side -type CachedSortedOrderBookEntries struct { - CachedEntries []OrderBookEntry - currentPtr int - currentChanged bool - - loader func(ctx sdk.Context, startingPriceExclusive sdk.Dec, withLimit bool) []OrderBookEntry - setter func(sdk.Context, OrderBookEntry) - deleter func(sdk.Context, OrderBookEntry) -} - -func NewCachedSortedOrderBookEntries( - loader func(ctx sdk.Context, startingPriceExclusive sdk.Dec, withLimit bool) []OrderBookEntry, - setter func(sdk.Context, OrderBookEntry), - deleter func(sdk.Context, OrderBookEntry), -) *CachedSortedOrderBookEntries { - return &CachedSortedOrderBookEntries{ - CachedEntries: []OrderBookEntry{}, - currentPtr: 0, - currentChanged: false, - loader: loader, - setter: setter, - deleter: deleter, - } -} - -func (c *CachedSortedOrderBookEntries) load(ctx sdk.Context) { - var loaded []OrderBookEntry - if len(c.CachedEntries) == 0 { - loaded = c.loader(ctx, sdk.ZeroDec(), false) - } else { - loaded = c.loader(ctx, c.CachedEntries[len(c.CachedEntries)-1].GetOrderEntry().Price, true) - } - c.CachedEntries = append(c.CachedEntries, loaded...) -} - -// Reduce quantity of the order book entry currently being pointed at by the specified quantity. -// Also remove/reduce allocations of the order book entry in FIFO order. If the order book entry -// does not have enough quantity to settle against, the returned `settled` value will equal to -// the quantity of the order book entry; otherwise it will equal to the specified quantity. -func (c *CachedSortedOrderBookEntries) SettleQuantity(_ sdk.Context, quantity sdk.Dec) (res []ToSettle, settled sdk.Dec) { - if quantity.IsZero() { - return []ToSettle{}, quantity - } - currentEntry := c.CachedEntries[c.currentPtr].GetOrderEntry() - c.currentChanged = true - - if quantity.GTE(currentEntry.Quantity) { - res = utils.Map(currentEntry.Allocations, AllocationToSettle) - settled = currentEntry.Quantity - currentEntry.Quantity = sdk.ZeroDec() - currentEntry.Allocations = []*Allocation{} - return res, settled - } - - settled = sdk.ZeroDec() - newFirstAllocationIdx := 0 - for idx, a := range currentEntry.Allocations { - postSettle := settled.Add(a.Quantity) - if postSettle.LTE(quantity) { - settled = postSettle - res = append(res, AllocationToSettle(a)) - } else { - newFirstAllocationIdx = idx - if settled.Equal(quantity) { - break - } - res = append(res, ToSettle{ - OrderID: a.OrderId, - Account: a.Account, - Amount: quantity.Sub(settled), - }) - a.Quantity = a.Quantity.Sub(quantity.Sub(settled)) - settled = quantity - break - } - } - currentEntry.Quantity = currentEntry.Quantity.Sub(quantity) - currentEntry.Allocations = currentEntry.Allocations[newFirstAllocationIdx:] - return res, settled -} - -// Discard all dirty changes and reload -func (c *CachedSortedOrderBookEntries) Refresh(ctx sdk.Context) { - c.CachedEntries = c.loader(ctx, sdk.ZeroDec(), false) - c.currentPtr = 0 - c.currentChanged = false -} - -func (c *CachedSortedOrderBookEntries) Flush(ctx sdk.Context) { - stop := c.currentPtr - if !c.currentChanged { - stop-- - } - for i := 0; i <= stop; i++ { - if i >= len(c.CachedEntries) { - break - } - entry := c.CachedEntries[i] - if entry.GetOrderEntry().Quantity.IsZero() { - c.deleter(ctx, entry) - } else { - c.setter(ctx, entry) - } - } - c.CachedEntries = c.CachedEntries[c.currentPtr:] - c.currentPtr = 0 - c.currentChanged = false -} - -// Next will only move on to the next order if the current order quantity hits zero. -// So it should not be used for read-only iteration -func (c *CachedSortedOrderBookEntries) Next(ctx sdk.Context) OrderBookEntry { - for c.currentPtr < len(c.CachedEntries) && c.CachedEntries[c.currentPtr].GetOrderEntry().Quantity.IsZero() { - c.currentPtr++ - c.currentChanged = false - } - if c.currentPtr >= len(c.CachedEntries) { - c.load(ctx) - // if nothing is loaded, we've reached the end - if c.currentPtr >= len(c.CachedEntries) { - return nil - } - } - return c.CachedEntries[c.currentPtr] -} - -type OrderBookEntry interface { - GetPrice() sdk.Dec - GetOrderEntry() *OrderEntry - DeepCopy() OrderBookEntry - SetEntry(*OrderEntry) - SetPrice(sdk.Dec) -} - -func (m *LongBook) SetPrice(p sdk.Dec) { - m.Price = p -} - -type PriceStore struct { - Store prefix.Store - PriceKeys [][]byte -} - -func (m *LongBook) GetPrice() sdk.Dec { - return m.Price -} - -func (m *LongBook) GetOrderEntry() *OrderEntry { - return m.Entry -} - -func (m *LongBook) SetEntry(newEntry *OrderEntry) { - m.Entry = newEntry -} - -func (m *LongBook) DeepCopy() OrderBookEntry { - allocations := []*Allocation{} - for _, allo := range m.Entry.Allocations { - allocations = append(allocations, &Allocation{ - OrderId: allo.OrderId, - Quantity: allo.Quantity, - Account: allo.Account, - }) - } - newOrderEntry := OrderEntry{ - Price: m.Entry.Price, - Quantity: m.Entry.Quantity, - PriceDenom: m.Entry.PriceDenom, - AssetDenom: m.Entry.AssetDenom, - Allocations: allocations, - } - return &LongBook{ - Price: m.Price, - Entry: &newOrderEntry, - } -} - -func (m *ShortBook) SetPrice(p sdk.Dec) { - m.Price = p -} - -func (m *ShortBook) GetPrice() sdk.Dec { - return m.Price -} - -func (m *ShortBook) GetOrderEntry() *OrderEntry { - return m.Entry -} - -func (m *ShortBook) SetEntry(newEntry *OrderEntry) { - m.Entry = newEntry -} - -func (m *ShortBook) DeepCopy() OrderBookEntry { - allocations := []*Allocation{} - for _, allo := range m.Entry.Allocations { - allocations = append(allocations, &Allocation{ - OrderId: allo.OrderId, - Quantity: allo.Quantity, - Account: allo.Account, - }) - } - newOrderEntry := OrderEntry{ - Price: m.Entry.Price, - Quantity: m.Entry.Quantity, - PriceDenom: m.Entry.PriceDenom, - AssetDenom: m.Entry.AssetDenom, - Allocations: allocations, - } - return &ShortBook{ - Price: m.Price, - Entry: &newOrderEntry, - } -} - -type ToSettle struct { - OrderID uint64 - Amount sdk.Dec - Account string -} - -func AllocationToSettle(a *Allocation) ToSettle { - return ToSettle{ - OrderID: a.OrderId, - Amount: a.Quantity, - Account: a.Account, - } -} diff --git a/x/dex/types/orders_test.go b/x/dex/types/orders_test.go deleted file mode 100644 index 65439dfc4a..0000000000 --- a/x/dex/types/orders_test.go +++ /dev/null @@ -1,166 +0,0 @@ -package types_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -var TestEntryOne = types.OrderEntry{ - Price: sdk.MustNewDecFromStr("10"), - Quantity: sdk.MustNewDecFromStr("3"), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - Allocations: []*types.Allocation{ - { - Quantity: sdk.MustNewDecFromStr("2"), - Account: "abc", - OrderId: 1, - }, { - Quantity: sdk.MustNewDecFromStr("1"), - Account: "def", - OrderId: 2, - }, - }, -} - -var TestEntryTwo = types.OrderEntry{ - Price: sdk.MustNewDecFromStr("11"), - Quantity: sdk.MustNewDecFromStr("2"), - PriceDenom: keepertest.TestPriceDenom, - AssetDenom: keepertest.TestAssetDenom, - Allocations: []*types.Allocation{ - { - Quantity: sdk.MustNewDecFromStr("2"), - Account: "ghi", - OrderId: 3, - }, - }, -} - -func getCachedSortedOrderBookEntries(keeper *keeper.Keeper) *types.CachedSortedOrderBookEntries { - loader := func(lctx sdk.Context, startExclusive sdk.Dec, withLimit bool) []types.OrderBookEntry { - if !withLimit { - return keeper.GetTopNLongBooksForPair(lctx, keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom, 1) - } - return keeper.GetTopNLongBooksForPairStarting(lctx, keepertest.TestContract, keepertest.TestPriceDenom, keepertest.TestAssetDenom, 1, startExclusive) - } - setter := func(lctx sdk.Context, o types.OrderBookEntry) { - keeper.SetLongOrderBookEntry(lctx, keepertest.TestContract, o) - } - deleter := func(lctx sdk.Context, o types.OrderBookEntry) { - keeper.RemoveLongBookByPrice(lctx, keepertest.TestContract, o.GetPrice(), keepertest.TestPriceDenom, keepertest.TestAssetDenom) - } - return types.NewCachedSortedOrderBookEntries(loader, setter, deleter) -} - -func populateEntries(ctx sdk.Context, keeper *keeper.Keeper) { - keeper.SetLongBook(ctx, keepertest.TestContract, types.LongBook{ - Price: TestEntryOne.Price, - Entry: &TestEntryOne, - }) - keeper.SetLongBook(ctx, keepertest.TestContract, types.LongBook{ - Price: TestEntryTwo.Price, - Entry: &TestEntryTwo, - }) -} - -func TestIterateAndMutate(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - populateEntries(ctx, dexkeeper) - cache := getCachedSortedOrderBookEntries(dexkeeper) - // first Next should return entry two since its a higher priced long - entry := cache.Next(ctx) - require.NotNil(t, entry) - require.Equal(t, TestEntryTwo.Price, entry.GetPrice()) - require.Equal(t, TestEntryTwo, *entry.GetOrderEntry()) - res, settled := cache.SettleQuantity(ctx, sdk.OneDec()) - require.Equal(t, []types.ToSettle{{ - Amount: sdk.OneDec(), - Account: "ghi", - OrderID: 3, - }}, res) - require.Equal(t, sdk.OneDec(), settled) - - // second Next should still return entry two with decreased quantity - entry = cache.Next(ctx) - require.NotNil(t, entry) - require.Equal(t, TestEntryTwo.Price, entry.GetPrice()) - require.Equal(t, sdk.OneDec(), entry.GetOrderEntry().Quantity) - require.Equal(t, 1, len(entry.GetOrderEntry().Allocations)) - require.Equal(t, types.Allocation{ - Quantity: sdk.OneDec(), - Account: "ghi", - OrderId: 3, - }, *entry.GetOrderEntry().Allocations[0]) - res, settled = cache.SettleQuantity(ctx, sdk.OneDec()) - require.Equal(t, []types.ToSettle{{ - Amount: sdk.OneDec(), - Account: "ghi", - OrderID: 3, - }}, res) - require.Equal(t, sdk.OneDec(), settled) - - // third Next should return entry one since entry two has fully settled (whether flushed or not) - entry = cache.Next(ctx) - require.NotNil(t, entry) - require.Equal(t, TestEntryOne.Price, entry.GetPrice()) - require.Equal(t, TestEntryOne, *entry.GetOrderEntry()) - res, settled = cache.SettleQuantity(ctx, sdk.NewDec(4)) - require.Equal(t, []types.ToSettle{{ - Amount: sdk.NewDec(2), - Account: "abc", - OrderID: 1, - }, { - Amount: sdk.NewDec(1), - Account: "def", - OrderID: 2, - }}, res) - require.Equal(t, sdk.NewDec(3), settled) - - // fourth Next should return nil - entry = cache.Next(ctx) - require.Nil(t, entry) -} - -func TestRefreshAndFlush(t *testing.T) { - dexkeeper, ctx := keepertest.DexKeeper(t) - populateEntries(ctx, dexkeeper) - cache := getCachedSortedOrderBookEntries(dexkeeper) - _ = cache.Next(ctx) - _, _ = cache.SettleQuantity(ctx, sdk.OneDec()) - // refresh without flushing settle changes should undo the settle - cache.Refresh(ctx) - entry := cache.Next(ctx) - require.NotNil(t, entry) - require.Equal(t, TestEntryTwo.Price, entry.GetPrice()) - require.Equal(t, TestEntryTwo, *entry.GetOrderEntry()) - - _, _ = cache.SettleQuantity(ctx, sdk.OneDec()) - cache.Flush(ctx) - // refresh after flushing should reflect the settle change - cache.Refresh(ctx) - entry = cache.Next(ctx) - require.NotNil(t, entry) - require.Equal(t, TestEntryTwo.Price, entry.GetPrice()) - require.Equal(t, sdk.OneDec(), entry.GetOrderEntry().Quantity) - require.Equal(t, 1, len(entry.GetOrderEntry().Allocations)) - require.Equal(t, types.Allocation{ - Quantity: sdk.OneDec(), - Account: "ghi", - OrderId: 3, - }, *entry.GetOrderEntry().Allocations[0]) - - _, _ = cache.SettleQuantity(ctx, sdk.OneDec()) - cache.Flush(ctx) - // refresh after flushing a deleted entry should result in the next Next being the next entry - cache.Refresh(ctx) - entry = cache.Next(ctx) - require.NotNil(t, entry) - require.Equal(t, TestEntryOne.Price, entry.GetPrice()) - require.Equal(t, TestEntryOne, *entry.GetOrderEntry()) -} diff --git a/x/dex/types/pair.pb.go b/x/dex/types/pair.pb.go deleted file mode 100644 index 55841676db..0000000000 --- a/x/dex/types/pair.pb.go +++ /dev/null @@ -1,718 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/pair.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type Pair struct { - PriceDenom string `protobuf:"bytes,1,opt,name=priceDenom,proto3" json:"price_denom"` - AssetDenom string `protobuf:"bytes,2,opt,name=assetDenom,proto3" json:"asset_denom"` - PriceTicksize *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,3,opt,name=priceTicksize,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"price_tick_size"` - QuantityTicksize *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,4,opt,name=quantityTicksize,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"quantity_tick_size"` -} - -func (m *Pair) Reset() { *m = Pair{} } -func (m *Pair) String() string { return proto.CompactTextString(m) } -func (*Pair) ProtoMessage() {} -func (*Pair) Descriptor() ([]byte, []int) { - return fileDescriptor_d4350ebee878f69a, []int{0} -} -func (m *Pair) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *Pair) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_Pair.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *Pair) XXX_Merge(src proto.Message) { - xxx_messageInfo_Pair.Merge(m, src) -} -func (m *Pair) XXX_Size() int { - return m.Size() -} -func (m *Pair) XXX_DiscardUnknown() { - xxx_messageInfo_Pair.DiscardUnknown(m) -} - -var xxx_messageInfo_Pair proto.InternalMessageInfo - -func (m *Pair) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *Pair) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -type BatchContractPair struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_addr"` - Pairs []*Pair `protobuf:"bytes,2,rep,name=pairs,proto3" json:"pairs"` -} - -func (m *BatchContractPair) Reset() { *m = BatchContractPair{} } -func (m *BatchContractPair) String() string { return proto.CompactTextString(m) } -func (*BatchContractPair) ProtoMessage() {} -func (*BatchContractPair) Descriptor() ([]byte, []int) { - return fileDescriptor_d4350ebee878f69a, []int{1} -} -func (m *BatchContractPair) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *BatchContractPair) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_BatchContractPair.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *BatchContractPair) XXX_Merge(src proto.Message) { - xxx_messageInfo_BatchContractPair.Merge(m, src) -} -func (m *BatchContractPair) XXX_Size() int { - return m.Size() -} -func (m *BatchContractPair) XXX_DiscardUnknown() { - xxx_messageInfo_BatchContractPair.DiscardUnknown(m) -} - -var xxx_messageInfo_BatchContractPair proto.InternalMessageInfo - -func (m *BatchContractPair) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *BatchContractPair) GetPairs() []*Pair { - if m != nil { - return m.Pairs - } - return nil -} - -func init() { - proto.RegisterType((*Pair)(nil), "seiprotocol.seichain.dex.Pair") - proto.RegisterType((*BatchContractPair)(nil), "seiprotocol.seichain.dex.BatchContractPair") -} - -func init() { proto.RegisterFile("dex/pair.proto", fileDescriptor_d4350ebee878f69a) } - -var fileDescriptor_d4350ebee878f69a = []byte{ - // 368 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x94, 0x52, 0x3f, 0x4f, 0xf2, 0x40, - 0x18, 0xa7, 0xc0, 0xfb, 0x26, 0x1c, 0x22, 0xd2, 0x38, 0x34, 0x0e, 0x2d, 0x61, 0x30, 0x2c, 0xf4, - 0x12, 0x8d, 0xb3, 0xa1, 0x92, 0xb8, 0x9a, 0xc6, 0xc9, 0x85, 0x1c, 0x77, 0x97, 0x72, 0x41, 0x7a, - 0xf5, 0xee, 0x48, 0xc0, 0xaf, 0xe0, 0xe2, 0x77, 0x72, 0x61, 0x64, 0x34, 0x0e, 0x8d, 0x81, 0xad, - 0x9f, 0xc2, 0xdc, 0x95, 0x0a, 0xc4, 0x38, 0x38, 0xdd, 0x3d, 0xbf, 0xe7, 0xf7, 0xa7, 0x7d, 0x9e, - 0x03, 0xc7, 0x84, 0xce, 0x61, 0x82, 0x98, 0xf0, 0x13, 0xc1, 0x15, 0xb7, 0x1d, 0x49, 0x99, 0xb9, - 0x61, 0xfe, 0xe8, 0x4b, 0xca, 0xf0, 0x18, 0xb1, 0xd8, 0x27, 0x74, 0x7e, 0x76, 0x1a, 0xf1, 0x88, - 0x9b, 0x16, 0xd4, 0xb7, 0x9c, 0xdf, 0x79, 0x2b, 0x83, 0xea, 0x1d, 0x62, 0xc2, 0x86, 0x00, 0x24, - 0x82, 0x61, 0x3a, 0xa0, 0x31, 0x9f, 0x3a, 0x56, 0xdb, 0xea, 0xd6, 0x82, 0x66, 0x96, 0x7a, 0x75, - 0x83, 0x0e, 0x89, 0x86, 0xc3, 0x3d, 0x8a, 0x16, 0x20, 0x29, 0xa9, 0xca, 0x05, 0xe5, 0x9d, 0xc0, - 0xa0, 0x85, 0x60, 0x47, 0xb1, 0x23, 0xd0, 0x30, 0xf2, 0x7b, 0x86, 0x27, 0x92, 0x3d, 0x53, 0xa7, - 0x62, 0x34, 0xfd, 0x65, 0xea, 0x59, 0x1f, 0xa9, 0x77, 0x1e, 0x31, 0x35, 0x9e, 0x8d, 0x7c, 0xcc, - 0xa7, 0x10, 0x73, 0x39, 0xe5, 0x72, 0x7b, 0xf4, 0x24, 0x99, 0x40, 0xb5, 0x48, 0xa8, 0xf4, 0x07, - 0x14, 0x67, 0xa9, 0xd7, 0xcc, 0x3f, 0x49, 0x31, 0x3c, 0x19, 0x6a, 0xa3, 0xf0, 0xd0, 0xd7, 0x4e, - 0xc0, 0xc9, 0xd3, 0x0c, 0xc5, 0x8a, 0xa9, 0xc5, 0x77, 0x56, 0xd5, 0x64, 0x0d, 0xfe, 0x9c, 0x65, - 0x17, 0x4e, 0x7b, 0x71, 0x3f, 0xdc, 0x3b, 0x2f, 0x16, 0x68, 0x05, 0x48, 0xe1, 0xf1, 0x0d, 0x8f, - 0x95, 0x40, 0x58, 0x99, 0x91, 0x5e, 0x81, 0x23, 0xbc, 0xad, 0xfb, 0x84, 0x88, 0xed, 0x50, 0x5b, - 0x59, 0xea, 0x35, 0x0a, 0x7c, 0x88, 0x08, 0x11, 0xe1, 0x01, 0xcd, 0xbe, 0x06, 0xff, 0xf4, 0x42, - 0xa5, 0x53, 0x6e, 0x57, 0xba, 0xf5, 0x0b, 0xd7, 0xff, 0x6d, 0xa5, 0xbe, 0x4e, 0x09, 0x6a, 0x59, - 0xea, 0xe5, 0x82, 0x30, 0x3f, 0x82, 0xdb, 0xe5, 0xda, 0xb5, 0x56, 0x6b, 0xd7, 0xfa, 0x5c, 0xbb, - 0xd6, 0xeb, 0xc6, 0x2d, 0xad, 0x36, 0x6e, 0xe9, 0x7d, 0xe3, 0x96, 0x1e, 0x7a, 0x7b, 0xff, 0x2d, - 0x29, 0xeb, 0x15, 0xb6, 0xa6, 0x30, 0xbe, 0x70, 0x0e, 0xf5, 0x8b, 0x32, 0x23, 0x18, 0xfd, 0x37, - 0xfd, 0xcb, 0xaf, 0x00, 0x00, 0x00, 0xff, 0xff, 0xd0, 0x03, 0x32, 0x50, 0x65, 0x02, 0x00, 0x00, -} - -func (m *Pair) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *Pair) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *Pair) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.QuantityTicksize != nil { - { - size := m.QuantityTicksize.Size() - i -= size - if _, err := m.QuantityTicksize.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintPair(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x22 - } - if m.PriceTicksize != nil { - { - size := m.PriceTicksize.Size() - i -= size - if _, err := m.PriceTicksize.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintPair(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - } - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintPair(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x12 - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintPair(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *BatchContractPair) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *BatchContractPair) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *BatchContractPair) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Pairs) > 0 { - for iNdEx := len(m.Pairs) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Pairs[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintPair(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintPair(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func encodeVarintPair(dAtA []byte, offset int, v uint64) int { - offset -= sovPair(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *Pair) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovPair(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovPair(uint64(l)) - } - if m.PriceTicksize != nil { - l = m.PriceTicksize.Size() - n += 1 + l + sovPair(uint64(l)) - } - if m.QuantityTicksize != nil { - l = m.QuantityTicksize.Size() - n += 1 + l + sovPair(uint64(l)) - } - return n -} - -func (m *BatchContractPair) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovPair(uint64(l)) - } - if len(m.Pairs) > 0 { - for _, e := range m.Pairs { - l = e.Size() - n += 1 + l + sovPair(uint64(l)) - } - } - return n -} - -func sovPair(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozPair(x uint64) (n int) { - return sovPair(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *Pair) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPair - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: Pair: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: Pair: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPair - } - 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 ErrInvalidLengthPair - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPair - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPair - } - 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 ErrInvalidLengthPair - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPair - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceTicksize", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPair - } - 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 ErrInvalidLengthPair - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPair - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.PriceTicksize = &v - if err := m.PriceTicksize.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field QuantityTicksize", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPair - } - 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 ErrInvalidLengthPair - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPair - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.QuantityTicksize = &v - if err := m.QuantityTicksize.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipPair(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthPair - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *BatchContractPair) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPair - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: BatchContractPair: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: BatchContractPair: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPair - } - 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 ErrInvalidLengthPair - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPair - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Pairs", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPair - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthPair - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthPair - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Pairs = append(m.Pairs, &Pair{}) - if err := m.Pairs[len(m.Pairs)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipPair(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthPair - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipPair(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowPair - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowPair - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowPair - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthPair - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupPair - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthPair - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthPair = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowPair = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupPair = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/params.go b/x/dex/types/params.go deleted file mode 100644 index aa0f4cde71..0000000000 --- a/x/dex/types/params.go +++ /dev/null @@ -1,143 +0,0 @@ -package types - -import ( - "fmt" - - sdk "github.com/cosmos/cosmos-sdk/types" - paramtypes "github.com/cosmos/cosmos-sdk/x/params/types" - "gopkg.in/yaml.v2" -) - -var ( - KeyPriceSnapshotRetention = []byte("PriceSnapshotRetention") // number of epochs to retain price snapshots for - KeySudoCallGasPrice = []byte("KeySudoCallGasPrice") // gas price for sudo calls from endblock - KeyBeginBlockGasLimit = []byte("KeyBeginBlockGasLimit") - KeyEndBlockGasLimit = []byte("KeyEndBlockGasLimit") - KeyDefaultGasPerOrder = []byte("KeyDefaultGasPerOrder") - KeyDefaultGasPerCancel = []byte("KeyDefaultGasPerCancel") - KeyMinRentDeposit = []byte("KeyMinRentDeposit") - KeyGasAllowancePerSettlement = []byte("KeyGasAllowancePerSettlement") - KeyMinProcessableRent = []byte("KeyMinProcessableRent") - KeyOrderBookEntriesPerLoad = []byte("KeyOrderBookEntriesPerLoad") - KeyContractUnsuspendCost = []byte("KeyContractUnsuspendCost") - KeyMaxOrderPerPrice = []byte("KeyMaxOrderPerPrice") - KeyMaxPairsPerContract = []byte("KeyMaxPairsPerContract") - KeyDefaultGasPerOrderDataByte = []byte("KeyDefaultGasPerOrderDataByte") -) - -const ( - DefaultPriceSnapshotRetention = 24 * 3600 // default to one day - DefaultBeginBlockGasLimit = 200000000 // 200M - DefaultEndBlockGasLimit = 1000000000 // 1B - DefaultDefaultGasPerOrder = 55000 - DefaultDefaultGasPerCancel = 53000 - DefaultMinRentDeposit = 10000000 // 10 sei - DefaultGasAllowancePerSettlement = 10000 - DefaultMinProcessableRent = 100000 - DefaultOrderBookEntriesPerLoad = 10 - DefaultContractUnsuspendCost = 1000000 - DefaultMaxOrderPerPrice = 10000 - DefaultMaxPairsPerContract = 100 - DefaultDefaultGasPerOrderDataByte = 30 -) - -var DefaultSudoCallGasPrice = sdk.NewDecWithPrec(1, 1) // 0.1 - -var _ paramtypes.ParamSet = (*Params)(nil) - -// ParamKeyTable the param key table for launch module -func ParamKeyTable() paramtypes.KeyTable { - return paramtypes.NewKeyTable().RegisterParamSet(&Params{}) -} - -// DefaultParams returns a default set of parameters -func DefaultParams() Params { - return Params{ - PriceSnapshotRetention: DefaultPriceSnapshotRetention, - SudoCallGasPrice: DefaultSudoCallGasPrice, - BeginBlockGasLimit: DefaultBeginBlockGasLimit, - EndBlockGasLimit: DefaultEndBlockGasLimit, - DefaultGasPerOrder: DefaultDefaultGasPerOrder, - DefaultGasPerCancel: DefaultDefaultGasPerCancel, - MinRentDeposit: DefaultMinRentDeposit, - GasAllowancePerSettlement: DefaultGasAllowancePerSettlement, - MinProcessableRent: DefaultMinProcessableRent, - OrderBookEntriesPerLoad: DefaultOrderBookEntriesPerLoad, - ContractUnsuspendCost: DefaultContractUnsuspendCost, - MaxOrderPerPrice: DefaultMaxOrderPerPrice, - MaxPairsPerContract: DefaultMaxPairsPerContract, - DefaultGasPerOrderDataByte: DefaultDefaultGasPerOrderDataByte, - } -} - -// ParamSetPairs get the params.ParamSet -func (p *Params) ParamSetPairs() paramtypes.ParamSetPairs { - return paramtypes.ParamSetPairs{ - paramtypes.NewParamSetPair(KeyPriceSnapshotRetention, &p.PriceSnapshotRetention, validatePriceSnapshotRetention), - paramtypes.NewParamSetPair(KeySudoCallGasPrice, &p.SudoCallGasPrice, validateSudoCallGasPrice), - paramtypes.NewParamSetPair(KeyBeginBlockGasLimit, &p.BeginBlockGasLimit, validateUint64Param), - paramtypes.NewParamSetPair(KeyEndBlockGasLimit, &p.EndBlockGasLimit, validateUint64Param), - paramtypes.NewParamSetPair(KeyDefaultGasPerOrder, &p.DefaultGasPerOrder, validateUint64Param), - paramtypes.NewParamSetPair(KeyDefaultGasPerCancel, &p.DefaultGasPerCancel, validateUint64Param), - paramtypes.NewParamSetPair(KeyMinRentDeposit, &p.MinRentDeposit, validateUint64Param), - paramtypes.NewParamSetPair(KeyGasAllowancePerSettlement, &p.GasAllowancePerSettlement, validateUint64Param), - paramtypes.NewParamSetPair(KeyMinProcessableRent, &p.MinProcessableRent, validateUint64Param), - paramtypes.NewParamSetPair(KeyOrderBookEntriesPerLoad, &p.OrderBookEntriesPerLoad, validateUint64Param), - paramtypes.NewParamSetPair(KeyContractUnsuspendCost, &p.ContractUnsuspendCost, validateUint64Param), - paramtypes.NewParamSetPair(KeyMaxOrderPerPrice, &p.MaxOrderPerPrice, validateUint64Param), - paramtypes.NewParamSetPair(KeyMaxPairsPerContract, &p.MaxPairsPerContract, validateUint64Param), - paramtypes.NewParamSetPair(KeyDefaultGasPerOrderDataByte, &p.DefaultGasPerOrderDataByte, validateUint64Param), - } -} - -// Validate validates the set of params -func (p Params) Validate() error { - if err := validatePriceSnapshotRetention(p.PriceSnapshotRetention); err != nil { - return err - } - if err := validateSudoCallGasPrice(p.SudoCallGasPrice); err != nil { - return err - } - // it's not possible for other params to fail validation if they've already - // made it into Params' fields. - return nil -} - -// String implements the Stringer interface. -func (p Params) String() string { - out, _ := yaml.Marshal(p) - return string(out) -} - -func validatePriceSnapshotRetention(i interface{}) error { - v, ok := i.(uint64) - if !ok { - return fmt.Errorf("invalid parameter type: %T", i) - } - - if v == 0 { - return fmt.Errorf("price snapshot retention must be a positive integer: %d", v) - } - - return nil -} - -func validateSudoCallGasPrice(i interface{}) error { - price, ok := i.(sdk.Dec) - if !ok { - return fmt.Errorf("invalid parameter type: %T", i) - } - if !price.IsPositive() { - return fmt.Errorf("nonpositive sudo call price") - } - return nil -} - -func validateUint64Param(i interface{}) error { - _, ok := i.(uint64) - if !ok { - return fmt.Errorf("invalid parameter type: %T", i) - } - - return nil -} diff --git a/x/dex/types/params.pb.go b/x/dex/types/params.pb.go deleted file mode 100644 index 7322767bc4..0000000000 --- a/x/dex/types/params.pb.go +++ /dev/null @@ -1,870 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/params.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -// Params defines the parameters for the module. -type Params struct { - PriceSnapshotRetention uint64 `protobuf:"varint,1,opt,name=price_snapshot_retention,json=priceSnapshotRetention,proto3" json:"price_snapshot_retention" yaml:"price_snapshot_retention"` - SudoCallGasPrice github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,2,opt,name=sudo_call_gas_price,json=sudoCallGasPrice,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"sudo_call_gas_price"` - BeginBlockGasLimit uint64 `protobuf:"varint,3,opt,name=begin_block_gas_limit,json=beginBlockGasLimit,proto3" json:"begin_block_gas_limit" yaml:"begin_block_gas_limit"` - EndBlockGasLimit uint64 `protobuf:"varint,4,opt,name=end_block_gas_limit,json=endBlockGasLimit,proto3" json:"end_block_gas_limit" yaml:"end_block_gas_limit"` - DefaultGasPerOrder uint64 `protobuf:"varint,5,opt,name=default_gas_per_order,json=defaultGasPerOrder,proto3" json:"default_gas_per_order" yaml:"default_gas_per_order"` - DefaultGasPerCancel uint64 `protobuf:"varint,6,opt,name=default_gas_per_cancel,json=defaultGasPerCancel,proto3" json:"default_gas_per_cancel" yaml:"default_gas_per_cancel"` - MinRentDeposit uint64 `protobuf:"varint,7,opt,name=min_rent_deposit,json=minRentDeposit,proto3" json:"min_rent_deposit" yaml:"min_rent_deposit"` - GasAllowancePerSettlement uint64 `protobuf:"varint,8,opt,name=gas_allowance_per_settlement,json=gasAllowancePerSettlement,proto3" json:"gas_allowance_per_settlement" yaml:"gas_allowance_per_settlement"` - MinProcessableRent uint64 `protobuf:"varint,9,opt,name=min_processable_rent,json=minProcessableRent,proto3" json:"min_processable_rent" yaml:"min_processable_rent"` - OrderBookEntriesPerLoad uint64 `protobuf:"varint,10,opt,name=order_book_entries_per_load,json=orderBookEntriesPerLoad,proto3" json:"order_book_entries_per_load" yaml:"order_book_entries_per_load"` - ContractUnsuspendCost uint64 `protobuf:"varint,11,opt,name=contract_unsuspend_cost,json=contractUnsuspendCost,proto3" json:"contract_unsuspend_cost" yaml:"contract_unsuspend_cost"` - MaxOrderPerPrice uint64 `protobuf:"varint,12,opt,name=max_order_per_price,json=maxOrderPerPrice,proto3" json:"max_order_per_price" yaml:"max_order_per_price"` - MaxPairsPerContract uint64 `protobuf:"varint,13,opt,name=max_pairs_per_contract,json=maxPairsPerContract,proto3" json:"max_pairs_per_contract" yaml:"max_pairs_per_contract"` - DefaultGasPerOrderDataByte uint64 `protobuf:"varint,14,opt,name=default_gas_per_order_data_byte,json=defaultGasPerOrderDataByte,proto3" json:"default_gas_per_order_data_byte" yaml:"default_gas_per_order_data_byte"` -} - -func (m *Params) Reset() { *m = Params{} } -func (*Params) ProtoMessage() {} -func (*Params) Descriptor() ([]byte, []int) { - return fileDescriptor_e49286500ccff43e, []int{0} -} -func (m *Params) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *Params) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_Params.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *Params) XXX_Merge(src proto.Message) { - xxx_messageInfo_Params.Merge(m, src) -} -func (m *Params) XXX_Size() int { - return m.Size() -} -func (m *Params) XXX_DiscardUnknown() { - xxx_messageInfo_Params.DiscardUnknown(m) -} - -var xxx_messageInfo_Params proto.InternalMessageInfo - -func (m *Params) GetPriceSnapshotRetention() uint64 { - if m != nil { - return m.PriceSnapshotRetention - } - return 0 -} - -func (m *Params) GetBeginBlockGasLimit() uint64 { - if m != nil { - return m.BeginBlockGasLimit - } - return 0 -} - -func (m *Params) GetEndBlockGasLimit() uint64 { - if m != nil { - return m.EndBlockGasLimit - } - return 0 -} - -func (m *Params) GetDefaultGasPerOrder() uint64 { - if m != nil { - return m.DefaultGasPerOrder - } - return 0 -} - -func (m *Params) GetDefaultGasPerCancel() uint64 { - if m != nil { - return m.DefaultGasPerCancel - } - return 0 -} - -func (m *Params) GetMinRentDeposit() uint64 { - if m != nil { - return m.MinRentDeposit - } - return 0 -} - -func (m *Params) GetGasAllowancePerSettlement() uint64 { - if m != nil { - return m.GasAllowancePerSettlement - } - return 0 -} - -func (m *Params) GetMinProcessableRent() uint64 { - if m != nil { - return m.MinProcessableRent - } - return 0 -} - -func (m *Params) GetOrderBookEntriesPerLoad() uint64 { - if m != nil { - return m.OrderBookEntriesPerLoad - } - return 0 -} - -func (m *Params) GetContractUnsuspendCost() uint64 { - if m != nil { - return m.ContractUnsuspendCost - } - return 0 -} - -func (m *Params) GetMaxOrderPerPrice() uint64 { - if m != nil { - return m.MaxOrderPerPrice - } - return 0 -} - -func (m *Params) GetMaxPairsPerContract() uint64 { - if m != nil { - return m.MaxPairsPerContract - } - return 0 -} - -func (m *Params) GetDefaultGasPerOrderDataByte() uint64 { - if m != nil { - return m.DefaultGasPerOrderDataByte - } - return 0 -} - -func init() { - proto.RegisterType((*Params)(nil), "seiprotocol.seichain.dex.Params") -} - -func init() { proto.RegisterFile("dex/params.proto", fileDescriptor_e49286500ccff43e) } - -var fileDescriptor_e49286500ccff43e = []byte{ - // 787 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x95, 0xc1, 0x6f, 0x1b, 0x45, - 0x14, 0xc6, 0xbd, 0x50, 0x42, 0x3b, 0x94, 0xca, 0xda, 0x34, 0xc9, 0x92, 0x16, 0x4f, 0x35, 0x48, - 0x55, 0x2f, 0xb1, 0x0f, 0x08, 0x21, 0x8a, 0x10, 0xc2, 0x49, 0x94, 0x4b, 0x11, 0xd6, 0x54, 0x1c, - 0xe0, 0xb2, 0x1a, 0xef, 0x3e, 0x9c, 0x51, 0x66, 0x67, 0x56, 0x33, 0x63, 0x61, 0x9f, 0xb9, 0x70, - 0x44, 0x9c, 0x38, 0xf6, 0xcf, 0xe9, 0xb1, 0x47, 0xc4, 0x61, 0x84, 0x92, 0x0b, 0xda, 0xe3, 0xfe, - 0x05, 0x68, 0x66, 0x6d, 0x96, 0x24, 0x6b, 0xf7, 0x94, 0xcd, 0xf7, 0xfb, 0xb4, 0xdf, 0x7b, 0xde, - 0x79, 0x6f, 0x50, 0x3f, 0x87, 0xc5, 0xa8, 0x64, 0x9a, 0x15, 0x66, 0x58, 0x6a, 0x65, 0x55, 0x9c, - 0x18, 0xe0, 0xe1, 0x29, 0x53, 0x62, 0x68, 0x80, 0x67, 0xe7, 0x8c, 0xcb, 0x61, 0x0e, 0x8b, 0xc3, - 0x87, 0x33, 0x35, 0x53, 0x01, 0x8d, 0xfc, 0x53, 0xe3, 0x27, 0xf5, 0x7d, 0xb4, 0x33, 0x09, 0x2f, - 0x88, 0x97, 0x28, 0x29, 0x35, 0xcf, 0x20, 0x35, 0x92, 0x95, 0xe6, 0x5c, 0xd9, 0x54, 0x83, 0x05, - 0x69, 0xb9, 0x92, 0x49, 0xf4, 0x24, 0x7a, 0x76, 0x67, 0xfc, 0x75, 0xe5, 0xf0, 0x46, 0x4f, 0xed, - 0x30, 0x5e, 0xb2, 0x42, 0x3c, 0x27, 0x9b, 0x1c, 0x84, 0xee, 0x07, 0xf4, 0x72, 0x45, 0xe8, 0x1a, - 0xc4, 0x16, 0xed, 0x9a, 0x79, 0xae, 0xd2, 0x8c, 0x09, 0x91, 0xce, 0x98, 0x49, 0x83, 0x2f, 0x79, - 0xe7, 0x49, 0xf4, 0xec, 0xde, 0xf8, 0xf4, 0xb5, 0xc3, 0xbd, 0xbf, 0x1c, 0x7e, 0x3a, 0xe3, 0xf6, - 0x7c, 0x3e, 0x1d, 0x66, 0xaa, 0x18, 0x65, 0xca, 0x14, 0xca, 0xac, 0xfe, 0x1c, 0x99, 0xfc, 0x62, - 0x64, 0x97, 0x25, 0x98, 0xe1, 0x09, 0x64, 0x95, 0xc3, 0x5d, 0x2f, 0xa3, 0x7d, 0x2f, 0x1e, 0x33, - 0x21, 0xce, 0x98, 0x99, 0x78, 0x25, 0x16, 0x68, 0x6f, 0x0a, 0x33, 0x2e, 0xd3, 0xa9, 0x50, 0xd9, - 0x45, 0xb0, 0x0a, 0x5e, 0x70, 0x9b, 0xbc, 0x1b, 0xba, 0xfd, 0xa2, 0x72, 0xb8, 0xdb, 0x50, 0x3b, - 0xfc, 0xb8, 0x69, 0xb5, 0x13, 0x13, 0x1a, 0x07, 0x7d, 0xec, 0xe5, 0x33, 0x66, 0x5e, 0x78, 0x31, - 0xce, 0xd1, 0x2e, 0xc8, 0xfc, 0x56, 0xd6, 0x9d, 0x90, 0xf5, 0x99, 0xaf, 0xba, 0x03, 0xd7, 0x0e, - 0x1f, 0x36, 0x49, 0x1d, 0x90, 0xd0, 0x3e, 0xc8, 0xfc, 0x7a, 0x8a, 0x40, 0x7b, 0x39, 0xfc, 0xc4, - 0xe6, 0xc2, 0x36, 0xad, 0x83, 0x4e, 0x95, 0xce, 0x41, 0x27, 0xef, 0xb5, 0x3d, 0x75, 0x1a, 0xda, - 0x9e, 0x3a, 0x31, 0xa1, 0xf1, 0x4a, 0xf7, 0x3f, 0x1f, 0xe8, 0xef, 0xbc, 0x18, 0x97, 0x68, 0xff, - 0xa6, 0x3b, 0x63, 0x32, 0x03, 0x91, 0xec, 0x84, 0xb8, 0x2f, 0x2b, 0x87, 0x37, 0x38, 0x6a, 0x87, - 0x3f, 0xee, 0xce, 0x6b, 0x38, 0xa1, 0xbb, 0xd7, 0x02, 0x8f, 0x83, 0x1a, 0xff, 0x80, 0xfa, 0x05, - 0x97, 0xa9, 0x06, 0x69, 0xd3, 0x1c, 0x4a, 0x65, 0xb8, 0x4d, 0xde, 0x0f, 0x59, 0xa3, 0xca, 0xe1, - 0x5b, 0xac, 0x76, 0xf8, 0xa0, 0x49, 0xb9, 0x49, 0x08, 0x7d, 0x50, 0x70, 0x49, 0x41, 0xda, 0x93, - 0x46, 0x88, 0x7f, 0x8d, 0xd0, 0x63, 0x5f, 0x03, 0x13, 0x42, 0xfd, 0xec, 0xd3, 0x42, 0x35, 0x06, - 0xac, 0x15, 0x50, 0x80, 0xb4, 0xc9, 0xdd, 0x90, 0x73, 0x56, 0x39, 0xbc, 0xd5, 0x57, 0x3b, 0xfc, - 0x49, 0x93, 0xb9, 0xcd, 0x45, 0xe8, 0x47, 0x33, 0x66, 0xbe, 0x59, 0xd3, 0x09, 0xe8, 0x97, 0xff, - 0xb1, 0x98, 0xa3, 0x87, 0xbe, 0xde, 0x52, 0xab, 0x0c, 0x8c, 0x61, 0x53, 0x01, 0xa1, 0xf6, 0xe4, - 0x5e, 0xa8, 0xe0, 0xf3, 0xca, 0xe1, 0x4e, 0x5e, 0x3b, 0xfc, 0xa8, 0xed, 0xf6, 0x26, 0x25, 0x34, - 0x2e, 0xb8, 0x9c, 0xb4, 0xaa, 0x6f, 0x3e, 0xfe, 0x25, 0x42, 0x8f, 0xc2, 0x17, 0x4e, 0xa7, 0x4a, - 0x5d, 0xa4, 0x20, 0xad, 0xe6, 0xd0, 0x7c, 0x08, 0xa1, 0x58, 0x9e, 0xa0, 0x10, 0x79, 0x5a, 0x39, - 0xbc, 0xcd, 0x56, 0x3b, 0x4c, 0x9a, 0xe4, 0x2d, 0x26, 0x42, 0x0f, 0x02, 0x1d, 0x2b, 0x75, 0x71, - 0xda, 0xb0, 0x09, 0xe8, 0x17, 0x8a, 0xe5, 0xf1, 0x1c, 0x1d, 0x64, 0x4a, 0x5a, 0xcd, 0x32, 0x9b, - 0xce, 0xa5, 0x99, 0x9b, 0xd2, 0x9f, 0xf7, 0x4c, 0x19, 0x9b, 0x7c, 0x10, 0x0a, 0xf8, 0xaa, 0x72, - 0x78, 0x93, 0xa5, 0x76, 0x78, 0xd0, 0x84, 0x6f, 0x30, 0x10, 0xba, 0xb7, 0x26, 0xdf, 0xaf, 0xc1, - 0xb1, 0x32, 0x61, 0x26, 0x0b, 0xb6, 0x68, 0x4e, 0x78, 0x28, 0xb3, 0xd9, 0x3b, 0xf7, 0xdb, 0x99, - 0xec, 0xc0, 0xed, 0x4c, 0x76, 0x40, 0x42, 0xfb, 0x05, 0x5b, 0x84, 0xe9, 0x98, 0x80, 0x6e, 0xf6, - 0x4c, 0x89, 0xf6, 0xbd, 0xb3, 0x64, 0x5c, 0xaf, 0x4e, 0xf8, 0xaa, 0x98, 0xe4, 0xc3, 0x76, 0x4a, - 0xba, 0x1d, 0xed, 0x94, 0x74, 0x73, 0x42, 0x7d, 0x85, 0x13, 0xaf, 0xfb, 0x19, 0x59, 0xa9, 0xf1, - 0xef, 0x11, 0xc2, 0x9d, 0x63, 0x9c, 0xe6, 0xcc, 0xb2, 0x74, 0xba, 0xb4, 0x90, 0x3c, 0x08, 0xd9, - 0xdf, 0x56, 0x0e, 0xbf, 0xcd, 0x5a, 0x3b, 0xfc, 0x74, 0xcb, 0x6a, 0x68, 0x8d, 0x84, 0x1e, 0xde, - 0x5e, 0x12, 0x27, 0xcc, 0xb2, 0xf1, 0xd2, 0xc2, 0xf3, 0xbb, 0x7f, 0xbc, 0xc2, 0xbd, 0x7f, 0x5e, - 0xe1, 0x68, 0x7c, 0xf6, 0xfa, 0x72, 0x10, 0xbd, 0xb9, 0x1c, 0x44, 0x7f, 0x5f, 0x0e, 0xa2, 0xdf, - 0xae, 0x06, 0xbd, 0x37, 0x57, 0x83, 0xde, 0x9f, 0x57, 0x83, 0xde, 0x8f, 0x47, 0xff, 0xdb, 0xf1, - 0x06, 0xf8, 0xd1, 0xfa, 0x2a, 0x0b, 0xff, 0x84, 0xbb, 0x6c, 0xb4, 0x18, 0xf9, 0x4b, 0x2f, 0xac, - 0xfb, 0xe9, 0x4e, 0xe0, 0x9f, 0xfe, 0x1b, 0x00, 0x00, 0xff, 0xff, 0xff, 0x27, 0x82, 0x3c, 0x08, - 0x07, 0x00, 0x00, -} - -func (this *Params) Equal(that interface{}) bool { - if that == nil { - return this == nil - } - - that1, ok := that.(*Params) - if !ok { - that2, ok := that.(Params) - if ok { - that1 = &that2 - } else { - return false - } - } - if that1 == nil { - return this == nil - } else if this == nil { - return false - } - if this.PriceSnapshotRetention != that1.PriceSnapshotRetention { - return false - } - if !this.SudoCallGasPrice.Equal(that1.SudoCallGasPrice) { - return false - } - if this.BeginBlockGasLimit != that1.BeginBlockGasLimit { - return false - } - if this.EndBlockGasLimit != that1.EndBlockGasLimit { - return false - } - if this.DefaultGasPerOrder != that1.DefaultGasPerOrder { - return false - } - if this.DefaultGasPerCancel != that1.DefaultGasPerCancel { - return false - } - if this.MinRentDeposit != that1.MinRentDeposit { - return false - } - if this.GasAllowancePerSettlement != that1.GasAllowancePerSettlement { - return false - } - if this.MinProcessableRent != that1.MinProcessableRent { - return false - } - if this.OrderBookEntriesPerLoad != that1.OrderBookEntriesPerLoad { - return false - } - if this.ContractUnsuspendCost != that1.ContractUnsuspendCost { - return false - } - if this.MaxOrderPerPrice != that1.MaxOrderPerPrice { - return false - } - if this.MaxPairsPerContract != that1.MaxPairsPerContract { - return false - } - if this.DefaultGasPerOrderDataByte != that1.DefaultGasPerOrderDataByte { - return false - } - return true -} -func (m *Params) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *Params) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *Params) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.DefaultGasPerOrderDataByte != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.DefaultGasPerOrderDataByte)) - i-- - dAtA[i] = 0x70 - } - if m.MaxPairsPerContract != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.MaxPairsPerContract)) - i-- - dAtA[i] = 0x68 - } - if m.MaxOrderPerPrice != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.MaxOrderPerPrice)) - i-- - dAtA[i] = 0x60 - } - if m.ContractUnsuspendCost != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.ContractUnsuspendCost)) - i-- - dAtA[i] = 0x58 - } - if m.OrderBookEntriesPerLoad != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.OrderBookEntriesPerLoad)) - i-- - dAtA[i] = 0x50 - } - if m.MinProcessableRent != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.MinProcessableRent)) - i-- - dAtA[i] = 0x48 - } - if m.GasAllowancePerSettlement != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.GasAllowancePerSettlement)) - i-- - dAtA[i] = 0x40 - } - if m.MinRentDeposit != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.MinRentDeposit)) - i-- - dAtA[i] = 0x38 - } - if m.DefaultGasPerCancel != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.DefaultGasPerCancel)) - i-- - dAtA[i] = 0x30 - } - if m.DefaultGasPerOrder != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.DefaultGasPerOrder)) - i-- - dAtA[i] = 0x28 - } - if m.EndBlockGasLimit != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.EndBlockGasLimit)) - i-- - dAtA[i] = 0x20 - } - if m.BeginBlockGasLimit != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.BeginBlockGasLimit)) - i-- - dAtA[i] = 0x18 - } - { - size := m.SudoCallGasPrice.Size() - i -= size - if _, err := m.SudoCallGasPrice.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintParams(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - if m.PriceSnapshotRetention != 0 { - i = encodeVarintParams(dAtA, i, uint64(m.PriceSnapshotRetention)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func encodeVarintParams(dAtA []byte, offset int, v uint64) int { - offset -= sovParams(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *Params) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.PriceSnapshotRetention != 0 { - n += 1 + sovParams(uint64(m.PriceSnapshotRetention)) - } - l = m.SudoCallGasPrice.Size() - n += 1 + l + sovParams(uint64(l)) - if m.BeginBlockGasLimit != 0 { - n += 1 + sovParams(uint64(m.BeginBlockGasLimit)) - } - if m.EndBlockGasLimit != 0 { - n += 1 + sovParams(uint64(m.EndBlockGasLimit)) - } - if m.DefaultGasPerOrder != 0 { - n += 1 + sovParams(uint64(m.DefaultGasPerOrder)) - } - if m.DefaultGasPerCancel != 0 { - n += 1 + sovParams(uint64(m.DefaultGasPerCancel)) - } - if m.MinRentDeposit != 0 { - n += 1 + sovParams(uint64(m.MinRentDeposit)) - } - if m.GasAllowancePerSettlement != 0 { - n += 1 + sovParams(uint64(m.GasAllowancePerSettlement)) - } - if m.MinProcessableRent != 0 { - n += 1 + sovParams(uint64(m.MinProcessableRent)) - } - if m.OrderBookEntriesPerLoad != 0 { - n += 1 + sovParams(uint64(m.OrderBookEntriesPerLoad)) - } - if m.ContractUnsuspendCost != 0 { - n += 1 + sovParams(uint64(m.ContractUnsuspendCost)) - } - if m.MaxOrderPerPrice != 0 { - n += 1 + sovParams(uint64(m.MaxOrderPerPrice)) - } - if m.MaxPairsPerContract != 0 { - n += 1 + sovParams(uint64(m.MaxPairsPerContract)) - } - if m.DefaultGasPerOrderDataByte != 0 { - n += 1 + sovParams(uint64(m.DefaultGasPerOrderDataByte)) - } - return n -} - -func sovParams(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozParams(x uint64) (n int) { - return sovParams(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *Params) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: Params: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: Params: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceSnapshotRetention", wireType) - } - m.PriceSnapshotRetention = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.PriceSnapshotRetention |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field SudoCallGasPrice", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - 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 ErrInvalidLengthParams - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthParams - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.SudoCallGasPrice.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field BeginBlockGasLimit", wireType) - } - m.BeginBlockGasLimit = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.BeginBlockGasLimit |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field EndBlockGasLimit", wireType) - } - m.EndBlockGasLimit = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.EndBlockGasLimit |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 5: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field DefaultGasPerOrder", wireType) - } - m.DefaultGasPerOrder = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.DefaultGasPerOrder |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 6: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field DefaultGasPerCancel", wireType) - } - m.DefaultGasPerCancel = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.DefaultGasPerCancel |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 7: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field MinRentDeposit", wireType) - } - m.MinRentDeposit = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.MinRentDeposit |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 8: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field GasAllowancePerSettlement", wireType) - } - m.GasAllowancePerSettlement = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.GasAllowancePerSettlement |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 9: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field MinProcessableRent", wireType) - } - m.MinProcessableRent = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.MinProcessableRent |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 10: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field OrderBookEntriesPerLoad", wireType) - } - m.OrderBookEntriesPerLoad = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.OrderBookEntriesPerLoad |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 11: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractUnsuspendCost", wireType) - } - m.ContractUnsuspendCost = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.ContractUnsuspendCost |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 12: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field MaxOrderPerPrice", wireType) - } - m.MaxOrderPerPrice = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.MaxOrderPerPrice |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 13: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field MaxPairsPerContract", wireType) - } - m.MaxPairsPerContract = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.MaxPairsPerContract |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 14: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field DefaultGasPerOrderDataByte", wireType) - } - m.DefaultGasPerOrderDataByte = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowParams - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.DefaultGasPerOrderDataByte |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipParams(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthParams - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipParams(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowParams - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowParams - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowParams - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthParams - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupParams - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthParams - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthParams = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowParams = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupParams = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/params_test.go b/x/dex/types/params_test.go deleted file mode 100644 index efd19a5cf2..0000000000 --- a/x/dex/types/params_test.go +++ /dev/null @@ -1,17 +0,0 @@ -package types_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestParamsValidate(t *testing.T) { - p := types.Params{PriceSnapshotRetention: 0} - require.Error(t, p.Validate()) - - p = types.Params{SudoCallGasPrice: sdk.ZeroDec()} - require.Error(t, p.Validate()) -} diff --git a/x/dex/types/price.pb.go b/x/dex/types/price.pb.go deleted file mode 100644 index b85e68649e..0000000000 --- a/x/dex/types/price.pb.go +++ /dev/null @@ -1,881 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/price.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type Price struct { - SnapshotTimestampInSeconds uint64 `protobuf:"varint,1,opt,name=snapshotTimestampInSeconds,proto3" json:"snapshot_timestamp_in_seconds"` - Price github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,2,opt,name=price,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"price" yaml:"price"` - Pair *Pair `protobuf:"bytes,3,opt,name=pair,proto3" json:"pair"` -} - -func (m *Price) Reset() { *m = Price{} } -func (m *Price) String() string { return proto.CompactTextString(m) } -func (*Price) ProtoMessage() {} -func (*Price) Descriptor() ([]byte, []int) { - return fileDescriptor_bd5d1c9d490efb8c, []int{0} -} -func (m *Price) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *Price) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_Price.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *Price) XXX_Merge(src proto.Message) { - xxx_messageInfo_Price.Merge(m, src) -} -func (m *Price) XXX_Size() int { - return m.Size() -} -func (m *Price) XXX_DiscardUnknown() { - xxx_messageInfo_Price.DiscardUnknown(m) -} - -var xxx_messageInfo_Price proto.InternalMessageInfo - -func (m *Price) GetSnapshotTimestampInSeconds() uint64 { - if m != nil { - return m.SnapshotTimestampInSeconds - } - return 0 -} - -func (m *Price) GetPair() *Pair { - if m != nil { - return m.Pair - } - return nil -} - -type PriceCandlestick struct { - BeginTimestamp uint64 `protobuf:"varint,1,opt,name=beginTimestamp,proto3" json:"begin_timestamp"` - EndTimestamp uint64 `protobuf:"varint,2,opt,name=endTimestamp,proto3" json:"end_timestamp"` - Open *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,3,opt,name=open,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"open"` - High *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,4,opt,name=high,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"high"` - Low *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,5,opt,name=low,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"low"` - Close *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,6,opt,name=close,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"close"` - Volume *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,7,opt,name=volume,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"volume"` -} - -func (m *PriceCandlestick) Reset() { *m = PriceCandlestick{} } -func (m *PriceCandlestick) String() string { return proto.CompactTextString(m) } -func (*PriceCandlestick) ProtoMessage() {} -func (*PriceCandlestick) Descriptor() ([]byte, []int) { - return fileDescriptor_bd5d1c9d490efb8c, []int{1} -} -func (m *PriceCandlestick) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *PriceCandlestick) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_PriceCandlestick.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *PriceCandlestick) XXX_Merge(src proto.Message) { - xxx_messageInfo_PriceCandlestick.Merge(m, src) -} -func (m *PriceCandlestick) XXX_Size() int { - return m.Size() -} -func (m *PriceCandlestick) XXX_DiscardUnknown() { - xxx_messageInfo_PriceCandlestick.DiscardUnknown(m) -} - -var xxx_messageInfo_PriceCandlestick proto.InternalMessageInfo - -func (m *PriceCandlestick) GetBeginTimestamp() uint64 { - if m != nil { - return m.BeginTimestamp - } - return 0 -} - -func (m *PriceCandlestick) GetEndTimestamp() uint64 { - if m != nil { - return m.EndTimestamp - } - return 0 -} - -func init() { - proto.RegisterType((*Price)(nil), "seiprotocol.seichain.dex.Price") - proto.RegisterType((*PriceCandlestick)(nil), "seiprotocol.seichain.dex.PriceCandlestick") -} - -func init() { proto.RegisterFile("dex/price.proto", fileDescriptor_bd5d1c9d490efb8c) } - -var fileDescriptor_bd5d1c9d490efb8c = []byte{ - // 466 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x93, 0xcf, 0x6e, 0xd3, 0x40, - 0x10, 0xc6, 0xe3, 0xfc, 0x83, 0x2e, 0xa5, 0x85, 0x85, 0x83, 0x15, 0x09, 0x3b, 0xe4, 0x80, 0x72, - 0x89, 0x2d, 0x5a, 0xb8, 0x00, 0x27, 0x17, 0x51, 0x55, 0xe2, 0x50, 0x2d, 0x9c, 0x90, 0x50, 0xe4, - 0xac, 0x47, 0xf6, 0xaa, 0xf6, 0xae, 0x95, 0x75, 0x21, 0x7d, 0x02, 0xae, 0x3c, 0x56, 0x8f, 0x3d, - 0x22, 0x0e, 0x16, 0x4a, 0x6e, 0x3e, 0x22, 0x1e, 0x00, 0xed, 0x38, 0xa1, 0x01, 0x09, 0x24, 0x73, - 0x99, 0xd9, 0xf1, 0x7c, 0xdf, 0x4f, 0x9e, 0xf1, 0x9a, 0xec, 0x47, 0xb0, 0xf0, 0xf3, 0xb9, 0xe0, - 0xe0, 0xe5, 0x73, 0x55, 0x28, 0x6a, 0x6b, 0x10, 0x78, 0xe2, 0x2a, 0xf5, 0x34, 0x08, 0x9e, 0x84, - 0x42, 0x7a, 0x11, 0x2c, 0x06, 0xf7, 0x63, 0x15, 0x2b, 0x6c, 0xf9, 0xe6, 0x54, 0xeb, 0x07, 0x7b, - 0x08, 0x08, 0xc5, 0xbc, 0xae, 0x47, 0x9f, 0xda, 0xa4, 0x77, 0x6a, 0x78, 0x34, 0x24, 0x03, 0x2d, - 0xc3, 0x5c, 0x27, 0xaa, 0x78, 0x2b, 0x32, 0xd0, 0x45, 0x98, 0xe5, 0x27, 0xf2, 0x0d, 0x70, 0x25, - 0x23, 0x6d, 0x5b, 0x43, 0x6b, 0xdc, 0x0d, 0x1e, 0x56, 0xa5, 0xfb, 0x60, 0xa3, 0x9a, 0x16, 0x1b, - 0xd9, 0x54, 0xc8, 0xa9, 0xae, 0x85, 0xec, 0x1f, 0x10, 0xfa, 0x9e, 0xf4, 0xf0, 0xdd, 0xed, 0xf6, - 0xd0, 0x1a, 0xef, 0x04, 0xc7, 0x97, 0xa5, 0xdb, 0xfa, 0x5a, 0xba, 0x8f, 0x62, 0x51, 0x24, 0xe7, - 0x33, 0x8f, 0xab, 0xcc, 0xe7, 0x4a, 0x67, 0x4a, 0xaf, 0xd3, 0x44, 0x47, 0x67, 0x7e, 0x71, 0x91, - 0x83, 0xf6, 0x5e, 0x02, 0xaf, 0x4a, 0xb7, 0xb6, 0x7f, 0x2f, 0xdd, 0xdd, 0x8b, 0x30, 0x4b, 0x9f, - 0x8d, 0xb0, 0x1c, 0xb1, 0xfa, 0x31, 0x7d, 0x41, 0xba, 0x66, 0x32, 0xbb, 0x33, 0xb4, 0xc6, 0xb7, - 0x0e, 0x1c, 0xef, 0x6f, 0xab, 0xf1, 0x4e, 0x43, 0x31, 0x0f, 0x6e, 0x56, 0xa5, 0x8b, 0x7a, 0x86, - 0x71, 0xf4, 0xa3, 0x43, 0xee, 0xe0, 0x26, 0x8e, 0x42, 0x19, 0xa5, 0xa0, 0x0b, 0xc1, 0xcf, 0xe8, - 0x73, 0xb2, 0x37, 0x83, 0x58, 0xc8, 0x5f, 0xc3, 0xac, 0x17, 0x71, 0xaf, 0x2a, 0xdd, 0x7d, 0xec, - 0x5c, 0x6f, 0x81, 0xfd, 0x21, 0xa5, 0x4f, 0xc9, 0x2e, 0xc8, 0xe8, 0xda, 0xda, 0x46, 0xeb, 0xdd, - 0xaa, 0x74, 0x6f, 0x83, 0x8c, 0xb6, 0x8c, 0xbf, 0xc9, 0xe8, 0x2b, 0xd2, 0x55, 0x39, 0x48, 0x1c, - 0x63, 0x27, 0x38, 0x68, 0xb4, 0x20, 0x74, 0x32, 0x8c, 0x86, 0x93, 0x88, 0x38, 0xb1, 0xbb, 0xff, - 0xc3, 0x31, 0x4e, 0x86, 0x91, 0x1e, 0x91, 0x4e, 0xaa, 0x3e, 0xda, 0x3d, 0xc4, 0x3c, 0x6e, 0x84, - 0x31, 0x46, 0x66, 0x02, 0x3d, 0x21, 0x3d, 0x9e, 0x2a, 0x0d, 0x76, 0x1f, 0x31, 0x87, 0xcd, 0x3e, - 0x3b, 0x5a, 0x59, 0x9d, 0xe8, 0x6b, 0xd2, 0xff, 0xa0, 0xd2, 0xf3, 0x0c, 0xec, 0x1b, 0xc8, 0x7a, - 0xd2, 0x88, 0xb5, 0xf6, 0xb2, 0x75, 0x0e, 0x8e, 0x2f, 0x97, 0x8e, 0x75, 0xb5, 0x74, 0xac, 0x6f, - 0x4b, 0xc7, 0xfa, 0xbc, 0x72, 0x5a, 0x57, 0x2b, 0xa7, 0xf5, 0x65, 0xe5, 0xb4, 0xde, 0x4d, 0xb6, - 0x98, 0x1a, 0xc4, 0x64, 0x73, 0x97, 0xb0, 0xc0, 0xcb, 0xe4, 0x2f, 0x7c, 0xf3, 0x3b, 0x21, 0x7e, - 0xd6, 0xc7, 0xfe, 0xe1, 0xcf, 0x00, 0x00, 0x00, 0xff, 0xff, 0xa8, 0xe7, 0x11, 0xeb, 0xa3, 0x03, - 0x00, 0x00, -} - -func (m *Price) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *Price) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *Price) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Pair != nil { - { - size, err := m.Pair.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintPrice(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - } - { - size := m.Price.Size() - i -= size - if _, err := m.Price.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintPrice(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - if m.SnapshotTimestampInSeconds != 0 { - i = encodeVarintPrice(dAtA, i, uint64(m.SnapshotTimestampInSeconds)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func (m *PriceCandlestick) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *PriceCandlestick) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *PriceCandlestick) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Volume != nil { - { - size := m.Volume.Size() - i -= size - if _, err := m.Volume.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintPrice(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x3a - } - if m.Close != nil { - { - size := m.Close.Size() - i -= size - if _, err := m.Close.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintPrice(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x32 - } - if m.Low != nil { - { - size := m.Low.Size() - i -= size - if _, err := m.Low.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintPrice(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x2a - } - if m.High != nil { - { - size := m.High.Size() - i -= size - if _, err := m.High.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintPrice(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x22 - } - if m.Open != nil { - { - size := m.Open.Size() - i -= size - if _, err := m.Open.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintPrice(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - } - if m.EndTimestamp != 0 { - i = encodeVarintPrice(dAtA, i, uint64(m.EndTimestamp)) - i-- - dAtA[i] = 0x10 - } - if m.BeginTimestamp != 0 { - i = encodeVarintPrice(dAtA, i, uint64(m.BeginTimestamp)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func encodeVarintPrice(dAtA []byte, offset int, v uint64) int { - offset -= sovPrice(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *Price) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.SnapshotTimestampInSeconds != 0 { - n += 1 + sovPrice(uint64(m.SnapshotTimestampInSeconds)) - } - l = m.Price.Size() - n += 1 + l + sovPrice(uint64(l)) - if m.Pair != nil { - l = m.Pair.Size() - n += 1 + l + sovPrice(uint64(l)) - } - return n -} - -func (m *PriceCandlestick) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.BeginTimestamp != 0 { - n += 1 + sovPrice(uint64(m.BeginTimestamp)) - } - if m.EndTimestamp != 0 { - n += 1 + sovPrice(uint64(m.EndTimestamp)) - } - if m.Open != nil { - l = m.Open.Size() - n += 1 + l + sovPrice(uint64(l)) - } - if m.High != nil { - l = m.High.Size() - n += 1 + l + sovPrice(uint64(l)) - } - if m.Low != nil { - l = m.Low.Size() - n += 1 + l + sovPrice(uint64(l)) - } - if m.Close != nil { - l = m.Close.Size() - n += 1 + l + sovPrice(uint64(l)) - } - if m.Volume != nil { - l = m.Volume.Size() - n += 1 + l + sovPrice(uint64(l)) - } - return n -} - -func sovPrice(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozPrice(x uint64) (n int) { - return sovPrice(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *Price) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: Price: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: Price: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field SnapshotTimestampInSeconds", wireType) - } - m.SnapshotTimestampInSeconds = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.SnapshotTimestampInSeconds |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - 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 ErrInvalidLengthPrice - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPrice - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Price.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Pair", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthPrice - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthPrice - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Pair == nil { - m.Pair = &Pair{} - } - if err := m.Pair.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipPrice(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthPrice - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *PriceCandlestick) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: PriceCandlestick: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: PriceCandlestick: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field BeginTimestamp", wireType) - } - m.BeginTimestamp = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.BeginTimestamp |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field EndTimestamp", wireType) - } - m.EndTimestamp = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.EndTimestamp |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Open", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - 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 ErrInvalidLengthPrice - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPrice - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.Open = &v - if err := m.Open.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field High", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - 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 ErrInvalidLengthPrice - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPrice - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.High = &v - if err := m.High.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Low", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - 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 ErrInvalidLengthPrice - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPrice - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.Low = &v - if err := m.Low.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 6: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Close", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - 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 ErrInvalidLengthPrice - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPrice - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.Close = &v - if err := m.Close.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 7: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Volume", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowPrice - } - 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 ErrInvalidLengthPrice - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthPrice - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.Volume = &v - if err := m.Volume.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipPrice(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthPrice - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipPrice(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowPrice - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowPrice - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowPrice - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthPrice - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupPrice - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthPrice - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthPrice = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowPrice = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupPrice = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/query.pb.go b/x/dex/types/query.pb.go deleted file mode 100644 index 931520f809..0000000000 --- a/x/dex/types/query.pb.go +++ /dev/null @@ -1,10031 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/query.proto - -package types - -import ( - context "context" - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - query "github.com/cosmos/cosmos-sdk/types/query" - _ "github.com/gogo/protobuf/gogoproto" - grpc1 "github.com/gogo/protobuf/grpc" - proto "github.com/gogo/protobuf/proto" - _ "google.golang.org/genproto/googleapis/api/annotations" - grpc "google.golang.org/grpc" - codes "google.golang.org/grpc/codes" - status "google.golang.org/grpc/status" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -// QueryParamsRequest is request type for the Query/Params RPC method. -type QueryParamsRequest struct { -} - -func (m *QueryParamsRequest) Reset() { *m = QueryParamsRequest{} } -func (m *QueryParamsRequest) String() string { return proto.CompactTextString(m) } -func (*QueryParamsRequest) ProtoMessage() {} -func (*QueryParamsRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{0} -} -func (m *QueryParamsRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryParamsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryParamsRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryParamsRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryParamsRequest.Merge(m, src) -} -func (m *QueryParamsRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryParamsRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryParamsRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryParamsRequest proto.InternalMessageInfo - -// QueryParamsResponse is response type for the Query/Params RPC method. -type QueryParamsResponse struct { - // params holds all the parameters of this module. - Params Params `protobuf:"bytes,1,opt,name=params,proto3" json:"params"` -} - -func (m *QueryParamsResponse) Reset() { *m = QueryParamsResponse{} } -func (m *QueryParamsResponse) String() string { return proto.CompactTextString(m) } -func (*QueryParamsResponse) ProtoMessage() {} -func (*QueryParamsResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{1} -} -func (m *QueryParamsResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryParamsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryParamsResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryParamsResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryParamsResponse.Merge(m, src) -} -func (m *QueryParamsResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryParamsResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryParamsResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryParamsResponse proto.InternalMessageInfo - -func (m *QueryParamsResponse) GetParams() Params { - if m != nil { - return m.Params - } - return Params{} -} - -type QueryGetLongBookRequest struct { - Price string `protobuf:"bytes,1,opt,name=price,proto3" json:"price,omitempty"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contractAddr,omitempty"` - PriceDenom string `protobuf:"bytes,3,opt,name=priceDenom,proto3" json:"priceDenom,omitempty"` - AssetDenom string `protobuf:"bytes,4,opt,name=assetDenom,proto3" json:"assetDenom,omitempty"` -} - -func (m *QueryGetLongBookRequest) Reset() { *m = QueryGetLongBookRequest{} } -func (m *QueryGetLongBookRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetLongBookRequest) ProtoMessage() {} -func (*QueryGetLongBookRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{2} -} -func (m *QueryGetLongBookRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetLongBookRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetLongBookRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetLongBookRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetLongBookRequest.Merge(m, src) -} -func (m *QueryGetLongBookRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetLongBookRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetLongBookRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetLongBookRequest proto.InternalMessageInfo - -func (m *QueryGetLongBookRequest) GetPrice() string { - if m != nil { - return m.Price - } - return "" -} - -func (m *QueryGetLongBookRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryGetLongBookRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryGetLongBookRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -type QueryGetLongBookResponse struct { - LongBook LongBook `protobuf:"bytes,1,opt,name=LongBook,proto3" json:"LongBook"` -} - -func (m *QueryGetLongBookResponse) Reset() { *m = QueryGetLongBookResponse{} } -func (m *QueryGetLongBookResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetLongBookResponse) ProtoMessage() {} -func (*QueryGetLongBookResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{3} -} -func (m *QueryGetLongBookResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetLongBookResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetLongBookResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetLongBookResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetLongBookResponse.Merge(m, src) -} -func (m *QueryGetLongBookResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetLongBookResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetLongBookResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetLongBookResponse proto.InternalMessageInfo - -func (m *QueryGetLongBookResponse) GetLongBook() LongBook { - if m != nil { - return m.LongBook - } - return LongBook{} -} - -type QueryAllLongBookRequest struct { - Pagination *query.PageRequest `protobuf:"bytes,1,opt,name=pagination,proto3" json:"pagination,omitempty"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contractAddr,omitempty"` - PriceDenom string `protobuf:"bytes,3,opt,name=priceDenom,proto3" json:"priceDenom,omitempty"` - AssetDenom string `protobuf:"bytes,4,opt,name=assetDenom,proto3" json:"assetDenom,omitempty"` -} - -func (m *QueryAllLongBookRequest) Reset() { *m = QueryAllLongBookRequest{} } -func (m *QueryAllLongBookRequest) String() string { return proto.CompactTextString(m) } -func (*QueryAllLongBookRequest) ProtoMessage() {} -func (*QueryAllLongBookRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{4} -} -func (m *QueryAllLongBookRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryAllLongBookRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryAllLongBookRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryAllLongBookRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryAllLongBookRequest.Merge(m, src) -} -func (m *QueryAllLongBookRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryAllLongBookRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryAllLongBookRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryAllLongBookRequest proto.InternalMessageInfo - -func (m *QueryAllLongBookRequest) GetPagination() *query.PageRequest { - if m != nil { - return m.Pagination - } - return nil -} - -func (m *QueryAllLongBookRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryAllLongBookRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryAllLongBookRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -type QueryAllLongBookResponse struct { - LongBook []LongBook `protobuf:"bytes,1,rep,name=LongBook,proto3" json:"LongBook"` - Pagination *query.PageResponse `protobuf:"bytes,2,opt,name=pagination,proto3" json:"pagination,omitempty"` -} - -func (m *QueryAllLongBookResponse) Reset() { *m = QueryAllLongBookResponse{} } -func (m *QueryAllLongBookResponse) String() string { return proto.CompactTextString(m) } -func (*QueryAllLongBookResponse) ProtoMessage() {} -func (*QueryAllLongBookResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{5} -} -func (m *QueryAllLongBookResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryAllLongBookResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryAllLongBookResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryAllLongBookResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryAllLongBookResponse.Merge(m, src) -} -func (m *QueryAllLongBookResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryAllLongBookResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryAllLongBookResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryAllLongBookResponse proto.InternalMessageInfo - -func (m *QueryAllLongBookResponse) GetLongBook() []LongBook { - if m != nil { - return m.LongBook - } - return nil -} - -func (m *QueryAllLongBookResponse) GetPagination() *query.PageResponse { - if m != nil { - return m.Pagination - } - return nil -} - -type QueryGetShortBookRequest struct { - Price string `protobuf:"bytes,1,opt,name=price,proto3" json:"price,omitempty"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contractAddr,omitempty"` - PriceDenom string `protobuf:"bytes,3,opt,name=priceDenom,proto3" json:"priceDenom,omitempty"` - AssetDenom string `protobuf:"bytes,4,opt,name=assetDenom,proto3" json:"assetDenom,omitempty"` -} - -func (m *QueryGetShortBookRequest) Reset() { *m = QueryGetShortBookRequest{} } -func (m *QueryGetShortBookRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetShortBookRequest) ProtoMessage() {} -func (*QueryGetShortBookRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{6} -} -func (m *QueryGetShortBookRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetShortBookRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetShortBookRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetShortBookRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetShortBookRequest.Merge(m, src) -} -func (m *QueryGetShortBookRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetShortBookRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetShortBookRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetShortBookRequest proto.InternalMessageInfo - -func (m *QueryGetShortBookRequest) GetPrice() string { - if m != nil { - return m.Price - } - return "" -} - -func (m *QueryGetShortBookRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryGetShortBookRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryGetShortBookRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -type QueryGetShortBookResponse struct { - ShortBook ShortBook `protobuf:"bytes,1,opt,name=ShortBook,proto3" json:"ShortBook"` -} - -func (m *QueryGetShortBookResponse) Reset() { *m = QueryGetShortBookResponse{} } -func (m *QueryGetShortBookResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetShortBookResponse) ProtoMessage() {} -func (*QueryGetShortBookResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{7} -} -func (m *QueryGetShortBookResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetShortBookResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetShortBookResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetShortBookResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetShortBookResponse.Merge(m, src) -} -func (m *QueryGetShortBookResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetShortBookResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetShortBookResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetShortBookResponse proto.InternalMessageInfo - -func (m *QueryGetShortBookResponse) GetShortBook() ShortBook { - if m != nil { - return m.ShortBook - } - return ShortBook{} -} - -type QueryAllShortBookRequest struct { - Pagination *query.PageRequest `protobuf:"bytes,1,opt,name=pagination,proto3" json:"pagination,omitempty"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contractAddr,omitempty"` - PriceDenom string `protobuf:"bytes,3,opt,name=priceDenom,proto3" json:"priceDenom,omitempty"` - AssetDenom string `protobuf:"bytes,4,opt,name=assetDenom,proto3" json:"assetDenom,omitempty"` -} - -func (m *QueryAllShortBookRequest) Reset() { *m = QueryAllShortBookRequest{} } -func (m *QueryAllShortBookRequest) String() string { return proto.CompactTextString(m) } -func (*QueryAllShortBookRequest) ProtoMessage() {} -func (*QueryAllShortBookRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{8} -} -func (m *QueryAllShortBookRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryAllShortBookRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryAllShortBookRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryAllShortBookRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryAllShortBookRequest.Merge(m, src) -} -func (m *QueryAllShortBookRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryAllShortBookRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryAllShortBookRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryAllShortBookRequest proto.InternalMessageInfo - -func (m *QueryAllShortBookRequest) GetPagination() *query.PageRequest { - if m != nil { - return m.Pagination - } - return nil -} - -func (m *QueryAllShortBookRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryAllShortBookRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryAllShortBookRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -type QueryAllShortBookResponse struct { - ShortBook []ShortBook `protobuf:"bytes,1,rep,name=ShortBook,proto3" json:"ShortBook"` - Pagination *query.PageResponse `protobuf:"bytes,2,opt,name=pagination,proto3" json:"pagination,omitempty"` -} - -func (m *QueryAllShortBookResponse) Reset() { *m = QueryAllShortBookResponse{} } -func (m *QueryAllShortBookResponse) String() string { return proto.CompactTextString(m) } -func (*QueryAllShortBookResponse) ProtoMessage() {} -func (*QueryAllShortBookResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{9} -} -func (m *QueryAllShortBookResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryAllShortBookResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryAllShortBookResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryAllShortBookResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryAllShortBookResponse.Merge(m, src) -} -func (m *QueryAllShortBookResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryAllShortBookResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryAllShortBookResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryAllShortBookResponse proto.InternalMessageInfo - -func (m *QueryAllShortBookResponse) GetShortBook() []ShortBook { - if m != nil { - return m.ShortBook - } - return nil -} - -func (m *QueryAllShortBookResponse) GetPagination() *query.PageResponse { - if m != nil { - return m.Pagination - } - return nil -} - -type QueryGetPricesRequest struct { - PriceDenom string `protobuf:"bytes,1,opt,name=priceDenom,proto3" json:"priceDenom,omitempty"` - AssetDenom string `protobuf:"bytes,2,opt,name=assetDenom,proto3" json:"assetDenom,omitempty"` - ContractAddr string `protobuf:"bytes,3,opt,name=contractAddr,proto3" json:"contractAddr,omitempty"` -} - -func (m *QueryGetPricesRequest) Reset() { *m = QueryGetPricesRequest{} } -func (m *QueryGetPricesRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetPricesRequest) ProtoMessage() {} -func (*QueryGetPricesRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{10} -} -func (m *QueryGetPricesRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetPricesRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetPricesRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetPricesRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetPricesRequest.Merge(m, src) -} -func (m *QueryGetPricesRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetPricesRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetPricesRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetPricesRequest proto.InternalMessageInfo - -func (m *QueryGetPricesRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryGetPricesRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -func (m *QueryGetPricesRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -type QueryGetPricesResponse struct { - Prices []*Price `protobuf:"bytes,1,rep,name=prices,proto3" json:"prices,omitempty"` -} - -func (m *QueryGetPricesResponse) Reset() { *m = QueryGetPricesResponse{} } -func (m *QueryGetPricesResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetPricesResponse) ProtoMessage() {} -func (*QueryGetPricesResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{11} -} -func (m *QueryGetPricesResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetPricesResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetPricesResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetPricesResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetPricesResponse.Merge(m, src) -} -func (m *QueryGetPricesResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetPricesResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetPricesResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetPricesResponse proto.InternalMessageInfo - -func (m *QueryGetPricesResponse) GetPrices() []*Price { - if m != nil { - return m.Prices - } - return nil -} - -type QueryGetPriceRequest struct { - PriceDenom string `protobuf:"bytes,1,opt,name=priceDenom,proto3" json:"priceDenom,omitempty"` - AssetDenom string `protobuf:"bytes,2,opt,name=assetDenom,proto3" json:"assetDenom,omitempty"` - ContractAddr string `protobuf:"bytes,3,opt,name=contractAddr,proto3" json:"contractAddr,omitempty"` - Timestamp uint64 `protobuf:"varint,4,opt,name=timestamp,proto3" json:"timestamp,omitempty"` -} - -func (m *QueryGetPriceRequest) Reset() { *m = QueryGetPriceRequest{} } -func (m *QueryGetPriceRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetPriceRequest) ProtoMessage() {} -func (*QueryGetPriceRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{12} -} -func (m *QueryGetPriceRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetPriceRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetPriceRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetPriceRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetPriceRequest.Merge(m, src) -} -func (m *QueryGetPriceRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetPriceRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetPriceRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetPriceRequest proto.InternalMessageInfo - -func (m *QueryGetPriceRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryGetPriceRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -func (m *QueryGetPriceRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryGetPriceRequest) GetTimestamp() uint64 { - if m != nil { - return m.Timestamp - } - return 0 -} - -type QueryGetPriceResponse struct { - Price *Price `protobuf:"bytes,1,opt,name=price,proto3" json:"price,omitempty"` - Found bool `protobuf:"varint,2,opt,name=found,proto3" json:"found,omitempty"` -} - -func (m *QueryGetPriceResponse) Reset() { *m = QueryGetPriceResponse{} } -func (m *QueryGetPriceResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetPriceResponse) ProtoMessage() {} -func (*QueryGetPriceResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{13} -} -func (m *QueryGetPriceResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetPriceResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetPriceResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetPriceResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetPriceResponse.Merge(m, src) -} -func (m *QueryGetPriceResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetPriceResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetPriceResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetPriceResponse proto.InternalMessageInfo - -func (m *QueryGetPriceResponse) GetPrice() *Price { - if m != nil { - return m.Price - } - return nil -} - -func (m *QueryGetPriceResponse) GetFound() bool { - if m != nil { - return m.Found - } - return false -} - -type QueryGetLatestPriceRequest struct { - PriceDenom string `protobuf:"bytes,1,opt,name=priceDenom,proto3" json:"price_denom"` - AssetDenom string `protobuf:"bytes,2,opt,name=assetDenom,proto3" json:"asset_denom"` - ContractAddr string `protobuf:"bytes,3,opt,name=contractAddr,proto3" json:"contract_address"` -} - -func (m *QueryGetLatestPriceRequest) Reset() { *m = QueryGetLatestPriceRequest{} } -func (m *QueryGetLatestPriceRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetLatestPriceRequest) ProtoMessage() {} -func (*QueryGetLatestPriceRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{14} -} -func (m *QueryGetLatestPriceRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetLatestPriceRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetLatestPriceRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetLatestPriceRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetLatestPriceRequest.Merge(m, src) -} -func (m *QueryGetLatestPriceRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetLatestPriceRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetLatestPriceRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetLatestPriceRequest proto.InternalMessageInfo - -func (m *QueryGetLatestPriceRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryGetLatestPriceRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -func (m *QueryGetLatestPriceRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -type QueryGetLatestPriceResponse struct { - Price *Price `protobuf:"bytes,1,opt,name=price,proto3" json:"price,omitempty"` -} - -func (m *QueryGetLatestPriceResponse) Reset() { *m = QueryGetLatestPriceResponse{} } -func (m *QueryGetLatestPriceResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetLatestPriceResponse) ProtoMessage() {} -func (*QueryGetLatestPriceResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{15} -} -func (m *QueryGetLatestPriceResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetLatestPriceResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetLatestPriceResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetLatestPriceResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetLatestPriceResponse.Merge(m, src) -} -func (m *QueryGetLatestPriceResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetLatestPriceResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetLatestPriceResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetLatestPriceResponse proto.InternalMessageInfo - -func (m *QueryGetLatestPriceResponse) GetPrice() *Price { - if m != nil { - return m.Price - } - return nil -} - -type QueryGetTwapsRequest struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_address"` - LookbackSeconds uint64 `protobuf:"varint,2,opt,name=lookbackSeconds,proto3" json:"lookback_seconds"` -} - -func (m *QueryGetTwapsRequest) Reset() { *m = QueryGetTwapsRequest{} } -func (m *QueryGetTwapsRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetTwapsRequest) ProtoMessage() {} -func (*QueryGetTwapsRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{16} -} -func (m *QueryGetTwapsRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetTwapsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetTwapsRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetTwapsRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetTwapsRequest.Merge(m, src) -} -func (m *QueryGetTwapsRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetTwapsRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetTwapsRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetTwapsRequest proto.InternalMessageInfo - -func (m *QueryGetTwapsRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryGetTwapsRequest) GetLookbackSeconds() uint64 { - if m != nil { - return m.LookbackSeconds - } - return 0 -} - -type QueryGetTwapsResponse struct { - Twaps []*Twap `protobuf:"bytes,1,rep,name=twaps,proto3" json:"twaps"` -} - -func (m *QueryGetTwapsResponse) Reset() { *m = QueryGetTwapsResponse{} } -func (m *QueryGetTwapsResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetTwapsResponse) ProtoMessage() {} -func (*QueryGetTwapsResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{17} -} -func (m *QueryGetTwapsResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetTwapsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetTwapsResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetTwapsResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetTwapsResponse.Merge(m, src) -} -func (m *QueryGetTwapsResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetTwapsResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetTwapsResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetTwapsResponse proto.InternalMessageInfo - -func (m *QueryGetTwapsResponse) GetTwaps() []*Twap { - if m != nil { - return m.Twaps - } - return nil -} - -type QueryAssetListRequest struct { -} - -func (m *QueryAssetListRequest) Reset() { *m = QueryAssetListRequest{} } -func (m *QueryAssetListRequest) String() string { return proto.CompactTextString(m) } -func (*QueryAssetListRequest) ProtoMessage() {} -func (*QueryAssetListRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{18} -} -func (m *QueryAssetListRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryAssetListRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryAssetListRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryAssetListRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryAssetListRequest.Merge(m, src) -} -func (m *QueryAssetListRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryAssetListRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryAssetListRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryAssetListRequest proto.InternalMessageInfo - -type QueryAssetListResponse struct { - AssetList []AssetMetadata `protobuf:"bytes,1,rep,name=assetList,proto3" json:"assetList"` -} - -func (m *QueryAssetListResponse) Reset() { *m = QueryAssetListResponse{} } -func (m *QueryAssetListResponse) String() string { return proto.CompactTextString(m) } -func (*QueryAssetListResponse) ProtoMessage() {} -func (*QueryAssetListResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{19} -} -func (m *QueryAssetListResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryAssetListResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryAssetListResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryAssetListResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryAssetListResponse.Merge(m, src) -} -func (m *QueryAssetListResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryAssetListResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryAssetListResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryAssetListResponse proto.InternalMessageInfo - -func (m *QueryAssetListResponse) GetAssetList() []AssetMetadata { - if m != nil { - return m.AssetList - } - return nil -} - -type QueryAssetMetadataRequest struct { - Denom string `protobuf:"bytes,1,opt,name=denom,proto3" json:"denom,omitempty"` -} - -func (m *QueryAssetMetadataRequest) Reset() { *m = QueryAssetMetadataRequest{} } -func (m *QueryAssetMetadataRequest) String() string { return proto.CompactTextString(m) } -func (*QueryAssetMetadataRequest) ProtoMessage() {} -func (*QueryAssetMetadataRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{20} -} -func (m *QueryAssetMetadataRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryAssetMetadataRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryAssetMetadataRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryAssetMetadataRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryAssetMetadataRequest.Merge(m, src) -} -func (m *QueryAssetMetadataRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryAssetMetadataRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryAssetMetadataRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryAssetMetadataRequest proto.InternalMessageInfo - -func (m *QueryAssetMetadataRequest) GetDenom() string { - if m != nil { - return m.Denom - } - return "" -} - -type QueryAssetMetadataResponse struct { - Metadata *AssetMetadata `protobuf:"bytes,1,opt,name=metadata,proto3" json:"metadata,omitempty"` -} - -func (m *QueryAssetMetadataResponse) Reset() { *m = QueryAssetMetadataResponse{} } -func (m *QueryAssetMetadataResponse) String() string { return proto.CompactTextString(m) } -func (*QueryAssetMetadataResponse) ProtoMessage() {} -func (*QueryAssetMetadataResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{21} -} -func (m *QueryAssetMetadataResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryAssetMetadataResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryAssetMetadataResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryAssetMetadataResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryAssetMetadataResponse.Merge(m, src) -} -func (m *QueryAssetMetadataResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryAssetMetadataResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryAssetMetadataResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryAssetMetadataResponse proto.InternalMessageInfo - -func (m *QueryAssetMetadataResponse) GetMetadata() *AssetMetadata { - if m != nil { - return m.Metadata - } - return nil -} - -type QueryRegisteredPairsRequest struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_address"` -} - -func (m *QueryRegisteredPairsRequest) Reset() { *m = QueryRegisteredPairsRequest{} } -func (m *QueryRegisteredPairsRequest) String() string { return proto.CompactTextString(m) } -func (*QueryRegisteredPairsRequest) ProtoMessage() {} -func (*QueryRegisteredPairsRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{22} -} -func (m *QueryRegisteredPairsRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryRegisteredPairsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryRegisteredPairsRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryRegisteredPairsRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryRegisteredPairsRequest.Merge(m, src) -} -func (m *QueryRegisteredPairsRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryRegisteredPairsRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryRegisteredPairsRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryRegisteredPairsRequest proto.InternalMessageInfo - -func (m *QueryRegisteredPairsRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -type QueryRegisteredPairsResponse struct { - Pairs []Pair `protobuf:"bytes,1,rep,name=pairs,proto3" json:"pairs"` -} - -func (m *QueryRegisteredPairsResponse) Reset() { *m = QueryRegisteredPairsResponse{} } -func (m *QueryRegisteredPairsResponse) String() string { return proto.CompactTextString(m) } -func (*QueryRegisteredPairsResponse) ProtoMessage() {} -func (*QueryRegisteredPairsResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{23} -} -func (m *QueryRegisteredPairsResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryRegisteredPairsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryRegisteredPairsResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryRegisteredPairsResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryRegisteredPairsResponse.Merge(m, src) -} -func (m *QueryRegisteredPairsResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryRegisteredPairsResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryRegisteredPairsResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryRegisteredPairsResponse proto.InternalMessageInfo - -func (m *QueryRegisteredPairsResponse) GetPairs() []Pair { - if m != nil { - return m.Pairs - } - return nil -} - -type QueryRegisteredContractRequest struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_address"` -} - -func (m *QueryRegisteredContractRequest) Reset() { *m = QueryRegisteredContractRequest{} } -func (m *QueryRegisteredContractRequest) String() string { return proto.CompactTextString(m) } -func (*QueryRegisteredContractRequest) ProtoMessage() {} -func (*QueryRegisteredContractRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{24} -} -func (m *QueryRegisteredContractRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryRegisteredContractRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryRegisteredContractRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryRegisteredContractRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryRegisteredContractRequest.Merge(m, src) -} -func (m *QueryRegisteredContractRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryRegisteredContractRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryRegisteredContractRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryRegisteredContractRequest proto.InternalMessageInfo - -func (m *QueryRegisteredContractRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -type QueryRegisteredContractResponse struct { - ContractInfo *ContractInfoV2 `protobuf:"bytes,1,opt,name=contract_info,json=contractInfo,proto3" json:"contract_info,omitempty"` -} - -func (m *QueryRegisteredContractResponse) Reset() { *m = QueryRegisteredContractResponse{} } -func (m *QueryRegisteredContractResponse) String() string { return proto.CompactTextString(m) } -func (*QueryRegisteredContractResponse) ProtoMessage() {} -func (*QueryRegisteredContractResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{25} -} -func (m *QueryRegisteredContractResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryRegisteredContractResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryRegisteredContractResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryRegisteredContractResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryRegisteredContractResponse.Merge(m, src) -} -func (m *QueryRegisteredContractResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryRegisteredContractResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryRegisteredContractResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryRegisteredContractResponse proto.InternalMessageInfo - -func (m *QueryRegisteredContractResponse) GetContractInfo() *ContractInfoV2 { - if m != nil { - return m.ContractInfo - } - return nil -} - -type QueryGetOrdersRequest struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_address"` - Account string `protobuf:"bytes,2,opt,name=account,proto3" json:"account"` -} - -func (m *QueryGetOrdersRequest) Reset() { *m = QueryGetOrdersRequest{} } -func (m *QueryGetOrdersRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetOrdersRequest) ProtoMessage() {} -func (*QueryGetOrdersRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{26} -} -func (m *QueryGetOrdersRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetOrdersRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetOrdersRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetOrdersRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetOrdersRequest.Merge(m, src) -} -func (m *QueryGetOrdersRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetOrdersRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetOrdersRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetOrdersRequest proto.InternalMessageInfo - -func (m *QueryGetOrdersRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryGetOrdersRequest) GetAccount() string { - if m != nil { - return m.Account - } - return "" -} - -type QueryGetOrdersResponse struct { - Orders []*Order `protobuf:"bytes,1,rep,name=orders,proto3" json:"orders"` -} - -func (m *QueryGetOrdersResponse) Reset() { *m = QueryGetOrdersResponse{} } -func (m *QueryGetOrdersResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetOrdersResponse) ProtoMessage() {} -func (*QueryGetOrdersResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{27} -} -func (m *QueryGetOrdersResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetOrdersResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetOrdersResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetOrdersResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetOrdersResponse.Merge(m, src) -} -func (m *QueryGetOrdersResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetOrdersResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetOrdersResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetOrdersResponse proto.InternalMessageInfo - -func (m *QueryGetOrdersResponse) GetOrders() []*Order { - if m != nil { - return m.Orders - } - return nil -} - -type QueryGetOrderByIDRequest struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_address"` - PriceDenom string `protobuf:"bytes,2,opt,name=priceDenom,proto3" json:"price_denom"` - AssetDenom string `protobuf:"bytes,3,opt,name=assetDenom,proto3" json:"asset_denom"` - Id uint64 `protobuf:"varint,4,opt,name=id,proto3" json:"id"` -} - -func (m *QueryGetOrderByIDRequest) Reset() { *m = QueryGetOrderByIDRequest{} } -func (m *QueryGetOrderByIDRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetOrderByIDRequest) ProtoMessage() {} -func (*QueryGetOrderByIDRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{28} -} -func (m *QueryGetOrderByIDRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetOrderByIDRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetOrderByIDRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetOrderByIDRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetOrderByIDRequest.Merge(m, src) -} -func (m *QueryGetOrderByIDRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetOrderByIDRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetOrderByIDRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetOrderByIDRequest proto.InternalMessageInfo - -func (m *QueryGetOrderByIDRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryGetOrderByIDRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryGetOrderByIDRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -func (m *QueryGetOrderByIDRequest) GetId() uint64 { - if m != nil { - return m.Id - } - return 0 -} - -type QueryGetOrderByIDResponse struct { - Order *Order `protobuf:"bytes,1,opt,name=order,proto3" json:"order"` -} - -func (m *QueryGetOrderByIDResponse) Reset() { *m = QueryGetOrderByIDResponse{} } -func (m *QueryGetOrderByIDResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetOrderByIDResponse) ProtoMessage() {} -func (*QueryGetOrderByIDResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{29} -} -func (m *QueryGetOrderByIDResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetOrderByIDResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetOrderByIDResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetOrderByIDResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetOrderByIDResponse.Merge(m, src) -} -func (m *QueryGetOrderByIDResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetOrderByIDResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetOrderByIDResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetOrderByIDResponse proto.InternalMessageInfo - -func (m *QueryGetOrderByIDResponse) GetOrder() *Order { - if m != nil { - return m.Order - } - return nil -} - -type QueryGetHistoricalPricesRequest struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_address"` - PriceDenom string `protobuf:"bytes,2,opt,name=priceDenom,proto3" json:"price_denom"` - AssetDenom string `protobuf:"bytes,3,opt,name=assetDenom,proto3" json:"asset_denom"` - PeriodLengthInSeconds uint64 `protobuf:"varint,4,opt,name=periodLengthInSeconds,proto3" json:"period_length_in_seconds"` - NumOfPeriods uint64 `protobuf:"varint,5,opt,name=numOfPeriods,proto3" json:"number_of_periods"` -} - -func (m *QueryGetHistoricalPricesRequest) Reset() { *m = QueryGetHistoricalPricesRequest{} } -func (m *QueryGetHistoricalPricesRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetHistoricalPricesRequest) ProtoMessage() {} -func (*QueryGetHistoricalPricesRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{30} -} -func (m *QueryGetHistoricalPricesRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetHistoricalPricesRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetHistoricalPricesRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetHistoricalPricesRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetHistoricalPricesRequest.Merge(m, src) -} -func (m *QueryGetHistoricalPricesRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetHistoricalPricesRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetHistoricalPricesRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetHistoricalPricesRequest proto.InternalMessageInfo - -func (m *QueryGetHistoricalPricesRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryGetHistoricalPricesRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryGetHistoricalPricesRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -func (m *QueryGetHistoricalPricesRequest) GetPeriodLengthInSeconds() uint64 { - if m != nil { - return m.PeriodLengthInSeconds - } - return 0 -} - -func (m *QueryGetHistoricalPricesRequest) GetNumOfPeriods() uint64 { - if m != nil { - return m.NumOfPeriods - } - return 0 -} - -type QueryGetHistoricalPricesResponse struct { - Prices []*PriceCandlestick `protobuf:"bytes,1,rep,name=prices,proto3" json:"prices"` -} - -func (m *QueryGetHistoricalPricesResponse) Reset() { *m = QueryGetHistoricalPricesResponse{} } -func (m *QueryGetHistoricalPricesResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetHistoricalPricesResponse) ProtoMessage() {} -func (*QueryGetHistoricalPricesResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{31} -} -func (m *QueryGetHistoricalPricesResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetHistoricalPricesResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetHistoricalPricesResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetHistoricalPricesResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetHistoricalPricesResponse.Merge(m, src) -} -func (m *QueryGetHistoricalPricesResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetHistoricalPricesResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetHistoricalPricesResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetHistoricalPricesResponse proto.InternalMessageInfo - -func (m *QueryGetHistoricalPricesResponse) GetPrices() []*PriceCandlestick { - if m != nil { - return m.Prices - } - return nil -} - -type QueryGetMarketSummaryRequest struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_address"` - PriceDenom string `protobuf:"bytes,2,opt,name=priceDenom,proto3" json:"price_denom"` - AssetDenom string `protobuf:"bytes,3,opt,name=assetDenom,proto3" json:"asset_denom"` - LookbackInSeconds uint64 `protobuf:"varint,4,opt,name=lookbackInSeconds,proto3" json:"lookback_in_seconds"` -} - -func (m *QueryGetMarketSummaryRequest) Reset() { *m = QueryGetMarketSummaryRequest{} } -func (m *QueryGetMarketSummaryRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetMarketSummaryRequest) ProtoMessage() {} -func (*QueryGetMarketSummaryRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{32} -} -func (m *QueryGetMarketSummaryRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetMarketSummaryRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetMarketSummaryRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetMarketSummaryRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetMarketSummaryRequest.Merge(m, src) -} -func (m *QueryGetMarketSummaryRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetMarketSummaryRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetMarketSummaryRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetMarketSummaryRequest proto.InternalMessageInfo - -func (m *QueryGetMarketSummaryRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryGetMarketSummaryRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryGetMarketSummaryRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -func (m *QueryGetMarketSummaryRequest) GetLookbackInSeconds() uint64 { - if m != nil { - return m.LookbackInSeconds - } - return 0 -} - -type QueryGetMarketSummaryResponse struct { - TotalVolume *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,1,opt,name=totalVolume,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"total_volume"` - TotalVolumeNotional *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,2,opt,name=totalVolumeNotional,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"total_volume_notional"` - HighPrice *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,3,opt,name=highPrice,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"high_price"` - LowPrice *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,4,opt,name=lowPrice,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"low_price"` - LastPrice *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,5,opt,name=lastPrice,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"last_price"` -} - -func (m *QueryGetMarketSummaryResponse) Reset() { *m = QueryGetMarketSummaryResponse{} } -func (m *QueryGetMarketSummaryResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetMarketSummaryResponse) ProtoMessage() {} -func (*QueryGetMarketSummaryResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{33} -} -func (m *QueryGetMarketSummaryResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetMarketSummaryResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetMarketSummaryResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetMarketSummaryResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetMarketSummaryResponse.Merge(m, src) -} -func (m *QueryGetMarketSummaryResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetMarketSummaryResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetMarketSummaryResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetMarketSummaryResponse proto.InternalMessageInfo - -type QueryOrderSimulationRequest struct { - Order *Order `protobuf:"bytes,1,opt,name=order,proto3" json:"order"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contract_address"` -} - -func (m *QueryOrderSimulationRequest) Reset() { *m = QueryOrderSimulationRequest{} } -func (m *QueryOrderSimulationRequest) String() string { return proto.CompactTextString(m) } -func (*QueryOrderSimulationRequest) ProtoMessage() {} -func (*QueryOrderSimulationRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{34} -} -func (m *QueryOrderSimulationRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryOrderSimulationRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryOrderSimulationRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryOrderSimulationRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryOrderSimulationRequest.Merge(m, src) -} -func (m *QueryOrderSimulationRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryOrderSimulationRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryOrderSimulationRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryOrderSimulationRequest proto.InternalMessageInfo - -func (m *QueryOrderSimulationRequest) GetOrder() *Order { - if m != nil { - return m.Order - } - return nil -} - -func (m *QueryOrderSimulationRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -type QueryOrderSimulationResponse struct { - ExecutedQuantity *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,1,opt,name=ExecutedQuantity,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"executed_quantity"` -} - -func (m *QueryOrderSimulationResponse) Reset() { *m = QueryOrderSimulationResponse{} } -func (m *QueryOrderSimulationResponse) String() string { return proto.CompactTextString(m) } -func (*QueryOrderSimulationResponse) ProtoMessage() {} -func (*QueryOrderSimulationResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{35} -} -func (m *QueryOrderSimulationResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryOrderSimulationResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryOrderSimulationResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryOrderSimulationResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryOrderSimulationResponse.Merge(m, src) -} -func (m *QueryOrderSimulationResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryOrderSimulationResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryOrderSimulationResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryOrderSimulationResponse proto.InternalMessageInfo - -type QueryGetMatchResultRequest struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_address"` -} - -func (m *QueryGetMatchResultRequest) Reset() { *m = QueryGetMatchResultRequest{} } -func (m *QueryGetMatchResultRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetMatchResultRequest) ProtoMessage() {} -func (*QueryGetMatchResultRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{36} -} -func (m *QueryGetMatchResultRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetMatchResultRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetMatchResultRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetMatchResultRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetMatchResultRequest.Merge(m, src) -} -func (m *QueryGetMatchResultRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetMatchResultRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetMatchResultRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetMatchResultRequest proto.InternalMessageInfo - -func (m *QueryGetMatchResultRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -type QueryGetMatchResultResponse struct { - Result *MatchResult `protobuf:"bytes,1,opt,name=result,proto3" json:"result"` -} - -func (m *QueryGetMatchResultResponse) Reset() { *m = QueryGetMatchResultResponse{} } -func (m *QueryGetMatchResultResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetMatchResultResponse) ProtoMessage() {} -func (*QueryGetMatchResultResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{37} -} -func (m *QueryGetMatchResultResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetMatchResultResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetMatchResultResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetMatchResultResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetMatchResultResponse.Merge(m, src) -} -func (m *QueryGetMatchResultResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetMatchResultResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetMatchResultResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetMatchResultResponse proto.InternalMessageInfo - -func (m *QueryGetMatchResultResponse) GetResult() *MatchResult { - if m != nil { - return m.Result - } - return nil -} - -type QueryGetOrderCountRequest struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_address"` - PriceDenom string `protobuf:"bytes,2,opt,name=priceDenom,proto3" json:"price_denom"` - AssetDenom string `protobuf:"bytes,3,opt,name=assetDenom,proto3" json:"asset_denom"` - Price *github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,4,opt,name=price,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"price"` - PositionDirection PositionDirection `protobuf:"varint,5,opt,name=positionDirection,proto3,enum=seiprotocol.seichain.dex.PositionDirection" json:"position_direction"` -} - -func (m *QueryGetOrderCountRequest) Reset() { *m = QueryGetOrderCountRequest{} } -func (m *QueryGetOrderCountRequest) String() string { return proto.CompactTextString(m) } -func (*QueryGetOrderCountRequest) ProtoMessage() {} -func (*QueryGetOrderCountRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{38} -} -func (m *QueryGetOrderCountRequest) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetOrderCountRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetOrderCountRequest.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetOrderCountRequest) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetOrderCountRequest.Merge(m, src) -} -func (m *QueryGetOrderCountRequest) XXX_Size() int { - return m.Size() -} -func (m *QueryGetOrderCountRequest) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetOrderCountRequest.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetOrderCountRequest proto.InternalMessageInfo - -func (m *QueryGetOrderCountRequest) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *QueryGetOrderCountRequest) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *QueryGetOrderCountRequest) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -func (m *QueryGetOrderCountRequest) GetPositionDirection() PositionDirection { - if m != nil { - return m.PositionDirection - } - return PositionDirection_LONG -} - -type QueryGetOrderCountResponse struct { - Count uint64 `protobuf:"varint,1,opt,name=count,proto3" json:"count"` -} - -func (m *QueryGetOrderCountResponse) Reset() { *m = QueryGetOrderCountResponse{} } -func (m *QueryGetOrderCountResponse) String() string { return proto.CompactTextString(m) } -func (*QueryGetOrderCountResponse) ProtoMessage() {} -func (*QueryGetOrderCountResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_d8e98105e6e08a59, []int{39} -} -func (m *QueryGetOrderCountResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *QueryGetOrderCountResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_QueryGetOrderCountResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *QueryGetOrderCountResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_QueryGetOrderCountResponse.Merge(m, src) -} -func (m *QueryGetOrderCountResponse) XXX_Size() int { - return m.Size() -} -func (m *QueryGetOrderCountResponse) XXX_DiscardUnknown() { - xxx_messageInfo_QueryGetOrderCountResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_QueryGetOrderCountResponse proto.InternalMessageInfo - -func (m *QueryGetOrderCountResponse) GetCount() uint64 { - if m != nil { - return m.Count - } - return 0 -} - -func init() { - proto.RegisterType((*QueryParamsRequest)(nil), "seiprotocol.seichain.dex.QueryParamsRequest") - proto.RegisterType((*QueryParamsResponse)(nil), "seiprotocol.seichain.dex.QueryParamsResponse") - proto.RegisterType((*QueryGetLongBookRequest)(nil), "seiprotocol.seichain.dex.QueryGetLongBookRequest") - proto.RegisterType((*QueryGetLongBookResponse)(nil), "seiprotocol.seichain.dex.QueryGetLongBookResponse") - proto.RegisterType((*QueryAllLongBookRequest)(nil), "seiprotocol.seichain.dex.QueryAllLongBookRequest") - proto.RegisterType((*QueryAllLongBookResponse)(nil), "seiprotocol.seichain.dex.QueryAllLongBookResponse") - proto.RegisterType((*QueryGetShortBookRequest)(nil), "seiprotocol.seichain.dex.QueryGetShortBookRequest") - proto.RegisterType((*QueryGetShortBookResponse)(nil), "seiprotocol.seichain.dex.QueryGetShortBookResponse") - proto.RegisterType((*QueryAllShortBookRequest)(nil), "seiprotocol.seichain.dex.QueryAllShortBookRequest") - proto.RegisterType((*QueryAllShortBookResponse)(nil), "seiprotocol.seichain.dex.QueryAllShortBookResponse") - proto.RegisterType((*QueryGetPricesRequest)(nil), "seiprotocol.seichain.dex.QueryGetPricesRequest") - proto.RegisterType((*QueryGetPricesResponse)(nil), "seiprotocol.seichain.dex.QueryGetPricesResponse") - proto.RegisterType((*QueryGetPriceRequest)(nil), "seiprotocol.seichain.dex.QueryGetPriceRequest") - proto.RegisterType((*QueryGetPriceResponse)(nil), "seiprotocol.seichain.dex.QueryGetPriceResponse") - proto.RegisterType((*QueryGetLatestPriceRequest)(nil), "seiprotocol.seichain.dex.QueryGetLatestPriceRequest") - proto.RegisterType((*QueryGetLatestPriceResponse)(nil), "seiprotocol.seichain.dex.QueryGetLatestPriceResponse") - proto.RegisterType((*QueryGetTwapsRequest)(nil), "seiprotocol.seichain.dex.QueryGetTwapsRequest") - proto.RegisterType((*QueryGetTwapsResponse)(nil), "seiprotocol.seichain.dex.QueryGetTwapsResponse") - proto.RegisterType((*QueryAssetListRequest)(nil), "seiprotocol.seichain.dex.QueryAssetListRequest") - proto.RegisterType((*QueryAssetListResponse)(nil), "seiprotocol.seichain.dex.QueryAssetListResponse") - proto.RegisterType((*QueryAssetMetadataRequest)(nil), "seiprotocol.seichain.dex.QueryAssetMetadataRequest") - proto.RegisterType((*QueryAssetMetadataResponse)(nil), "seiprotocol.seichain.dex.QueryAssetMetadataResponse") - proto.RegisterType((*QueryRegisteredPairsRequest)(nil), "seiprotocol.seichain.dex.QueryRegisteredPairsRequest") - proto.RegisterType((*QueryRegisteredPairsResponse)(nil), "seiprotocol.seichain.dex.QueryRegisteredPairsResponse") - proto.RegisterType((*QueryRegisteredContractRequest)(nil), "seiprotocol.seichain.dex.QueryRegisteredContractRequest") - proto.RegisterType((*QueryRegisteredContractResponse)(nil), "seiprotocol.seichain.dex.QueryRegisteredContractResponse") - proto.RegisterType((*QueryGetOrdersRequest)(nil), "seiprotocol.seichain.dex.QueryGetOrdersRequest") - proto.RegisterType((*QueryGetOrdersResponse)(nil), "seiprotocol.seichain.dex.QueryGetOrdersResponse") - proto.RegisterType((*QueryGetOrderByIDRequest)(nil), "seiprotocol.seichain.dex.QueryGetOrderByIDRequest") - proto.RegisterType((*QueryGetOrderByIDResponse)(nil), "seiprotocol.seichain.dex.QueryGetOrderByIDResponse") - proto.RegisterType((*QueryGetHistoricalPricesRequest)(nil), "seiprotocol.seichain.dex.QueryGetHistoricalPricesRequest") - proto.RegisterType((*QueryGetHistoricalPricesResponse)(nil), "seiprotocol.seichain.dex.QueryGetHistoricalPricesResponse") - proto.RegisterType((*QueryGetMarketSummaryRequest)(nil), "seiprotocol.seichain.dex.QueryGetMarketSummaryRequest") - proto.RegisterType((*QueryGetMarketSummaryResponse)(nil), "seiprotocol.seichain.dex.QueryGetMarketSummaryResponse") - proto.RegisterType((*QueryOrderSimulationRequest)(nil), "seiprotocol.seichain.dex.QueryOrderSimulationRequest") - proto.RegisterType((*QueryOrderSimulationResponse)(nil), "seiprotocol.seichain.dex.QueryOrderSimulationResponse") - proto.RegisterType((*QueryGetMatchResultRequest)(nil), "seiprotocol.seichain.dex.QueryGetMatchResultRequest") - proto.RegisterType((*QueryGetMatchResultResponse)(nil), "seiprotocol.seichain.dex.QueryGetMatchResultResponse") - proto.RegisterType((*QueryGetOrderCountRequest)(nil), "seiprotocol.seichain.dex.QueryGetOrderCountRequest") - proto.RegisterType((*QueryGetOrderCountResponse)(nil), "seiprotocol.seichain.dex.QueryGetOrderCountResponse") -} - -func init() { proto.RegisterFile("dex/query.proto", fileDescriptor_d8e98105e6e08a59) } - -var fileDescriptor_d8e98105e6e08a59 = []byte{ - // 2281 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xd4, 0x59, 0xcb, 0x6f, 0x1c, 0x49, - 0x1d, 0x76, 0x8f, 0x63, 0x63, 0x97, 0xf3, 0x2c, 0xdb, 0x89, 0x19, 0xc2, 0x4c, 0xa8, 0x55, 0x36, - 0xcb, 0x2e, 0x9e, 0x26, 0x4e, 0xb2, 0x79, 0x48, 0x9b, 0x6c, 0xc6, 0xce, 0x1a, 0x8b, 0x38, 0x71, - 0xda, 0x89, 0x37, 0x84, 0x0d, 0xbd, 0xe5, 0xe9, 0xf2, 0x4c, 0xe3, 0x9e, 0xae, 0x49, 0x77, 0xcf, - 0xc6, 0x96, 0x19, 0xf1, 0x12, 0x17, 0xb8, 0x44, 0x5a, 0x0e, 0xec, 0x81, 0x3f, 0x00, 0x09, 0x0e, - 0x5c, 0xd0, 0x8a, 0x3b, 0xab, 0x95, 0x40, 0x4b, 0xa4, 0x05, 0x09, 0x81, 0x34, 0x42, 0x09, 0xa7, - 0xb9, 0x23, 0xc4, 0x6d, 0xd5, 0x55, 0xd5, 0xef, 0x19, 0x77, 0x77, 0x1c, 0xad, 0xb2, 0xa7, 0xf6, - 0x54, 0xd7, 0xf7, 0xab, 0xdf, 0xf7, 0xd5, 0xaf, 0x1e, 0xfd, 0x19, 0x1c, 0xd2, 0xc8, 0x96, 0xfc, - 0xa0, 0x4d, 0xac, 0xed, 0x4a, 0xcb, 0xa2, 0x0e, 0x85, 0x33, 0x36, 0xd1, 0xd9, 0x5f, 0x35, 0x6a, - 0x54, 0x6c, 0xa2, 0xd7, 0x1a, 0x58, 0x37, 0x2b, 0x1a, 0xd9, 0x2a, 0x4e, 0xd5, 0x69, 0x9d, 0xb2, - 0x57, 0xb2, 0xfb, 0x17, 0xef, 0x5f, 0x3c, 0x5e, 0xa7, 0xb4, 0x6e, 0x10, 0x19, 0xb7, 0x74, 0x19, - 0x9b, 0x26, 0x75, 0xb0, 0xa3, 0x53, 0xd3, 0x16, 0x6f, 0x5f, 0xad, 0x51, 0xbb, 0x49, 0x6d, 0x79, - 0x1d, 0xdb, 0x84, 0x0f, 0x23, 0xbf, 0x77, 0x7a, 0x9d, 0x38, 0xf8, 0xb4, 0xdc, 0xc2, 0x75, 0xdd, - 0x64, 0x9d, 0x45, 0xdf, 0xc3, 0x6e, 0x2a, 0x2d, 0x6c, 0xe1, 0xa6, 0x87, 0x9e, 0x74, 0x5b, 0x0c, - 0x6a, 0xd6, 0xd5, 0x75, 0x4a, 0x37, 0x45, 0xe3, 0x94, 0xdb, 0x68, 0x37, 0xa8, 0xe5, 0x84, 0x5b, - 0x19, 0x8f, 0x96, 0xa5, 0xd7, 0x88, 0x68, 0x80, 0x6e, 0x43, 0x8d, 0x9a, 0x8e, 0x85, 0x6b, 0x8e, - 0x68, 0x3b, 0xe8, 0xb6, 0x39, 0x0f, 0x71, 0x2b, 0x1c, 0x0a, 0xdb, 0x36, 0x71, 0x54, 0x43, 0xb7, - 0x23, 0xbd, 0x5a, 0x58, 0xb7, 0xc2, 0xa1, 0xa9, 0xa5, 0x11, 0xaf, 0xe1, 0xa8, 0xdb, 0xd0, 0xc4, - 0x4e, 0xad, 0xa1, 0x5a, 0xc4, 0x6e, 0x1b, 0x4e, 0xb8, 0x23, 0x31, 0xdb, 0x5e, 0xfe, 0x68, 0x0a, - 0xc0, 0x5b, 0x2e, 0xe7, 0x15, 0x46, 0x4a, 0x21, 0x0f, 0xda, 0xc4, 0x76, 0xd0, 0x1d, 0x30, 0x19, - 0x69, 0xb5, 0x5b, 0xd4, 0xb4, 0x09, 0xbc, 0x0c, 0x46, 0x39, 0xf9, 0x19, 0xe9, 0x84, 0xf4, 0xca, - 0xc4, 0xdc, 0x89, 0xca, 0xa0, 0x99, 0xa8, 0x70, 0x64, 0x75, 0xdf, 0xc7, 0xdd, 0xf2, 0x90, 0x22, - 0x50, 0xe8, 0x7d, 0x09, 0x1c, 0x63, 0x71, 0x17, 0x89, 0x73, 0x9d, 0x9a, 0xf5, 0x2a, 0xa5, 0x9b, - 0x62, 0x48, 0x38, 0x05, 0x46, 0x98, 0x36, 0x2c, 0xf4, 0xb8, 0xc2, 0x7f, 0x40, 0x04, 0xf6, 0x7b, - 0x02, 0x5d, 0xd5, 0x34, 0x6b, 0xa6, 0xc0, 0x5e, 0x46, 0xda, 0x60, 0x09, 0x00, 0xd6, 0x79, 0x81, - 0x98, 0xb4, 0x39, 0x33, 0xcc, 0x7a, 0x84, 0x5a, 0xdc, 0xf7, 0x4c, 0x40, 0xfe, 0x7e, 0x1f, 0x7f, - 0x1f, 0xb4, 0xa0, 0x77, 0xc1, 0x4c, 0x32, 0x29, 0xc1, 0x78, 0x01, 0x8c, 0x79, 0x6d, 0x82, 0x33, - 0x1a, 0xcc, 0xd9, 0xeb, 0x29, 0x58, 0xfb, 0x48, 0xf4, 0x27, 0x8f, 0xf7, 0x55, 0xc3, 0x88, 0xf3, - 0x7e, 0x0b, 0x80, 0xa0, 0xcc, 0xc4, 0x18, 0x2f, 0x57, 0x78, 0x4d, 0x56, 0xdc, 0x9a, 0xac, 0xf0, - 0xd2, 0x17, 0x35, 0x59, 0x59, 0xc1, 0x75, 0x22, 0xb0, 0x4a, 0x08, 0xf9, 0xb9, 0x28, 0xf5, 0x1b, - 0x49, 0x48, 0x15, 0xe1, 0xd1, 0x57, 0xaa, 0xe1, 0x67, 0x93, 0x0a, 0x2e, 0x46, 0xe4, 0x28, 0x30, - 0x39, 0x4e, 0xa5, 0xca, 0xc1, 0x53, 0x08, 0xeb, 0x81, 0x7e, 0x29, 0x05, 0xd3, 0xba, 0xea, 0x2e, - 0xc5, 0x17, 0xa3, 0xd8, 0x34, 0xf0, 0xe5, 0x3e, 0x59, 0x09, 0x09, 0x17, 0xc1, 0xb8, 0xdf, 0x28, - 0x4a, 0xe1, 0xa5, 0xc1, 0x1a, 0xfa, 0x5d, 0x85, 0x88, 0x01, 0x16, 0x7d, 0x14, 0x9a, 0xa8, 0x04, - 0xf9, 0x2f, 0x52, 0xc5, 0xfd, 0x4e, 0x12, 0x7a, 0x45, 0x89, 0xf4, 0xd7, 0x6b, 0xf8, 0x59, 0xf5, - 0x7a, 0x7e, 0x55, 0xb7, 0x03, 0xa6, 0xbd, 0xe9, 0x5d, 0x71, 0x59, 0x7a, 0x3b, 0x6a, 0x4c, 0x08, - 0x29, 0x45, 0x88, 0x42, 0x5c, 0x88, 0x84, 0xd8, 0xc3, 0x49, 0xb1, 0xd1, 0x2d, 0x70, 0x34, 0x3e, - 0xb8, 0x10, 0xea, 0x3c, 0x18, 0x65, 0x63, 0xd9, 0x42, 0xa5, 0xf2, 0x2e, 0x1b, 0xb7, 0xdb, 0x4f, - 0x11, 0xdd, 0xd1, 0xaf, 0x24, 0x30, 0x15, 0x89, 0xf9, 0x39, 0xf2, 0x81, 0xc7, 0xc1, 0xb8, 0xa3, - 0x37, 0x89, 0xed, 0xe0, 0x66, 0x8b, 0xd5, 0xc6, 0x3e, 0x25, 0x68, 0x40, 0x5a, 0x4c, 0x6a, 0x9f, - 0xec, 0xb9, 0xf0, 0xe2, 0xce, 0xc0, 0x55, 0xac, 0xfe, 0x29, 0x30, 0xb2, 0x41, 0xdb, 0xa6, 0xc6, - 0x92, 0x1d, 0x53, 0xf8, 0x0f, 0xf4, 0xa1, 0x04, 0x8a, 0xfe, 0xe9, 0x80, 0x1d, 0x62, 0x47, 0x65, - 0x90, 0x93, 0x32, 0x54, 0x0f, 0xf5, 0xba, 0xe5, 0x09, 0xd6, 0xaa, 0x6a, 0x6e, 0x73, 0x44, 0x17, - 0x39, 0xa9, 0x0b, 0x07, 0xf0, 0x33, 0x5e, 0x00, 0x42, 0x42, 0x5d, 0xe8, 0x27, 0x54, 0x75, 0xaa, - 0xd7, 0x2d, 0x1f, 0xf6, 0xda, 0x55, 0xac, 0x69, 0x16, 0xb1, 0xed, 0x58, 0x39, 0xdc, 0x06, 0x5f, - 0xe9, 0x9b, 0xf9, 0x9e, 0x64, 0x42, 0x8f, 0x42, 0x15, 0x71, 0xfb, 0x21, 0x6e, 0xf9, 0x15, 0x1e, - 0x4f, 0x54, 0xca, 0x9a, 0x28, 0xbc, 0x0c, 0x0e, 0x19, 0x94, 0x6e, 0xae, 0xe3, 0xda, 0xe6, 0x2a, - 0xa9, 0x51, 0x53, 0xb3, 0x99, 0x30, 0xfb, 0x38, 0xd8, 0x7b, 0xa5, 0xda, 0xfc, 0x9d, 0x12, 0xef, - 0x8c, 0xee, 0x06, 0x95, 0x20, 0x32, 0x12, 0x14, 0xaf, 0x80, 0x11, 0xf7, 0x2a, 0xe5, 0x55, 0x7d, - 0x69, 0x30, 0x45, 0x17, 0x57, 0x1d, 0xef, 0x75, 0xcb, 0x1c, 0xa0, 0xf0, 0x07, 0x3a, 0x26, 0x22, - 0x5f, 0x75, 0xe7, 0xe3, 0xba, 0x6e, 0x3b, 0xde, 0x05, 0x89, 0x88, 0xa5, 0x16, 0x7a, 0x21, 0xc6, - 0xfc, 0x36, 0x18, 0xc7, 0x5e, 0xa3, 0x18, 0xf7, 0xd4, 0xe0, 0x71, 0x19, 0x7e, 0x99, 0x38, 0x58, - 0xc3, 0x0e, 0xf6, 0xf6, 0x25, 0x1f, 0x8f, 0x4e, 0x7b, 0xbb, 0x5f, 0xb8, 0x5b, 0xe8, 0x10, 0xd3, - 0x42, 0xab, 0x8f, 0xff, 0x40, 0x58, 0xd4, 0x6b, 0x0c, 0x22, 0xb2, 0x9b, 0x07, 0x63, 0x4d, 0xd1, - 0x26, 0xe6, 0x3d, 0x6b, 0x72, 0x8a, 0x0f, 0x44, 0x6f, 0x8b, 0xc2, 0x52, 0x48, 0x5d, 0xb7, 0x1d, - 0x62, 0x11, 0x6d, 0x05, 0xeb, 0xd6, 0xde, 0x0b, 0x01, 0xdd, 0x03, 0xc7, 0xfb, 0x07, 0x16, 0xd9, - 0x5f, 0x02, 0x23, 0xee, 0xa5, 0x37, 0xc3, 0x7c, 0xba, 0x38, 0x21, 0x27, 0x87, 0xa0, 0x7b, 0xa0, - 0x14, 0x8b, 0x3d, 0x2f, 0x86, 0xde, 0x7b, 0xde, 0x2d, 0x50, 0x1e, 0x18, 0x5b, 0xa4, 0xbe, 0x0c, - 0x0e, 0xf8, 0x41, 0x74, 0x73, 0x83, 0x0a, 0xf5, 0x5f, 0x19, 0x4c, 0xc1, 0x0b, 0xb1, 0x64, 0x6e, - 0xd0, 0xb5, 0xb9, 0x60, 0x44, 0xf7, 0x37, 0xda, 0x0a, 0x4a, 0xfe, 0xa6, 0x7b, 0xed, 0x7f, 0x0e, - 0xab, 0xf0, 0x24, 0xf8, 0x12, 0xae, 0xd5, 0x68, 0xdb, 0x74, 0xc4, 0xb6, 0x34, 0xd1, 0xeb, 0x96, - 0xbd, 0x26, 0xc5, 0xfb, 0x03, 0xdd, 0x0f, 0x0e, 0x19, 0x6f, 0x64, 0xbf, 0xb6, 0x46, 0xd9, 0x27, - 0x48, 0x86, 0x43, 0x86, 0x21, 0xab, 0xa0, 0xd7, 0x2d, 0x0b, 0x88, 0x22, 0x9e, 0xe8, 0x93, 0xd0, - 0xb5, 0x8d, 0xf7, 0xda, 0x5e, 0x5a, 0xd8, 0x3b, 0xb9, 0xe8, 0x3e, 0x5d, 0xc8, 0xbb, 0x4f, 0x0f, - 0xa7, 0xef, 0xd3, 0x47, 0x41, 0x41, 0xd7, 0xf8, 0x29, 0x55, 0x1d, 0xed, 0x75, 0xcb, 0x05, 0x5d, - 0x53, 0x0a, 0xba, 0x86, 0xee, 0x07, 0x17, 0xbe, 0x10, 0x1f, 0x21, 0xd9, 0x9b, 0x60, 0x84, 0xf1, - 0x4e, 0xdf, 0x83, 0x39, 0x96, 0xed, 0x50, 0x0c, 0xa1, 0xf0, 0x07, 0xfa, 0x4b, 0x41, 0xd4, 0xde, - 0x22, 0x71, 0xbe, 0xa5, 0xdb, 0x0e, 0xb5, 0xf4, 0x1a, 0x36, 0xa2, 0x77, 0x8f, 0x17, 0x59, 0x36, - 0x05, 0x4c, 0xb7, 0x88, 0xa5, 0x53, 0xed, 0x3a, 0x31, 0xeb, 0x4e, 0x63, 0xc9, 0xf4, 0x4e, 0x00, - 0xae, 0xe4, 0xf1, 0x5e, 0xb7, 0x3c, 0xc3, 0x3b, 0xa8, 0x06, 0xeb, 0xa1, 0xea, 0xa6, 0x7f, 0x12, - 0xf4, 0x87, 0xc2, 0x8b, 0x60, 0xbf, 0xd9, 0x6e, 0xde, 0xdc, 0x58, 0x61, 0x6f, 0xed, 0x99, 0x11, - 0x16, 0x6a, 0xba, 0xd7, 0x2d, 0x1f, 0x31, 0xdb, 0xcd, 0x75, 0x62, 0xa9, 0x74, 0x43, 0xe5, 0x50, - 0x5b, 0x89, 0x74, 0x45, 0x16, 0x38, 0x31, 0x58, 0x4d, 0x31, 0x69, 0x37, 0x62, 0x97, 0xa9, 0x57, - 0x53, 0x4e, 0xce, 0x79, 0x6c, 0x6a, 0x06, 0xb1, 0x1d, 0xbd, 0xb6, 0xc9, 0x4b, 0x9e, 0xa3, 0xfd, - 0x3b, 0xd6, 0x8f, 0x0b, 0x62, 0xdb, 0x5b, 0x24, 0xce, 0x32, 0xb6, 0x36, 0x89, 0xb3, 0xda, 0x6e, - 0x36, 0xb1, 0xbb, 0x9d, 0xbc, 0xf8, 0xf3, 0x77, 0x0d, 0x1c, 0xf1, 0x8e, 0xe3, 0xf8, 0xdc, 0x1d, - 0xeb, 0x75, 0xcb, 0x93, 0xfe, 0xe9, 0x1d, 0x9a, 0xb6, 0x24, 0x02, 0xfd, 0x7f, 0x18, 0x7c, 0x75, - 0x80, 0x06, 0x42, 0xf5, 0x77, 0xc0, 0x84, 0x43, 0x1d, 0x6c, 0xac, 0x51, 0xa3, 0xdd, 0x14, 0x1f, - 0x6e, 0xd5, 0x4b, 0xff, 0xec, 0x96, 0x5f, 0xae, 0xeb, 0x4e, 0xa3, 0xbd, 0x5e, 0xa9, 0xd1, 0xa6, - 0x2c, 0xac, 0x1c, 0xfe, 0x98, 0xb5, 0xb5, 0x4d, 0xd9, 0xd9, 0x6e, 0x11, 0xbb, 0xb2, 0x40, 0x6a, - 0xbd, 0x6e, 0x79, 0x3f, 0x0b, 0xa0, 0xbe, 0xc7, 0x22, 0x28, 0xe1, 0x70, 0xb0, 0x0d, 0x26, 0x43, - 0x3f, 0x6f, 0x50, 0xf7, 0x32, 0x8f, 0x0d, 0xa1, 0xd8, 0x7c, 0xae, 0x51, 0xa6, 0xc3, 0xa3, 0xa8, - 0xa6, 0x08, 0xa5, 0xf4, 0x8b, 0x0f, 0xd7, 0xc0, 0x78, 0x43, 0xaf, 0x37, 0x58, 0x99, 0x08, 0xb5, - 0x2f, 0xe4, 0x1a, 0x0c, 0xb8, 0x70, 0x95, 0x4d, 0xa0, 0x12, 0x84, 0x82, 0xab, 0x60, 0xcc, 0xa0, - 0x0f, 0x79, 0x58, 0xf6, 0x51, 0x55, 0x3d, 0x9f, 0x2b, 0xec, 0xb8, 0x41, 0x1f, 0x8a, 0xa8, 0x7e, - 0x20, 0x37, 0x59, 0x03, 0x8b, 0x5b, 0x24, 0x5b, 0x53, 0xb9, 0x93, 0x75, 0xe1, 0x5e, 0xb2, 0x7e, - 0x28, 0xf4, 0x81, 0x24, 0xee, 0x13, 0x6c, 0x8f, 0x5b, 0xd5, 0x9b, 0x6d, 0x83, 0x7d, 0x4c, 0x79, - 0xe5, 0xbf, 0xe7, 0x4d, 0x32, 0xb1, 0x80, 0x0a, 0x99, 0x4f, 0xf6, 0x5f, 0x48, 0x62, 0x6d, 0x26, - 0x72, 0x13, 0x65, 0xb9, 0x09, 0x0e, 0x5f, 0xdb, 0x22, 0xb5, 0xb6, 0x43, 0xb4, 0x5b, 0x6d, 0x6c, - 0x3a, 0xba, 0xb3, 0x2d, 0x6a, 0xf3, 0x4a, 0x2e, 0x6d, 0x8e, 0x10, 0x11, 0x45, 0x7d, 0x20, 0xc2, - 0x28, 0x89, 0xc0, 0x68, 0x2d, 0xf8, 0x16, 0x59, 0xc6, 0x4e, 0xad, 0xa1, 0x30, 0x6b, 0x6f, 0xef, - 0xf7, 0x97, 0x46, 0xf0, 0xa5, 0x10, 0x89, 0x2b, 0x38, 0x2e, 0x81, 0x51, 0x6e, 0x22, 0x8a, 0x19, - 0x38, 0x39, 0x78, 0x06, 0x42, 0x70, 0xbe, 0xd7, 0x71, 0xa0, 0x22, 0x9e, 0xe8, 0xbf, 0x85, 0xd8, - 0x71, 0x38, 0xcf, 0x6e, 0x17, 0x5f, 0x80, 0x8d, 0x6e, 0xc9, 0xfb, 0x5c, 0xe2, 0xeb, 0xe9, 0x4c, - 0xae, 0xd9, 0xe5, 0x50, 0xef, 0x4b, 0xf3, 0x01, 0x38, 0xd2, 0xa2, 0xb6, 0xee, 0xd6, 0xd1, 0x82, - 0x6e, 0x91, 0x1a, 0x33, 0x1d, 0xdc, 0x05, 0x75, 0x70, 0xee, 0xb5, 0x5d, 0xce, 0x92, 0x38, 0xa4, - 0x7a, 0xb4, 0xd7, 0x2d, 0x43, 0x2f, 0x92, 0xaa, 0x79, 0xed, 0x4a, 0x32, 0x3a, 0x7a, 0x23, 0xa8, - 0x9c, 0xb0, 0xec, 0x62, 0x82, 0xcb, 0x60, 0x84, 0x5f, 0xfc, 0x24, 0xb6, 0x71, 0xb3, 0x05, 0xc4, - 0xaf, 0x7d, 0xfc, 0x31, 0xf7, 0xdb, 0x12, 0x18, 0x61, 0x78, 0xf8, 0x48, 0x02, 0xa3, 0xdc, 0xdb, - 0x85, 0xdf, 0x18, 0x9c, 0x6b, 0xd2, 0x52, 0x2e, 0xce, 0x66, 0xec, 0xcd, 0x53, 0x42, 0x5f, 0xff, - 0xc9, 0xa7, 0xff, 0x79, 0xbf, 0xf0, 0x12, 0xfc, 0x9a, 0x6c, 0x13, 0x7d, 0xd6, 0xc3, 0xc9, 0x1e, - 0x4e, 0x0e, 0x8c, 0x78, 0xf8, 0x58, 0x0a, 0x9c, 0x47, 0x78, 0x3a, 0x65, 0x98, 0xa4, 0xf3, 0x5c, - 0x9c, 0xcb, 0x03, 0x11, 0xe9, 0xdd, 0x67, 0xe9, 0xbd, 0x0d, 0xef, 0xec, 0x92, 0x9e, 0xff, 0x5f, - 0x01, 0x79, 0x27, 0x5c, 0xab, 0x1d, 0x79, 0x27, 0xa8, 0xc3, 0x8e, 0xbc, 0x13, 0xd4, 0x98, 0xf7, - 0xa6, 0x03, 0xff, 0x2c, 0x81, 0x09, 0x6f, 0xcc, 0xab, 0x86, 0x91, 0xca, 0x2a, 0xe9, 0x2b, 0xa7, - 0xb2, 0xea, 0x63, 0xe1, 0xa2, 0x3b, 0x8c, 0xd5, 0x4d, 0xb8, 0xfc, 0x5c, 0x59, 0xc1, 0xbf, 0x49, - 0x21, 0x9f, 0x0e, 0x66, 0x90, 0x3b, 0x6e, 0x59, 0x16, 0xcf, 0xe4, 0xc2, 0x08, 0x36, 0xdf, 0x63, - 0x6c, 0xee, 0xc2, 0xb5, 0x5d, 0xd8, 0x04, 0xff, 0xa4, 0xc9, 0x3f, 0x49, 0x7f, 0x95, 0xc0, 0x7e, - 0x7f, 0x54, 0x77, 0x96, 0x32, 0x48, 0x9e, 0x9b, 0x59, 0x3f, 0xdf, 0x13, 0xad, 0x31, 0x66, 0x2b, - 0xf0, 0xc6, 0xf3, 0x65, 0x06, 0x3f, 0x91, 0xc0, 0x98, 0x67, 0xa7, 0xc1, 0x4a, 0xba, 0xe6, 0x61, - 0x2b, 0xac, 0x28, 0x67, 0xee, 0x2f, 0x58, 0x60, 0xc6, 0xe2, 0xbb, 0xf0, 0x3b, 0xbb, 0xb0, 0xa8, - 0x13, 0x71, 0x61, 0xc8, 0x31, 0x3d, 0xbe, 0x45, 0xd8, 0x81, 0xff, 0x92, 0xc0, 0xc1, 0xa8, 0xfd, - 0x05, 0xcf, 0x66, 0x58, 0xed, 0x09, 0x9f, 0xaf, 0x78, 0x2e, 0x27, 0x4a, 0x50, 0x7c, 0x87, 0x51, - 0x5c, 0x83, 0xb7, 0x53, 0x28, 0x1a, 0x0c, 0x9b, 0x93, 0x29, 0xfc, 0x48, 0x02, 0xe3, 0xbe, 0xd7, - 0x0b, 0xb3, 0xea, 0xef, 0xef, 0xc8, 0xdf, 0xcc, 0x0e, 0xc8, 0x51, 0x77, 0xfe, 0x8c, 0xd9, 0xd9, - 0x89, 0xfc, 0x91, 0xd7, 0x1d, 0x33, 0xef, 0xb2, 0xd4, 0x5d, 0xd8, 0x77, 0xcc, 0x52, 0x77, 0x11, - 0x57, 0x10, 0x2d, 0x33, 0x16, 0x8b, 0xf0, 0x5a, 0x0a, 0x0b, 0x66, 0x01, 0x26, 0x48, 0xc4, 0xcc, - 0xc7, 0x0e, 0xfc, 0xbd, 0x04, 0x0e, 0x44, 0x9c, 0x32, 0x98, 0xba, 0xa6, 0xfb, 0xb8, 0x79, 0xc5, - 0xb3, 0xf9, 0x40, 0x82, 0xcb, 0x39, 0xc6, 0x45, 0x86, 0xb3, 0xbb, 0x70, 0x09, 0xfe, 0x7b, 0x2c, - 0xef, 0x68, 0x5c, 0xf0, 0x5f, 0x4b, 0x60, 0xdc, 0xb7, 0x2e, 0x53, 0x2b, 0x27, 0xee, 0x7e, 0xa6, - 0x56, 0x4e, 0xc2, 0x15, 0x45, 0xb3, 0x2c, 0xcf, 0x53, 0xf0, 0x64, 0xa6, 0x3c, 0xe1, 0x87, 0x12, - 0x80, 0x8b, 0xc4, 0x89, 0xf9, 0x80, 0x30, 0x6d, 0x15, 0xf6, 0x37, 0x24, 0x8b, 0xaf, 0xe7, 0x85, - 0x89, 0xa4, 0xcf, 0xb0, 0xa4, 0x67, 0xe1, 0x6b, 0xbb, 0x24, 0x6d, 0xf9, 0x58, 0x95, 0xf9, 0x8c, - 0xf0, 0x53, 0x09, 0x4c, 0x47, 0x52, 0xf7, 0x7c, 0x3c, 0x78, 0x21, 0x73, 0x1a, 0x31, 0x67, 0xb2, - 0x78, 0xf1, 0x19, 0x90, 0x82, 0xc3, 0x35, 0xc6, 0xe1, 0x0a, 0x7c, 0x23, 0x1b, 0x07, 0xaf, 0xd8, - 0x63, 0x65, 0x0f, 0xff, 0xc0, 0xb7, 0x1a, 0xee, 0xf8, 0x65, 0xd9, 0x6a, 0x22, 0xae, 0x64, 0x96, - 0xad, 0x26, 0x6a, 0x26, 0xa2, 0xb7, 0x58, 0xde, 0x6f, 0xc2, 0xcb, 0x29, 0x8b, 0x94, 0xdb, 0x86, - 0x89, 0x55, 0x2a, 0xdc, 0xca, 0x0e, 0xfc, 0x3b, 0xdf, 0x5a, 0x58, 0xf4, 0x2c, 0x57, 0x8f, 0xb8, - 0xe7, 0x98, 0xe5, 0xea, 0x91, 0xf0, 0xf5, 0xd0, 0xbb, 0x2c, 0xfb, 0x7b, 0xf0, 0x6e, 0x96, 0xec, - 0xd5, 0xf5, 0x6d, 0x55, 0xd7, 0x72, 0x1c, 0x70, 0xba, 0xd6, 0x81, 0x1f, 0x14, 0xc0, 0x64, 0x1f, - 0x93, 0x0a, 0x5e, 0x4c, 0x4f, 0x77, 0x80, 0x4d, 0x58, 0xbc, 0xf4, 0x2c, 0x50, 0x41, 0xf8, 0xe7, - 0x12, 0x63, 0xfc, 0x53, 0x09, 0xfe, 0x48, 0x4a, 0xe1, 0xdc, 0xf0, 0x63, 0xe4, 0x3d, 0x27, 0xe4, - 0x9d, 0xbe, 0x7e, 0x5f, 0x47, 0xde, 0x09, 0x7b, 0x78, 0x1d, 0xf8, 0x3f, 0x09, 0x1c, 0x8e, 0xfb, - 0x48, 0xf0, 0xf5, 0x74, 0x76, 0xfd, 0xcc, 0xb7, 0xe2, 0xf9, 0xdc, 0x38, 0x21, 0x89, 0xc5, 0x14, - 0x31, 0xe0, 0xf7, 0x53, 0xf4, 0x68, 0x32, 0xb4, 0x6a, 0x73, 0x78, 0x0e, 0x31, 0x12, 0x2e, 0x5a, - 0x07, 0xfe, 0x8c, 0xef, 0x9b, 0x31, 0xb3, 0x22, 0x75, 0xdf, 0xec, 0x6f, 0xbc, 0xa4, 0xee, 0x9b, - 0x03, 0x3c, 0x11, 0x34, 0x04, 0x7f, 0xc8, 0xae, 0x5d, 0x21, 0x33, 0x20, 0xcb, 0xb5, 0x2b, 0x69, - 0x69, 0x64, 0xb9, 0x76, 0xf5, 0x31, 0x2c, 0xd0, 0x10, 0xfc, 0x01, 0x38, 0x10, 0xf9, 0xd4, 0x85, - 0x59, 0x97, 0x71, 0xd8, 0x8f, 0x28, 0x9e, 0xcd, 0x07, 0xf2, 0x46, 0xaf, 0x2e, 0x7e, 0xfc, 0xa4, - 0x24, 0x3d, 0x7e, 0x52, 0x92, 0xfe, 0xfd, 0xa4, 0x24, 0x3d, 0x7a, 0x5a, 0x1a, 0x7a, 0xfc, 0xb4, - 0x34, 0xf4, 0x8f, 0xa7, 0xa5, 0xa1, 0x7b, 0xb3, 0x21, 0xcb, 0x20, 0x5e, 0x16, 0xb3, 0xbc, 0x2e, - 0xb6, 0x58, 0x65, 0x30, 0xf7, 0x60, 0x7d, 0x94, 0xbd, 0x3f, 0xf3, 0x59, 0x00, 0x00, 0x00, 0xff, - 0xff, 0xf0, 0x0a, 0x3f, 0x2b, 0x03, 0x27, 0x00, 0x00, -} - -// Reference imports to suppress errors if they are not otherwise used. -var _ context.Context -var _ grpc.ClientConn - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the grpc package it is being compiled against. -const _ = grpc.SupportPackageIsVersion4 - -// QueryClient is the client API for Query service. -// -// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. -type QueryClient interface { - // Parameters queries the parameters of the module. - Params(ctx context.Context, in *QueryParamsRequest, opts ...grpc.CallOption) (*QueryParamsResponse, error) - // Queries a LongBook by id. - LongBook(ctx context.Context, in *QueryGetLongBookRequest, opts ...grpc.CallOption) (*QueryGetLongBookResponse, error) - // Queries a list of LongBook items. - LongBookAll(ctx context.Context, in *QueryAllLongBookRequest, opts ...grpc.CallOption) (*QueryAllLongBookResponse, error) - // Queries a ShortBook by id. - ShortBook(ctx context.Context, in *QueryGetShortBookRequest, opts ...grpc.CallOption) (*QueryGetShortBookResponse, error) - // Queries a list of ShortBook items. - ShortBookAll(ctx context.Context, in *QueryAllShortBookRequest, opts ...grpc.CallOption) (*QueryAllShortBookResponse, error) - GetPrice(ctx context.Context, in *QueryGetPriceRequest, opts ...grpc.CallOption) (*QueryGetPriceResponse, error) - GetLatestPrice(ctx context.Context, in *QueryGetLatestPriceRequest, opts ...grpc.CallOption) (*QueryGetLatestPriceResponse, error) - GetPrices(ctx context.Context, in *QueryGetPricesRequest, opts ...grpc.CallOption) (*QueryGetPricesResponse, error) - GetTwaps(ctx context.Context, in *QueryGetTwapsRequest, opts ...grpc.CallOption) (*QueryGetTwapsResponse, error) - // Returns the metadata for a specified denom / display type - AssetMetadata(ctx context.Context, in *QueryAssetMetadataRequest, opts ...grpc.CallOption) (*QueryAssetMetadataResponse, error) - // Returns metadata for all the assets - AssetList(ctx context.Context, in *QueryAssetListRequest, opts ...grpc.CallOption) (*QueryAssetListResponse, error) - // Returns all registered pairs for specified contract address - GetRegisteredPairs(ctx context.Context, in *QueryRegisteredPairsRequest, opts ...grpc.CallOption) (*QueryRegisteredPairsResponse, error) - // Returns registered contract information - GetRegisteredContract(ctx context.Context, in *QueryRegisteredContractRequest, opts ...grpc.CallOption) (*QueryRegisteredContractResponse, error) - GetOrders(ctx context.Context, in *QueryGetOrdersRequest, opts ...grpc.CallOption) (*QueryGetOrdersResponse, error) - GetOrder(ctx context.Context, in *QueryGetOrderByIDRequest, opts ...grpc.CallOption) (*QueryGetOrderByIDResponse, error) - GetHistoricalPrices(ctx context.Context, in *QueryGetHistoricalPricesRequest, opts ...grpc.CallOption) (*QueryGetHistoricalPricesResponse, error) - GetMarketSummary(ctx context.Context, in *QueryGetMarketSummaryRequest, opts ...grpc.CallOption) (*QueryGetMarketSummaryResponse, error) - GetOrderSimulation(ctx context.Context, in *QueryOrderSimulationRequest, opts ...grpc.CallOption) (*QueryOrderSimulationResponse, error) - GetMatchResult(ctx context.Context, in *QueryGetMatchResultRequest, opts ...grpc.CallOption) (*QueryGetMatchResultResponse, error) - GetOrderCount(ctx context.Context, in *QueryGetOrderCountRequest, opts ...grpc.CallOption) (*QueryGetOrderCountResponse, error) -} - -type queryClient struct { - cc grpc1.ClientConn -} - -func NewQueryClient(cc grpc1.ClientConn) QueryClient { - return &queryClient{cc} -} - -func (c *queryClient) Params(ctx context.Context, in *QueryParamsRequest, opts ...grpc.CallOption) (*QueryParamsResponse, error) { - out := new(QueryParamsResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/Params", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) LongBook(ctx context.Context, in *QueryGetLongBookRequest, opts ...grpc.CallOption) (*QueryGetLongBookResponse, error) { - out := new(QueryGetLongBookResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/LongBook", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) LongBookAll(ctx context.Context, in *QueryAllLongBookRequest, opts ...grpc.CallOption) (*QueryAllLongBookResponse, error) { - out := new(QueryAllLongBookResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/LongBookAll", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) ShortBook(ctx context.Context, in *QueryGetShortBookRequest, opts ...grpc.CallOption) (*QueryGetShortBookResponse, error) { - out := new(QueryGetShortBookResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/ShortBook", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) ShortBookAll(ctx context.Context, in *QueryAllShortBookRequest, opts ...grpc.CallOption) (*QueryAllShortBookResponse, error) { - out := new(QueryAllShortBookResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/ShortBookAll", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetPrice(ctx context.Context, in *QueryGetPriceRequest, opts ...grpc.CallOption) (*QueryGetPriceResponse, error) { - out := new(QueryGetPriceResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetPrice", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetLatestPrice(ctx context.Context, in *QueryGetLatestPriceRequest, opts ...grpc.CallOption) (*QueryGetLatestPriceResponse, error) { - out := new(QueryGetLatestPriceResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetLatestPrice", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetPrices(ctx context.Context, in *QueryGetPricesRequest, opts ...grpc.CallOption) (*QueryGetPricesResponse, error) { - out := new(QueryGetPricesResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetPrices", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetTwaps(ctx context.Context, in *QueryGetTwapsRequest, opts ...grpc.CallOption) (*QueryGetTwapsResponse, error) { - out := new(QueryGetTwapsResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetTwaps", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) AssetMetadata(ctx context.Context, in *QueryAssetMetadataRequest, opts ...grpc.CallOption) (*QueryAssetMetadataResponse, error) { - out := new(QueryAssetMetadataResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/AssetMetadata", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) AssetList(ctx context.Context, in *QueryAssetListRequest, opts ...grpc.CallOption) (*QueryAssetListResponse, error) { - out := new(QueryAssetListResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/AssetList", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetRegisteredPairs(ctx context.Context, in *QueryRegisteredPairsRequest, opts ...grpc.CallOption) (*QueryRegisteredPairsResponse, error) { - out := new(QueryRegisteredPairsResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetRegisteredPairs", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetRegisteredContract(ctx context.Context, in *QueryRegisteredContractRequest, opts ...grpc.CallOption) (*QueryRegisteredContractResponse, error) { - out := new(QueryRegisteredContractResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetRegisteredContract", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetOrders(ctx context.Context, in *QueryGetOrdersRequest, opts ...grpc.CallOption) (*QueryGetOrdersResponse, error) { - out := new(QueryGetOrdersResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetOrders", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetOrder(ctx context.Context, in *QueryGetOrderByIDRequest, opts ...grpc.CallOption) (*QueryGetOrderByIDResponse, error) { - out := new(QueryGetOrderByIDResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetOrder", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetHistoricalPrices(ctx context.Context, in *QueryGetHistoricalPricesRequest, opts ...grpc.CallOption) (*QueryGetHistoricalPricesResponse, error) { - out := new(QueryGetHistoricalPricesResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetHistoricalPrices", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetMarketSummary(ctx context.Context, in *QueryGetMarketSummaryRequest, opts ...grpc.CallOption) (*QueryGetMarketSummaryResponse, error) { - out := new(QueryGetMarketSummaryResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetMarketSummary", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetOrderSimulation(ctx context.Context, in *QueryOrderSimulationRequest, opts ...grpc.CallOption) (*QueryOrderSimulationResponse, error) { - out := new(QueryOrderSimulationResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetOrderSimulation", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetMatchResult(ctx context.Context, in *QueryGetMatchResultRequest, opts ...grpc.CallOption) (*QueryGetMatchResultResponse, error) { - out := new(QueryGetMatchResultResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetMatchResult", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *queryClient) GetOrderCount(ctx context.Context, in *QueryGetOrderCountRequest, opts ...grpc.CallOption) (*QueryGetOrderCountResponse, error) { - out := new(QueryGetOrderCountResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Query/GetOrderCount", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -// QueryServer is the server API for Query service. -type QueryServer interface { - // Parameters queries the parameters of the module. - Params(context.Context, *QueryParamsRequest) (*QueryParamsResponse, error) - // Queries a LongBook by id. - LongBook(context.Context, *QueryGetLongBookRequest) (*QueryGetLongBookResponse, error) - // Queries a list of LongBook items. - LongBookAll(context.Context, *QueryAllLongBookRequest) (*QueryAllLongBookResponse, error) - // Queries a ShortBook by id. - ShortBook(context.Context, *QueryGetShortBookRequest) (*QueryGetShortBookResponse, error) - // Queries a list of ShortBook items. - ShortBookAll(context.Context, *QueryAllShortBookRequest) (*QueryAllShortBookResponse, error) - GetPrice(context.Context, *QueryGetPriceRequest) (*QueryGetPriceResponse, error) - GetLatestPrice(context.Context, *QueryGetLatestPriceRequest) (*QueryGetLatestPriceResponse, error) - GetPrices(context.Context, *QueryGetPricesRequest) (*QueryGetPricesResponse, error) - GetTwaps(context.Context, *QueryGetTwapsRequest) (*QueryGetTwapsResponse, error) - // Returns the metadata for a specified denom / display type - AssetMetadata(context.Context, *QueryAssetMetadataRequest) (*QueryAssetMetadataResponse, error) - // Returns metadata for all the assets - AssetList(context.Context, *QueryAssetListRequest) (*QueryAssetListResponse, error) - // Returns all registered pairs for specified contract address - GetRegisteredPairs(context.Context, *QueryRegisteredPairsRequest) (*QueryRegisteredPairsResponse, error) - // Returns registered contract information - GetRegisteredContract(context.Context, *QueryRegisteredContractRequest) (*QueryRegisteredContractResponse, error) - GetOrders(context.Context, *QueryGetOrdersRequest) (*QueryGetOrdersResponse, error) - GetOrder(context.Context, *QueryGetOrderByIDRequest) (*QueryGetOrderByIDResponse, error) - GetHistoricalPrices(context.Context, *QueryGetHistoricalPricesRequest) (*QueryGetHistoricalPricesResponse, error) - GetMarketSummary(context.Context, *QueryGetMarketSummaryRequest) (*QueryGetMarketSummaryResponse, error) - GetOrderSimulation(context.Context, *QueryOrderSimulationRequest) (*QueryOrderSimulationResponse, error) - GetMatchResult(context.Context, *QueryGetMatchResultRequest) (*QueryGetMatchResultResponse, error) - GetOrderCount(context.Context, *QueryGetOrderCountRequest) (*QueryGetOrderCountResponse, error) -} - -// UnimplementedQueryServer can be embedded to have forward compatible implementations. -type UnimplementedQueryServer struct { -} - -func (*UnimplementedQueryServer) Params(ctx context.Context, req *QueryParamsRequest) (*QueryParamsResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method Params not implemented") -} -func (*UnimplementedQueryServer) LongBook(ctx context.Context, req *QueryGetLongBookRequest) (*QueryGetLongBookResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method LongBook not implemented") -} -func (*UnimplementedQueryServer) LongBookAll(ctx context.Context, req *QueryAllLongBookRequest) (*QueryAllLongBookResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method LongBookAll not implemented") -} -func (*UnimplementedQueryServer) ShortBook(ctx context.Context, req *QueryGetShortBookRequest) (*QueryGetShortBookResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method ShortBook not implemented") -} -func (*UnimplementedQueryServer) ShortBookAll(ctx context.Context, req *QueryAllShortBookRequest) (*QueryAllShortBookResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method ShortBookAll not implemented") -} -func (*UnimplementedQueryServer) GetPrice(ctx context.Context, req *QueryGetPriceRequest) (*QueryGetPriceResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetPrice not implemented") -} -func (*UnimplementedQueryServer) GetLatestPrice(ctx context.Context, req *QueryGetLatestPriceRequest) (*QueryGetLatestPriceResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetLatestPrice not implemented") -} -func (*UnimplementedQueryServer) GetPrices(ctx context.Context, req *QueryGetPricesRequest) (*QueryGetPricesResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetPrices not implemented") -} -func (*UnimplementedQueryServer) GetTwaps(ctx context.Context, req *QueryGetTwapsRequest) (*QueryGetTwapsResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetTwaps not implemented") -} -func (*UnimplementedQueryServer) AssetMetadata(ctx context.Context, req *QueryAssetMetadataRequest) (*QueryAssetMetadataResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method AssetMetadata not implemented") -} -func (*UnimplementedQueryServer) AssetList(ctx context.Context, req *QueryAssetListRequest) (*QueryAssetListResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method AssetList not implemented") -} -func (*UnimplementedQueryServer) GetRegisteredPairs(ctx context.Context, req *QueryRegisteredPairsRequest) (*QueryRegisteredPairsResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetRegisteredPairs not implemented") -} -func (*UnimplementedQueryServer) GetRegisteredContract(ctx context.Context, req *QueryRegisteredContractRequest) (*QueryRegisteredContractResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetRegisteredContract not implemented") -} -func (*UnimplementedQueryServer) GetOrders(ctx context.Context, req *QueryGetOrdersRequest) (*QueryGetOrdersResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetOrders not implemented") -} -func (*UnimplementedQueryServer) GetOrder(ctx context.Context, req *QueryGetOrderByIDRequest) (*QueryGetOrderByIDResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetOrder not implemented") -} -func (*UnimplementedQueryServer) GetHistoricalPrices(ctx context.Context, req *QueryGetHistoricalPricesRequest) (*QueryGetHistoricalPricesResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetHistoricalPrices not implemented") -} -func (*UnimplementedQueryServer) GetMarketSummary(ctx context.Context, req *QueryGetMarketSummaryRequest) (*QueryGetMarketSummaryResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetMarketSummary not implemented") -} -func (*UnimplementedQueryServer) GetOrderSimulation(ctx context.Context, req *QueryOrderSimulationRequest) (*QueryOrderSimulationResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetOrderSimulation not implemented") -} -func (*UnimplementedQueryServer) GetMatchResult(ctx context.Context, req *QueryGetMatchResultRequest) (*QueryGetMatchResultResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetMatchResult not implemented") -} -func (*UnimplementedQueryServer) GetOrderCount(ctx context.Context, req *QueryGetOrderCountRequest) (*QueryGetOrderCountResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method GetOrderCount not implemented") -} - -func RegisterQueryServer(s grpc1.Server, srv QueryServer) { - s.RegisterService(&_Query_serviceDesc, srv) -} - -func _Query_Params_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryParamsRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).Params(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/Params", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).Params(ctx, req.(*QueryParamsRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_LongBook_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetLongBookRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).LongBook(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/LongBook", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).LongBook(ctx, req.(*QueryGetLongBookRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_LongBookAll_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryAllLongBookRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).LongBookAll(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/LongBookAll", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).LongBookAll(ctx, req.(*QueryAllLongBookRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_ShortBook_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetShortBookRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).ShortBook(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/ShortBook", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).ShortBook(ctx, req.(*QueryGetShortBookRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_ShortBookAll_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryAllShortBookRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).ShortBookAll(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/ShortBookAll", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).ShortBookAll(ctx, req.(*QueryAllShortBookRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetPrice_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetPriceRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetPrice(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetPrice", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetPrice(ctx, req.(*QueryGetPriceRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetLatestPrice_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetLatestPriceRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetLatestPrice(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetLatestPrice", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetLatestPrice(ctx, req.(*QueryGetLatestPriceRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetPrices_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetPricesRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetPrices(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetPrices", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetPrices(ctx, req.(*QueryGetPricesRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetTwaps_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetTwapsRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetTwaps(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetTwaps", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetTwaps(ctx, req.(*QueryGetTwapsRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_AssetMetadata_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryAssetMetadataRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).AssetMetadata(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/AssetMetadata", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).AssetMetadata(ctx, req.(*QueryAssetMetadataRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_AssetList_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryAssetListRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).AssetList(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/AssetList", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).AssetList(ctx, req.(*QueryAssetListRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetRegisteredPairs_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryRegisteredPairsRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetRegisteredPairs(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetRegisteredPairs", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetRegisteredPairs(ctx, req.(*QueryRegisteredPairsRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetRegisteredContract_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryRegisteredContractRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetRegisteredContract(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetRegisteredContract", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetRegisteredContract(ctx, req.(*QueryRegisteredContractRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetOrders_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetOrdersRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetOrders(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetOrders", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetOrders(ctx, req.(*QueryGetOrdersRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetOrder_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetOrderByIDRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetOrder(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetOrder", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetOrder(ctx, req.(*QueryGetOrderByIDRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetHistoricalPrices_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetHistoricalPricesRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetHistoricalPrices(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetHistoricalPrices", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetHistoricalPrices(ctx, req.(*QueryGetHistoricalPricesRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetMarketSummary_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetMarketSummaryRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetMarketSummary(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetMarketSummary", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetMarketSummary(ctx, req.(*QueryGetMarketSummaryRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetOrderSimulation_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryOrderSimulationRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetOrderSimulation(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetOrderSimulation", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetOrderSimulation(ctx, req.(*QueryOrderSimulationRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetMatchResult_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetMatchResultRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetMatchResult(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetMatchResult", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetMatchResult(ctx, req.(*QueryGetMatchResultRequest)) - } - return interceptor(ctx, in, info, handler) -} - -func _Query_GetOrderCount_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(QueryGetOrderCountRequest) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(QueryServer).GetOrderCount(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Query/GetOrderCount", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(QueryServer).GetOrderCount(ctx, req.(*QueryGetOrderCountRequest)) - } - return interceptor(ctx, in, info, handler) -} - -var _Query_serviceDesc = grpc.ServiceDesc{ - ServiceName: "seiprotocol.seichain.dex.Query", - HandlerType: (*QueryServer)(nil), - Methods: []grpc.MethodDesc{ - { - MethodName: "Params", - Handler: _Query_Params_Handler, - }, - { - MethodName: "LongBook", - Handler: _Query_LongBook_Handler, - }, - { - MethodName: "LongBookAll", - Handler: _Query_LongBookAll_Handler, - }, - { - MethodName: "ShortBook", - Handler: _Query_ShortBook_Handler, - }, - { - MethodName: "ShortBookAll", - Handler: _Query_ShortBookAll_Handler, - }, - { - MethodName: "GetPrice", - Handler: _Query_GetPrice_Handler, - }, - { - MethodName: "GetLatestPrice", - Handler: _Query_GetLatestPrice_Handler, - }, - { - MethodName: "GetPrices", - Handler: _Query_GetPrices_Handler, - }, - { - MethodName: "GetTwaps", - Handler: _Query_GetTwaps_Handler, - }, - { - MethodName: "AssetMetadata", - Handler: _Query_AssetMetadata_Handler, - }, - { - MethodName: "AssetList", - Handler: _Query_AssetList_Handler, - }, - { - MethodName: "GetRegisteredPairs", - Handler: _Query_GetRegisteredPairs_Handler, - }, - { - MethodName: "GetRegisteredContract", - Handler: _Query_GetRegisteredContract_Handler, - }, - { - MethodName: "GetOrders", - Handler: _Query_GetOrders_Handler, - }, - { - MethodName: "GetOrder", - Handler: _Query_GetOrder_Handler, - }, - { - MethodName: "GetHistoricalPrices", - Handler: _Query_GetHistoricalPrices_Handler, - }, - { - MethodName: "GetMarketSummary", - Handler: _Query_GetMarketSummary_Handler, - }, - { - MethodName: "GetOrderSimulation", - Handler: _Query_GetOrderSimulation_Handler, - }, - { - MethodName: "GetMatchResult", - Handler: _Query_GetMatchResult_Handler, - }, - { - MethodName: "GetOrderCount", - Handler: _Query_GetOrderCount_Handler, - }, - }, - Streams: []grpc.StreamDesc{}, - Metadata: "dex/query.proto", -} - -func (m *QueryParamsRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryParamsRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryParamsRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - return len(dAtA) - i, nil -} - -func (m *QueryParamsResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryParamsResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryParamsResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - { - size, err := m.Params.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - return len(dAtA) - i, nil -} - -func (m *QueryGetLongBookRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetLongBookRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetLongBookRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x22 - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x1a - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if len(m.Price) > 0 { - i -= len(m.Price) - copy(dAtA[i:], m.Price) - i = encodeVarintQuery(dAtA, i, uint64(len(m.Price))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetLongBookResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetLongBookResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetLongBookResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - { - size, err := m.LongBook.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - return len(dAtA) - i, nil -} - -func (m *QueryAllLongBookRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryAllLongBookRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryAllLongBookRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x22 - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x1a - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if m.Pagination != nil { - { - size, err := m.Pagination.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryAllLongBookResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryAllLongBookResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryAllLongBookResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Pagination != nil { - { - size, err := m.Pagination.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - if len(m.LongBook) > 0 { - for iNdEx := len(m.LongBook) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.LongBook[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - } - return len(dAtA) - i, nil -} - -func (m *QueryGetShortBookRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetShortBookRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetShortBookRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x22 - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x1a - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if len(m.Price) > 0 { - i -= len(m.Price) - copy(dAtA[i:], m.Price) - i = encodeVarintQuery(dAtA, i, uint64(len(m.Price))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetShortBookResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetShortBookResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetShortBookResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - { - size, err := m.ShortBook.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - return len(dAtA) - i, nil -} - -func (m *QueryAllShortBookRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryAllShortBookRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryAllShortBookRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x22 - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x1a - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if m.Pagination != nil { - { - size, err := m.Pagination.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryAllShortBookResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryAllShortBookResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryAllShortBookResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Pagination != nil { - { - size, err := m.Pagination.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - if len(m.ShortBook) > 0 { - for iNdEx := len(m.ShortBook) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.ShortBook[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - } - return len(dAtA) - i, nil -} - -func (m *QueryGetPricesRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetPricesRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetPricesRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x1a - } - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x12 - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetPricesResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetPricesResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetPricesResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Prices) > 0 { - for iNdEx := len(m.Prices) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Prices[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - } - return len(dAtA) - i, nil -} - -func (m *QueryGetPriceRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetPriceRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetPriceRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Timestamp != 0 { - i = encodeVarintQuery(dAtA, i, uint64(m.Timestamp)) - i-- - dAtA[i] = 0x20 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x1a - } - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x12 - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetPriceResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetPriceResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetPriceResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Found { - i-- - if m.Found { - dAtA[i] = 1 - } else { - dAtA[i] = 0 - } - i-- - dAtA[i] = 0x10 - } - if m.Price != nil { - { - size, err := m.Price.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetLatestPriceRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetLatestPriceRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetLatestPriceRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x1a - } - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x12 - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetLatestPriceResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetLatestPriceResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetLatestPriceResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Price != nil { - { - size, err := m.Price.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetTwapsRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetTwapsRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetTwapsRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.LookbackSeconds != 0 { - i = encodeVarintQuery(dAtA, i, uint64(m.LookbackSeconds)) - i-- - dAtA[i] = 0x10 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetTwapsResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetTwapsResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetTwapsResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Twaps) > 0 { - for iNdEx := len(m.Twaps) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Twaps[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - } - return len(dAtA) - i, nil -} - -func (m *QueryAssetListRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryAssetListRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryAssetListRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - return len(dAtA) - i, nil -} - -func (m *QueryAssetListResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryAssetListResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryAssetListResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.AssetList) > 0 { - for iNdEx := len(m.AssetList) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.AssetList[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - } - return len(dAtA) - i, nil -} - -func (m *QueryAssetMetadataRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryAssetMetadataRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryAssetMetadataRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Denom) > 0 { - i -= len(m.Denom) - copy(dAtA[i:], m.Denom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.Denom))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryAssetMetadataResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryAssetMetadataResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryAssetMetadataResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Metadata != nil { - { - size, err := m.Metadata.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryRegisteredPairsRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryRegisteredPairsRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryRegisteredPairsRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryRegisteredPairsResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryRegisteredPairsResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryRegisteredPairsResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Pairs) > 0 { - for iNdEx := len(m.Pairs) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Pairs[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - } - return len(dAtA) - i, nil -} - -func (m *QueryRegisteredContractRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryRegisteredContractRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryRegisteredContractRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryRegisteredContractResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryRegisteredContractResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryRegisteredContractResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.ContractInfo != nil { - { - size, err := m.ContractInfo.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetOrdersRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetOrdersRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetOrdersRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Account) > 0 { - i -= len(m.Account) - copy(dAtA[i:], m.Account) - i = encodeVarintQuery(dAtA, i, uint64(len(m.Account))) - i-- - dAtA[i] = 0x12 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetOrdersResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetOrdersResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetOrdersResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Orders) > 0 { - for iNdEx := len(m.Orders) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Orders[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - } - return len(dAtA) - i, nil -} - -func (m *QueryGetOrderByIDRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetOrderByIDRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetOrderByIDRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Id != 0 { - i = encodeVarintQuery(dAtA, i, uint64(m.Id)) - i-- - dAtA[i] = 0x20 - } - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x1a - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x12 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetOrderByIDResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetOrderByIDResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetOrderByIDResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Order != nil { - { - size, err := m.Order.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetHistoricalPricesRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetHistoricalPricesRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetHistoricalPricesRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.NumOfPeriods != 0 { - i = encodeVarintQuery(dAtA, i, uint64(m.NumOfPeriods)) - i-- - dAtA[i] = 0x28 - } - if m.PeriodLengthInSeconds != 0 { - i = encodeVarintQuery(dAtA, i, uint64(m.PeriodLengthInSeconds)) - i-- - dAtA[i] = 0x20 - } - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x1a - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x12 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetHistoricalPricesResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetHistoricalPricesResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetHistoricalPricesResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Prices) > 0 { - for iNdEx := len(m.Prices) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Prices[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - } - return len(dAtA) - i, nil -} - -func (m *QueryGetMarketSummaryRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetMarketSummaryRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetMarketSummaryRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.LookbackInSeconds != 0 { - i = encodeVarintQuery(dAtA, i, uint64(m.LookbackInSeconds)) - i-- - dAtA[i] = 0x20 - } - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x1a - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x12 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetMarketSummaryResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetMarketSummaryResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetMarketSummaryResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.LastPrice != nil { - { - size := m.LastPrice.Size() - i -= size - if _, err := m.LastPrice.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x2a - } - if m.LowPrice != nil { - { - size := m.LowPrice.Size() - i -= size - if _, err := m.LowPrice.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x22 - } - if m.HighPrice != nil { - { - size := m.HighPrice.Size() - i -= size - if _, err := m.HighPrice.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - } - if m.TotalVolumeNotional != nil { - { - size := m.TotalVolumeNotional.Size() - i -= size - if _, err := m.TotalVolumeNotional.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - if m.TotalVolume != nil { - { - size := m.TotalVolume.Size() - i -= size - if _, err := m.TotalVolume.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryOrderSimulationRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryOrderSimulationRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryOrderSimulationRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if m.Order != nil { - { - size, err := m.Order.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryOrderSimulationResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryOrderSimulationResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryOrderSimulationResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.ExecutedQuantity != nil { - { - size := m.ExecutedQuantity.Size() - i -= size - if _, err := m.ExecutedQuantity.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetMatchResultRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetMatchResultRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetMatchResultRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetMatchResultResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetMatchResultResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetMatchResultResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Result != nil { - { - size, err := m.Result.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetOrderCountRequest) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetOrderCountRequest) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetOrderCountRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.PositionDirection != 0 { - i = encodeVarintQuery(dAtA, i, uint64(m.PositionDirection)) - i-- - dAtA[i] = 0x28 - } - if m.Price != nil { - { - size := m.Price.Size() - i -= size - if _, err := m.Price.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintQuery(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x22 - } - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x1a - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintQuery(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x12 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintQuery(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *QueryGetOrderCountResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *QueryGetOrderCountResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *QueryGetOrderCountResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Count != 0 { - i = encodeVarintQuery(dAtA, i, uint64(m.Count)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func encodeVarintQuery(dAtA []byte, offset int, v uint64) int { - offset -= sovQuery(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *QueryParamsRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - return n -} - -func (m *QueryParamsResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = m.Params.Size() - n += 1 + l + sovQuery(uint64(l)) - return n -} - -func (m *QueryGetLongBookRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Price) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetLongBookResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = m.LongBook.Size() - n += 1 + l + sovQuery(uint64(l)) - return n -} - -func (m *QueryAllLongBookRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Pagination != nil { - l = m.Pagination.Size() - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryAllLongBookResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.LongBook) > 0 { - for _, e := range m.LongBook { - l = e.Size() - n += 1 + l + sovQuery(uint64(l)) - } - } - if m.Pagination != nil { - l = m.Pagination.Size() - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetShortBookRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Price) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetShortBookResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = m.ShortBook.Size() - n += 1 + l + sovQuery(uint64(l)) - return n -} - -func (m *QueryAllShortBookRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Pagination != nil { - l = m.Pagination.Size() - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryAllShortBookResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.ShortBook) > 0 { - for _, e := range m.ShortBook { - l = e.Size() - n += 1 + l + sovQuery(uint64(l)) - } - } - if m.Pagination != nil { - l = m.Pagination.Size() - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetPricesRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetPricesResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.Prices) > 0 { - for _, e := range m.Prices { - l = e.Size() - n += 1 + l + sovQuery(uint64(l)) - } - } - return n -} - -func (m *QueryGetPriceRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - if m.Timestamp != 0 { - n += 1 + sovQuery(uint64(m.Timestamp)) - } - return n -} - -func (m *QueryGetPriceResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Price != nil { - l = m.Price.Size() - n += 1 + l + sovQuery(uint64(l)) - } - if m.Found { - n += 2 - } - return n -} - -func (m *QueryGetLatestPriceRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetLatestPriceResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Price != nil { - l = m.Price.Size() - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetTwapsRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - if m.LookbackSeconds != 0 { - n += 1 + sovQuery(uint64(m.LookbackSeconds)) - } - return n -} - -func (m *QueryGetTwapsResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.Twaps) > 0 { - for _, e := range m.Twaps { - l = e.Size() - n += 1 + l + sovQuery(uint64(l)) - } - } - return n -} - -func (m *QueryAssetListRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - return n -} - -func (m *QueryAssetListResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.AssetList) > 0 { - for _, e := range m.AssetList { - l = e.Size() - n += 1 + l + sovQuery(uint64(l)) - } - } - return n -} - -func (m *QueryAssetMetadataRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Denom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryAssetMetadataResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Metadata != nil { - l = m.Metadata.Size() - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryRegisteredPairsRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryRegisteredPairsResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.Pairs) > 0 { - for _, e := range m.Pairs { - l = e.Size() - n += 1 + l + sovQuery(uint64(l)) - } - } - return n -} - -func (m *QueryRegisteredContractRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryRegisteredContractResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.ContractInfo != nil { - l = m.ContractInfo.Size() - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetOrdersRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.Account) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetOrdersResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.Orders) > 0 { - for _, e := range m.Orders { - l = e.Size() - n += 1 + l + sovQuery(uint64(l)) - } - } - return n -} - -func (m *QueryGetOrderByIDRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - if m.Id != 0 { - n += 1 + sovQuery(uint64(m.Id)) - } - return n -} - -func (m *QueryGetOrderByIDResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Order != nil { - l = m.Order.Size() - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetHistoricalPricesRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - if m.PeriodLengthInSeconds != 0 { - n += 1 + sovQuery(uint64(m.PeriodLengthInSeconds)) - } - if m.NumOfPeriods != 0 { - n += 1 + sovQuery(uint64(m.NumOfPeriods)) - } - return n -} - -func (m *QueryGetHistoricalPricesResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.Prices) > 0 { - for _, e := range m.Prices { - l = e.Size() - n += 1 + l + sovQuery(uint64(l)) - } - } - return n -} - -func (m *QueryGetMarketSummaryRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - if m.LookbackInSeconds != 0 { - n += 1 + sovQuery(uint64(m.LookbackInSeconds)) - } - return n -} - -func (m *QueryGetMarketSummaryResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.TotalVolume != nil { - l = m.TotalVolume.Size() - n += 1 + l + sovQuery(uint64(l)) - } - if m.TotalVolumeNotional != nil { - l = m.TotalVolumeNotional.Size() - n += 1 + l + sovQuery(uint64(l)) - } - if m.HighPrice != nil { - l = m.HighPrice.Size() - n += 1 + l + sovQuery(uint64(l)) - } - if m.LowPrice != nil { - l = m.LowPrice.Size() - n += 1 + l + sovQuery(uint64(l)) - } - if m.LastPrice != nil { - l = m.LastPrice.Size() - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryOrderSimulationRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Order != nil { - l = m.Order.Size() - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryOrderSimulationResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.ExecutedQuantity != nil { - l = m.ExecutedQuantity.Size() - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetMatchResultRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetMatchResultResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Result != nil { - l = m.Result.Size() - n += 1 + l + sovQuery(uint64(l)) - } - return n -} - -func (m *QueryGetOrderCountRequest) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovQuery(uint64(l)) - } - if m.Price != nil { - l = m.Price.Size() - n += 1 + l + sovQuery(uint64(l)) - } - if m.PositionDirection != 0 { - n += 1 + sovQuery(uint64(m.PositionDirection)) - } - return n -} - -func (m *QueryGetOrderCountResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Count != 0 { - n += 1 + sovQuery(uint64(m.Count)) - } - return n -} - -func sovQuery(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozQuery(x uint64) (n int) { - return sovQuery(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *QueryParamsRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryParamsRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryParamsRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryParamsResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryParamsResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryParamsResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Params", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Params.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetLongBookRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetLongBookRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetLongBookRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Price = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetLongBookResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetLongBookResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetLongBookResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field LongBook", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.LongBook.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryAllLongBookRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryAllLongBookRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryAllLongBookRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Pagination", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Pagination == nil { - m.Pagination = &query.PageRequest{} - } - if err := m.Pagination.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryAllLongBookResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryAllLongBookResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryAllLongBookResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field LongBook", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.LongBook = append(m.LongBook, LongBook{}) - if err := m.LongBook[len(m.LongBook)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Pagination", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Pagination == nil { - m.Pagination = &query.PageResponse{} - } - if err := m.Pagination.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetShortBookRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetShortBookRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetShortBookRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Price = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetShortBookResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetShortBookResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetShortBookResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ShortBook", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.ShortBook.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryAllShortBookRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryAllShortBookRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryAllShortBookRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Pagination", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Pagination == nil { - m.Pagination = &query.PageRequest{} - } - if err := m.Pagination.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryAllShortBookResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryAllShortBookResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryAllShortBookResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ShortBook", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ShortBook = append(m.ShortBook, ShortBook{}) - if err := m.ShortBook[len(m.ShortBook)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Pagination", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Pagination == nil { - m.Pagination = &query.PageResponse{} - } - if err := m.Pagination.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetPricesRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetPricesRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetPricesRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetPricesResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetPricesResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetPricesResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Prices", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Prices = append(m.Prices, &Price{}) - if err := m.Prices[len(m.Prices)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetPriceRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetPriceRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetPriceRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Timestamp", wireType) - } - m.Timestamp = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Timestamp |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetPriceResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetPriceResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetPriceResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Price == nil { - m.Price = &Price{} - } - if err := m.Price.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Found", wireType) - } - var v int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.Found = bool(v != 0) - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetLatestPriceRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetLatestPriceRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetLatestPriceRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetLatestPriceResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetLatestPriceResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetLatestPriceResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Price == nil { - m.Price = &Price{} - } - if err := m.Price.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetTwapsRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetTwapsRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetTwapsRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field LookbackSeconds", wireType) - } - m.LookbackSeconds = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.LookbackSeconds |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetTwapsResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetTwapsResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetTwapsResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Twaps", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Twaps = append(m.Twaps, &Twap{}) - if err := m.Twaps[len(m.Twaps)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryAssetListRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryAssetListRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryAssetListRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryAssetListResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryAssetListResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryAssetListResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetList", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetList = append(m.AssetList, AssetMetadata{}) - if err := m.AssetList[len(m.AssetList)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryAssetMetadataRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryAssetMetadataRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryAssetMetadataRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Denom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Denom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryAssetMetadataResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryAssetMetadataResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryAssetMetadataResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Metadata", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Metadata == nil { - m.Metadata = &AssetMetadata{} - } - if err := m.Metadata.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryRegisteredPairsRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryRegisteredPairsRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryRegisteredPairsRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryRegisteredPairsResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryRegisteredPairsResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryRegisteredPairsResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Pairs", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Pairs = append(m.Pairs, Pair{}) - if err := m.Pairs[len(m.Pairs)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryRegisteredContractRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryRegisteredContractRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryRegisteredContractRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryRegisteredContractResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryRegisteredContractResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryRegisteredContractResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractInfo", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.ContractInfo == nil { - m.ContractInfo = &ContractInfoV2{} - } - if err := m.ContractInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetOrdersRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetOrdersRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetOrdersRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Account", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Account = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetOrdersResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetOrdersResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetOrdersResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Orders", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Orders = append(m.Orders, &Order{}) - if err := m.Orders[len(m.Orders)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetOrderByIDRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetOrderByIDRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetOrderByIDRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Id", wireType) - } - m.Id = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Id |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetOrderByIDResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetOrderByIDResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetOrderByIDResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Order", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Order == nil { - m.Order = &Order{} - } - if err := m.Order.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetHistoricalPricesRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetHistoricalPricesRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetHistoricalPricesRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field PeriodLengthInSeconds", wireType) - } - m.PeriodLengthInSeconds = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.PeriodLengthInSeconds |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 5: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field NumOfPeriods", wireType) - } - m.NumOfPeriods = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.NumOfPeriods |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetHistoricalPricesResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetHistoricalPricesResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetHistoricalPricesResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Prices", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Prices = append(m.Prices, &PriceCandlestick{}) - if err := m.Prices[len(m.Prices)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetMarketSummaryRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetMarketSummaryRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetMarketSummaryRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field LookbackInSeconds", wireType) - } - m.LookbackInSeconds = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.LookbackInSeconds |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetMarketSummaryResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetMarketSummaryResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetMarketSummaryResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field TotalVolume", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.TotalVolume = &v - if err := m.TotalVolume.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field TotalVolumeNotional", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.TotalVolumeNotional = &v - if err := m.TotalVolumeNotional.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field HighPrice", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.HighPrice = &v - if err := m.HighPrice.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field LowPrice", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.LowPrice = &v - if err := m.LowPrice.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field LastPrice", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.LastPrice = &v - if err := m.LastPrice.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryOrderSimulationRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryOrderSimulationRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryOrderSimulationRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Order", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Order == nil { - m.Order = &Order{} - } - if err := m.Order.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryOrderSimulationResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryOrderSimulationResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryOrderSimulationResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ExecutedQuantity", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.ExecutedQuantity = &v - if err := m.ExecutedQuantity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetMatchResultRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetMatchResultRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetMatchResultRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetMatchResultResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetMatchResultResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetMatchResultResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Result", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthQuery - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Result == nil { - m.Result = &MatchResult{} - } - if err := m.Result.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetOrderCountRequest) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetOrderCountRequest: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetOrderCountRequest: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - 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 ErrInvalidLengthQuery - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthQuery - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var v github_com_cosmos_cosmos_sdk_types.Dec - m.Price = &v - if err := m.Price.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 5: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field PositionDirection", wireType) - } - m.PositionDirection = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.PositionDirection |= PositionDirection(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *QueryGetOrderCountResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: QueryGetOrderCountResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: QueryGetOrderCountResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Count", wireType) - } - m.Count = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowQuery - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Count |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipQuery(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthQuery - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipQuery(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowQuery - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowQuery - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowQuery - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthQuery - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupQuery - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthQuery - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthQuery = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowQuery = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupQuery = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/query.pb.gw.go b/x/dex/types/query.pb.gw.go deleted file mode 100644 index d7d13cf888..0000000000 --- a/x/dex/types/query.pb.gw.go +++ /dev/null @@ -1,2389 +0,0 @@ -// Code generated by protoc-gen-grpc-gateway. DO NOT EDIT. -// source: dex/query.proto - -/* -Package types is a reverse proxy. - -It translates gRPC into RESTful JSON APIs. -*/ -package types - -import ( - "context" - "io" - "net/http" - - "github.com/golang/protobuf/descriptor" - "github.com/golang/protobuf/proto" - "github.com/grpc-ecosystem/grpc-gateway/runtime" - "github.com/grpc-ecosystem/grpc-gateway/utilities" - "google.golang.org/grpc" - "google.golang.org/grpc/codes" - "google.golang.org/grpc/grpclog" - "google.golang.org/grpc/metadata" - "google.golang.org/grpc/status" -) - -// Suppress "imported and not used" errors -var _ codes.Code -var _ io.Reader -var _ status.Status -var _ = runtime.String -var _ = utilities.NewDoubleArray -var _ = descriptor.ForMessage -var _ = metadata.Join - -func request_Query_Params_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryParamsRequest - var metadata runtime.ServerMetadata - - msg, err := client.Params(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_Params_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryParamsRequest - var metadata runtime.ServerMetadata - - msg, err := server.Params(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_LongBook_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetLongBookRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["price"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "price") - } - - protoReq.Price, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "price", err) - } - - msg, err := client.LongBook(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_LongBook_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetLongBookRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["price"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "price") - } - - protoReq.Price, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "price", err) - } - - msg, err := server.LongBook(ctx, &protoReq) - return msg, metadata, err - -} - -var ( - filter_Query_LongBookAll_0 = &utilities.DoubleArray{Encoding: map[string]int{"contractAddr": 0, "priceDenom": 1, "assetDenom": 2}, Base: []int{1, 1, 2, 3, 0, 0, 0}, Check: []int{0, 1, 1, 1, 2, 3, 4}} -) - -func request_Query_LongBookAll_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryAllLongBookRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - if err := req.ParseForm(); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - if err := runtime.PopulateQueryParameters(&protoReq, req.Form, filter_Query_LongBookAll_0); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - - msg, err := client.LongBookAll(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_LongBookAll_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryAllLongBookRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - if err := req.ParseForm(); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - if err := runtime.PopulateQueryParameters(&protoReq, req.Form, filter_Query_LongBookAll_0); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - - msg, err := server.LongBookAll(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_ShortBook_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetShortBookRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["price"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "price") - } - - protoReq.Price, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "price", err) - } - - msg, err := client.ShortBook(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_ShortBook_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetShortBookRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["price"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "price") - } - - protoReq.Price, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "price", err) - } - - msg, err := server.ShortBook(ctx, &protoReq) - return msg, metadata, err - -} - -var ( - filter_Query_ShortBookAll_0 = &utilities.DoubleArray{Encoding: map[string]int{"contractAddr": 0, "priceDenom": 1, "assetDenom": 2}, Base: []int{1, 1, 2, 3, 0, 0, 0}, Check: []int{0, 1, 1, 1, 2, 3, 4}} -) - -func request_Query_ShortBookAll_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryAllShortBookRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - if err := req.ParseForm(); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - if err := runtime.PopulateQueryParameters(&protoReq, req.Form, filter_Query_ShortBookAll_0); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - - msg, err := client.ShortBookAll(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_ShortBookAll_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryAllShortBookRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - if err := req.ParseForm(); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - if err := runtime.PopulateQueryParameters(&protoReq, req.Form, filter_Query_ShortBookAll_0); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - - msg, err := server.ShortBookAll(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_GetPrice_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetPriceRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["timestamp"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "timestamp") - } - - protoReq.Timestamp, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "timestamp", err) - } - - msg, err := client.GetPrice(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_GetPrice_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetPriceRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["timestamp"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "timestamp") - } - - protoReq.Timestamp, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "timestamp", err) - } - - msg, err := server.GetPrice(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_GetLatestPrice_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetLatestPriceRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - msg, err := client.GetLatestPrice(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_GetLatestPrice_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetLatestPriceRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - msg, err := server.GetLatestPrice(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_GetPrices_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetPricesRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - msg, err := client.GetPrices(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_GetPrices_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetPricesRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - msg, err := server.GetPrices(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_GetTwaps_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetTwapsRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["lookbackSeconds"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "lookbackSeconds") - } - - protoReq.LookbackSeconds, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "lookbackSeconds", err) - } - - msg, err := client.GetTwaps(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_GetTwaps_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetTwapsRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["lookbackSeconds"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "lookbackSeconds") - } - - protoReq.LookbackSeconds, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "lookbackSeconds", err) - } - - msg, err := server.GetTwaps(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_AssetMetadata_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryAssetMetadataRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["denom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "denom") - } - - protoReq.Denom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "denom", err) - } - - msg, err := client.AssetMetadata(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_AssetMetadata_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryAssetMetadataRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["denom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "denom") - } - - protoReq.Denom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "denom", err) - } - - msg, err := server.AssetMetadata(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_AssetList_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryAssetListRequest - var metadata runtime.ServerMetadata - - msg, err := client.AssetList(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_AssetList_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryAssetListRequest - var metadata runtime.ServerMetadata - - msg, err := server.AssetList(ctx, &protoReq) - return msg, metadata, err - -} - -var ( - filter_Query_GetRegisteredPairs_0 = &utilities.DoubleArray{Encoding: map[string]int{}, Base: []int(nil), Check: []int(nil)} -) - -func request_Query_GetRegisteredPairs_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryRegisteredPairsRequest - var metadata runtime.ServerMetadata - - if err := req.ParseForm(); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - if err := runtime.PopulateQueryParameters(&protoReq, req.Form, filter_Query_GetRegisteredPairs_0); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - - msg, err := client.GetRegisteredPairs(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_GetRegisteredPairs_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryRegisteredPairsRequest - var metadata runtime.ServerMetadata - - if err := req.ParseForm(); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - if err := runtime.PopulateQueryParameters(&protoReq, req.Form, filter_Query_GetRegisteredPairs_0); err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "%v", err) - } - - msg, err := server.GetRegisteredPairs(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_GetRegisteredContract_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryRegisteredContractRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - msg, err := client.GetRegisteredContract(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_GetRegisteredContract_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryRegisteredContractRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - msg, err := server.GetRegisteredContract(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_GetOrders_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetOrdersRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["account"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "account") - } - - protoReq.Account, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "account", err) - } - - msg, err := client.GetOrders(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_GetOrders_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetOrdersRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["account"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "account") - } - - protoReq.Account, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "account", err) - } - - msg, err := server.GetOrders(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_GetOrder_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetOrderByIDRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["id"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "id") - } - - protoReq.Id, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "id", err) - } - - msg, err := client.GetOrder(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_GetOrder_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetOrderByIDRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["id"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "id") - } - - protoReq.Id, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "id", err) - } - - msg, err := server.GetOrder(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_GetHistoricalPrices_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetHistoricalPricesRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["periodLengthInSeconds"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "periodLengthInSeconds") - } - - protoReq.PeriodLengthInSeconds, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "periodLengthInSeconds", err) - } - - val, ok = pathParams["numOfPeriods"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "numOfPeriods") - } - - protoReq.NumOfPeriods, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "numOfPeriods", err) - } - - msg, err := client.GetHistoricalPrices(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_GetHistoricalPrices_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetHistoricalPricesRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["periodLengthInSeconds"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "periodLengthInSeconds") - } - - protoReq.PeriodLengthInSeconds, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "periodLengthInSeconds", err) - } - - val, ok = pathParams["numOfPeriods"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "numOfPeriods") - } - - protoReq.NumOfPeriods, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "numOfPeriods", err) - } - - msg, err := server.GetHistoricalPrices(ctx, &protoReq) - return msg, metadata, err - -} - -func request_Query_GetMarketSummary_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetMarketSummaryRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["lookbackInSeconds"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "lookbackInSeconds") - } - - protoReq.LookbackInSeconds, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "lookbackInSeconds", err) - } - - msg, err := client.GetMarketSummary(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) - return msg, metadata, err - -} - -func local_request_Query_GetMarketSummary_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { - var protoReq QueryGetMarketSummaryRequest - var metadata runtime.ServerMetadata - - var ( - val string - ok bool - err error - _ = err - ) - - val, ok = pathParams["contractAddr"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "contractAddr") - } - - protoReq.ContractAddr, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "contractAddr", err) - } - - val, ok = pathParams["priceDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "priceDenom") - } - - protoReq.PriceDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "priceDenom", err) - } - - val, ok = pathParams["assetDenom"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "assetDenom") - } - - protoReq.AssetDenom, err = runtime.String(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "assetDenom", err) - } - - val, ok = pathParams["lookbackInSeconds"] - if !ok { - return nil, metadata, status.Errorf(codes.InvalidArgument, "missing parameter %s", "lookbackInSeconds") - } - - protoReq.LookbackInSeconds, err = runtime.Uint64(val) - - if err != nil { - return nil, metadata, status.Errorf(codes.InvalidArgument, "type mismatch, parameter: %s, error: %v", "lookbackInSeconds", err) - } - - msg, err := server.GetMarketSummary(ctx, &protoReq) - return msg, metadata, err - -} - -// RegisterQueryHandlerServer registers the http handlers for service Query to "mux". -// UnaryRPC :call QueryServer directly. -// StreamingRPC :currently unsupported pending https://github.com/grpc/grpc-go/issues/906. -// Note that using this registration option will cause many gRPC library features to stop working. Consider using RegisterQueryHandlerFromEndpoint instead. -func RegisterQueryHandlerServer(ctx context.Context, mux *runtime.ServeMux, server QueryServer) error { - - mux.Handle("GET", pattern_Query_Params_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_Params_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_Params_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_LongBook_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_LongBook_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_LongBook_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_LongBookAll_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_LongBookAll_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_LongBookAll_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_ShortBook_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_ShortBook_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_ShortBook_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_ShortBookAll_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_ShortBookAll_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_ShortBookAll_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetPrice_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_GetPrice_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetPrice_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetLatestPrice_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_GetLatestPrice_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetLatestPrice_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetPrices_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_GetPrices_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetPrices_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetTwaps_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_GetTwaps_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetTwaps_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_AssetMetadata_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_AssetMetadata_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_AssetMetadata_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_AssetList_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_AssetList_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_AssetList_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetRegisteredPairs_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_GetRegisteredPairs_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetRegisteredPairs_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetRegisteredContract_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_GetRegisteredContract_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetRegisteredContract_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetOrders_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_GetOrders_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetOrders_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetOrder_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_GetOrder_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetOrder_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetHistoricalPrices_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_GetHistoricalPrices_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetHistoricalPrices_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetMarketSummary_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - var stream runtime.ServerTransportStream - ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := local_request_Query_GetMarketSummary_0(rctx, inboundMarshaler, server, req, pathParams) - md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetMarketSummary_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - return nil -} - -// RegisterQueryHandlerFromEndpoint is same as RegisterQueryHandler but -// automatically dials to "endpoint" and closes the connection when "ctx" gets done. -func RegisterQueryHandlerFromEndpoint(ctx context.Context, mux *runtime.ServeMux, endpoint string, opts []grpc.DialOption) (err error) { - conn, err := grpc.Dial(endpoint, opts...) - if err != nil { - return err - } - defer func() { - if err != nil { - if cerr := conn.Close(); cerr != nil { - grpclog.Infof("Failed to close conn to %s: %v", endpoint, cerr) - } - return - } - go func() { - <-ctx.Done() - if cerr := conn.Close(); cerr != nil { - grpclog.Infof("Failed to close conn to %s: %v", endpoint, cerr) - } - }() - }() - - return RegisterQueryHandler(ctx, mux, conn) -} - -// RegisterQueryHandler registers the http handlers for service Query to "mux". -// The handlers forward requests to the grpc endpoint over "conn". -func RegisterQueryHandler(ctx context.Context, mux *runtime.ServeMux, conn *grpc.ClientConn) error { - return RegisterQueryHandlerClient(ctx, mux, NewQueryClient(conn)) -} - -// RegisterQueryHandlerClient registers the http handlers for service Query -// to "mux". The handlers forward requests to the grpc endpoint over the given implementation of "QueryClient". -// Note: the gRPC framework executes interceptors within the gRPC handler. If the passed in "QueryClient" -// doesn't go through the normal gRPC flow (creating a gRPC client etc.) then it will be up to the passed in -// "QueryClient" to call the correct interceptors. -func RegisterQueryHandlerClient(ctx context.Context, mux *runtime.ServeMux, client QueryClient) error { - - mux.Handle("GET", pattern_Query_Params_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_Params_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_Params_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_LongBook_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_LongBook_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_LongBook_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_LongBookAll_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_LongBookAll_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_LongBookAll_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_ShortBook_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_ShortBook_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_ShortBook_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_ShortBookAll_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_ShortBookAll_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_ShortBookAll_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetPrice_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_GetPrice_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetPrice_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetLatestPrice_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_GetLatestPrice_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetLatestPrice_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetPrices_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_GetPrices_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetPrices_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetTwaps_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_GetTwaps_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetTwaps_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_AssetMetadata_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_AssetMetadata_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_AssetMetadata_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_AssetList_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_AssetList_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_AssetList_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetRegisteredPairs_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_GetRegisteredPairs_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetRegisteredPairs_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetRegisteredContract_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_GetRegisteredContract_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetRegisteredContract_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetOrders_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_GetOrders_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetOrders_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetOrder_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_GetOrder_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetOrder_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetHistoricalPrices_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_GetHistoricalPrices_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetHistoricalPrices_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - mux.Handle("GET", pattern_Query_GetMarketSummary_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { - ctx, cancel := context.WithCancel(req.Context()) - defer cancel() - inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) - rctx, err := runtime.AnnotateContext(ctx, mux, req) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - resp, md, err := request_Query_GetMarketSummary_0(rctx, inboundMarshaler, client, req, pathParams) - ctx = runtime.NewServerMetadataContext(ctx, md) - if err != nil { - runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) - return - } - - forward_Query_GetMarketSummary_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) - - }) - - return nil -} - -var ( - pattern_Query_Params_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3}, []string{"sei-protocol", "seichain", "dex", "params"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_LongBook_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5, 1, 0, 4, 1, 5, 6, 1, 0, 4, 1, 5, 7}, []string{"sei-protocol", "seichain", "dex", "long_book", "contractAddr", "priceDenom", "assetDenom", "price"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_LongBookAll_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5, 1, 0, 4, 1, 5, 6}, []string{"sei-protocol", "seichain", "dex", "long_book", "contractAddr", "priceDenom", "assetDenom"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_ShortBook_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5, 1, 0, 4, 1, 5, 6, 1, 0, 4, 1, 5, 7}, []string{"sei-protocol", "seichain", "dex", "short_book", "contractAddr", "priceDenom", "assetDenom", "price"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_ShortBookAll_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5, 1, 0, 4, 1, 5, 6}, []string{"sei-protocol", "seichain", "dex", "short_book", "contractAddr", "priceDenom", "assetDenom"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_GetPrice_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5, 1, 0, 4, 1, 5, 6, 1, 0, 4, 1, 5, 7}, []string{"sei-protocol", "seichain", "dex", "get_price", "contractAddr", "priceDenom", "assetDenom", "timestamp"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_GetLatestPrice_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5, 1, 0, 4, 1, 5, 6}, []string{"sei-protocol", "seichain", "dex", "get_latest_price", "contractAddr", "priceDenom", "assetDenom"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_GetPrices_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5, 1, 0, 4, 1, 5, 6}, []string{"sei-protocol", "seichain", "dex", "get_prices", "contractAddr", "priceDenom", "assetDenom"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_GetTwaps_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5}, []string{"sei-protocol", "seichain", "dex", "get_twaps", "contractAddr", "lookbackSeconds"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_AssetMetadata_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4}, []string{"sei-protocol", "seichain", "dex", "asset_list", "denom"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_AssetList_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3}, []string{"sei-protocol", "seichain", "dex", "asset_list"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_GetRegisteredPairs_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3}, []string{"sei-protocol", "seichain", "dex", "registered_pairs"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_GetRegisteredContract_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4}, []string{"sei-protocol", "seichain", "dex", "registered_contract", "contractAddr"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_GetOrders_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5}, []string{"sei-protocol", "seichain", "dex", "get_orders", "contractAddr", "account"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_GetOrder_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5, 1, 0, 4, 1, 5, 6, 1, 0, 4, 1, 5, 7}, []string{"sei-protocol", "seichain", "dex", "get_order_by_id", "contractAddr", "priceDenom", "assetDenom", "id"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_GetHistoricalPrices_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5, 1, 0, 4, 1, 5, 6, 1, 0, 4, 1, 5, 7, 1, 0, 4, 1, 5, 8}, []string{"sei-protocol", "seichain", "dex", "get_historical_prices", "contractAddr", "priceDenom", "assetDenom", "periodLengthInSeconds", "numOfPeriods"}, "", runtime.AssumeColonVerbOpt(true))) - - pattern_Query_GetMarketSummary_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4, 1, 0, 4, 1, 5, 5, 1, 0, 4, 1, 5, 6, 1, 0, 4, 1, 5, 7}, []string{"sei-protocol", "seichain", "dex", "get_market_summary", "contractAddr", "priceDenom", "assetDenom", "lookbackInSeconds"}, "", runtime.AssumeColonVerbOpt(true))) -) - -var ( - forward_Query_Params_0 = runtime.ForwardResponseMessage - - forward_Query_LongBook_0 = runtime.ForwardResponseMessage - - forward_Query_LongBookAll_0 = runtime.ForwardResponseMessage - - forward_Query_ShortBook_0 = runtime.ForwardResponseMessage - - forward_Query_ShortBookAll_0 = runtime.ForwardResponseMessage - - forward_Query_GetPrice_0 = runtime.ForwardResponseMessage - - forward_Query_GetLatestPrice_0 = runtime.ForwardResponseMessage - - forward_Query_GetPrices_0 = runtime.ForwardResponseMessage - - forward_Query_GetTwaps_0 = runtime.ForwardResponseMessage - - forward_Query_AssetMetadata_0 = runtime.ForwardResponseMessage - - forward_Query_AssetList_0 = runtime.ForwardResponseMessage - - forward_Query_GetRegisteredPairs_0 = runtime.ForwardResponseMessage - - forward_Query_GetRegisteredContract_0 = runtime.ForwardResponseMessage - - forward_Query_GetOrders_0 = runtime.ForwardResponseMessage - - forward_Query_GetOrder_0 = runtime.ForwardResponseMessage - - forward_Query_GetHistoricalPrices_0 = runtime.ForwardResponseMessage - - forward_Query_GetMarketSummary_0 = runtime.ForwardResponseMessage -) diff --git a/x/dex/types/settlement.go b/x/dex/types/settlement.go deleted file mode 100644 index ee3d3378ec..0000000000 --- a/x/dex/types/settlement.go +++ /dev/null @@ -1,36 +0,0 @@ -package types - -import ( - sdk "github.com/cosmos/cosmos-sdk/types" -) - -type SudoSettlementMsg struct { - Settlement Settlements `json:"settlement"` -} - -func NewSettlementEntry( - ctx sdk.Context, - orderID uint64, - account string, - direction PositionDirection, - priceDenom string, - assetDenom string, - quantity sdk.Dec, - executionCostOrProceed sdk.Dec, - expectedCostOrProceed sdk.Dec, - orderType OrderType, -) *SettlementEntry { - return &SettlementEntry{ - OrderId: orderID, - PositionDirection: GetContractPositionDirection(direction), - PriceDenom: priceDenom, - AssetDenom: assetDenom, - Quantity: quantity, - ExecutionCostOrProceed: executionCostOrProceed, - ExpectedCostOrProceed: expectedCostOrProceed, - Account: account, - OrderType: GetContractOrderType(orderType), - Timestamp: uint64(ctx.BlockTime().Unix()), - Height: uint64(ctx.BlockHeight()), - } -} diff --git a/x/dex/types/settlement.pb.go b/x/dex/types/settlement.pb.go deleted file mode 100644 index 0df73a0ccc..0000000000 --- a/x/dex/types/settlement.pb.go +++ /dev/null @@ -1,1044 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/settlement.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type SettlementEntry struct { - Account string `protobuf:"bytes,1,opt,name=account,proto3" json:"account"` - PriceDenom string `protobuf:"bytes,2,opt,name=priceDenom,proto3" json:"price_denom"` - AssetDenom string `protobuf:"bytes,3,opt,name=assetDenom,proto3" json:"asset_denom"` - Quantity github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,4,opt,name=quantity,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"quantity" yaml:"quantity"` - ExecutionCostOrProceed github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,5,opt,name=executionCostOrProceed,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"execution_cost_or_proceed" yaml:"execution_cost_or_proceed"` - ExpectedCostOrProceed github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,6,opt,name=expectedCostOrProceed,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"expected_cost_or_proceed" yaml:"expected_cost_or_proceed"` - PositionDirection string `protobuf:"bytes,7,opt,name=positionDirection,proto3" json:"position_direction"` - OrderType string `protobuf:"bytes,8,opt,name=orderType,proto3" json:"order_type"` - OrderId uint64 `protobuf:"varint,9,opt,name=orderId,proto3" json:"order_id"` - Timestamp uint64 `protobuf:"varint,10,opt,name=timestamp,proto3" json:"timestamp"` - Height uint64 `protobuf:"varint,11,opt,name=height,proto3" json:"height"` - SettlementId uint64 `protobuf:"varint,12,opt,name=settlementId,proto3" json:"settlement_id"` -} - -func (m *SettlementEntry) Reset() { *m = SettlementEntry{} } -func (m *SettlementEntry) String() string { return proto.CompactTextString(m) } -func (*SettlementEntry) ProtoMessage() {} -func (*SettlementEntry) Descriptor() ([]byte, []int) { - return fileDescriptor_c24d83c09612bb1c, []int{0} -} -func (m *SettlementEntry) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *SettlementEntry) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_SettlementEntry.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *SettlementEntry) XXX_Merge(src proto.Message) { - xxx_messageInfo_SettlementEntry.Merge(m, src) -} -func (m *SettlementEntry) XXX_Size() int { - return m.Size() -} -func (m *SettlementEntry) XXX_DiscardUnknown() { - xxx_messageInfo_SettlementEntry.DiscardUnknown(m) -} - -var xxx_messageInfo_SettlementEntry proto.InternalMessageInfo - -func (m *SettlementEntry) GetAccount() string { - if m != nil { - return m.Account - } - return "" -} - -func (m *SettlementEntry) GetPriceDenom() string { - if m != nil { - return m.PriceDenom - } - return "" -} - -func (m *SettlementEntry) GetAssetDenom() string { - if m != nil { - return m.AssetDenom - } - return "" -} - -func (m *SettlementEntry) GetPositionDirection() string { - if m != nil { - return m.PositionDirection - } - return "" -} - -func (m *SettlementEntry) GetOrderType() string { - if m != nil { - return m.OrderType - } - return "" -} - -func (m *SettlementEntry) GetOrderId() uint64 { - if m != nil { - return m.OrderId - } - return 0 -} - -func (m *SettlementEntry) GetTimestamp() uint64 { - if m != nil { - return m.Timestamp - } - return 0 -} - -func (m *SettlementEntry) GetHeight() uint64 { - if m != nil { - return m.Height - } - return 0 -} - -func (m *SettlementEntry) GetSettlementId() uint64 { - if m != nil { - return m.SettlementId - } - return 0 -} - -type Settlements struct { - Epoch int64 `protobuf:"varint,1,opt,name=epoch,proto3" json:"epoch"` - Entries []*SettlementEntry `protobuf:"bytes,2,rep,name=entries,proto3" json:"entries"` -} - -func (m *Settlements) Reset() { *m = Settlements{} } -func (m *Settlements) String() string { return proto.CompactTextString(m) } -func (*Settlements) ProtoMessage() {} -func (*Settlements) Descriptor() ([]byte, []int) { - return fileDescriptor_c24d83c09612bb1c, []int{1} -} -func (m *Settlements) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *Settlements) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_Settlements.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *Settlements) XXX_Merge(src proto.Message) { - xxx_messageInfo_Settlements.Merge(m, src) -} -func (m *Settlements) XXX_Size() int { - return m.Size() -} -func (m *Settlements) XXX_DiscardUnknown() { - xxx_messageInfo_Settlements.DiscardUnknown(m) -} - -var xxx_messageInfo_Settlements proto.InternalMessageInfo - -func (m *Settlements) GetEpoch() int64 { - if m != nil { - return m.Epoch - } - return 0 -} - -func (m *Settlements) GetEntries() []*SettlementEntry { - if m != nil { - return m.Entries - } - return nil -} - -func init() { - proto.RegisterType((*SettlementEntry)(nil), "seiprotocol.seichain.dex.SettlementEntry") - proto.RegisterType((*Settlements)(nil), "seiprotocol.seichain.dex.Settlements") -} - -func init() { proto.RegisterFile("dex/settlement.proto", fileDescriptor_c24d83c09612bb1c) } - -var fileDescriptor_c24d83c09612bb1c = []byte{ - // 584 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x94, 0x94, 0x3f, 0x6f, 0xdb, 0x3c, - 0x10, 0xc6, 0xad, 0xfc, 0xb1, 0x63, 0x3a, 0x79, 0x83, 0x10, 0x79, 0x03, 0xb6, 0x83, 0x68, 0x08, - 0x68, 0x90, 0xa2, 0x8d, 0x04, 0xb4, 0xe8, 0xd2, 0xd1, 0x75, 0x51, 0x64, 0x28, 0x1a, 0xb0, 0x9d, - 0xba, 0x08, 0x0a, 0x75, 0xb0, 0x89, 0x46, 0xa2, 0x2a, 0xd2, 0x80, 0xbd, 0xf5, 0x23, 0xf4, 0x3b, - 0x74, 0xe8, 0x57, 0xc9, 0x98, 0xb1, 0xe8, 0x40, 0x14, 0xc9, 0xa6, 0x31, 0x5b, 0xb7, 0x42, 0x94, - 0x65, 0x25, 0xad, 0x3d, 0x64, 0xe2, 0xf1, 0xb9, 0xdf, 0xdd, 0x3d, 0x86, 0x79, 0x42, 0xfb, 0x31, - 0x4c, 0x03, 0x05, 0x5a, 0x9f, 0x43, 0x02, 0xa9, 0xf6, 0xb3, 0x5c, 0x6a, 0x89, 0x89, 0x02, 0x61, - 0x23, 0x2e, 0xcf, 0x7d, 0x05, 0x82, 0x8f, 0x23, 0x91, 0xfa, 0x31, 0x4c, 0x1f, 0xee, 0x8f, 0xe4, - 0x48, 0xda, 0x54, 0x50, 0x46, 0x15, 0xef, 0xfd, 0x6e, 0xa3, 0xdd, 0xf7, 0x8b, 0x26, 0xaf, 0x53, - 0x9d, 0xcf, 0xf0, 0x23, 0xd4, 0x89, 0x38, 0x97, 0x93, 0x54, 0x13, 0xa7, 0xef, 0x1c, 0x75, 0x07, - 0xbd, 0xc2, 0xd0, 0x5a, 0x62, 0x75, 0x80, 0x03, 0x84, 0xb2, 0x5c, 0x70, 0x18, 0x42, 0x2a, 0x13, - 0xb2, 0x66, 0xc9, 0xdd, 0xc2, 0xd0, 0x9e, 0x55, 0xc3, 0xb8, 0x94, 0xd9, 0x2d, 0xa4, 0x2c, 0x88, - 0x94, 0x02, 0x5d, 0x15, 0xac, 0x37, 0x05, 0x56, 0xad, 0x0b, 0x1a, 0x04, 0x0b, 0xb4, 0xf5, 0x79, - 0x12, 0xa5, 0x5a, 0xe8, 0x19, 0xd9, 0xb0, 0xf8, 0xdb, 0x0b, 0x43, 0x5b, 0x3f, 0x0d, 0x3d, 0x1c, - 0x09, 0x3d, 0x9e, 0x9c, 0xf9, 0x5c, 0x26, 0x01, 0x97, 0x2a, 0x91, 0x6a, 0x7e, 0x1c, 0xab, 0xf8, - 0x53, 0xa0, 0x67, 0x19, 0x28, 0x7f, 0x08, 0xbc, 0x30, 0x74, 0xd1, 0xe1, 0xc6, 0xd0, 0xdd, 0x59, - 0x94, 0x9c, 0xbf, 0xf4, 0x6a, 0xc5, 0x63, 0x8b, 0x24, 0xfe, 0xee, 0xa0, 0x03, 0x98, 0x02, 0x9f, - 0x68, 0x21, 0xd3, 0x57, 0x52, 0xe9, 0x77, 0xf9, 0x69, 0x2e, 0x39, 0x40, 0x4c, 0x36, 0xed, 0x64, - 0x79, 0xef, 0xc9, 0x0f, 0x16, 0xfd, 0x42, 0x2e, 0x95, 0x0e, 0x65, 0x1e, 0x66, 0x55, 0xcb, 0x1b, - 0x43, 0xfb, 0x95, 0x95, 0x95, 0x88, 0xc7, 0x56, 0xd8, 0xc1, 0xdf, 0x1c, 0xf4, 0x3f, 0x4c, 0x33, - 0xe0, 0x1a, 0xe2, 0xbb, 0x46, 0xdb, 0xd6, 0x68, 0x72, 0x6f, 0xa3, 0xa4, 0x6e, 0xb7, 0xc4, 0x27, - 0xad, 0x7d, 0x2e, 0x27, 0x3c, 0xb6, 0xdc, 0x0b, 0x1e, 0xa2, 0xbd, 0x4c, 0x2a, 0x51, 0xda, 0x1f, - 0x8a, 0x1c, 0x78, 0x19, 0x90, 0x8e, 0x35, 0x78, 0x50, 0x18, 0x8a, 0xeb, 0x64, 0x18, 0xd7, 0x59, - 0xf6, 0x6f, 0x01, 0x7e, 0x8a, 0xba, 0x32, 0x8f, 0x21, 0xff, 0x30, 0xcb, 0x80, 0x6c, 0xd9, 0xea, - 0xff, 0x0a, 0x43, 0x91, 0x15, 0xc3, 0xf2, 0x37, 0xb0, 0x06, 0xc0, 0x87, 0xa8, 0x63, 0x2f, 0x27, - 0x31, 0xe9, 0xf6, 0x9d, 0xa3, 0x8d, 0xc1, 0x76, 0xf9, 0xff, 0x57, 0xac, 0x88, 0x59, 0x9d, 0xc4, - 0x4f, 0x50, 0x57, 0x8b, 0x04, 0x94, 0x8e, 0x92, 0x8c, 0x20, 0x4b, 0xee, 0x14, 0x86, 0x36, 0x22, - 0x6b, 0x42, 0xec, 0xa1, 0xf6, 0x18, 0xc4, 0x68, 0xac, 0x49, 0xcf, 0x92, 0xa8, 0x30, 0x74, 0xae, - 0xb0, 0xf9, 0x89, 0x5f, 0xa0, 0xed, 0x66, 0x11, 0x4f, 0x62, 0xb2, 0x6d, 0xc9, 0xbd, 0xc2, 0xd0, - 0x9d, 0x46, 0x2f, 0x2d, 0xdc, 0xc1, 0xbc, 0x2f, 0x0e, 0xea, 0x35, 0xbb, 0xa7, 0x30, 0x45, 0x9b, - 0x90, 0x49, 0x3e, 0xb6, 0x5b, 0xb7, 0x3e, 0xe8, 0x16, 0x86, 0x56, 0x02, 0xab, 0x0e, 0x7c, 0x8a, - 0x3a, 0x90, 0xea, 0x5c, 0x80, 0x22, 0x6b, 0xfd, 0xf5, 0xa3, 0xde, 0xb3, 0xc7, 0xfe, 0xaa, 0x75, - 0xf7, 0xff, 0x5a, 0xea, 0x6a, 0x87, 0xe7, 0xd5, 0xac, 0x0e, 0x06, 0x6f, 0x2e, 0xae, 0x5c, 0xe7, - 0xf2, 0xca, 0x75, 0x7e, 0x5d, 0xb9, 0xce, 0xd7, 0x6b, 0xb7, 0x75, 0x79, 0xed, 0xb6, 0x7e, 0x5c, - 0xbb, 0xad, 0x8f, 0xc7, 0xb7, 0x9e, 0x8f, 0x02, 0x71, 0x5c, 0x4f, 0xb1, 0x17, 0x3b, 0x26, 0x98, - 0x06, 0xe5, 0x27, 0xc8, 0xbe, 0xa4, 0xb3, 0xb6, 0xcd, 0x3f, 0xff, 0x13, 0x00, 0x00, 0xff, 0xff, - 0x07, 0xa3, 0x0d, 0xb2, 0x96, 0x04, 0x00, 0x00, -} - -func (m *SettlementEntry) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *SettlementEntry) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *SettlementEntry) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.SettlementId != 0 { - i = encodeVarintSettlement(dAtA, i, uint64(m.SettlementId)) - i-- - dAtA[i] = 0x60 - } - if m.Height != 0 { - i = encodeVarintSettlement(dAtA, i, uint64(m.Height)) - i-- - dAtA[i] = 0x58 - } - if m.Timestamp != 0 { - i = encodeVarintSettlement(dAtA, i, uint64(m.Timestamp)) - i-- - dAtA[i] = 0x50 - } - if m.OrderId != 0 { - i = encodeVarintSettlement(dAtA, i, uint64(m.OrderId)) - i-- - dAtA[i] = 0x48 - } - if len(m.OrderType) > 0 { - i -= len(m.OrderType) - copy(dAtA[i:], m.OrderType) - i = encodeVarintSettlement(dAtA, i, uint64(len(m.OrderType))) - i-- - dAtA[i] = 0x42 - } - if len(m.PositionDirection) > 0 { - i -= len(m.PositionDirection) - copy(dAtA[i:], m.PositionDirection) - i = encodeVarintSettlement(dAtA, i, uint64(len(m.PositionDirection))) - i-- - dAtA[i] = 0x3a - } - { - size := m.ExpectedCostOrProceed.Size() - i -= size - if _, err := m.ExpectedCostOrProceed.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintSettlement(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x32 - { - size := m.ExecutionCostOrProceed.Size() - i -= size - if _, err := m.ExecutionCostOrProceed.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintSettlement(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x2a - { - size := m.Quantity.Size() - i -= size - if _, err := m.Quantity.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintSettlement(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x22 - if len(m.AssetDenom) > 0 { - i -= len(m.AssetDenom) - copy(dAtA[i:], m.AssetDenom) - i = encodeVarintSettlement(dAtA, i, uint64(len(m.AssetDenom))) - i-- - dAtA[i] = 0x1a - } - if len(m.PriceDenom) > 0 { - i -= len(m.PriceDenom) - copy(dAtA[i:], m.PriceDenom) - i = encodeVarintSettlement(dAtA, i, uint64(len(m.PriceDenom))) - i-- - dAtA[i] = 0x12 - } - if len(m.Account) > 0 { - i -= len(m.Account) - copy(dAtA[i:], m.Account) - i = encodeVarintSettlement(dAtA, i, uint64(len(m.Account))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *Settlements) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *Settlements) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *Settlements) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Entries) > 0 { - for iNdEx := len(m.Entries) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Entries[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintSettlement(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - } - if m.Epoch != 0 { - i = encodeVarintSettlement(dAtA, i, uint64(m.Epoch)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - -func encodeVarintSettlement(dAtA []byte, offset int, v uint64) int { - offset -= sovSettlement(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *SettlementEntry) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Account) - if l > 0 { - n += 1 + l + sovSettlement(uint64(l)) - } - l = len(m.PriceDenom) - if l > 0 { - n += 1 + l + sovSettlement(uint64(l)) - } - l = len(m.AssetDenom) - if l > 0 { - n += 1 + l + sovSettlement(uint64(l)) - } - l = m.Quantity.Size() - n += 1 + l + sovSettlement(uint64(l)) - l = m.ExecutionCostOrProceed.Size() - n += 1 + l + sovSettlement(uint64(l)) - l = m.ExpectedCostOrProceed.Size() - n += 1 + l + sovSettlement(uint64(l)) - l = len(m.PositionDirection) - if l > 0 { - n += 1 + l + sovSettlement(uint64(l)) - } - l = len(m.OrderType) - if l > 0 { - n += 1 + l + sovSettlement(uint64(l)) - } - if m.OrderId != 0 { - n += 1 + sovSettlement(uint64(m.OrderId)) - } - if m.Timestamp != 0 { - n += 1 + sovSettlement(uint64(m.Timestamp)) - } - if m.Height != 0 { - n += 1 + sovSettlement(uint64(m.Height)) - } - if m.SettlementId != 0 { - n += 1 + sovSettlement(uint64(m.SettlementId)) - } - return n -} - -func (m *Settlements) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Epoch != 0 { - n += 1 + sovSettlement(uint64(m.Epoch)) - } - if len(m.Entries) > 0 { - for _, e := range m.Entries { - l = e.Size() - n += 1 + l + sovSettlement(uint64(l)) - } - } - return n -} - -func sovSettlement(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozSettlement(x uint64) (n int) { - return sovSettlement(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *SettlementEntry) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: SettlementEntry: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: SettlementEntry: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Account", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - 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 ErrInvalidLengthSettlement - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSettlement - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Account = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PriceDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - 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 ErrInvalidLengthSettlement - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSettlement - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PriceDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field AssetDenom", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - 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 ErrInvalidLengthSettlement - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSettlement - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.AssetDenom = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Quantity", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - 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 ErrInvalidLengthSettlement - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSettlement - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Quantity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 5: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ExecutionCostOrProceed", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - 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 ErrInvalidLengthSettlement - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSettlement - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.ExecutionCostOrProceed.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 6: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ExpectedCostOrProceed", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - 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 ErrInvalidLengthSettlement - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSettlement - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.ExpectedCostOrProceed.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 7: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field PositionDirection", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - 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 ErrInvalidLengthSettlement - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSettlement - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.PositionDirection = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 8: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field OrderType", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - 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 ErrInvalidLengthSettlement - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthSettlement - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.OrderType = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 9: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field OrderId", wireType) - } - m.OrderId = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.OrderId |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 10: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Timestamp", wireType) - } - m.Timestamp = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Timestamp |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 11: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Height", wireType) - } - m.Height = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Height |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 12: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field SettlementId", wireType) - } - m.SettlementId = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.SettlementId |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipSettlement(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthSettlement - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *Settlements) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: Settlements: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: Settlements: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Epoch", wireType) - } - m.Epoch = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Epoch |= int64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Entries", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowSettlement - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthSettlement - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthSettlement - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.Entries = append(m.Entries, &SettlementEntry{}) - if err := m.Entries[len(m.Entries)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipSettlement(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthSettlement - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipSettlement(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowSettlement - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowSettlement - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowSettlement - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthSettlement - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupSettlement - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthSettlement - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthSettlement = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowSettlement = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupSettlement = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/settlement_test.go b/x/dex/types/settlement_test.go deleted file mode 100644 index 245e33d052..0000000000 --- a/x/dex/types/settlement_test.go +++ /dev/null @@ -1,31 +0,0 @@ -package types_test - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - "github.com/sei-protocol/sei-chain/x/dex/types" - "github.com/stretchr/testify/require" -) - -func TestNewSettlementEntry(t *testing.T) { - _, ctx := keepertest.DexKeeper(t) - ctx = ctx.WithBlockHeight(100) - sudoFinalizeBlockMsg := types.NewSettlementEntry( - ctx, - 1, - "TEST_ACCOUNT", - types.PositionDirection_LONG, - "USDC", - "ATOM", - sdk.MustNewDecFromStr("1"), - sdk.MustNewDecFromStr("2"), - sdk.MustNewDecFromStr("3"), - types.OrderType_MARKET, - ) - - require.Equal(t, "Long", sudoFinalizeBlockMsg.PositionDirection) - require.Equal(t, "Market", sudoFinalizeBlockMsg.OrderType) - require.Equal(t, uint64(100), sudoFinalizeBlockMsg.Height) -} diff --git a/x/dex/types/short_book.pb.go b/x/dex/types/short_book.pb.go deleted file mode 100644 index 83c969121d..0000000000 --- a/x/dex/types/short_book.pb.go +++ /dev/null @@ -1,380 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/short_book.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type ShortBook struct { - Price github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,1,opt,name=price,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"price" yaml:"price"` - Entry *OrderEntry `protobuf:"bytes,2,opt,name=entry,proto3" json:"entry"` -} - -func (m *ShortBook) Reset() { *m = ShortBook{} } -func (m *ShortBook) String() string { return proto.CompactTextString(m) } -func (*ShortBook) ProtoMessage() {} -func (*ShortBook) Descriptor() ([]byte, []int) { - return fileDescriptor_2554593a991dd89d, []int{0} -} -func (m *ShortBook) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *ShortBook) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_ShortBook.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *ShortBook) XXX_Merge(src proto.Message) { - xxx_messageInfo_ShortBook.Merge(m, src) -} -func (m *ShortBook) XXX_Size() int { - return m.Size() -} -func (m *ShortBook) XXX_DiscardUnknown() { - xxx_messageInfo_ShortBook.DiscardUnknown(m) -} - -var xxx_messageInfo_ShortBook proto.InternalMessageInfo - -func (m *ShortBook) GetEntry() *OrderEntry { - if m != nil { - return m.Entry - } - return nil -} - -func init() { - proto.RegisterType((*ShortBook)(nil), "seiprotocol.seichain.dex.ShortBook") -} - -func init() { proto.RegisterFile("dex/short_book.proto", fileDescriptor_2554593a991dd89d) } - -var fileDescriptor_2554593a991dd89d = []byte{ - // 278 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x12, 0x49, 0x49, 0xad, 0xd0, - 0x2f, 0xce, 0xc8, 0x2f, 0x2a, 0x89, 0x4f, 0xca, 0xcf, 0xcf, 0xd6, 0x2b, 0x28, 0xca, 0x2f, 0xc9, - 0x17, 0x92, 0x28, 0x4e, 0xcd, 0x04, 0xb3, 0x92, 0xf3, 0x73, 0xf4, 0x8a, 0x53, 0x33, 0x93, 0x33, - 0x12, 0x33, 0xf3, 0xf4, 0x52, 0x52, 0x2b, 0xa4, 0x44, 0x41, 0xea, 0xf3, 0x8b, 0x52, 0x52, 0x8b, - 0xe2, 0x53, 0xf3, 0x4a, 0x8a, 0x2a, 0x21, 0x1a, 0xa4, 0x44, 0xd2, 0xf3, 0xd3, 0xf3, 0xc1, 0x4c, - 0x7d, 0x10, 0x0b, 0x22, 0xaa, 0xb4, 0x91, 0x91, 0x8b, 0x33, 0x18, 0x64, 0xb6, 0x53, 0x7e, 0x7e, - 0xb6, 0x50, 0x2c, 0x17, 0x6b, 0x41, 0x51, 0x66, 0x72, 0xaa, 0x04, 0xa3, 0x02, 0xa3, 0x06, 0xa7, - 0x93, 0xfb, 0x89, 0x7b, 0xf2, 0x0c, 0xb7, 0xee, 0xc9, 0xab, 0xa5, 0x67, 0x96, 0x64, 0x94, 0x26, - 0xe9, 0x25, 0xe7, 0xe7, 0xea, 0x27, 0xe7, 0x17, 0xe7, 0xe6, 0x17, 0x43, 0x29, 0xdd, 0xe2, 0x94, - 0x6c, 0xfd, 0x92, 0xca, 0x82, 0xd4, 0x62, 0x3d, 0x97, 0xd4, 0xe4, 0x57, 0xf7, 0xe4, 0x21, 0xda, - 0x3f, 0xdd, 0x93, 0xe7, 0xa9, 0x4c, 0xcc, 0xcd, 0xb1, 0x52, 0x02, 0x73, 0x95, 0x82, 0x20, 0xc2, - 0x42, 0xae, 0x5c, 0xac, 0x60, 0x17, 0x49, 0x30, 0x29, 0x30, 0x6a, 0x70, 0x1b, 0xa9, 0xe8, 0xe1, - 0xf2, 0x83, 0x9e, 0x3f, 0xc8, 0xf9, 0xae, 0x20, 0xb5, 0x4e, 0x9c, 0x20, 0x63, 0xc1, 0xda, 0x82, - 0x20, 0x94, 0x93, 0xfb, 0x89, 0x47, 0x72, 0x8c, 0x17, 0x1e, 0xc9, 0x31, 0x3e, 0x78, 0x24, 0xc7, - 0x38, 0xe1, 0xb1, 0x1c, 0xc3, 0x85, 0xc7, 0x72, 0x0c, 0x37, 0x1e, 0xcb, 0x31, 0x44, 0xe9, 0x22, - 0x39, 0xb4, 0x38, 0x35, 0x53, 0x17, 0x66, 0x38, 0x98, 0x03, 0x36, 0x5d, 0xbf, 0x42, 0x1f, 0x14, - 0x3c, 0x60, 0x37, 0x27, 0xb1, 0x81, 0xe5, 0x8d, 0x01, 0x01, 0x00, 0x00, 0xff, 0xff, 0x90, 0x12, - 0x40, 0x1c, 0x62, 0x01, 0x00, 0x00, -} - -func (m *ShortBook) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *ShortBook) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *ShortBook) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Entry != nil { - { - size, err := m.Entry.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintShortBook(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - { - size := m.Price.Size() - i -= size - if _, err := m.Price.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintShortBook(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - return len(dAtA) - i, nil -} - -func encodeVarintShortBook(dAtA []byte, offset int, v uint64) int { - offset -= sovShortBook(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *ShortBook) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = m.Price.Size() - n += 1 + l + sovShortBook(uint64(l)) - if m.Entry != nil { - l = m.Entry.Size() - n += 1 + l + sovShortBook(uint64(l)) - } - return n -} - -func sovShortBook(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozShortBook(x uint64) (n int) { - return sovShortBook(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *ShortBook) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowShortBook - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: ShortBook: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: ShortBook: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowShortBook - } - 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 ErrInvalidLengthShortBook - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthShortBook - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Price.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Entry", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowShortBook - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthShortBook - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthShortBook - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Entry == nil { - m.Entry = &OrderEntry{} - } - if err := m.Entry.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipShortBook(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthShortBook - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipShortBook(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowShortBook - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowShortBook - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowShortBook - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthShortBook - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupShortBook - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthShortBook - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthShortBook = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowShortBook = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupShortBook = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/tick_size.pb.go b/x/dex/types/tick_size.pb.go deleted file mode 100644 index c6f6a6f1e7..0000000000 --- a/x/dex/types/tick_size.pb.go +++ /dev/null @@ -1,433 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/tick_size.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type TickSize struct { - Pair *Pair `protobuf:"bytes,1,opt,name=pair,proto3" json:"pair"` - Ticksize github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,2,opt,name=ticksize,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"tick_size" yaml:"tick_size"` - ContractAddr string `protobuf:"bytes,3,opt,name=contractAddr,proto3" json:"contract_addr" yaml:"tick_size"` -} - -func (m *TickSize) Reset() { *m = TickSize{} } -func (m *TickSize) String() string { return proto.CompactTextString(m) } -func (*TickSize) ProtoMessage() {} -func (*TickSize) Descriptor() ([]byte, []int) { - return fileDescriptor_17c2b52038d2f694, []int{0} -} -func (m *TickSize) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *TickSize) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_TickSize.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *TickSize) XXX_Merge(src proto.Message) { - xxx_messageInfo_TickSize.Merge(m, src) -} -func (m *TickSize) XXX_Size() int { - return m.Size() -} -func (m *TickSize) XXX_DiscardUnknown() { - xxx_messageInfo_TickSize.DiscardUnknown(m) -} - -var xxx_messageInfo_TickSize proto.InternalMessageInfo - -func (m *TickSize) GetPair() *Pair { - if m != nil { - return m.Pair - } - return nil -} - -func (m *TickSize) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func init() { - proto.RegisterType((*TickSize)(nil), "seiprotocol.seichain.dex.TickSize") -} - -func init() { proto.RegisterFile("dex/tick_size.proto", fileDescriptor_17c2b52038d2f694) } - -var fileDescriptor_17c2b52038d2f694 = []byte{ - // 307 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x12, 0x4e, 0x49, 0xad, 0xd0, - 0x2f, 0xc9, 0x4c, 0xce, 0x8e, 0x2f, 0xce, 0xac, 0x4a, 0xd5, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, - 0x92, 0x28, 0x4e, 0xcd, 0x04, 0xb3, 0x92, 0xf3, 0x73, 0xf4, 0x8a, 0x53, 0x33, 0x93, 0x33, 0x12, - 0x33, 0xf3, 0xf4, 0x52, 0x52, 0x2b, 0xa4, 0xf8, 0x40, 0xca, 0x0b, 0x12, 0x33, 0x8b, 0x20, 0x2a, - 0xa5, 0x44, 0xd2, 0xf3, 0xd3, 0xf3, 0xc1, 0x4c, 0x7d, 0x10, 0x0b, 0x22, 0xaa, 0xd4, 0xc0, 0xc4, - 0xc5, 0x11, 0x92, 0x99, 0x9c, 0x1d, 0x9c, 0x59, 0x95, 0x2a, 0x64, 0xc3, 0xc5, 0x02, 0xd2, 0x20, - 0xc1, 0xa8, 0xc0, 0xa8, 0xc1, 0x6d, 0x24, 0xa7, 0x87, 0xcb, 0x6c, 0xbd, 0x80, 0xc4, 0xcc, 0x22, - 0x27, 0x8e, 0x57, 0xf7, 0xe4, 0xc1, 0xea, 0x83, 0xc0, 0xa4, 0x50, 0x36, 0x17, 0x07, 0xc8, 0x75, - 0x20, 0xc7, 0x49, 0x30, 0x29, 0x30, 0x6a, 0x70, 0x3a, 0xf9, 0x9f, 0xb8, 0x27, 0xcf, 0x70, 0xeb, - 0x9e, 0xbc, 0x5a, 0x7a, 0x66, 0x49, 0x46, 0x69, 0x92, 0x5e, 0x72, 0x7e, 0xae, 0x7e, 0x72, 0x7e, - 0x71, 0x6e, 0x7e, 0x31, 0x94, 0xd2, 0x2d, 0x4e, 0xc9, 0xd6, 0x2f, 0xa9, 0x2c, 0x48, 0x2d, 0xd6, - 0x73, 0x49, 0x4d, 0x7e, 0x75, 0x4f, 0x9e, 0x13, 0xee, 0xbf, 0x4f, 0xf7, 0xe4, 0x05, 0x2a, 0x13, - 0x73, 0x73, 0xac, 0x94, 0xe0, 0x42, 0x4a, 0x41, 0x70, 0x0b, 0x84, 0x3c, 0xb9, 0x78, 0x92, 0xf3, - 0xf3, 0x4a, 0x8a, 0x12, 0x93, 0x4b, 0x1c, 0x53, 0x52, 0x8a, 0x24, 0x98, 0xc1, 0x16, 0xaa, 0xbe, - 0xba, 0x27, 0xcf, 0x0b, 0x13, 0x8f, 0x4f, 0x4c, 0x49, 0x29, 0xc2, 0x6a, 0x0c, 0x8a, 0x56, 0x27, - 0xf7, 0x13, 0x8f, 0xe4, 0x18, 0x2f, 0x3c, 0x92, 0x63, 0x7c, 0xf0, 0x48, 0x8e, 0x71, 0xc2, 0x63, - 0x39, 0x86, 0x0b, 0x8f, 0xe5, 0x18, 0x6e, 0x3c, 0x96, 0x63, 0x88, 0xd2, 0x45, 0x72, 0x77, 0x71, - 0x6a, 0xa6, 0x2e, 0x2c, 0x30, 0xc0, 0x1c, 0x70, 0x68, 0xe8, 0x57, 0xe8, 0x83, 0x63, 0x05, 0xe4, - 0x85, 0x24, 0x36, 0xb0, 0xbc, 0x31, 0x20, 0x00, 0x00, 0xff, 0xff, 0x04, 0x0d, 0x45, 0x14, 0xa9, - 0x01, 0x00, 0x00, -} - -func (m *TickSize) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *TickSize) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *TickSize) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintTickSize(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x1a - } - { - size := m.Ticksize.Size() - i -= size - if _, err := m.Ticksize.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintTickSize(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - if m.Pair != nil { - { - size, err := m.Pair.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTickSize(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func encodeVarintTickSize(dAtA []byte, offset int, v uint64) int { - offset -= sovTickSize(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *TickSize) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Pair != nil { - l = m.Pair.Size() - n += 1 + l + sovTickSize(uint64(l)) - } - l = m.Ticksize.Size() - n += 1 + l + sovTickSize(uint64(l)) - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovTickSize(uint64(l)) - } - return n -} - -func sovTickSize(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozTickSize(x uint64) (n int) { - return sovTickSize(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *TickSize) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTickSize - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: TickSize: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: TickSize: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Pair", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTickSize - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthTickSize - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthTickSize - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Pair == nil { - m.Pair = &Pair{} - } - if err := m.Pair.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Ticksize", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTickSize - } - 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 ErrInvalidLengthTickSize - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthTickSize - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Ticksize.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTickSize - } - 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 ErrInvalidLengthTickSize - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthTickSize - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - m.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipTickSize(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTickSize - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipTickSize(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowTickSize - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowTickSize - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowTickSize - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthTickSize - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupTickSize - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthTickSize - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthTickSize = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowTickSize = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupTickSize = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/twap.pb.go b/x/dex/types/twap.pb.go deleted file mode 100644 index c1976c198b..0000000000 --- a/x/dex/types/twap.pb.go +++ /dev/null @@ -1,416 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/twap.proto - -package types - -import ( - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - proto "github.com/gogo/protobuf/proto" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type Twap struct { - Pair *Pair `protobuf:"bytes,1,opt,name=pair,proto3" json:"pair"` - Twap github_com_cosmos_cosmos_sdk_types.Dec `protobuf:"bytes,2,opt,name=twap,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Dec" json:"twap" yaml:"twap"` - LookbackSeconds uint64 `protobuf:"varint,3,opt,name=lookbackSeconds,proto3" json:"lookback_seconds"` -} - -func (m *Twap) Reset() { *m = Twap{} } -func (m *Twap) String() string { return proto.CompactTextString(m) } -func (*Twap) ProtoMessage() {} -func (*Twap) Descriptor() ([]byte, []int) { - return fileDescriptor_10aa4b136085207a, []int{0} -} -func (m *Twap) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *Twap) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_Twap.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *Twap) XXX_Merge(src proto.Message) { - xxx_messageInfo_Twap.Merge(m, src) -} -func (m *Twap) XXX_Size() int { - return m.Size() -} -func (m *Twap) XXX_DiscardUnknown() { - xxx_messageInfo_Twap.DiscardUnknown(m) -} - -var xxx_messageInfo_Twap proto.InternalMessageInfo - -func (m *Twap) GetPair() *Pair { - if m != nil { - return m.Pair - } - return nil -} - -func (m *Twap) GetLookbackSeconds() uint64 { - if m != nil { - return m.LookbackSeconds - } - return 0 -} - -func init() { - proto.RegisterType((*Twap)(nil), "seiprotocol.seichain.dex.Twap") -} - -func init() { proto.RegisterFile("dex/twap.proto", fileDescriptor_10aa4b136085207a) } - -var fileDescriptor_10aa4b136085207a = []byte{ - // 296 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0xe2, 0x4b, 0x49, 0xad, 0xd0, - 0x2f, 0x29, 0x4f, 0x2c, 0xd0, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, 0x92, 0x28, 0x4e, 0xcd, 0x04, - 0xb3, 0x92, 0xf3, 0x73, 0xf4, 0x8a, 0x53, 0x33, 0x93, 0x33, 0x12, 0x33, 0xf3, 0xf4, 0x52, 0x52, - 0x2b, 0xa4, 0x44, 0xd2, 0xf3, 0xd3, 0xf3, 0xc1, 0x52, 0xfa, 0x20, 0x16, 0x44, 0xbd, 0x14, 0x58, - 0x7f, 0x41, 0x62, 0x66, 0x11, 0x84, 0xaf, 0x74, 0x9f, 0x91, 0x8b, 0x25, 0xa4, 0x3c, 0xb1, 0x40, - 0xc8, 0x86, 0x8b, 0x05, 0x24, 0x2c, 0xc1, 0xa8, 0xc0, 0xa8, 0xc1, 0x6d, 0x24, 0xa7, 0x87, 0xcb, - 0x5c, 0xbd, 0x80, 0xc4, 0xcc, 0x22, 0x27, 0x8e, 0x57, 0xf7, 0xe4, 0xc1, 0xea, 0x83, 0xc0, 0xa4, - 0x50, 0x24, 0x17, 0x0b, 0xc8, 0x51, 0x12, 0x4c, 0x0a, 0x8c, 0x1a, 0x9c, 0x4e, 0xae, 0x27, 0xee, - 0xc9, 0x33, 0xdc, 0xba, 0x27, 0xaf, 0x96, 0x9e, 0x59, 0x92, 0x51, 0x9a, 0xa4, 0x97, 0x9c, 0x9f, - 0xab, 0x9f, 0x9c, 0x5f, 0x9c, 0x9b, 0x5f, 0x0c, 0xa5, 0x74, 0x8b, 0x53, 0xb2, 0xf5, 0x4b, 0x2a, - 0x0b, 0x52, 0x8b, 0xf5, 0x5c, 0x52, 0x93, 0x41, 0x66, 0x81, 0x74, 0x7f, 0xba, 0x27, 0xcf, 0x5d, - 0x99, 0x98, 0x9b, 0x63, 0xa5, 0x04, 0xe2, 0x29, 0x05, 0x81, 0x05, 0x85, 0xec, 0xb8, 0xf8, 0x73, - 0xf2, 0xf3, 0xb3, 0x93, 0x12, 0x93, 0xb3, 0x83, 0x53, 0x93, 0xf3, 0xf3, 0x52, 0x8a, 0x25, 0x98, - 0x15, 0x18, 0x35, 0x58, 0x9c, 0x44, 0x5e, 0xdd, 0x93, 0x17, 0x80, 0x49, 0xc5, 0x17, 0x43, 0xe4, - 0x82, 0xd0, 0x15, 0x3b, 0xb9, 0x9f, 0x78, 0x24, 0xc7, 0x78, 0xe1, 0x91, 0x1c, 0xe3, 0x83, 0x47, - 0x72, 0x8c, 0x13, 0x1e, 0xcb, 0x31, 0x5c, 0x78, 0x2c, 0xc7, 0x70, 0xe3, 0xb1, 0x1c, 0x43, 0x94, - 0x2e, 0x92, 0xf3, 0x8a, 0x53, 0x33, 0x75, 0x61, 0xfe, 0x05, 0x73, 0xc0, 0x1e, 0xd6, 0xaf, 0xd0, - 0x07, 0x87, 0x37, 0xc8, 0xa5, 0x49, 0x6c, 0x60, 0x79, 0x63, 0x40, 0x00, 0x00, 0x00, 0xff, 0xff, - 0x6e, 0x96, 0x9d, 0x05, 0x83, 0x01, 0x00, 0x00, -} - -func (m *Twap) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *Twap) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *Twap) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.LookbackSeconds != 0 { - i = encodeVarintTwap(dAtA, i, uint64(m.LookbackSeconds)) - i-- - dAtA[i] = 0x18 - } - { - size := m.Twap.Size() - i -= size - if _, err := m.Twap.MarshalTo(dAtA[i:]); err != nil { - return 0, err - } - i = encodeVarintTwap(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - if m.Pair != nil { - { - size, err := m.Pair.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTwap(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func encodeVarintTwap(dAtA []byte, offset int, v uint64) int { - offset -= sovTwap(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *Twap) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Pair != nil { - l = m.Pair.Size() - n += 1 + l + sovTwap(uint64(l)) - } - l = m.Twap.Size() - n += 1 + l + sovTwap(uint64(l)) - if m.LookbackSeconds != 0 { - n += 1 + sovTwap(uint64(m.LookbackSeconds)) - } - return n -} - -func sovTwap(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozTwap(x uint64) (n int) { - return sovTwap(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *Twap) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTwap - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: Twap: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: Twap: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Pair", wireType) - } - var msglen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTwap - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - msglen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if msglen < 0 { - return ErrInvalidLengthTwap - } - postIndex := iNdEx + msglen - if postIndex < 0 { - return ErrInvalidLengthTwap - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if m.Pair == nil { - m.Pair = &Pair{} - } - if err := m.Pair.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Twap", wireType) - } - var stringLen uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTwap - } - 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 ErrInvalidLengthTwap - } - postIndex := iNdEx + intStringLen - if postIndex < 0 { - return ErrInvalidLengthTwap - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - if err := m.Twap.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field LookbackSeconds", wireType) - } - m.LookbackSeconds = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTwap - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.LookbackSeconds |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - default: - iNdEx = preIndex - skippy, err := skipTwap(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTwap - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipTwap(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowTwap - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowTwap - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowTwap - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthTwap - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupTwap - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthTwap - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthTwap = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowTwap = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupTwap = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/tx.pb.go b/x/dex/types/tx.pb.go deleted file mode 100644 index 88c8440954..0000000000 --- a/x/dex/types/tx.pb.go +++ /dev/null @@ -1,3884 +0,0 @@ -// Code generated by protoc-gen-gogo. DO NOT EDIT. -// source: dex/tx.proto - -package types - -import ( - context "context" - fmt "fmt" - github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" - types "github.com/cosmos/cosmos-sdk/types" - _ "github.com/gogo/protobuf/gogoproto" - grpc1 "github.com/gogo/protobuf/grpc" - proto "github.com/gogo/protobuf/proto" - grpc "google.golang.org/grpc" - codes "google.golang.org/grpc/codes" - status "google.golang.org/grpc/status" - io "io" - math "math" - math_bits "math/bits" -) - -// Reference imports to suppress errors if they are not otherwise used. -var _ = proto.Marshal -var _ = fmt.Errorf -var _ = math.Inf - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the proto package it is being compiled against. -// A compilation error at this line likely means your copy of the -// proto package needs to be updated. -const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package - -type MsgPlaceOrders struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator"` - Orders []*Order `protobuf:"bytes,2,rep,name=orders,proto3" json:"orders"` - ContractAddr string `protobuf:"bytes,3,opt,name=contractAddr,proto3" json:"contract_address"` - Funds github_com_cosmos_cosmos_sdk_types.Coins `protobuf:"bytes,4,rep,name=funds,proto3,castrepeated=github.com/cosmos/cosmos-sdk/types.Coins" json:"funds"` -} - -func (m *MsgPlaceOrders) Reset() { *m = MsgPlaceOrders{} } -func (m *MsgPlaceOrders) String() string { return proto.CompactTextString(m) } -func (*MsgPlaceOrders) ProtoMessage() {} -func (*MsgPlaceOrders) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{0} -} -func (m *MsgPlaceOrders) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgPlaceOrders) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgPlaceOrders.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgPlaceOrders) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgPlaceOrders.Merge(m, src) -} -func (m *MsgPlaceOrders) XXX_Size() int { - return m.Size() -} -func (m *MsgPlaceOrders) XXX_DiscardUnknown() { - xxx_messageInfo_MsgPlaceOrders.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgPlaceOrders proto.InternalMessageInfo - -func (m *MsgPlaceOrders) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *MsgPlaceOrders) GetOrders() []*Order { - if m != nil { - return m.Orders - } - return nil -} - -func (m *MsgPlaceOrders) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *MsgPlaceOrders) GetFunds() github_com_cosmos_cosmos_sdk_types.Coins { - if m != nil { - return m.Funds - } - return nil -} - -type MsgPlaceOrdersResponse struct { - OrderIds []uint64 `protobuf:"varint,1,rep,packed,name=orderIds,proto3" json:"order_ids" yaml:"order_ids"` -} - -func (m *MsgPlaceOrdersResponse) Reset() { *m = MsgPlaceOrdersResponse{} } -func (m *MsgPlaceOrdersResponse) String() string { return proto.CompactTextString(m) } -func (*MsgPlaceOrdersResponse) ProtoMessage() {} -func (*MsgPlaceOrdersResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{1} -} -func (m *MsgPlaceOrdersResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgPlaceOrdersResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgPlaceOrdersResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgPlaceOrdersResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgPlaceOrdersResponse.Merge(m, src) -} -func (m *MsgPlaceOrdersResponse) XXX_Size() int { - return m.Size() -} -func (m *MsgPlaceOrdersResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgPlaceOrdersResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgPlaceOrdersResponse proto.InternalMessageInfo - -func (m *MsgPlaceOrdersResponse) GetOrderIds() []uint64 { - if m != nil { - return m.OrderIds - } - return nil -} - -type MsgCancelOrders struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator"` - Cancellations []*Cancellation `protobuf:"bytes,2,rep,name=cancellations,proto3" json:"cancellations"` - ContractAddr string `protobuf:"bytes,3,opt,name=contractAddr,proto3" json:"contract_address"` -} - -func (m *MsgCancelOrders) Reset() { *m = MsgCancelOrders{} } -func (m *MsgCancelOrders) String() string { return proto.CompactTextString(m) } -func (*MsgCancelOrders) ProtoMessage() {} -func (*MsgCancelOrders) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{2} -} -func (m *MsgCancelOrders) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgCancelOrders) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgCancelOrders.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgCancelOrders) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgCancelOrders.Merge(m, src) -} -func (m *MsgCancelOrders) XXX_Size() int { - return m.Size() -} -func (m *MsgCancelOrders) XXX_DiscardUnknown() { - xxx_messageInfo_MsgCancelOrders.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgCancelOrders proto.InternalMessageInfo - -func (m *MsgCancelOrders) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *MsgCancelOrders) GetCancellations() []*Cancellation { - if m != nil { - return m.Cancellations - } - return nil -} - -func (m *MsgCancelOrders) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -type MsgCancelOrdersResponse struct { -} - -func (m *MsgCancelOrdersResponse) Reset() { *m = MsgCancelOrdersResponse{} } -func (m *MsgCancelOrdersResponse) String() string { return proto.CompactTextString(m) } -func (*MsgCancelOrdersResponse) ProtoMessage() {} -func (*MsgCancelOrdersResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{3} -} -func (m *MsgCancelOrdersResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgCancelOrdersResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgCancelOrdersResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgCancelOrdersResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgCancelOrdersResponse.Merge(m, src) -} -func (m *MsgCancelOrdersResponse) XXX_Size() int { - return m.Size() -} -func (m *MsgCancelOrdersResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgCancelOrdersResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgCancelOrdersResponse proto.InternalMessageInfo - -type MsgRegisterContract struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` - Contract *ContractInfoV2 `protobuf:"bytes,2,opt,name=contract,proto3" json:"contract,omitempty"` -} - -func (m *MsgRegisterContract) Reset() { *m = MsgRegisterContract{} } -func (m *MsgRegisterContract) String() string { return proto.CompactTextString(m) } -func (*MsgRegisterContract) ProtoMessage() {} -func (*MsgRegisterContract) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{4} -} -func (m *MsgRegisterContract) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgRegisterContract) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgRegisterContract.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgRegisterContract) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgRegisterContract.Merge(m, src) -} -func (m *MsgRegisterContract) XXX_Size() int { - return m.Size() -} -func (m *MsgRegisterContract) XXX_DiscardUnknown() { - xxx_messageInfo_MsgRegisterContract.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgRegisterContract proto.InternalMessageInfo - -func (m *MsgRegisterContract) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *MsgRegisterContract) GetContract() *ContractInfoV2 { - if m != nil { - return m.Contract - } - return nil -} - -type MsgRegisterContractResponse struct { -} - -func (m *MsgRegisterContractResponse) Reset() { *m = MsgRegisterContractResponse{} } -func (m *MsgRegisterContractResponse) String() string { return proto.CompactTextString(m) } -func (*MsgRegisterContractResponse) ProtoMessage() {} -func (*MsgRegisterContractResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{5} -} -func (m *MsgRegisterContractResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgRegisterContractResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgRegisterContractResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgRegisterContractResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgRegisterContractResponse.Merge(m, src) -} -func (m *MsgRegisterContractResponse) XXX_Size() int { - return m.Size() -} -func (m *MsgRegisterContractResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgRegisterContractResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgRegisterContractResponse proto.InternalMessageInfo - -type MsgContractDepositRent struct { - ContractAddr string `protobuf:"bytes,1,opt,name=contractAddr,proto3" json:"contract_address"` - Amount uint64 `protobuf:"varint,2,opt,name=amount,proto3" json:"amount"` - Sender string `protobuf:"bytes,3,opt,name=sender,proto3" json:"sender"` -} - -func (m *MsgContractDepositRent) Reset() { *m = MsgContractDepositRent{} } -func (m *MsgContractDepositRent) String() string { return proto.CompactTextString(m) } -func (*MsgContractDepositRent) ProtoMessage() {} -func (*MsgContractDepositRent) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{6} -} -func (m *MsgContractDepositRent) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgContractDepositRent) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgContractDepositRent.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgContractDepositRent) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgContractDepositRent.Merge(m, src) -} -func (m *MsgContractDepositRent) XXX_Size() int { - return m.Size() -} -func (m *MsgContractDepositRent) XXX_DiscardUnknown() { - xxx_messageInfo_MsgContractDepositRent.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgContractDepositRent proto.InternalMessageInfo - -func (m *MsgContractDepositRent) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -func (m *MsgContractDepositRent) GetAmount() uint64 { - if m != nil { - return m.Amount - } - return 0 -} - -func (m *MsgContractDepositRent) GetSender() string { - if m != nil { - return m.Sender - } - return "" -} - -type MsgContractDepositRentResponse struct { -} - -func (m *MsgContractDepositRentResponse) Reset() { *m = MsgContractDepositRentResponse{} } -func (m *MsgContractDepositRentResponse) String() string { return proto.CompactTextString(m) } -func (*MsgContractDepositRentResponse) ProtoMessage() {} -func (*MsgContractDepositRentResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{7} -} -func (m *MsgContractDepositRentResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgContractDepositRentResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgContractDepositRentResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgContractDepositRentResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgContractDepositRentResponse.Merge(m, src) -} -func (m *MsgContractDepositRentResponse) XXX_Size() int { - return m.Size() -} -func (m *MsgContractDepositRentResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgContractDepositRentResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgContractDepositRentResponse proto.InternalMessageInfo - -type MsgUnregisterContract struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contract_address"` -} - -func (m *MsgUnregisterContract) Reset() { *m = MsgUnregisterContract{} } -func (m *MsgUnregisterContract) String() string { return proto.CompactTextString(m) } -func (*MsgUnregisterContract) ProtoMessage() {} -func (*MsgUnregisterContract) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{8} -} -func (m *MsgUnregisterContract) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgUnregisterContract) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgUnregisterContract.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgUnregisterContract) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUnregisterContract.Merge(m, src) -} -func (m *MsgUnregisterContract) XXX_Size() int { - return m.Size() -} -func (m *MsgUnregisterContract) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUnregisterContract.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgUnregisterContract proto.InternalMessageInfo - -func (m *MsgUnregisterContract) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *MsgUnregisterContract) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -type MsgUnregisterContractResponse struct { -} - -func (m *MsgUnregisterContractResponse) Reset() { *m = MsgUnregisterContractResponse{} } -func (m *MsgUnregisterContractResponse) String() string { return proto.CompactTextString(m) } -func (*MsgUnregisterContractResponse) ProtoMessage() {} -func (*MsgUnregisterContractResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{9} -} -func (m *MsgUnregisterContractResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgUnregisterContractResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgUnregisterContractResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgUnregisterContractResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUnregisterContractResponse.Merge(m, src) -} -func (m *MsgUnregisterContractResponse) XXX_Size() int { - return m.Size() -} -func (m *MsgUnregisterContractResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUnregisterContractResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgUnregisterContractResponse proto.InternalMessageInfo - -type MsgRegisterPairs struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` - Batchcontractpair []BatchContractPair `protobuf:"bytes,3,rep,name=batchcontractpair,proto3" json:"batch_contract_pair" yaml:"batch_contract_pair"` -} - -func (m *MsgRegisterPairs) Reset() { *m = MsgRegisterPairs{} } -func (m *MsgRegisterPairs) String() string { return proto.CompactTextString(m) } -func (*MsgRegisterPairs) ProtoMessage() {} -func (*MsgRegisterPairs) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{10} -} -func (m *MsgRegisterPairs) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgRegisterPairs) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgRegisterPairs.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgRegisterPairs) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgRegisterPairs.Merge(m, src) -} -func (m *MsgRegisterPairs) XXX_Size() int { - return m.Size() -} -func (m *MsgRegisterPairs) XXX_DiscardUnknown() { - xxx_messageInfo_MsgRegisterPairs.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgRegisterPairs proto.InternalMessageInfo - -func (m *MsgRegisterPairs) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *MsgRegisterPairs) GetBatchcontractpair() []BatchContractPair { - if m != nil { - return m.Batchcontractpair - } - return nil -} - -type MsgRegisterPairsResponse struct { -} - -func (m *MsgRegisterPairsResponse) Reset() { *m = MsgRegisterPairsResponse{} } -func (m *MsgRegisterPairsResponse) String() string { return proto.CompactTextString(m) } -func (*MsgRegisterPairsResponse) ProtoMessage() {} -func (*MsgRegisterPairsResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{11} -} -func (m *MsgRegisterPairsResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgRegisterPairsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgRegisterPairsResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgRegisterPairsResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgRegisterPairsResponse.Merge(m, src) -} -func (m *MsgRegisterPairsResponse) XXX_Size() int { - return m.Size() -} -func (m *MsgRegisterPairsResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgRegisterPairsResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgRegisterPairsResponse proto.InternalMessageInfo - -type MsgUpdatePriceTickSize struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator"` - TickSizeList []TickSize `protobuf:"bytes,2,rep,name=tickSizeList,proto3" json:"tick_size_list" yaml:"tick_size_list"` -} - -func (m *MsgUpdatePriceTickSize) Reset() { *m = MsgUpdatePriceTickSize{} } -func (m *MsgUpdatePriceTickSize) String() string { return proto.CompactTextString(m) } -func (*MsgUpdatePriceTickSize) ProtoMessage() {} -func (*MsgUpdatePriceTickSize) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{12} -} -func (m *MsgUpdatePriceTickSize) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgUpdatePriceTickSize) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgUpdatePriceTickSize.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgUpdatePriceTickSize) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUpdatePriceTickSize.Merge(m, src) -} -func (m *MsgUpdatePriceTickSize) XXX_Size() int { - return m.Size() -} -func (m *MsgUpdatePriceTickSize) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUpdatePriceTickSize.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgUpdatePriceTickSize proto.InternalMessageInfo - -func (m *MsgUpdatePriceTickSize) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *MsgUpdatePriceTickSize) GetTickSizeList() []TickSize { - if m != nil { - return m.TickSizeList - } - return nil -} - -type MsgUpdateQuantityTickSize struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator"` - TickSizeList []TickSize `protobuf:"bytes,2,rep,name=tickSizeList,proto3" json:"tick_size_list" yaml:"tick_size_list"` -} - -func (m *MsgUpdateQuantityTickSize) Reset() { *m = MsgUpdateQuantityTickSize{} } -func (m *MsgUpdateQuantityTickSize) String() string { return proto.CompactTextString(m) } -func (*MsgUpdateQuantityTickSize) ProtoMessage() {} -func (*MsgUpdateQuantityTickSize) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{13} -} -func (m *MsgUpdateQuantityTickSize) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgUpdateQuantityTickSize) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgUpdateQuantityTickSize.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgUpdateQuantityTickSize) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUpdateQuantityTickSize.Merge(m, src) -} -func (m *MsgUpdateQuantityTickSize) XXX_Size() int { - return m.Size() -} -func (m *MsgUpdateQuantityTickSize) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUpdateQuantityTickSize.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgUpdateQuantityTickSize proto.InternalMessageInfo - -func (m *MsgUpdateQuantityTickSize) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *MsgUpdateQuantityTickSize) GetTickSizeList() []TickSize { - if m != nil { - return m.TickSizeList - } - return nil -} - -type MsgUpdateTickSizeResponse struct { -} - -func (m *MsgUpdateTickSizeResponse) Reset() { *m = MsgUpdateTickSizeResponse{} } -func (m *MsgUpdateTickSizeResponse) String() string { return proto.CompactTextString(m) } -func (*MsgUpdateTickSizeResponse) ProtoMessage() {} -func (*MsgUpdateTickSizeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{14} -} -func (m *MsgUpdateTickSizeResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgUpdateTickSizeResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgUpdateTickSizeResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgUpdateTickSizeResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUpdateTickSizeResponse.Merge(m, src) -} -func (m *MsgUpdateTickSizeResponse) XXX_Size() int { - return m.Size() -} -func (m *MsgUpdateTickSizeResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUpdateTickSizeResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgUpdateTickSizeResponse proto.InternalMessageInfo - -type MsgUnsuspendContract struct { - Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator"` - ContractAddr string `protobuf:"bytes,2,opt,name=contractAddr,proto3" json:"contract_address"` -} - -func (m *MsgUnsuspendContract) Reset() { *m = MsgUnsuspendContract{} } -func (m *MsgUnsuspendContract) String() string { return proto.CompactTextString(m) } -func (*MsgUnsuspendContract) ProtoMessage() {} -func (*MsgUnsuspendContract) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{15} -} -func (m *MsgUnsuspendContract) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgUnsuspendContract) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgUnsuspendContract.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgUnsuspendContract) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUnsuspendContract.Merge(m, src) -} -func (m *MsgUnsuspendContract) XXX_Size() int { - return m.Size() -} -func (m *MsgUnsuspendContract) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUnsuspendContract.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgUnsuspendContract proto.InternalMessageInfo - -func (m *MsgUnsuspendContract) GetCreator() string { - if m != nil { - return m.Creator - } - return "" -} - -func (m *MsgUnsuspendContract) GetContractAddr() string { - if m != nil { - return m.ContractAddr - } - return "" -} - -type MsgUnsuspendContractResponse struct { -} - -func (m *MsgUnsuspendContractResponse) Reset() { *m = MsgUnsuspendContractResponse{} } -func (m *MsgUnsuspendContractResponse) String() string { return proto.CompactTextString(m) } -func (*MsgUnsuspendContractResponse) ProtoMessage() {} -func (*MsgUnsuspendContractResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_463701e671e5a5e0, []int{16} -} -func (m *MsgUnsuspendContractResponse) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *MsgUnsuspendContractResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_MsgUnsuspendContractResponse.Marshal(b, m, deterministic) - } else { - b = b[:cap(b)] - n, err := m.MarshalToSizedBuffer(b) - if err != nil { - return nil, err - } - return b[:n], nil - } -} -func (m *MsgUnsuspendContractResponse) XXX_Merge(src proto.Message) { - xxx_messageInfo_MsgUnsuspendContractResponse.Merge(m, src) -} -func (m *MsgUnsuspendContractResponse) XXX_Size() int { - return m.Size() -} -func (m *MsgUnsuspendContractResponse) XXX_DiscardUnknown() { - xxx_messageInfo_MsgUnsuspendContractResponse.DiscardUnknown(m) -} - -var xxx_messageInfo_MsgUnsuspendContractResponse proto.InternalMessageInfo - -func init() { - proto.RegisterType((*MsgPlaceOrders)(nil), "seiprotocol.seichain.dex.MsgPlaceOrders") - proto.RegisterType((*MsgPlaceOrdersResponse)(nil), "seiprotocol.seichain.dex.MsgPlaceOrdersResponse") - proto.RegisterType((*MsgCancelOrders)(nil), "seiprotocol.seichain.dex.MsgCancelOrders") - proto.RegisterType((*MsgCancelOrdersResponse)(nil), "seiprotocol.seichain.dex.MsgCancelOrdersResponse") - proto.RegisterType((*MsgRegisterContract)(nil), "seiprotocol.seichain.dex.MsgRegisterContract") - proto.RegisterType((*MsgRegisterContractResponse)(nil), "seiprotocol.seichain.dex.MsgRegisterContractResponse") - proto.RegisterType((*MsgContractDepositRent)(nil), "seiprotocol.seichain.dex.MsgContractDepositRent") - proto.RegisterType((*MsgContractDepositRentResponse)(nil), "seiprotocol.seichain.dex.MsgContractDepositRentResponse") - proto.RegisterType((*MsgUnregisterContract)(nil), "seiprotocol.seichain.dex.MsgUnregisterContract") - proto.RegisterType((*MsgUnregisterContractResponse)(nil), "seiprotocol.seichain.dex.MsgUnregisterContractResponse") - proto.RegisterType((*MsgRegisterPairs)(nil), "seiprotocol.seichain.dex.MsgRegisterPairs") - proto.RegisterType((*MsgRegisterPairsResponse)(nil), "seiprotocol.seichain.dex.MsgRegisterPairsResponse") - proto.RegisterType((*MsgUpdatePriceTickSize)(nil), "seiprotocol.seichain.dex.MsgUpdatePriceTickSize") - proto.RegisterType((*MsgUpdateQuantityTickSize)(nil), "seiprotocol.seichain.dex.MsgUpdateQuantityTickSize") - proto.RegisterType((*MsgUpdateTickSizeResponse)(nil), "seiprotocol.seichain.dex.MsgUpdateTickSizeResponse") - proto.RegisterType((*MsgUnsuspendContract)(nil), "seiprotocol.seichain.dex.MsgUnsuspendContract") - proto.RegisterType((*MsgUnsuspendContractResponse)(nil), "seiprotocol.seichain.dex.MsgUnsuspendContractResponse") -} - -func init() { proto.RegisterFile("dex/tx.proto", fileDescriptor_463701e671e5a5e0) } - -var fileDescriptor_463701e671e5a5e0 = []byte{ - // 962 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xd4, 0x57, 0x41, 0x6f, 0xe3, 0x44, - 0x14, 0xae, 0x9b, 0x52, 0xba, 0xaf, 0xdd, 0x6e, 0xeb, 0x74, 0x17, 0xd7, 0xcb, 0xda, 0xc1, 0x12, - 0x28, 0x80, 0x6a, 0xd3, 0xac, 0x80, 0x05, 0x89, 0x03, 0xc9, 0x4a, 0x68, 0x25, 0x22, 0x8a, 0x61, - 0x41, 0xe2, 0x12, 0x39, 0xf6, 0xac, 0x3b, 0x34, 0xf5, 0x44, 0x9e, 0x09, 0x9b, 0x2e, 0x08, 0x09, - 0x7e, 0x01, 0x07, 0x4e, 0x1c, 0x39, 0xf2, 0x0b, 0x90, 0x38, 0x72, 0xd9, 0x0b, 0xd2, 0x4a, 0x5c, - 0x38, 0x19, 0xd4, 0xde, 0x72, 0xec, 0x2f, 0x40, 0x1e, 0xdb, 0x43, 0xec, 0x38, 0xc1, 0xd9, 0x03, - 0x12, 0x27, 0x8f, 0x5f, 0xde, 0xf7, 0xbe, 0xf7, 0xbe, 0x37, 0xf3, 0xc6, 0x81, 0x2d, 0x0f, 0x8d, - 0x2d, 0x36, 0x36, 0x87, 0x21, 0x61, 0x44, 0x56, 0x28, 0xc2, 0x7c, 0xe5, 0x92, 0x81, 0x49, 0x11, - 0x76, 0x8f, 0x1d, 0x1c, 0x98, 0x1e, 0x1a, 0xab, 0x9a, 0x4b, 0xe8, 0x29, 0xa1, 0x56, 0xdf, 0xa1, - 0xc8, 0xfa, 0xe2, 0xb0, 0x8f, 0x98, 0x73, 0x68, 0xb9, 0x04, 0x07, 0x09, 0x52, 0xdd, 0xf3, 0x89, - 0x4f, 0xf8, 0xd2, 0x8a, 0x57, 0xa9, 0x55, 0x8e, 0xa3, 0xbb, 0x24, 0x60, 0xa1, 0xe3, 0xb2, 0xd4, - 0x76, 0x2d, 0xb6, 0x91, 0xd0, 0x43, 0x61, 0x6a, 0xd8, 0x8e, 0x0d, 0x43, 0x07, 0x67, 0xef, 0x75, - 0x9e, 0x12, 0x76, 0x4f, 0x7a, 0x14, 0x3f, 0x42, 0x89, 0xd1, 0xf8, 0x71, 0x15, 0xb6, 0xbb, 0xd4, - 0x3f, 0x1a, 0x38, 0x2e, 0xfa, 0x20, 0x06, 0x53, 0xf9, 0x45, 0x78, 0xd6, 0x0d, 0x91, 0xc3, 0x48, - 0xa8, 0x48, 0x0d, 0xa9, 0x79, 0xa5, 0xbd, 0x39, 0x89, 0xf4, 0xcc, 0x64, 0x67, 0x0b, 0xb9, 0x03, - 0xeb, 0x9c, 0x8d, 0x2a, 0xab, 0x8d, 0x5a, 0x73, 0xb3, 0xa5, 0x9b, 0xf3, 0x8a, 0x34, 0x79, 0xe0, - 0x36, 0x4c, 0x22, 0x3d, 0x85, 0xd8, 0xe9, 0x53, 0xbe, 0x03, 0x5b, 0x59, 0x19, 0xef, 0x7a, 0x5e, - 0xa8, 0xd4, 0x38, 0xe1, 0xde, 0x24, 0xd2, 0x77, 0x32, 0x7b, 0xcf, 0xf1, 0xbc, 0x10, 0x51, 0x6a, - 0xe7, 0x3c, 0xe5, 0xcf, 0xe1, 0x99, 0x07, 0xa3, 0xc0, 0xa3, 0xca, 0x1a, 0x67, 0xdf, 0x37, 0x13, - 0x21, 0xcd, 0x58, 0x48, 0x33, 0x15, 0xd2, 0xec, 0x10, 0x1c, 0xb4, 0xdf, 0x7a, 0x1c, 0xe9, 0x2b, - 0x93, 0x48, 0x4f, 0xfc, 0x7f, 0xfa, 0x53, 0x6f, 0xfa, 0x98, 0x1d, 0x8f, 0xfa, 0xa6, 0x4b, 0x4e, - 0xad, 0x54, 0xfe, 0xe4, 0x71, 0x40, 0xbd, 0x13, 0x8b, 0x9d, 0x0d, 0x11, 0xe5, 0x48, 0x6a, 0x27, - 0x10, 0xe3, 0x53, 0xb8, 0x91, 0xd7, 0xc8, 0x46, 0x74, 0x48, 0x02, 0x8a, 0xe4, 0x77, 0x60, 0x83, - 0x57, 0x72, 0xcf, 0xa3, 0x8a, 0xd4, 0xa8, 0x35, 0xd7, 0xda, 0x2f, 0x4c, 0x22, 0xfd, 0x0a, 0xb7, - 0xf5, 0xb0, 0x47, 0x2f, 0x23, 0x7d, 0xe7, 0xcc, 0x39, 0x1d, 0xbc, 0x6d, 0x08, 0x93, 0x61, 0x0b, - 0x88, 0xf1, 0xbb, 0x04, 0xd7, 0xba, 0xd4, 0xef, 0x38, 0x81, 0x8b, 0x06, 0xcb, 0xc9, 0xdf, 0x83, - 0xab, 0x2e, 0x87, 0x0d, 0x1c, 0x86, 0x49, 0x90, 0x75, 0xe1, 0xa5, 0xf9, 0x5d, 0xe8, 0x4c, 0xb9, - 0xb7, 0x77, 0x27, 0x91, 0x9e, 0x0f, 0x60, 0xe7, 0x5f, 0x9f, 0xbe, 0x35, 0xc6, 0x3e, 0x3c, 0x57, - 0x28, 0x2a, 0xd3, 0xcb, 0x18, 0x41, 0xbd, 0x4b, 0x7d, 0x1b, 0xf9, 0x98, 0x32, 0x14, 0x76, 0x52, - 0x94, 0xac, 0x14, 0x6a, 0xfe, 0xa7, 0xcc, 0xbb, 0xb0, 0x91, 0xc5, 0x56, 0x56, 0x1b, 0x52, 0x73, - 0xb3, 0xd5, 0x5c, 0x50, 0x61, 0xea, 0x79, 0x2f, 0x78, 0x40, 0x3e, 0x69, 0xd9, 0x02, 0x69, 0xdc, - 0x82, 0x9b, 0x25, 0xb4, 0x22, 0xab, 0x1f, 0x24, 0xde, 0xe0, 0xcc, 0x7e, 0x17, 0x0d, 0x09, 0xc5, - 0xcc, 0x46, 0x01, 0x9b, 0x51, 0x41, 0xaa, 0xbc, 0x41, 0x0d, 0x58, 0x77, 0x4e, 0xc9, 0x28, 0x48, - 0xf2, 0x5e, 0x4b, 0xb6, 0x7f, 0x62, 0xb1, 0xd3, 0x67, 0xec, 0x43, 0x51, 0xe0, 0xa1, 0x4c, 0x5d, - 0xee, 0x93, 0x58, 0xec, 0xf4, 0x69, 0x34, 0x40, 0x2b, 0xcf, 0x4d, 0xa4, 0x3f, 0x86, 0xeb, 0x5d, - 0xea, 0xdf, 0x0f, 0xc2, 0xa2, 0xac, 0x15, 0xb7, 0x52, 0xb1, 0xc6, 0xd5, 0xca, 0x9d, 0xd6, 0xe1, - 0x56, 0x29, 0xb3, 0x48, 0xed, 0x57, 0x09, 0x76, 0xa6, 0x94, 0x3f, 0x72, 0x70, 0x48, 0x17, 0x74, - 0xfb, 0x7b, 0x09, 0x76, 0xfb, 0x0e, 0x73, 0x8f, 0x33, 0x96, 0x78, 0x7c, 0x29, 0x35, 0xbe, 0xb3, - 0x5f, 0x9d, 0xdf, 0xf7, 0x76, 0x0c, 0xc9, 0xb8, 0x63, 0x0e, 0x71, 0xe6, 0xeb, 0x3c, 0x5a, 0x4f, - 0x94, 0x11, 0xc7, 0xbb, 0x8c, 0x74, 0x35, 0x39, 0x93, 0x25, 0x3f, 0x1a, 0xf6, 0x6c, 0x02, 0x86, - 0x0a, 0x4a, 0xb1, 0x08, 0x51, 0xe1, 0xcf, 0xc9, 0xde, 0xb9, 0x3f, 0xf4, 0x1c, 0x86, 0x8e, 0x42, - 0xec, 0xa2, 0x8f, 0xb1, 0x7b, 0xf2, 0x11, 0x7e, 0x84, 0xaa, 0xca, 0xff, 0x10, 0xb6, 0x58, 0x0a, - 0x79, 0x1f, 0x53, 0x96, 0x1e, 0x64, 0x63, 0x7e, 0xb9, 0x19, 0x41, 0xdb, 0x4a, 0xab, 0xdc, 0x16, - 0x53, 0xbd, 0x37, 0xc0, 0x94, 0x5d, 0x46, 0xfa, 0xf5, 0xa4, 0xc0, 0xbc, 0xdd, 0xb0, 0x73, 0x44, - 0xc6, 0x2f, 0x12, 0xec, 0x8b, 0xd4, 0x3f, 0x1c, 0x39, 0x01, 0xc3, 0xec, 0xec, 0x7f, 0x93, 0xfd, - 0xcd, 0xa9, 0xe4, 0xb3, 0x98, 0xa2, 0x2b, 0x0f, 0x61, 0x8f, 0x6f, 0x4c, 0x3a, 0xa2, 0x43, 0x14, - 0x78, 0xff, 0xdd, 0x89, 0xd0, 0xe0, 0xf9, 0x32, 0xe2, 0x2c, 0xb1, 0xd6, 0x6f, 0x1b, 0x50, 0xeb, - 0x52, 0x5f, 0xc6, 0xb0, 0x39, 0x7d, 0xe7, 0x2e, 0x18, 0x6a, 0xf9, 0x9b, 0x47, 0x7d, 0xad, 0xaa, - 0xa7, 0xb8, 0xa3, 0x06, 0xb0, 0x95, 0xbb, 0x60, 0x5e, 0x5e, 0x18, 0x61, 0xda, 0x55, 0x3d, 0xac, - 0xec, 0x2a, 0xd8, 0xc6, 0xb0, 0x33, 0x33, 0xde, 0x0f, 0x16, 0x86, 0x29, 0xba, 0xab, 0xaf, 0x2f, - 0xe5, 0x2e, 0x98, 0xbf, 0x91, 0xa0, 0x5e, 0x36, 0xc2, 0x17, 0x2b, 0x56, 0x82, 0x50, 0xef, 0x2c, - 0x8b, 0x10, 0x39, 0x7c, 0x0d, 0x72, 0xc9, 0x1c, 0xb6, 0x16, 0xc6, 0x9b, 0x05, 0xa8, 0x6f, 0x2e, - 0x09, 0x10, 0xfc, 0x04, 0xae, 0xe6, 0x67, 0xed, 0x2b, 0x95, 0xb4, 0xe4, 0xbe, 0x6a, 0xab, 0xba, - 0xaf, 0x20, 0xfc, 0x0a, 0xea, 0x65, 0xa3, 0x6f, 0xb1, 0xe6, 0x25, 0x08, 0xf5, 0x76, 0x05, 0x44, - 0xf1, 0x98, 0xcb, 0xdf, 0x4a, 0x70, 0x63, 0xce, 0xf8, 0xaa, 0x12, 0xaf, 0x08, 0x7a, 0xba, 0x24, - 0xbe, 0x84, 0xdd, 0xd9, 0x41, 0x63, 0xfe, 0x4b, 0x07, 0x0b, 0xfe, 0xea, 0x1b, 0xcb, 0xf9, 0x67, - 0xe4, 0xed, 0xf7, 0x1e, 0x9f, 0x6b, 0xd2, 0x93, 0x73, 0x4d, 0xfa, 0xeb, 0x5c, 0x93, 0xbe, 0xbb, - 0xd0, 0x56, 0x9e, 0x5c, 0x68, 0x2b, 0x7f, 0x5c, 0x68, 0x2b, 0x9f, 0x1d, 0x4c, 0x7d, 0xe5, 0x52, - 0x84, 0x0f, 0xb2, 0xe0, 0xfc, 0x85, 0x47, 0xb7, 0xc6, 0x16, 0xff, 0x4b, 0x10, 0x7f, 0xf0, 0xf6, - 0xd7, 0xf9, 0xef, 0xb7, 0xff, 0x0e, 0x00, 0x00, 0xff, 0xff, 0x87, 0xb0, 0xd3, 0x48, 0xb9, 0x0c, - 0x00, 0x00, -} - -// Reference imports to suppress errors if they are not otherwise used. -var _ context.Context -var _ grpc.ClientConn - -// This is a compile-time assertion to ensure that this generated file -// is compatible with the grpc package it is being compiled against. -const _ = grpc.SupportPackageIsVersion4 - -// MsgClient is the client API for Msg service. -// -// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream. -type MsgClient interface { - PlaceOrders(ctx context.Context, in *MsgPlaceOrders, opts ...grpc.CallOption) (*MsgPlaceOrdersResponse, error) - CancelOrders(ctx context.Context, in *MsgCancelOrders, opts ...grpc.CallOption) (*MsgCancelOrdersResponse, error) - RegisterContract(ctx context.Context, in *MsgRegisterContract, opts ...grpc.CallOption) (*MsgRegisterContractResponse, error) - ContractDepositRent(ctx context.Context, in *MsgContractDepositRent, opts ...grpc.CallOption) (*MsgContractDepositRentResponse, error) - UnregisterContract(ctx context.Context, in *MsgUnregisterContract, opts ...grpc.CallOption) (*MsgUnregisterContractResponse, error) - RegisterPairs(ctx context.Context, in *MsgRegisterPairs, opts ...grpc.CallOption) (*MsgRegisterPairsResponse, error) - UpdatePriceTickSize(ctx context.Context, in *MsgUpdatePriceTickSize, opts ...grpc.CallOption) (*MsgUpdateTickSizeResponse, error) - UpdateQuantityTickSize(ctx context.Context, in *MsgUpdateQuantityTickSize, opts ...grpc.CallOption) (*MsgUpdateTickSizeResponse, error) - UnsuspendContract(ctx context.Context, in *MsgUnsuspendContract, opts ...grpc.CallOption) (*MsgUnsuspendContractResponse, error) -} - -type msgClient struct { - cc grpc1.ClientConn -} - -func NewMsgClient(cc grpc1.ClientConn) MsgClient { - return &msgClient{cc} -} - -func (c *msgClient) PlaceOrders(ctx context.Context, in *MsgPlaceOrders, opts ...grpc.CallOption) (*MsgPlaceOrdersResponse, error) { - out := new(MsgPlaceOrdersResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Msg/PlaceOrders", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *msgClient) CancelOrders(ctx context.Context, in *MsgCancelOrders, opts ...grpc.CallOption) (*MsgCancelOrdersResponse, error) { - out := new(MsgCancelOrdersResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Msg/CancelOrders", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *msgClient) RegisterContract(ctx context.Context, in *MsgRegisterContract, opts ...grpc.CallOption) (*MsgRegisterContractResponse, error) { - out := new(MsgRegisterContractResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Msg/RegisterContract", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *msgClient) ContractDepositRent(ctx context.Context, in *MsgContractDepositRent, opts ...grpc.CallOption) (*MsgContractDepositRentResponse, error) { - out := new(MsgContractDepositRentResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Msg/ContractDepositRent", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *msgClient) UnregisterContract(ctx context.Context, in *MsgUnregisterContract, opts ...grpc.CallOption) (*MsgUnregisterContractResponse, error) { - out := new(MsgUnregisterContractResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Msg/UnregisterContract", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *msgClient) RegisterPairs(ctx context.Context, in *MsgRegisterPairs, opts ...grpc.CallOption) (*MsgRegisterPairsResponse, error) { - out := new(MsgRegisterPairsResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Msg/RegisterPairs", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *msgClient) UpdatePriceTickSize(ctx context.Context, in *MsgUpdatePriceTickSize, opts ...grpc.CallOption) (*MsgUpdateTickSizeResponse, error) { - out := new(MsgUpdateTickSizeResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Msg/UpdatePriceTickSize", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *msgClient) UpdateQuantityTickSize(ctx context.Context, in *MsgUpdateQuantityTickSize, opts ...grpc.CallOption) (*MsgUpdateTickSizeResponse, error) { - out := new(MsgUpdateTickSizeResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Msg/UpdateQuantityTickSize", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -func (c *msgClient) UnsuspendContract(ctx context.Context, in *MsgUnsuspendContract, opts ...grpc.CallOption) (*MsgUnsuspendContractResponse, error) { - out := new(MsgUnsuspendContractResponse) - err := c.cc.Invoke(ctx, "/seiprotocol.seichain.dex.Msg/UnsuspendContract", in, out, opts...) - if err != nil { - return nil, err - } - return out, nil -} - -// MsgServer is the server API for Msg service. -type MsgServer interface { - PlaceOrders(context.Context, *MsgPlaceOrders) (*MsgPlaceOrdersResponse, error) - CancelOrders(context.Context, *MsgCancelOrders) (*MsgCancelOrdersResponse, error) - RegisterContract(context.Context, *MsgRegisterContract) (*MsgRegisterContractResponse, error) - ContractDepositRent(context.Context, *MsgContractDepositRent) (*MsgContractDepositRentResponse, error) - UnregisterContract(context.Context, *MsgUnregisterContract) (*MsgUnregisterContractResponse, error) - RegisterPairs(context.Context, *MsgRegisterPairs) (*MsgRegisterPairsResponse, error) - UpdatePriceTickSize(context.Context, *MsgUpdatePriceTickSize) (*MsgUpdateTickSizeResponse, error) - UpdateQuantityTickSize(context.Context, *MsgUpdateQuantityTickSize) (*MsgUpdateTickSizeResponse, error) - UnsuspendContract(context.Context, *MsgUnsuspendContract) (*MsgUnsuspendContractResponse, error) -} - -// UnimplementedMsgServer can be embedded to have forward compatible implementations. -type UnimplementedMsgServer struct { -} - -func (*UnimplementedMsgServer) PlaceOrders(ctx context.Context, req *MsgPlaceOrders) (*MsgPlaceOrdersResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method PlaceOrders not implemented") -} -func (*UnimplementedMsgServer) CancelOrders(ctx context.Context, req *MsgCancelOrders) (*MsgCancelOrdersResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method CancelOrders not implemented") -} -func (*UnimplementedMsgServer) RegisterContract(ctx context.Context, req *MsgRegisterContract) (*MsgRegisterContractResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method RegisterContract not implemented") -} -func (*UnimplementedMsgServer) ContractDepositRent(ctx context.Context, req *MsgContractDepositRent) (*MsgContractDepositRentResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method ContractDepositRent not implemented") -} -func (*UnimplementedMsgServer) UnregisterContract(ctx context.Context, req *MsgUnregisterContract) (*MsgUnregisterContractResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method UnregisterContract not implemented") -} -func (*UnimplementedMsgServer) RegisterPairs(ctx context.Context, req *MsgRegisterPairs) (*MsgRegisterPairsResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method RegisterPairs not implemented") -} -func (*UnimplementedMsgServer) UpdatePriceTickSize(ctx context.Context, req *MsgUpdatePriceTickSize) (*MsgUpdateTickSizeResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method UpdatePriceTickSize not implemented") -} -func (*UnimplementedMsgServer) UpdateQuantityTickSize(ctx context.Context, req *MsgUpdateQuantityTickSize) (*MsgUpdateTickSizeResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method UpdateQuantityTickSize not implemented") -} -func (*UnimplementedMsgServer) UnsuspendContract(ctx context.Context, req *MsgUnsuspendContract) (*MsgUnsuspendContractResponse, error) { - return nil, status.Errorf(codes.Unimplemented, "method UnsuspendContract not implemented") -} - -func RegisterMsgServer(s grpc1.Server, srv MsgServer) { - s.RegisterService(&_Msg_serviceDesc, srv) -} - -func _Msg_PlaceOrders_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgPlaceOrders) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(MsgServer).PlaceOrders(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Msg/PlaceOrders", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).PlaceOrders(ctx, req.(*MsgPlaceOrders)) - } - return interceptor(ctx, in, info, handler) -} - -func _Msg_CancelOrders_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgCancelOrders) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(MsgServer).CancelOrders(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Msg/CancelOrders", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).CancelOrders(ctx, req.(*MsgCancelOrders)) - } - return interceptor(ctx, in, info, handler) -} - -func _Msg_RegisterContract_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgRegisterContract) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(MsgServer).RegisterContract(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Msg/RegisterContract", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).RegisterContract(ctx, req.(*MsgRegisterContract)) - } - return interceptor(ctx, in, info, handler) -} - -func _Msg_ContractDepositRent_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgContractDepositRent) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(MsgServer).ContractDepositRent(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Msg/ContractDepositRent", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).ContractDepositRent(ctx, req.(*MsgContractDepositRent)) - } - return interceptor(ctx, in, info, handler) -} - -func _Msg_UnregisterContract_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgUnregisterContract) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(MsgServer).UnregisterContract(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Msg/UnregisterContract", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).UnregisterContract(ctx, req.(*MsgUnregisterContract)) - } - return interceptor(ctx, in, info, handler) -} - -func _Msg_RegisterPairs_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgRegisterPairs) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(MsgServer).RegisterPairs(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Msg/RegisterPairs", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).RegisterPairs(ctx, req.(*MsgRegisterPairs)) - } - return interceptor(ctx, in, info, handler) -} - -func _Msg_UpdatePriceTickSize_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgUpdatePriceTickSize) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(MsgServer).UpdatePriceTickSize(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Msg/UpdatePriceTickSize", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).UpdatePriceTickSize(ctx, req.(*MsgUpdatePriceTickSize)) - } - return interceptor(ctx, in, info, handler) -} - -func _Msg_UpdateQuantityTickSize_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgUpdateQuantityTickSize) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(MsgServer).UpdateQuantityTickSize(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Msg/UpdateQuantityTickSize", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).UpdateQuantityTickSize(ctx, req.(*MsgUpdateQuantityTickSize)) - } - return interceptor(ctx, in, info, handler) -} - -func _Msg_UnsuspendContract_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { - in := new(MsgUnsuspendContract) - if err := dec(in); err != nil { - return nil, err - } - if interceptor == nil { - return srv.(MsgServer).UnsuspendContract(ctx, in) - } - info := &grpc.UnaryServerInfo{ - Server: srv, - FullMethod: "/seiprotocol.seichain.dex.Msg/UnsuspendContract", - } - handler := func(ctx context.Context, req interface{}) (interface{}, error) { - return srv.(MsgServer).UnsuspendContract(ctx, req.(*MsgUnsuspendContract)) - } - return interceptor(ctx, in, info, handler) -} - -var _Msg_serviceDesc = grpc.ServiceDesc{ - ServiceName: "seiprotocol.seichain.dex.Msg", - HandlerType: (*MsgServer)(nil), - Methods: []grpc.MethodDesc{ - { - MethodName: "PlaceOrders", - Handler: _Msg_PlaceOrders_Handler, - }, - { - MethodName: "CancelOrders", - Handler: _Msg_CancelOrders_Handler, - }, - { - MethodName: "RegisterContract", - Handler: _Msg_RegisterContract_Handler, - }, - { - MethodName: "ContractDepositRent", - Handler: _Msg_ContractDepositRent_Handler, - }, - { - MethodName: "UnregisterContract", - Handler: _Msg_UnregisterContract_Handler, - }, - { - MethodName: "RegisterPairs", - Handler: _Msg_RegisterPairs_Handler, - }, - { - MethodName: "UpdatePriceTickSize", - Handler: _Msg_UpdatePriceTickSize_Handler, - }, - { - MethodName: "UpdateQuantityTickSize", - Handler: _Msg_UpdateQuantityTickSize_Handler, - }, - { - MethodName: "UnsuspendContract", - Handler: _Msg_UnsuspendContract_Handler, - }, - }, - Streams: []grpc.StreamDesc{}, - Metadata: "dex/tx.proto", -} - -func (m *MsgPlaceOrders) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgPlaceOrders) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgPlaceOrders) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Funds) > 0 { - for iNdEx := len(m.Funds) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Funds[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x22 - } - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintTx(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x1a - } - if len(m.Orders) > 0 { - for iNdEx := len(m.Orders) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Orders[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgPlaceOrdersResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgPlaceOrdersResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgPlaceOrdersResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.OrderIds) > 0 { - dAtA2 := make([]byte, len(m.OrderIds)*10) - var j1 int - for _, num := range m.OrderIds { - for num >= 1<<7 { - dAtA2[j1] = uint8(uint64(num)&0x7f | 0x80) - num >>= 7 - j1++ - } - dAtA2[j1] = uint8(num) - j1++ - } - i -= j1 - copy(dAtA[i:], dAtA2[:j1]) - i = encodeVarintTx(dAtA, i, uint64(j1)) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgCancelOrders) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgCancelOrders) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgCancelOrders) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintTx(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x1a - } - if len(m.Cancellations) > 0 { - for iNdEx := len(m.Cancellations) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Cancellations[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgCancelOrdersResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgCancelOrdersResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgCancelOrdersResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - return len(dAtA) - i, nil -} - -func (m *MsgRegisterContract) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgRegisterContract) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgRegisterContract) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if m.Contract != nil { - { - size, err := m.Contract.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgRegisterContractResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgRegisterContractResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgRegisterContractResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - return len(dAtA) - i, nil -} - -func (m *MsgContractDepositRent) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgContractDepositRent) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgContractDepositRent) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Sender) > 0 { - i -= len(m.Sender) - copy(dAtA[i:], m.Sender) - i = encodeVarintTx(dAtA, i, uint64(len(m.Sender))) - i-- - dAtA[i] = 0x1a - } - if m.Amount != 0 { - i = encodeVarintTx(dAtA, i, uint64(m.Amount)) - i-- - dAtA[i] = 0x10 - } - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintTx(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgContractDepositRentResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgContractDepositRentResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgContractDepositRentResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - return len(dAtA) - i, nil -} - -func (m *MsgUnregisterContract) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgUnregisterContract) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgUnregisterContract) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintTx(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgUnregisterContractResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgUnregisterContractResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgUnregisterContractResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - return len(dAtA) - i, nil -} - -func (m *MsgRegisterPairs) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgRegisterPairs) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgRegisterPairs) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.Batchcontractpair) > 0 { - for iNdEx := len(m.Batchcontractpair) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.Batchcontractpair[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x1a - } - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgRegisterPairsResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgRegisterPairsResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgRegisterPairsResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - return len(dAtA) - i, nil -} - -func (m *MsgUpdatePriceTickSize) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgUpdatePriceTickSize) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgUpdatePriceTickSize) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.TickSizeList) > 0 { - for iNdEx := len(m.TickSizeList) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.TickSizeList[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgUpdateQuantityTickSize) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgUpdateQuantityTickSize) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgUpdateQuantityTickSize) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.TickSizeList) > 0 { - for iNdEx := len(m.TickSizeList) - 1; iNdEx >= 0; iNdEx-- { - { - size, err := m.TickSizeList[iNdEx].MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintTx(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - } - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgUpdateTickSizeResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgUpdateTickSizeResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgUpdateTickSizeResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - return len(dAtA) - i, nil -} - -func (m *MsgUnsuspendContract) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgUnsuspendContract) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgUnsuspendContract) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - if len(m.ContractAddr) > 0 { - i -= len(m.ContractAddr) - copy(dAtA[i:], m.ContractAddr) - i = encodeVarintTx(dAtA, i, uint64(len(m.ContractAddr))) - i-- - dAtA[i] = 0x12 - } - if len(m.Creator) > 0 { - i -= len(m.Creator) - copy(dAtA[i:], m.Creator) - i = encodeVarintTx(dAtA, i, uint64(len(m.Creator))) - i-- - dAtA[i] = 0xa - } - return len(dAtA) - i, nil -} - -func (m *MsgUnsuspendContractResponse) Marshal() (dAtA []byte, err error) { - size := m.Size() - dAtA = make([]byte, size) - n, err := m.MarshalToSizedBuffer(dAtA[:size]) - if err != nil { - return nil, err - } - return dAtA[:n], nil -} - -func (m *MsgUnsuspendContractResponse) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *MsgUnsuspendContractResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - return len(dAtA) - i, nil -} - -func encodeVarintTx(dAtA []byte, offset int, v uint64) int { - offset -= sovTx(v) - base := offset - for v >= 1<<7 { - dAtA[offset] = uint8(v&0x7f | 0x80) - v >>= 7 - offset++ - } - dAtA[offset] = uint8(v) - return base -} -func (m *MsgPlaceOrders) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - if len(m.Orders) > 0 { - for _, e := range m.Orders { - l = e.Size() - n += 1 + l + sovTx(uint64(l)) - } - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - if len(m.Funds) > 0 { - for _, e := range m.Funds { - l = e.Size() - n += 1 + l + sovTx(uint64(l)) - } - } - return n -} - -func (m *MsgPlaceOrdersResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if len(m.OrderIds) > 0 { - l = 0 - for _, e := range m.OrderIds { - l += sovTx(uint64(e)) - } - n += 1 + sovTx(uint64(l)) + l - } - return n -} - -func (m *MsgCancelOrders) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - if len(m.Cancellations) > 0 { - for _, e := range m.Cancellations { - l = e.Size() - n += 1 + l + sovTx(uint64(l)) - } - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - return n -} - -func (m *MsgCancelOrdersResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - return n -} - -func (m *MsgRegisterContract) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - if m.Contract != nil { - l = m.Contract.Size() - n += 1 + l + sovTx(uint64(l)) - } - return n -} - -func (m *MsgRegisterContractResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - return n -} - -func (m *MsgContractDepositRent) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - if m.Amount != 0 { - n += 1 + sovTx(uint64(m.Amount)) - } - l = len(m.Sender) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - return n -} - -func (m *MsgContractDepositRentResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - return n -} - -func (m *MsgUnregisterContract) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - return n -} - -func (m *MsgUnregisterContractResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - return n -} - -func (m *MsgRegisterPairs) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - if len(m.Batchcontractpair) > 0 { - for _, e := range m.Batchcontractpair { - l = e.Size() - n += 1 + l + sovTx(uint64(l)) - } - } - return n -} - -func (m *MsgRegisterPairsResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - return n -} - -func (m *MsgUpdatePriceTickSize) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - if len(m.TickSizeList) > 0 { - for _, e := range m.TickSizeList { - l = e.Size() - n += 1 + l + sovTx(uint64(l)) - } - } - return n -} - -func (m *MsgUpdateQuantityTickSize) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - if len(m.TickSizeList) > 0 { - for _, e := range m.TickSizeList { - l = e.Size() - n += 1 + l + sovTx(uint64(l)) - } - } - return n -} - -func (m *MsgUpdateTickSizeResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - return n -} - -func (m *MsgUnsuspendContract) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - l = len(m.Creator) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - l = len(m.ContractAddr) - if l > 0 { - n += 1 + l + sovTx(uint64(l)) - } - return n -} - -func (m *MsgUnsuspendContractResponse) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - return n -} - -func sovTx(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozTx(x uint64) (n int) { - return sovTx(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *MsgPlaceOrders) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgPlaceOrders: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgPlaceOrders: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", 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.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Orders", 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 - } - m.Orders = append(m.Orders, &Order{}) - if err := m.Orders[len(m.Orders)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", 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.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 4: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Funds", 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 - } - m.Funds = append(m.Funds, types.Coin{}) - if err := m.Funds[len(m.Funds)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgPlaceOrdersResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgPlaceOrdersResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgPlaceOrdersResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType == 0 { - var v uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.OrderIds = append(m.OrderIds, v) - } else if wireType == 2 { - var packedLen int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - packedLen |= int(b&0x7F) << shift - if b < 0x80 { - break - } - } - if packedLen < 0 { - return ErrInvalidLengthTx - } - postIndex := iNdEx + packedLen - if postIndex < 0 { - return ErrInvalidLengthTx - } - if postIndex > l { - return io.ErrUnexpectedEOF - } - var elementCount int - var count int - for _, integer := range dAtA[iNdEx:postIndex] { - if integer < 128 { - count++ - } - } - elementCount = count - if elementCount != 0 && len(m.OrderIds) == 0 { - m.OrderIds = make([]uint64, 0, elementCount) - } - for iNdEx < postIndex { - var v uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - v |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - m.OrderIds = append(m.OrderIds, v) - } - } else { - return fmt.Errorf("proto: wrong wireType = %d for field OrderIds", wireType) - } - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgCancelOrders) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgCancelOrders: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgCancelOrders: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", 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.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Cancellations", 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 - } - m.Cancellations = append(m.Cancellations, &Cancellation{}) - if err := m.Cancellations[len(m.Cancellations)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", 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.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgCancelOrdersResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgCancelOrdersResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgCancelOrdersResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgRegisterContract) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgRegisterContract: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgRegisterContract: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", 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.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Contract", 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.Contract == nil { - m.Contract = &ContractInfoV2{} - } - if err := m.Contract.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgRegisterContractResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgRegisterContractResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgRegisterContractResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgContractDepositRent) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgContractDepositRent: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgContractDepositRent: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", 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.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Amount", wireType) - } - m.Amount = 0 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - m.Amount |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Sender", 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.Sender = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgContractDepositRentResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgContractDepositRentResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgContractDepositRentResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgUnregisterContract) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgUnregisterContract: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUnregisterContract: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", 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.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", 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.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgUnregisterContractResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgUnregisterContractResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUnregisterContractResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgRegisterPairs) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgRegisterPairs: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgRegisterPairs: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", 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.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 3: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Batchcontractpair", 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 - } - m.Batchcontractpair = append(m.Batchcontractpair, BatchContractPair{}) - if err := m.Batchcontractpair[len(m.Batchcontractpair)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgRegisterPairsResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgRegisterPairsResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgRegisterPairsResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgUpdatePriceTickSize) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgUpdatePriceTickSize: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdatePriceTickSize: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", 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.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field TickSizeList", 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 - } - m.TickSizeList = append(m.TickSizeList, TickSize{}) - if err := m.TickSizeList[len(m.TickSizeList)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgUpdateQuantityTickSize) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateQuantityTickSize: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateQuantityTickSize: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", 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.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field TickSizeList", 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 - } - m.TickSizeList = append(m.TickSizeList, TickSize{}) - if err := m.TickSizeList[len(m.TickSizeList)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err - } - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgUpdateTickSizeResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgUpdateTickSizeResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUpdateTickSizeResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgUnsuspendContract) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgUnsuspendContract: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUnsuspendContract: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - case 1: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Creator", 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.Creator = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - case 2: - if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field ContractAddr", 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.ContractAddr = string(dAtA[iNdEx:postIndex]) - iNdEx = postIndex - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func (m *MsgUnsuspendContractResponse) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return ErrIntOverflowTx - } - if iNdEx >= l { - return io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= uint64(b&0x7F) << shift - if b < 0x80 { - break - } - } - fieldNum := int32(wire >> 3) - wireType := int(wire & 0x7) - if wireType == 4 { - return fmt.Errorf("proto: MsgUnsuspendContractResponse: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: MsgUnsuspendContractResponse: illegal tag %d (wire type %d)", fieldNum, wire) - } - switch fieldNum { - default: - iNdEx = preIndex - skippy, err := skipTx(dAtA[iNdEx:]) - if err != nil { - return err - } - if (skippy < 0) || (iNdEx+skippy) < 0 { - return ErrInvalidLengthTx - } - if (iNdEx + skippy) > l { - return io.ErrUnexpectedEOF - } - iNdEx += skippy - } - } - - if iNdEx > l { - return io.ErrUnexpectedEOF - } - return nil -} -func skipTx(dAtA []byte) (n int, err error) { - l := len(dAtA) - iNdEx := 0 - depth := 0 - for iNdEx < l { - var wire uint64 - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowTx - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - wire |= (uint64(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - wireType := int(wire & 0x7) - switch wireType { - case 0: - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowTx - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - iNdEx++ - if dAtA[iNdEx-1] < 0x80 { - break - } - } - case 1: - iNdEx += 8 - case 2: - var length int - for shift := uint(0); ; shift += 7 { - if shift >= 64 { - return 0, ErrIntOverflowTx - } - if iNdEx >= l { - return 0, io.ErrUnexpectedEOF - } - b := dAtA[iNdEx] - iNdEx++ - length |= (int(b) & 0x7F) << shift - if b < 0x80 { - break - } - } - if length < 0 { - return 0, ErrInvalidLengthTx - } - iNdEx += length - case 3: - depth++ - case 4: - if depth == 0 { - return 0, ErrUnexpectedEndOfGroupTx - } - depth-- - case 5: - iNdEx += 4 - default: - return 0, fmt.Errorf("proto: illegal wireType %d", wireType) - } - if iNdEx < 0 { - return 0, ErrInvalidLengthTx - } - if depth == 0 { - return iNdEx, nil - } - } - return 0, io.ErrUnexpectedEOF -} - -var ( - ErrInvalidLengthTx = fmt.Errorf("proto: negative length found during unmarshaling") - ErrIntOverflowTx = fmt.Errorf("proto: integer overflow") - ErrUnexpectedEndOfGroupTx = fmt.Errorf("proto: unexpected end of group") -) diff --git a/x/dex/types/types.go b/x/dex/types/types.go deleted file mode 100644 index 7cc81e44f3..0000000000 --- a/x/dex/types/types.go +++ /dev/null @@ -1,6 +0,0 @@ -package types - -var OppositePositionDirection = map[PositionDirection]PositionDirection{ - PositionDirection_LONG: PositionDirection_SHORT, - PositionDirection_SHORT: PositionDirection_LONG, -} diff --git a/x/dex/types/utils.go b/x/dex/types/utils.go deleted file mode 100644 index 2d55878132..0000000000 --- a/x/dex/types/utils.go +++ /dev/null @@ -1,14 +0,0 @@ -package types - -import ( - "golang.org/x/text/cases" - "golang.org/x/text/language" -) - -func GetContractPositionDirection(direction PositionDirection) string { - return cases.Title(language.English).String(cases.Lower(language.English).String(PositionDirection_name[int32(direction)])) -} - -func GetContractOrderType(orderType OrderType) string { - return cases.Title(language.English).String(cases.Lower(language.English).String(OrderType_name[int32(orderType)])) -} diff --git a/x/dex/utils/context.go b/x/dex/utils/context.go deleted file mode 100644 index 7c7ca27408..0000000000 --- a/x/dex/utils/context.go +++ /dev/null @@ -1,18 +0,0 @@ -package utils - -import ( - "context" - - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" -) - -type MemStateKeyType string - -const DexMemStateContextKey MemStateKeyType = MemStateKeyType("dex-memstate") - -func GetMemState(ctx context.Context) *dexcache.MemState { - if val := ctx.Value(DexMemStateContextKey); val != nil { - return val.(*dexcache.MemState) - } - return nil -} diff --git a/x/dex/utils/dec.go b/x/dex/utils/dec.go deleted file mode 100644 index b43b708980..0000000000 --- a/x/dex/utils/dec.go +++ /dev/null @@ -1,71 +0,0 @@ -package utils - -import ( - "encoding/binary" - "math/big" - - sdk "github.com/cosmos/cosmos-sdk/types" -) - -func DecToBigEndian(d sdk.Dec) (res []byte) { - i := d.BigInt() - words := i.Bits() - // words are little-endian but we want big-endian so we start from the back - for idx := len(words) - 1; idx >= 0; idx-- { - bz := make([]byte, 8) - word := uint64(words[idx]) - if d.IsNegative() { - word = ^word - } - binary.BigEndian.PutUint64(bz, word) - res = append(res, bz...) - } - lastZeroByteIdx := -1 - for i := 0; i < len(res); i++ { - if res[i] != 0 { - break - } - lastZeroByteIdx = i - } - numNonZeroBytes := uint32(len(res) - lastZeroByteIdx - 1) - if d.IsNegative() { - numNonZeroBytes = ^numNonZeroBytes - } - lengthHeaderBz := make([]byte, 4) - binary.BigEndian.PutUint32(lengthHeaderBz, numNonZeroBytes) - res = append(lengthHeaderBz, res[lastZeroByteIdx+1:]...) - if d.IsNegative() { - res = append([]byte{0}, res...) - } else { - res = append([]byte{1}, res...) - } - return res -} - -func BytesToDec(bz []byte) sdk.Dec { - neg := bz[0] == 0 - length := binary.BigEndian.Uint32(bz[1:5]) - if neg { - length = ^length - } - paddingLength := 0 - if length%8 != 0 { - paddingLength = 8 - int(length)%8 - } - padding := make([]byte, paddingLength) - bz = append(padding, bz[5:]...) - words := []big.Word{} - for i := 0; i < len(bz); i += 8 { - word := binary.BigEndian.Uint64(bz[i : i+8]) - if neg { - word = ^word - } - words = append([]big.Word{big.Word(word)}, words...) - } - bi := &big.Int{} - bi.SetBits(words) - if neg { - bi.Neg(bi) - } - return sdk.NewDecFromBigIntWithPrec(bi, sdk.Precision) -} diff --git a/x/dex/utils/dec_test.go b/x/dex/utils/dec_test.go deleted file mode 100644 index 7d170cc42d..0000000000 --- a/x/dex/utils/dec_test.go +++ /dev/null @@ -1,54 +0,0 @@ -package utils - -import ( - "testing" - - sdk "github.com/cosmos/cosmos-sdk/types" - "github.com/stretchr/testify/require" -) - -var DECS = []sdk.Dec{ - sdk.MustNewDecFromStr("90.0"), - sdk.MustNewDecFromStr("10.01"), - sdk.MustNewDecFromStr("10"), - sdk.MustNewDecFromStr("9.99"), - sdk.MustNewDecFromStr("9.9"), - sdk.MustNewDecFromStr("9.0"), - sdk.MustNewDecFromStr("1"), - sdk.MustNewDecFromStr("0.001"), - sdk.MustNewDecFromStr("0"), - sdk.MustNewDecFromStr("-0.001"), - sdk.MustNewDecFromStr("-1"), - sdk.MustNewDecFromStr("-9.0"), - sdk.MustNewDecFromStr("-9.9"), - sdk.MustNewDecFromStr("-9.99"), - sdk.MustNewDecFromStr("-10"), - sdk.MustNewDecFromStr("-10.01"), - sdk.MustNewDecFromStr("-90.0"), -} - -func TestDecToBigEndian(t *testing.T) { - for i := 1; i < len(DECS); i++ { - require.True(t, compBz(DecToBigEndian(DECS[i-1]), DecToBigEndian(DECS[i]))) - } -} - -func TestBytesToDec(t *testing.T) { - for _, dec := range DECS { - require.Equal(t, dec, BytesToDec(DecToBigEndian(dec))) - } -} - -func compBz(b1 []byte, b2 []byte) bool { - ptr := 0 - for ; ptr < len(b1) && ptr < len(b2); ptr++ { - if b1[ptr] < b2[ptr] { - return false - } - if b1[ptr] > b2[ptr] { - return true - } - } - - return ptr >= len(b2) -} diff --git a/x/dex/utils/errors.go b/x/dex/utils/errors.go deleted file mode 100644 index 6139efd4fc..0000000000 --- a/x/dex/utils/errors.go +++ /dev/null @@ -1,11 +0,0 @@ -package utils - -const ErrorByteLimit = 50 - -func GetTruncatedErrors(err error) string { - errStr := err.Error() - if len(errStr) <= ErrorByteLimit { - return errStr - } - return errStr[:ErrorByteLimit] -} diff --git a/x/evm/keeper/msg_server_test.go b/x/evm/keeper/msg_server_test.go index 7a96a68f59..20482b1c70 100644 --- a/x/evm/keeper/msg_server_test.go +++ b/x/evm/keeper/msg_server_test.go @@ -2,7 +2,6 @@ package keeper_test import ( "bytes" - "context" "crypto/sha256" "encoding/hex" "math/big" @@ -20,8 +19,6 @@ import ( "github.com/sei-protocol/sei-chain/example/contracts/sendall" "github.com/sei-protocol/sei-chain/example/contracts/simplestorage" testkeeper "github.com/sei-protocol/sei-chain/testutil/keeper" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" "github.com/sei-protocol/sei-chain/x/evm/ante" "github.com/sei-protocol/sei-chain/x/evm/artifacts/erc20" "github.com/sei-protocol/sei-chain/x/evm/artifacts/erc721" @@ -725,9 +722,6 @@ func TestAssociateContractAddress(t *testing.T) { func TestAssociate(t *testing.T) { ctx := testkeeper.EVMTestApp.GetContextForDeliverTx([]byte{}).WithChainID("sei-test").WithBlockHeight(1) - ctx = ctx.WithContext( - context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, &dexcache.MemState{}), - ) privKey := testkeeper.MockPrivateKey() seiAddr, evmAddr := testkeeper.PrivateKeyToAddresses(privKey) acc := testkeeper.EVMTestApp.AccountKeeper.NewAccountWithAddress(ctx, seiAddr) diff --git a/x/mint/keeper/hooks_test.go b/x/mint/keeper/hooks_test.go index 760eea3dd1..787bfe5042 100644 --- a/x/mint/keeper/hooks_test.go +++ b/x/mint/keeper/hooks_test.go @@ -1,14 +1,10 @@ package keeper_test import ( - "context" "testing" "time" keepertest "github.com/sei-protocol/sei-chain/testutil/keeper" - dexcache "github.com/sei-protocol/sei-chain/x/dex/cache" - dextypes "github.com/sei-protocol/sei-chain/x/dex/types" - dexutils "github.com/sei-protocol/sei-chain/x/dex/utils" "github.com/sei-protocol/sei-chain/x/epoch/types" minttypes "github.com/sei-protocol/sei-chain/x/mint/types" "github.com/stretchr/testify/require" @@ -38,7 +34,6 @@ func TestEndOfEpochMintedCoinDistribution(t *testing.T) { t.Run("Initial should be zero", func(t *testing.T) { seiApp := keepertest.TestApp() ctx := seiApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(seiApp.GetMemKey(dextypes.MemStoreKey)))) header := tmproto.Header{ Height: seiApp.LastBlockHeight() + 1, @@ -51,7 +46,6 @@ func TestEndOfEpochMintedCoinDistribution(t *testing.T) { t.Run("even full release", func(t *testing.T) { seiApp := keepertest.TestApp() ctx := seiApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(seiApp.GetMemKey(dextypes.MemStoreKey)))) header := tmproto.Header{ Height: seiApp.LastBlockHeight() + 1, @@ -97,7 +91,6 @@ func TestEndOfEpochMintedCoinDistribution(t *testing.T) { t.Run("uneven full release", func(t *testing.T) { seiApp := keepertest.TestApp() ctx := seiApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(seiApp.GetMemKey(dextypes.MemStoreKey)))) header := tmproto.Header{ Height: seiApp.LastBlockHeight() + 1, @@ -144,7 +137,6 @@ func TestEndOfEpochMintedCoinDistribution(t *testing.T) { t.Run("multiple full releases", func(t *testing.T) { seiApp := keepertest.TestApp() ctx := seiApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(seiApp.GetMemKey(dextypes.MemStoreKey)))) header := tmproto.Header{ Height: seiApp.LastBlockHeight() + 1, @@ -203,7 +195,6 @@ func TestEndOfEpochMintedCoinDistribution(t *testing.T) { t.Run("outage during release", func(t *testing.T) { seiApp := keepertest.TestApp() ctx := seiApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(seiApp.GetMemKey(dextypes.MemStoreKey)))) header := tmproto.Header{ Height: seiApp.LastBlockHeight() + 1, @@ -278,7 +269,6 @@ func TestEndOfEpochMintedCoinDistribution(t *testing.T) { func TestNoEpochPassedNoDistribution(t *testing.T) { seiApp := keepertest.TestApp() ctx := seiApp.BaseApp.NewContext(false, tmproto.Header{Time: time.Now()}) - ctx = ctx.WithContext(context.WithValue(ctx.Context(), dexutils.DexMemStateContextKey, dexcache.NewMemState(seiApp.GetMemKey(dextypes.MemStoreKey)))) header := tmproto.Header{Height: seiApp.LastBlockHeight() + 1} seiApp.BeginBlock(ctx, abci.RequestBeginBlock{Header: header}) diff --git a/x/mint/types/gov.pb.go b/x/mint/types/gov.pb.go index 4ebcd8a7e6..32a3d8c9a7 100644 --- a/x/mint/types/gov.pb.go +++ b/x/mint/types/gov.pb.go @@ -23,8 +23,6 @@ var _ = math.Inf // proto package needs to be updated. const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package -// AddAssetMetadataProposal is a gov Content type for adding a new asset -// to the dex module's asset list. type UpdateMinterProposal struct { Title string `protobuf:"bytes,1,opt,name=title,proto3" json:"title,omitempty" yaml:"title"` Description string `protobuf:"bytes,2,opt,name=description,proto3" json:"description,omitempty" yaml:"description"`

      +i64Y9Hhv? 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 U?G!|?&mIeS6MO!r0NBU=50r}adH?_b diff --git a/x/dex/testdata/mars.wasm b/x/dex/testdata/mars.wasm deleted file mode 100644 index 8addcee304dbfe95128720b948d636864291403a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 191011 zcmeFa542}jRp)vC{QkY)pZ9+CFZEuk67KIuN?%Ep7LHOy$kKPKsU(O>Ovlw}o0(Kd ziXpE;NGb)5JsGM3X^0RoD6K(J3r(8{gpM}dlh%w@FhI0v32PWTJ&m)03L3Q^9$DqLsoL8PcdUxlN|M9vaF-lzojCC}{J#yoBe)o63^yO3UY>kDlyZ-nMZ{tc9fT&G}Noch> z*G}7c+HN+}@CKE51*npCXgW=s&D(>;xbo4$Ip{}@_ELyaV* zayQ?!Sv|M1R%1)DHLZ_Ipad?f0hL)*Fw!@lD5mG)sCn-E#Z!>u))JlSt>=8n?gs#y2H5_KzL8 z?aenGJ97JVw;#DFd1L4Ln{R&84XW^=w0q-`>h9;#O;trG_t^Ev-*hZ_7D7@ z(|?-2GksTjclu-LyVLii_oVMl7jC%W244HM^uy`DO#j#0jvc>c;UB-{tq-UF%c=BN z(|^K~hiLZ1!d>b6(jQOnRe!&n{#^F9g*&+V&Yw=-ys-b{>Az6%!q2C_kbW+G{laI{ zf0r(N=Wl1P|9utz`*cB7o=X2O9{tDki#+I{eRPE(mzlC zYx-=u@RQk3Wbe=ZJpJ+P-s}U}1KESwsqA#N@Qc~+WFO6bHT$*fce8()eIol;*}u)Y zAAYd=$?QMpY2!q;6#o^;VwTJ{(ngjiy&@_5%iNE%#*!X1Mro0i^EZ#Oe5pvwhMw^x z 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