From edbcd223be9045ce3938606cb48f4421455b01e4 Mon Sep 17 00:00:00 2001 From: "mergify[bot]" <37929162+mergify[bot]@users.noreply.github.com> Date: Tue, 14 May 2024 10:49:42 -0400 Subject: [PATCH] [CT-834] new endpoint for stateful orders (#1501) (#1509) * [CT-834] new endpoint for stateful orders * fix test * indexer (cherry picked from commit c24be3a49245400b353997f4a4704f72ecd37e40) Co-authored-by: jayy04 <103467857+jayy04@users.noreply.github.com> --- .../dydxprotocol/clob/query.rpc.Query.ts | 16 +- .../src/codegen/dydxprotocol/clob/query.ts | 154 +++- proto/dydxprotocol/clob/query.proto | 23 + protocol/mocks/QueryClient.go | 37 + protocol/x/clob/client/cli/query.go | 1 + .../x/clob/client/cli/query_stateful_order.go | 70 ++ .../clob/keeper/grpc_query_stateful_order.go | 43 ++ .../keeper/grpc_query_stateful_order_test.go | 52 ++ protocol/x/clob/module_test.go | 3 +- protocol/x/clob/types/query.pb.go | 686 +++++++++++++++--- 10 files changed, 975 insertions(+), 110 deletions(-) create mode 100644 protocol/x/clob/client/cli/query_stateful_order.go create mode 100644 protocol/x/clob/keeper/grpc_query_stateful_order.go create mode 100644 protocol/x/clob/keeper/grpc_query_stateful_order_test.go diff --git a/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.rpc.Query.ts b/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.rpc.Query.ts index 0c7757ed00..5f49481ef3 100644 --- a/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.rpc.Query.ts +++ b/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.rpc.Query.ts @@ -1,7 +1,7 @@ import { Rpc } from "../../helpers"; import * as _m0 from "protobufjs/minimal"; import { QueryClient, createProtobufRpcClient } from "@cosmjs/stargate"; -import { QueryGetClobPairRequest, QueryClobPairResponse, QueryAllClobPairRequest, QueryClobPairAllResponse, MevNodeToNodeCalculationRequest, MevNodeToNodeCalculationResponse, QueryEquityTierLimitConfigurationRequest, QueryEquityTierLimitConfigurationResponse, QueryBlockRateLimitConfigurationRequest, QueryBlockRateLimitConfigurationResponse, QueryLiquidationsConfigurationRequest, QueryLiquidationsConfigurationResponse, StreamOrderbookUpdatesRequest, StreamOrderbookUpdatesResponse } from "./query"; +import { QueryGetClobPairRequest, QueryClobPairResponse, QueryAllClobPairRequest, QueryClobPairAllResponse, MevNodeToNodeCalculationRequest, MevNodeToNodeCalculationResponse, QueryEquityTierLimitConfigurationRequest, QueryEquityTierLimitConfigurationResponse, QueryBlockRateLimitConfigurationRequest, QueryBlockRateLimitConfigurationResponse, QueryLiquidationsConfigurationRequest, QueryLiquidationsConfigurationResponse, QueryStatefulOrderRequest, QueryStatefulOrderResponse, StreamOrderbookUpdatesRequest, StreamOrderbookUpdatesResponse } from "./query"; /** Query defines the gRPC querier service. */ export interface Query { @@ -22,6 +22,9 @@ export interface Query { /** Queries LiquidationsConfiguration. */ liquidationsConfiguration(request?: QueryLiquidationsConfigurationRequest): Promise; + /** Queries the stateful order for a given order id. */ + + statefulOrder(request: QueryStatefulOrderRequest): Promise; /** * Streams orderbook updates. Updates contain orderbook data * such as order placements, updates, and fills. @@ -40,6 +43,7 @@ export class QueryClientImpl implements Query { this.equityTierLimitConfiguration = this.equityTierLimitConfiguration.bind(this); this.blockRateLimitConfiguration = this.blockRateLimitConfiguration.bind(this); this.liquidationsConfiguration = this.liquidationsConfiguration.bind(this); + this.statefulOrder = this.statefulOrder.bind(this); this.streamOrderbookUpdates = this.streamOrderbookUpdates.bind(this); } @@ -81,6 +85,12 @@ export class QueryClientImpl implements Query { return promise.then(data => QueryLiquidationsConfigurationResponse.decode(new _m0.Reader(data))); } + statefulOrder(request: QueryStatefulOrderRequest): Promise { + const data = QueryStatefulOrderRequest.encode(request).finish(); + const promise = this.rpc.request("dydxprotocol.clob.Query", "StatefulOrder", data); + return promise.then(data => QueryStatefulOrderResponse.decode(new _m0.Reader(data))); + } + streamOrderbookUpdates(request: StreamOrderbookUpdatesRequest): Promise { const data = StreamOrderbookUpdatesRequest.encode(request).finish(); const promise = this.rpc.request("dydxprotocol.clob.Query", "StreamOrderbookUpdates", data); @@ -116,6 +126,10 @@ export const createRpcQueryExtension = (base: QueryClient) => { return queryService.liquidationsConfiguration(request); }, + statefulOrder(request: QueryStatefulOrderRequest): Promise { + return queryService.statefulOrder(request); + }, + streamOrderbookUpdates(request: StreamOrderbookUpdatesRequest): Promise { return queryService.streamOrderbookUpdates(request); } diff --git a/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.ts b/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.ts index d9e318e6b0..50fe19d57f 100644 --- a/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.ts +++ b/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.ts @@ -1,12 +1,12 @@ import { PageRequest, PageRequestSDKType, PageResponse, PageResponseSDKType } from "../../cosmos/base/query/v1beta1/pagination"; import { ValidatorMevMatches, ValidatorMevMatchesSDKType, MevNodeToNodeMetrics, MevNodeToNodeMetricsSDKType } from "./mev"; +import { OrderId, OrderIdSDKType, LongTermOrderPlacement, LongTermOrderPlacementSDKType, Order, OrderSDKType } from "./order"; import { ClobPair, ClobPairSDKType } from "./clob_pair"; import { EquityTierLimitConfiguration, EquityTierLimitConfigurationSDKType } from "./equity_tier_limit_config"; import { BlockRateLimitConfiguration, BlockRateLimitConfigurationSDKType } from "./block_rate_limit_config"; import { LiquidationsConfig, LiquidationsConfigSDKType } from "./liquidations_config"; import { OffChainUpdateV1, OffChainUpdateV1SDKType } from "../indexer/off_chain_updates/off_chain_updates"; import { ClobMatch, ClobMatchSDKType } from "./matches"; -import { Order, OrderSDKType } from "./order"; import * as _m0 from "protobufjs/minimal"; import { DeepPartial, Long } from "../../helpers"; /** QueryGetClobPairRequest is request type for the ClobPair method. */ @@ -173,6 +173,48 @@ export interface QueryBlockRateLimitConfigurationResponse { export interface QueryBlockRateLimitConfigurationResponseSDKType { block_rate_limit_config?: BlockRateLimitConfigurationSDKType; } +/** QueryStatefulOrderRequest is a request message for StatefulOrder. */ + +export interface QueryStatefulOrderRequest { + /** Order id to query. */ + orderId?: OrderId; +} +/** QueryStatefulOrderRequest is a request message for StatefulOrder. */ + +export interface QueryStatefulOrderRequestSDKType { + /** Order id to query. */ + order_id?: OrderIdSDKType; +} +/** + * QueryStatefulOrderResponse is a response message that contains the stateful + * order. + */ + +export interface QueryStatefulOrderResponse { + /** Stateful order placement. */ + orderPlacement?: LongTermOrderPlacement; + /** Fill amounts. */ + + fillAmount: Long; + /** Triggered status. */ + + triggered: boolean; +} +/** + * QueryStatefulOrderResponse is a response message that contains the stateful + * order. + */ + +export interface QueryStatefulOrderResponseSDKType { + /** Stateful order placement. */ + order_placement?: LongTermOrderPlacementSDKType; + /** Fill amounts. */ + + fill_amount: Long; + /** Triggered status. */ + + triggered: boolean; +} /** * QueryLiquidationsConfigurationRequest is a request message for * LiquidationsConfiguration. @@ -869,6 +911,116 @@ export const QueryBlockRateLimitConfigurationResponse = { }; +function createBaseQueryStatefulOrderRequest(): QueryStatefulOrderRequest { + return { + orderId: undefined + }; +} + +export const QueryStatefulOrderRequest = { + encode(message: QueryStatefulOrderRequest, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer { + if (message.orderId !== undefined) { + OrderId.encode(message.orderId, writer.uint32(10).fork()).ldelim(); + } + + return writer; + }, + + decode(input: _m0.Reader | Uint8Array, length?: number): QueryStatefulOrderRequest { + const reader = input instanceof _m0.Reader ? input : new _m0.Reader(input); + let end = length === undefined ? reader.len : reader.pos + length; + const message = createBaseQueryStatefulOrderRequest(); + + while (reader.pos < end) { + const tag = reader.uint32(); + + switch (tag >>> 3) { + case 1: + message.orderId = OrderId.decode(reader, reader.uint32()); + break; + + default: + reader.skipType(tag & 7); + break; + } + } + + return message; + }, + + fromPartial(object: DeepPartial): QueryStatefulOrderRequest { + const message = createBaseQueryStatefulOrderRequest(); + message.orderId = object.orderId !== undefined && object.orderId !== null ? OrderId.fromPartial(object.orderId) : undefined; + return message; + } + +}; + +function createBaseQueryStatefulOrderResponse(): QueryStatefulOrderResponse { + return { + orderPlacement: undefined, + fillAmount: Long.UZERO, + triggered: false + }; +} + +export const QueryStatefulOrderResponse = { + encode(message: QueryStatefulOrderResponse, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer { + if (message.orderPlacement !== undefined) { + LongTermOrderPlacement.encode(message.orderPlacement, writer.uint32(10).fork()).ldelim(); + } + + if (!message.fillAmount.isZero()) { + writer.uint32(16).uint64(message.fillAmount); + } + + if (message.triggered === true) { + writer.uint32(24).bool(message.triggered); + } + + return writer; + }, + + decode(input: _m0.Reader | Uint8Array, length?: number): QueryStatefulOrderResponse { + const reader = input instanceof _m0.Reader ? input : new _m0.Reader(input); + let end = length === undefined ? reader.len : reader.pos + length; + const message = createBaseQueryStatefulOrderResponse(); + + while (reader.pos < end) { + const tag = reader.uint32(); + + switch (tag >>> 3) { + case 1: + message.orderPlacement = LongTermOrderPlacement.decode(reader, reader.uint32()); + break; + + case 2: + message.fillAmount = (reader.uint64() as Long); + break; + + case 3: + message.triggered = reader.bool(); + break; + + default: + reader.skipType(tag & 7); + break; + } + } + + return message; + }, + + fromPartial(object: DeepPartial): QueryStatefulOrderResponse { + const message = createBaseQueryStatefulOrderResponse(); + message.orderPlacement = object.orderPlacement !== undefined && object.orderPlacement !== null ? LongTermOrderPlacement.fromPartial(object.orderPlacement) : undefined; + message.fillAmount = object.fillAmount !== undefined && object.fillAmount !== null ? Long.fromValue(object.fillAmount) : Long.UZERO; + message.triggered = object.triggered ?? false; + return message; + } + +}; + function createBaseQueryLiquidationsConfigurationRequest(): QueryLiquidationsConfigurationRequest { return {}; } diff --git a/proto/dydxprotocol/clob/query.proto b/proto/dydxprotocol/clob/query.proto index de80d26e4a..cfed065ba0 100644 --- a/proto/dydxprotocol/clob/query.proto +++ b/proto/dydxprotocol/clob/query.proto @@ -54,6 +54,10 @@ service Query { option (google.api.http).get = "/dydxprotocol/clob/liquidations_config"; } + // Queries the stateful order for a given order id. + rpc StatefulOrder(QueryStatefulOrderRequest) + returns (QueryStatefulOrderResponse) {} + // GRPC Streams // Streams orderbook updates. Updates contain orderbook data @@ -127,6 +131,25 @@ message QueryBlockRateLimitConfigurationResponse { [ (gogoproto.nullable) = false ]; } +// QueryStatefulOrderRequest is a request message for StatefulOrder. +message QueryStatefulOrderRequest { + // Order id to query. + OrderId order_id = 1 [ (gogoproto.nullable) = false ]; +} + +// QueryStatefulOrderResponse is a response message that contains the stateful +// order. +message QueryStatefulOrderResponse { + // Stateful order placement. + LongTermOrderPlacement order_placement = 1 [ (gogoproto.nullable) = false ]; + + // Fill amounts. + uint64 fill_amount = 2; + + // Triggered status. + bool triggered = 3; +} + // QueryLiquidationsConfigurationRequest is a request message for // LiquidationsConfiguration. message QueryLiquidationsConfigurationRequest {} diff --git a/protocol/mocks/QueryClient.go b/protocol/mocks/QueryClient.go index bd9c3832e8..ad66aec158 100644 --- a/protocol/mocks/QueryClient.go +++ b/protocol/mocks/QueryClient.go @@ -756,6 +756,43 @@ func (_m *QueryClient) PreviousBlockInfo(ctx context.Context, in *types.QueryPre return r0, r1 } +// StatefulOrder provides a mock function with given fields: ctx, in, opts +func (_m *QueryClient) StatefulOrder(ctx context.Context, in *clobtypes.QueryStatefulOrderRequest, opts ...grpc.CallOption) (*clobtypes.QueryStatefulOrderResponse, error) { + _va := make([]interface{}, len(opts)) + for _i := range opts { + _va[_i] = opts[_i] + } + var _ca []interface{} + _ca = append(_ca, ctx, in) + _ca = append(_ca, _va...) + ret := _m.Called(_ca...) + + if len(ret) == 0 { + panic("no return value specified for StatefulOrder") + } + + var r0 *clobtypes.QueryStatefulOrderResponse + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *clobtypes.QueryStatefulOrderRequest, ...grpc.CallOption) (*clobtypes.QueryStatefulOrderResponse, error)); ok { + return rf(ctx, in, opts...) + } + if rf, ok := ret.Get(0).(func(context.Context, *clobtypes.QueryStatefulOrderRequest, ...grpc.CallOption) *clobtypes.QueryStatefulOrderResponse); ok { + r0 = rf(ctx, in, opts...) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*clobtypes.QueryStatefulOrderResponse) + } + } + + if rf, ok := ret.Get(1).(func(context.Context, *clobtypes.QueryStatefulOrderRequest, ...grpc.CallOption) error); ok { + r1 = rf(ctx, in, opts...) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} + // StreamOrderbookUpdates provides a mock function with given fields: ctx, in, opts func (_m *QueryClient) StreamOrderbookUpdates(ctx context.Context, in *clobtypes.StreamOrderbookUpdatesRequest, opts ...grpc.CallOption) (clobtypes.Query_StreamOrderbookUpdatesClient, error) { _va := make([]interface{}, len(opts)) diff --git a/protocol/x/clob/client/cli/query.go b/protocol/x/clob/client/cli/query.go index d6dcb9025d..6c7a49f77c 100644 --- a/protocol/x/clob/client/cli/query.go +++ b/protocol/x/clob/client/cli/query.go @@ -26,6 +26,7 @@ func GetQueryCmd(queryRoute string) *cobra.Command { cmd.AddCommand(CmdGetBlockRateLimitConfiguration()) cmd.AddCommand(CmdGetEquityTierLimitConfig()) cmd.AddCommand(CmdGetLiquidationsConfiguration()) + cmd.AddCommand(CmdQueryStatefulOrder()) return cmd } diff --git a/protocol/x/clob/client/cli/query_stateful_order.go b/protocol/x/clob/client/cli/query_stateful_order.go new file mode 100644 index 0000000000..09cf30dc8e --- /dev/null +++ b/protocol/x/clob/client/cli/query_stateful_order.go @@ -0,0 +1,70 @@ +package cli + +import ( + "context" + + "github.com/cosmos/cosmos-sdk/client" + "github.com/cosmos/cosmos-sdk/client/flags" + "github.com/dydxprotocol/v4-chain/protocol/x/clob/types" + satypes "github.com/dydxprotocol/v4-chain/protocol/x/subaccounts/types" + "github.com/spf13/cast" + "github.com/spf13/cobra" +) + +func CmdQueryStatefulOrder() *cobra.Command { + cmd := &cobra.Command{ + Use: "stateful-order subaccount_owner subaccount_number client_id clob_pair_id order_flags", + Short: "queries a stateful order by id", + Args: cobra.ExactArgs(5), + RunE: func(cmd *cobra.Command, args []string) (err error) { + clientCtx := client.GetClientContextFromCmd(cmd) + + queryClient := types.NewQueryClient(clientCtx) + + owner := args[0] + + number, err := cast.ToUint32E(args[1]) + if err != nil { + return err + } + + clientId, err := cast.ToUint32E(args[2]) + if err != nil { + return err + } + + clobPairId, err := cast.ToUint32E(args[3]) + if err != nil { + return err + } + + orderFlag, err := cast.ToUint32E(args[4]) + if err != nil { + return err + } + + req := &types.QueryStatefulOrderRequest{ + OrderId: types.OrderId{ + SubaccountId: satypes.SubaccountId{ + Owner: owner, + Number: number, + }, + ClientId: clientId, + ClobPairId: clobPairId, + OrderFlags: orderFlag, + }, + } + + res, err := queryClient.StatefulOrder(context.Background(), req) + if err != nil { + return err + } + + return clientCtx.PrintProto(res) + }, + } + + flags.AddQueryFlagsToCmd(cmd) + + return cmd +} diff --git a/protocol/x/clob/keeper/grpc_query_stateful_order.go b/protocol/x/clob/keeper/grpc_query_stateful_order.go new file mode 100644 index 0000000000..5fdb365695 --- /dev/null +++ b/protocol/x/clob/keeper/grpc_query_stateful_order.go @@ -0,0 +1,43 @@ +package keeper + +import ( + "context" + + "github.com/dydxprotocol/v4-chain/protocol/lib" + "github.com/dydxprotocol/v4-chain/protocol/x/clob/types" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/status" +) + +func (k Keeper) StatefulOrder( + c context.Context, + req *types.QueryStatefulOrderRequest, +) (*types.QueryStatefulOrderResponse, error) { + if req == nil { + return nil, status.Error(codes.InvalidArgument, "invalid request") + } + ctx := lib.UnwrapSDKContext(c, types.ModuleName) + + val, found := k.GetLongTermOrderPlacement( + ctx, + req.OrderId, + ) + if !found { + return nil, status.Error(codes.NotFound, "not found") + } + + res := &types.QueryStatefulOrderResponse{ + OrderPlacement: val, + } + + // Get the fill amount + _, fillAmount, _ := k.GetOrderFillAmount(ctx, req.OrderId) + res.FillAmount = fillAmount.ToUint64() + + // Get triggered status for conditional orders + if req.OrderId.IsConditionalOrder() { + res.Triggered = k.IsConditionalOrderTriggered(ctx, req.OrderId) + } + + return res, nil +} diff --git a/protocol/x/clob/keeper/grpc_query_stateful_order_test.go b/protocol/x/clob/keeper/grpc_query_stateful_order_test.go new file mode 100644 index 0000000000..f99791d838 --- /dev/null +++ b/protocol/x/clob/keeper/grpc_query_stateful_order_test.go @@ -0,0 +1,52 @@ +package keeper_test + +import ( + "testing" + + testApp "github.com/dydxprotocol/v4-chain/protocol/testutil/app" + "github.com/dydxprotocol/v4-chain/protocol/testutil/constants" + "github.com/dydxprotocol/v4-chain/protocol/x/clob/types" + "github.com/stretchr/testify/require" +) + +func TestStatefulOrderTest(t *testing.T) { + tApp := testApp.NewTestAppBuilder(t).Build() + ctx := tApp.InitChain() + + tApp.App.ClobKeeper.SetLongTermOrderPlacement( + ctx, + constants.LongTermOrder_Alice_Num0_Id0_Clob0_Buy100_Price10_GTBT15, + 1, + ) + + tApp.App.ClobKeeper.SetOrderFillAmount( + ctx, + constants.LongTermOrder_Alice_Num0_Id0_Clob0_Buy100_Price10_GTBT15.OrderId, + 5, + 123456789, + ) + + res, err := tApp.App.ClobKeeper.StatefulOrder( + ctx, + &types.QueryStatefulOrderRequest{ + OrderId: constants.LongTermOrder_Alice_Num0_Id0_Clob0_Buy100_Price10_GTBT15.OrderId, + }, + ) + + require.NoError(t, err) + require.Equal( + t, + &types.QueryStatefulOrderResponse{ + OrderPlacement: types.LongTermOrderPlacement{ + Order: constants.LongTermOrder_Alice_Num0_Id0_Clob0_Buy100_Price10_GTBT15, + PlacementIndex: types.TransactionOrdering{ + BlockHeight: 1, + TransactionIndex: 0, + }, + }, + FillAmount: 5, + Triggered: false, + }, + res, + ) +} diff --git a/protocol/x/clob/module_test.go b/protocol/x/clob/module_test.go index 643abde49e..4217b6eb4d 100644 --- a/protocol/x/clob/module_test.go +++ b/protocol/x/clob/module_test.go @@ -250,12 +250,13 @@ func TestAppModuleBasic_GetQueryCmd(t *testing.T) { cmd := am.GetQueryCmd() require.Equal(t, "clob", cmd.Use) - require.Equal(t, 5, len(cmd.Commands())) + require.Equal(t, 6, len(cmd.Commands())) require.Equal(t, "get-block-rate-limit-config", cmd.Commands()[0].Name()) require.Equal(t, "get-equity-tier-limit-config", cmd.Commands()[1].Name()) require.Equal(t, "get-liquidations-config", cmd.Commands()[2].Name()) require.Equal(t, "list-clob-pair", cmd.Commands()[3].Name()) require.Equal(t, "show-clob-pair", cmd.Commands()[4].Name()) + require.Equal(t, "stateful-order", cmd.Commands()[5].Name()) } func TestAppModule_Name(t *testing.T) { diff --git a/protocol/x/clob/types/query.pb.go b/protocol/x/clob/types/query.pb.go index 18ff69a570..9dce006bd3 100644 --- a/protocol/x/clob/types/query.pb.go +++ b/protocol/x/clob/types/query.pb.go @@ -568,6 +568,117 @@ func (m *QueryBlockRateLimitConfigurationResponse) GetBlockRateLimitConfig() Blo return BlockRateLimitConfiguration{} } +// QueryStatefulOrderRequest is a request message for StatefulOrder. +type QueryStatefulOrderRequest struct { + // Order id to query. + OrderId OrderId `protobuf:"bytes,1,opt,name=order_id,json=orderId,proto3" json:"order_id"` +} + +func (m *QueryStatefulOrderRequest) Reset() { *m = QueryStatefulOrderRequest{} } +func (m *QueryStatefulOrderRequest) String() string { return proto.CompactTextString(m) } +func (*QueryStatefulOrderRequest) ProtoMessage() {} +func (*QueryStatefulOrderRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_3365c195b25c5bc0, []int{10} +} +func (m *QueryStatefulOrderRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *QueryStatefulOrderRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_QueryStatefulOrderRequest.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 *QueryStatefulOrderRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_QueryStatefulOrderRequest.Merge(m, src) +} +func (m *QueryStatefulOrderRequest) XXX_Size() int { + return m.Size() +} +func (m *QueryStatefulOrderRequest) XXX_DiscardUnknown() { + xxx_messageInfo_QueryStatefulOrderRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_QueryStatefulOrderRequest proto.InternalMessageInfo + +func (m *QueryStatefulOrderRequest) GetOrderId() OrderId { + if m != nil { + return m.OrderId + } + return OrderId{} +} + +// QueryStatefulOrderResponse is a response message that contains the stateful +// order. +type QueryStatefulOrderResponse struct { + // Stateful order placement. + OrderPlacement LongTermOrderPlacement `protobuf:"bytes,1,opt,name=order_placement,json=orderPlacement,proto3" json:"order_placement"` + // Fill amounts. + FillAmount uint64 `protobuf:"varint,2,opt,name=fill_amount,json=fillAmount,proto3" json:"fill_amount,omitempty"` + // Triggered status. + Triggered bool `protobuf:"varint,3,opt,name=triggered,proto3" json:"triggered,omitempty"` +} + +func (m *QueryStatefulOrderResponse) Reset() { *m = QueryStatefulOrderResponse{} } +func (m *QueryStatefulOrderResponse) String() string { return proto.CompactTextString(m) } +func (*QueryStatefulOrderResponse) ProtoMessage() {} +func (*QueryStatefulOrderResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_3365c195b25c5bc0, []int{11} +} +func (m *QueryStatefulOrderResponse) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *QueryStatefulOrderResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_QueryStatefulOrderResponse.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 *QueryStatefulOrderResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_QueryStatefulOrderResponse.Merge(m, src) +} +func (m *QueryStatefulOrderResponse) XXX_Size() int { + return m.Size() +} +func (m *QueryStatefulOrderResponse) XXX_DiscardUnknown() { + xxx_messageInfo_QueryStatefulOrderResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_QueryStatefulOrderResponse proto.InternalMessageInfo + +func (m *QueryStatefulOrderResponse) GetOrderPlacement() LongTermOrderPlacement { + if m != nil { + return m.OrderPlacement + } + return LongTermOrderPlacement{} +} + +func (m *QueryStatefulOrderResponse) GetFillAmount() uint64 { + if m != nil { + return m.FillAmount + } + return 0 +} + +func (m *QueryStatefulOrderResponse) GetTriggered() bool { + if m != nil { + return m.Triggered + } + return false +} + // QueryLiquidationsConfigurationRequest is a request message for // LiquidationsConfiguration. type QueryLiquidationsConfigurationRequest struct { @@ -577,7 +688,7 @@ func (m *QueryLiquidationsConfigurationRequest) Reset() { *m = QueryLiqu func (m *QueryLiquidationsConfigurationRequest) String() string { return proto.CompactTextString(m) } func (*QueryLiquidationsConfigurationRequest) ProtoMessage() {} func (*QueryLiquidationsConfigurationRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_3365c195b25c5bc0, []int{10} + return fileDescriptor_3365c195b25c5bc0, []int{12} } func (m *QueryLiquidationsConfigurationRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -618,7 +729,7 @@ func (m *QueryLiquidationsConfigurationResponse) Reset() { func (m *QueryLiquidationsConfigurationResponse) String() string { return proto.CompactTextString(m) } func (*QueryLiquidationsConfigurationResponse) ProtoMessage() {} func (*QueryLiquidationsConfigurationResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_3365c195b25c5bc0, []int{11} + return fileDescriptor_3365c195b25c5bc0, []int{13} } func (m *QueryLiquidationsConfigurationResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -665,7 +776,7 @@ func (m *StreamOrderbookUpdatesRequest) Reset() { *m = StreamOrderbookUp func (m *StreamOrderbookUpdatesRequest) String() string { return proto.CompactTextString(m) } func (*StreamOrderbookUpdatesRequest) ProtoMessage() {} func (*StreamOrderbookUpdatesRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_3365c195b25c5bc0, []int{12} + return fileDescriptor_3365c195b25c5bc0, []int{14} } func (m *StreamOrderbookUpdatesRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -717,7 +828,7 @@ func (m *StreamOrderbookUpdatesResponse) Reset() { *m = StreamOrderbookU func (m *StreamOrderbookUpdatesResponse) String() string { return proto.CompactTextString(m) } func (*StreamOrderbookUpdatesResponse) ProtoMessage() {} func (*StreamOrderbookUpdatesResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_3365c195b25c5bc0, []int{13} + return fileDescriptor_3365c195b25c5bc0, []int{15} } func (m *StreamOrderbookUpdatesResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -784,7 +895,7 @@ func (m *StreamUpdate) Reset() { *m = StreamUpdate{} } func (m *StreamUpdate) String() string { return proto.CompactTextString(m) } func (*StreamUpdate) ProtoMessage() {} func (*StreamUpdate) Descriptor() ([]byte, []int) { - return fileDescriptor_3365c195b25c5bc0, []int{14} + return fileDescriptor_3365c195b25c5bc0, []int{16} } func (m *StreamUpdate) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -875,7 +986,7 @@ func (m *StreamOrderbookUpdate) Reset() { *m = StreamOrderbookUpdate{} } func (m *StreamOrderbookUpdate) String() string { return proto.CompactTextString(m) } func (*StreamOrderbookUpdate) ProtoMessage() {} func (*StreamOrderbookUpdate) Descriptor() ([]byte, []int) { - return fileDescriptor_3365c195b25c5bc0, []int{15} + return fileDescriptor_3365c195b25c5bc0, []int{17} } func (m *StreamOrderbookUpdate) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -935,7 +1046,7 @@ func (m *StreamOrderbookFill) Reset() { *m = StreamOrderbookFill{} } func (m *StreamOrderbookFill) String() string { return proto.CompactTextString(m) } func (*StreamOrderbookFill) ProtoMessage() {} func (*StreamOrderbookFill) Descriptor() ([]byte, []int) { - return fileDescriptor_3365c195b25c5bc0, []int{16} + return fileDescriptor_3365c195b25c5bc0, []int{18} } func (m *StreamOrderbookFill) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -997,6 +1108,8 @@ func init() { proto.RegisterType((*QueryEquityTierLimitConfigurationResponse)(nil), "dydxprotocol.clob.QueryEquityTierLimitConfigurationResponse") proto.RegisterType((*QueryBlockRateLimitConfigurationRequest)(nil), "dydxprotocol.clob.QueryBlockRateLimitConfigurationRequest") proto.RegisterType((*QueryBlockRateLimitConfigurationResponse)(nil), "dydxprotocol.clob.QueryBlockRateLimitConfigurationResponse") + proto.RegisterType((*QueryStatefulOrderRequest)(nil), "dydxprotocol.clob.QueryStatefulOrderRequest") + proto.RegisterType((*QueryStatefulOrderResponse)(nil), "dydxprotocol.clob.QueryStatefulOrderResponse") proto.RegisterType((*QueryLiquidationsConfigurationRequest)(nil), "dydxprotocol.clob.QueryLiquidationsConfigurationRequest") proto.RegisterType((*QueryLiquidationsConfigurationResponse)(nil), "dydxprotocol.clob.QueryLiquidationsConfigurationResponse") proto.RegisterType((*StreamOrderbookUpdatesRequest)(nil), "dydxprotocol.clob.StreamOrderbookUpdatesRequest") @@ -1009,88 +1122,95 @@ func init() { func init() { proto.RegisterFile("dydxprotocol/clob/query.proto", fileDescriptor_3365c195b25c5bc0) } var fileDescriptor_3365c195b25c5bc0 = []byte{ - // 1281 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x57, 0x41, 0x6f, 0xdc, 0x44, - 0x14, 0xde, 0xc9, 0x96, 0x36, 0x79, 0x49, 0x4b, 0x98, 0x34, 0xe9, 0xb2, 0x49, 0x36, 0x1b, 0x43, - 0x92, 0x4d, 0x2a, 0xec, 0x24, 0xad, 0xaa, 0x92, 0xa0, 0xa2, 0x24, 0xa2, 0x09, 0x52, 0x43, 0x83, - 0x69, 0x03, 0x82, 0x4a, 0x96, 0xd7, 0x9e, 0xdd, 0xb5, 0x62, 0x7b, 0x36, 0xb6, 0x77, 0x95, 0x08, - 0x21, 0x24, 0x0e, 0x5c, 0x00, 0x09, 0x89, 0x03, 0x07, 0x4e, 0x88, 0x3b, 0x17, 0xce, 0x88, 0x72, - 0xeb, 0xb1, 0x12, 0x17, 0x0e, 0x08, 0xa1, 0x84, 0x33, 0xbf, 0x01, 0x79, 0x66, 0xbc, 0xdd, 0x5d, - 0xdb, 0xbb, 0x49, 0x2e, 0xbb, 0xf6, 0x9b, 0xef, 0xbd, 0xf9, 0xde, 0x9b, 0x37, 0xf3, 0x8d, 0x61, - 0xda, 0x3c, 0x36, 0x8f, 0xea, 0x1e, 0x0d, 0xa8, 0x41, 0x6d, 0xc5, 0xb0, 0x69, 0x59, 0x39, 0x6c, - 0x10, 0xef, 0x58, 0x66, 0x36, 0xfc, 0x4a, 0xfb, 0xb0, 0x1c, 0x0e, 0xe7, 0xaf, 0x57, 0x69, 0x95, - 0x32, 0x93, 0x12, 0x3e, 0x71, 0x60, 0x7e, 0xaa, 0x4a, 0x69, 0xd5, 0x26, 0x8a, 0x5e, 0xb7, 0x14, - 0xdd, 0x75, 0x69, 0xa0, 0x07, 0x16, 0x75, 0x7d, 0x31, 0xba, 0x64, 0x50, 0xdf, 0xa1, 0xbe, 0x52, - 0xd6, 0x7d, 0xc2, 0xe3, 0x2b, 0xcd, 0x95, 0x32, 0x09, 0xf4, 0x15, 0xa5, 0xae, 0x57, 0x2d, 0x97, - 0x81, 0x05, 0x56, 0x89, 0x33, 0x2a, 0xdb, 0xd4, 0x38, 0xd0, 0x3c, 0x3d, 0x20, 0x9a, 0x6d, 0x39, - 0x56, 0xa0, 0x19, 0xd4, 0xad, 0x58, 0x55, 0xe1, 0x30, 0x1b, 0x77, 0x08, 0x7f, 0xb4, 0xba, 0x6e, - 0x79, 0x02, 0xb2, 0x1c, 0x87, 0x90, 0xc3, 0x86, 0x15, 0x1c, 0x6b, 0x81, 0x45, 0xbc, 0xa4, 0xa0, - 0x09, 0x75, 0xa1, 0x9e, 0x49, 0xa2, 0x80, 0x33, 0xf1, 0x61, 0x47, 0x0f, 0x8c, 0x1a, 0x89, 0x32, - 0xbe, 0x19, 0x07, 0xd8, 0xd6, 0x61, 0xc3, 0x32, 0x79, 0x5d, 0x3a, 0x27, 0x9b, 0x4c, 0x88, 0x46, - 0x9a, 0x62, 0xf0, 0x5e, 0xc7, 0xa0, 0xe5, 0x9a, 0xe4, 0x88, 0x78, 0x0a, 0xad, 0x54, 0x34, 0xa3, - 0xa6, 0x5b, 0xae, 0xd6, 0xa8, 0x9b, 0x7a, 0x40, 0xfc, 0xb8, 0x85, 0xfb, 0x4b, 0x8b, 0x70, 0xe3, - 0xfd, 0xb0, 0xe2, 0xdb, 0x24, 0xd8, 0xb2, 0x69, 0x79, 0x4f, 0xb7, 0x3c, 0x95, 0x1c, 0x36, 0x88, - 0x1f, 0xe0, 0x6b, 0x30, 0x60, 0x99, 0x39, 0x54, 0x44, 0xa5, 0xab, 0xea, 0x80, 0x65, 0x4a, 0x1f, - 0xc2, 0x38, 0x83, 0xbe, 0xc0, 0xf9, 0x75, 0xea, 0xfa, 0x04, 0xdf, 0x83, 0xa1, 0x56, 0x49, 0x19, - 0x7e, 0x78, 0x75, 0x52, 0x8e, 0xb5, 0x86, 0x1c, 0xf9, 0x6d, 0x5e, 0x7a, 0xf6, 0xf7, 0x4c, 0x46, - 0x1d, 0x34, 0xc4, 0xbb, 0xa4, 0x0b, 0x0e, 0x1b, 0xb6, 0xdd, 0xcd, 0xe1, 0x3e, 0xc0, 0x8b, 0x16, - 0x10, 0xb1, 0xe7, 0x65, 0xde, 0x2f, 0x72, 0xd8, 0x2f, 0x32, 0xef, 0x47, 0xd1, 0x2f, 0xf2, 0x9e, - 0x5e, 0x25, 0xc2, 0x57, 0x6d, 0xf3, 0x94, 0x7e, 0x42, 0x90, 0xeb, 0x20, 0xbf, 0x61, 0xdb, 0x69, - 0xfc, 0xb3, 0xe7, 0xe4, 0x8f, 0xb7, 0x3b, 0x48, 0x0e, 0x30, 0x92, 0x0b, 0x7d, 0x49, 0xf2, 0xc9, - 0x3b, 0x58, 0xfe, 0x85, 0x60, 0x66, 0x97, 0x34, 0xdf, 0xa3, 0x26, 0x79, 0x44, 0xc3, 0xdf, 0x2d, - 0xdd, 0x36, 0x1a, 0x36, 0x1b, 0x8c, 0x2a, 0xf2, 0x04, 0x26, 0x78, 0xc3, 0xd7, 0x3d, 0x5a, 0xa7, - 0x3e, 0xf1, 0x34, 0xd1, 0x5a, 0xad, 0xea, 0xc4, 0x99, 0xef, 0xeb, 0x76, 0xd8, 0x5a, 0xd4, 0xdb, - 0x25, 0xcd, 0x5d, 0x8e, 0x56, 0xaf, 0xb3, 0x28, 0x7b, 0x22, 0x88, 0xb0, 0xe2, 0x4f, 0x60, 0xbc, - 0x19, 0x81, 0x35, 0x87, 0x34, 0x35, 0x87, 0x04, 0x9e, 0x65, 0xf8, 0xad, 0xac, 0xe2, 0xc1, 0x3b, - 0x08, 0xef, 0x72, 0xb8, 0x3a, 0xd6, 0x6c, 0x9f, 0x92, 0x1b, 0xa5, 0xff, 0x10, 0x14, 0xd3, 0xd3, - 0x13, 0x8b, 0x51, 0x85, 0x2b, 0x1e, 0xf1, 0x1b, 0x76, 0xe0, 0x8b, 0xa5, 0xd8, 0xee, 0x37, 0x67, - 0x42, 0x94, 0x10, 0xb0, 0xe1, 0x9a, 0xfb, 0xd4, 0x6e, 0x38, 0x64, 0x8f, 0x78, 0xe1, 0xd2, 0x89, - 0x65, 0x8b, 0xa2, 0xe7, 0x75, 0x18, 0x4b, 0x40, 0xe1, 0x22, 0x8c, 0xb4, 0x9a, 0x41, 0x6b, 0xf5, - 0x3f, 0x44, 0x8b, 0xfd, 0xae, 0x89, 0x47, 0x21, 0xeb, 0x90, 0x26, 0xab, 0xc8, 0x80, 0x1a, 0x3e, - 0xe2, 0x09, 0xb8, 0xdc, 0x64, 0x41, 0x72, 0xd9, 0x22, 0x2a, 0x5d, 0x52, 0xc5, 0x9b, 0xb4, 0x04, - 0x25, 0xd6, 0x74, 0xef, 0xb0, 0xd3, 0xe4, 0x91, 0x45, 0xbc, 0x07, 0xe1, 0x59, 0xb2, 0xc5, 0x76, - 0x77, 0xc3, 0x6b, 0x5f, 0x57, 0xe9, 0x07, 0x04, 0x8b, 0x67, 0x00, 0x8b, 0x2a, 0xb9, 0x90, 0x4b, - 0x3b, 0xa2, 0x44, 0x1f, 0x28, 0x09, 0x65, 0xeb, 0x15, 0x5a, 0x94, 0x67, 0x9c, 0x24, 0x61, 0xa4, - 0x45, 0x58, 0x60, 0xe4, 0x36, 0xc3, 0xa6, 0x51, 0xf5, 0x80, 0xa4, 0x27, 0xf2, 0x3d, 0x12, 0x59, - 0xf7, 0xc4, 0x8a, 0x3c, 0x0e, 0xe0, 0x46, 0xca, 0xf1, 0x2d, 0xd2, 0x90, 0x13, 0xd2, 0xe8, 0x11, - 0x58, 0x64, 0xc1, 0x9b, 0xbb, 0x0b, 0x22, 0x2d, 0xc0, 0x1c, 0x23, 0xf6, 0xa0, 0xed, 0xa8, 0x4d, - 0x4c, 0xe1, 0x4b, 0x04, 0xf3, 0xfd, 0x90, 0x22, 0x81, 0x27, 0x30, 0x96, 0x70, 0x72, 0x0b, 0xf2, - 0x73, 0x09, 0xe4, 0xe3, 0x21, 0x05, 0x67, 0x6c, 0xc7, 0x46, 0xa4, 0x0d, 0x98, 0xfe, 0x20, 0xf0, - 0x88, 0xee, 0x3c, 0x0c, 0xd5, 0xa5, 0x4c, 0xe9, 0xc1, 0x63, 0x7e, 0x7a, 0x47, 0xa7, 0x41, 0xbc, - 0x5b, 0xb3, 0x9d, 0xdd, 0x2a, 0xfd, 0x88, 0xa0, 0x90, 0x16, 0x43, 0xe4, 0xf0, 0x36, 0x5c, 0x11, - 0xa2, 0x20, 0xb6, 0xdc, 0x4c, 0x02, 0x6f, 0x1e, 0x83, 0xbb, 0x46, 0x5b, 0x49, 0x78, 0xe1, 0x59, - 0x18, 0xe1, 0xab, 0x58, 0x23, 0x56, 0xb5, 0x16, 0xb0, 0xad, 0x71, 0x55, 0x1d, 0x66, 0xb6, 0x1d, - 0x66, 0xc2, 0x93, 0x30, 0x44, 0x8e, 0x88, 0xa1, 0x39, 0xd4, 0xe4, 0xbb, 0xe4, 0xaa, 0x3a, 0x18, - 0x1a, 0x76, 0xa9, 0x49, 0xa4, 0xa7, 0x08, 0x46, 0xda, 0xe3, 0xe3, 0xc7, 0x30, 0x4a, 0x23, 0xb6, - 0x42, 0xb0, 0x44, 0x49, 0x4b, 0xa9, 0xd4, 0xba, 0xd2, 0xdb, 0xc9, 0xa8, 0x2f, 0xd3, 0x4e, 0x53, - 0x78, 0x50, 0x33, 0x93, 0x56, 0xb1, 0x6c, 0x5b, 0x1c, 0x69, 0xf3, 0xfd, 0x03, 0xde, 0xb7, 0x6c, - 0x7b, 0x27, 0xa3, 0x0e, 0x31, 0xdf, 0xf0, 0x65, 0x73, 0x14, 0xae, 0x71, 0x56, 0x9a, 0x43, 0x7c, - 0x5f, 0xaf, 0x12, 0xe9, 0x1b, 0x04, 0xe3, 0x89, 0x3c, 0xf0, 0x47, 0xdd, 0xd5, 0xbd, 0xdb, 0x39, - 0xa3, 0xd0, 0x6c, 0x39, 0xae, 0xd0, 0x0f, 0x2b, 0x95, 0xad, 0xd0, 0xc0, 0x03, 0xed, 0xaf, 0x74, - 0x97, 0x3d, 0x0f, 0x83, 0xbe, 0xab, 0xd7, 0xfd, 0x1a, 0xe5, 0x25, 0x1f, 0x54, 0x5b, 0xef, 0xd2, - 0x2f, 0x08, 0xc6, 0x12, 0xd2, 0xc0, 0xeb, 0xc0, 0x9a, 0x83, 0x8b, 0x86, 0xa8, 0xe9, 0x54, 0x8a, - 0xd8, 0x31, 0x51, 0x50, 0x99, 0x36, 0xb2, 0x47, 0x7c, 0x07, 0x2e, 0xb3, 0x1a, 0x84, 0x72, 0x10, - 0x66, 0x92, 0x4b, 0x70, 0x64, 0xd3, 0x09, 0xa6, 0x02, 0x8d, 0x17, 0x60, 0x24, 0xac, 0xb8, 0xa6, - 0x3b, 0xb4, 0xe1, 0x06, 0x7e, 0x2e, 0x5b, 0xcc, 0x96, 0x2e, 0x09, 0xcc, 0x70, 0x38, 0xb2, 0xc1, - 0x07, 0x56, 0x7f, 0x1e, 0x82, 0x97, 0xd8, 0xc6, 0xc3, 0x5f, 0x21, 0x18, 0x8c, 0x04, 0x17, 0x2f, - 0x25, 0xcc, 0x93, 0x72, 0x6b, 0xc9, 0x97, 0xd2, 0xb0, 0xdd, 0xd7, 0x16, 0x69, 0xf1, 0x8b, 0x3f, - 0xfe, 0xfd, 0x6e, 0xe0, 0x35, 0x3c, 0xab, 0xf4, 0xb8, 0x22, 0x2a, 0x9f, 0x5a, 0xe6, 0x67, 0xf8, - 0x6b, 0x04, 0xc3, 0x6d, 0x37, 0x87, 0x74, 0x42, 0xf1, 0x2b, 0x4c, 0xfe, 0x66, 0x3f, 0x42, 0x6d, - 0x57, 0x11, 0xe9, 0x75, 0xc6, 0xa9, 0x80, 0xa7, 0x7a, 0x71, 0xc2, 0xbf, 0x21, 0xc8, 0xa5, 0x49, - 0x20, 0x5e, 0x3d, 0x97, 0x5e, 0x72, 0x8e, 0xb7, 0x2e, 0xa0, 0xb1, 0xd2, 0x1a, 0xe3, 0x7a, 0x7b, - 0x0d, 0x2d, 0x49, 0x8a, 0x92, 0x78, 0x47, 0xd5, 0x5c, 0x6a, 0x12, 0x2d, 0xa0, 0xfc, 0xdf, 0x68, - 0x23, 0xf9, 0x3b, 0x82, 0xa9, 0x5e, 0x6a, 0x84, 0xd7, 0xd3, 0xaa, 0x76, 0x06, 0x2d, 0xcd, 0xbf, - 0x75, 0x31, 0x67, 0x91, 0xd7, 0x3c, 0xcb, 0xab, 0x88, 0x0b, 0x4a, 0xcf, 0xef, 0x02, 0xfc, 0x2b, - 0x82, 0xc9, 0x1e, 0x52, 0x84, 0xd7, 0xd2, 0x58, 0xf4, 0x17, 0xd1, 0xfc, 0xfa, 0x85, 0x7c, 0x45, - 0x02, 0x73, 0x2c, 0x81, 0x19, 0x3c, 0xdd, 0xf3, 0x63, 0x09, 0x3f, 0x45, 0xf0, 0x6a, 0xaa, 0xc0, - 0xe1, 0xbb, 0x69, 0x0c, 0xfa, 0xa9, 0x67, 0xfe, 0xcd, 0x0b, 0x78, 0x0a, 0xe6, 0x32, 0x63, 0x5e, - 0xc2, 0xf3, 0xca, 0x99, 0x3e, 0x90, 0xf0, 0xe7, 0x30, 0x91, 0xac, 0x6d, 0x78, 0xf9, 0xac, 0x3a, - 0x11, 0x49, 0x69, 0x7e, 0xe5, 0x1c, 0x1e, 0x9c, 0xee, 0x32, 0xda, 0xdc, 0x7b, 0x76, 0x52, 0x40, - 0xcf, 0x4f, 0x0a, 0xe8, 0x9f, 0x93, 0x02, 0xfa, 0xf6, 0xb4, 0x90, 0x79, 0x7e, 0x5a, 0xc8, 0xfc, - 0x79, 0x5a, 0xc8, 0x7c, 0x7c, 0xa7, 0x6a, 0x05, 0xb5, 0x46, 0x59, 0x36, 0xa8, 0xd3, 0x99, 0x4c, - 0xf3, 0xf6, 0x1b, 0xec, 0x98, 0x57, 0x5a, 0x96, 0x23, 0x9e, 0x60, 0x70, 0x5c, 0x27, 0x7e, 0xf9, - 0x32, 0x33, 0xdf, 0xfa, 0x3f, 0x00, 0x00, 0xff, 0xff, 0x5c, 0x97, 0xf2, 0x13, 0x7b, 0x0f, 0x00, - 0x00, + // 1407 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x57, 0xcd, 0x6f, 0xdc, 0x44, + 0x14, 0xdf, 0x49, 0x42, 0xbb, 0x79, 0x49, 0xda, 0x32, 0x69, 0xda, 0xad, 0x93, 0x6e, 0x52, 0x43, + 0x93, 0x4d, 0x4a, 0xd7, 0x4d, 0x5a, 0x55, 0xa5, 0x41, 0x45, 0x49, 0x44, 0x3f, 0xa4, 0x86, 0x06, + 0xf7, 0x83, 0x0a, 0x2a, 0x59, 0x5e, 0x7b, 0xd6, 0xb1, 0x6a, 0x7b, 0x36, 0xf6, 0xec, 0x2a, 0x11, + 0x42, 0x48, 0x1c, 0xb8, 0x00, 0x12, 0x12, 0x07, 0x0e, 0x48, 0x48, 0x88, 0x3f, 0x01, 0x71, 0x44, + 0x94, 0x5b, 0x8f, 0x95, 0xb8, 0x70, 0x40, 0x08, 0xb5, 0x9c, 0xf9, 0x1b, 0x90, 0x67, 0xc6, 0x9b, + 0xdd, 0xd8, 0xde, 0x4d, 0x72, 0xd9, 0xb5, 0xdf, 0xbc, 0x8f, 0xdf, 0x7b, 0xf3, 0x9b, 0x79, 0xcf, + 0x70, 0xd6, 0xde, 0xb1, 0xb7, 0x1b, 0x21, 0x65, 0xd4, 0xa2, 0x9e, 0x66, 0x79, 0xb4, 0xa6, 0x6d, + 0x35, 0x49, 0xb8, 0x53, 0xe5, 0x32, 0xfc, 0x7a, 0xe7, 0x72, 0x35, 0x5e, 0x56, 0x4e, 0x3a, 0xd4, + 0xa1, 0x5c, 0xa4, 0xc5, 0x4f, 0x42, 0x51, 0x99, 0x72, 0x28, 0x75, 0x3c, 0xa2, 0x99, 0x0d, 0x57, + 0x33, 0x83, 0x80, 0x32, 0x93, 0xb9, 0x34, 0x88, 0xe4, 0xea, 0x82, 0x45, 0x23, 0x9f, 0x46, 0x5a, + 0xcd, 0x8c, 0x88, 0xf0, 0xaf, 0xb5, 0x16, 0x6b, 0x84, 0x99, 0x8b, 0x5a, 0xc3, 0x74, 0xdc, 0x80, + 0x2b, 0x4b, 0x5d, 0x2d, 0x8d, 0xa8, 0xe6, 0x51, 0xeb, 0xa9, 0x11, 0x9a, 0x8c, 0x18, 0x9e, 0xeb, + 0xbb, 0xcc, 0xb0, 0x68, 0x50, 0x77, 0x1d, 0x69, 0x70, 0x2e, 0x6d, 0x10, 0xff, 0x18, 0x0d, 0xd3, + 0x0d, 0xa5, 0xca, 0xa5, 0xb4, 0x0a, 0xd9, 0x6a, 0xba, 0x6c, 0xc7, 0x60, 0x2e, 0x09, 0xb3, 0x9c, + 0x66, 0xd4, 0x85, 0x86, 0x36, 0x49, 0x1c, 0x4e, 0xa7, 0x97, 0x7d, 0x93, 0x59, 0x9b, 0x24, 0xc9, + 0xf8, 0x42, 0x5a, 0xc1, 0x73, 0xb7, 0x9a, 0xae, 0x2d, 0xea, 0xd2, 0x1d, 0x6c, 0x32, 0xc3, 0x1b, + 0x69, 0xc9, 0xc5, 0x1b, 0x5d, 0x8b, 0x6e, 0x60, 0x93, 0x6d, 0x12, 0x6a, 0xb4, 0x5e, 0x37, 0xac, + 0x4d, 0xd3, 0x0d, 0x8c, 0x66, 0xc3, 0x36, 0x19, 0x89, 0xd2, 0x12, 0x61, 0xaf, 0xce, 0xc3, 0xe9, + 0x0f, 0xe2, 0x8a, 0xdf, 0x22, 0x6c, 0xcd, 0xa3, 0xb5, 0x0d, 0xd3, 0x0d, 0x75, 0xb2, 0xd5, 0x24, + 0x11, 0xc3, 0xc7, 0x60, 0xc0, 0xb5, 0x4b, 0x68, 0x06, 0x55, 0xc6, 0xf4, 0x01, 0xd7, 0x56, 0x3f, + 0x84, 0x09, 0xae, 0xba, 0xab, 0x17, 0x35, 0x68, 0x10, 0x11, 0x7c, 0x03, 0x86, 0xdb, 0x25, 0xe5, + 0xfa, 0x23, 0x4b, 0x93, 0xd5, 0x14, 0x35, 0xaa, 0x89, 0xdd, 0xea, 0xd0, 0xf3, 0xbf, 0xa7, 0x0b, + 0x7a, 0xd1, 0x92, 0xef, 0xaa, 0x29, 0x31, 0xac, 0x78, 0xde, 0x5e, 0x0c, 0x37, 0x01, 0x76, 0x29, + 0x20, 0x7d, 0xcf, 0x56, 0x05, 0x5f, 0xaa, 0x31, 0x5f, 0xaa, 0x82, 0x8f, 0x92, 0x2f, 0xd5, 0x0d, + 0xd3, 0x21, 0xd2, 0x56, 0xef, 0xb0, 0x54, 0x7f, 0x42, 0x50, 0xea, 0x02, 0xbf, 0xe2, 0x79, 0x79, + 0xf8, 0x07, 0x0f, 0x88, 0x1f, 0xdf, 0xea, 0x02, 0x39, 0xc0, 0x41, 0xce, 0xf5, 0x05, 0x29, 0x82, + 0x77, 0xa1, 0xfc, 0x0b, 0xc1, 0xf4, 0x3a, 0x69, 0xbd, 0x4f, 0x6d, 0xf2, 0x80, 0xc6, 0xbf, 0x6b, + 0xa6, 0x67, 0x35, 0x3d, 0xbe, 0x98, 0x54, 0xe4, 0x09, 0x9c, 0x12, 0x84, 0x6f, 0x84, 0xb4, 0x41, + 0x23, 0x12, 0x1a, 0x92, 0x5a, 0xed, 0xea, 0xa4, 0x91, 0x3f, 0x32, 0xbd, 0x98, 0x5a, 0x34, 0x5c, + 0x27, 0xad, 0x75, 0xa1, 0xad, 0x9f, 0xe4, 0x5e, 0x36, 0xa4, 0x13, 0x29, 0xc5, 0x1f, 0xc3, 0x44, + 0x2b, 0x51, 0x36, 0x7c, 0xd2, 0x32, 0x7c, 0xc2, 0x42, 0xd7, 0x8a, 0xda, 0x59, 0xa5, 0x9d, 0x77, + 0x01, 0x5e, 0x17, 0xea, 0xfa, 0x78, 0xab, 0x33, 0xa4, 0x10, 0xaa, 0xff, 0x21, 0x98, 0xc9, 0x4f, + 0x4f, 0x6e, 0x86, 0x03, 0x47, 0x43, 0x12, 0x35, 0x3d, 0x16, 0xc9, 0xad, 0xb8, 0xd5, 0x2f, 0x66, + 0x86, 0x97, 0x58, 0x61, 0x25, 0xb0, 0x1f, 0x51, 0xaf, 0xe9, 0x93, 0x0d, 0x12, 0xc6, 0x5b, 0x27, + 0xb7, 0x2d, 0xf1, 0xae, 0x98, 0x30, 0x9e, 0xa1, 0x85, 0x67, 0x60, 0xb4, 0x4d, 0x06, 0xa3, 0xcd, + 0x7f, 0x48, 0x36, 0xfb, 0x8e, 0x8d, 0x4f, 0xc0, 0xa0, 0x4f, 0x5a, 0xbc, 0x22, 0x03, 0x7a, 0xfc, + 0x88, 0x4f, 0xc1, 0x91, 0x16, 0x77, 0x52, 0x1a, 0x9c, 0x41, 0x95, 0x21, 0x5d, 0xbe, 0xa9, 0x0b, + 0x50, 0xe1, 0xa4, 0x7b, 0x8f, 0xdf, 0x26, 0x0f, 0x5c, 0x12, 0xde, 0x8d, 0xef, 0x92, 0x35, 0x7e, + 0xba, 0x9b, 0x61, 0xe7, 0xbe, 0xaa, 0xdf, 0x23, 0x98, 0xdf, 0x87, 0xb2, 0xac, 0x52, 0x00, 0xa5, + 0xbc, 0x2b, 0x4a, 0xf2, 0x40, 0xcb, 0x28, 0x5b, 0x2f, 0xd7, 0xb2, 0x3c, 0x13, 0x24, 0x4b, 0x47, + 0x9d, 0x87, 0x39, 0x0e, 0x6e, 0x35, 0x26, 0x8d, 0x6e, 0x32, 0x92, 0x9f, 0xc8, 0x77, 0x48, 0x66, + 0xdd, 0x53, 0x57, 0xe6, 0xf1, 0x14, 0x4e, 0xe7, 0x5c, 0xdf, 0x32, 0x8d, 0x6a, 0x46, 0x1a, 0x3d, + 0x1c, 0xcb, 0x2c, 0x04, 0xb9, 0xf7, 0xa8, 0xa8, 0x8f, 0xe1, 0x0c, 0x07, 0x76, 0x9f, 0x99, 0x8c, + 0xd4, 0x9b, 0xde, 0xbd, 0xf8, 0xca, 0x4e, 0xce, 0xd5, 0x32, 0x14, 0xf9, 0x15, 0x9e, 0xec, 0xf9, + 0xc8, 0x92, 0x92, 0x11, 0x9a, 0x9b, 0xdc, 0xb1, 0x13, 0x2e, 0x51, 0xf1, 0xaa, 0xfe, 0x82, 0x40, + 0xc9, 0x72, 0x2d, 0xb3, 0x7c, 0x0c, 0xc7, 0x85, 0xef, 0x86, 0x67, 0x5a, 0xc4, 0x27, 0x01, 0x93, + 0x21, 0xe6, 0x33, 0x42, 0xdc, 0xa5, 0x81, 0xf3, 0x80, 0x84, 0x3e, 0x77, 0xb1, 0x91, 0x18, 0xc8, + 0x88, 0xc7, 0x68, 0x97, 0x14, 0x4f, 0xc3, 0x48, 0xdd, 0xf5, 0x3c, 0xc3, 0xf4, 0x69, 0x33, 0x60, + 0x9c, 0x93, 0x43, 0x3a, 0xc4, 0xa2, 0x15, 0x2e, 0xc1, 0x53, 0x30, 0xcc, 0x42, 0xd7, 0x71, 0x48, + 0x48, 0x6c, 0xce, 0xce, 0xa2, 0xbe, 0x2b, 0x50, 0xe7, 0xe0, 0x3c, 0x87, 0x7d, 0xb7, 0xa3, 0xf9, + 0x64, 0x6e, 0xea, 0x17, 0x08, 0x66, 0xfb, 0x69, 0xca, 0x64, 0x9f, 0xc0, 0x78, 0x46, 0x2f, 0x93, + 0x09, 0x9f, 0xcf, 0x4a, 0x38, 0xe5, 0x52, 0x26, 0x8b, 0xbd, 0xd4, 0x8a, 0xba, 0x02, 0x67, 0xef, + 0xb3, 0x90, 0x98, 0xa2, 0x3c, 0x35, 0x4a, 0x9f, 0x3e, 0x14, 0xfd, 0x2c, 0xd9, 0xc7, 0xf4, 0xf9, + 0x1d, 0xec, 0x3e, 0xbf, 0xea, 0x8f, 0x08, 0xca, 0x79, 0x3e, 0x64, 0x0e, 0xef, 0xc2, 0x51, 0xd9, + 0x26, 0xe5, 0x25, 0x34, 0x9d, 0x81, 0x5b, 0xf8, 0x10, 0xa6, 0x09, 0x21, 0xa4, 0x15, 0x3e, 0x07, + 0xa3, 0x82, 0xd7, 0x9b, 0xc4, 0x75, 0x36, 0xc5, 0xc6, 0x8c, 0xe9, 0x23, 0x5c, 0x76, 0x9b, 0x8b, + 0xf0, 0x24, 0x0c, 0x93, 0x6d, 0x62, 0x19, 0x3e, 0xb5, 0xc5, 0xbd, 0x31, 0xa6, 0x17, 0x63, 0xc1, + 0x3a, 0xb5, 0x89, 0xfa, 0x0c, 0xc1, 0x68, 0xa7, 0x7f, 0xfc, 0x10, 0x4e, 0xd0, 0x04, 0xad, 0x6c, + 0xe1, 0xb2, 0xa4, 0x95, 0x5c, 0x68, 0x7b, 0xd2, 0xbb, 0x5d, 0xd0, 0x8f, 0xd3, 0x6e, 0x51, 0xdc, + 0xba, 0x04, 0x33, 0x63, 0xca, 0xc8, 0x4b, 0x7e, 0xb6, 0xbf, 0xc3, 0x9b, 0xae, 0xe7, 0xdd, 0x2e, + 0xe8, 0xc3, 0xdc, 0x36, 0x7e, 0x59, 0x3d, 0x01, 0xc7, 0x04, 0x2a, 0xc3, 0x27, 0x51, 0x64, 0x3a, + 0x44, 0xfd, 0x1a, 0xc1, 0x44, 0x26, 0x0e, 0xfc, 0x78, 0x6f, 0x75, 0xaf, 0x75, 0x47, 0x94, 0x53, + 0x4c, 0x35, 0x3d, 0xb3, 0xdc, 0xab, 0xd7, 0xd7, 0x62, 0x81, 0x70, 0xf4, 0x68, 0x71, 0x6f, 0xd9, + 0x15, 0x28, 0x46, 0x81, 0xd9, 0x88, 0x36, 0xa9, 0x28, 0x79, 0x51, 0x6f, 0xbf, 0xab, 0x3f, 0x23, + 0x18, 0xcf, 0x48, 0x03, 0x2f, 0x03, 0x27, 0x87, 0x68, 0xa3, 0xb2, 0xa6, 0x53, 0x39, 0xed, 0x9f, + 0xb7, 0x49, 0x9d, 0x4f, 0x0b, 0xfc, 0x11, 0x5f, 0x85, 0x23, 0xbc, 0x06, 0x71, 0x83, 0x8c, 0x33, + 0x29, 0xe5, 0xdd, 0x19, 0x12, 0xa9, 0xd4, 0xc6, 0x73, 0x30, 0xda, 0x71, 0x6e, 0xa3, 0xd2, 0xe0, + 0xcc, 0x60, 0x65, 0x48, 0xea, 0x8c, 0xec, 0x1e, 0xdf, 0x68, 0xe9, 0x07, 0x80, 0xd7, 0xf8, 0xc1, + 0xc3, 0x5f, 0x22, 0x28, 0x26, 0x23, 0x08, 0x5e, 0xc8, 0x88, 0x93, 0x33, 0xc7, 0x29, 0x95, 0x3c, + 0xdd, 0xbd, 0x83, 0x9c, 0x3a, 0xff, 0xf9, 0x1f, 0xff, 0x7e, 0x3b, 0xf0, 0x06, 0x3e, 0xa7, 0xf5, + 0x18, 0x9a, 0xb5, 0x4f, 0x5c, 0xfb, 0x53, 0xfc, 0x15, 0x82, 0x91, 0x8e, 0x59, 0x2a, 0x1f, 0x50, + 0x7a, 0xa8, 0x53, 0x2e, 0xf4, 0x03, 0xd4, 0x31, 0x9c, 0xa9, 0x6f, 0x72, 0x4c, 0x65, 0x3c, 0xd5, + 0x0b, 0x13, 0xfe, 0x0d, 0x41, 0x29, 0x6f, 0x28, 0xc0, 0x4b, 0x07, 0x9a, 0x20, 0x04, 0xc6, 0xcb, + 0x87, 0x98, 0x3a, 0xd4, 0xeb, 0x1c, 0xeb, 0x95, 0xeb, 0x68, 0x41, 0xd5, 0xb4, 0xcc, 0xa9, 0xdd, + 0x08, 0xa8, 0x4d, 0x0c, 0x46, 0xc5, 0xbf, 0xd5, 0x01, 0xf2, 0x77, 0x04, 0x53, 0xbd, 0xfa, 0x33, + 0x5e, 0xce, 0xab, 0xda, 0x3e, 0xa6, 0x0b, 0xe5, 0x9d, 0xc3, 0x19, 0xcb, 0xbc, 0x66, 0x79, 0x5e, + 0x33, 0xb8, 0xac, 0xf5, 0xfc, 0x52, 0xc2, 0xbf, 0x22, 0x98, 0xec, 0xd1, 0x9c, 0xf1, 0xf5, 0x3c, + 0x14, 0xfd, 0xc7, 0x0a, 0x65, 0xf9, 0x50, 0xb6, 0x32, 0x81, 0xf3, 0x3c, 0x81, 0x69, 0x7c, 0xb6, + 0xe7, 0xe7, 0x23, 0x7e, 0x86, 0xe0, 0x4c, 0x6e, 0x83, 0xc3, 0xd7, 0xf2, 0x10, 0xf4, 0xeb, 0x9e, + 0xca, 0xdb, 0x87, 0xb0, 0x94, 0xc8, 0xab, 0x1c, 0x79, 0x05, 0xcf, 0x6a, 0xfb, 0xfa, 0x64, 0xc4, + 0x01, 0x8c, 0x75, 0xcd, 0x20, 0xf8, 0xad, 0xbc, 0xd8, 0x59, 0x53, 0x90, 0x72, 0x71, 0x9f, 0xda, + 0x12, 0x5d, 0x01, 0x7f, 0x06, 0xa7, 0xb2, 0x7b, 0x29, 0xbe, 0xb4, 0xdf, 0xbe, 0x94, 0xb4, 0x6e, + 0x65, 0xf1, 0x00, 0x16, 0x02, 0xc0, 0x25, 0xb4, 0xba, 0xf1, 0xfc, 0x65, 0x19, 0xbd, 0x78, 0x59, + 0x46, 0xff, 0xbc, 0x2c, 0xa3, 0x6f, 0x5e, 0x95, 0x0b, 0x2f, 0x5e, 0x95, 0x0b, 0x7f, 0xbe, 0x2a, + 0x17, 0x3e, 0xba, 0xea, 0xb8, 0x6c, 0xb3, 0x59, 0xab, 0x5a, 0xd4, 0xef, 0x2e, 0x5e, 0xeb, 0xca, + 0x45, 0xde, 0x56, 0xb4, 0xb6, 0x64, 0x5b, 0x14, 0x94, 0xed, 0x34, 0x48, 0x54, 0x3b, 0xc2, 0xc5, + 0x97, 0xff, 0x0f, 0x00, 0x00, 0xff, 0xff, 0x63, 0x36, 0x67, 0x96, 0xfd, 0x10, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -1117,6 +1237,8 @@ type QueryClient interface { BlockRateLimitConfiguration(ctx context.Context, in *QueryBlockRateLimitConfigurationRequest, opts ...grpc.CallOption) (*QueryBlockRateLimitConfigurationResponse, error) // Queries LiquidationsConfiguration. LiquidationsConfiguration(ctx context.Context, in *QueryLiquidationsConfigurationRequest, opts ...grpc.CallOption) (*QueryLiquidationsConfigurationResponse, error) + // Queries the stateful order for a given order id. + StatefulOrder(ctx context.Context, in *QueryStatefulOrderRequest, opts ...grpc.CallOption) (*QueryStatefulOrderResponse, error) // Streams orderbook updates. Updates contain orderbook data // such as order placements, updates, and fills. StreamOrderbookUpdates(ctx context.Context, in *StreamOrderbookUpdatesRequest, opts ...grpc.CallOption) (Query_StreamOrderbookUpdatesClient, error) @@ -1184,6 +1306,15 @@ func (c *queryClient) LiquidationsConfiguration(ctx context.Context, in *QueryLi return out, nil } +func (c *queryClient) StatefulOrder(ctx context.Context, in *QueryStatefulOrderRequest, opts ...grpc.CallOption) (*QueryStatefulOrderResponse, error) { + out := new(QueryStatefulOrderResponse) + err := c.cc.Invoke(ctx, "/dydxprotocol.clob.Query/StatefulOrder", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + func (c *queryClient) StreamOrderbookUpdates(ctx context.Context, in *StreamOrderbookUpdatesRequest, opts ...grpc.CallOption) (Query_StreamOrderbookUpdatesClient, error) { stream, err := c.cc.NewStream(ctx, &_Query_serviceDesc.Streams[0], "/dydxprotocol.clob.Query/StreamOrderbookUpdates", opts...) if err != nil { @@ -1230,6 +1361,8 @@ type QueryServer interface { BlockRateLimitConfiguration(context.Context, *QueryBlockRateLimitConfigurationRequest) (*QueryBlockRateLimitConfigurationResponse, error) // Queries LiquidationsConfiguration. LiquidationsConfiguration(context.Context, *QueryLiquidationsConfigurationRequest) (*QueryLiquidationsConfigurationResponse, error) + // Queries the stateful order for a given order id. + StatefulOrder(context.Context, *QueryStatefulOrderRequest) (*QueryStatefulOrderResponse, error) // Streams orderbook updates. Updates contain orderbook data // such as order placements, updates, and fills. StreamOrderbookUpdates(*StreamOrderbookUpdatesRequest, Query_StreamOrderbookUpdatesServer) error @@ -1257,6 +1390,9 @@ func (*UnimplementedQueryServer) BlockRateLimitConfiguration(ctx context.Context func (*UnimplementedQueryServer) LiquidationsConfiguration(ctx context.Context, req *QueryLiquidationsConfigurationRequest) (*QueryLiquidationsConfigurationResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method LiquidationsConfiguration not implemented") } +func (*UnimplementedQueryServer) StatefulOrder(ctx context.Context, req *QueryStatefulOrderRequest) (*QueryStatefulOrderResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method StatefulOrder not implemented") +} func (*UnimplementedQueryServer) StreamOrderbookUpdates(req *StreamOrderbookUpdatesRequest, srv Query_StreamOrderbookUpdatesServer) error { return status.Errorf(codes.Unimplemented, "method StreamOrderbookUpdates not implemented") } @@ -1373,6 +1509,24 @@ func _Query_LiquidationsConfiguration_Handler(srv interface{}, ctx context.Conte return interceptor(ctx, in, info, handler) } +func _Query_StatefulOrder_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(QueryStatefulOrderRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(QueryServer).StatefulOrder(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/dydxprotocol.clob.Query/StatefulOrder", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(QueryServer).StatefulOrder(ctx, req.(*QueryStatefulOrderRequest)) + } + return interceptor(ctx, in, info, handler) +} + func _Query_StreamOrderbookUpdates_Handler(srv interface{}, stream grpc.ServerStream) error { m := new(StreamOrderbookUpdatesRequest) if err := stream.RecvMsg(m); err != nil { @@ -1422,6 +1576,10 @@ var _Query_serviceDesc = grpc.ServiceDesc{ MethodName: "LiquidationsConfiguration", Handler: _Query_LiquidationsConfiguration_Handler, }, + { + MethodName: "StatefulOrder", + Handler: _Query_StatefulOrder_Handler, + }, }, Streams: []grpc.StreamDesc{ { @@ -1813,6 +1971,87 @@ func (m *QueryBlockRateLimitConfigurationResponse) MarshalToSizedBuffer(dAtA []b return len(dAtA) - i, nil } +func (m *QueryStatefulOrderRequest) 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 *QueryStatefulOrderRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryStatefulOrderRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + { + size, err := m.OrderId.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintQuery(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + +func (m *QueryStatefulOrderResponse) 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 *QueryStatefulOrderResponse) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryStatefulOrderResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.Triggered { + i-- + if m.Triggered { + dAtA[i] = 1 + } else { + dAtA[i] = 0 + } + i-- + dAtA[i] = 0x18 + } + if m.FillAmount != 0 { + i = encodeVarintQuery(dAtA, i, uint64(m.FillAmount)) + i-- + dAtA[i] = 0x10 + } + { + size, err := m.OrderPlacement.MarshalToSizedBuffer(dAtA[:i]) + if err != nil { + return 0, err + } + i -= size + i = encodeVarintQuery(dAtA, i, uint64(size)) + } + i-- + dAtA[i] = 0xa + return len(dAtA) - i, nil +} + func (m *QueryLiquidationsConfigurationRequest) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) @@ -1890,20 +2129,20 @@ func (m *StreamOrderbookUpdatesRequest) MarshalToSizedBuffer(dAtA []byte) (int, var l int _ = l if len(m.ClobPairId) > 0 { - dAtA10 := make([]byte, len(m.ClobPairId)*10) - var j9 int + dAtA12 := make([]byte, len(m.ClobPairId)*10) + var j11 int for _, num := range m.ClobPairId { for num >= 1<<7 { - dAtA10[j9] = uint8(uint64(num)&0x7f | 0x80) + dAtA12[j11] = uint8(uint64(num)&0x7f | 0x80) num >>= 7 - j9++ + j11++ } - dAtA10[j9] = uint8(num) - j9++ + dAtA12[j11] = uint8(num) + j11++ } - i -= j9 - copy(dAtA[i:], dAtA10[:j9]) - i = encodeVarintQuery(dAtA, i, uint64(j9)) + i -= j11 + copy(dAtA[i:], dAtA12[:j11]) + i = encodeVarintQuery(dAtA, i, uint64(j11)) i-- dAtA[i] = 0xa } @@ -2099,20 +2338,20 @@ func (m *StreamOrderbookFill) MarshalToSizedBuffer(dAtA []byte) (int, error) { var l int _ = l if len(m.FillAmounts) > 0 { - dAtA14 := make([]byte, len(m.FillAmounts)*10) - var j13 int + dAtA16 := make([]byte, len(m.FillAmounts)*10) + var j15 int for _, num := range m.FillAmounts { for num >= 1<<7 { - dAtA14[j13] = uint8(uint64(num)&0x7f | 0x80) + dAtA16[j15] = uint8(uint64(num)&0x7f | 0x80) num >>= 7 - j13++ + j15++ } - dAtA14[j13] = uint8(num) - j13++ + dAtA16[j15] = uint8(num) + j15++ } - i -= j13 - copy(dAtA[i:], dAtA14[:j13]) - i = encodeVarintQuery(dAtA, i, uint64(j13)) + i -= j15 + copy(dAtA[i:], dAtA16[:j15]) + i = encodeVarintQuery(dAtA, i, uint64(j15)) i-- dAtA[i] = 0x1a } @@ -2301,6 +2540,34 @@ func (m *QueryBlockRateLimitConfigurationResponse) Size() (n int) { return n } +func (m *QueryStatefulOrderRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.OrderId.Size() + n += 1 + l + sovQuery(uint64(l)) + return n +} + +func (m *QueryStatefulOrderResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + l = m.OrderPlacement.Size() + n += 1 + l + sovQuery(uint64(l)) + if m.FillAmount != 0 { + n += 1 + sovQuery(uint64(m.FillAmount)) + } + if m.Triggered { + n += 2 + } + return n +} + func (m *QueryLiquidationsConfigurationRequest) Size() (n int) { if m == nil { return 0 @@ -3373,6 +3640,211 @@ func (m *QueryBlockRateLimitConfigurationResponse) Unmarshal(dAtA []byte) error } return nil } +func (m *QueryStatefulOrderRequest) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: QueryStatefulOrderRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: QueryStatefulOrderRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field OrderId", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthQuery + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthQuery + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.OrderId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + default: + iNdEx = preIndex + skippy, err := skipQuery(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthQuery + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *QueryStatefulOrderResponse) Unmarshal(dAtA []byte) error { + l := len(dAtA) + iNdEx := 0 + for iNdEx < l { + preIndex := iNdEx + var wire uint64 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + wire |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + fieldNum := int32(wire >> 3) + wireType := int(wire & 0x7) + if wireType == 4 { + return fmt.Errorf("proto: QueryStatefulOrderResponse: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: QueryStatefulOrderResponse: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field OrderPlacement", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthQuery + } + postIndex := iNdEx + msglen + if postIndex < 0 { + return ErrInvalidLengthQuery + } + if postIndex > l { + return io.ErrUnexpectedEOF + } + if err := m.OrderPlacement.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex + case 2: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field FillAmount", wireType) + } + m.FillAmount = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.FillAmount |= uint64(b&0x7F) << shift + if b < 0x80 { + break + } + } + case 3: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field Triggered", wireType) + } + var v int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + v |= int(b&0x7F) << shift + if b < 0x80 { + break + } + } + m.Triggered = bool(v != 0) + default: + iNdEx = preIndex + skippy, err := skipQuery(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthQuery + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func (m *QueryLiquidationsConfigurationRequest) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0