From 8e4474cc1ba31549a0f55e60076cf6abd1965b78 Mon Sep 17 00:00:00 2001 From: Dzmitry Hil Date: Tue, 19 Nov 2024 13:46:24 +0300 Subject: [PATCH] Integrate order sequence into new DEX events and order queries. * Integrate new DEX events with the min required info * Add order sequence to all queries returning order(s) * Update all required tests + add extra to test the events consistency * Update genesis import/export to import/export current order sequence * Update naming of the order sequence * Describe DEX events in the spec. --- build/coreum/build.go | 2 +- build/coreum/generate-proto-breaking.go | 2 +- docs/api.md | 66 +- docs/static/openapi.json | 5 + integration-tests/modules/dex_test.go | 89 ++- proto/coreum/dex/v1/event.proto | 57 +- proto/coreum/dex/v1/genesis.proto | 14 +- proto/coreum/dex/v1/order.proto | 30 +- x/dex/client/cli/query_test.go | 4 + x/dex/genesis.go | 51 +- x/dex/genesis_test.go | 122 ++- x/dex/keeper/good_til_delay_msg_handler.go | 4 +- x/dex/keeper/keeper.go | 230 +++--- x/dex/keeper/keeper_good_til.go | 44 +- x/dex/keeper/keeper_good_til_test.go | 6 +- x/dex/keeper/keeper_matching.go | 33 +- x/dex/keeper/keeper_matching_result.go | 9 +- x/dex/keeper/keeper_matching_test.go | 99 ++- x/dex/keeper/keeper_ob_iterator.go | 10 +- x/dex/keeper/keeper_ob_iterator_test.go | 8 +- x/dex/keeper/keeper_store.go | 24 +- x/dex/keeper/keeper_test.go | 138 ++-- x/dex/spec/README.md | 12 + x/dex/types/event.pb.go | 870 ++++++++++++++++++--- x/dex/types/genesis.go | 13 +- x/dex/types/genesis.pb.go | 313 ++------ x/dex/types/keys.go | 76 +- x/dex/types/order.go | 14 +- x/dex/types/order.pb.go | 250 +++--- x/dex/types/order_test.go | 9 + 30 files changed, 1659 insertions(+), 945 deletions(-) diff --git a/build/coreum/build.go b/build/coreum/build.go index 8d63f9d0a..019531ae9 100644 --- a/build/coreum/build.go +++ b/build/coreum/build.go @@ -195,7 +195,7 @@ func Lint(ctx context.Context, deps types.DepsFunc) error { CompileAllSmartContracts, formatProto, lintProto, - // breakingProto, // TODO: uncomment in next PR + // breakingProto, // FIXME: uncomment in next PR ) return golang.Lint(ctx, deps) } diff --git a/build/coreum/generate-proto-breaking.go b/build/coreum/generate-proto-breaking.go index 5e869f1a5..7a724c59e 100644 --- a/build/coreum/generate-proto-breaking.go +++ b/build/coreum/generate-proto-breaking.go @@ -22,7 +22,7 @@ import ( ) //go:embed proto-breaking.tmpl.json -//nolint:unused // TODO: uncomment in next PR +//nolint:unused // FIXME: uncomment in next PR var configBreakingTmpl string //nolint:deadcode diff --git a/docs/api.md b/docs/api.md index d061d5586..78b487549 100644 --- a/docs/api.md +++ b/docs/api.md @@ -198,13 +198,13 @@ - [coreum/dex/v1/event.proto](#coreum/dex/v1/event.proto) - [EventOrderClosed](#coreum.dex.v1.EventOrderClosed) - [EventOrderCreated](#coreum.dex.v1.EventOrderCreated) + - [EventOrderPlaced](#coreum.dex.v1.EventOrderPlaced) - [EventOrderReduced](#coreum.dex.v1.EventOrderReduced) - [coreum/dex/v1/genesis.proto](#coreum/dex/v1/genesis.proto) - [AccountDenomOrdersCount](#coreum.dex.v1.AccountDenomOrdersCount) - [GenesisState](#coreum.dex.v1.GenesisState) - [OrderBookDataWithID](#coreum.dex.v1.OrderBookDataWithID) - - [OrderWithSequence](#coreum.dex.v1.OrderWithSequence) - [coreum/dex/v1/order.proto](#coreum/dex/v1/order.proto) - [CancelGoodTil](#coreum.dex.v1.CancelGoodTil) @@ -4488,14 +4488,18 @@ EventGas is emitted by deterministic gas module to report gas information. ### EventOrderClosed ``` -EventOrderClosed is emitted when the order is closed during matching or manually. +EventOrderClosed is emitted when the order is closed during matching or manually, and removed from the order book. ``` | Field | Type | Label | Description | | ----- | ---- | ----- | ----------- | -| `order` | [Order](#coreum.dex.v1.Order) | | | +| `creator` | [string](#string) | | `creator is order creator address.` | +| `id` | [string](#string) | | `id is unique order ID.` | +| `sequence` | [uint64](#uint64) | | `sequence is unique order sequence.` | +| `remaining_quantity` | [string](#string) | | `remaining_quantity is remaining filling quantity sell/buy.` | +| `remaining_balance` | [string](#string) | | `remaining_balance is remaining order balance.` | @@ -4514,7 +4518,32 @@ EventOrderCreated is emitted when the limit order is saved to the order book. | Field | Type | Label | Description | | ----- | ---- | ----- | ----------- | -| `order` | [Order](#coreum.dex.v1.Order) | | | +| `creator` | [string](#string) | | `creator is order creator address.` | +| `id` | [string](#string) | | `id is unique order ID.` | +| `sequence` | [uint64](#uint64) | | `sequence is unique order sequence.` | +| `remaining_quantity` | [string](#string) | | `remaining_quantity is remaining filling quantity sell/buy.` | +| `remaining_balance` | [string](#string) | | `remaining_balance is remaining order balance.` | + + + + + + + + +### EventOrderPlaced + +``` +EventOrderPlaced is emitted when a new order is placed and new sequence is generated for it. +``` + + + +| Field | Type | Label | Description | +| ----- | ---- | ----- | ----------- | +| `creator` | [string](#string) | | `creator is order creator address.` | +| `id` | [string](#string) | | `id is unique order ID.` | +| `sequence` | [uint64](#uint64) | | `sequence is unique order sequence.` | @@ -4535,6 +4564,7 @@ EventOrderReduced is emitted when the order is reduced during the matching. | ----- | ---- | ----- | ----------- | | `creator` | [string](#string) | | `creator is order creator address.` | | `id` | [string](#string) | | `id is unique order ID.` | +| `sequence` | [uint64](#uint64) | | `sequence is unique order sequence.` | | `sent_coin` | [string](#string) | | `sent_coin is coin sent during matching.` | | `received_coin` | [string](#string) | | `received_coin is coin received during matching.` | @@ -4594,7 +4624,8 @@ GenesisState defines the module genesis state. | ----- | ---- | ----- | ----------- | | `params` | [Params](#coreum.dex.v1.Params) | | `params defines all the parameters of the module.` | | `order_books` | [OrderBookDataWithID](#coreum.dex.v1.OrderBookDataWithID) | repeated | | -| `orders` | [OrderWithSequence](#coreum.dex.v1.OrderWithSequence) | repeated | | +| `orders` | [Order](#coreum.dex.v1.Order) | repeated | | +| `order_sequence` | [uint64](#uint64) | | `order_sequence is current order sequence;` | | `accounts_denoms_orders_counts` | [AccountDenomOrdersCount](#coreum.dex.v1.AccountDenomOrdersCount) | repeated | | @@ -4621,26 +4652,6 @@ OrderBookDataWithID is a order book data with it's corresponding ID. - - - -### OrderWithSequence - -``` -OrderWithSequence is a order with it's corresponding sequence. -``` - - - -| Field | Type | Label | Description | -| ----- | ---- | ----- | ----------- | -| `sequence` | [uint64](#uint64) | | `sequence is order sequence.` | -| `order` | [Order](#coreum.dex.v1.Order) | | `data is order book data.` | - - - - - @@ -4671,7 +4682,7 @@ CancelGoodTil is a cancel good til message for the delay router. | Field | Type | Label | Description | | ----- | ---- | ----- | ----------- | | `creator` | [string](#string) | | `creator is order creator address.` | -| `order_seq` | [uint64](#uint64) | | `order_seq is order sequence.` | +| `order_sequence` | [uint64](#uint64) | | `order_sequence is order sequence.` | @@ -4713,6 +4724,7 @@ Order is a DEX order. | `creator` | [string](#string) | | `creator is order creator address.` | | `type` | [OrderType](#coreum.dex.v1.OrderType) | | `type is order type.` | | `id` | [string](#string) | | `id is unique order ID.` | +| `sequence` | [uint64](#uint64) | | `sequence is unique order sequence generated at the time of the order placement.` | | `base_denom` | [string](#string) | | `base_denom is base order denom.` | | `quote_denom` | [string](#string) | | `quote_denom is quote order denom` | | `price` | [string](#string) | | `price is value of one unit of the base_denom expressed in terms of the quote_denom.` | @@ -4764,7 +4776,7 @@ OrderBookRecord is a single order book record. | `order_book_id` | [uint32](#uint32) | | `order_book_id is order book ID.` | | `side` | [Side](#coreum.dex.v1.Side) | | `side is order side.` | | `price` | [string](#string) | | `price is order book record price.` | -| `order_seq` | [uint64](#uint64) | | `order_seq is order sequence.` | +| `order_sequence` | [uint64](#uint64) | | `order_sequence is order sequence.` | | `order_id` | [string](#string) | | `order ID provided by the creator.` | | `account_number` | [uint64](#uint64) | | `account_number is account number which corresponds the order creator.` | | `remaining_quantity` | [string](#string) | | `remaining_quantity is remaining filling quantity sell/buy.` | diff --git a/docs/static/openapi.json b/docs/static/openapi.json index 7a4a924d1..981a9c795 100644 --- a/docs/static/openapi.json +++ b/docs/static/openapi.json @@ -10101,6 +10101,11 @@ "type": "string", "description": "id is unique order ID." }, + "sequence": { + "type": "string", + "format": "uint64", + "description": "sequence is unique order sequence generated at the time of the order placement." + }, "base_denom": { "type": "string", "description": "base_denom is base order denom." diff --git a/integration-tests/modules/dex_test.go b/integration-tests/modules/dex_test.go index a88d2fe1b..6a5ea838a 100644 --- a/integration-tests/modules/dex_test.go +++ b/integration-tests/modules/dex_test.go @@ -90,6 +90,7 @@ func TestLimitOrdersMatching(t *testing.T) { Creator: acc1.String(), Type: dextypes.ORDER_TYPE_LIMIT, ID: "id1", + Sequence: sellOrderRes.Order.Sequence, BaseDenom: denom1, QuoteDenom: denom2, Price: lo.ToPtr(dextypes.MustNewPriceFromString("1e-1")), @@ -141,6 +142,7 @@ func TestLimitOrdersMatching(t *testing.T) { Creator: acc2.String(), Type: dextypes.ORDER_TYPE_LIMIT, ID: "id1", // same ID allowed for different users + Sequence: buyOrderRes.Order.Sequence, BaseDenom: denom1, QuoteDenom: denom2, Price: lo.ToPtr(dextypes.MustNewPriceFromString("11e-2")), @@ -615,6 +617,7 @@ func TestOrderBooksAndOrdersQueries(t *testing.T) { acc1OrderPlaceMsgs..., ) requireT.NoError(err) + acc1Orders = fillOrderSequences(ctx, t, chain.ClientContext, acc1Orders) // create acc2 orders acc2Orders := []dextypes.Order{ @@ -661,6 +664,7 @@ func TestOrderBooksAndOrdersQueries(t *testing.T) { acc2OrderPlaceMsgs..., ) requireT.NoError(err) + acc2Orders = fillOrderSequences(ctx, t, chain.ClientContext, acc2Orders) // check order books query orderBooksRes, err := dexClient.OrderBooks(ctx, &dextypes.QueryOrderBooksRequest{}) @@ -1608,6 +1612,7 @@ func TestLimitOrdersMatchingWithBurnRate(t *testing.T) { Creator: acc1.String(), Type: dextypes.ORDER_TYPE_LIMIT, ID: "id1", + Sequence: sellOrderRes.Order.Sequence, BaseDenom: denom1, QuoteDenom: denom2, Price: lo.ToPtr(dextypes.MustNewPriceFromString("1e-1")), @@ -1757,6 +1762,7 @@ func TestLimitOrdersMatchingWithCommissionRate(t *testing.T) { Creator: acc1.String(), Type: dextypes.ORDER_TYPE_LIMIT, ID: "id1", + Sequence: sellOrderRes.Order.Sequence, BaseDenom: denom1, QuoteDenom: denom2, Price: lo.ToPtr(dextypes.MustNewPriceFromString("1e-1")), @@ -2155,38 +2161,6 @@ func TestCancelOrdersByDenom(t *testing.T) { requireT.Empty(orderRes.Orders) } -func issueFT( - ctx context.Context, - t *testing.T, - chain integration.CoreumChain, - issuer sdk.AccAddress, - initialAmount sdkmath.Int, - features ...assetfttypes.Feature, -) string { - chain.FundAccountWithOptions(ctx, t, issuer, integration.BalancesOptions{ - Messages: []sdk.Msg{ - &assetfttypes.MsgIssue{}, - }, - Amount: chain.QueryAssetFTParams(ctx, t).IssueFee.Amount, - }) - issueMsg := &assetfttypes.MsgIssue{ - Issuer: issuer.String(), - Symbol: "TKN" + uuid.NewString()[:4], - Subunit: "tkn" + uuid.NewString()[:4], - Precision: 5, - InitialAmount: initialAmount, - Features: features, - } - _, err := client.BroadcastTx( - ctx, - chain.ClientContext.WithFromAddress(issuer), - chain.TxFactory().WithGas(chain.GasLimitByMsgs(issueMsg)), - issueMsg, - ) - require.NoError(t, err) - return assetfttypes.BuildDenom(issueMsg.Subunit, issuer) -} - // TestAssetFTBlockSmartContractsFeatureWithDEX tests the dex module integration with the asset ft // block_smart_contracts features. func TestAssetFTBlockSmartContractsFeatureWithDEX(t *testing.T) { @@ -2522,6 +2496,57 @@ func TestLimitOrdersMatchingWithAssetBurning(t *testing.T) { requireT.Equal(sdkmath.NewInt(0).String(), balanceRes.LockedInDEX.String()) } +func issueFT( + ctx context.Context, + t *testing.T, + chain integration.CoreumChain, + issuer sdk.AccAddress, + initialAmount sdkmath.Int, + features ...assetfttypes.Feature, +) string { + chain.FundAccountWithOptions(ctx, t, issuer, integration.BalancesOptions{ + Messages: []sdk.Msg{ + &assetfttypes.MsgIssue{}, + }, + Amount: chain.QueryAssetFTParams(ctx, t).IssueFee.Amount, + }) + issueMsg := &assetfttypes.MsgIssue{ + Issuer: issuer.String(), + Symbol: "TKN" + uuid.NewString()[:4], + Subunit: "tkn" + uuid.NewString()[:4], + Precision: 5, + InitialAmount: initialAmount, + Features: features, + } + _, err := client.BroadcastTx( + ctx, + chain.ClientContext.WithFromAddress(issuer), + chain.TxFactory().WithGas(chain.GasLimitByMsgs(issueMsg)), + issueMsg, + ) + require.NoError(t, err) + return assetfttypes.BuildDenom(issueMsg.Subunit, issuer) +} + +func fillOrderSequences( + ctx context.Context, + t *testing.T, + clientCtx client.Context, + orders []dextypes.Order, +) []dextypes.Order { + dexClient := dextypes.NewQueryClient(clientCtx) + for i, order := range orders { + res, err := dexClient.Order(ctx, &dextypes.QueryOrderRequest{ + Creator: order.Creator, + Id: order.ID, + }) + require.NoError(t, err) + orders[i].Sequence = res.Order.Sequence + } + + return orders +} + func ordersToPlaceMsgs(orders []dextypes.Order) []sdk.Msg { return lo.Map(orders, func(order dextypes.Order, _ int) sdk.Msg { return &dextypes.MsgPlaceOrder{ diff --git a/proto/coreum/dex/v1/event.proto b/proto/coreum/dex/v1/event.proto index be3415bee..1ba321ac3 100644 --- a/proto/coreum/dex/v1/event.proto +++ b/proto/coreum/dex/v1/event.proto @@ -1,14 +1,18 @@ syntax = "proto3"; package coreum.dex.v1; -import "coreum/dex/v1/order.proto"; import "gogoproto/gogo.proto"; option go_package = "github.com/CoreumFoundation/coreum/v5/x/dex/types"; -// EventOrderCreated is emitted when the limit order is saved to the order book. -message EventOrderCreated { - Order order = 1 [(gogoproto.nullable) = false]; +// EventOrderPlaced is emitted when a new order is placed and new sequence is generated for it. +message EventOrderPlaced { + // creator is order creator address. + string creator = 1; + // id is unique order ID. + string id = 2 [(gogoproto.customname) = "ID"]; + // sequence is unique order sequence. + uint64 sequence = 3; } // EventOrderReduced is emitted when the order is reduced during the matching. @@ -17,19 +21,56 @@ message EventOrderReduced { string creator = 1; // id is unique order ID. string id = 2 [(gogoproto.customname) = "ID"]; + // sequence is unique order sequence. + uint64 sequence = 3; // sent_coin is coin sent during matching. - string sent_coin = 3 [ + string sent_coin = 4 [ (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Coin", (gogoproto.nullable) = false ]; // received_coin is coin received during matching. - string received_coin = 4 [ + string received_coin = 5 [ (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Coin", (gogoproto.nullable) = false ]; } -// EventOrderClosed is emitted when the order is closed during matching or manually. +// EventOrderCreated is emitted when the limit order is saved to the order book. +message EventOrderCreated { + // creator is order creator address. + string creator = 1; + // id is unique order ID. + string id = 2 [(gogoproto.customname) = "ID"]; + // sequence is unique order sequence. + uint64 sequence = 3; + // remaining_quantity is remaining filling quantity sell/buy. + string remaining_quantity = 4 [ + (gogoproto.customtype) = "cosmossdk.io/math.Int", + (gogoproto.nullable) = false + ]; + // remaining_balance is remaining order balance. + string remaining_balance = 5 [ + (gogoproto.customtype) = "cosmossdk.io/math.Int", + (gogoproto.nullable) = false + ]; +} + +// EventOrderClosed is emitted when the order is closed during matching or manually, and removed from the order book. message EventOrderClosed { - Order order = 1 [(gogoproto.nullable) = false]; + // creator is order creator address. + string creator = 1; + // id is unique order ID. + string id = 2 [(gogoproto.customname) = "ID"]; + // sequence is unique order sequence. + uint64 sequence = 3; + // remaining_quantity is remaining filling quantity sell/buy. + string remaining_quantity = 4 [ + (gogoproto.customtype) = "cosmossdk.io/math.Int", + (gogoproto.nullable) = false + ]; + // remaining_balance is remaining order balance. + string remaining_balance = 5 [ + (gogoproto.customtype) = "cosmossdk.io/math.Int", + (gogoproto.nullable) = false + ]; } diff --git a/proto/coreum/dex/v1/genesis.proto b/proto/coreum/dex/v1/genesis.proto index 555f65d94..e04186c93 100644 --- a/proto/coreum/dex/v1/genesis.proto +++ b/proto/coreum/dex/v1/genesis.proto @@ -12,8 +12,10 @@ message GenesisState { // params defines all the parameters of the module. Params params = 1 [(gogoproto.nullable) = false]; repeated OrderBookDataWithID order_books = 2 [(gogoproto.nullable) = false]; - repeated OrderWithSequence orders = 3 [(gogoproto.nullable) = false]; - repeated AccountDenomOrdersCount accounts_denoms_orders_counts = 4 [(gogoproto.nullable) = false]; + repeated Order orders = 3 [(gogoproto.nullable) = false]; + // order_sequence is current order sequence; + uint64 order_sequence = 4; + repeated AccountDenomOrdersCount accounts_denoms_orders_counts = 5 [(gogoproto.nullable) = false]; } // OrderBookDataWithID is a order book data with it's corresponding ID. @@ -24,14 +26,6 @@ message OrderBookDataWithID { OrderBookData data = 2 [(gogoproto.nullable) = false]; } -// OrderWithSequence is a order with it's corresponding sequence. -message OrderWithSequence { - // sequence is order sequence. - uint64 sequence = 1; - // data is order book data. - Order order = 2 [(gogoproto.nullable) = false]; -} - // AccountDenomOrderCount is a count of orders per account and denom. message AccountDenomOrdersCount { uint64 account_number = 1; diff --git a/proto/coreum/dex/v1/order.proto b/proto/coreum/dex/v1/order.proto index 4374bc83b..57ea358a6 100644 --- a/proto/coreum/dex/v1/order.proto +++ b/proto/coreum/dex/v1/order.proto @@ -42,8 +42,8 @@ message GoodTil { message CancelGoodTil { // creator is order creator address. string creator = 1; - // order_seq is order sequence. - uint64 order_seq = 2; + // order_sequence is order sequence. + uint64 order_sequence = 2; } // TimeInForce is order time in force. @@ -68,35 +68,37 @@ message Order { OrderType type = 2; // id is unique order ID. string id = 3 [(gogoproto.customname) = "ID"]; + // sequence is unique order sequence generated at the time of the order placement. + uint64 sequence = 4; // base_denom is base order denom. - string base_denom = 4; + string base_denom = 5; // quote_denom is quote order denom - string quote_denom = 5; + string quote_denom = 6; // price is value of one unit of the base_denom expressed in terms of the quote_denom. - string price = 6 [(gogoproto.customtype) = "Price"]; + string price = 7 [(gogoproto.customtype) = "Price"]; // quantity is amount of the base base_denom being traded. - string quantity = 7 [ + string quantity = 8 [ (gogoproto.customtype) = "cosmossdk.io/math.Int", (gogoproto.nullable) = false ]; // side is order side. - Side side = 8; + Side side = 9; // remaining_quantity is remaining filling quantity sell/buy. - string remaining_quantity = 9 [ + string remaining_quantity = 10 [ (gogoproto.customtype) = "cosmossdk.io/math.Int", (gogoproto.nullable) = false ]; // remaining_balance is remaining order balance. - string remaining_balance = 10 [ + string remaining_balance = 11 [ (gogoproto.customtype) = "cosmossdk.io/math.Int", (gogoproto.nullable) = false ]; // good_til is order good til - GoodTil good_til = 11; + GoodTil good_til = 12; // time_in_force is order time in force - TimeInForce time_in_force = 12; + TimeInForce time_in_force = 13; // reserve is the reserve required to save the order in the order book - cosmos.base.v1beta1.Coin reserve = 13 [ + cosmos.base.v1beta1.Coin reserve = 14 [ (gogoproto.nullable) = false, (gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Coin" ]; @@ -148,8 +150,8 @@ message OrderBookRecord { (gogoproto.customtype) = "Price", (gogoproto.nullable) = false ]; - // order_seq is order sequence. - uint64 order_seq = 4; + // order_sequence is order sequence. + uint64 order_sequence = 4; // order ID provided by the creator. string order_id = 5 [(gogoproto.customname) = "OrderID"]; // account_number is account number which corresponds the order creator. diff --git a/x/dex/client/cli/query_test.go b/x/dex/client/cli/query_test.go index ea9ccafe8..e53b5e5ba 100644 --- a/x/dex/client/cli/query_test.go +++ b/x/dex/client/cli/query_test.go @@ -40,6 +40,7 @@ func TestCmdQueryOrderBooksAndOrders(t *testing.T) { Creator: creator.String(), Type: types.ORDER_TYPE_LIMIT, ID: "id1", + Sequence: 1, BaseDenom: denom1, QuoteDenom: denom2, Price: lo.ToPtr(types.MustNewPriceFromString("123e-2")), @@ -77,6 +78,7 @@ func TestCmdQueryOrderBooksAndOrders(t *testing.T) { Creator: creator.String(), Type: types.ORDER_TYPE_LIMIT, ID: "id2", + Sequence: 2, BaseDenom: denom1, QuoteDenom: denom3, Price: lo.ToPtr(types.MustNewPriceFromString("124e-2")), @@ -122,6 +124,7 @@ func TestCmdQueryAccountDenomOrdersCount(t *testing.T) { Creator: creator.String(), Type: types.ORDER_TYPE_LIMIT, ID: "id1", + Sequence: 1, BaseDenom: denom1, QuoteDenom: denom2, Price: lo.ToPtr(types.MustNewPriceFromString("123e-2")), @@ -159,6 +162,7 @@ func TestCmdQueryAccountDenomOrdersCount(t *testing.T) { Creator: creator.String(), Type: types.ORDER_TYPE_LIMIT, ID: "id2", + Sequence: 2, BaseDenom: denom1, QuoteDenom: denom3, Price: lo.ToPtr(types.MustNewPriceFromString("124e-2")), diff --git a/x/dex/genesis.go b/x/dex/genesis.go index cf40a19e2..649e692a8 100644 --- a/x/dex/genesis.go +++ b/x/dex/genesis.go @@ -35,36 +35,31 @@ func InitGenesis( } } if maxOrderID != 0 { - if err := dexKeeper.SetOrderBookSeq(ctx, maxOrderID); err != nil { + if err := dexKeeper.SetOrderBookSequence(ctx, maxOrderID); err != nil { panic(errors.Wrap(err, "failed to set order book sequence")) } } - maxOrderSeq := uint64(0) - accAddressToNumberCache := make(map[string]uint64) - for _, orderWithSeq := range genState.Orders { + for _, order := range genState.Orders { // check that the order book exists - orderBookID, err := dexKeeper.GetOrderBookIDByDenoms(ctx, orderWithSeq.Order.BaseDenom, orderWithSeq.Order.QuoteDenom) + orderBookID, err := dexKeeper.GetOrderBookIDByDenoms(ctx, order.BaseDenom, order.QuoteDenom) if err != nil { panic( errors.Wrapf( err, "failed to get order book ID by denoms, base: %s, quote: %s", - orderWithSeq.Order.BaseDenom, orderWithSeq.Order.QuoteDenom, + order.BaseDenom, order.QuoteDenom, ), ) } - if orderWithSeq.Sequence > maxOrderSeq { - maxOrderSeq = orderWithSeq.Sequence - } - creator, err := sdk.AccAddressFromBech32(orderWithSeq.Order.Creator) + creator, err := sdk.AccAddressFromBech32(order.Creator) if err != nil { - panic(sdkerrors.Wrapf(types.ErrInvalidInput, "invalid address: %s", orderWithSeq.Order.Creator)) + panic(sdkerrors.Wrapf(types.ErrInvalidInput, "invalid address: %s", order.Creator)) } - accNumber, ok := accAddressToNumberCache[orderWithSeq.Order.Creator] + accNumber, ok := accAddressToNumberCache[order.Creator] if !ok { var err error acc := accountKeeper.GetAccount(ctx, creator) @@ -72,27 +67,25 @@ func InitGenesis( panic(errors.Wrap(err, "account not fond: "+creator.String())) } accNumber = acc.GetAccountNumber() - accAddressToNumberCache[orderWithSeq.Order.Creator] = accNumber + accAddressToNumberCache[order.Creator] = accNumber } record := types.OrderBookRecord{ OrderBookID: orderBookID, - Side: orderWithSeq.Order.Side, - Price: *orderWithSeq.Order.Price, - OrderSeq: orderWithSeq.Sequence, - OrderID: orderWithSeq.Order.ID, + Side: order.Side, + Price: *order.Price, + OrderSequence: order.Sequence, + OrderID: order.ID, AccountNumber: accNumber, - RemainingQuantity: orderWithSeq.Order.RemainingQuantity, - RemainingBalance: orderWithSeq.Order.RemainingBalance, + RemainingQuantity: order.RemainingQuantity, + RemainingBalance: order.RemainingBalance, } - if err := dexKeeper.SaveOrderWithOrderBookRecord(ctx, orderWithSeq.Order, record); err != nil { + if err := dexKeeper.SaveOrderWithOrderBookRecord(ctx, order, record); err != nil { panic(errors.Wrap(err, "failed to set order with order book record")) } } - if maxOrderSeq != 0 { - if err := dexKeeper.SetOrderSeq(ctx, maxOrderSeq); err != nil { - panic(errors.Wrap(err, "failed to set order sequence")) - } + if err := dexKeeper.SetOrderSequence(ctx, genState.OrderSequence); err != nil { + panic(errors.Wrap(err, "failed to set order sequence")) } for _, accountDenomOrdersCount := range genState.AccountsDenomsOrdersCounts { @@ -104,7 +97,7 @@ func InitGenesis( // ExportGenesis returns the dex module's exported genesis. func ExportGenesis(ctx sdk.Context, k keeper.Keeper) *types.GenesisState { - ordersWithSeq, _, err := k.GetOrdersWithSequence(ctx, &query.PageRequest{Limit: query.PaginationMaxLimit}) + orders, _, err := k.GetAccountsOrders(ctx, &query.PageRequest{Limit: query.PaginationMaxLimit}) if err != nil { panic(errors.Wrap(err, "failed to get orders with sequence")) } @@ -121,10 +114,16 @@ func ExportGenesis(ctx sdk.Context, k keeper.Keeper) *types.GenesisState { panic(errors.Wrap(err, "failed to get accounts denoms orders counts")) } + orderSequence, err := k.GetOrderSequence(ctx) + if err != nil { + panic(errors.Wrap(err, "failed to get order sequence")) + } + return &types.GenesisState{ Params: k.GetParams(ctx), - Orders: ordersWithSeq, + Orders: orders, OrderBooks: orderBooksWithID, + OrderSequence: orderSequence, AccountsDenomsOrdersCounts: accountsDenomsOrdersCounts, } } diff --git a/x/dex/genesis_test.go b/x/dex/genesis_test.go index 47579f5ee..07d35db64 100644 --- a/x/dex/genesis_test.go +++ b/x/dex/genesis_test.go @@ -79,72 +79,66 @@ func TestInitAndExportGenesis(t *testing.T) { }, }, }, - Orders: []types.OrderWithSequence{ + Orders: []types.Order{ { - Sequence: 0, - Order: types.Order{ - Creator: acc1.String(), - Type: types.ORDER_TYPE_LIMIT, - ID: "id1", - BaseDenom: denom1, - QuoteDenom: denom2, - Price: lo.ToPtr(types.MustNewPriceFromString("1e-2")), - Quantity: sdkmath.NewInt(100), - Side: types.SIDE_BUY, - GoodTil: &types.GoodTil{ - GoodTilBlockHeight: 1000, - }, - TimeInForce: types.TIME_IN_FORCE_GTC, - RemainingQuantity: sdkmath.NewInt(90), - RemainingBalance: sdkmath.NewInt(90), - Reserve: prams.OrderReserve, + Creator: acc1.String(), + Type: types.ORDER_TYPE_LIMIT, + ID: "id1", + Sequence: 1, + BaseDenom: denom1, + QuoteDenom: denom2, + Price: lo.ToPtr(types.MustNewPriceFromString("1e-2")), + Quantity: sdkmath.NewInt(100), + Side: types.SIDE_BUY, + GoodTil: &types.GoodTil{ + GoodTilBlockHeight: 1000, }, + TimeInForce: types.TIME_IN_FORCE_GTC, + RemainingQuantity: sdkmath.NewInt(90), + RemainingBalance: sdkmath.NewInt(90), + Reserve: prams.OrderReserve, }, { - Sequence: 1, - Order: types.Order{ - Creator: acc2.String(), - Type: types.ORDER_TYPE_LIMIT, - ID: "id2", - BaseDenom: denom2, - QuoteDenom: denom1, - Price: lo.ToPtr(types.MustNewPriceFromString("3e3")), - Quantity: sdkmath.NewInt(100), - Side: types.SIDE_SELL, - TimeInForce: types.TIME_IN_FORCE_GTC, - RemainingQuantity: sdkmath.NewInt(90), - RemainingBalance: sdkmath.NewInt(90), - Reserve: prams.OrderReserve, - }, + Creator: acc2.String(), + Type: types.ORDER_TYPE_LIMIT, + ID: "id2", + Sequence: 2, + BaseDenom: denom2, + QuoteDenom: denom1, + Price: lo.ToPtr(types.MustNewPriceFromString("3e3")), + Quantity: sdkmath.NewInt(100), + Side: types.SIDE_SELL, + TimeInForce: types.TIME_IN_FORCE_GTC, + RemainingQuantity: sdkmath.NewInt(90), + RemainingBalance: sdkmath.NewInt(90), + Reserve: prams.OrderReserve, }, { - Sequence: 2, - Order: types.Order{ - Creator: acc2.String(), - Type: types.ORDER_TYPE_LIMIT, - ID: "id3", - BaseDenom: denom2, - QuoteDenom: denom3, - Price: lo.ToPtr(types.MustNewPriceFromString("11111e12")), - Quantity: sdkmath.NewInt(10000000), - Side: types.SIDE_BUY, - GoodTil: &types.GoodTil{ - GoodTilBlockHeight: 323, - }, - TimeInForce: types.TIME_IN_FORCE_GTC, - RemainingQuantity: sdkmath.NewInt(70000), - RemainingBalance: sdkmath.NewInt(50), - Reserve: prams.OrderReserve, + Creator: acc2.String(), + Type: types.ORDER_TYPE_LIMIT, + ID: "id3", + Sequence: 3, + BaseDenom: denom2, + QuoteDenom: denom3, + Price: lo.ToPtr(types.MustNewPriceFromString("11111e12")), + Quantity: sdkmath.NewInt(10000000), + Side: types.SIDE_BUY, + GoodTil: &types.GoodTil{ + GoodTilBlockHeight: 323, }, + TimeInForce: types.TIME_IN_FORCE_GTC, + RemainingQuantity: sdkmath.NewInt(70000), + RemainingBalance: sdkmath.NewInt(50), + Reserve: prams.OrderReserve, }, }, } accountDenomToAccountDenomOrdersCount := make(map[string]types.AccountDenomOrdersCount, 0) - for _, orderWithSeq := range genState.Orders { - creator := sdk.MustAccAddressFromBech32(orderWithSeq.Order.Creator) + for _, order := range genState.Orders { + creator := sdk.MustAccAddressFromBech32(order.Creator) accNum := testApp.AccountKeeper.GetAccount(sdkCtx, creator).GetAccountNumber() - for _, denom := range orderWithSeq.Order.Denoms() { + for _, denom := range order.Denoms() { key := fmt.Sprintf("%d%s", accNum, denom) count, ok := accountDenomToAccountDenomOrdersCount[key] if !ok { @@ -158,7 +152,7 @@ func TestInitAndExportGenesis(t *testing.T) { accountDenomToAccountDenomOrdersCount[key] = count } // emulate asset FT locking, expecting that the asset FT imports state before the DEX - lockedBalance, err := orderWithSeq.Order.ComputeLimitOrderLockedBalance() + lockedBalance, err := order.ComputeLimitOrderLockedBalance() require.NoError(t, err) testApp.MintAndSendCoin(t, sdkCtx, creator, sdk.NewCoins(lockedBalance)) require.NoError(t, testApp.AssetFTKeeper.DEXIncreaseLocked( @@ -166,12 +160,15 @@ func TestInitAndExportGenesis(t *testing.T) { )) testApp.MintAndSendCoin(t, sdkCtx, creator, sdk.NewCoins(prams.OrderReserve)) require.NoError(t, testApp.AssetFTKeeper.DEXIncreaseLocked( - sdkCtx, creator, orderWithSeq.Order.Reserve, + sdkCtx, creator, order.Reserve, )) } // set the correct state genState.AccountsDenomsOrdersCounts = lo.Values(accountDenomToAccountDenomOrdersCount) + // the order sequence is last order sequence + genState.OrderSequence = 3 + // init the keeper dex.InitGenesis(sdkCtx, dexKeeper, testApp.AccountKeeper, genState) @@ -201,6 +198,7 @@ func TestInitAndExportGenesis(t *testing.T) { Creator: acc2.String(), Type: types.ORDER_TYPE_LIMIT, ID: "id4", + Sequence: 0, BaseDenom: denom2, QuoteDenom: denom3, Price: lo.ToPtr(types.MustNewPriceFromString("4e3")), @@ -215,6 +213,7 @@ func TestInitAndExportGenesis(t *testing.T) { require.NoError(t, dexKeeper.PlaceOrder(sdkCtx, orderWithExisingOrderBook)) // set the expected state + orderWithExisingOrderBook.Sequence = 4 orderWithExisingOrderBook.RemainingQuantity = sdkmath.NewInt(10000000) orderWithExisingOrderBook.RemainingBalance = sdkmath.NewInt(40000000000) orderWithExisingOrderBook.Reserve = params.OrderReserve @@ -228,18 +227,17 @@ func TestInitAndExportGenesis(t *testing.T) { require.Equal(t, uint64(2), denom3Count) // check that this order sequence is next - ordersWithSeq, _, err := dexKeeper.GetOrdersWithSequence( + orders, _, err := dexKeeper.GetAccountsOrders( sdkCtx, &query.PageRequest{Limit: query.PaginationMaxLimit}, ) require.NoError(t, err) orderFound := false - for _, orderWithSeq := range ordersWithSeq { - if orderWithSeq.Order.Creator == acc2.String() && orderWithSeq.Order.ID == orderWithExisingOrderBook.ID { + for _, order := range orders { + if order.Creator == acc2.String() && order.ID == orderWithExisingOrderBook.ID { orderFound = true - // check that next seq is max from imported + 1 - requireT.Equal(uint64(3), orderWithSeq.Sequence) - requireT.EqualValues(orderWithExisingOrderBook, orderWithSeq.Order) + // the `orderWithExisingOrderBook` has the sequence eq to 4 to check that next sequence from imported is used + requireT.EqualValues(orderWithExisingOrderBook, order) } } require.True(t, orderFound) @@ -270,7 +268,7 @@ func TestInitAndExportGenesis(t *testing.T) { require.NoError(t, err) require.Equal(t, uint32(5), denom3ToDenom1OrderBookID) - // cancel orders by denom to be sure that the acc-denom-orderSeq mapping is saved + // cancel orders by denom to be sure that the acc-denom-order mapping is saved acc1Orders, _, err := dexKeeper.GetOrders(sdkCtx, acc2, &query.PageRequest{Limit: query.PaginationMaxLimit}) require.NoError(t, err) require.Len(t, acc1Orders, 3) diff --git a/x/dex/keeper/good_til_delay_msg_handler.go b/x/dex/keeper/good_til_delay_msg_handler.go index ed48296e9..4eb859a68 100644 --- a/x/dex/keeper/good_til_delay_msg_handler.go +++ b/x/dex/keeper/good_til_delay_msg_handler.go @@ -11,7 +11,7 @@ import ( // CancelOrderKeeper is keeper interface required for CancelGoodTil. type CancelOrderKeeper interface { - CancelOrderBySeq(ctx sdk.Context, acc sdk.AccAddress, orderSeq uint64) error + CancelOrderBySequence(ctx sdk.Context, acc sdk.AccAddress, orderSequence uint64) error } // NewDelayCancelOrderHandler handles order cancellation. @@ -26,6 +26,6 @@ func NewDelayCancelOrderHandler(keeper CancelOrderKeeper) func(ctx sdk.Context, return sdkerrors.Wrap(cosmoserrors.ErrInvalidAddress, "invalid sender") } - return keeper.CancelOrderBySeq(ctx, sender, msg.OrderSeq) + return keeper.CancelOrderBySequence(ctx, sender, msg.OrderSequence) } } diff --git a/x/dex/keeper/keeper.go b/x/dex/keeper/keeper.go index 4ad41a512..f329a2dbd 100644 --- a/x/dex/keeper/keeper.go +++ b/x/dex/keeper/keeper.go @@ -74,7 +74,7 @@ func (k Keeper) PlaceOrder(ctx sdk.Context, order types.Order) error { } // validate duplicated order ID - _, err = k.getOrderSeqByID(ctx, accNumber, order.ID) + _, err = k.getOrderSequenceByID(ctx, accNumber, order.ID) if err != nil { if !sdkerrors.IsOf(err, types.ErrRecordNotFound) { return err @@ -96,9 +96,9 @@ func (k Keeper) CancelOrder(ctx sdk.Context, acc sdk.AccAddress, orderID string) return k.cancelOrder(ctx, acc, orderID) } -// CancelOrderBySeq cancels order and unlock locked balance by order sequence. -func (k Keeper) CancelOrderBySeq(ctx sdk.Context, acc sdk.AccAddress, orderSeq uint64) error { - return k.cancelOrderBySeq(ctx, acc, orderSeq) +// CancelOrderBySequence cancels order and unlock locked balance by order sequence. +func (k Keeper) CancelOrderBySequence(ctx sdk.Context, acc sdk.AccAddress, orderSequence uint64) error { + return k.cancelOrderBySequence(ctx, acc, orderSequence) } // CancelOrdersByDenom cancels all orders of specified denom. @@ -120,11 +120,11 @@ func (k Keeper) CancelOrdersByDenom(ctx sdk.Context, admin, acc sdk.AccAddress, defer iterator.Close() for ; iterator.Valid(); iterator.Next() { - orderSeq, err := types.DecodeAccountDenomKeyOrderSeq(iterator.Key()) + orderSequence, err := types.DecodeAccountDenomKeyOrderSequence(iterator.Key()) if err != nil { return err } - if err := k.cancelOrderBySeq(ctx, acc, orderSeq); err != nil { + if err := k.cancelOrderBySequence(ctx, acc, orderSequence); err != nil { return err } } @@ -217,12 +217,12 @@ func (k Keeper) SetParams(ctx sdk.Context, params types.Params) error { return nil } -// GetOrdersWithSequence returns orders with sequence. -func (k Keeper) GetOrdersWithSequence( +// GetAccountsOrders returns paginated orders. +func (k Keeper) GetAccountsOrders( ctx sdk.Context, pagination *query.PageRequest, -) ([]types.OrderWithSequence, *query.PageResponse, error) { - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderIDToSeqKeyPrefix) +) ([]types.Order, *query.PageResponse, error) { + store := prefix.NewStore(ctx.KVStore(k.storeKey), types.OrderIDToSequenceKeyPrefix) orderBookIDToOrderBookData := make(map[uint32]types.OrderBookData) accNumberToAddCache := make(map[uint64]sdk.AccAddress) orders, pageRes, err := query.GenericFilteredPaginate( @@ -230,8 +230,8 @@ func (k Keeper) GetOrdersWithSequence( store, pagination, // builder - func(key []byte, record *gogotypes.UInt64Value) (*types.OrderWithSequence, error) { - accNumber, _, err := types.DecodeOrderIDToSeqKey(key) + func(key []byte, record *gogotypes.UInt64Value) (*types.Order, error) { + accNumber, _, err := types.DecodeOrderIDToSequenceKey(key) if err != nil { return nil, err } @@ -242,8 +242,8 @@ func (k Keeper) GetOrdersWithSequence( return nil, err } - orderSeq := record.Value - orderData, err := k.getOrderData(ctx, orderSeq) + orderSequence := record.Value + orderData, err := k.getOrderData(ctx, orderSequence) if err != nil { return nil, err } @@ -263,29 +263,27 @@ func (k Keeper) GetOrdersWithSequence( orderData.OrderBookID, orderData.Side, orderData.Price, - orderSeq, + orderSequence, ) if err != nil { return nil, err } - return &types.OrderWithSequence{ - Sequence: orderSeq, - Order: types.Order{ - Creator: acc.String(), - Type: types.ORDER_TYPE_LIMIT, - ID: orderBookRecord.OrderID, - BaseDenom: orderBookData.BaseDenom, - QuoteDenom: orderBookData.QuoteDenom, - Price: &orderData.Price, - Quantity: orderData.Quantity, - Side: orderData.Side, - GoodTil: orderData.GoodTil, - TimeInForce: types.TIME_IN_FORCE_GTC, - RemainingQuantity: orderBookRecord.RemainingQuantity, - RemainingBalance: orderBookRecord.RemainingBalance, - Reserve: orderData.Reserve, - }, + return &types.Order{ + Creator: acc.String(), + Type: types.ORDER_TYPE_LIMIT, + ID: orderBookRecord.OrderID, + Sequence: orderSequence, + BaseDenom: orderBookData.BaseDenom, + QuoteDenom: orderBookData.QuoteDenom, + Price: &orderData.Price, + Quantity: orderData.Quantity, + Side: orderData.Side, + GoodTil: orderData.GoodTil, + TimeInForce: types.TIME_IN_FORCE_GTC, + RemainingQuantity: orderBookRecord.RemainingQuantity, + RemainingBalance: orderBookRecord.RemainingBalance, + Reserve: orderData.Reserve, }, nil }, // constructor @@ -296,8 +294,8 @@ func (k Keeper) GetOrdersWithSequence( if err != nil { return nil, nil, sdkerrors.Wrapf(types.ErrInvalidInput, "failed to paginate: %s", err) } - return lo.Map(orders, func(orderWithSeq *types.OrderWithSequence, _ int) types.OrderWithSequence { - return *orderWithSeq + return lo.Map(orders, func(order *types.Order, _ int) types.Order { + return *order }), pageRes, nil } @@ -314,14 +312,19 @@ func (k Keeper) SaveOrderBookIDWithData(ctx sdk.Context, orderBookID uint32, dat return k.saveOrderBookIDWithData(ctx, orderBookID, data.BaseDenom, data.QuoteDenom) } -// SetOrderSeq sets order sequence. -func (k Keeper) SetOrderSeq(ctx sdk.Context, seq uint64) error { - return k.setUint64Value(ctx, types.OrderSeqKey, seq) +// GetOrderSequence returns current order sequence. +func (k Keeper) GetOrderSequence(ctx sdk.Context) (uint64, error) { + return k.getUint64Value(ctx, types.OrderSequenceKey) +} + +// SetOrderSequence sets order sequence. +func (k Keeper) SetOrderSequence(ctx sdk.Context, sequence uint64) error { + return k.setUint64Value(ctx, types.OrderSequenceKey, sequence) } -// SetOrderBookSeq sets order book sequence. -func (k Keeper) SetOrderBookSeq(ctx sdk.Context, seq uint32) error { - return k.setUint32Value(ctx, types.OrderBookSeqKey, seq) +// SetOrderBookSequence sets order book sequence. +func (k Keeper) SetOrderBookSequence(ctx sdk.Context, sequence uint32) error { + return k.setUint32Value(ctx, types.OrderBookSequenceKey, sequence) } // SaveOrderWithOrderBookRecord saves order with order book record. @@ -568,7 +571,7 @@ func (k Keeper) genOrderBookIDsFromDenoms(ctx sdk.Context, denom0, denom1 string } func (k Keeper) genNextOrderBookID(ctx sdk.Context) (uint32, error) { - id, err := k.genNextUint32Seq(ctx, types.OrderBookSeqKey) + id, err := k.genNextUint32Sequence(ctx, types.OrderBookSequenceKey) if err != nil { return 0, err } @@ -616,24 +619,22 @@ func (k Keeper) createOrder( return err } - orderSeq, err := k.genNextOrderSeq(ctx) - if err != nil { - return err - } - record.OrderSeq = orderSeq - + // update the reserve to be saved in the order data if params.OrderReserve.IsPositive() { order.Reserve = params.OrderReserve } - order.RemainingQuantity = record.RemainingQuantity - order.RemainingBalance = record.RemainingBalance + // the remaining quantity and balance will be taker from record if err := k.saveOrderWithOrderBookRecord(ctx, order, record); err != nil { return err } if err := ctx.EventManager().EmitTypedEvent(&types.EventOrderCreated{ - Order: order, + Creator: order.Creator, + ID: order.ID, + Sequence: order.Sequence, + RemainingQuantity: record.RemainingQuantity, + RemainingBalance: record.RemainingBalance, }); err != nil { return sdkerrors.Wrapf(types.ErrInvalidInput, "failed to emit event EventOrderCreated: %s", err) } @@ -675,14 +676,14 @@ func (k Keeper) saveOrderWithOrderBookRecord( if err := k.delayGoodTilCancellation( ctx, *order.GoodTil, - record.OrderSeq, + record.OrderSequence, creator, ); err != nil { return err } } - if err := k.saveOrderData(ctx, record.OrderSeq, types.OrderData{ + if err := k.saveOrderData(ctx, record.OrderSequence, types.OrderData{ OrderID: order.ID, OrderBookID: record.OrderBookID, Price: *order.Price, @@ -694,11 +695,11 @@ func (k Keeper) saveOrderWithOrderBookRecord( return err } - if err := k.saveOrderIDToSeq(ctx, record.AccountNumber, record.OrderID, record.OrderSeq); err != nil { + if err := k.saveOrderIDToSequence(ctx, record.AccountNumber, record.OrderID, record.OrderSequence); err != nil { return err } - return k.saveAccountDenomOrderSeq(ctx, record.AccountNumber, order.Denoms(), record.OrderSeq) + return k.saveAccountDenomOrderSequence(ctx, record.AccountNumber, order.Denoms(), record.OrderSequence) } func (k Keeper) removeOrderByRecord( @@ -711,22 +712,24 @@ func (k Keeper) removeOrderByRecord( "record", record, ) - if err := k.removeOrderBookRecord(ctx, record.OrderBookID, record.Side, record.Price, record.OrderSeq); err != nil { + if err := k.removeOrderBookRecord( + ctx, record.OrderBookID, record.Side, record.Price, record.OrderSequence, + ); err != nil { return err } - orderData, err := k.getOrderData(ctx, record.OrderSeq) + orderData, err := k.getOrderData(ctx, record.OrderSequence) if err != nil { return err } if orderData.GoodTil != nil { - if err := k.removeGoodTilDelay(ctx, *orderData.GoodTil, record.OrderSeq); err != nil { + if err := k.removeGoodTilDelay(ctx, *orderData.GoodTil, record.OrderSequence); err != nil { return err } } - k.removeOrderData(ctx, record.OrderSeq) + k.removeOrderData(ctx, record.OrderSequence) - if err := k.removeOrderIDToSeq(ctx, record.AccountNumber, record.OrderID); err != nil { + if err := k.removeOrderIDToSequence(ctx, record.AccountNumber, record.OrderID); err != nil { return err } @@ -739,26 +742,16 @@ func (k Keeper) removeOrderByRecord( if err := k.decrementAccountDenomOrdersCounter(ctx, record.AccountNumber, denoms); err != nil { return err } - if err := k.removeAccountDenomOrderSeq(ctx, record.AccountNumber, denoms, record.OrderSeq); err != nil { + if err := k.removeAccountDenomOrderSequence(ctx, record.AccountNumber, denoms, record.OrderSequence); err != nil { return err } if err := ctx.EventManager().EmitTypedEvent(&types.EventOrderClosed{ - Order: types.Order{ - Creator: creator.String(), - Type: types.ORDER_TYPE_LIMIT, - ID: record.OrderID, - BaseDenom: orderBookData.BaseDenom, - QuoteDenom: orderBookData.QuoteDenom, - Price: &orderData.Price, - Quantity: orderData.Quantity, - Side: orderData.Side, - GoodTil: orderData.GoodTil, - TimeInForce: types.TIME_IN_FORCE_GTC, - RemainingQuantity: record.RemainingQuantity, - RemainingBalance: record.RemainingBalance, - Reserve: orderData.Reserve, - }, + Creator: creator.String(), + ID: record.OrderID, + Sequence: record.OrderSequence, + RemainingQuantity: record.RemainingQuantity, + RemainingBalance: record.RemainingBalance, }); err != nil { return sdkerrors.Wrapf(types.ErrInvalidInput, "failed to emit event EventOrderCreated: %s", err) } @@ -770,8 +763,8 @@ func (k Keeper) saveOrderBookData(ctx sdk.Context, orderBookID uint32, data type return k.setDataToStore(ctx, types.CreateOrderBookDataKey(orderBookID), &data) } -func (k Keeper) cancelOrderBySeq(ctx sdk.Context, acc sdk.AccAddress, orderSeq uint64) error { - orderData, err := k.getOrderData(ctx, orderSeq) +func (k Keeper) cancelOrderBySequence(ctx sdk.Context, acc sdk.AccAddress, orderSequence uint64) error { + orderData, err := k.getOrderData(ctx, orderSequence) if err != nil { return err } @@ -815,8 +808,8 @@ func (k Keeper) getOrderBookData(ctx sdk.Context, orderBookID uint32) (types.Ord return val, nil } -func (k Keeper) genNextOrderSeq(ctx sdk.Context) (uint64, error) { - return k.genNextUint64Seq(ctx, types.OrderSeqKey) +func (k Keeper) genNextOrderSequence(ctx sdk.Context) (uint64, error) { + return k.genNextUint64Sequence(ctx, types.OrderSequenceKey) } func (k Keeper) saveOrderBookRecord( @@ -825,7 +818,7 @@ func (k Keeper) saveOrderBookRecord( ) error { k.logger(ctx).Debug("Saving order book record.", "record", record.String()) - key, err := types.CreateOrderBookRecordKey(record.OrderBookID, record.Side, record.Price, record.OrderSeq) + key, err := types.CreateOrderBookRecordKey(record.OrderBookID, record.Side, record.Price, record.OrderSequence) if err != nil { return err } @@ -848,12 +841,12 @@ func (k Keeper) getOrderWithRecordByAddressAndID( return types.Order{}, types.OrderBookRecord{}, err } - orderSeq, err := k.getOrderSeqByID(ctx, accNumber, orderID) + orderSequence, err := k.getOrderSequenceByID(ctx, accNumber, orderID) if err != nil { return types.Order{}, types.OrderBookRecord{}, err } - orderData, err := k.getOrderData(ctx, orderSeq) + orderData, err := k.getOrderData(ctx, orderSequence) if err != nil { return types.Order{}, types.OrderBookRecord{}, err } @@ -863,7 +856,7 @@ func (k Keeper) getOrderWithRecordByAddressAndID( orderData.OrderBookID, orderData.Side, orderData.Price, - orderSeq, + orderSequence, ) if err != nil { return types.Order{}, types.OrderBookRecord{}, err @@ -878,6 +871,7 @@ func (k Keeper) getOrderWithRecordByAddressAndID( Creator: acc.String(), Type: types.ORDER_TYPE_LIMIT, ID: orderID, + Sequence: orderSequence, BaseDenom: orderBookData.BaseDenom, QuoteDenom: orderBookData.QuoteDenom, Price: &orderBookRecord.Price, @@ -898,9 +892,9 @@ func (k Keeper) getOrderBookRecord( orderBookID uint32, side types.Side, price types.Price, - orderSeq uint64, + orderSequence uint64, ) (types.OrderBookRecord, error) { - key, err := types.CreateOrderBookRecordKey(orderBookID, side, price, orderSeq) + key, err := types.CreateOrderBookRecordKey(orderBookID, side, price, orderSequence) if err != nil { return types.OrderBookRecord{}, err } @@ -910,14 +904,14 @@ func (k Keeper) getOrderBookRecord( return types.OrderBookRecord{}, sdkerrors.Wrapf( err, - "faild to get order book record, orderBookID: %d, side: %s, price: %s, orderSeq: %d", - orderBookID, side.String(), price.String(), orderSeq) + "faild to get order book record, orderBookID: %d, side: %s, price: %s, orderSequence: %d", + orderBookID, side.String(), price.String(), orderSequence) } return types.OrderBookRecord{ OrderBookID: orderBookID, Side: side, Price: price, - OrderSeq: orderSeq, + OrderSequence: orderSequence, OrderID: val.OrderID, AccountNumber: val.AccountNumber, RemainingQuantity: val.RemainingQuantity, @@ -935,7 +929,7 @@ func (k Keeper) getPaginatedOrders( return nil, nil, err } - store := prefix.NewStore(ctx.KVStore(k.storeKey), types.CreateOrderIDToSeqKeyPrefix(accNumber)) + store := prefix.NewStore(ctx.KVStore(k.storeKey), types.CreateOrderIDToSequenceKeyPrefix(accNumber)) orderBookIDToOrderBookData := make(map[uint32]types.OrderBookData) orders, pageRes, err := query.GenericFilteredPaginate( k.cdc, @@ -943,8 +937,8 @@ func (k Keeper) getPaginatedOrders( pagination, // builder func(_ []byte, record *gogotypes.UInt64Value) (*types.Order, error) { - orderSeq := record.Value - orderData, err := k.getOrderData(ctx, orderSeq) + orderSequence := record.Value + orderData, err := k.getOrderData(ctx, orderSequence) if err != nil { return nil, err } @@ -964,7 +958,7 @@ func (k Keeper) getPaginatedOrders( orderData.OrderBookID, orderData.Side, orderData.Price, - orderSeq, + orderSequence, ) if err != nil { return nil, err @@ -974,6 +968,7 @@ func (k Keeper) getPaginatedOrders( Creator: acc.String(), Type: types.ORDER_TYPE_LIMIT, ID: orderBookRecord.OrderID, + Sequence: orderSequence, BaseDenom: orderBookData.BaseDenom, QuoteDenom: orderBookData.QuoteDenom, Price: &orderData.Price, @@ -1054,7 +1049,7 @@ func (k Keeper) getPaginatedOrderBookOrders( // builder func(key []byte, record *types.OrderBookRecordData) (*types.Order, error) { // decode key to values - price, orderSeq, err := types.DecodeOrderBookSideRecordKey(key) + price, orderSequence, err := types.DecodeOrderBookSideRecordKey(key) if err != nil { return nil, err } @@ -1065,7 +1060,7 @@ func (k Keeper) getPaginatedOrderBookOrders( return nil, err } - orderData, err := k.getOrderData(ctx, orderSeq) + orderData, err := k.getOrderData(ctx, orderSequence) if err != nil { return nil, err } @@ -1074,6 +1069,7 @@ func (k Keeper) getPaginatedOrderBookOrders( Creator: acc.String(), Type: types.ORDER_TYPE_LIMIT, ID: record.OrderID, + Sequence: orderSequence, BaseDenom: baseDenom, QuoteDenom: quoteDenom, Price: &price, @@ -1104,9 +1100,9 @@ func (k Keeper) removeOrderBookRecord( orderBookID uint32, side types.Side, price types.Price, - orderSeq uint64, + orderSequence uint64, ) error { - key, err := types.CreateOrderBookRecordKey(orderBookID, side, price, orderSeq) + key, err := types.CreateOrderBookRecordKey(orderBookID, side, price, orderSequence) if err != nil { return err } @@ -1115,36 +1111,36 @@ func (k Keeper) removeOrderBookRecord( return nil } -func (k Keeper) saveOrderData(ctx sdk.Context, orderSeq uint64, data types.OrderData) error { - return k.setDataToStore(ctx, types.CreateOrderKey(orderSeq), &data) +func (k Keeper) saveOrderData(ctx sdk.Context, orderSequence uint64, data types.OrderData) error { + return k.setDataToStore(ctx, types.CreateOrderKey(orderSequence), &data) } -func (k Keeper) removeOrderData(ctx sdk.Context, orderSeq uint64) { - ctx.KVStore(k.storeKey).Delete(types.CreateOrderKey(orderSeq)) +func (k Keeper) removeOrderData(ctx sdk.Context, orderSequence uint64) { + ctx.KVStore(k.storeKey).Delete(types.CreateOrderKey(orderSequence)) } -func (k Keeper) getOrderData(ctx sdk.Context, orderSeq uint64) (types.OrderData, error) { +func (k Keeper) getOrderData(ctx sdk.Context, orderSequence uint64) (types.OrderData, error) { var val types.OrderData - if err := k.getDataFromStore(ctx, types.CreateOrderKey(orderSeq), &val); err != nil { - return types.OrderData{}, sdkerrors.Wrapf(err, "failed to get order data, orderSeq: %d", orderSeq) + if err := k.getDataFromStore(ctx, types.CreateOrderKey(orderSequence), &val); err != nil { + return types.OrderData{}, sdkerrors.Wrapf(err, "failed to get order data, orderSequence: %d", orderSequence) } return val, nil } -func (k Keeper) saveOrderIDToSeq(ctx sdk.Context, accNumber uint64, orderID string, orderSeq uint64) error { - key := types.CreateOrderIDToSeqKey(accNumber, orderID) - return k.setDataToStore(ctx, key, &gogotypes.UInt64Value{Value: orderSeq}) +func (k Keeper) saveOrderIDToSequence(ctx sdk.Context, accNumber uint64, orderID string, orderSequence uint64) error { + key := types.CreateOrderIDToSequenceKey(accNumber, orderID) + return k.setDataToStore(ctx, key, &gogotypes.UInt64Value{Value: orderSequence}) } -func (k Keeper) removeOrderIDToSeq(ctx sdk.Context, accNumber uint64, orderID string) error { - ctx.KVStore(k.storeKey).Delete(types.CreateOrderIDToSeqKey(accNumber, orderID)) +func (k Keeper) removeOrderIDToSequence(ctx sdk.Context, accNumber uint64, orderID string) error { + ctx.KVStore(k.storeKey).Delete(types.CreateOrderIDToSequenceKey(accNumber, orderID)) return nil } -func (k Keeper) getOrderSeqByID(ctx sdk.Context, accNumber uint64, orderID string) (uint64, error) { +func (k Keeper) getOrderSequenceByID(ctx sdk.Context, accNumber uint64, orderID string) (uint64, error) { var val gogotypes.UInt64Value - if err := k.getDataFromStore(ctx, types.CreateOrderIDToSeqKey(accNumber, orderID), &val); err != nil { - return 0, sdkerrors.Wrapf(err, "failed to get order seq, accNumber: %d, orderID: %s", accNumber, orderID) + if err := k.getDataFromStore(ctx, types.CreateOrderIDToSequenceKey(accNumber, orderID), &val); err != nil { + return 0, sdkerrors.Wrapf(err, "failed to get order sequence, accNumber: %d, orderID: %s", accNumber, orderID) } return val.GetValue(), nil @@ -1210,9 +1206,11 @@ func (k Keeper) decrementAccountDenomOrdersCounter( return nil } -func (k Keeper) saveAccountDenomOrderSeq(ctx sdk.Context, accNumber uint64, denoms []string, orderSeq uint64) error { +func (k Keeper) saveAccountDenomOrderSequence( + ctx sdk.Context, accNumber uint64, denoms []string, orderSequence uint64, +) error { for _, denom := range denoms { - key, err := types.CreateAccountDenomOrderSeqKey(accNumber, denom, orderSeq) + key, err := types.CreateAccountDenomOrderSequenceKey(accNumber, denom, orderSequence) if err != nil { return err } @@ -1223,9 +1221,11 @@ func (k Keeper) saveAccountDenomOrderSeq(ctx sdk.Context, accNumber uint64, deno return nil } -func (k Keeper) removeAccountDenomOrderSeq(ctx sdk.Context, accNumber uint64, denoms []string, orderSeq uint64) error { +func (k Keeper) removeAccountDenomOrderSequence( + ctx sdk.Context, accNumber uint64, denoms []string, orderSequence uint64, +) error { for _, denom := range denoms { - key, err := types.CreateAccountDenomOrderSeqKey(accNumber, denom, orderSeq) + key, err := types.CreateAccountDenomOrderSequenceKey(accNumber, denom, orderSequence) if err != nil { return err } diff --git a/x/dex/keeper/keeper_good_til.go b/x/dex/keeper/keeper_good_til.go index 77497a63b..9e0e84bdc 100644 --- a/x/dex/keeper/keeper_good_til.go +++ b/x/dex/keeper/keeper_good_til.go @@ -12,14 +12,14 @@ import ( func (k Keeper) delayGoodTilCancellation( ctx sdk.Context, goodTil types.GoodTil, - orderSeq uint64, + orderSequence uint64, creator sdk.AccAddress, ) error { if goodTil.GoodTilBlockHeight > 0 { - return k.delayGoodTilBlockHeightCancellation(ctx, goodTil.GoodTilBlockHeight, orderSeq, creator) + return k.delayGoodTilBlockHeightCancellation(ctx, goodTil.GoodTilBlockHeight, orderSequence, creator) } if goodTil.GoodTilBlockTime != nil { - return k.delayGoodTilBlockTimeCancellation(ctx, *goodTil.GoodTilBlockTime, orderSeq, creator) + return k.delayGoodTilBlockTimeCancellation(ctx, *goodTil.GoodTilBlockTime, orderSequence, creator) } return nil @@ -28,21 +28,21 @@ func (k Keeper) delayGoodTilCancellation( func (k Keeper) delayGoodTilBlockHeightCancellation( ctx sdk.Context, height uint64, - orderSeq uint64, + orderSequence uint64, creator sdk.AccAddress, ) error { k.logger(ctx).Debug( "Delaying good til height cancellation.", - "orderSeq", orderSeq, + "orderSequence", orderSequence, "height", height, "creator", creator.String(), ) if err := k.delayKeeper.ExecuteAfterBlock( ctx, - types.BuildGoodTilBlockHeightDelayKey(orderSeq), + types.BuildGoodTilBlockHeightDelayKey(orderSequence), &types.CancelGoodTil{ - Creator: creator.String(), - OrderSeq: orderSeq, + Creator: creator.String(), + OrderSequence: orderSequence, }, height, ); err != nil { @@ -55,21 +55,21 @@ func (k Keeper) delayGoodTilBlockHeightCancellation( func (k Keeper) delayGoodTilBlockTimeCancellation( ctx sdk.Context, time time.Time, - orderSeq uint64, + orderSequence uint64, creator sdk.AccAddress, ) error { k.logger(ctx).Debug( "Delaying good til time cancellation.", - "orderSeq", orderSeq, + "orderSequence", orderSequence, "time", time, "creator", creator.String(), ) if err := k.delayKeeper.ExecuteAfter( ctx, - types.BuildGoodTilBlockTimeDelayKey(orderSeq), + types.BuildGoodTilBlockTimeDelayKey(orderSequence), &types.CancelGoodTil{ - Creator: creator.String(), - OrderSeq: orderSeq, + Creator: creator.String(), + OrderSequence: orderSequence, }, time, ); err != nil { @@ -79,14 +79,14 @@ func (k Keeper) delayGoodTilBlockTimeCancellation( return nil } -func (k Keeper) removeGoodTilDelay(ctx sdk.Context, goodTil types.GoodTil, orderSeq uint64) error { +func (k Keeper) removeGoodTilDelay(ctx sdk.Context, goodTil types.GoodTil, orderSequence uint64) error { if goodTil.GoodTilBlockHeight > 0 { - if err := k.removeGoodTilBlockHeightCancellation(ctx, goodTil.GoodTilBlockHeight, orderSeq); err != nil { + if err := k.removeGoodTilBlockHeightCancellation(ctx, goodTil.GoodTilBlockHeight, orderSequence); err != nil { return err } } if goodTil.GoodTilBlockTime != nil { - if err := k.removeGoodTilBlockTimeCancellation(ctx, *goodTil.GoodTilBlockTime, orderSeq); err != nil { + if err := k.removeGoodTilBlockTimeCancellation(ctx, *goodTil.GoodTilBlockTime, orderSequence); err != nil { return err } } @@ -97,12 +97,12 @@ func (k Keeper) removeGoodTilDelay(ctx sdk.Context, goodTil types.GoodTil, order func (k Keeper) removeGoodTilBlockHeightCancellation( ctx sdk.Context, height uint64, - orderSeq uint64, + orderSequence uint64, ) error { - k.logger(ctx).Debug("Removing good til height delayed cancellation.", "orderSeq", orderSeq, "height", height) + k.logger(ctx).Debug("Removing good til height delayed cancellation.", "orderSequence", orderSequence, "height", height) if err := k.delayKeeper.RemoveExecuteAtBlock( ctx, - types.BuildGoodTilBlockHeightDelayKey(orderSeq), + types.BuildGoodTilBlockHeightDelayKey(orderSequence), height, ); err != nil { return sdkerrors.Wrap(err, "failed to remove good til height delayed cancellation") @@ -114,12 +114,12 @@ func (k Keeper) removeGoodTilBlockHeightCancellation( func (k Keeper) removeGoodTilBlockTimeCancellation( ctx sdk.Context, time time.Time, - orderSeq uint64, + orderSequence uint64, ) error { - k.logger(ctx).Debug("Removing good til time delayed cancellation.", "orderSeq", orderSeq, "time", time) + k.logger(ctx).Debug("Removing good til time delayed cancellation.", "orderSequence", orderSequence, "time", time) if err := k.delayKeeper.RemoveExecuteAfter( ctx, - types.BuildGoodTilBlockTimeDelayKey(orderSeq), + types.BuildGoodTilBlockTimeDelayKey(orderSequence), time, ); err != nil { return sdkerrors.Wrap(err, "failed to remove good til time delayed cancellation") diff --git a/x/dex/keeper/keeper_good_til_test.go b/x/dex/keeper/keeper_good_til_test.go index 3e08b75cc..e9359c801 100644 --- a/x/dex/keeper/keeper_good_til_test.go +++ b/x/dex/keeper/keeper_good_til_test.go @@ -585,10 +585,8 @@ func TestKeeper_GoodTil(t *testing.T) { gotOrders = append(gotOrders, getSorterOrderBookOrders(t, testApp, sdkCtx, orderBookID, types.SIDE_SELL)...) } wantOrders := tt.wantOrders(testSet) - // set order reserve for all orders - for i := range wantOrders { - wantOrders[i].Reserve = testApp.DEXKeeper.GetParams(sdkCtx).OrderReserve - } + wantOrders = fillReserveAndOrderSequence(t, sdkCtx, testApp, wantOrders) + require.ElementsMatch(t, wantOrders, gotOrders) }) } diff --git a/x/dex/keeper/keeper_matching.go b/x/dex/keeper/keeper_matching.go index 961ed4127..443b069d2 100644 --- a/x/dex/keeper/keeper_matching.go +++ b/x/dex/keeper/keeper_matching.go @@ -34,6 +34,15 @@ func (k Keeper) matchOrder( if err != nil { return err } + order.Sequence = takerRecord.OrderSequence + + if err := ctx.EventManager().EmitTypedEvent(&types.EventOrderPlaced{ + Creator: order.Creator, + ID: order.ID, + Sequence: takerRecord.OrderSequence, + }); err != nil { + return sdkerrors.Wrapf(types.ErrInvalidInput, "failed to emit event EventOrderPlaced: %s", err) + } mr, err := NewMatchingResult(order) if err != nil { @@ -108,11 +117,17 @@ func (k Keeper) initTakerRecord( if order.Price != nil { price = *order.Price } + + orderSequence, err := k.genNextOrderSequence(ctx) + if err != nil { + return types.OrderBookRecord{}, err + } + return types.OrderBookRecord{ OrderBookID: orderBookID, Side: order.Side, Price: price, - OrderSeq: 0, // set to zero and update only if we need to save it to the state + OrderSequence: orderSequence, OrderID: order.ID, AccountNumber: accNumber, RemainingQuantity: order.Quantity, @@ -182,13 +197,14 @@ func (k Keeper) matchRecords( } recordToCloseRemainingQuantity := recordToClose.RemainingQuantity.Sub(recordToCloseReducedQuantity) - if recordToClose.IsMaker() { + closeMaker := order.Sequence != recordToClose.OrderSequence + if closeMaker { makerAddr, err := k.getAccountAddressWithCache(ctx, recordToClose.AccountNumber, accNumberToAddCache) if err != nil { return false, err } mr.TakerSend( - makerAddr, recordToClose.OrderID, recordToCloseReceiveCoin, + makerAddr, recordToClose.OrderID, recordToClose.OrderSequence, recordToCloseReceiveCoin, ) mr.MakerSend( makerAddr, recordToClose.OrderID, recordToReduceReceiveCoin, @@ -209,7 +225,7 @@ func (k Keeper) matchRecords( return false, err } mr.TakerSend( - makerAddr, recordToReduce.OrderID, recordToReduceReceiveCoin, + makerAddr, recordToReduce.OrderID, recordToReduce.OrderSequence, recordToReduceReceiveCoin, ) mr.MakerSend( makerAddr, recordToReduce.OrderID, recordToCloseReceiveCoin, @@ -225,7 +241,7 @@ func (k Keeper) matchRecords( k.logger(ctx).Debug("Updated recordToReduce.", "recordToReduce", recordToReduce) // continue or stop - if recordToClose.IsMaker() { + if closeMaker { if recordToReduce.RemainingQuantity.IsZero() { k.logger(ctx).Debug("Taker record is filled fully.") recordToReduce.RemainingBalance = sdkmath.ZeroInt() @@ -250,7 +266,7 @@ func (k Keeper) getMakerLockedAndExpectedToReceiveCoins( recordToReduceReceiveCoin.Denom, recordToClose.RemainingBalance.Sub(recordToReduceReceiveCoin.Amount), )) // get the record data to unlock the reserve if present - recordToCloseOrderData, err := k.getOrderData(ctx, recordToClose.OrderSeq) + recordToCloseOrderData, err := k.getOrderData(ctx, recordToClose.OrderSequence) if err != nil { return nil, sdk.Coin{}, err } @@ -314,6 +330,7 @@ func getRecordsReceiveCoins( oppositeExecutionQuantity sdkmath.Int ) + closeMaker := order.Sequence != recordToClose.OrderSequence if recordToClose.Side != recordToReduce.Side { // self executionQuantity, oppositeExecutionQuantity = computeMaxExecutionQuantity( makerRecord.Price.Rat(), recordToClose.RemainingQuantity, @@ -323,7 +340,7 @@ func getRecordsReceiveCoins( } else { // if closeMaker is true we find max execution quantity with its price, // else with inverse price - if recordToClose.IsMaker() { + if closeMaker { executionQuantity, oppositeExecutionQuantity = computeMaxExecutionQuantity( makerRecord.Price.Rat(), recordToClose.RemainingQuantity, ) @@ -345,7 +362,7 @@ func getRecordsReceiveCoins( recordToReduceReceiveAmt = executionQuantity } - if recordToClose.IsMaker() { + if closeMaker { recordToCloseReceiveDenom = order.GetSpendDenom() recordToReduceReceiveDenom = order.GetReceiveDenom() } else { diff --git a/x/dex/keeper/keeper_matching_result.go b/x/dex/keeper/keeper_matching_result.go index 6cf604b72..321430acf 100644 --- a/x/dex/keeper/keeper_matching_result.go +++ b/x/dex/keeper/keeper_matching_result.go @@ -56,6 +56,7 @@ func NewMatchingResult(order types.Order) (*MatchingResult, error) { TakerOrderReducedEvent: types.EventOrderReduced{ Creator: order.Creator, ID: order.ID, + Sequence: order.Sequence, SentCoin: sdk.NewCoin(order.GetSpendDenom(), sdkmath.ZeroInt()), ReceivedCoin: sdk.NewCoin(order.GetReceiveDenom(), sdkmath.ZeroInt()), }, @@ -66,7 +67,9 @@ func NewMatchingResult(order types.Order) (*MatchingResult, error) { } // TakerSend registers the coin to send from taker to maker. -func (mr *MatchingResult) TakerSend(makerAddr sdk.AccAddress, makerOrderID string, coin sdk.Coin) { +func (mr *MatchingResult) TakerSend( + makerAddr sdk.AccAddress, makerOrderID string, makerOrderSequence uint64, coin sdk.Coin, +) { if coin.IsZero() { return } @@ -75,7 +78,7 @@ func (mr *MatchingResult) TakerSend(makerAddr sdk.AccAddress, makerOrderID strin mr.FTActions.AddSend(mr.TakerAddress, makerAddr, coin) mr.FTActions.AddDecreaseExpectedToReceive(makerAddr, coin) - mr.updateTakerSendEvents(makerAddr, makerOrderID, coin) + mr.updateTakerSendEvents(makerAddr, makerOrderID, makerOrderSequence, coin) } // MakerSend registers the coin to send from maker to taker. @@ -167,12 +170,14 @@ func (mr *MatchingResult) UpdateRecord(record types.OrderBookRecord) { func (mr *MatchingResult) updateTakerSendEvents( makerAddr sdk.AccAddress, makerOrderID string, + makerOrderSequence uint64, coin sdk.Coin, ) { mr.TakerOrderReducedEvent.SentCoin = mr.TakerOrderReducedEvent.SentCoin.Add(coin) mr.MakerOrderReducedEvents = append(mr.MakerOrderReducedEvents, types.EventOrderReduced{ Creator: makerAddr.String(), ID: makerOrderID, + Sequence: makerOrderSequence, ReceivedCoin: coin, }) } diff --git a/x/dex/keeper/keeper_matching_test.go b/x/dex/keeper/keeper_matching_test.go index 8967b3e26..611b05001 100644 --- a/x/dex/keeper/keeper_matching_test.go +++ b/x/dex/keeper/keeper_matching_test.go @@ -6369,10 +6369,8 @@ func TestKeeper_MatchOrders(t *testing.T) { orders = append(orders, getSorterOrderBookOrders(t, testApp, sdkCtx, orderBookID, types.SIDE_SELL)...) } wantOrders := tt.wantOrders(testSet) - // set order reserve for all orders - for i := range wantOrders { - wantOrders[i].Reserve = testApp.DEXKeeper.GetParams(sdkCtx).OrderReserve - } + // set order reserve and order sequence for all orders + wantOrders = fillReserveAndOrderSequence(t, sdkCtx, testApp, wantOrders) require.ElementsMatch(t, wantOrders, orders) availableBalances := make(map[string]sdk.Coins) @@ -6504,6 +6502,26 @@ func removeEmptyBalances(balances map[string]sdk.Coins) map[string]sdk.Coins { return balances } +func fillReserveAndOrderSequence( + t *testing.T, + sdkCtx sdk.Context, + testApp *simapp.App, + orders []types.Order, +) []types.Order { + orderReserve := testApp.DEXKeeper.GetParams(sdkCtx).OrderReserve + for i, order := range orders { + storedOrder, err := testApp.DEXKeeper.GetOrderByAddressAndID( + sdkCtx, sdk.MustAccAddressFromBech32(order.Creator), order.ID, + ) + require.NoError(t, err) + require.Greater(t, storedOrder.Sequence, uint64(0)) + orders[i].Sequence = storedOrder.Sequence + orders[i].Reserve = orderReserve + } + + return orders +} + func assertOrderPlacementResult( t *testing.T, sdkCtx sdk.Context, @@ -6511,7 +6529,8 @@ func assertOrderPlacementResult( availableBalancesBefore map[string]sdkmath.Int, order types.Order, ) { - events := readOrderEvents(t, sdkCtx, testApp) + events := readOrderEvents(t, sdkCtx) + assertPlacementEvents(t, order, events) sentAmt, receivedAmt := assetOrderSentReceivedAmounts( t, sdkCtx, testApp, availableBalancesBefore, order, events, @@ -6528,7 +6547,13 @@ func assertOrderPlacementResult( t.Logf("Order found in the order book.") require.NotNil(t, events.OrderCreated) - require.Equal(t, events.OrderCreated.Order, storedOrder) + require.Equal(t, types.EventOrderCreated{ + Creator: storedOrder.Creator, + ID: storedOrder.ID, + Sequence: events.OrderPlaced.Sequence, + RemainingQuantity: storedOrder.RemainingQuantity, + RemainingBalance: storedOrder.RemainingBalance, + }, *events.OrderCreated) if order.Type != types.ORDER_TYPE_LIMIT { t.Fatalf("Saved not market order, type: %s", order.Type.String()) @@ -6538,6 +6563,56 @@ func assertOrderPlacementResult( } } +func assertPlacementEvents(t *testing.T, order types.Order, events OrderPlacementEvents) { + require.Greater(t, events.OrderPlaced.Sequence, uint64(0)) + require.Equal(t, types.EventOrderPlaced{ + Creator: order.Creator, + ID: order.ID, + Sequence: events.OrderPlaced.Sequence, + }, events.OrderPlaced) + + // set initial quantity + expectedRemainingQuantity := order.Quantity + + takerSentAmt := sdk.NewCoin(order.GetSpendDenom(), sdkmath.ZeroInt()) + takerReceivedAmt := sdk.NewCoin(order.GetReceiveDenom(), sdkmath.ZeroInt()) + makerSentAmt := sdk.NewCoin(order.GetReceiveDenom(), sdkmath.ZeroInt()) + makerReceivedAmt := sdk.NewCoin(order.GetSpendDenom(), sdkmath.ZeroInt()) + for _, reducedEvt := range events.OrdersReduced { + // is taker + if events.OrderPlaced.Sequence == reducedEvt.Sequence { + require.True(t, takerSentAmt.IsZero()) + require.True(t, takerReceivedAmt.IsZero()) + takerSentAmt = reducedEvt.SentCoin + takerReceivedAmt = reducedEvt.ReceivedCoin + + if order.Side == types.SIDE_BUY { + expectedRemainingQuantity = expectedRemainingQuantity.Sub(reducedEvt.ReceivedCoin.Amount) + } else { + expectedRemainingQuantity = expectedRemainingQuantity.Sub(reducedEvt.SentCoin.Amount) + } + continue + } + makerSentAmt = makerSentAmt.Add(reducedEvt.SentCoin) + makerReceivedAmt = makerReceivedAmt.Add(reducedEvt.ReceivedCoin) + } + require.Equal(t, takerSentAmt.String(), makerReceivedAmt.String()) + require.Equal(t, makerSentAmt.String(), takerReceivedAmt.String()) + if events.OrderCreated != nil { + expectedRemainingBalance, err := types.ComputeLimitOrderLockedBalance( + order.Side, order.BaseDenom, order.QuoteDenom, expectedRemainingQuantity, *order.Price, + ) + require.NoError(t, err) + require.Equal(t, types.EventOrderCreated{ + Creator: order.Creator, + ID: order.ID, + Sequence: events.OrderPlaced.Sequence, + RemainingQuantity: expectedRemainingQuantity, + RemainingBalance: expectedRemainingBalance.Amount, + }, *events.OrderCreated) + } +} + func assetOrderSentReceivedAmounts( t *testing.T, sdkCtx sdk.Context, @@ -6583,7 +6658,7 @@ func assetOrderSentReceivedAmounts( orderUsedAmt := orderSentAmt if events.OrderCreated != nil { // locked balance - orderUsedAmt = orderUsedAmt.Add(events.OrderCreated.Order.RemainingBalance) + orderUsedAmt = orderUsedAmt.Add(events.OrderCreated.RemainingBalance) } creator := sdk.MustAccAddressFromBech32(order.Creator) @@ -6687,7 +6762,7 @@ func cancelAllOrdersAndAssertState( ) { t.Helper() - orders, _, err := testApp.DEXKeeper.GetOrdersWithSequence(sdkCtx, &query.PageRequest{Limit: query.PaginationMaxLimit}) + orders, _, err := testApp.DEXKeeper.GetAccountsOrders(sdkCtx, &query.PageRequest{Limit: query.PaginationMaxLimit}) require.NoError(t, err) t.Logf("Cancelling all orders, count %d", len(orders)) @@ -6696,11 +6771,11 @@ func cancelAllOrdersAndAssertState( denoms := make(map[string]struct{}) for _, order := range orders { require.NoError(t, testApp.DEXKeeper.CancelOrder( - sdkCtx, sdk.MustAccAddressFromBech32(order.Order.Creator), order.Order.ID), + sdkCtx, sdk.MustAccAddressFromBech32(order.Creator), order.ID), ) - accounts[order.Order.Creator] = struct{}{} - denoms[order.Order.BaseDenom] = struct{}{} - denoms[order.Order.QuoteDenom] = struct{}{} + accounts[order.Creator] = struct{}{} + denoms[order.BaseDenom] = struct{}{} + denoms[order.QuoteDenom] = struct{}{} } for acc := range accounts { for denom := range denoms { diff --git a/x/dex/keeper/keeper_ob_iterator.go b/x/dex/keeper/keeper_ob_iterator.go index d0defe1d7..62ce5cfe1 100644 --- a/x/dex/keeper/keeper_ob_iterator.go +++ b/x/dex/keeper/keeper_ob_iterator.go @@ -144,7 +144,7 @@ func (i *OrderBookIterator) nextFromIterator() (types.OrderBookRecord, bool, err func (i *OrderBookIterator) readOrderBookRecordFromIterator() (types.OrderBookRecord, error) { // decode key to values - price, orderSeq, err := types.DecodeOrderBookSideRecordKey(i.iterator.Key()) + price, orderSequence, err := types.DecodeOrderBookSideRecordKey(i.iterator.Key()) if err != nil { return types.OrderBookRecord{}, err } @@ -157,10 +157,10 @@ func (i *OrderBookIterator) readOrderBookRecordFromIterator() (types.OrderBookRe return types.OrderBookRecord{ // key attributes - OrderBookID: i.orderBookID, - Side: i.side, - Price: price, - OrderSeq: orderSeq, + OrderBookID: i.orderBookID, + Side: i.side, + Price: price, + OrderSequence: orderSequence, // value attributes OrderID: storedRecord.OrderID, AccountNumber: storedRecord.AccountNumber, diff --git a/x/dex/keeper/keeper_ob_iterator_test.go b/x/dex/keeper/keeper_ob_iterator_test.go index 96caf528b..5038f2124 100644 --- a/x/dex/keeper/keeper_ob_iterator_test.go +++ b/x/dex/keeper/keeper_ob_iterator_test.go @@ -319,8 +319,8 @@ func assertOrdersOrdering( ) if left.Price.Rat().Cmp(right.Price.Rat()) == 0 { require.Less(t, - left.OrderSeq, right.OrderSeq, - fmt.Sprintf("left order seq: %d >= right order seq: %d", left.OrderSeq, right.OrderSeq), + left.OrderSequence, right.OrderSequence, + fmt.Sprintf("left order sequence: %d >= right order sequence: %d", left.OrderSequence, right.OrderSequence), ) } } @@ -337,8 +337,8 @@ func assertOrdersOrdering( ) if left.Price.Rat().Cmp(right.Price.Rat()) == 0 { require.Less(t, - left.OrderSeq, right.OrderSeq, - fmt.Sprintf("left order seq: %d >= right order seq: %d", left.OrderSeq, right.OrderSeq), + left.OrderSequence, right.OrderSequence, + fmt.Sprintf("left order sequence: %d >= right order sequence: %d", left.OrderSequence, right.OrderSequence), ) } } diff --git a/x/dex/keeper/keeper_store.go b/x/dex/keeper/keeper_store.go index 06da2607b..a638de573 100644 --- a/x/dex/keeper/keeper_store.go +++ b/x/dex/keeper/keeper_store.go @@ -10,7 +10,7 @@ import ( ) func (k Keeper) incrementUint64Counter(ctx sdk.Context, key []byte) (uint64, error) { - return k.genNextUint64Seq(ctx, key) + return k.genNextUint64Sequence(ctx, key) } func (k Keeper) decrementUint64Counter(ctx sdk.Context, key []byte) (uint64, error) { @@ -24,15 +24,25 @@ func (k Keeper) decrementUint64Counter(ctx sdk.Context, key []byte) (uint64, err return val.Value, k.setDataToStore(ctx, key, &val) } -func (k Keeper) setUint64Value(ctx sdk.Context, key []byte, seq uint64) error { +func (k Keeper) getUint64Value(ctx sdk.Context, key []byte) (uint64, error) { + var val gogotypes.UInt64Value + err := k.getDataFromStore(ctx, key, &val) + if err != nil { + return 0, err + } + + return val.Value, nil +} + +func (k Keeper) setUint64Value(ctx sdk.Context, key []byte, sequence uint64) error { val := gogotypes.UInt64Value{ - Value: seq, + Value: sequence, } return k.setDataToStore(ctx, key, &val) } -func (k Keeper) genNextUint64Seq(ctx sdk.Context, key []byte) (uint64, error) { +func (k Keeper) genNextUint64Sequence(ctx sdk.Context, key []byte) (uint64, error) { var val gogotypes.UInt64Value err := k.getDataFromStore(ctx, key, &val) if err != nil { @@ -46,15 +56,15 @@ func (k Keeper) genNextUint64Seq(ctx sdk.Context, key []byte) (uint64, error) { return val.Value, k.setDataToStore(ctx, key, &val) } -func (k Keeper) setUint32Value(ctx sdk.Context, key []byte, seq uint32) error { +func (k Keeper) setUint32Value(ctx sdk.Context, key []byte, sequence uint32) error { val := gogotypes.UInt32Value{ - Value: seq, + Value: sequence, } return k.setDataToStore(ctx, key, &val) } -func (k Keeper) genNextUint32Seq(ctx sdk.Context, key []byte) (uint32, error) { +func (k Keeper) genNextUint32Sequence(ctx sdk.Context, key []byte) (uint32, error) { var val gogotypes.UInt32Value err := k.getDataFromStore(ctx, key, &val) if err != nil { diff --git a/x/dex/keeper/keeper_test.go b/x/dex/keeper/keeper_test.go index d04dbda6f..441219f44 100644 --- a/x/dex/keeper/keeper_test.go +++ b/x/dex/keeper/keeper_test.go @@ -4,6 +4,7 @@ import ( "fmt" "math" "reflect" + "strings" "testing" "time" @@ -16,7 +17,6 @@ import ( authkeeper "github.com/cosmos/cosmos-sdk/x/auth/keeper" authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" govtypes "github.com/cosmos/cosmos-sdk/x/gov/types" - "github.com/cosmos/gogoproto/proto" "github.com/docker/distribution/uuid" "github.com/samber/lo" "github.com/stretchr/testify/require" @@ -34,8 +34,9 @@ const ( ) type OrderPlacementEvents struct { - OrderCreated *types.EventOrderCreated + OrderPlaced types.EventOrderPlaced OrdersReduced []types.EventOrderReduced + OrderCreated *types.EventOrderCreated OrdersClosed []types.EventOrderClosed } @@ -52,65 +53,30 @@ func (o OrderPlacementEvents) getOrderReduced(acc, id string) (types.EventOrderR func readOrderEvents( t *testing.T, sdkCtx sdk.Context, - testApp *simapp.App, ) OrderPlacementEvents { - const ( - attrKeyOrder = "order" - attrKeyCreator = "creator" - attrKeyID = "id" - attrKeySentCoin = "sent_coin" - attrKeyReceivedCoin = "received_coin" - ) events := OrderPlacementEvents{ OrderCreated: nil, OrdersReduced: make([]types.EventOrderReduced, 0), OrdersClosed: make([]types.EventOrderClosed, 0), } - for _, evt := range sdkCtx.EventManager().Events() { - switch evt.Type { - case proto.MessageName(&types.EventOrderCreated{}): + for _, evt := range sdkCtx.EventManager().Events().ToABCIEvents() { + if !strings.HasPrefix(evt.Type, "coreum.dex.v1") { + continue + } + msg, err := sdk.ParseTypedEvent(evt) + require.NoError(t, err) + switch typedEvt := msg.(type) { + case *types.EventOrderPlaced: + require.Empty(t, events.OrderPlaced.Creator, "Only one types.OrderPlaced is expected.") + events.OrderPlaced = *typedEvt + case *types.EventOrderReduced: + events.OrdersReduced = append(events.OrdersReduced, *typedEvt) + case *types.EventOrderCreated: require.Nil(t, events.OrderCreated, "Only one types.EventOrderCreated is expected.") - orderAttr, ok := evt.GetAttribute(attrKeyOrder) - require.True(t, ok) - order := types.Order{} - require.NoError(t, testApp.AppCodec().UnmarshalJSON([]byte(orderAttr.Value), &order)) - events.OrderCreated = &types.EventOrderCreated{ - Order: order, - } - case proto.MessageName(&types.EventOrderReduced{}): - creatorAttr, ok := evt.GetAttribute(attrKeyCreator) - require.True(t, ok) - creator := creatorAttr.Value[1 : len(creatorAttr.Value)-1] // unwrap quotes - - idAttr, ok := evt.GetAttribute(attrKeyID) - require.True(t, ok) - id := idAttr.Value[1 : len(idAttr.Value)-1] // unwrap quotes - - sentCoinAttr, ok := evt.GetAttribute(attrKeySentCoin) - require.True(t, ok) - spentCoin := sdk.Coin{} - require.NoError(t, testApp.AppCodec().UnmarshalJSON([]byte(sentCoinAttr.Value), &spentCoin)) - - receivedCoinAttr, ok := evt.GetAttribute(attrKeyReceivedCoin) - require.True(t, ok) - receivedCoin := sdk.Coin{} - require.NoError(t, testApp.AppCodec().UnmarshalJSON([]byte(receivedCoinAttr.Value), &receivedCoin)) - - events.OrdersReduced = append(events.OrdersReduced, types.EventOrderReduced{ - Creator: creator, - ID: id, - SentCoin: spentCoin, - ReceivedCoin: receivedCoin, - }) - case proto.MessageName(&types.EventOrderClosed{}): - orderAttr, ok := evt.GetAttribute(attrKeyOrder) - require.True(t, ok) - order := types.Order{} - require.NoError(t, testApp.AppCodec().UnmarshalJSON([]byte(orderAttr.Value), &order)) - events.OrdersClosed = append(events.OrdersClosed, types.EventOrderClosed{ - Order: order, - }) + events.OrderCreated = typedEvt + case *types.EventOrderClosed: + events.OrdersClosed = append(events.OrdersClosed, *typedEvt) } } @@ -257,6 +223,7 @@ func TestKeeper_PlaceAndGetOrderByID(t *testing.T) { require.NoError(t, err) // set expected values + sellOrder.Sequence = 1 sellOrder.RemainingQuantity = sdkmath.NewInt(10) sellOrder.RemainingBalance = sdkmath.NewInt(10) orderReserve := testApp.DEXKeeper.GetParams(sdkCtx).OrderReserve @@ -289,6 +256,7 @@ func TestKeeper_PlaceAndGetOrderByID(t *testing.T) { require.NoError(t, err) // set expected values + buyOrder.Sequence = 2 buyOrder.RemainingQuantity = sdkmath.NewInt(100) buyOrder.RemainingBalance = sdkmath.NewInt(120) buyOrder.Reserve = orderReserve @@ -343,14 +311,23 @@ func TestKeeper_PlaceAndCancelOrder(t *testing.T) { sdkCtx = sdkCtx.WithEventManager(sdk.NewEventManager()) require.NoError(t, dexKeeper.PlaceOrder(sdkCtx, sellOrder)) - events := readOrderEvents(t, sdkCtx, testApp) + events := readOrderEvents(t, sdkCtx) require.NotNil(t, events.OrderCreated) - orderReserve := testApp.DEXKeeper.GetParams(sdkCtx).OrderReserve - expectedOrder := sellOrder - expectedOrder.RemainingBalance = sellLockedBalance.Amount - expectedOrder.RemainingQuantity = sellOrder.Quantity - expectedOrder.Reserve = orderReserve - require.Equal(t, expectedOrder, events.OrderCreated.Order) + + expectedSellOrderSequence := uint64(1) + require.Equal(t, types.EventOrderPlaced{ + Creator: sellOrder.Creator, + ID: sellOrder.ID, + Sequence: expectedSellOrderSequence, // first order sequence + }, events.OrderPlaced) + + require.Equal(t, types.EventOrderCreated{ + Creator: sellOrder.Creator, + ID: sellOrder.ID, + Sequence: expectedSellOrderSequence, + RemainingQuantity: sellOrder.Quantity, + RemainingBalance: sellLockedBalance.Amount, + }, *events.OrderCreated) require.Empty(t, events.OrdersClosed) require.Empty(t, events.OrdersReduced) @@ -363,11 +340,15 @@ func TestKeeper_PlaceAndCancelOrder(t *testing.T) { sdkCtx = sdkCtx.WithEventManager(sdk.NewEventManager()) require.NoError(t, dexKeeper.CancelOrder(sdkCtx, acc, sellOrder.ID)) - events = readOrderEvents(t, sdkCtx, testApp) + events = readOrderEvents(t, sdkCtx) require.Nil(t, events.OrderCreated) require.EqualValues(t, []types.EventOrderClosed{ { - Order: expectedOrder, + Creator: sellOrder.Creator, + ID: sellOrder.ID, + Sequence: expectedSellOrderSequence, + RemainingQuantity: sellOrder.Quantity, + RemainingBalance: sellLockedBalance.Amount, }, }, events.OrdersClosed) require.Empty(t, events.OrdersReduced) @@ -441,35 +422,43 @@ func TestKeeper_PlaceAndCancelOrder(t *testing.T) { sdkCtx = sdkCtx.WithEventManager(sdk.NewEventManager()) require.NoError(t, dexKeeper.PlaceOrder(sdkCtx, buyOrder)) - events = readOrderEvents(t, sdkCtx, testApp) - expectedOrder = buyOrder - expectedOrder.RemainingQuantity = sdkmath.NewInt(4000) // filled partially - expectedOrder.RemainingBalance = sdkmath.NewInt(5200) - expectedOrder.Reserve = orderReserve - require.Equal(t, expectedOrder, events.OrderCreated.Order) + events = readOrderEvents(t, sdkCtx) + + // update sequence + expectedSellOrderSequence = uint64(3) + expectedBuyOrderSequence := uint64(4) + require.Equal(t, types.EventOrderCreated{ + Creator: buyOrder.Creator, + ID: buyOrder.ID, + Sequence: expectedBuyOrderSequence, + RemainingQuantity: sdkmath.NewInt(4000), // filled partially + RemainingBalance: sdkmath.NewInt(5200), + }, *events.OrderCreated) require.EqualValues(t, []types.EventOrderReduced{ { Creator: sellOrder.Creator, ID: sellOrder.ID, + Sequence: expectedSellOrderSequence, SentCoin: sdk.NewCoin(sellOrder.BaseDenom, sdkmath.NewIntFromUint64(1000)), ReceivedCoin: sdk.NewCoin(sellOrder.QuoteDenom, sdkmath.NewIntFromUint64(1200)), }, { Creator: buyOrder.Creator, ID: buyOrder.ID, + Sequence: expectedBuyOrderSequence, SentCoin: sdk.NewCoin(buyOrder.QuoteDenom, sdkmath.NewIntFromUint64(1200)), ReceivedCoin: sdk.NewCoin(buyOrder.BaseDenom, sdkmath.NewIntFromUint64(1000)), }, }, events.OrdersReduced) - expectedOrder = sellOrder - expectedOrder.Reserve = orderReserve - expectedOrder.RemainingBalance = sdkmath.ZeroInt() - expectedOrder.RemainingQuantity = sdkmath.ZeroInt() require.EqualValues(t, []types.EventOrderClosed{ { - Order: expectedOrder, + Creator: sellOrder.Creator, + ID: sellOrder.ID, + Sequence: expectedSellOrderSequence, + RemainingQuantity: sdkmath.ZeroInt(), + RemainingBalance: sdkmath.ZeroInt(), }, }, events.OrdersClosed) @@ -666,9 +655,9 @@ func TestKeeper_GetOrdersAndOrderBookOrders(t *testing.T) { // fill order with the remaining quantity for assertions order.RemainingQuantity = order.Quantity order.RemainingBalance = lockedBalance.Amount - order.Reserve = testApp.DEXKeeper.GetParams(sdkCtx).OrderReserve orders[i] = order } + orders = fillReserveAndOrderSequence(t, sdkCtx, testApp, orders) // get account orders acc1Orders, pageRes, err := testApp.DEXKeeper.GetOrders(sdkCtx, acc1, &query.PageRequest{ @@ -685,6 +674,7 @@ func TestKeeper_GetOrdersAndOrderBookOrders(t *testing.T) { Limit: query.PaginationMaxLimit, }) require.NoError(t, err) + require.ElementsMatch(t, []types.Order{ orders[0], orders[1], orders[2], }, acc1Orders) diff --git a/x/dex/spec/README.md b/x/dex/spec/README.md index cc17c7dfb..3c2eb32ff 100644 --- a/x/dex/spec/README.md +++ b/x/dex/spec/README.md @@ -235,6 +235,18 @@ The default reserve amount is `10 CORE` and can be updated by the governance. The number of active orders a user can have for each denom is limited by a value called `max_orders_per_denom`, which is determined by DEX governance. +### Events + +The DEX module emits events at the time of the matching to notify the interested parties of the changes caused by the +matching. The events are defined in the [event.proto](../../../proto/coreum/dex/v1/event.proto). The events are emitted +for each order that was placed. The events are: + +1. `EventOrderPlaced` is emitted when the order is placed. +2. `EventOrderReduced` is emitted when the order is reduced during the matching. +3. `EventOrderClosed` is emitted when the order is closed during the matching or manually, or because of `good_til` in + the `begin blocker`, and removed from the order book. +4. `EventOrderCreated` is emitted when the order is saved to the order book. + ## Asset FT and DEX ### Unified ref amount diff --git a/x/dex/types/event.pb.go b/x/dex/types/event.pb.go index 24067e4c2..070bfc09a 100644 --- a/x/dex/types/event.pb.go +++ b/x/dex/types/event.pb.go @@ -4,6 +4,7 @@ package types import ( + cosmossdk_io_math "cosmossdk.io/math" fmt "fmt" github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types" _ "github.com/cosmos/gogoproto/gogoproto" @@ -24,23 +25,28 @@ var _ = math.Inf // proto package needs to be updated. const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package -// EventOrderCreated is emitted when the limit order is saved to the order book. -type EventOrderCreated struct { - Order Order `protobuf:"bytes,1,opt,name=order,proto3" json:"order"` +// EventOrderPlaced is emitted when a new order is placed and new sequence is generated for it. +type EventOrderPlaced struct { + // creator is order creator address. + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + // id is unique order ID. + ID string `protobuf:"bytes,2,opt,name=id,proto3" json:"id,omitempty"` + // sequence is unique order sequence. + Sequence uint64 `protobuf:"varint,3,opt,name=sequence,proto3" json:"sequence,omitempty"` } -func (m *EventOrderCreated) Reset() { *m = EventOrderCreated{} } -func (m *EventOrderCreated) String() string { return proto.CompactTextString(m) } -func (*EventOrderCreated) ProtoMessage() {} -func (*EventOrderCreated) Descriptor() ([]byte, []int) { +func (m *EventOrderPlaced) Reset() { *m = EventOrderPlaced{} } +func (m *EventOrderPlaced) String() string { return proto.CompactTextString(m) } +func (*EventOrderPlaced) ProtoMessage() {} +func (*EventOrderPlaced) Descriptor() ([]byte, []int) { return fileDescriptor_cecfe712f14d2a81, []int{0} } -func (m *EventOrderCreated) XXX_Unmarshal(b []byte) error { +func (m *EventOrderPlaced) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) } -func (m *EventOrderCreated) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { +func (m *EventOrderPlaced) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { if deterministic { - return xxx_messageInfo_EventOrderCreated.Marshal(b, m, deterministic) + return xxx_messageInfo_EventOrderPlaced.Marshal(b, m, deterministic) } else { b = b[:cap(b)] n, err := m.MarshalToSizedBuffer(b) @@ -50,23 +56,37 @@ func (m *EventOrderCreated) XXX_Marshal(b []byte, deterministic bool) ([]byte, e return b[:n], nil } } -func (m *EventOrderCreated) XXX_Merge(src proto.Message) { - xxx_messageInfo_EventOrderCreated.Merge(m, src) +func (m *EventOrderPlaced) XXX_Merge(src proto.Message) { + xxx_messageInfo_EventOrderPlaced.Merge(m, src) } -func (m *EventOrderCreated) XXX_Size() int { +func (m *EventOrderPlaced) XXX_Size() int { return m.Size() } -func (m *EventOrderCreated) XXX_DiscardUnknown() { - xxx_messageInfo_EventOrderCreated.DiscardUnknown(m) +func (m *EventOrderPlaced) XXX_DiscardUnknown() { + xxx_messageInfo_EventOrderPlaced.DiscardUnknown(m) } -var xxx_messageInfo_EventOrderCreated proto.InternalMessageInfo +var xxx_messageInfo_EventOrderPlaced proto.InternalMessageInfo + +func (m *EventOrderPlaced) GetCreator() string { + if m != nil { + return m.Creator + } + return "" +} + +func (m *EventOrderPlaced) GetID() string { + if m != nil { + return m.ID + } + return "" +} -func (m *EventOrderCreated) GetOrder() Order { +func (m *EventOrderPlaced) GetSequence() uint64 { if m != nil { - return m.Order + return m.Sequence } - return Order{} + return 0 } // EventOrderReduced is emitted when the order is reduced during the matching. @@ -75,10 +95,12 @@ type EventOrderReduced struct { Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` // id is unique order ID. ID string `protobuf:"bytes,2,opt,name=id,proto3" json:"id,omitempty"` + // sequence is unique order sequence. + Sequence uint64 `protobuf:"varint,3,opt,name=sequence,proto3" json:"sequence,omitempty"` // sent_coin is coin sent during matching. - SentCoin github_com_cosmos_cosmos_sdk_types.Coin `protobuf:"bytes,3,opt,name=sent_coin,json=sentCoin,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Coin" json:"sent_coin"` + SentCoin github_com_cosmos_cosmos_sdk_types.Coin `protobuf:"bytes,4,opt,name=sent_coin,json=sentCoin,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Coin" json:"sent_coin"` // received_coin is coin received during matching. - ReceivedCoin github_com_cosmos_cosmos_sdk_types.Coin `protobuf:"bytes,4,opt,name=received_coin,json=receivedCoin,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Coin" json:"received_coin"` + ReceivedCoin github_com_cosmos_cosmos_sdk_types.Coin `protobuf:"bytes,5,opt,name=received_coin,json=receivedCoin,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Coin" json:"received_coin"` } func (m *EventOrderReduced) Reset() { *m = EventOrderReduced{} } @@ -128,16 +150,100 @@ func (m *EventOrderReduced) GetID() string { return "" } -// EventOrderClosed is emitted when the order is closed during matching or manually. +func (m *EventOrderReduced) GetSequence() uint64 { + if m != nil { + return m.Sequence + } + return 0 +} + +// EventOrderCreated is emitted when the limit order is saved to the order book. +type EventOrderCreated struct { + // creator is order creator address. + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + // id is unique order ID. + ID string `protobuf:"bytes,2,opt,name=id,proto3" json:"id,omitempty"` + // sequence is unique order sequence. + Sequence uint64 `protobuf:"varint,3,opt,name=sequence,proto3" json:"sequence,omitempty"` + // remaining_quantity is remaining filling quantity sell/buy. + RemainingQuantity cosmossdk_io_math.Int `protobuf:"bytes,4,opt,name=remaining_quantity,json=remainingQuantity,proto3,customtype=cosmossdk.io/math.Int" json:"remaining_quantity"` + // remaining_balance is remaining order balance. + RemainingBalance cosmossdk_io_math.Int `protobuf:"bytes,5,opt,name=remaining_balance,json=remainingBalance,proto3,customtype=cosmossdk.io/math.Int" json:"remaining_balance"` +} + +func (m *EventOrderCreated) Reset() { *m = EventOrderCreated{} } +func (m *EventOrderCreated) String() string { return proto.CompactTextString(m) } +func (*EventOrderCreated) ProtoMessage() {} +func (*EventOrderCreated) Descriptor() ([]byte, []int) { + return fileDescriptor_cecfe712f14d2a81, []int{2} +} +func (m *EventOrderCreated) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *EventOrderCreated) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_EventOrderCreated.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 *EventOrderCreated) XXX_Merge(src proto.Message) { + xxx_messageInfo_EventOrderCreated.Merge(m, src) +} +func (m *EventOrderCreated) XXX_Size() int { + return m.Size() +} +func (m *EventOrderCreated) XXX_DiscardUnknown() { + xxx_messageInfo_EventOrderCreated.DiscardUnknown(m) +} + +var xxx_messageInfo_EventOrderCreated proto.InternalMessageInfo + +func (m *EventOrderCreated) GetCreator() string { + if m != nil { + return m.Creator + } + return "" +} + +func (m *EventOrderCreated) GetID() string { + if m != nil { + return m.ID + } + return "" +} + +func (m *EventOrderCreated) GetSequence() uint64 { + if m != nil { + return m.Sequence + } + return 0 +} + +// EventOrderClosed is emitted when the order is closed during matching or manually, and removed from the order book. type EventOrderClosed struct { - Order Order `protobuf:"bytes,1,opt,name=order,proto3" json:"order"` + // creator is order creator address. + Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` + // id is unique order ID. + ID string `protobuf:"bytes,2,opt,name=id,proto3" json:"id,omitempty"` + // sequence is unique order sequence. + Sequence uint64 `protobuf:"varint,3,opt,name=sequence,proto3" json:"sequence,omitempty"` + // remaining_quantity is remaining filling quantity sell/buy. + RemainingQuantity cosmossdk_io_math.Int `protobuf:"bytes,4,opt,name=remaining_quantity,json=remainingQuantity,proto3,customtype=cosmossdk.io/math.Int" json:"remaining_quantity"` + // remaining_balance is remaining order balance. + RemainingBalance cosmossdk_io_math.Int `protobuf:"bytes,5,opt,name=remaining_balance,json=remainingBalance,proto3,customtype=cosmossdk.io/math.Int" json:"remaining_balance"` } func (m *EventOrderClosed) Reset() { *m = EventOrderClosed{} } func (m *EventOrderClosed) String() string { return proto.CompactTextString(m) } func (*EventOrderClosed) ProtoMessage() {} func (*EventOrderClosed) Descriptor() ([]byte, []int) { - return fileDescriptor_cecfe712f14d2a81, []int{2} + return fileDescriptor_cecfe712f14d2a81, []int{3} } func (m *EventOrderClosed) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -166,47 +272,67 @@ func (m *EventOrderClosed) XXX_DiscardUnknown() { var xxx_messageInfo_EventOrderClosed proto.InternalMessageInfo -func (m *EventOrderClosed) GetOrder() Order { +func (m *EventOrderClosed) GetCreator() string { + if m != nil { + return m.Creator + } + return "" +} + +func (m *EventOrderClosed) GetID() string { + if m != nil { + return m.ID + } + return "" +} + +func (m *EventOrderClosed) GetSequence() uint64 { if m != nil { - return m.Order + return m.Sequence } - return Order{} + return 0 } func init() { - proto.RegisterType((*EventOrderCreated)(nil), "coreum.dex.v1.EventOrderCreated") + proto.RegisterType((*EventOrderPlaced)(nil), "coreum.dex.v1.EventOrderPlaced") proto.RegisterType((*EventOrderReduced)(nil), "coreum.dex.v1.EventOrderReduced") + proto.RegisterType((*EventOrderCreated)(nil), "coreum.dex.v1.EventOrderCreated") proto.RegisterType((*EventOrderClosed)(nil), "coreum.dex.v1.EventOrderClosed") } func init() { proto.RegisterFile("coreum/dex/v1/event.proto", fileDescriptor_cecfe712f14d2a81) } var fileDescriptor_cecfe712f14d2a81 = []byte{ - // 333 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x91, 0xcd, 0x4a, 0xc3, 0x40, - 0x10, 0xc7, 0x93, 0x58, 0xab, 0x5d, 0x2d, 0x68, 0x28, 0x12, 0x7b, 0x48, 0xa5, 0x17, 0xbd, 0xb8, - 0x6b, 0x15, 0x5f, 0xa0, 0x1f, 0x82, 0x28, 0x08, 0xc1, 0x93, 0x17, 0x69, 0x77, 0x87, 0xba, 0x68, - 0x33, 0x25, 0xd9, 0x84, 0xfa, 0x16, 0x3e, 0x56, 0x8f, 0x3d, 0x8a, 0x87, 0x22, 0xe9, 0xc9, 0xb7, - 0x90, 0xdd, 0x6d, 0xa1, 0x7a, 0xec, 0x69, 0xe7, 0xe3, 0xbf, 0xbf, 0x19, 0xe6, 0x4f, 0x8e, 0x39, - 0x26, 0x90, 0x8d, 0x98, 0x80, 0x09, 0xcb, 0x5b, 0x0c, 0x72, 0x88, 0x15, 0x1d, 0x27, 0xa8, 0xd0, - 0xaf, 0xda, 0x16, 0x15, 0x30, 0xa1, 0x79, 0xab, 0xfe, 0x4f, 0x89, 0x89, 0x80, 0xc4, 0x2a, 0xeb, - 0xb5, 0x21, 0x0e, 0xd1, 0x84, 0x4c, 0x47, 0xb6, 0xda, 0xec, 0x91, 0xc3, 0x9e, 0xc6, 0x3d, 0x68, - 0x65, 0x27, 0x81, 0xbe, 0x02, 0xe1, 0x5f, 0x90, 0x6d, 0xf3, 0x33, 0x70, 0x4f, 0xdc, 0xb3, 0xbd, - 0xcb, 0x1a, 0xfd, 0x33, 0x84, 0x1a, 0x6d, 0xbb, 0x34, 0x9d, 0x37, 0x9c, 0xc8, 0x0a, 0x9b, 0x3f, - 0xee, 0x3a, 0x27, 0x02, 0x91, 0x71, 0x10, 0x7e, 0x40, 0x76, 0xb8, 0x46, 0xa2, 0x25, 0x55, 0xa2, - 0x55, 0xea, 0x1f, 0x11, 0x4f, 0x8a, 0xc0, 0xd3, 0xc5, 0x76, 0xb9, 0x98, 0x37, 0xbc, 0xdb, 0x6e, - 0xe4, 0x49, 0xe1, 0xdf, 0x93, 0x4a, 0x0a, 0xb1, 0x7a, 0xe6, 0x28, 0xe3, 0x60, 0xcb, 0xb4, 0x99, - 0x9e, 0xf3, 0x35, 0x6f, 0x9c, 0x0e, 0xa5, 0x7a, 0xc9, 0x06, 0x94, 0xe3, 0x88, 0x71, 0x4c, 0x47, - 0x98, 0x2e, 0x9f, 0xf3, 0x54, 0xbc, 0x32, 0xf5, 0x3e, 0x86, 0x94, 0x76, 0x50, 0xc6, 0xd1, 0xae, - 0x26, 0xe8, 0xc8, 0x7f, 0x24, 0xd5, 0x04, 0x38, 0xc8, 0x1c, 0x84, 0x25, 0x96, 0x36, 0x23, 0xee, - 0xaf, 0x28, 0x3a, 0x6b, 0x76, 0xc9, 0xc1, 0xda, 0xc9, 0xde, 0x30, 0xdd, 0xe4, 0x62, 0xed, 0xbb, - 0x69, 0x11, 0xba, 0xb3, 0x22, 0x74, 0xbf, 0x8b, 0xd0, 0xfd, 0x58, 0x84, 0xce, 0x6c, 0x11, 0x3a, - 0x9f, 0x8b, 0xd0, 0x79, 0x6a, 0xad, 0xad, 0xd5, 0x31, 0x98, 0x1b, 0xcc, 0x62, 0xd1, 0x57, 0x12, - 0x63, 0xb6, 0xf4, 0x37, 0xbf, 0x66, 0x13, 0x63, 0xb2, 0xd9, 0x72, 0x50, 0x36, 0x66, 0x5e, 0xfd, - 0x06, 0x00, 0x00, 0xff, 0xff, 0x1c, 0xc7, 0x6a, 0x7a, 0x29, 0x02, 0x00, 0x00, + // 406 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe4, 0x53, 0xcb, 0x6e, 0xd4, 0x30, + 0x14, 0x8d, 0x43, 0x5b, 0xa8, 0x45, 0xa5, 0xd6, 0x02, 0x14, 0x2a, 0x91, 0xa9, 0xb2, 0xa1, 0x1b, + 0x62, 0x8d, 0x10, 0x3f, 0x30, 0x01, 0xa4, 0x02, 0x12, 0x10, 0xb1, 0x62, 0x33, 0x78, 0xec, 0xab, + 0xd4, 0xea, 0xc4, 0x6e, 0x6d, 0x27, 0x9a, 0x7e, 0x00, 0x7b, 0x3e, 0xab, 0xcb, 0x59, 0x22, 0x16, + 0x23, 0x94, 0xf9, 0x0b, 0xd8, 0x20, 0x27, 0x99, 0xc7, 0x12, 0x21, 0x58, 0xb1, 0xf2, 0x7d, 0xf8, + 0x9c, 0xfb, 0xd0, 0x3d, 0xf8, 0x21, 0xd7, 0x06, 0xaa, 0x92, 0x0a, 0x98, 0xd1, 0x7a, 0x48, 0xa1, + 0x06, 0xe5, 0xd2, 0x4b, 0xa3, 0x9d, 0x26, 0x07, 0x5d, 0x2a, 0x15, 0x30, 0x4b, 0xeb, 0xe1, 0xf1, + 0xbd, 0x42, 0x17, 0xba, 0xcd, 0x50, 0x6f, 0x75, 0x9f, 0x92, 0x4f, 0xf8, 0xf0, 0x85, 0xc7, 0xbc, + 0x35, 0x02, 0xcc, 0xbb, 0x29, 0xe3, 0x20, 0x48, 0x84, 0x6f, 0x73, 0x03, 0xcc, 0x69, 0x13, 0xa1, + 0x13, 0x74, 0xba, 0x9f, 0xaf, 0x5c, 0xf2, 0x00, 0x87, 0x52, 0x44, 0xa1, 0x0f, 0x8e, 0xf6, 0x9a, + 0xc5, 0x20, 0x3c, 0x7b, 0x9e, 0x87, 0x52, 0x90, 0x63, 0x7c, 0xc7, 0xc2, 0x55, 0x05, 0x8a, 0x43, + 0x74, 0xeb, 0x04, 0x9d, 0xee, 0xe4, 0x6b, 0x3f, 0xf9, 0x1c, 0xe2, 0xa3, 0x4d, 0x89, 0x1c, 0x44, + 0xf5, 0xd7, 0x6b, 0x90, 0x37, 0x78, 0xdf, 0x82, 0x72, 0x63, 0xae, 0xa5, 0x8a, 0x76, 0x5a, 0x28, + 0xbd, 0x59, 0x0c, 0x82, 0x6f, 0x8b, 0xc1, 0xe3, 0x42, 0xba, 0xf3, 0x6a, 0x92, 0x72, 0x5d, 0x52, + 0xae, 0x6d, 0xa9, 0x6d, 0xff, 0x3c, 0xb1, 0xe2, 0x82, 0xba, 0xeb, 0x4b, 0xb0, 0x69, 0xa6, 0xa5, + 0xf2, 0x6c, 0xca, 0x79, 0x8b, 0x7c, 0xc0, 0x07, 0x06, 0x38, 0xc8, 0x1a, 0x44, 0xc7, 0xb8, 0xfb, + 0x67, 0x8c, 0x77, 0x57, 0x2c, 0xde, 0x4b, 0x7e, 0xa2, 0xed, 0x3d, 0x64, 0x7e, 0xda, 0x7f, 0xb0, + 0x07, 0x62, 0xa0, 0x64, 0x52, 0x49, 0x55, 0x8c, 0xaf, 0x2a, 0xa6, 0x9c, 0x74, 0xd7, 0xfd, 0x42, + 0x1e, 0xf5, 0xed, 0xdf, 0xef, 0x9a, 0xb5, 0xe2, 0x22, 0x95, 0x9a, 0x96, 0xcc, 0x9d, 0xa7, 0x67, + 0xca, 0xe5, 0x47, 0x6b, 0xe0, 0xfb, 0x1e, 0x47, 0x5e, 0xe1, 0x4d, 0x70, 0x3c, 0x61, 0x53, 0xe6, + 0x4b, 0xee, 0xfe, 0x0e, 0xd9, 0xe1, 0x1a, 0x37, 0xea, 0x60, 0xc9, 0x0f, 0xb4, 0x7d, 0x68, 0xd9, + 0x54, 0xdb, 0xff, 0x67, 0xf8, 0xd1, 0xeb, 0x9b, 0x26, 0x46, 0xf3, 0x26, 0x46, 0xdf, 0x9b, 0x18, + 0x7d, 0x59, 0xc6, 0xc1, 0x7c, 0x19, 0x07, 0x5f, 0x97, 0x71, 0xf0, 0x71, 0xb8, 0x75, 0x4b, 0x59, + 0x2b, 0xd7, 0x97, 0xba, 0x52, 0x82, 0x39, 0xa9, 0x15, 0xed, 0xa5, 0x5d, 0x3f, 0xa3, 0xb3, 0x56, + 0xdf, 0xed, 0x69, 0x4d, 0xf6, 0x5a, 0xe1, 0x3e, 0xfd, 0x15, 0x00, 0x00, 0xff, 0xff, 0xe1, 0xd5, + 0xa3, 0x78, 0xfa, 0x03, 0x00, 0x00, } -func (m *EventOrderCreated) Marshal() (dAtA []byte, err error) { +func (m *EventOrderPlaced) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) n, err := m.MarshalToSizedBuffer(dAtA[:size]) @@ -216,26 +342,35 @@ func (m *EventOrderCreated) Marshal() (dAtA []byte, err error) { return dAtA[:n], nil } -func (m *EventOrderCreated) MarshalTo(dAtA []byte) (int, error) { +func (m *EventOrderPlaced) MarshalTo(dAtA []byte) (int, error) { size := m.Size() return m.MarshalToSizedBuffer(dAtA[:size]) } -func (m *EventOrderCreated) MarshalToSizedBuffer(dAtA []byte) (int, error) { +func (m *EventOrderPlaced) MarshalToSizedBuffer(dAtA []byte) (int, error) { i := len(dAtA) _ = i var l int _ = l - { - size, err := m.Order.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintEvent(dAtA, i, uint64(size)) + if m.Sequence != 0 { + i = encodeVarintEvent(dAtA, i, uint64(m.Sequence)) + i-- + dAtA[i] = 0x18 + } + if len(m.ID) > 0 { + i -= len(m.ID) + copy(dAtA[i:], m.ID) + i = encodeVarintEvent(dAtA, i, uint64(len(m.ID))) + i-- + dAtA[i] = 0x12 + } + if len(m.Creator) > 0 { + i -= len(m.Creator) + copy(dAtA[i:], m.Creator) + i = encodeVarintEvent(dAtA, i, uint64(len(m.Creator))) + i-- + dAtA[i] = 0xa } - i-- - dAtA[i] = 0xa return len(dAtA) - i, nil } @@ -268,7 +403,7 @@ func (m *EventOrderReduced) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintEvent(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x22 + dAtA[i] = 0x2a { size := m.SentCoin.Size() i -= size @@ -278,7 +413,74 @@ func (m *EventOrderReduced) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintEvent(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x1a + dAtA[i] = 0x22 + if m.Sequence != 0 { + i = encodeVarintEvent(dAtA, i, uint64(m.Sequence)) + i-- + dAtA[i] = 0x18 + } + if len(m.ID) > 0 { + i -= len(m.ID) + copy(dAtA[i:], m.ID) + i = encodeVarintEvent(dAtA, i, uint64(len(m.ID))) + i-- + dAtA[i] = 0x12 + } + if len(m.Creator) > 0 { + i -= len(m.Creator) + copy(dAtA[i:], m.Creator) + i = encodeVarintEvent(dAtA, i, uint64(len(m.Creator))) + i-- + dAtA[i] = 0xa + } + return len(dAtA) - i, nil +} + +func (m *EventOrderCreated) 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 *EventOrderCreated) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *EventOrderCreated) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size := m.RemainingBalance.Size() + i -= size + if _, err := m.RemainingBalance.MarshalTo(dAtA[i:]); err != nil { + return 0, err + } + i = encodeVarintEvent(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + { + size := m.RemainingQuantity.Size() + i -= size + if _, err := m.RemainingQuantity.MarshalTo(dAtA[i:]); err != nil { + return 0, err + } + i = encodeVarintEvent(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x22 + if m.Sequence != 0 { + i = encodeVarintEvent(dAtA, i, uint64(m.Sequence)) + i-- + dAtA[i] = 0x18 + } if len(m.ID) > 0 { i -= len(m.ID) copy(dAtA[i:], m.ID) @@ -317,15 +519,44 @@ func (m *EventOrderClosed) MarshalToSizedBuffer(dAtA []byte) (int, error) { var l int _ = l { - size, err := m.Order.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { + size := m.RemainingBalance.Size() + i -= size + if _, err := m.RemainingBalance.MarshalTo(dAtA[i:]); err != nil { return 0, err } + i = encodeVarintEvent(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0x2a + { + size := m.RemainingQuantity.Size() i -= size + if _, err := m.RemainingQuantity.MarshalTo(dAtA[i:]); err != nil { + return 0, err + } i = encodeVarintEvent(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0xa + dAtA[i] = 0x22 + if m.Sequence != 0 { + i = encodeVarintEvent(dAtA, i, uint64(m.Sequence)) + i-- + dAtA[i] = 0x18 + } + if len(m.ID) > 0 { + i -= len(m.ID) + copy(dAtA[i:], m.ID) + i = encodeVarintEvent(dAtA, i, uint64(len(m.ID))) + i-- + dAtA[i] = 0x12 + } + if len(m.Creator) > 0 { + i -= len(m.Creator) + copy(dAtA[i:], m.Creator) + i = encodeVarintEvent(dAtA, i, uint64(len(m.Creator))) + i-- + dAtA[i] = 0xa + } return len(dAtA) - i, nil } @@ -340,14 +571,23 @@ func encodeVarintEvent(dAtA []byte, offset int, v uint64) int { dAtA[offset] = uint8(v) return base } -func (m *EventOrderCreated) Size() (n int) { +func (m *EventOrderPlaced) Size() (n int) { if m == nil { return 0 } var l int _ = l - l = m.Order.Size() - n += 1 + l + sovEvent(uint64(l)) + l = len(m.Creator) + if l > 0 { + n += 1 + l + sovEvent(uint64(l)) + } + l = len(m.ID) + if l > 0 { + n += 1 + l + sovEvent(uint64(l)) + } + if m.Sequence != 0 { + n += 1 + sovEvent(uint64(m.Sequence)) + } return n } @@ -365,6 +605,9 @@ func (m *EventOrderReduced) Size() (n int) { if l > 0 { n += 1 + l + sovEvent(uint64(l)) } + if m.Sequence != 0 { + n += 1 + sovEvent(uint64(m.Sequence)) + } l = m.SentCoin.Size() n += 1 + l + sovEvent(uint64(l)) l = m.ReceivedCoin.Size() @@ -372,30 +615,67 @@ func (m *EventOrderReduced) Size() (n int) { return n } -func (m *EventOrderClosed) Size() (n int) { +func (m *EventOrderCreated) Size() (n int) { if m == nil { return 0 } var l int _ = l - l = m.Order.Size() + l = len(m.Creator) + if l > 0 { + n += 1 + l + sovEvent(uint64(l)) + } + l = len(m.ID) + if l > 0 { + n += 1 + l + sovEvent(uint64(l)) + } + if m.Sequence != 0 { + n += 1 + sovEvent(uint64(m.Sequence)) + } + l = m.RemainingQuantity.Size() + n += 1 + l + sovEvent(uint64(l)) + l = m.RemainingBalance.Size() n += 1 + l + sovEvent(uint64(l)) return n } -func sovEvent(x uint64) (n int) { - return (math_bits.Len64(x|1) + 6) / 7 -} -func sozEvent(x uint64) (n int) { - return sovEvent(uint64((x << 1) ^ uint64((int64(x) >> 63)))) -} -func (m *EventOrderCreated) Unmarshal(dAtA []byte) error { - l := len(dAtA) - iNdEx := 0 - for iNdEx < l { - preIndex := iNdEx - var wire uint64 - for shift := uint(0); ; shift += 7 { +func (m *EventOrderClosed) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = len(m.Creator) + if l > 0 { + n += 1 + l + sovEvent(uint64(l)) + } + l = len(m.ID) + if l > 0 { + n += 1 + l + sovEvent(uint64(l)) + } + if m.Sequence != 0 { + n += 1 + sovEvent(uint64(m.Sequence)) + } + l = m.RemainingQuantity.Size() + n += 1 + l + sovEvent(uint64(l)) + l = m.RemainingBalance.Size() + n += 1 + l + sovEvent(uint64(l)) + return n +} + +func sovEvent(x uint64) (n int) { + return (math_bits.Len64(x|1) + 6) / 7 +} +func sozEvent(x uint64) (n int) { + return sovEvent(uint64((x << 1) ^ uint64((int64(x) >> 63)))) +} +func (m *EventOrderPlaced) 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 ErrIntOverflowEvent } @@ -412,17 +692,17 @@ func (m *EventOrderCreated) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: EventOrderCreated: wiretype end group for non-group") + return fmt.Errorf("proto: EventOrderPlaced: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: EventOrderCreated: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: EventOrderPlaced: 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) + return fmt.Errorf("proto: wrong wireType = %d for field Creator", wireType) } - var msglen int + var stringLen uint64 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowEvent @@ -432,25 +712,75 @@ func (m *EventOrderCreated) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + stringLen |= uint64(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + intStringLen := int(stringLen) + if intStringLen < 0 { return ErrInvalidLengthEvent } - postIndex := iNdEx + msglen + postIndex := iNdEx + intStringLen if postIndex < 0 { return ErrInvalidLengthEvent } if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.Order.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { - return err + m.Creator = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 2: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field ID", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + 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 ErrInvalidLengthEvent } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvent + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ID = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Sequence", wireType) + } + m.Sequence = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Sequence |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } default: iNdEx = preIndex skippy, err := skipEvent(dAtA[iNdEx:]) @@ -566,6 +896,25 @@ func (m *EventOrderReduced) Unmarshal(dAtA []byte) error { m.ID = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Sequence", wireType) + } + m.Sequence = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Sequence |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 4: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field SentCoin", wireType) } @@ -599,7 +948,7 @@ func (m *EventOrderReduced) Unmarshal(dAtA []byte) error { return err } iNdEx = postIndex - case 4: + case 5: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field ReceivedCoin", wireType) } @@ -654,6 +1003,207 @@ func (m *EventOrderReduced) Unmarshal(dAtA []byte) error { } return nil } +func (m *EventOrderCreated) 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 ErrIntOverflowEvent + } + 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: EventOrderCreated: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: EventOrderCreated: 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 ErrIntOverflowEvent + } + 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 ErrInvalidLengthEvent + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvent + } + 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 ID", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + 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 ErrInvalidLengthEvent + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvent + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ID = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Sequence", wireType) + } + m.Sequence = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Sequence |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RemainingQuantity", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + 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 ErrInvalidLengthEvent + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvent + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.RemainingQuantity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RemainingBalance", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + 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 ErrInvalidLengthEvent + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvent + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.RemainingBalance.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipEvent(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthEvent + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func (m *EventOrderClosed) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 @@ -685,9 +1235,9 @@ func (m *EventOrderClosed) Unmarshal(dAtA []byte) error { switch fieldNum { case 1: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Order", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field Creator", wireType) } - var msglen int + var stringLen uint64 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowEvent @@ -697,22 +1247,140 @@ func (m *EventOrderClosed) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - msglen |= int(b&0x7F) << shift + stringLen |= uint64(b&0x7F) << shift if b < 0x80 { break } } - if msglen < 0 { + intStringLen := int(stringLen) + if intStringLen < 0 { return ErrInvalidLengthEvent } - postIndex := iNdEx + msglen + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvent + } + 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 ID", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + 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 ErrInvalidLengthEvent + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvent + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + m.ID = string(dAtA[iNdEx:postIndex]) + iNdEx = postIndex + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Sequence", wireType) + } + m.Sequence = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Sequence |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RemainingQuantity", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + 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 ErrInvalidLengthEvent + } + postIndex := iNdEx + intStringLen + if postIndex < 0 { + return ErrInvalidLengthEvent + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.RemainingQuantity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 5: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field RemainingBalance", wireType) + } + var stringLen uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowEvent + } + 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 ErrInvalidLengthEvent + } + postIndex := iNdEx + intStringLen if postIndex < 0 { return ErrInvalidLengthEvent } if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.Order.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + if err := m.RemainingBalance.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err } iNdEx = postIndex diff --git a/x/dex/types/genesis.go b/x/dex/types/genesis.go index 3da0a0c16..2295f0c8c 100644 --- a/x/dex/types/genesis.go +++ b/x/dex/types/genesis.go @@ -23,14 +23,14 @@ func (gs GenesisState) Validate() error { denoms[ob.Data.BaseDenom] = struct{}{} denoms[ob.Data.QuoteDenom] = struct{}{} } - usedSeq := make(map[uint64]struct{}) - for _, orderWithSeq := range gs.Orders { - if _, ok := usedSeq[orderWithSeq.Sequence]; ok { - return sdkerrors.Wrapf(ErrInvalidInput, "duplicate order sequence %d", orderWithSeq.Sequence) + usedSequence := make(map[uint64]struct{}) + for _, order := range gs.Orders { + if _, ok := usedSequence[order.Sequence]; ok { + return sdkerrors.Wrapf(ErrInvalidInput, "duplicate order sequence %d", order.Sequence) } - usedSeq[orderWithSeq.Sequence] = struct{}{} + usedSequence[order.Sequence] = struct{}{} - order := orderWithSeq.Order // copy + order := order // copy if _, ok := denoms[order.BaseDenom]; !ok { return sdkerrors.Wrapf(ErrInvalidInput, "base denom %s does not exist in order books", order.BaseDenom) } @@ -38,6 +38,7 @@ func (gs GenesisState) Validate() error { return sdkerrors.Wrapf(ErrInvalidInput, "quote denom %s does not exist in order books", order.QuoteDenom) } + order.Sequence = 0 order.RemainingQuantity = sdkmath.Int{} order.RemainingBalance = sdkmath.Int{} order.Reserve = sdk.Coin{} diff --git a/x/dex/types/genesis.pb.go b/x/dex/types/genesis.pb.go index b77523d12..55fd0bb87 100644 --- a/x/dex/types/genesis.pb.go +++ b/x/dex/types/genesis.pb.go @@ -26,10 +26,12 @@ const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package // GenesisState defines the module genesis state. type GenesisState struct { // params defines all the parameters of the module. - Params Params `protobuf:"bytes,1,opt,name=params,proto3" json:"params"` - OrderBooks []OrderBookDataWithID `protobuf:"bytes,2,rep,name=order_books,json=orderBooks,proto3" json:"order_books"` - Orders []OrderWithSequence `protobuf:"bytes,3,rep,name=orders,proto3" json:"orders"` - AccountsDenomsOrdersCounts []AccountDenomOrdersCount `protobuf:"bytes,4,rep,name=accounts_denoms_orders_counts,json=accountsDenomsOrdersCounts,proto3" json:"accounts_denoms_orders_counts"` + Params Params `protobuf:"bytes,1,opt,name=params,proto3" json:"params"` + OrderBooks []OrderBookDataWithID `protobuf:"bytes,2,rep,name=order_books,json=orderBooks,proto3" json:"order_books"` + Orders []Order `protobuf:"bytes,3,rep,name=orders,proto3" json:"orders"` + // order_sequence is current order sequence; + OrderSequence uint64 `protobuf:"varint,4,opt,name=order_sequence,json=orderSequence,proto3" json:"order_sequence,omitempty"` + AccountsDenomsOrdersCounts []AccountDenomOrdersCount `protobuf:"bytes,5,rep,name=accounts_denoms_orders_counts,json=accountsDenomsOrdersCounts,proto3" json:"accounts_denoms_orders_counts"` } func (m *GenesisState) Reset() { *m = GenesisState{} } @@ -79,13 +81,20 @@ func (m *GenesisState) GetOrderBooks() []OrderBookDataWithID { return nil } -func (m *GenesisState) GetOrders() []OrderWithSequence { +func (m *GenesisState) GetOrders() []Order { if m != nil { return m.Orders } return nil } +func (m *GenesisState) GetOrderSequence() uint64 { + if m != nil { + return m.OrderSequence + } + return 0 +} + func (m *GenesisState) GetAccountsDenomsOrdersCounts() []AccountDenomOrdersCount { if m != nil { return m.AccountsDenomsOrdersCounts @@ -148,61 +157,6 @@ func (m *OrderBookDataWithID) GetData() OrderBookData { return OrderBookData{} } -// OrderWithSequence is a order with it's corresponding sequence. -type OrderWithSequence struct { - // sequence is order sequence. - Sequence uint64 `protobuf:"varint,1,opt,name=sequence,proto3" json:"sequence,omitempty"` - // data is order book data. - Order Order `protobuf:"bytes,2,opt,name=order,proto3" json:"order"` -} - -func (m *OrderWithSequence) Reset() { *m = OrderWithSequence{} } -func (m *OrderWithSequence) String() string { return proto.CompactTextString(m) } -func (*OrderWithSequence) ProtoMessage() {} -func (*OrderWithSequence) Descriptor() ([]byte, []int) { - return fileDescriptor_a9d24a0566883c25, []int{2} -} -func (m *OrderWithSequence) XXX_Unmarshal(b []byte) error { - return m.Unmarshal(b) -} -func (m *OrderWithSequence) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { - if deterministic { - return xxx_messageInfo_OrderWithSequence.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 *OrderWithSequence) XXX_Merge(src proto.Message) { - xxx_messageInfo_OrderWithSequence.Merge(m, src) -} -func (m *OrderWithSequence) XXX_Size() int { - return m.Size() -} -func (m *OrderWithSequence) XXX_DiscardUnknown() { - xxx_messageInfo_OrderWithSequence.DiscardUnknown(m) -} - -var xxx_messageInfo_OrderWithSequence proto.InternalMessageInfo - -func (m *OrderWithSequence) GetSequence() uint64 { - if m != nil { - return m.Sequence - } - return 0 -} - -func (m *OrderWithSequence) GetOrder() Order { - if m != nil { - return m.Order - } - return Order{} -} - // AccountDenomOrderCount is a count of orders per account and denom. type AccountDenomOrdersCount struct { AccountNumber uint64 `protobuf:"varint,1,opt,name=account_number,json=accountNumber,proto3" json:"account_number,omitempty"` @@ -214,7 +168,7 @@ func (m *AccountDenomOrdersCount) Reset() { *m = AccountDenomOrdersCount func (m *AccountDenomOrdersCount) String() string { return proto.CompactTextString(m) } func (*AccountDenomOrdersCount) ProtoMessage() {} func (*AccountDenomOrdersCount) Descriptor() ([]byte, []int) { - return fileDescriptor_a9d24a0566883c25, []int{3} + return fileDescriptor_a9d24a0566883c25, []int{2} } func (m *AccountDenomOrdersCount) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -267,43 +221,41 @@ func (m *AccountDenomOrdersCount) GetOrdersCount() uint64 { func init() { proto.RegisterType((*GenesisState)(nil), "coreum.dex.v1.GenesisState") proto.RegisterType((*OrderBookDataWithID)(nil), "coreum.dex.v1.OrderBookDataWithID") - proto.RegisterType((*OrderWithSequence)(nil), "coreum.dex.v1.OrderWithSequence") proto.RegisterType((*AccountDenomOrdersCount)(nil), "coreum.dex.v1.AccountDenomOrdersCount") } func init() { proto.RegisterFile("coreum/dex/v1/genesis.proto", fileDescriptor_a9d24a0566883c25) } var fileDescriptor_a9d24a0566883c25 = []byte{ - // 461 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x7c, 0x52, 0xcd, 0x6e, 0xd3, 0x40, - 0x10, 0x8e, 0x9d, 0x34, 0x82, 0x49, 0x83, 0xc4, 0x12, 0xc0, 0x18, 0x70, 0x83, 0x25, 0x50, 0x4f, - 0x36, 0x69, 0x05, 0x47, 0x24, 0xd2, 0x08, 0x14, 0x21, 0x01, 0x4a, 0x0f, 0x48, 0x5c, 0xac, 0x8d, - 0xbd, 0x4a, 0xad, 0xca, 0x9e, 0xe0, 0x5d, 0x47, 0xe9, 0x5b, 0xf0, 0x46, 0x5c, 0x7b, 0xec, 0x91, - 0x53, 0x85, 0x9c, 0x17, 0x41, 0x9e, 0xdd, 0xa0, 0x26, 0x04, 0x6e, 0x3b, 0x33, 0xdf, 0x8f, 0xe7, - 0xf3, 0xc0, 0xe3, 0x18, 0x0b, 0x51, 0x66, 0x61, 0x22, 0x96, 0xe1, 0x62, 0x10, 0xce, 0x44, 0x2e, - 0x64, 0x2a, 0x83, 0x79, 0x81, 0x0a, 0x59, 0x57, 0x0f, 0x83, 0x44, 0x2c, 0x83, 0xc5, 0xc0, 0x7d, - 0xb4, 0x89, 0xc5, 0x22, 0x11, 0x85, 0x46, 0xba, 0xee, 0xe6, 0x68, 0xce, 0x0b, 0x9e, 0x19, 0x15, - 0xb7, 0x37, 0xc3, 0x19, 0xd2, 0x33, 0xac, 0x5f, 0xba, 0xeb, 0xff, 0xb0, 0x61, 0xff, 0xbd, 0x76, - 0x3b, 0x55, 0x5c, 0x09, 0x76, 0x0c, 0x6d, 0x4d, 0x73, 0xac, 0xbe, 0x75, 0xd8, 0x39, 0xba, 0x1f, - 0x6c, 0xb8, 0x07, 0x9f, 0x69, 0x38, 0x6c, 0x5d, 0x5e, 0x1f, 0x34, 0x26, 0x06, 0xca, 0xc6, 0xd0, - 0xa1, 0xcf, 0x88, 0xa6, 0x88, 0xe7, 0xd2, 0xb1, 0xfb, 0xcd, 0xc3, 0xce, 0x91, 0xbf, 0xc5, 0xfc, - 0x54, 0x23, 0x86, 0x88, 0xe7, 0x23, 0xae, 0xf8, 0x97, 0x54, 0x9d, 0x8d, 0x47, 0x46, 0x06, 0x70, - 0x3d, 0x92, 0xec, 0x0d, 0xb4, 0xa9, 0x92, 0x4e, 0x93, 0x54, 0xfa, 0xbb, 0x54, 0x6a, 0xf6, 0xa9, - 0xf8, 0x56, 0x8a, 0x3c, 0x16, 0xeb, 0x4f, 0xd1, 0x2c, 0x86, 0xf0, 0x94, 0xc7, 0x31, 0x96, 0xb9, - 0x92, 0x51, 0x22, 0x72, 0xcc, 0x64, 0xa4, 0x27, 0x91, 0x6e, 0x3a, 0x2d, 0x92, 0x7d, 0xb1, 0x25, - 0xfb, 0x56, 0x73, 0x46, 0x35, 0x83, 0x2c, 0xe4, 0x49, 0x5d, 0x1b, 0x71, 0x77, 0x2d, 0x49, 0x73, - 0x79, 0x03, 0x20, 0x7d, 0x01, 0xf7, 0x76, 0x6c, 0xc6, 0x1e, 0x80, 0x9d, 0x26, 0x94, 0x61, 0x77, - 0xd8, 0xae, 0xae, 0x0f, 0xec, 0xf1, 0x68, 0x62, 0xa7, 0x09, 0x7b, 0x0d, 0xad, 0x84, 0x2b, 0xee, - 0xd8, 0x94, 0xee, 0x93, 0xff, 0x65, 0x64, 0xcc, 0x09, 0xef, 0x73, 0xb8, 0xfb, 0xd7, 0xea, 0xcc, - 0x85, 0x5b, 0xd2, 0xbc, 0xc9, 0xaa, 0x35, 0xf9, 0x53, 0xb3, 0x97, 0xb0, 0x47, 0x8b, 0x1b, 0xa7, - 0xde, 0x4e, 0x27, 0xed, 0xa0, 0x81, 0xfe, 0x05, 0x3c, 0xfc, 0x47, 0x0c, 0xec, 0x39, 0xdc, 0x31, - 0x11, 0x44, 0x79, 0x99, 0x4d, 0x45, 0x61, 0xec, 0xba, 0xa6, 0xfb, 0x91, 0x9a, 0xac, 0x07, 0x7b, - 0x94, 0x39, 0x79, 0xde, 0x9e, 0xe8, 0x82, 0x3d, 0x83, 0xfd, 0x9b, 0xbf, 0xc0, 0x69, 0x12, 0x55, - 0x5f, 0x8c, 0x89, 0xf9, 0xc3, 0x65, 0xe5, 0x59, 0x57, 0x95, 0x67, 0xfd, 0xaa, 0x3c, 0xeb, 0xfb, - 0xca, 0x6b, 0x5c, 0xad, 0xbc, 0xc6, 0xcf, 0x95, 0xd7, 0xf8, 0x3a, 0x98, 0xa5, 0xea, 0xac, 0x9c, - 0x06, 0x31, 0x66, 0xe1, 0x09, 0x6d, 0xf0, 0x0e, 0xcb, 0x3c, 0xe1, 0x2a, 0xc5, 0x3c, 0x34, 0xe7, - 0xbe, 0x78, 0x15, 0x2e, 0xe9, 0xe6, 0xd5, 0xc5, 0x5c, 0xc8, 0x69, 0x9b, 0x4e, 0xfb, 0xf8, 0x77, - 0x00, 0x00, 0x00, 0xff, 0xff, 0x9b, 0xb9, 0x67, 0xcf, 0x55, 0x03, 0x00, 0x00, + // 444 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x7c, 0x52, 0xc1, 0x6e, 0xd3, 0x40, + 0x10, 0x8d, 0x1d, 0x37, 0x12, 0x9b, 0x86, 0xc3, 0x12, 0xc0, 0x18, 0x70, 0x43, 0x24, 0x50, 0x4e, + 0xb6, 0x92, 0x0a, 0xee, 0xa4, 0x16, 0x28, 0x42, 0x02, 0xe4, 0x1e, 0x90, 0xb8, 0x58, 0x6b, 0xef, + 0xca, 0xb5, 0x2a, 0x7b, 0x82, 0x77, 0x1d, 0xa5, 0x7f, 0xc1, 0x67, 0xf5, 0xd8, 0x23, 0xe2, 0x50, + 0x21, 0xe7, 0x47, 0x90, 0x67, 0xb7, 0x52, 0x53, 0x15, 0x6e, 0x9e, 0x37, 0x6f, 0xde, 0x9b, 0x7d, + 0x1e, 0xf2, 0x3c, 0x83, 0x5a, 0x34, 0x65, 0xc8, 0xc5, 0x36, 0xdc, 0xcc, 0xc3, 0x5c, 0x54, 0x42, + 0x16, 0x32, 0x58, 0xd7, 0xa0, 0x80, 0x8e, 0x74, 0x33, 0xe0, 0x62, 0x1b, 0x6c, 0xe6, 0xde, 0xb3, + 0x7d, 0x2e, 0xd4, 0x5c, 0xd4, 0x9a, 0xe9, 0x79, 0xfb, 0xad, 0x35, 0xab, 0x59, 0x69, 0x54, 0xbc, + 0x71, 0x0e, 0x39, 0xe0, 0x67, 0xd8, 0x7d, 0x69, 0x74, 0xfa, 0xdb, 0x26, 0x87, 0x1f, 0xb5, 0xdb, + 0xa9, 0x62, 0x4a, 0xd0, 0x63, 0x32, 0xd0, 0x63, 0xae, 0x35, 0xb1, 0x66, 0xc3, 0xc5, 0xe3, 0x60, + 0xcf, 0x3d, 0xf8, 0x8a, 0xcd, 0xa5, 0x73, 0x79, 0x7d, 0xd4, 0x8b, 0x0d, 0x95, 0xae, 0xc8, 0x10, + 0xd7, 0x48, 0x52, 0x80, 0x73, 0xe9, 0xda, 0x93, 0xfe, 0x6c, 0xb8, 0x98, 0xde, 0x99, 0xfc, 0xd2, + 0x31, 0x96, 0x00, 0xe7, 0x11, 0x53, 0xec, 0x5b, 0xa1, 0xce, 0x56, 0x91, 0x91, 0x21, 0x70, 0xd3, + 0x92, 0x74, 0x41, 0x06, 0x58, 0x49, 0xb7, 0x8f, 0x2a, 0xe3, 0x7b, 0x55, 0x8c, 0xbd, 0x66, 0xd2, + 0xd7, 0xe4, 0xa1, 0xb6, 0x97, 0xe2, 0x47, 0x23, 0xaa, 0x4c, 0xb8, 0xce, 0xc4, 0x9a, 0x39, 0xf1, + 0x08, 0xd1, 0x53, 0x03, 0x52, 0x20, 0x2f, 0x59, 0x96, 0x41, 0x53, 0x29, 0x99, 0x70, 0x51, 0x41, + 0x29, 0x13, 0x2d, 0x90, 0x68, 0xd0, 0x3d, 0x40, 0xc7, 0x37, 0x77, 0x1c, 0xdf, 0xeb, 0x99, 0xa8, + 0x9b, 0x40, 0x77, 0x79, 0xd2, 0xd5, 0x66, 0x07, 0xef, 0x46, 0x12, 0xfb, 0xf2, 0x16, 0x41, 0x4e, + 0x05, 0x79, 0x74, 0xcf, 0xa3, 0xe9, 0x13, 0x62, 0x17, 0x1c, 0xe3, 0x1d, 0x2d, 0x07, 0xed, 0xf5, + 0x91, 0xbd, 0x8a, 0x62, 0xbb, 0xe0, 0xf4, 0x1d, 0x71, 0x38, 0x53, 0xcc, 0xb5, 0x31, 0xf8, 0x17, + 0xff, 0x8b, 0xcf, 0x98, 0x23, 0x7f, 0x7a, 0x41, 0x9e, 0xfe, 0x63, 0xc7, 0x2e, 0x19, 0xb3, 0x5f, + 0x52, 0x35, 0x65, 0x2a, 0x6a, 0xb4, 0x75, 0xe2, 0x91, 0x41, 0x3f, 0x23, 0x48, 0xc7, 0xe4, 0x00, + 0x03, 0x41, 0xeb, 0x07, 0xb1, 0x2e, 0xe8, 0x2b, 0x72, 0x78, 0x3b, 0x1f, 0xb7, 0x8f, 0xa3, 0xfa, + 0x4f, 0x9b, 0x0c, 0x3e, 0x5d, 0xb6, 0xbe, 0x75, 0xd5, 0xfa, 0xd6, 0x9f, 0xd6, 0xb7, 0x7e, 0xee, + 0xfc, 0xde, 0xd5, 0xce, 0xef, 0xfd, 0xda, 0xf9, 0xbd, 0xef, 0xf3, 0xbc, 0x50, 0x67, 0x4d, 0x1a, + 0x64, 0x50, 0x86, 0x27, 0xf8, 0x90, 0x0f, 0xd0, 0x54, 0x9c, 0xa9, 0x02, 0xaa, 0xd0, 0x9c, 0xe9, + 0xe6, 0x6d, 0xb8, 0xc5, 0x5b, 0x55, 0x17, 0x6b, 0x21, 0xd3, 0x01, 0x9e, 0xe4, 0xf1, 0xdf, 0x00, + 0x00, 0x00, 0xff, 0xff, 0x7b, 0xfd, 0x20, 0x4e, 0x0d, 0x03, 0x00, 0x00, } func (m *GenesisState) Marshal() (dAtA []byte, err error) { @@ -337,9 +289,14 @@ func (m *GenesisState) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintGenesis(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x22 + dAtA[i] = 0x2a } } + if m.OrderSequence != 0 { + i = encodeVarintGenesis(dAtA, i, uint64(m.OrderSequence)) + i-- + dAtA[i] = 0x20 + } if len(m.Orders) > 0 { for iNdEx := len(m.Orders) - 1; iNdEx >= 0; iNdEx-- { { @@ -419,44 +376,6 @@ func (m *OrderBookDataWithID) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } -func (m *OrderWithSequence) 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 *OrderWithSequence) MarshalTo(dAtA []byte) (int, error) { - size := m.Size() - return m.MarshalToSizedBuffer(dAtA[:size]) -} - -func (m *OrderWithSequence) MarshalToSizedBuffer(dAtA []byte) (int, error) { - i := len(dAtA) - _ = i - var l int - _ = l - { - size, err := m.Order.MarshalToSizedBuffer(dAtA[:i]) - if err != nil { - return 0, err - } - i -= size - i = encodeVarintGenesis(dAtA, i, uint64(size)) - } - i-- - dAtA[i] = 0x12 - if m.Sequence != 0 { - i = encodeVarintGenesis(dAtA, i, uint64(m.Sequence)) - i-- - dAtA[i] = 0x8 - } - return len(dAtA) - i, nil -} - func (m *AccountDenomOrdersCount) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) @@ -528,6 +447,9 @@ func (m *GenesisState) Size() (n int) { n += 1 + l + sovGenesis(uint64(l)) } } + if m.OrderSequence != 0 { + n += 1 + sovGenesis(uint64(m.OrderSequence)) + } if len(m.AccountsDenomsOrdersCounts) > 0 { for _, e := range m.AccountsDenomsOrdersCounts { l = e.Size() @@ -551,20 +473,6 @@ func (m *OrderBookDataWithID) Size() (n int) { return n } -func (m *OrderWithSequence) Size() (n int) { - if m == nil { - return 0 - } - var l int - _ = l - if m.Sequence != 0 { - n += 1 + sovGenesis(uint64(m.Sequence)) - } - l = m.Order.Size() - n += 1 + l + sovGenesis(uint64(l)) - return n -} - func (m *AccountDenomOrdersCount) Size() (n int) { if m == nil { return 0 @@ -715,100 +623,16 @@ func (m *GenesisState) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - m.Orders = append(m.Orders, OrderWithSequence{}) + 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 AccountsDenomsOrdersCounts", 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.AccountsDenomsOrdersCounts = append(m.AccountsDenomsOrdersCounts, AccountDenomOrdersCount{}) - if err := m.AccountsDenomsOrdersCounts[len(m.AccountsDenomsOrdersCounts)-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 (m *OrderBookDataWithID) 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: OrderBookDataWithID: wiretype end group for non-group") - } - if fieldNum <= 0 { - return fmt.Errorf("proto: OrderBookDataWithID: 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) + return fmt.Errorf("proto: wrong wireType = %d for field OrderSequence", wireType) } - m.ID = 0 + m.OrderSequence = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowGenesis @@ -818,14 +642,14 @@ func (m *OrderBookDataWithID) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.ID |= uint32(b&0x7F) << shift + m.OrderSequence |= uint64(b&0x7F) << shift if b < 0x80 { break } } - case 2: + case 5: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Data", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field AccountsDenomsOrdersCounts", wireType) } var msglen int for shift := uint(0); ; shift += 7 { @@ -852,7 +676,8 @@ func (m *OrderBookDataWithID) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.Data.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + m.AccountsDenomsOrdersCounts = append(m.AccountsDenomsOrdersCounts, AccountDenomOrdersCount{}) + if err := m.AccountsDenomsOrdersCounts[len(m.AccountsDenomsOrdersCounts)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err } iNdEx = postIndex @@ -877,7 +702,7 @@ func (m *OrderBookDataWithID) Unmarshal(dAtA []byte) error { } return nil } -func (m *OrderWithSequence) Unmarshal(dAtA []byte) error { +func (m *OrderBookDataWithID) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 for iNdEx < l { @@ -900,17 +725,17 @@ func (m *OrderWithSequence) Unmarshal(dAtA []byte) error { fieldNum := int32(wire >> 3) wireType := int(wire & 0x7) if wireType == 4 { - return fmt.Errorf("proto: OrderWithSequence: wiretype end group for non-group") + return fmt.Errorf("proto: OrderBookDataWithID: wiretype end group for non-group") } if fieldNum <= 0 { - return fmt.Errorf("proto: OrderWithSequence: illegal tag %d (wire type %d)", fieldNum, wire) + return fmt.Errorf("proto: OrderBookDataWithID: illegal tag %d (wire type %d)", fieldNum, wire) } switch fieldNum { case 1: if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field Sequence", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field ID", wireType) } - m.Sequence = 0 + m.ID = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowGenesis @@ -920,14 +745,14 @@ func (m *OrderWithSequence) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.Sequence |= uint64(b&0x7F) << shift + m.ID |= uint32(b&0x7F) << shift if b < 0x80 { break } } case 2: if wireType != 2 { - return fmt.Errorf("proto: wrong wireType = %d for field Order", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field Data", wireType) } var msglen int for shift := uint(0); ; shift += 7 { @@ -954,7 +779,7 @@ func (m *OrderWithSequence) Unmarshal(dAtA []byte) error { if postIndex > l { return io.ErrUnexpectedEOF } - if err := m.Order.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + if err := m.Data.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { return err } iNdEx = postIndex diff --git a/x/dex/types/keys.go b/x/dex/types/keys.go index 2e50fcfa8..e338ae2f3 100644 --- a/x/dex/types/keys.go +++ b/x/dex/types/keys.go @@ -21,24 +21,24 @@ const ( var ( // OrderBookKeyPrefix defines the key prefix for the order book. OrderBookKeyPrefix = []byte{0x01} - // OrderBookSeqKey defines the key for the order book sequence. - OrderBookSeqKey = []byte{0x02} + // OrderBookSequenceKey defines the key for the order book sequence. + OrderBookSequenceKey = []byte{0x02} // OrderBookDataKeyPrefix defines the key prefix for the order book data. OrderBookDataKeyPrefix = []byte{0x03} - // OrderSeqKey defines the key for the order sequence. - OrderSeqKey = []byte{0x04} + // OrderSequenceKey defines the key for the order sequence. + OrderSequenceKey = []byte{0x04} // OrderKeyPrefix defines the key prefix for the order. OrderKeyPrefix = []byte{0x05} - // OrderIDToSeqKeyPrefix defines the key prefix for the order ID to sequence. - OrderIDToSeqKeyPrefix = []byte{0x06} + // OrderIDToSequenceKeyPrefix defines the key prefix for the order ID to sequence. + OrderIDToSequenceKeyPrefix = []byte{0x06} // OrderBookRecordKeyPrefix defines the key prefix for the order book record. OrderBookRecordKeyPrefix = []byte{0x07} // ParamsKey defines the key to store parameters of the module, set via governance. - ParamsKey = []byte{0x09} + ParamsKey = []byte{0x08} // AccountDenomOrdersCountKeyPrefix defines the key prefix for the account denom orders count. - AccountDenomOrdersCountKeyPrefix = []byte{0x10} - // AccountDenomOrderSeqKeyPrefix defines the key prefix for the account denom order seq. - AccountDenomOrderSeqKeyPrefix = []byte{0x11} + AccountDenomOrdersCountKeyPrefix = []byte{0x09} + // AccountDenomOrderSequenceKeyPrefix defines the key prefix for the account denom order sequence. + AccountDenomOrderSequenceKeyPrefix = []byte{0x10} ) // CreateOrderBookKey creates order book key. @@ -74,26 +74,26 @@ func DecodeOrderBookDataKey(key []byte) (uint32, error) { } // CreateOrderKey creates order key. -func CreateOrderKey(orderSeq uint64) []byte { +func CreateOrderKey(orderSequence uint64) []byte { key := make([]byte, 0) - key = store.AppendUint64ToOrderedBytes(key, orderSeq) + key = store.AppendUint64ToOrderedBytes(key, orderSequence) return store.JoinKeys(OrderKeyPrefix, key) } -// CreateOrderIDToSeqKey creates order ID to sequence key. -func CreateOrderIDToSeqKey(accountNumber uint64, orderID string) []byte { - return store.JoinKeys(CreateOrderIDToSeqKeyPrefix(accountNumber), []byte(orderID)) +// CreateOrderIDToSequenceKey creates order ID to sequence key. +func CreateOrderIDToSequenceKey(accountNumber uint64, orderID string) []byte { + return store.JoinKeys(CreateOrderIDToSequenceKeyPrefix(accountNumber), []byte(orderID)) } -// CreateOrderIDToSeqKeyPrefix creates order ID to sequence key prefix. -func CreateOrderIDToSeqKeyPrefix(accountNumber uint64) []byte { +// CreateOrderIDToSequenceKeyPrefix creates order ID to sequence key prefix. +func CreateOrderIDToSequenceKeyPrefix(accountNumber uint64) []byte { key := make([]byte, 0) key = store.AppendUint64ToOrderedBytes(key, accountNumber) - return store.JoinKeys(OrderIDToSeqKeyPrefix, key) + return store.JoinKeys(OrderIDToSequenceKeyPrefix, key) } -// DecodeOrderIDToSeqKey decodes order ID to sequence key and returns the account number and order ID. -func DecodeOrderIDToSeqKey(key []byte) (uint64, string, error) { +// DecodeOrderIDToSequenceKey decodes order ID to sequence key and returns the account number and order ID. +func DecodeOrderIDToSequenceKey(key []byte) (uint64, string, error) { accNumber, orderID, err := store.ReadOrderedBytesToUint64(key) if err != nil { return 0, "", err @@ -104,10 +104,10 @@ func DecodeOrderIDToSeqKey(key []byte) (uint64, string, error) { // CreateOrderBookRecordKey creates order book key record with fixed key length to support the correct ordering // and be able to decode the key into the values. -func CreateOrderBookRecordKey(orderBookID uint32, side Side, price Price, orderSeq uint64) ([]byte, error) { +func CreateOrderBookRecordKey(orderBookID uint32, side Side, price Price, orderSequence uint64) ([]byte, error) { key := CreateOrderBookSideKey(orderBookID, side) var err error - key, err = CreateOrderBookSideRecordKey(key, price, orderSeq) + key, err = CreateOrderBookSideRecordKey(key, price, orderSequence) if err != nil { return nil, err } @@ -116,13 +116,13 @@ func CreateOrderBookRecordKey(orderBookID uint32, side Side, price Price, orderS } // CreateOrderBookSideRecordKey creates order book side record key. -func CreateOrderBookSideRecordKey(key []byte, price Price, orderSeq uint64) ([]byte, error) { +func CreateOrderBookSideRecordKey(key []byte, price Price, orderSequence uint64) ([]byte, error) { priceKey, err := price.MarshallToOrderedBytes() if err != nil { return nil, err } key = store.JoinKeys(key, priceKey) - key = store.AppendUint64ToOrderedBytes(key, orderSeq) + key = store.AppendUint64ToOrderedBytes(key, orderSequence) return key, nil } @@ -134,12 +134,12 @@ func DecodeOrderBookSideRecordKey(key []byte) (Price, uint64, error) { if err != nil { return Price{}, 0, err } - orderSeq, _, err := store.ReadOrderedBytesToUint64(nextKeyPart) + orderSequence, _, err := store.ReadOrderedBytesToUint64(nextKeyPart) if err != nil { return Price{}, 0, err } - return p, orderSeq, nil + return p, orderSequence, nil } // CreateOrderBookSideKey creates order book side key. @@ -152,15 +152,15 @@ func CreateOrderBookSideKey(orderBookID uint32, side Side) []byte { } // BuildGoodTilBlockHeightDelayKey builds the key for the good til block height delay store. -func BuildGoodTilBlockHeightDelayKey(orderSeq uint64) string { +func BuildGoodTilBlockHeightDelayKey(orderSequence uint64) string { // the string will be store the delay store and must be unique for the app - return fmt.Sprintf("%stlh%d", ModuleName, orderSeq) + return fmt.Sprintf("%stlh%d", ModuleName, orderSequence) } // BuildGoodTilBlockTimeDelayKey builds the key for the good til block time delay store. -func BuildGoodTilBlockTimeDelayKey(orderSeq uint64) string { +func BuildGoodTilBlockTimeDelayKey(orderSequence uint64) string { // the string will be store the delay store and must be unique for the app - return fmt.Sprintf("%stlt%d", ModuleName, orderSeq) + return fmt.Sprintf("%stlt%d", ModuleName, orderSequence) } // CreateAccountDenomOrdersCountKey creates account denom orders count key. @@ -193,13 +193,13 @@ func DecodeAccountDenomOrdersCountKey(key []byte) (uint64, string, error) { return accNumber, denom, nil } -// CreateAccountDenomOrderSeqKey creates account denom order seq key. -func CreateAccountDenomOrderSeqKey(accNumber uint64, denom string, orderSeq uint64) ([]byte, error) { +// CreateAccountDenomOrderSequenceKey creates account denom order sequence key. +func CreateAccountDenomOrderSequenceKey(accNumber uint64, denom string, orderSequence uint64) ([]byte, error) { key, err := CreateAccountDenomKeyPrefix(accNumber, denom) if err != nil { return nil, err } - key = store.AppendUint64ToOrderedBytes(key, orderSeq) + key = store.AppendUint64ToOrderedBytes(key, orderSequence) return key, nil } @@ -212,15 +212,15 @@ func CreateAccountDenomKeyPrefix(accNumber uint64, denom string) ([]byte, error) if err != nil { return key, err } - return store.JoinKeys(AccountDenomOrderSeqKeyPrefix, key, denomKey), nil + return store.JoinKeys(AccountDenomOrderSequenceKeyPrefix, key, denomKey), nil } -// DecodeAccountDenomKeyOrderSeq decodes the order seq from account denom key. -func DecodeAccountDenomKeyOrderSeq(key []byte) (uint64, error) { - orderSeq, _, err := store.ReadOrderedBytesToUint64(key) +// DecodeAccountDenomKeyOrderSequence decodes the order sequence from account denom key. +func DecodeAccountDenomKeyOrderSequence(key []byte) (uint64, error) { + orderSequence, _, err := store.ReadOrderedBytesToUint64(key) if err != nil { return 0, err } - return orderSeq, nil + return orderSequence, nil } diff --git a/x/dex/types/order.go b/x/dex/types/order.go index a4f1af715..73433d808 100644 --- a/x/dex/types/order.go +++ b/x/dex/types/order.go @@ -88,6 +88,10 @@ func (o Order) Validate() error { return err } + if o.Sequence != 0 { + return sdkerrors.Wrap(ErrInvalidInput, "order sequence must be zero") + } + if o.BaseDenom == "" { return sdkerrors.Wrap(ErrInvalidInput, "base denom can't be empty") } @@ -212,16 +216,6 @@ func (o Order) Denoms() []string { return []string{o.BaseDenom, o.QuoteDenom} } -// IsTaker returns true if record is taker record (based on sequence). -func (r OrderBookRecord) IsTaker() bool { - return r.OrderSeq == 0 -} - -// IsMaker returns true if record is maker record (based on sequence). -func (r OrderBookRecord) IsMaker() bool { - return r.OrderSeq > 0 -} - // ComputeLimitOrderLockedBalance computes the limit order locked balance. func ComputeLimitOrderLockedBalance( side Side, baseDenom, quoteDenom string, quantity sdkmath.Int, price Price, diff --git a/x/dex/types/order.pb.go b/x/dex/types/order.pb.go index 6af0ec6a3..325062353 100644 --- a/x/dex/types/order.pb.go +++ b/x/dex/types/order.pb.go @@ -176,8 +176,8 @@ var xxx_messageInfo_GoodTil proto.InternalMessageInfo type CancelGoodTil struct { // creator is order creator address. Creator string `protobuf:"bytes,1,opt,name=creator,proto3" json:"creator,omitempty"` - // order_seq is order sequence. - OrderSeq uint64 `protobuf:"varint,2,opt,name=order_seq,json=orderSeq,proto3" json:"order_seq,omitempty"` + // order_sequence is order sequence. + OrderSequence uint64 `protobuf:"varint,2,opt,name=order_sequence,json=orderSequence,proto3" json:"order_sequence,omitempty"` } func (m *CancelGoodTil) Reset() { *m = CancelGoodTil{} } @@ -221,26 +221,28 @@ type Order struct { Type OrderType `protobuf:"varint,2,opt,name=type,proto3,enum=coreum.dex.v1.OrderType" json:"type,omitempty"` // id is unique order ID. ID string `protobuf:"bytes,3,opt,name=id,proto3" json:"id,omitempty"` + // sequence is unique order sequence generated at the time of the order placement. + Sequence uint64 `protobuf:"varint,4,opt,name=sequence,proto3" json:"sequence,omitempty"` // base_denom is base order denom. - BaseDenom string `protobuf:"bytes,4,opt,name=base_denom,json=baseDenom,proto3" json:"base_denom,omitempty"` + BaseDenom string `protobuf:"bytes,5,opt,name=base_denom,json=baseDenom,proto3" json:"base_denom,omitempty"` // quote_denom is quote order denom - QuoteDenom string `protobuf:"bytes,5,opt,name=quote_denom,json=quoteDenom,proto3" json:"quote_denom,omitempty"` + QuoteDenom string `protobuf:"bytes,6,opt,name=quote_denom,json=quoteDenom,proto3" json:"quote_denom,omitempty"` // price is value of one unit of the base_denom expressed in terms of the quote_denom. - Price *Price `protobuf:"bytes,6,opt,name=price,proto3,customtype=Price" json:"price,omitempty"` + Price *Price `protobuf:"bytes,7,opt,name=price,proto3,customtype=Price" json:"price,omitempty"` // quantity is amount of the base base_denom being traded. - Quantity cosmossdk_io_math.Int `protobuf:"bytes,7,opt,name=quantity,proto3,customtype=cosmossdk.io/math.Int" json:"quantity"` + Quantity cosmossdk_io_math.Int `protobuf:"bytes,8,opt,name=quantity,proto3,customtype=cosmossdk.io/math.Int" json:"quantity"` // side is order side. - Side Side `protobuf:"varint,8,opt,name=side,proto3,enum=coreum.dex.v1.Side" json:"side,omitempty"` + Side Side `protobuf:"varint,9,opt,name=side,proto3,enum=coreum.dex.v1.Side" json:"side,omitempty"` // remaining_quantity is remaining filling quantity sell/buy. - RemainingQuantity cosmossdk_io_math.Int `protobuf:"bytes,9,opt,name=remaining_quantity,json=remainingQuantity,proto3,customtype=cosmossdk.io/math.Int" json:"remaining_quantity"` + RemainingQuantity cosmossdk_io_math.Int `protobuf:"bytes,10,opt,name=remaining_quantity,json=remainingQuantity,proto3,customtype=cosmossdk.io/math.Int" json:"remaining_quantity"` // remaining_balance is remaining order balance. - RemainingBalance cosmossdk_io_math.Int `protobuf:"bytes,10,opt,name=remaining_balance,json=remainingBalance,proto3,customtype=cosmossdk.io/math.Int" json:"remaining_balance"` + RemainingBalance cosmossdk_io_math.Int `protobuf:"bytes,11,opt,name=remaining_balance,json=remainingBalance,proto3,customtype=cosmossdk.io/math.Int" json:"remaining_balance"` // good_til is order good til - GoodTil *GoodTil `protobuf:"bytes,11,opt,name=good_til,json=goodTil,proto3" json:"good_til,omitempty"` + GoodTil *GoodTil `protobuf:"bytes,12,opt,name=good_til,json=goodTil,proto3" json:"good_til,omitempty"` // time_in_force is order time in force - TimeInForce TimeInForce `protobuf:"varint,12,opt,name=time_in_force,json=timeInForce,proto3,enum=coreum.dex.v1.TimeInForce" json:"time_in_force,omitempty"` + TimeInForce TimeInForce `protobuf:"varint,13,opt,name=time_in_force,json=timeInForce,proto3,enum=coreum.dex.v1.TimeInForce" json:"time_in_force,omitempty"` // reserve is the reserve required to save the order in the order book - Reserve github_com_cosmos_cosmos_sdk_types.Coin `protobuf:"bytes,13,opt,name=reserve,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Coin" json:"reserve"` + Reserve github_com_cosmos_cosmos_sdk_types.Coin `protobuf:"bytes,14,opt,name=reserve,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Coin" json:"reserve"` } func (m *Order) Reset() { *m = Order{} } @@ -376,8 +378,8 @@ type OrderBookRecord struct { Side Side `protobuf:"varint,2,opt,name=side,proto3,enum=coreum.dex.v1.Side" json:"side,omitempty"` // price is order book record price. Price Price `protobuf:"bytes,3,opt,name=price,proto3,customtype=Price" json:"price"` - // order_seq is order sequence. - OrderSeq uint64 `protobuf:"varint,4,opt,name=order_seq,json=orderSeq,proto3" json:"order_seq,omitempty"` + // order_sequence is order sequence. + OrderSequence uint64 `protobuf:"varint,4,opt,name=order_sequence,json=orderSequence,proto3" json:"order_sequence,omitempty"` // order ID provided by the creator. OrderID string `protobuf:"bytes,5,opt,name=order_id,json=orderId,proto3" json:"order_id,omitempty"` // account_number is account number which corresponds the order creator. @@ -482,70 +484,71 @@ func init() { func init() { proto.RegisterFile("coreum/dex/v1/order.proto", fileDescriptor_302bb6c9a553771c) } var fileDescriptor_302bb6c9a553771c = []byte{ - // 995 bytes of a gzipped FileDescriptorProto + // 1011 bytes of a gzipped FileDescriptorProto 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x56, 0xcb, 0x6e, 0xdb, 0x46, - 0x14, 0x15, 0x65, 0xca, 0x92, 0xae, 0xc2, 0x84, 0x1e, 0x3f, 0x40, 0xab, 0xb0, 0x14, 0xa8, 0x68, - 0x13, 0x04, 0x2d, 0x09, 0x25, 0xe8, 0xa2, 0x9b, 0x16, 0xa5, 0x1e, 0x29, 0x1b, 0xdb, 0x72, 0x47, - 0xca, 0x22, 0xd9, 0x10, 0x14, 0x39, 0x91, 0x09, 0x49, 0x1c, 0x99, 0xa4, 0x54, 0xfb, 0x0f, 0x8a, - 0x02, 0x05, 0xb2, 0xee, 0xa6, 0x8b, 0xfe, 0x8c, 0x97, 0x59, 0x16, 0x59, 0xa8, 0xad, 0xfc, 0x1f, - 0x45, 0x31, 0x43, 0x52, 0x91, 0x94, 0x26, 0x56, 0x8d, 0x74, 0x65, 0xcd, 0xb9, 0xaf, 0x99, 0x7b, - 0xce, 0xbd, 0x26, 0xec, 0xdb, 0xd4, 0x27, 0xe3, 0xa1, 0xe6, 0x90, 0x73, 0x6d, 0x52, 0xd5, 0xa8, - 0xef, 0x10, 0x5f, 0x1d, 0xf9, 0x34, 0xa4, 0x48, 0x8a, 0x4c, 0xaa, 0x43, 0xce, 0xd5, 0x49, 0xb5, - 0x58, 0xb2, 0x69, 0x30, 0xa4, 0x81, 0xd6, 0xb5, 0x02, 0xa2, 0x4d, 0xaa, 0x5d, 0x12, 0x5a, 0x55, - 0xcd, 0xa6, 0xae, 0x17, 0xb9, 0x17, 0x77, 0x7a, 0xb4, 0x47, 0xf9, 0x4f, 0x8d, 0xfd, 0x8a, 0xd1, - 0x72, 0x8f, 0xd2, 0xde, 0x80, 0x68, 0xfc, 0xd4, 0x1d, 0xbf, 0xd0, 0x42, 0x77, 0x48, 0x82, 0xd0, - 0x1a, 0x8e, 0x22, 0x87, 0xca, 0xcf, 0x02, 0x64, 0x1f, 0x53, 0xea, 0x74, 0xdc, 0x01, 0xaa, 0xc2, - 0x6e, 0x8f, 0x52, 0xc7, 0x0c, 0xdd, 0x81, 0xd9, 0x1d, 0x50, 0xbb, 0x6f, 0x9e, 0x12, 0xb7, 0x77, - 0x1a, 0x2a, 0xc2, 0x5d, 0xe1, 0xbe, 0x88, 0x51, 0x2f, 0xf2, 0xd3, 0x99, 0xe9, 0x5b, 0x6e, 0x41, - 0x2d, 0xd8, 0x5e, 0x09, 0x61, 0x05, 0x94, 0xf4, 0x5d, 0xe1, 0x7e, 0xe1, 0x61, 0x51, 0x8d, 0xaa, - 0xab, 0x49, 0x75, 0xb5, 0x93, 0x54, 0xd7, 0xc5, 0x97, 0x7f, 0x94, 0x05, 0x2c, 0x2f, 0xa6, 0x64, - 0xc6, 0x4a, 0x13, 0xa4, 0x9a, 0xe5, 0xd9, 0x64, 0x90, 0x5c, 0x4a, 0x81, 0xac, 0xed, 0x13, 0x2b, - 0xa4, 0x3e, 0xbf, 0x46, 0x1e, 0x27, 0x47, 0xf4, 0x11, 0xe4, 0x79, 0xbf, 0xcc, 0x80, 0x9c, 0xf1, - 0x8a, 0x22, 0xce, 0x71, 0xa0, 0x4d, 0xce, 0x2a, 0xbf, 0x66, 0x20, 0xd3, 0x62, 0x87, 0xf7, 0x24, - 0xf8, 0x0c, 0xc4, 0xf0, 0x62, 0x14, 0xdd, 0xf6, 0xf6, 0x43, 0x45, 0x5d, 0x6a, 0xb8, 0xca, 0xa3, - 0x3b, 0x17, 0x23, 0x82, 0xb9, 0x17, 0xda, 0x83, 0xb4, 0xeb, 0x28, 0x1b, 0x2c, 0x85, 0xbe, 0x39, - 0x9b, 0x96, 0xd3, 0x46, 0x1d, 0xa7, 0x5d, 0x07, 0x1d, 0x00, 0x30, 0x4e, 0x4c, 0x87, 0x78, 0x74, - 0xa8, 0x88, 0xbc, 0x44, 0x9e, 0x21, 0x75, 0x06, 0xa0, 0x32, 0x14, 0xce, 0xc6, 0x34, 0x4c, 0xec, - 0x19, 0x6e, 0x07, 0x0e, 0x25, 0x0e, 0x99, 0x91, 0xef, 0xda, 0x44, 0xd9, 0xe4, 0xa9, 0xf3, 0xaf, - 0xa7, 0xe5, 0xcc, 0x09, 0x03, 0x70, 0x84, 0xa3, 0x2f, 0x21, 0x77, 0x36, 0xb6, 0xbc, 0xd0, 0x0d, - 0x2f, 0x94, 0x2c, 0xf7, 0x39, 0xb8, 0x9c, 0x96, 0x53, 0xaf, 0xa7, 0xe5, 0xdd, 0x48, 0x13, 0x81, - 0xd3, 0x57, 0x5d, 0xaa, 0x0d, 0xad, 0xf0, 0x54, 0x35, 0xbc, 0x10, 0xcf, 0xdd, 0xd1, 0x3d, 0x10, - 0x03, 0xd7, 0x21, 0x4a, 0x8e, 0xbf, 0x70, 0x7b, 0xe5, 0x85, 0x6d, 0xd7, 0x21, 0x98, 0x3b, 0xa0, - 0x43, 0x40, 0x3e, 0x19, 0x5a, 0xae, 0xe7, 0x7a, 0x3d, 0x73, 0x5e, 0x2d, 0xbf, 0x4e, 0xb5, 0xad, - 0x79, 0xe0, 0xf7, 0x49, 0xd9, 0xef, 0xe0, 0x0d, 0x68, 0x76, 0xad, 0x01, 0x23, 0x54, 0x81, 0x75, - 0x92, 0xc9, 0xf3, 0x38, 0x3d, 0x0a, 0x43, 0x55, 0xc8, 0x25, 0x0a, 0x53, 0x0a, 0x5c, 0x56, 0x7b, - 0x2b, 0xcf, 0x88, 0x95, 0x82, 0xb3, 0xb1, 0x98, 0xd0, 0x57, 0x20, 0x31, 0x15, 0x9a, 0xae, 0x67, - 0xbe, 0xa0, 0xbe, 0x4d, 0x94, 0x5b, 0xfc, 0xf9, 0xc5, 0x95, 0x38, 0xa6, 0x37, 0xc3, 0x6b, 0x32, - 0x0f, 0x5c, 0x08, 0xdf, 0x1c, 0x90, 0x03, 0x59, 0x9f, 0x04, 0xc4, 0x9f, 0x10, 0x45, 0xe2, 0x15, - 0xf7, 0xd5, 0xe8, 0xb6, 0x2a, 0xa3, 0x55, 0x8d, 0x87, 0x4f, 0xad, 0x51, 0xd7, 0xd3, 0xb5, 0xf8, - 0x3d, 0xf7, 0x7a, 0x6e, 0x78, 0x3a, 0xee, 0xaa, 0x36, 0x1d, 0x6a, 0xf1, 0xa4, 0x46, 0x7f, 0x3e, - 0x0f, 0x9c, 0xbe, 0xc6, 0x04, 0x14, 0xf0, 0x00, 0x9c, 0xa4, 0xae, 0xfc, 0xb4, 0x01, 0x79, 0xae, - 0xb1, 0xba, 0x15, 0x5a, 0xe8, 0x53, 0x88, 0xb4, 0x6b, 0xba, 0x4e, 0x24, 0x53, 0xbd, 0x30, 0x9b, - 0x96, 0xb3, 0xdc, 0xc1, 0xa8, 0xe3, 0x2c, 0x37, 0x1a, 0x0e, 0x7a, 0x04, 0x52, 0xe4, 0xd7, 0xa5, - 0xb4, 0xcf, 0x9c, 0x99, 0x78, 0x25, 0xfd, 0xce, 0x6c, 0x5a, 0x2e, 0x70, 0x67, 0x9d, 0xd2, 0xbe, - 0x51, 0xc7, 0x05, 0x3a, 0x3f, 0x38, 0xe8, 0xe3, 0x44, 0x62, 0x91, 0x7a, 0xa5, 0xf8, 0xce, 0xef, - 0x96, 0x99, 0x78, 0x33, 0x99, 0x65, 0xae, 0x93, 0xd9, 0x22, 0x99, 0x9b, 0xeb, 0x91, 0xb9, 0x40, - 0x46, 0xf6, 0xff, 0x23, 0xa3, 0x05, 0xd2, 0xbc, 0x7b, 0x9c, 0x8f, 0xe5, 0xa9, 0x16, 0xae, 0x99, - 0xea, 0xf4, 0xea, 0x54, 0x57, 0x7e, 0xd9, 0x80, 0x3b, 0xf3, 0x8c, 0x98, 0xd8, 0xd4, 0xff, 0x17, - 0xee, 0x84, 0x35, 0xb8, 0x4b, 0x7a, 0x9b, 0xbe, 0xae, 0xb7, 0x6b, 0x91, 0xbc, 0xb4, 0x33, 0xc5, - 0xe5, 0x9d, 0xb9, 0xa4, 0xc1, 0xcc, 0x7b, 0x34, 0xf8, 0x09, 0xdc, 0xb6, 0x6c, 0x9b, 0x8e, 0xbd, - 0xd0, 0xf4, 0xc6, 0xc3, 0x2e, 0xf1, 0x39, 0x97, 0x22, 0x96, 0x62, 0xf4, 0x98, 0x83, 0xef, 0xd8, - 0x29, 0xd9, 0x0f, 0xb9, 0x53, 0x72, 0x37, 0xda, 0x29, 0x95, 0xbf, 0x05, 0xd8, 0x5e, 0x21, 0xe7, - 0x3f, 0x0d, 0xe1, 0xdb, 0x0d, 0x48, 0xaf, 0xdf, 0x80, 0x8d, 0x0f, 0xd9, 0x00, 0xf1, 0x46, 0x0d, - 0x78, 0xf0, 0x35, 0x88, 0x4c, 0x39, 0x68, 0x07, 0xe4, 0xb6, 0x51, 0x6f, 0x98, 0x4f, 0x8f, 0xdb, - 0x27, 0x8d, 0x9a, 0xd1, 0x34, 0x1a, 0x75, 0x39, 0x85, 0x6e, 0x41, 0x8e, 0xa3, 0xfa, 0xd3, 0x67, - 0xb2, 0x80, 0x24, 0xc8, 0xf3, 0x53, 0xbb, 0x71, 0x78, 0x28, 0xa7, 0x8b, 0xe2, 0x8f, 0xbf, 0x95, - 0x52, 0x0f, 0x9e, 0xc7, 0xbb, 0x8b, 0xfd, 0x7f, 0x44, 0x45, 0xd8, 0x6b, 0xe1, 0x7a, 0x03, 0x9b, - 0x9d, 0x67, 0x27, 0xab, 0xb9, 0x76, 0x40, 0x5e, 0xb0, 0x1d, 0x1a, 0x47, 0x46, 0x47, 0x16, 0xd0, - 0x2e, 0x6c, 0x2d, 0xa0, 0x47, 0xdf, 0xe0, 0x27, 0x8d, 0xce, 0x3c, 0xf7, 0x0f, 0x50, 0x58, 0x58, - 0xcd, 0xe8, 0x00, 0xf6, 0x3b, 0xc6, 0x51, 0xc3, 0x34, 0x8e, 0xcd, 0x66, 0x0b, 0xd7, 0x56, 0x0b, - 0xec, 0xc2, 0xd6, 0xb2, 0xf9, 0x71, 0xa7, 0x16, 0x55, 0x58, 0x86, 0x8d, 0x56, 0x4d, 0x4e, 0xbf, - 0x0d, 0x37, 0x5b, 0x4f, 0xe4, 0x8d, 0xa8, 0xb0, 0xde, 0xba, 0xfc, 0xab, 0x94, 0xba, 0x9c, 0x95, - 0x84, 0x57, 0xb3, 0x92, 0xf0, 0xe7, 0xac, 0x24, 0xbc, 0xbc, 0x2a, 0xa5, 0x5e, 0x5d, 0x95, 0x52, - 0xbf, 0x5f, 0x95, 0x52, 0xcf, 0xab, 0x0b, 0x4b, 0xa5, 0xc6, 0x87, 0xb0, 0x49, 0xc7, 0x9e, 0x63, - 0x85, 0x2e, 0xf5, 0xb4, 0xf8, 0x33, 0x6e, 0xf2, 0x85, 0x76, 0xce, 0xbf, 0xe5, 0xf8, 0x8e, 0xe9, - 0x6e, 0xf2, 0x0f, 0x9f, 0x47, 0xff, 0x04, 0x00, 0x00, 0xff, 0xff, 0xa6, 0x16, 0xa4, 0xf2, 0xe6, - 0x09, 0x00, 0x00, + 0x17, 0x16, 0x65, 0xca, 0x92, 0x8e, 0x42, 0x87, 0x1e, 0x5f, 0x40, 0x0b, 0xb0, 0x14, 0xe8, 0x47, + 0xfe, 0x04, 0x41, 0x4b, 0x42, 0x09, 0xba, 0xe8, 0xa6, 0x45, 0x29, 0xc9, 0x29, 0x1b, 0xdb, 0x72, + 0xc7, 0xca, 0x22, 0xd9, 0x10, 0x14, 0x39, 0x91, 0x09, 0x4b, 0x1c, 0x99, 0xa4, 0x54, 0xfb, 0x0d, + 0x8a, 0x02, 0x05, 0xf2, 0x0e, 0xed, 0x5b, 0xf4, 0x05, 0xbc, 0xcc, 0xb2, 0xc8, 0x42, 0x6d, 0xe5, + 0xf7, 0x28, 0x8a, 0x19, 0x5e, 0x22, 0xc9, 0x49, 0xac, 0x1a, 0xe9, 0xca, 0x9a, 0xef, 0x5c, 0xbe, + 0x99, 0x73, 0xbe, 0x73, 0x4c, 0xd8, 0xb1, 0xa9, 0x4f, 0x46, 0x03, 0xcd, 0x21, 0xe7, 0xda, 0xb8, + 0xae, 0x51, 0xdf, 0x21, 0xbe, 0x3a, 0xf4, 0x69, 0x48, 0x91, 0x14, 0x99, 0x54, 0x87, 0x9c, 0xab, + 0xe3, 0x7a, 0xb9, 0x62, 0xd3, 0x60, 0x40, 0x03, 0xad, 0x6b, 0x05, 0x44, 0x1b, 0xd7, 0xbb, 0x24, + 0xb4, 0xea, 0x9a, 0x4d, 0x5d, 0x2f, 0x72, 0x2f, 0x6f, 0xf6, 0x68, 0x8f, 0xf2, 0x9f, 0x1a, 0xfb, + 0x15, 0xa3, 0xd5, 0x1e, 0xa5, 0xbd, 0x3e, 0xd1, 0xf8, 0xa9, 0x3b, 0x7a, 0xa5, 0x85, 0xee, 0x80, + 0x04, 0xa1, 0x35, 0x18, 0x46, 0x0e, 0xb5, 0x9f, 0x05, 0xc8, 0x3f, 0xa5, 0xd4, 0xe9, 0xb8, 0x7d, + 0x54, 0x87, 0xad, 0x1e, 0xa5, 0x8e, 0x19, 0xba, 0x7d, 0xb3, 0xdb, 0xa7, 0xf6, 0xa9, 0x79, 0x42, + 0xdc, 0xde, 0x49, 0xa8, 0x08, 0xf7, 0x84, 0x87, 0x22, 0x46, 0xbd, 0xc8, 0x4f, 0x67, 0xa6, 0x6f, + 0xb9, 0x05, 0xb5, 0x61, 0x63, 0x21, 0x84, 0x11, 0x28, 0xd9, 0x7b, 0xc2, 0xc3, 0xd2, 0xe3, 0xb2, + 0x1a, 0xb1, 0xab, 0x09, 0xbb, 0xda, 0x49, 0xd8, 0x75, 0xf1, 0xf5, 0x1f, 0x55, 0x01, 0xcb, 0xb3, + 0x29, 0x99, 0xb1, 0x76, 0x04, 0x52, 0xc3, 0xf2, 0x6c, 0xd2, 0x4f, 0x2e, 0xa5, 0x40, 0xde, 0xf6, + 0x89, 0x15, 0x52, 0x9f, 0x5f, 0xa3, 0x88, 0x93, 0x23, 0xba, 0x0f, 0x6b, 0xbc, 0x5e, 0x66, 0x40, + 0xce, 0x46, 0xc4, 0xb3, 0x23, 0x5a, 0x11, 0x4b, 0x1c, 0x3d, 0x8e, 0xc1, 0xda, 0x6f, 0x39, 0xc8, + 0xb5, 0x19, 0xf2, 0x91, 0x54, 0x9f, 0x81, 0x18, 0x5e, 0x0c, 0xa3, 0x04, 0x6b, 0x8f, 0x15, 0x75, + 0xae, 0xf4, 0x2a, 0x8f, 0xee, 0x5c, 0x0c, 0x09, 0xe6, 0x5e, 0x68, 0x1b, 0xb2, 0xae, 0xa3, 0xac, + 0xb0, 0x14, 0xfa, 0xea, 0x74, 0x52, 0xcd, 0x1a, 0x4d, 0x9c, 0x75, 0x1d, 0x54, 0x86, 0x42, 0x7a, + 0x15, 0x91, 0x5f, 0x25, 0x3d, 0xa3, 0x5d, 0x00, 0xd6, 0x39, 0xd3, 0x21, 0x1e, 0x1d, 0x28, 0x39, + 0x4e, 0x5f, 0x64, 0x48, 0x93, 0x01, 0xa8, 0x0a, 0xa5, 0xb3, 0x11, 0x0d, 0x13, 0xfb, 0x2a, 0xb7, + 0x03, 0x87, 0x12, 0x87, 0xdc, 0xd0, 0x77, 0x6d, 0xa2, 0xe4, 0x39, 0x6d, 0xf1, 0xed, 0xa4, 0x9a, + 0x3b, 0x62, 0x00, 0x8e, 0x70, 0xf4, 0x25, 0x14, 0xce, 0x46, 0x96, 0x17, 0xba, 0xe1, 0x85, 0x52, + 0xe0, 0x3e, 0xbb, 0x97, 0x93, 0x6a, 0xe6, 0xed, 0xa4, 0xba, 0x15, 0x29, 0x27, 0x70, 0x4e, 0x55, + 0x97, 0x6a, 0x03, 0x2b, 0x3c, 0x51, 0x0d, 0x2f, 0xc4, 0xa9, 0x3b, 0x7a, 0x00, 0x62, 0xe0, 0x3a, + 0x44, 0x29, 0xf2, 0xd7, 0x6f, 0x2c, 0xbc, 0xfe, 0xd8, 0x75, 0x08, 0xe6, 0x0e, 0x68, 0x1f, 0x90, + 0x4f, 0x06, 0x96, 0xeb, 0xb9, 0x5e, 0xcf, 0x4c, 0xd9, 0x60, 0x19, 0xb6, 0xf5, 0x34, 0xf0, 0xfb, + 0x84, 0xf6, 0x3b, 0x78, 0x07, 0x9a, 0x5d, 0xab, 0xcf, 0xda, 0xae, 0x94, 0x96, 0x49, 0x26, 0xa7, + 0x71, 0x7a, 0x14, 0x86, 0xea, 0x50, 0x48, 0x74, 0xa8, 0xdc, 0xe1, 0xe2, 0xdb, 0x5e, 0x78, 0x46, + 0xac, 0x27, 0x9c, 0x8f, 0x25, 0x87, 0xbe, 0x02, 0x89, 0x69, 0xd5, 0x74, 0x3d, 0xf3, 0x15, 0xf5, + 0x6d, 0xa2, 0x48, 0xfc, 0xf9, 0xe5, 0x85, 0x38, 0xa6, 0x4a, 0xc3, 0xdb, 0x63, 0x1e, 0xb8, 0x14, + 0xbe, 0x3b, 0x20, 0x07, 0xf2, 0x3e, 0x09, 0x88, 0x3f, 0x26, 0xca, 0x1a, 0x67, 0xdc, 0x51, 0xa3, + 0xdb, 0xaa, 0xac, 0xad, 0x6a, 0x3c, 0xa2, 0x6a, 0x83, 0xba, 0x9e, 0xae, 0xc5, 0xef, 0x79, 0xd0, + 0x73, 0xc3, 0x93, 0x51, 0x57, 0xb5, 0xe9, 0x40, 0x8b, 0xe7, 0x39, 0xfa, 0xf3, 0x79, 0xe0, 0x9c, + 0x6a, 0x4c, 0x5c, 0x01, 0x0f, 0xc0, 0x49, 0xea, 0xda, 0x4f, 0x2b, 0x50, 0xe4, 0xfa, 0x6b, 0x5a, + 0xa1, 0x85, 0xfe, 0x0f, 0x85, 0x48, 0xf2, 0xae, 0x13, 0x49, 0x58, 0x2f, 0x4d, 0x27, 0xd5, 0x3c, + 0x77, 0x30, 0x9a, 0x38, 0xcf, 0x8d, 0x86, 0x83, 0x9e, 0x40, 0x34, 0x04, 0x66, 0x97, 0xd2, 0x53, + 0xe6, 0xcc, 0x84, 0x2d, 0xe9, 0x77, 0xa7, 0x93, 0x6a, 0x89, 0x3b, 0xeb, 0x94, 0x9e, 0x1a, 0x4d, + 0x5c, 0xa2, 0xe9, 0xc1, 0x41, 0xff, 0x4b, 0x24, 0x16, 0x29, 0x5b, 0x8a, 0xef, 0xfc, 0x61, 0x99, + 0x89, 0xb7, 0x93, 0x59, 0xee, 0x26, 0x99, 0xcd, 0x36, 0x73, 0x75, 0xb9, 0x66, 0xce, 0x34, 0x23, + 0xff, 0xdf, 0x35, 0xa3, 0x0d, 0x52, 0x5a, 0x3d, 0xde, 0x8f, 0xf9, 0xa9, 0x16, 0x6e, 0x98, 0xea, + 0xec, 0xe2, 0x54, 0xd7, 0x7e, 0x5d, 0x81, 0xbb, 0x69, 0x46, 0x4c, 0x6c, 0xea, 0xbf, 0xa7, 0x77, + 0xc2, 0x12, 0xbd, 0x4b, 0x6a, 0x9b, 0xbd, 0xa9, 0xb6, 0x4b, 0x35, 0xf9, 0xfa, 0x66, 0x15, 0xdf, + 0xb3, 0x59, 0xe7, 0xd4, 0x98, 0xfb, 0x88, 0x1a, 0xef, 0xc3, 0x9a, 0x65, 0xdb, 0x74, 0xe4, 0x85, + 0xa6, 0x37, 0x1a, 0x74, 0x89, 0xcf, 0xbb, 0x2a, 0x62, 0x29, 0x46, 0x0f, 0x39, 0xf8, 0x81, 0xed, + 0x92, 0xff, 0x94, 0xdb, 0xa5, 0x70, 0xab, 0xed, 0x52, 0xfb, 0x5b, 0x80, 0x8d, 0x85, 0x36, 0xfd, + 0xab, 0x71, 0xbc, 0x5e, 0x80, 0xec, 0xf2, 0x05, 0x58, 0xf9, 0x94, 0x05, 0x10, 0x6f, 0x55, 0x80, + 0x47, 0x5f, 0x83, 0xc8, 0x34, 0x84, 0x36, 0x41, 0x3e, 0x36, 0x9a, 0x2d, 0xf3, 0xf9, 0xe1, 0xf1, + 0x51, 0xab, 0x61, 0xec, 0x19, 0xad, 0xa6, 0x9c, 0x41, 0x77, 0xa0, 0xc0, 0x51, 0xfd, 0xf9, 0x0b, + 0x59, 0x40, 0x12, 0x14, 0xf9, 0xe9, 0xb8, 0xb5, 0xbf, 0x2f, 0x67, 0xcb, 0xe2, 0x8f, 0xbf, 0x54, + 0x32, 0x8f, 0x5e, 0xc6, 0x5b, 0x8c, 0xfd, 0x17, 0x45, 0x65, 0xd8, 0x6e, 0xe3, 0x66, 0x0b, 0x9b, + 0x9d, 0x17, 0x47, 0x8b, 0xb9, 0x36, 0x41, 0x9e, 0xb1, 0xed, 0x1b, 0x07, 0x46, 0x47, 0x16, 0xd0, + 0x16, 0xac, 0xcf, 0xa0, 0x07, 0xdf, 0xe0, 0x67, 0xad, 0x4e, 0x9a, 0xfb, 0x07, 0x28, 0xcd, 0x2c, + 0x69, 0xb4, 0x0b, 0x3b, 0x1d, 0xe3, 0xa0, 0x65, 0x1a, 0x87, 0xe6, 0x5e, 0x1b, 0x37, 0x16, 0x09, + 0xb6, 0x60, 0x7d, 0xde, 0xfc, 0xb4, 0xd3, 0x88, 0x18, 0xe6, 0x61, 0xa3, 0xdd, 0x90, 0xb3, 0xd7, + 0xe1, 0xbd, 0xf6, 0x33, 0x79, 0x25, 0x22, 0xd6, 0xdb, 0x97, 0x7f, 0x55, 0x32, 0x97, 0xd3, 0x8a, + 0xf0, 0x66, 0x5a, 0x11, 0xfe, 0x9c, 0x56, 0x84, 0xd7, 0x57, 0x95, 0xcc, 0x9b, 0xab, 0x4a, 0xe6, + 0xf7, 0xab, 0x4a, 0xe6, 0x65, 0x7d, 0x66, 0xbd, 0x34, 0xf8, 0x38, 0xee, 0xd1, 0x91, 0xe7, 0x58, + 0xa1, 0x4b, 0x3d, 0x2d, 0xfe, 0xec, 0x1b, 0x7f, 0xa1, 0x9d, 0xf3, 0x6f, 0x3f, 0xbe, 0x6d, 0xba, + 0xab, 0xfc, 0x43, 0xe9, 0xc9, 0x3f, 0x01, 0x00, 0x00, 0xff, 0xff, 0x29, 0x65, 0x67, 0xc7, 0x16, + 0x0a, 0x00, 0x00, } func (m *GoodTil) Marshal() (dAtA []byte, err error) { @@ -606,8 +609,8 @@ func (m *CancelGoodTil) MarshalToSizedBuffer(dAtA []byte) (int, error) { _ = i var l int _ = l - if m.OrderSeq != 0 { - i = encodeVarintOrder(dAtA, i, uint64(m.OrderSeq)) + if m.OrderSequence != 0 { + i = encodeVarintOrder(dAtA, i, uint64(m.OrderSequence)) i-- dAtA[i] = 0x10 } @@ -650,11 +653,11 @@ func (m *Order) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintOrder(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x6a + dAtA[i] = 0x72 if m.TimeInForce != 0 { i = encodeVarintOrder(dAtA, i, uint64(m.TimeInForce)) i-- - dAtA[i] = 0x60 + dAtA[i] = 0x68 } if m.GoodTil != nil { { @@ -666,7 +669,7 @@ func (m *Order) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintOrder(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x5a + dAtA[i] = 0x62 } { size := m.RemainingBalance.Size() @@ -677,7 +680,7 @@ func (m *Order) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintOrder(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x52 + dAtA[i] = 0x5a { size := m.RemainingQuantity.Size() i -= size @@ -687,11 +690,11 @@ func (m *Order) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintOrder(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x4a + dAtA[i] = 0x52 if m.Side != 0 { i = encodeVarintOrder(dAtA, i, uint64(m.Side)) i-- - dAtA[i] = 0x40 + dAtA[i] = 0x48 } { size := m.Quantity.Size() @@ -702,7 +705,7 @@ func (m *Order) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintOrder(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x3a + dAtA[i] = 0x42 if m.Price != nil { { size := m.Price.Size() @@ -713,21 +716,26 @@ func (m *Order) MarshalToSizedBuffer(dAtA []byte) (int, error) { i = encodeVarintOrder(dAtA, i, uint64(size)) } i-- - dAtA[i] = 0x32 + dAtA[i] = 0x3a } if len(m.QuoteDenom) > 0 { i -= len(m.QuoteDenom) copy(dAtA[i:], m.QuoteDenom) i = encodeVarintOrder(dAtA, i, uint64(len(m.QuoteDenom))) i-- - dAtA[i] = 0x2a + dAtA[i] = 0x32 } if len(m.BaseDenom) > 0 { i -= len(m.BaseDenom) copy(dAtA[i:], m.BaseDenom) i = encodeVarintOrder(dAtA, i, uint64(len(m.BaseDenom))) i-- - dAtA[i] = 0x22 + dAtA[i] = 0x2a + } + if m.Sequence != 0 { + i = encodeVarintOrder(dAtA, i, uint64(m.Sequence)) + i-- + dAtA[i] = 0x20 } if len(m.ID) > 0 { i -= len(m.ID) @@ -922,8 +930,8 @@ func (m *OrderBookRecord) MarshalToSizedBuffer(dAtA []byte) (int, error) { i-- dAtA[i] = 0x2a } - if m.OrderSeq != 0 { - i = encodeVarintOrder(dAtA, i, uint64(m.OrderSeq)) + if m.OrderSequence != 0 { + i = encodeVarintOrder(dAtA, i, uint64(m.OrderSequence)) i-- dAtA[i] = 0x20 } @@ -1042,8 +1050,8 @@ func (m *CancelGoodTil) Size() (n int) { if l > 0 { n += 1 + l + sovOrder(uint64(l)) } - if m.OrderSeq != 0 { - n += 1 + sovOrder(uint64(m.OrderSeq)) + if m.OrderSequence != 0 { + n += 1 + sovOrder(uint64(m.OrderSequence)) } return n } @@ -1065,6 +1073,9 @@ func (m *Order) Size() (n int) { if l > 0 { n += 1 + l + sovOrder(uint64(l)) } + if m.Sequence != 0 { + n += 1 + sovOrder(uint64(m.Sequence)) + } l = len(m.BaseDenom) if l > 0 { n += 1 + l + sovOrder(uint64(l)) @@ -1158,8 +1169,8 @@ func (m *OrderBookRecord) Size() (n int) { } l = m.Price.Size() n += 1 + l + sovOrder(uint64(l)) - if m.OrderSeq != 0 { - n += 1 + sovOrder(uint64(m.OrderSeq)) + if m.OrderSequence != 0 { + n += 1 + sovOrder(uint64(m.OrderSequence)) } l = len(m.OrderID) if l > 0 { @@ -1369,9 +1380,9 @@ func (m *CancelGoodTil) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 2: if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field OrderSeq", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field OrderSequence", wireType) } - m.OrderSeq = 0 + m.OrderSequence = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowOrder @@ -1381,7 +1392,7 @@ func (m *CancelGoodTil) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.OrderSeq |= uint64(b&0x7F) << shift + m.OrderSequence |= uint64(b&0x7F) << shift if b < 0x80 { break } @@ -1520,6 +1531,25 @@ func (m *Order) Unmarshal(dAtA []byte) error { m.ID = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex case 4: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Sequence", wireType) + } + m.Sequence = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowOrder + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.Sequence |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 5: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field BaseDenom", wireType) } @@ -1551,7 +1581,7 @@ func (m *Order) Unmarshal(dAtA []byte) error { } m.BaseDenom = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex - case 5: + case 6: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field QuoteDenom", wireType) } @@ -1583,7 +1613,7 @@ func (m *Order) Unmarshal(dAtA []byte) error { } m.QuoteDenom = string(dAtA[iNdEx:postIndex]) iNdEx = postIndex - case 6: + case 7: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Price", wireType) } @@ -1619,7 +1649,7 @@ func (m *Order) Unmarshal(dAtA []byte) error { return err } iNdEx = postIndex - case 7: + case 8: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Quantity", wireType) } @@ -1653,7 +1683,7 @@ func (m *Order) Unmarshal(dAtA []byte) error { return err } iNdEx = postIndex - case 8: + case 9: if wireType != 0 { return fmt.Errorf("proto: wrong wireType = %d for field Side", wireType) } @@ -1672,7 +1702,7 @@ func (m *Order) Unmarshal(dAtA []byte) error { break } } - case 9: + case 10: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field RemainingQuantity", wireType) } @@ -1706,7 +1736,7 @@ func (m *Order) Unmarshal(dAtA []byte) error { return err } iNdEx = postIndex - case 10: + case 11: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field RemainingBalance", wireType) } @@ -1740,7 +1770,7 @@ func (m *Order) Unmarshal(dAtA []byte) error { return err } iNdEx = postIndex - case 11: + case 12: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field GoodTil", wireType) } @@ -1776,7 +1806,7 @@ func (m *Order) Unmarshal(dAtA []byte) error { return err } iNdEx = postIndex - case 12: + case 13: if wireType != 0 { return fmt.Errorf("proto: wrong wireType = %d for field TimeInForce", wireType) } @@ -1795,7 +1825,7 @@ func (m *Order) Unmarshal(dAtA []byte) error { break } } - case 13: + case 14: if wireType != 2 { return fmt.Errorf("proto: wrong wireType = %d for field Reserve", wireType) } @@ -2323,9 +2353,9 @@ func (m *OrderBookRecord) Unmarshal(dAtA []byte) error { iNdEx = postIndex case 4: if wireType != 0 { - return fmt.Errorf("proto: wrong wireType = %d for field OrderSeq", wireType) + return fmt.Errorf("proto: wrong wireType = %d for field OrderSequence", wireType) } - m.OrderSeq = 0 + m.OrderSequence = 0 for shift := uint(0); ; shift += 7 { if shift >= 64 { return ErrIntOverflowOrder @@ -2335,7 +2365,7 @@ func (m *OrderBookRecord) Unmarshal(dAtA []byte) error { } b := dAtA[iNdEx] iNdEx++ - m.OrderSeq |= uint64(b&0x7F) << shift + m.OrderSequence |= uint64(b&0x7F) << shift if b < 0x80 { break } diff --git a/x/dex/types/order_test.go b/x/dex/types/order_test.go index a0f47dc27..fa1d4483e 100644 --- a/x/dex/types/order_test.go +++ b/x/dex/types/order_test.go @@ -58,6 +58,15 @@ func TestOrder_Validate(t *testing.T) { }(), wantErr: types.ErrInvalidInput, }, + { + name: "invalid_order_sequence", + order: func() types.Order { + order := validOrder() + order.Sequence = 1 + return order + }(), + wantErr: types.ErrInvalidInput, + }, { name: "invalid_id_too_long", order: func() types.Order {