diff --git a/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.lcd.ts b/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.lcd.ts index 4ef2949724..034cbad3db 100644 --- a/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.lcd.ts +++ b/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.lcd.ts @@ -1,6 +1,6 @@ import { setPaginationParams } from "../../helpers"; import { LCDClient } from "@osmonauts/lcd"; -import { QueryGetClobPairRequest, QueryClobPairResponseSDKType, QueryAllClobPairRequest, QueryClobPairAllResponseSDKType, QueryEquityTierLimitConfigurationRequest, QueryEquityTierLimitConfigurationResponseSDKType, QueryBlockRateLimitConfigurationRequest, QueryBlockRateLimitConfigurationResponseSDKType, QueryLiquidationsConfigurationRequest, QueryLiquidationsConfigurationResponseSDKType } from "./query"; +import { QueryGetClobPairRequest, QueryClobPairResponseSDKType, QueryAllClobPairRequest, QueryClobPairAllResponseSDKType, QueryEquityTierLimitConfigurationRequest, QueryEquityTierLimitConfigurationResponseSDKType, QueryBlockRateLimitConfigurationRequest, QueryBlockRateLimitConfigurationResponseSDKType, QueryLiquidationsConfigurationRequest, QueryLiquidationsConfigurationResponseSDKType, QueryNextClobPairIdRequest, QueryNextClobPairIdResponseSDKType } from "./query"; export class LCDQueryClient { req: LCDClient; @@ -15,6 +15,7 @@ export class LCDQueryClient { this.equityTierLimitConfiguration = this.equityTierLimitConfiguration.bind(this); this.blockRateLimitConfiguration = this.blockRateLimitConfiguration.bind(this); this.liquidationsConfiguration = this.liquidationsConfiguration.bind(this); + this.nextClobPairId = this.nextClobPairId.bind(this); } /* Queries a ClobPair by id. */ @@ -61,5 +62,12 @@ export class LCDQueryClient { const endpoint = `dydxprotocol/clob/liquidations_config`; return await this.req.get(endpoint); } + /* Queries the next clob pair id. */ + + + async nextClobPairId(_params: QueryNextClobPairIdRequest = {}): Promise { + const endpoint = `dydxprotocol/clob/next_clob_pair_id`; + return await this.req.get(endpoint); + } } \ No newline at end of file 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 5f49481ef3..5c87afce0f 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, QueryStatefulOrderRequest, QueryStatefulOrderResponse, StreamOrderbookUpdatesRequest, StreamOrderbookUpdatesResponse } from "./query"; +import { QueryGetClobPairRequest, QueryClobPairResponse, QueryAllClobPairRequest, QueryClobPairAllResponse, MevNodeToNodeCalculationRequest, MevNodeToNodeCalculationResponse, QueryEquityTierLimitConfigurationRequest, QueryEquityTierLimitConfigurationResponse, QueryBlockRateLimitConfigurationRequest, QueryBlockRateLimitConfigurationResponse, QueryLiquidationsConfigurationRequest, QueryLiquidationsConfigurationResponse, QueryStatefulOrderRequest, QueryStatefulOrderResponse, QueryNextClobPairIdRequest, QueryNextClobPairIdResponse, StreamOrderbookUpdatesRequest, StreamOrderbookUpdatesResponse } from "./query"; /** Query defines the gRPC querier service. */ export interface Query { @@ -25,6 +25,9 @@ export interface Query { /** Queries the stateful order for a given order id. */ statefulOrder(request: QueryStatefulOrderRequest): Promise; + /** Queries the next clob pair id. */ + + nextClobPairId(request?: QueryNextClobPairIdRequest): Promise; /** * Streams orderbook updates. Updates contain orderbook data * such as order placements, updates, and fills. @@ -44,6 +47,7 @@ export class QueryClientImpl implements Query { this.blockRateLimitConfiguration = this.blockRateLimitConfiguration.bind(this); this.liquidationsConfiguration = this.liquidationsConfiguration.bind(this); this.statefulOrder = this.statefulOrder.bind(this); + this.nextClobPairId = this.nextClobPairId.bind(this); this.streamOrderbookUpdates = this.streamOrderbookUpdates.bind(this); } @@ -91,6 +95,12 @@ export class QueryClientImpl implements Query { return promise.then(data => QueryStatefulOrderResponse.decode(new _m0.Reader(data))); } + nextClobPairId(request: QueryNextClobPairIdRequest = {}): Promise { + const data = QueryNextClobPairIdRequest.encode(request).finish(); + const promise = this.rpc.request("dydxprotocol.clob.Query", "NextClobPairId", data); + return promise.then(data => QueryNextClobPairIdResponse.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); @@ -130,6 +140,10 @@ export const createRpcQueryExtension = (base: QueryClient) => { return queryService.statefulOrder(request); }, + nextClobPairId(request?: QueryNextClobPairIdRequest): Promise { + return queryService.nextClobPairId(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 acd5104528..b603256197 100644 --- a/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.ts +++ b/indexer/packages/v4-protos/src/codegen/dydxprotocol/clob/query.ts @@ -246,6 +246,24 @@ export interface QueryLiquidationsConfigurationResponse { export interface QueryLiquidationsConfigurationResponseSDKType { liquidations_config?: LiquidationsConfigSDKType; } +/** QueryNextClobPairIdRequest is a request message for the next clob pair id */ + +export interface QueryNextClobPairIdRequest {} +/** QueryNextClobPairIdRequest is a request message for the next clob pair id */ + +export interface QueryNextClobPairIdRequestSDKType {} +/** QueryNextClobPairIdResponse is a response message for the next clob pair id */ + +export interface QueryNextClobPairIdResponse { + /** QueryNextClobPairIdResponse is a response message for the next clob pair id */ + nextClobPairId: number; +} +/** QueryNextClobPairIdResponse is a response message for the next clob pair id */ + +export interface QueryNextClobPairIdResponseSDKType { + /** QueryNextClobPairIdResponse is a response message for the next clob pair id */ + next_clob_pair_id: number; +} /** * StreamOrderbookUpdatesRequest is a request message for the * StreamOrderbookUpdates method. @@ -1197,6 +1215,85 @@ export const QueryLiquidationsConfigurationResponse = { }; +function createBaseQueryNextClobPairIdRequest(): QueryNextClobPairIdRequest { + return {}; +} + +export const QueryNextClobPairIdRequest = { + encode(_: QueryNextClobPairIdRequest, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer { + return writer; + }, + + decode(input: _m0.Reader | Uint8Array, length?: number): QueryNextClobPairIdRequest { + const reader = input instanceof _m0.Reader ? input : new _m0.Reader(input); + let end = length === undefined ? reader.len : reader.pos + length; + const message = createBaseQueryNextClobPairIdRequest(); + + while (reader.pos < end) { + const tag = reader.uint32(); + + switch (tag >>> 3) { + default: + reader.skipType(tag & 7); + break; + } + } + + return message; + }, + + fromPartial(_: DeepPartial): QueryNextClobPairIdRequest { + const message = createBaseQueryNextClobPairIdRequest(); + return message; + } + +}; + +function createBaseQueryNextClobPairIdResponse(): QueryNextClobPairIdResponse { + return { + nextClobPairId: 0 + }; +} + +export const QueryNextClobPairIdResponse = { + encode(message: QueryNextClobPairIdResponse, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer { + if (message.nextClobPairId !== 0) { + writer.uint32(8).uint32(message.nextClobPairId); + } + + return writer; + }, + + decode(input: _m0.Reader | Uint8Array, length?: number): QueryNextClobPairIdResponse { + const reader = input instanceof _m0.Reader ? input : new _m0.Reader(input); + let end = length === undefined ? reader.len : reader.pos + length; + const message = createBaseQueryNextClobPairIdResponse(); + + while (reader.pos < end) { + const tag = reader.uint32(); + + switch (tag >>> 3) { + case 1: + message.nextClobPairId = reader.uint32(); + break; + + default: + reader.skipType(tag & 7); + break; + } + } + + return message; + }, + + fromPartial(object: DeepPartial): QueryNextClobPairIdResponse { + const message = createBaseQueryNextClobPairIdResponse(); + message.nextClobPairId = object.nextClobPairId ?? 0; + return message; + } + +}; + function createBaseStreamOrderbookUpdatesRequest(): StreamOrderbookUpdatesRequest { return { clobPairId: [], diff --git a/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.lcd.ts b/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.lcd.ts index bf75ee98d4..a0bdc49c4b 100644 --- a/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.lcd.ts +++ b/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.lcd.ts @@ -1,6 +1,6 @@ import { setPaginationParams } from "../../helpers"; import { LCDClient } from "@osmonauts/lcd"; -import { QueryPerpetualRequest, QueryPerpetualResponseSDKType, QueryAllPerpetualsRequest, QueryAllPerpetualsResponseSDKType, QueryAllLiquidityTiersRequest, QueryAllLiquidityTiersResponseSDKType, QueryPremiumVotesRequest, QueryPremiumVotesResponseSDKType, QueryPremiumSamplesRequest, QueryPremiumSamplesResponseSDKType, QueryParamsRequest, QueryParamsResponseSDKType } from "./query"; +import { QueryPerpetualRequest, QueryPerpetualResponseSDKType, QueryAllPerpetualsRequest, QueryAllPerpetualsResponseSDKType, QueryAllLiquidityTiersRequest, QueryAllLiquidityTiersResponseSDKType, QueryPremiumVotesRequest, QueryPremiumVotesResponseSDKType, QueryPremiumSamplesRequest, QueryPremiumSamplesResponseSDKType, QueryParamsRequest, QueryParamsResponseSDKType, QueryNextPerpetualIdRequest, QueryNextPerpetualIdResponseSDKType } from "./query"; export class LCDQueryClient { req: LCDClient; @@ -16,6 +16,7 @@ export class LCDQueryClient { this.premiumVotes = this.premiumVotes.bind(this); this.premiumSamples = this.premiumSamples.bind(this); this.params = this.params.bind(this); + this.nextPerpetualId = this.nextPerpetualId.bind(this); } /* Queries a Perpetual by id. */ @@ -79,5 +80,12 @@ export class LCDQueryClient { const endpoint = `dydxprotocol/perpetuals/params`; return await this.req.get(endpoint); } + /* Queries the next perpetual id. */ + + + async nextPerpetualId(_params: QueryNextPerpetualIdRequest = {}): Promise { + const endpoint = `dydxprotocol/perpetuals/next_perpetual_id`; + return await this.req.get(endpoint); + } } \ No newline at end of file diff --git a/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.rpc.Query.ts b/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.rpc.Query.ts index afd777b2df..64c43f1b96 100644 --- a/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.rpc.Query.ts +++ b/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/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 { QueryPerpetualRequest, QueryPerpetualResponse, QueryAllPerpetualsRequest, QueryAllPerpetualsResponse, QueryAllLiquidityTiersRequest, QueryAllLiquidityTiersResponse, QueryPremiumVotesRequest, QueryPremiumVotesResponse, QueryPremiumSamplesRequest, QueryPremiumSamplesResponse, QueryParamsRequest, QueryParamsResponse } from "./query"; +import { QueryPerpetualRequest, QueryPerpetualResponse, QueryAllPerpetualsRequest, QueryAllPerpetualsResponse, QueryAllLiquidityTiersRequest, QueryAllLiquidityTiersResponse, QueryPremiumVotesRequest, QueryPremiumVotesResponse, QueryPremiumSamplesRequest, QueryPremiumSamplesResponse, QueryParamsRequest, QueryParamsResponse, QueryNextPerpetualIdRequest, QueryNextPerpetualIdResponse } from "./query"; /** Query defines the gRPC querier service. */ export interface Query { @@ -22,6 +22,9 @@ export interface Query { /** Queries the perpetual params. */ params(request?: QueryParamsRequest): Promise; + /** Queries the next perpetual id. */ + + nextPerpetualId(request?: QueryNextPerpetualIdRequest): Promise; } export class QueryClientImpl implements Query { private readonly rpc: Rpc; @@ -34,6 +37,7 @@ export class QueryClientImpl implements Query { this.premiumVotes = this.premiumVotes.bind(this); this.premiumSamples = this.premiumSamples.bind(this); this.params = this.params.bind(this); + this.nextPerpetualId = this.nextPerpetualId.bind(this); } perpetual(request: QueryPerpetualRequest): Promise { @@ -76,6 +80,12 @@ export class QueryClientImpl implements Query { return promise.then(data => QueryParamsResponse.decode(new _m0.Reader(data))); } + nextPerpetualId(request: QueryNextPerpetualIdRequest = {}): Promise { + const data = QueryNextPerpetualIdRequest.encode(request).finish(); + const promise = this.rpc.request("dydxprotocol.perpetuals.Query", "NextPerpetualId", data); + return promise.then(data => QueryNextPerpetualIdResponse.decode(new _m0.Reader(data))); + } + } export const createRpcQueryExtension = (base: QueryClient) => { const rpc = createProtobufRpcClient(base); @@ -103,6 +113,10 @@ export const createRpcQueryExtension = (base: QueryClient) => { params(request?: QueryParamsRequest): Promise { return queryService.params(request); + }, + + nextPerpetualId(request?: QueryNextPerpetualIdRequest): Promise { + return queryService.nextPerpetualId(request); } }; diff --git a/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.ts b/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.ts index 4dda168b08..8fd1e273c6 100644 --- a/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.ts +++ b/indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/query.ts @@ -141,6 +141,24 @@ export interface QueryParamsResponse { export interface QueryParamsResponseSDKType { params?: ParamsSDKType; } +/** QueryNextPerpetualIdRequest is the request type for the NextPerpetualId RPC */ + +export interface QueryNextPerpetualIdRequest {} +/** QueryNextPerpetualIdRequest is the request type for the NextPerpetualId RPC */ + +export interface QueryNextPerpetualIdRequestSDKType {} +/** QueryNextPerpetualIdResponse is the response type for the NextPerpetualId RPC */ + +export interface QueryNextPerpetualIdResponse { + /** QueryNextPerpetualIdResponse is the response type for the NextPerpetualId RPC */ + nextPerpetualId: number; +} +/** QueryNextPerpetualIdResponse is the response type for the NextPerpetualId RPC */ + +export interface QueryNextPerpetualIdResponseSDKType { + /** QueryNextPerpetualIdResponse is the response type for the NextPerpetualId RPC */ + next_perpetual_id: number; +} function createBaseQueryPerpetualRequest(): QueryPerpetualRequest { return { @@ -667,4 +685,83 @@ export const QueryParamsResponse = { return message; } +}; + +function createBaseQueryNextPerpetualIdRequest(): QueryNextPerpetualIdRequest { + return {}; +} + +export const QueryNextPerpetualIdRequest = { + encode(_: QueryNextPerpetualIdRequest, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer { + return writer; + }, + + decode(input: _m0.Reader | Uint8Array, length?: number): QueryNextPerpetualIdRequest { + const reader = input instanceof _m0.Reader ? input : new _m0.Reader(input); + let end = length === undefined ? reader.len : reader.pos + length; + const message = createBaseQueryNextPerpetualIdRequest(); + + while (reader.pos < end) { + const tag = reader.uint32(); + + switch (tag >>> 3) { + default: + reader.skipType(tag & 7); + break; + } + } + + return message; + }, + + fromPartial(_: DeepPartial): QueryNextPerpetualIdRequest { + const message = createBaseQueryNextPerpetualIdRequest(); + return message; + } + +}; + +function createBaseQueryNextPerpetualIdResponse(): QueryNextPerpetualIdResponse { + return { + nextPerpetualId: 0 + }; +} + +export const QueryNextPerpetualIdResponse = { + encode(message: QueryNextPerpetualIdResponse, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer { + if (message.nextPerpetualId !== 0) { + writer.uint32(8).uint32(message.nextPerpetualId); + } + + return writer; + }, + + decode(input: _m0.Reader | Uint8Array, length?: number): QueryNextPerpetualIdResponse { + const reader = input instanceof _m0.Reader ? input : new _m0.Reader(input); + let end = length === undefined ? reader.len : reader.pos + length; + const message = createBaseQueryNextPerpetualIdResponse(); + + while (reader.pos < end) { + const tag = reader.uint32(); + + switch (tag >>> 3) { + case 1: + message.nextPerpetualId = reader.uint32(); + break; + + default: + reader.skipType(tag & 7); + break; + } + } + + return message; + }, + + fromPartial(object: DeepPartial): QueryNextPerpetualIdResponse { + const message = createBaseQueryNextPerpetualIdResponse(); + message.nextPerpetualId = object.nextPerpetualId ?? 0; + return message; + } + }; \ No newline at end of file diff --git a/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.lcd.ts b/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.lcd.ts index 0f78eab48a..aa78b042ee 100644 --- a/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.lcd.ts +++ b/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.lcd.ts @@ -1,6 +1,6 @@ import { setPaginationParams } from "../../helpers"; import { LCDClient } from "@osmonauts/lcd"; -import { QueryMarketPriceRequest, QueryMarketPriceResponseSDKType, QueryAllMarketPricesRequest, QueryAllMarketPricesResponseSDKType, QueryMarketParamRequest, QueryMarketParamResponseSDKType, QueryAllMarketParamsRequest, QueryAllMarketParamsResponseSDKType } from "./query"; +import { QueryMarketPriceRequest, QueryMarketPriceResponseSDKType, QueryAllMarketPricesRequest, QueryAllMarketPricesResponseSDKType, QueryMarketParamRequest, QueryMarketParamResponseSDKType, QueryAllMarketParamsRequest, QueryAllMarketParamsResponseSDKType, QueryNextMarketIdRequest, QueryNextMarketIdResponseSDKType } from "./query"; export class LCDQueryClient { req: LCDClient; @@ -14,6 +14,7 @@ export class LCDQueryClient { this.allMarketPrices = this.allMarketPrices.bind(this); this.marketParam = this.marketParam.bind(this); this.allMarketParams = this.allMarketParams.bind(this); + this.nextMarketId = this.nextMarketId.bind(this); } /* Queries a MarketPrice by id. */ @@ -63,5 +64,12 @@ export class LCDQueryClient { const endpoint = `dydxprotocol/prices/params/market`; return await this.req.get(endpoint, options); } + /* Queries the next market id. */ + + + async nextMarketId(_params: QueryNextMarketIdRequest = {}): Promise { + const endpoint = `dydxprotocol/prices/next_market_id`; + return await this.req.get(endpoint); + } } \ No newline at end of file diff --git a/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.rpc.Query.ts b/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.rpc.Query.ts index 2c24a6d01a..e6b955ad29 100644 --- a/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.rpc.Query.ts +++ b/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/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 { QueryMarketPriceRequest, QueryMarketPriceResponse, QueryAllMarketPricesRequest, QueryAllMarketPricesResponse, QueryMarketParamRequest, QueryMarketParamResponse, QueryAllMarketParamsRequest, QueryAllMarketParamsResponse } from "./query"; +import { QueryMarketPriceRequest, QueryMarketPriceResponse, QueryAllMarketPricesRequest, QueryAllMarketPricesResponse, QueryMarketParamRequest, QueryMarketParamResponse, QueryAllMarketParamsRequest, QueryAllMarketParamsResponse, QueryNextMarketIdRequest, QueryNextMarketIdResponse } from "./query"; /** Query defines the gRPC querier service. */ export interface Query { @@ -16,6 +16,9 @@ export interface Query { /** Queries a list of MarketParam items. */ allMarketParams(request?: QueryAllMarketParamsRequest): Promise; + /** Queries the next market id. */ + + nextMarketId(request?: QueryNextMarketIdRequest): Promise; } export class QueryClientImpl implements Query { private readonly rpc: Rpc; @@ -26,6 +29,7 @@ export class QueryClientImpl implements Query { this.allMarketPrices = this.allMarketPrices.bind(this); this.marketParam = this.marketParam.bind(this); this.allMarketParams = this.allMarketParams.bind(this); + this.nextMarketId = this.nextMarketId.bind(this); } marketPrice(request: QueryMarketPriceRequest): Promise { @@ -56,6 +60,12 @@ export class QueryClientImpl implements Query { return promise.then(data => QueryAllMarketParamsResponse.decode(new _m0.Reader(data))); } + nextMarketId(request: QueryNextMarketIdRequest = {}): Promise { + const data = QueryNextMarketIdRequest.encode(request).finish(); + const promise = this.rpc.request("dydxprotocol.prices.Query", "NextMarketId", data); + return promise.then(data => QueryNextMarketIdResponse.decode(new _m0.Reader(data))); + } + } export const createRpcQueryExtension = (base: QueryClient) => { const rpc = createProtobufRpcClient(base); @@ -75,6 +85,10 @@ export const createRpcQueryExtension = (base: QueryClient) => { allMarketParams(request?: QueryAllMarketParamsRequest): Promise { return queryService.allMarketParams(request); + }, + + nextMarketId(request?: QueryNextMarketIdRequest): Promise { + return queryService.nextMarketId(request); } }; diff --git a/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.ts b/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.ts index 4c7a38db92..525f64b6b0 100644 --- a/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.ts +++ b/indexer/packages/v4-protos/src/codegen/dydxprotocol/prices/query.ts @@ -151,6 +151,36 @@ export interface QueryAllMarketParamsResponseSDKType { market_params: MarketParamSDKType[]; pagination?: PageResponseSDKType; } +/** QueryNextMarketIdRequest is request type for the Query/Params `NextMarketId` */ + +export interface QueryNextMarketIdRequest {} +/** QueryNextMarketIdRequest is request type for the Query/Params `NextMarketId` */ + +export interface QueryNextMarketIdRequestSDKType {} +/** + * QueryNextMarketIdResponse is response type for the Query/Params + * `NextMarketId` + */ + +export interface QueryNextMarketIdResponse { + /** + * QueryNextMarketIdResponse is response type for the Query/Params + * `NextMarketId` + */ + nextMarketId: number; +} +/** + * QueryNextMarketIdResponse is response type for the Query/Params + * `NextMarketId` + */ + +export interface QueryNextMarketIdResponseSDKType { + /** + * QueryNextMarketIdResponse is response type for the Query/Params + * `NextMarketId` + */ + next_market_id: number; +} function createBaseQueryMarketPriceRequest(): QueryMarketPriceRequest { return { @@ -530,4 +560,83 @@ export const QueryAllMarketParamsResponse = { return message; } +}; + +function createBaseQueryNextMarketIdRequest(): QueryNextMarketIdRequest { + return {}; +} + +export const QueryNextMarketIdRequest = { + encode(_: QueryNextMarketIdRequest, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer { + return writer; + }, + + decode(input: _m0.Reader | Uint8Array, length?: number): QueryNextMarketIdRequest { + const reader = input instanceof _m0.Reader ? input : new _m0.Reader(input); + let end = length === undefined ? reader.len : reader.pos + length; + const message = createBaseQueryNextMarketIdRequest(); + + while (reader.pos < end) { + const tag = reader.uint32(); + + switch (tag >>> 3) { + default: + reader.skipType(tag & 7); + break; + } + } + + return message; + }, + + fromPartial(_: DeepPartial): QueryNextMarketIdRequest { + const message = createBaseQueryNextMarketIdRequest(); + return message; + } + +}; + +function createBaseQueryNextMarketIdResponse(): QueryNextMarketIdResponse { + return { + nextMarketId: 0 + }; +} + +export const QueryNextMarketIdResponse = { + encode(message: QueryNextMarketIdResponse, writer: _m0.Writer = _m0.Writer.create()): _m0.Writer { + if (message.nextMarketId !== 0) { + writer.uint32(8).uint32(message.nextMarketId); + } + + return writer; + }, + + decode(input: _m0.Reader | Uint8Array, length?: number): QueryNextMarketIdResponse { + const reader = input instanceof _m0.Reader ? input : new _m0.Reader(input); + let end = length === undefined ? reader.len : reader.pos + length; + const message = createBaseQueryNextMarketIdResponse(); + + while (reader.pos < end) { + const tag = reader.uint32(); + + switch (tag >>> 3) { + case 1: + message.nextMarketId = reader.uint32(); + break; + + default: + reader.skipType(tag & 7); + break; + } + } + + return message; + }, + + fromPartial(object: DeepPartial): QueryNextMarketIdResponse { + const message = createBaseQueryNextMarketIdResponse(); + message.nextMarketId = object.nextMarketId ?? 0; + return message; + } + }; \ No newline at end of file diff --git a/proto/dydxprotocol/clob/query.proto b/proto/dydxprotocol/clob/query.proto index 380336bbf9..5584a1e950 100644 --- a/proto/dydxprotocol/clob/query.proto +++ b/proto/dydxprotocol/clob/query.proto @@ -61,6 +61,12 @@ service Query { rpc StatefulOrder(QueryStatefulOrderRequest) returns (QueryStatefulOrderResponse) {} + // Queries the next clob pair id. + rpc NextClobPairId(QueryNextClobPairIdRequest) + returns (QueryNextClobPairIdResponse) { + option (google.api.http).get = "/dydxprotocol/clob/next_clob_pair_id"; + } + // GRPC Streams // Streams orderbook updates. Updates contain orderbook data @@ -163,6 +169,12 @@ message QueryLiquidationsConfigurationResponse { LiquidationsConfig liquidations_config = 1 [ (gogoproto.nullable) = false ]; } +// QueryNextClobPairIdRequest is a request message for the next clob pair id +message QueryNextClobPairIdRequest {} + +// QueryNextClobPairIdResponse is a response message for the next clob pair id +message QueryNextClobPairIdResponse { uint32 next_clob_pair_id = 1; } + // StreamOrderbookUpdatesRequest is a request message for the // StreamOrderbookUpdates method. message StreamOrderbookUpdatesRequest { diff --git a/proto/dydxprotocol/perpetuals/query.proto b/proto/dydxprotocol/perpetuals/query.proto index 8433b112f8..b69c442050 100644 --- a/proto/dydxprotocol/perpetuals/query.proto +++ b/proto/dydxprotocol/perpetuals/query.proto @@ -44,6 +44,12 @@ service Query { rpc Params(QueryParamsRequest) returns (QueryParamsResponse) { option (google.api.http).get = "/dydxprotocol/perpetuals/params"; } + + // Queries the next perpetual id. + rpc NextPerpetualId(QueryNextPerpetualIdRequest) + returns (QueryNextPerpetualIdResponse) { + option (google.api.http).get = "/dydxprotocol/perpetuals/next_perpetual_id"; + } } // Queries a Perpetual by id. @@ -104,4 +110,10 @@ message QueryParamsResponse { Params params = 1 [ (gogoproto.nullable) = false ]; } +// QueryNextPerpetualIdRequest is the request type for the NextPerpetualId RPC +message QueryNextPerpetualIdRequest {} + +// QueryNextPerpetualIdResponse is the response type for the NextPerpetualId RPC +message QueryNextPerpetualIdResponse { uint32 next_perpetual_id = 1; } + // this line is used by starport scaffolding # 3 diff --git a/proto/dydxprotocol/prices/query.proto b/proto/dydxprotocol/prices/query.proto index 624db55dd5..fc55b304e8 100644 --- a/proto/dydxprotocol/prices/query.proto +++ b/proto/dydxprotocol/prices/query.proto @@ -32,6 +32,12 @@ service Query { returns (QueryAllMarketParamsResponse) { option (google.api.http).get = "/dydxprotocol/prices/params/market"; } + + // Queries the next market id. + rpc NextMarketId(QueryNextMarketIdRequest) + returns (QueryNextMarketIdResponse) { + option (google.api.http).get = "/dydxprotocol/prices/next_market_id"; + } } // QueryMarketPriceRequest is request type for the Query/Params `MarketPrice` @@ -79,3 +85,10 @@ message QueryAllMarketParamsResponse { repeated MarketParam market_params = 1 [ (gogoproto.nullable) = false ]; cosmos.base.query.v1beta1.PageResponse pagination = 2; } + +// QueryNextMarketIdRequest is request type for the Query/Params `NextMarketId` +message QueryNextMarketIdRequest {} + +// QueryNextMarketIdResponse is response type for the Query/Params +// `NextMarketId` +message QueryNextMarketIdResponse { uint32 next_market_id = 1; } diff --git a/protocol/app/upgrades.go b/protocol/app/upgrades.go index 207a5ba815..90e4a4d0cc 100644 --- a/protocol/app/upgrades.go +++ b/protocol/app/upgrades.go @@ -3,7 +3,7 @@ package app import ( "fmt" - v7_0 "github.com/dydxprotocol/v4-chain/protocol/app/upgrades/v7.0" + v_8_0 "github.com/dydxprotocol/v4-chain/protocol/app/upgrades/v8.0" upgradetypes "cosmossdk.io/x/upgrade/types" sdk "github.com/cosmos/cosmos-sdk/types" @@ -14,7 +14,7 @@ var ( // `Upgrades` defines the upgrade handlers and store loaders for the application. // New upgrades should be added to this slice after they are implemented. Upgrades = []upgrades.Upgrade{ - v7_0.Upgrade, + v_8_0.Upgrade, } Forks = []upgrades.Fork{} ) @@ -22,18 +22,17 @@ var ( // setupUpgradeHandlers registers the upgrade handlers to perform custom upgrade // logic and state migrations for software upgrades. func (app *App) setupUpgradeHandlers() { - if app.UpgradeKeeper.HasHandler(v7_0.UpgradeName) { - panic(fmt.Sprintf("Cannot register duplicate upgrade handler '%s'", v7_0.UpgradeName)) + if app.UpgradeKeeper.HasHandler(v_8_0.UpgradeName) { + panic(fmt.Sprintf("Cannot register duplicate upgrade handler '%s'", v_8_0.UpgradeName)) } app.UpgradeKeeper.SetUpgradeHandler( - v7_0.UpgradeName, - v7_0.CreateUpgradeHandler( + v_8_0.UpgradeName, + v_8_0.CreateUpgradeHandler( app.ModuleManager, app.configurator, - app.AccountKeeper, app.PricesKeeper, - app.VaultKeeper, - app.ListingKeeper, + app.PerpetualsKeeper, + app.ClobKeeper, ), ) } diff --git a/protocol/app/upgrades/v7.0/upgrade_container_test.go b/protocol/app/upgrades/v7.0/upgrade_container_test.go deleted file mode 100644 index d65a77d568..0000000000 --- a/protocol/app/upgrades/v7.0/upgrade_container_test.go +++ /dev/null @@ -1,241 +0,0 @@ -//go:build all || container_test - -package v_7_0_test - -import ( - "math/big" - "testing" - - listingtypes "github.com/dydxprotocol/v4-chain/protocol/x/listing/types" - - "github.com/cosmos/gogoproto/proto" - - authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - v_7_0 "github.com/dydxprotocol/v4-chain/protocol/app/upgrades/v7.0" - "github.com/dydxprotocol/v4-chain/protocol/dtypes" - "github.com/dydxprotocol/v4-chain/protocol/testing/containertest" - "github.com/dydxprotocol/v4-chain/protocol/testutil/constants" - affiliatestypes "github.com/dydxprotocol/v4-chain/protocol/x/affiliates/types" - vaulttypes "github.com/dydxprotocol/v4-chain/protocol/x/vault/types" - "github.com/stretchr/testify/require" -) - -const ( - AliceBobBTCQuantums = 1_000_000 - CarlDaveBTCQuantums = 2_000_000 - CarlDaveETHQuantums = 4_000_000 -) - -func TestStateUpgrade(t *testing.T) { - testnet, err := containertest.NewTestnetWithPreupgradeGenesis() - require.NoError(t, err, "failed to create testnet - is docker daemon running?") - err = testnet.Start() - require.NoError(t, err) - defer testnet.MustCleanUp() - node := testnet.Nodes["alice"] - nodeAddress := constants.AliceAccAddress.String() - - preUpgradeSetups(node, t) - preUpgradeChecks(node, t) - - err = containertest.UpgradeTestnet(nodeAddress, t, node, v_7_0.UpgradeName) - require.NoError(t, err) - - postUpgradeChecks(node, t) -} - -func preUpgradeSetups(node *containertest.Node, t *testing.T) {} - -func preUpgradeChecks(node *containertest.Node, t *testing.T) { - // Add test for your upgrade handler logic below -} - -func postUpgradeChecks(node *containertest.Node, t *testing.T) { - // Check that vault quoting params are successfully migrated to vault params. - postUpgradeVaultParamsCheck(node, t) - // Check that vault shares are successfully migrated to megavault shares. - postUpgradeMegavaultSharesCheck(node, t) - // Check that megavault module account is successfully initialized. - postUpgradeMegavaultModuleAccCheck(node, t) - - // Check that the affiliates module has been initialized with the default tiers. - postUpgradeAffiliatesModuleTiersCheck(node, t) - - // Check that the listing module state has been initialized with the hard cap and default deposit params. - postUpgradeListingModuleStateCheck(node, t) -} - -func postUpgradeVaultParamsCheck(node *containertest.Node, t *testing.T) { - // Check that a vault with quoting params is successfully migrated and the quoting params are - // successfully migrated to the vault params. - expectedQuotingParams := &vaulttypes.QuotingParams{ - Layers: 3, - SpreadMinPpm: 1500, - SpreadBufferPpm: 500, - SkewFactorPpm: 1000000, - OrderSizePctPpm: 50000, - OrderExpirationSeconds: 30, - ActivationThresholdQuoteQuantums: dtypes.NewIntFromUint64(500_000_000), - } - - checkVaultParams(node, t, 0, vaulttypes.VaultStatus_VAULT_STATUS_QUOTING, expectedQuotingParams) - - // Check that a vault without quoting params is successfully migrated and the quoting params are - // not set in the migrated vault params. - checkVaultParams(node, t, 1, vaulttypes.VaultStatus_VAULT_STATUS_QUOTING, nil) -} - -func checkVaultParams( - node *containertest.Node, - t *testing.T, - vaultNumber uint32, - expectedStatus vaulttypes.VaultStatus, - expectedQuotingParams *vaulttypes.QuotingParams, -) { - resp, err := containertest.Query( - node, - vaulttypes.NewQueryClient, - vaulttypes.QueryClient.VaultParams, - &vaulttypes.QueryVaultParamsRequest{ - Type: vaulttypes.VaultType_VAULT_TYPE_CLOB, - Number: vaultNumber, - }, - ) - require.NoError(t, err) - require.NotNil(t, resp) - - vaultParamsResp := vaulttypes.QueryVaultParamsResponse{} - err = proto.UnmarshalText(resp.String(), &vaultParamsResp) - require.NoError(t, err) - - require.Equal(t, expectedStatus, vaultParamsResp.VaultParams.Status) - require.Equal(t, expectedQuotingParams, vaultParamsResp.VaultParams.QuotingParams) -} - -func postUpgradeMegavaultSharesCheck(node *containertest.Node, t *testing.T) { - // Alice equity = vault_0_equity * 1 + vault_1_equity * 1/3 + vault_2_equity * 123_456/556_677 - // = 1_000 + 2_000 * 1/3 + 3_000 * 123_456/556_677 - // ~= 2331.98605 - // Bob equity = vault_1_equity * 1/3 + vault_2_equity * 433_221/556_677 - // = 2_000 * 1/3 + 3_000 * 433_221/556_677 - // ~= 3001.34728 - // Carl equity = vault_1_equity * 1/3 - // = 2_000 * 1/3 - // ~= 666.66667 - // 0.001 USDC in equity should be granted 1 megavault share and round down to nearest integer. - expectedOwnerShares := map[string]*big.Int{ - constants.AliceAccAddress.String(): big.NewInt(2_331_986), - constants.BobAccAddress.String(): big.NewInt(3_001_347), - constants.CarlAccAddress.String(): big.NewInt(666_666), - } - // 2_331_986 + 3_001_347 + 666_666 = 5_999_999 - expectedTotalShares := big.NewInt(5_999_999) - - // Check MegaVault total shares. - resp, err := containertest.Query( - node, - vaulttypes.NewQueryClient, - vaulttypes.QueryClient.MegavaultTotalShares, - &vaulttypes.QueryMegavaultTotalSharesRequest{}, - ) - require.NoError(t, err) - require.NotNil(t, resp) - - totalSharesResp := vaulttypes.QueryMegavaultTotalSharesResponse{} - err = proto.UnmarshalText(resp.String(), &totalSharesResp) - require.NoError(t, err) - - require.Equal( - t, - expectedTotalShares, - totalSharesResp.TotalShares.NumShares.BigInt(), - ) - - // Check MegaVault owner shares. - resp, err = containertest.Query( - node, - vaulttypes.NewQueryClient, - vaulttypes.QueryClient.MegavaultAllOwnerShares, - &vaulttypes.QueryMegavaultAllOwnerSharesRequest{}, - ) - require.NoError(t, err) - require.NotNil(t, resp) - - allOwnerSharesResp := vaulttypes.QueryMegavaultAllOwnerSharesResponse{} - err = proto.UnmarshalText(resp.String(), &allOwnerSharesResp) - require.NoError(t, err) - - require.Len(t, allOwnerSharesResp.OwnerShares, 3) - gotOwnerShares := make(map[string]*big.Int) - for _, ownerShare := range allOwnerSharesResp.OwnerShares { - gotOwnerShares[ownerShare.Owner] = ownerShare.Shares.NumShares.BigInt() - } - for owner, expectedShares := range expectedOwnerShares { - require.Contains(t, gotOwnerShares, owner) - require.Equal(t, expectedShares, gotOwnerShares[owner]) - } -} - -func postUpgradeAffiliatesModuleTiersCheck(node *containertest.Node, t *testing.T) { - resp, err := containertest.Query( - node, - affiliatestypes.NewQueryClient, - affiliatestypes.QueryClient.AllAffiliateTiers, - &affiliatestypes.AllAffiliateTiersRequest{}, - ) - require.NoError(t, err) - require.NotNil(t, resp) - - affiliateTiersResp := affiliatestypes.AllAffiliateTiersResponse{} - err = proto.UnmarshalText(resp.String(), &affiliateTiersResp) - require.NoError(t, err) - require.Equal(t, affiliatestypes.DefaultAffiliateTiers, affiliateTiersResp.Tiers) -} - -func postUpgradeMegavaultModuleAccCheck(node *containertest.Node, t *testing.T) { - resp, err := containertest.Query( - node, - authtypes.NewQueryClient, - authtypes.QueryClient.ModuleAccountByName, - &authtypes.QueryModuleAccountByNameRequest{ - Name: vaulttypes.MegavaultAccountName, - }, - ) - require.NoError(t, err) - require.NotNil(t, resp) - - moduleAccResp := authtypes.QueryModuleAccountByNameResponse{} - err = proto.UnmarshalText(resp.String(), &moduleAccResp) - require.NoError(t, err) -} - -func postUpgradeListingModuleStateCheck(node *containertest.Node, t *testing.T) { - // Check that the listing module state has been initialized with the hard cap and default deposit params. - resp, err := containertest.Query( - node, - listingtypes.NewQueryClient, - listingtypes.QueryClient.ListingVaultDepositParams, - &listingtypes.QueryListingVaultDepositParams{}, - ) - require.NoError(t, err) - require.NotNil(t, resp) - - listingVaultDepositParamsResp := listingtypes.QueryListingVaultDepositParamsResponse{} - err = proto.UnmarshalText(resp.String(), &listingVaultDepositParamsResp) - require.NoError(t, err) - require.Equal(t, listingtypes.DefaultParams(), listingVaultDepositParamsResp.Params) - - resp, err = containertest.Query( - node, - listingtypes.NewQueryClient, - listingtypes.QueryClient.MarketsHardCap, - &listingtypes.QueryMarketsHardCap{}, - ) - require.NoError(t, err) - require.NotNil(t, resp) - - marketsHardCapResp := listingtypes.QueryMarketsHardCapResponse{} - err = proto.UnmarshalText(resp.String(), &marketsHardCapResp) - require.NoError(t, err) - require.Equal(t, uint32(500), marketsHardCapResp.HardCap) -} diff --git a/protocol/app/upgrades/v8.0/constants.go b/protocol/app/upgrades/v8.0/constants.go new file mode 100644 index 0000000000..27951ed50e --- /dev/null +++ b/protocol/app/upgrades/v8.0/constants.go @@ -0,0 +1,15 @@ +package v_8_0 + +import ( + store "cosmossdk.io/store/types" + "github.com/dydxprotocol/v4-chain/protocol/app/upgrades" +) + +const ( + UpgradeName = "v8.0" +) + +var Upgrade = upgrades.Upgrade{ + UpgradeName: UpgradeName, + StoreUpgrades: store.StoreUpgrades{}, +} diff --git a/protocol/app/upgrades/v8.0/migrate_accountplus_test.go b/protocol/app/upgrades/v8.0/migrate_accountplus_test.go index 88be8a4994..ce46cbf01e 100644 --- a/protocol/app/upgrades/v8.0/migrate_accountplus_test.go +++ b/protocol/app/upgrades/v8.0/migrate_accountplus_test.go @@ -1,8 +1,10 @@ -package v_8_0 +package v_8_0_test import ( "testing" + v_8_0 "github.com/dydxprotocol/v4-chain/protocol/app/upgrades/v8.0" + "cosmossdk.io/store/prefix" sdk "github.com/cosmos/cosmos-sdk/types" testapp "github.com/dydxprotocol/v4-chain/protocol/testutil/app" @@ -54,7 +56,7 @@ func (s *UpgradeTestSuite) TestUpgrade_MigrateAccountplusAccountState() { } // Migrate - migrateAccountplusAccountState(ctx, s.tApp.App.AccountPlusKeeper) + v_8_0.MigrateAccountplusAccountState(ctx, s.tApp.App.AccountPlusKeeper) // Verify that unprefixed keys are deleted and prefixed keys exist for _, addr := range addresses { diff --git a/protocol/app/upgrades/v8.0/upgrade.go b/protocol/app/upgrades/v8.0/upgrade.go index 12707b727b..dbce44bb9d 100644 --- a/protocol/app/upgrades/v8.0/upgrade.go +++ b/protocol/app/upgrades/v8.0/upgrade.go @@ -2,8 +2,16 @@ package v_8_0 import ( "bytes" + "context" "fmt" + upgradetypes "cosmossdk.io/x/upgrade/types" + "github.com/cosmos/cosmos-sdk/types/module" + "github.com/dydxprotocol/v4-chain/protocol/lib" + clobtypes "github.com/dydxprotocol/v4-chain/protocol/x/clob/types" + perptypes "github.com/dydxprotocol/v4-chain/protocol/x/perpetuals/types" + pricestypes "github.com/dydxprotocol/v4-chain/protocol/x/prices/types" + storetypes "cosmossdk.io/store/types" sdk "github.com/cosmos/cosmos-sdk/types" accountpluskeeper "github.com/dydxprotocol/v4-chain/protocol/x/accountplus/keeper" @@ -11,7 +19,7 @@ import ( ) // Migrate accountplus AccountState in kvstore from non-prefixed keys to prefixed keys -func migrateAccountplusAccountState(ctx sdk.Context, k accountpluskeeper.Keeper) { +func MigrateAccountplusAccountState(ctx sdk.Context, k accountpluskeeper.Keeper) { ctx.Logger().Info("Migrating accountplus module AccountState in kvstore from non-prefixed keys to prefixed keys") store := ctx.KVStore(k.GetStoreKey()) @@ -60,4 +68,40 @@ func migrateAccountplusAccountState(ctx sdk.Context, k accountpluskeeper.Keeper) ctx.Logger().Info("Successfully migrated accountplus AccountState keys") } -// TODO: Scaffolding for upgrade: https://linear.app/dydx/issue/OTE-886/v8-upgrade-handler-scaffold +const ( + ID_NUM = 300 +) + +// Set market, perpetual, and clob ids to a set number +// This is done so that the ids are consistent for convenience +func setMarketListingBaseIds( + ctx sdk.Context, + pricesKeeper pricestypes.PricesKeeper, + perpetualsKeeper perptypes.PerpetualsKeeper, + clobKeeper clobtypes.ClobKeeper, +) { + // Set all ids to a set number + pricesKeeper.SetNextMarketID(ctx, ID_NUM) + + perpetualsKeeper.SetNextPerpetualID(ctx, ID_NUM) + + clobKeeper.SetNextClobPairID(ctx, ID_NUM) +} + +func CreateUpgradeHandler( + mm *module.Manager, + configurator module.Configurator, + pricesKeeper pricestypes.PricesKeeper, + perpetualsKeeper perptypes.PerpetualsKeeper, + clobKeeper clobtypes.ClobKeeper, +) upgradetypes.UpgradeHandler { + return func(ctx context.Context, plan upgradetypes.Plan, vm module.VersionMap) (module.VersionMap, error) { + sdkCtx := lib.UnwrapSDKContext(ctx, "app/upgrades") + sdkCtx.Logger().Info(fmt.Sprintf("Running %s Upgrade...", UpgradeName)) + + // Set market, perpetual, and clob ids to a set number + setMarketListingBaseIds(sdkCtx, pricesKeeper, perpetualsKeeper, clobKeeper) + + return mm.RunMigrations(ctx, configurator, vm) + } +} diff --git a/protocol/app/upgrades/v8.0/upgrade_container_test.go b/protocol/app/upgrades/v8.0/upgrade_container_test.go new file mode 100644 index 0000000000..90846694fc --- /dev/null +++ b/protocol/app/upgrades/v8.0/upgrade_container_test.go @@ -0,0 +1,96 @@ +//go:build all || container_test + +package v_8_0_test + +import ( + "testing" + + v_8_0 "github.com/dydxprotocol/v4-chain/protocol/app/upgrades/v8.0" + + "github.com/cosmos/gogoproto/proto" + + clobtypes "github.com/dydxprotocol/v4-chain/protocol/x/clob/types" + + perptypes "github.com/dydxprotocol/v4-chain/protocol/x/perpetuals/types" + pricetypes "github.com/dydxprotocol/v4-chain/protocol/x/prices/types" + + "github.com/dydxprotocol/v4-chain/protocol/testing/containertest" + "github.com/dydxprotocol/v4-chain/protocol/testutil/constants" + "github.com/stretchr/testify/require" +) + +func TestStateUpgrade(t *testing.T) { + testnet, err := containertest.NewTestnetWithPreupgradeGenesis() + require.NoError(t, err, "failed to create testnet - is docker daemon running?") + err = testnet.Start() + require.NoError(t, err) + defer testnet.MustCleanUp() + node := testnet.Nodes["alice"] + nodeAddress := constants.AliceAccAddress.String() + + preUpgradeSetups(node, t) + preUpgradeChecks(node, t) + + err = containertest.UpgradeTestnet(nodeAddress, t, node, v_8_0.UpgradeName) + require.NoError(t, err) + + postUpgradeChecks(node, t) +} + +func preUpgradeSetups(node *containertest.Node, t *testing.T) {} + +func preUpgradeChecks(node *containertest.Node, t *testing.T) { + // Add test for your upgrade handler logic below +} + +func postUpgradeChecks(node *containertest.Node, t *testing.T) { + // Check that the listing module state has been initialized with the hard cap and default deposit params. + postUpgradeMarketIdsCheck(node, t) +} + +func postUpgradeMarketIdsCheck(node *containertest.Node, t *testing.T) { + // query the next market id + resp, err := containertest.Query( + node, + pricetypes.NewQueryClient, + pricetypes.QueryClient.NextMarketId, + &pricetypes.QueryNextMarketIdRequest{}, + ) + require.NoError(t, err) + require.NotNil(t, resp) + + nextMarketIdResp := pricetypes.QueryNextMarketIdResponse{} + err = proto.UnmarshalText(resp.String(), &nextMarketIdResp) + require.NoError(t, err) + require.Equal(t, uint32(v_8_0.ID_NUM), nextMarketIdResp.NextMarketId) + + // query the next perpetual id + resp, err = containertest.Query( + node, + perptypes.NewQueryClient, + perptypes.QueryClient.NextPerpetualId, + &perptypes.QueryNextPerpetualIdRequest{}, + ) + require.NoError(t, err) + require.NotNil(t, resp) + + nextPerpIdResp := perptypes.QueryNextPerpetualIdResponse{} + err = proto.UnmarshalText(resp.String(), &nextPerpIdResp) + require.NoError(t, err) + require.Equal(t, uint32(v_8_0.ID_NUM), nextPerpIdResp.NextPerpetualId) + + // query the next clob pair id + resp, err = containertest.Query( + node, + clobtypes.NewQueryClient, + clobtypes.QueryClient.NextClobPairId, + &clobtypes.QueryNextClobPairIdRequest{}, + ) + require.NoError(t, err) + require.NotNil(t, resp) + + nextClobPairIdResp := clobtypes.QueryNextClobPairIdResponse{} + err = proto.UnmarshalText(resp.String(), &nextClobPairIdResp) + require.NoError(t, err) + require.Equal(t, uint32(v_8_0.ID_NUM), nextClobPairIdResp.NextClobPairId) +} diff --git a/protocol/mocks/ClobKeeper.go b/protocol/mocks/ClobKeeper.go index 0bc8520214..84dd25c454 100644 --- a/protocol/mocks/ClobKeeper.go +++ b/protocol/mocks/ClobKeeper.go @@ -1114,6 +1114,11 @@ func (_m *ClobKeeper) SetLongTermOrderPlacement(ctx types.Context, order clobtyp _m.Called(ctx, order, blockHeight) } +// SetNextClobPairID provides a mock function with given fields: ctx, nextID +func (_m *ClobKeeper) SetNextClobPairID(ctx types.Context, nextID uint32) { + _m.Called(ctx, nextID) +} + // UnsafeMigrateOrderExpirationState provides a mock function with given fields: ctx func (_m *ClobKeeper) UnsafeMigrateOrderExpirationState(ctx types.Context) { _m.Called(ctx) diff --git a/protocol/mocks/PerpetualsKeeper.go b/protocol/mocks/PerpetualsKeeper.go index 38721a5f1e..e856f54ced 100644 --- a/protocol/mocks/PerpetualsKeeper.go +++ b/protocol/mocks/PerpetualsKeeper.go @@ -1,4 +1,4 @@ -// Code generated by mockery v2.44.1. DO NOT EDIT. +// Code generated by mockery v2.46.0. DO NOT EDIT. package mocks @@ -393,6 +393,11 @@ func (_m *PerpetualsKeeper) SetLiquidityTier(ctx types.Context, id uint32, name return r0, r1 } +// SetNextPerpetualID provides a mock function with given fields: ctx, nextID +func (_m *PerpetualsKeeper) SetNextPerpetualID(ctx types.Context, nextID uint32) { + _m.Called(ctx, nextID) +} + // SetParams provides a mock function with given fields: ctx, params func (_m *PerpetualsKeeper) SetParams(ctx types.Context, params perpetualstypes.Params) error { ret := _m.Called(ctx, params) @@ -469,4 +474,4 @@ func NewPerpetualsKeeper(t interface { t.Cleanup(func() { mock.AssertExpectations(t) }) return mock -} \ No newline at end of file +} diff --git a/protocol/mocks/PricesKeeper.go b/protocol/mocks/PricesKeeper.go index 4776407623..6f7a512119 100644 --- a/protocol/mocks/PricesKeeper.go +++ b/protocol/mocks/PricesKeeper.go @@ -418,6 +418,11 @@ func (_m *PricesKeeper) PerformStatefulPriceUpdateValidation(ctx types.Context, return r0 } +// SetNextMarketID provides a mock function with given fields: ctx, nextID +func (_m *PricesKeeper) SetNextMarketID(ctx types.Context, nextID uint32) { + _m.Called(ctx, nextID) +} + // UpdateMarketPrices provides a mock function with given fields: ctx, updates func (_m *PricesKeeper) UpdateMarketPrices(ctx types.Context, updates []*pricestypes.MsgUpdateMarketPrices_MarketPrice) error { ret := _m.Called(ctx, updates) diff --git a/protocol/mocks/QueryClient.go b/protocol/mocks/QueryClient.go index e8c611ebb3..862029d0bd 100644 --- a/protocol/mocks/QueryClient.go +++ b/protocol/mocks/QueryClient.go @@ -696,6 +696,117 @@ func (_m *QueryClient) MevNodeToNodeCalculation(ctx context.Context, in *clobtyp return r0, r1 } +// NextClobPairId provides a mock function with given fields: ctx, in, opts +func (_m *QueryClient) NextClobPairId(ctx context.Context, in *clobtypes.QueryNextClobPairIdRequest, opts ...grpc.CallOption) (*clobtypes.QueryNextClobPairIdResponse, 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 NextClobPairId") + } + + var r0 *clobtypes.QueryNextClobPairIdResponse + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *clobtypes.QueryNextClobPairIdRequest, ...grpc.CallOption) (*clobtypes.QueryNextClobPairIdResponse, error)); ok { + return rf(ctx, in, opts...) + } + if rf, ok := ret.Get(0).(func(context.Context, *clobtypes.QueryNextClobPairIdRequest, ...grpc.CallOption) *clobtypes.QueryNextClobPairIdResponse); ok { + r0 = rf(ctx, in, opts...) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*clobtypes.QueryNextClobPairIdResponse) + } + } + + if rf, ok := ret.Get(1).(func(context.Context, *clobtypes.QueryNextClobPairIdRequest, ...grpc.CallOption) error); ok { + r1 = rf(ctx, in, opts...) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} + +// NextMarketId provides a mock function with given fields: ctx, in, opts +func (_m *QueryClient) NextMarketId(ctx context.Context, in *pricestypes.QueryNextMarketIdRequest, opts ...grpc.CallOption) (*pricestypes.QueryNextMarketIdResponse, 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 NextMarketId") + } + + var r0 *pricestypes.QueryNextMarketIdResponse + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *pricestypes.QueryNextMarketIdRequest, ...grpc.CallOption) (*pricestypes.QueryNextMarketIdResponse, error)); ok { + return rf(ctx, in, opts...) + } + if rf, ok := ret.Get(0).(func(context.Context, *pricestypes.QueryNextMarketIdRequest, ...grpc.CallOption) *pricestypes.QueryNextMarketIdResponse); ok { + r0 = rf(ctx, in, opts...) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*pricestypes.QueryNextMarketIdResponse) + } + } + + if rf, ok := ret.Get(1).(func(context.Context, *pricestypes.QueryNextMarketIdRequest, ...grpc.CallOption) error); ok { + r1 = rf(ctx, in, opts...) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} + +// NextPerpetualId provides a mock function with given fields: ctx, in, opts +func (_m *QueryClient) NextPerpetualId(ctx context.Context, in *perpetualstypes.QueryNextPerpetualIdRequest, opts ...grpc.CallOption) (*perpetualstypes.QueryNextPerpetualIdResponse, 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 NextPerpetualId") + } + + var r0 *perpetualstypes.QueryNextPerpetualIdResponse + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *perpetualstypes.QueryNextPerpetualIdRequest, ...grpc.CallOption) (*perpetualstypes.QueryNextPerpetualIdResponse, error)); ok { + return rf(ctx, in, opts...) + } + if rf, ok := ret.Get(0).(func(context.Context, *perpetualstypes.QueryNextPerpetualIdRequest, ...grpc.CallOption) *perpetualstypes.QueryNextPerpetualIdResponse); ok { + r0 = rf(ctx, in, opts...) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*perpetualstypes.QueryNextPerpetualIdResponse) + } + } + + if rf, ok := ret.Get(1).(func(context.Context, *perpetualstypes.QueryNextPerpetualIdRequest, ...grpc.CallOption) error); ok { + r1 = rf(ctx, in, opts...) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} + // Params provides a mock function with given fields: ctx, in, opts func (_m *QueryClient) Params(ctx context.Context, in *perpetualstypes.QueryParamsRequest, opts ...grpc.CallOption) (*perpetualstypes.QueryParamsResponse, error) { _va := make([]interface{}, len(opts)) diff --git a/protocol/mocks/QueryServer.go b/protocol/mocks/QueryServer.go index 4a7770a920..2e1187a66b 100644 --- a/protocol/mocks/QueryServer.go +++ b/protocol/mocks/QueryServer.go @@ -135,6 +135,36 @@ func (_m *QueryServer) MarketPrice(_a0 context.Context, _a1 *types.QueryMarketPr return r0, r1 } +// NextMarketId provides a mock function with given fields: _a0, _a1 +func (_m *QueryServer) NextMarketId(_a0 context.Context, _a1 *types.QueryNextMarketIdRequest) (*types.QueryNextMarketIdResponse, error) { + ret := _m.Called(_a0, _a1) + + if len(ret) == 0 { + panic("no return value specified for NextMarketId") + } + + var r0 *types.QueryNextMarketIdResponse + var r1 error + if rf, ok := ret.Get(0).(func(context.Context, *types.QueryNextMarketIdRequest) (*types.QueryNextMarketIdResponse, error)); ok { + return rf(_a0, _a1) + } + if rf, ok := ret.Get(0).(func(context.Context, *types.QueryNextMarketIdRequest) *types.QueryNextMarketIdResponse); ok { + r0 = rf(_a0, _a1) + } else { + if ret.Get(0) != nil { + r0 = ret.Get(0).(*types.QueryNextMarketIdResponse) + } + } + + if rf, ok := ret.Get(1).(func(context.Context, *types.QueryNextMarketIdRequest) error); ok { + r1 = rf(_a0, _a1) + } else { + r1 = ret.Error(1) + } + + return r0, r1 +} + // NewQueryServer creates a new instance of QueryServer. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations. // The first argument is typically a *testing.T value. func NewQueryServer(t interface { diff --git a/protocol/testing/containertest/preupgrade_genesis.json b/protocol/testing/containertest/preupgrade_genesis.json index 612ed3f5f5..5638c4f3d4 100644 --- a/protocol/testing/containertest/preupgrade_genesis.json +++ b/protocol/testing/containertest/preupgrade_genesis.json @@ -1,11 +1,57 @@ { - "app_name": "dydxprotocold", - "app_version": "6.0.0-dev999", "genesis_time": "2023-01-01T00:00:00Z", "chain_id": "localdydxprotocol", - "initial_height": 1, - "app_hash": null, + "initial_height": "1", + "consensus_params": { + "block": { + "max_bytes": "4194304", + "max_gas": "-1" + }, + "evidence": { + "max_age_num_blocks": "100000", + "max_age_duration": "172800000000000", + "max_bytes": "1048576" + }, + "validator": { + "pub_key_types": [ + "ed25519" + ] + }, + "version": { + "app": "0" + }, + "abci": { + "vote_extensions_enable_height": "1" + } + }, + "app_hash": "", "app_state": { + "affiliates": { + "affiliate_tiers": { + "tiers": [ + { + "req_referred_volume_quote_quantums": "0", + "req_staked_whole_coins": 0, + "taker_fee_share_ppm": 50000 + }, + { + "req_referred_volume_quote_quantums": "1000000000000", + "req_staked_whole_coins": 200, + "taker_fee_share_ppm": 100000 + }, + { + "req_referred_volume_quote_quantums": "5000000000000", + "req_staked_whole_coins": 1000, + "taker_fee_share_ppm": 125000 + }, + { + "req_referred_volume_quote_quantums": "25000000000000", + "req_staked_whole_coins": 5000, + "taker_fee_share_ppm": 150000 + } + ] + } + }, "assets": { "assets": [ { @@ -775,7 +821,12 @@ "validator_slash_events": [] }, "dydxaccountplus": { - "accounts": [] + "accounts": [], + "params": { + "is_smart_account_active": false + }, + "next_authenticator_id": "0", + "authenticator_data": [] }, "epochs": { "epoch_info_list": [ @@ -1159,8 +1210,8 @@ "amount": "10000000" } ], - "max_deposit_period": "300s", - "voting_period": "300s", + "max_deposit_period": "120s", + "voting_period": "120s", "quorum": "0.334000000000000000", "threshold": "0.500000000000000000", "veto_threshold": "0.334000000000000000", @@ -1246,7 +1297,12 @@ } }, "listing": { - "hard_cap_for_markets": 0 + "hard_cap_for_markets": 500, + "listing_vault_deposit_params": { + "new_vault_deposit_amount": "10000000000", + "main_vault_deposit_amount": "0", + "num_blocks_to_lock_shares": 2592000 + } }, "marketmap": { "market_map": { @@ -1426,21 +1482,20 @@ } ] }, - "POL/USD": { + "MATIC/USD": { "ticker": { "currency_pair": { - "Base": "POL", + "Base": "MATIC", "Quote": "USD" }, - "decimals": "10", - "min_provider_count": "3", - "enabled": true, - "metadata_JSON": "" + "decimals": 10, + "min_provider_count": 3, + "enabled": true }, "provider_configs": [ { "name": "binance_ws", - "off_chain_ticker": "POLUSDT", + "off_chain_ticker": "MATICUSDT", "normalize_by_pair": { "Base": "USDT", "Quote": "USD" @@ -1448,7 +1503,7 @@ }, { "name": "bybit_ws", - "off_chain_ticker": "POLUSDT", + "off_chain_ticker": "MATICUSDT", "normalize_by_pair": { "Base": "USDT", "Quote": "USD" @@ -1456,15 +1511,39 @@ }, { "name": "coinbase_ws", - "off_chain_ticker": "POL-USD" + "off_chain_ticker": "MATIC-USD" }, { - "name": "crypto_dot_com_ws", - "off_chain_ticker": "POL_USD" + "name": "gate_ws", + "off_chain_ticker": "MATIC_USDT", + "normalize_by_pair": { + "Base": "USDT", + "Quote": "USD" + } + }, + { + "name": "huobi_ws", + "off_chain_ticker": "maticusdt", + "normalize_by_pair": { + "Base": "USDT", + "Quote": "USD" + } + }, + { + "name": "kraken_api", + "off_chain_ticker": "MATICUSD" + }, + { + "name": "kucoin_ws", + "off_chain_ticker": "MATIC-USDT", + "normalize_by_pair": { + "Base": "USDT", + "Quote": "USD" + } }, { "name": "okx_ws", - "off_chain_ticker": "POL-USDT", + "off_chain_ticker": "MATIC-USDT", "normalize_by_pair": { "Base": "USDT", "Quote": "USD" @@ -3345,7 +3424,7 @@ }, { "params": { - "ticker": "POL-USD", + "ticker": "MATIC-USD", "id": 3, "market_id": 3, "atomic_resolution": -5, @@ -3680,7 +3759,7 @@ "market_id": 33, "atomic_resolution": -10, "default_funding_ppm": 0, - "liquidity_tier": 4, + "liquidity_tier": 7, "market_type": 1 } } @@ -3691,17 +3770,15 @@ "name": "Large-Cap", "initial_margin_ppm": 50000, "maintenance_fraction_ppm": 600000, - "base_position_notional": 1000000000000, "impact_notional": 10000000000, "open_interest_lower_cap": 0, "open_interest_upper_cap": 0 }, { "id": 1, - "name": "Mid-Cap", + "name": "Small-Cap", "initial_margin_ppm": 100000, "maintenance_fraction_ppm": 500000, - "base_position_notional": 250000000000, "impact_notional": 5000000000, "open_interest_lower_cap": 20000000000000, "open_interest_upper_cap": 50000000000000 @@ -3711,7 +3788,6 @@ "name": "Long-Tail", "initial_margin_ppm": 200000, "maintenance_fraction_ppm": 500000, - "base_position_notional": 100000000000, "impact_notional": 2500000000, "open_interest_lower_cap": 5000000000000, "open_interest_upper_cap": 10000000000000 @@ -3721,25 +3797,49 @@ "name": "Safety", "initial_margin_ppm": 1000000, "maintenance_fraction_ppm": 200000, - "base_position_notional": 1000000000, "impact_notional": 2500000000, "open_interest_lower_cap": 2000000000000, "open_interest_upper_cap": 5000000000000 }, { "id": 4, + "name": "Isolated", + "initial_margin_ppm": 50000, + "maintenance_fraction_ppm": 600000, + "impact_notional": 2500000000, + "open_interest_lower_cap": 500000000000, + "open_interest_upper_cap": 1000000000000 + }, + { + "id": 5, + "name": "Mid-Cap", + "initial_margin_ppm": 50000, + "maintenance_fraction_ppm": 600000, + "impact_notional": 5000000000, + "open_interest_lower_cap": 40000000000000, + "open_interest_upper_cap": 100000000000000 + }, + { + "id": 6, + "name": "FX", + "initial_margin_ppm": 10000, + "maintenance_fraction_ppm": 500000, + "impact_notional": 2500000000, + "open_interest_lower_cap": 500000000000, + "open_interest_upper_cap": 1000000000000 + }, + { + "id": 7, "name": "test-usd-100x-liq-tier-linear", "initial_margin_ppm": 10007, "maintenance_fraction_ppm": 500009, - "base_position_notional": 1000000000039, "impact_notional": 50000000000 }, { - "id": 5, + "id": 8, "name": "test-usd-100x-liq-tier-nonlinear", "initial_margin_ppm": 10007, "maintenance_fraction_ppm": 500009, - "base_position_notional": 100000007, "impact_notional": 50000000000 } ], @@ -3776,12 +3876,12 @@ "exchange_config_json": "{\"exchanges\":[{\"exchangeName\":\"Binance\",\"ticker\":\"LINKUSDT\",\"adjustByMarket\":\"USDT-USD\"},{\"exchangeName\":\"Bybit\",\"ticker\":\"LINKUSDT\",\"adjustByMarket\":\"USDT-USD\"},{\"exchangeName\":\"CoinbasePro\",\"ticker\":\"LINK-USD\"},{\"exchangeName\":\"Kraken\",\"ticker\":\"LINKUSD\"},{\"exchangeName\":\"Kucoin\",\"ticker\":\"LINK-USDT\",\"adjustByMarket\":\"USDT-USD\"},{\"exchangeName\":\"Okx\",\"ticker\":\"LINK-USDT\",\"adjustByMarket\":\"USDT-USD\"}]}" }, { - "pair": "POL-USD", + "pair": "MATIC-USD", "id": 3, "exponent": -10, "min_exchanges": 3, "min_price_change_ppm": 2500, - "exchange_config_json": "{\"exchanges\":[{\"exchangeName\":\"Bybit\",\"ticker\":\"POLUSDT\",\"adjustByMarket\":\"USDT-USD\"},{\"exchangeName\":\"CoinbasePro\",\"ticker\":\"POL-USD\"},{\"exchangeName\":\"CryptoCom\",\"ticker\":\"POL_USD\"},{\"exchangeName\":\"Okx\",\"ticker\":\"POL-USDT\",\"adjustByMarket\":\"USDT-USD\"}]}" + "exchange_config_json": "{\"exchanges\":[{\"exchangeName\":\"Binance\",\"ticker\":\"MATICUSDT\",\"adjustByMarket\":\"USDT-USD\"},{\"exchangeName\":\"Bybit\",\"ticker\":\"MATICUSDT\",\"adjustByMarket\":\"USDT-USD\"},{\"exchangeName\":\"CoinbasePro\",\"ticker\":\"MATIC-USD\"},{\"exchangeName\":\"Gate\",\"ticker\":\"MATIC_USDT\",\"adjustByMarket\":\"USDT-USD\"},{\"exchangeName\":\"Huobi\",\"ticker\":\"maticusdt\",\"adjustByMarket\":\"USDT-USD\"},{\"exchangeName\":\"Kraken\",\"ticker\":\"MATICUSD\"},{\"exchangeName\":\"Kucoin\",\"ticker\":\"MATIC-USDT\",\"adjustByMarket\":\"USDT-USD\"},{\"exchangeName\":\"Okx\",\"ticker\":\"MATIC-USDT\",\"adjustByMarket\":\"USDT-USD\"}]}" }, { "pair": "CRV-USD", @@ -4331,21 +4431,7 @@ "asset_positions": [ { "asset_id": 0, - "quantums": "2000000000", - "index": 0 - } - ] - }, - { - "id": { - "owner": "dydx190te44zcctdgk0qmqtenve2m00g3r2dn7ntd72", - "number": 0 - }, - "margin_enabled": true, - "asset_positions": [ - { - "asset_id": 0, - "quantums": "3000000000", + "quantums": "1000000000", "index": 0 } ] @@ -4363,31 +4449,25 @@ }, "upgrade": {}, "vault": { + "total_shares": { + "num_shares": "2000000000" + }, + "owner_shares": [ + { + "owner": "dydx199tqg4wdlnu4qjlxchpd7seg454937hjrknju4", + "shares": { + "num_shares": "2000000000" + } + } + ], "vaults": [ { "vault_id": { "type": "VAULT_TYPE_CLOB", "number": 0 }, - "total_shares": { - "num_shares": "1000000000" - }, - "owner_shares": [ - { - "owner": "dydx199tqg4wdlnu4qjlxchpd7seg454937hjrknju4", - "shares": { - "num_shares": "1000000000" - } - } - ], - "quoting_params": { - "layers": 3, - "spread_min_ppm": 1500, - "spread_buffer_ppm": 500, - "skew_factor_ppm": 1000000, - "order_size_pct_ppm": 50000, - "order_expiration_seconds": 30, - "activation_threshold_quote_quantums": "500000000" + "vault_params": { + "status": "VAULT_STATUS_QUOTING" } }, { @@ -4395,52 +4475,9 @@ "type": "VAULT_TYPE_CLOB", "number": 1 }, - "total_shares": { - "num_shares": "3000000000" - }, - "owner_shares": [ - { - "owner": "dydx199tqg4wdlnu4qjlxchpd7seg454937hjrknju4", - "shares": { - "num_shares": "1000000000" - } - }, - { - "owner": "dydx10fx7sy6ywd5senxae9dwytf8jxek3t2gcen2vs", - "shares": { - "num_shares": "1000000000" - } - }, - { - "owner": "dydx1fjg6zp6vv8t9wvy4lps03r5l4g7tkjw9wvmh70", - "shares": { - "num_shares": "1000000000" - } - } - ] - }, - { - "vault_id": { - "type": "VAULT_TYPE_CLOB", - "number": 2 - }, - "total_shares": { - "num_shares": "556677" - }, - "owner_shares": [ - { - "owner": "dydx199tqg4wdlnu4qjlxchpd7seg454937hjrknju4", - "shares": { - "num_shares": "123456" - } - }, - { - "owner": "dydx10fx7sy6ywd5senxae9dwytf8jxek3t2gcen2vs", - "shares": { - "num_shares": "433221" - } - } - ] + "vault_params": { + "status": "VAULT_STATUS_QUOTING" + } } ], "default_quoting_params": { @@ -4451,6 +4488,10 @@ "order_size_pct_ppm": 100000, "order_expiration_seconds": 60, "activation_threshold_quote_quantums": "1000000000" + }, + "all_owner_share_unlocks": [], + "operator_params": { + "operator": "dydx10d07y265gmmuvt4z0w9aw880jnsr700jnmapky" } }, "vest": { @@ -4471,29 +4512,5 @@ } ] } - }, - "consensus": { - "params": { - "block": { - "max_bytes": "4194304", - "max_gas": "-1" - }, - "evidence": { - "max_age_num_blocks": "100000", - "max_age_duration": "172800000000000", - "max_bytes": "1048576" - }, - "validator": { - "pub_key_types": [ - "ed25519" - ] - }, - "version": { - "app": "0" - }, - "abci": { - "vote_extensions_enable_height": "1" - } - } } -} \ No newline at end of file +} diff --git a/protocol/testing/version/VERSION_CURRENT b/protocol/testing/version/VERSION_CURRENT index 5593dc1fd4..d46924618c 100644 --- a/protocol/testing/version/VERSION_CURRENT +++ b/protocol/testing/version/VERSION_CURRENT @@ -1 +1 @@ -v7.0 \ No newline at end of file +v8.0 \ No newline at end of file diff --git a/protocol/testing/version/VERSION_FULL_NAME_PREUPGRADE b/protocol/testing/version/VERSION_FULL_NAME_PREUPGRADE index 5d112be4c5..d4a02f3447 100644 --- a/protocol/testing/version/VERSION_FULL_NAME_PREUPGRADE +++ b/protocol/testing/version/VERSION_FULL_NAME_PREUPGRADE @@ -1 +1 @@ -v6.0.0-dev999 \ No newline at end of file +v7.0.2 \ No newline at end of file diff --git a/protocol/testing/version/VERSION_PREUPGRADE b/protocol/testing/version/VERSION_PREUPGRADE index 9f925ba24c..5593dc1fd4 100644 --- a/protocol/testing/version/VERSION_PREUPGRADE +++ b/protocol/testing/version/VERSION_PREUPGRADE @@ -1 +1 @@ -v6.0.0 \ No newline at end of file +v7.0 \ No newline at end of file diff --git a/protocol/x/clob/keeper/grpc_query_clob_pair.go b/protocol/x/clob/keeper/grpc_query_clob_pair.go index f1597111aa..ed9bf4d890 100644 --- a/protocol/x/clob/keeper/grpc_query_clob_pair.go +++ b/protocol/x/clob/keeper/grpc_query_clob_pair.go @@ -58,3 +58,14 @@ func (k Keeper) ClobPair(c context.Context, req *types.QueryGetClobPairRequest) return &types.QueryClobPairResponse{ClobPair: val}, nil } + +func (k Keeper) NextClobPairId( + c context.Context, + request *types.QueryNextClobPairIdRequest, +) (*types.QueryNextClobPairIdResponse, error) { + ctx := lib.UnwrapSDKContext(c, types.ModuleName) + nextId := k.GetNextClobPairID(ctx) + return &types.QueryNextClobPairIdResponse{ + NextClobPairId: nextId, + }, nil +} diff --git a/protocol/x/clob/types/clob_keeper.go b/protocol/x/clob/types/clob_keeper.go index f5bbe110e0..770eaf491f 100644 --- a/protocol/x/clob/types/clob_keeper.go +++ b/protocol/x/clob/types/clob_keeper.go @@ -152,4 +152,5 @@ type ClobKeeper interface { ResetAllDeliveredOrderIds(ctx sdk.Context) // Migrate order expiration state (for upgrading to 5.2 only) UnsafeMigrateOrderExpirationState(ctx sdk.Context) + SetNextClobPairID(ctx sdk.Context, nextID uint32) } diff --git a/protocol/x/clob/types/query.pb.go b/protocol/x/clob/types/query.pb.go index a6f0c83c55..b259206910 100644 --- a/protocol/x/clob/types/query.pb.go +++ b/protocol/x/clob/types/query.pb.go @@ -767,6 +767,88 @@ func (m *QueryLiquidationsConfigurationResponse) GetLiquidationsConfig() Liquida return LiquidationsConfig{} } +// QueryNextClobPairIdRequest is a request message for the next clob pair id +type QueryNextClobPairIdRequest struct { +} + +func (m *QueryNextClobPairIdRequest) Reset() { *m = QueryNextClobPairIdRequest{} } +func (m *QueryNextClobPairIdRequest) String() string { return proto.CompactTextString(m) } +func (*QueryNextClobPairIdRequest) ProtoMessage() {} +func (*QueryNextClobPairIdRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_3365c195b25c5bc0, []int{14} +} +func (m *QueryNextClobPairIdRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *QueryNextClobPairIdRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_QueryNextClobPairIdRequest.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 *QueryNextClobPairIdRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_QueryNextClobPairIdRequest.Merge(m, src) +} +func (m *QueryNextClobPairIdRequest) XXX_Size() int { + return m.Size() +} +func (m *QueryNextClobPairIdRequest) XXX_DiscardUnknown() { + xxx_messageInfo_QueryNextClobPairIdRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_QueryNextClobPairIdRequest proto.InternalMessageInfo + +// QueryNextClobPairIdResponse is a response message for the next clob pair id +type QueryNextClobPairIdResponse struct { + NextClobPairId uint32 `protobuf:"varint,1,opt,name=next_clob_pair_id,json=nextClobPairId,proto3" json:"next_clob_pair_id,omitempty"` +} + +func (m *QueryNextClobPairIdResponse) Reset() { *m = QueryNextClobPairIdResponse{} } +func (m *QueryNextClobPairIdResponse) String() string { return proto.CompactTextString(m) } +func (*QueryNextClobPairIdResponse) ProtoMessage() {} +func (*QueryNextClobPairIdResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_3365c195b25c5bc0, []int{15} +} +func (m *QueryNextClobPairIdResponse) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *QueryNextClobPairIdResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_QueryNextClobPairIdResponse.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 *QueryNextClobPairIdResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_QueryNextClobPairIdResponse.Merge(m, src) +} +func (m *QueryNextClobPairIdResponse) XXX_Size() int { + return m.Size() +} +func (m *QueryNextClobPairIdResponse) XXX_DiscardUnknown() { + xxx_messageInfo_QueryNextClobPairIdResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_QueryNextClobPairIdResponse proto.InternalMessageInfo + +func (m *QueryNextClobPairIdResponse) GetNextClobPairId() uint32 { + if m != nil { + return m.NextClobPairId + } + return 0 +} + // StreamOrderbookUpdatesRequest is a request message for the // StreamOrderbookUpdates method. type StreamOrderbookUpdatesRequest struct { @@ -782,7 +864,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{14} + return fileDescriptor_3365c195b25c5bc0, []int{16} } func (m *StreamOrderbookUpdatesRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -843,7 +925,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{15} + return fileDescriptor_3365c195b25c5bc0, []int{17} } func (m *StreamOrderbookUpdatesResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -903,7 +985,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{16} + return fileDescriptor_3365c195b25c5bc0, []int{18} } func (m *StreamUpdate) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1044,7 +1126,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{17} + return fileDescriptor_3365c195b25c5bc0, []int{19} } func (m *StreamOrderbookUpdate) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1104,7 +1186,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{18} + return fileDescriptor_3365c195b25c5bc0, []int{20} } func (m *StreamOrderbookFill) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1175,7 +1257,7 @@ func (m *StreamTakerOrder) Reset() { *m = StreamTakerOrder{} } func (m *StreamTakerOrder) String() string { return proto.CompactTextString(m) } func (*StreamTakerOrder) ProtoMessage() {} func (*StreamTakerOrder) Descriptor() ([]byte, []int) { - return fileDescriptor_3365c195b25c5bc0, []int{19} + return fileDescriptor_3365c195b25c5bc0, []int{21} } func (m *StreamTakerOrder) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1278,7 +1360,7 @@ func (m *StreamTakerOrderStatus) Reset() { *m = StreamTakerOrderStatus{} func (m *StreamTakerOrderStatus) String() string { return proto.CompactTextString(m) } func (*StreamTakerOrderStatus) ProtoMessage() {} func (*StreamTakerOrderStatus) Descriptor() ([]byte, []int) { - return fileDescriptor_3365c195b25c5bc0, []int{20} + return fileDescriptor_3365c195b25c5bc0, []int{22} } func (m *StreamTakerOrderStatus) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1344,6 +1426,8 @@ func init() { proto.RegisterType((*QueryStatefulOrderResponse)(nil), "dydxprotocol.clob.QueryStatefulOrderResponse") proto.RegisterType((*QueryLiquidationsConfigurationRequest)(nil), "dydxprotocol.clob.QueryLiquidationsConfigurationRequest") proto.RegisterType((*QueryLiquidationsConfigurationResponse)(nil), "dydxprotocol.clob.QueryLiquidationsConfigurationResponse") + proto.RegisterType((*QueryNextClobPairIdRequest)(nil), "dydxprotocol.clob.QueryNextClobPairIdRequest") + proto.RegisterType((*QueryNextClobPairIdResponse)(nil), "dydxprotocol.clob.QueryNextClobPairIdResponse") proto.RegisterType((*StreamOrderbookUpdatesRequest)(nil), "dydxprotocol.clob.StreamOrderbookUpdatesRequest") proto.RegisterType((*StreamOrderbookUpdatesResponse)(nil), "dydxprotocol.clob.StreamOrderbookUpdatesResponse") proto.RegisterType((*StreamUpdate)(nil), "dydxprotocol.clob.StreamUpdate") @@ -1356,114 +1440,118 @@ func init() { func init() { proto.RegisterFile("dydxprotocol/clob/query.proto", fileDescriptor_3365c195b25c5bc0) } var fileDescriptor_3365c195b25c5bc0 = []byte{ - // 1708 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x58, 0x41, 0x4c, 0x1c, 0xc9, - 0x15, 0x9d, 0x06, 0x6c, 0xc3, 0x1f, 0xe3, 0xc5, 0xe5, 0xb5, 0x77, 0x76, 0x0c, 0x03, 0x6e, 0xc7, - 0x18, 0xd8, 0x78, 0x1a, 0xd8, 0xd5, 0x6a, 0x63, 0xa2, 0x8d, 0x80, 0x04, 0x83, 0x62, 0xb2, 0x6c, - 0xc3, 0x7a, 0x51, 0xb2, 0x52, 0xab, 0xa6, 0xbb, 0x18, 0x4a, 0x74, 0x77, 0x0d, 0xdd, 0xd5, 0x23, - 0x50, 0x14, 0x45, 0xca, 0x61, 0x2f, 0x49, 0xa4, 0x48, 0x39, 0xe4, 0x10, 0x29, 0x97, 0x9c, 0xa3, - 0xe4, 0x92, 0x63, 0x94, 0xe4, 0xb6, 0x47, 0x4b, 0xb9, 0xe4, 0x10, 0x45, 0x91, 0x9d, 0x73, 0x8e, - 0x39, 0xaf, 0xba, 0xaa, 0x7a, 0xa6, 0x7b, 0xba, 0x7b, 0xc0, 0x5c, 0xa0, 0xeb, 0xd7, 0xff, 0xaf, - 0xde, 0xff, 0xf5, 0xeb, 0xd7, 0xaf, 0x81, 0x19, 0xe7, 0xdc, 0x39, 0xeb, 0x04, 0x8c, 0x33, 0x9b, - 0xb9, 0x86, 0xed, 0xb2, 0x96, 0x71, 0x1a, 0x91, 0xe0, 0xbc, 0x29, 0x64, 0xe8, 0x76, 0x7a, 0xba, - 0x19, 0x4f, 0xd7, 0xdf, 0x6e, 0xb3, 0x36, 0x13, 0x22, 0x23, 0xfe, 0x92, 0x8a, 0xf5, 0xe9, 0x36, - 0x63, 0x6d, 0x97, 0x18, 0xb8, 0x43, 0x0d, 0xec, 0xfb, 0x8c, 0x63, 0x4e, 0x99, 0x1f, 0xaa, 0xd9, - 0x25, 0x9b, 0x85, 0x1e, 0x0b, 0x8d, 0x16, 0x0e, 0x89, 0xc4, 0x37, 0xba, 0x2b, 0x2d, 0xc2, 0xf1, - 0x8a, 0xd1, 0xc1, 0x6d, 0xea, 0x0b, 0x65, 0xa5, 0x6b, 0xe4, 0x19, 0xb5, 0x5c, 0x66, 0x9f, 0x58, - 0x01, 0xe6, 0xc4, 0x72, 0xa9, 0x47, 0xb9, 0x65, 0x33, 0xff, 0x88, 0xb6, 0x95, 0xc1, 0x83, 0xbc, - 0x41, 0xfc, 0xc7, 0xea, 0x60, 0x1a, 0x28, 0x95, 0xe5, 0xbc, 0x0a, 0x39, 0x8d, 0x28, 0x3f, 0xb7, - 0x38, 0x25, 0x41, 0x11, 0x68, 0x41, 0x5c, 0x58, 0xe0, 0x90, 0x04, 0x70, 0x36, 0x3f, 0xed, 0x61, - 0x6e, 0x1f, 0x93, 0xc4, 0xe3, 0xf7, 0xf2, 0x0a, 0x2e, 0x3d, 0x8d, 0xa8, 0x23, 0xe3, 0x92, 0x5d, - 0xec, 0x7e, 0x01, 0x1a, 0xe9, 0xaa, 0xc9, 0x8f, 0x33, 0x93, 0xd4, 0x77, 0xc8, 0x19, 0x09, 0x0c, - 0x76, 0x74, 0x64, 0xd9, 0xc7, 0x98, 0xfa, 0x56, 0xd4, 0x71, 0x30, 0x27, 0x61, 0x5e, 0xa2, 0xec, - 0x17, 0x32, 0xf6, 0x61, 0xd4, 0xc2, 0xb6, 0xcd, 0x22, 0x9f, 0x87, 0x46, 0xc8, 0x03, 0x82, 0x3d, - 0xea, 0x27, 0x34, 0x16, 0xcb, 0x35, 0x7b, 0xdf, 0x4a, 0xf5, 0x61, 0x46, 0xb5, 0x13, 0x50, 0x9b, - 0xe4, 0xf0, 0xf4, 0x45, 0x78, 0xe7, 0xd3, 0x78, 0xaf, 0x9f, 0x11, 0xbe, 0xe9, 0xb2, 0xd6, 0x1e, - 0xa6, 0x81, 0x49, 0x4e, 0x23, 0x12, 0x72, 0x74, 0x0b, 0x46, 0xa8, 0x53, 0xd3, 0xe6, 0xb4, 0x85, - 0x49, 0x73, 0x84, 0x3a, 0xfa, 0xe7, 0x70, 0x57, 0xa8, 0xf6, 0xf5, 0xc2, 0x0e, 0xf3, 0x43, 0x82, - 0x3e, 0x86, 0x89, 0xde, 0x66, 0x0a, 0xfd, 0xea, 0xea, 0xfd, 0x66, 0x2e, 0x29, 0x9b, 0x89, 0xdd, - 0xc6, 0xd8, 0x57, 0xff, 0x9e, 0xad, 0x98, 0xe3, 0xb6, 0x1a, 0xeb, 0x58, 0x71, 0x58, 0x77, 0xdd, - 0x41, 0x0e, 0x5b, 0x00, 0xfd, 0xe4, 0x53, 0xd8, 0xf3, 0x4d, 0x99, 0xa9, 0xcd, 0x38, 0x53, 0x9b, - 0xf2, 0x24, 0xa8, 0x4c, 0x6d, 0xee, 0xe1, 0x36, 0x51, 0xb6, 0x66, 0xca, 0x52, 0xff, 0xbd, 0x06, - 0xb5, 0x0c, 0xf9, 0x75, 0xd7, 0x2d, 0xe3, 0x3f, 0xfa, 0x86, 0xfc, 0xd1, 0xb3, 0x0c, 0xc9, 0x11, - 0x41, 0xf2, 0xf1, 0x85, 0x24, 0xe5, 0xe2, 0x19, 0x96, 0xff, 0xd2, 0x60, 0x76, 0x97, 0x74, 0x7f, - 0xc0, 0x1c, 0x72, 0xc0, 0xe2, 0xbf, 0x9b, 0xd8, 0xb5, 0x23, 0x57, 0x4c, 0x26, 0x11, 0xf9, 0x02, - 0xee, 0xc9, 0xa3, 0xd6, 0x09, 0x58, 0x87, 0x85, 0x24, 0xb0, 0x54, 0x52, 0xf7, 0xa2, 0x93, 0x67, - 0xfe, 0x02, 0xbb, 0x71, 0x52, 0xb3, 0x60, 0x97, 0x74, 0x77, 0xa5, 0xb6, 0xf9, 0xb6, 0x40, 0xd9, - 0x53, 0x20, 0x4a, 0x8a, 0x7e, 0x04, 0x77, 0xbb, 0x89, 0xb2, 0xe5, 0x91, 0xae, 0xe5, 0x11, 0x1e, - 0x50, 0x3b, 0xec, 0x79, 0x95, 0x07, 0xcf, 0x10, 0xde, 0x95, 0xea, 0xe6, 0x9d, 0x6e, 0x7a, 0x49, - 0x29, 0xd4, 0xff, 0xa7, 0xc1, 0x5c, 0xb9, 0x7b, 0x6a, 0x33, 0xda, 0x70, 0x23, 0x20, 0x61, 0xe4, - 0xf2, 0x50, 0x6d, 0xc5, 0xb3, 0x8b, 0xd6, 0x2c, 0x40, 0x89, 0x15, 0xd6, 0x7d, 0xe7, 0x05, 0x73, - 0x23, 0x8f, 0xec, 0x91, 0x20, 0xde, 0x3a, 0xb5, 0x6d, 0x09, 0x7a, 0x1d, 0xc3, 0x9d, 0x02, 0x2d, - 0x34, 0x07, 0x37, 0x7b, 0xc9, 0x60, 0xf5, 0xf2, 0x1f, 0x92, 0xcd, 0xde, 0x71, 0xd0, 0x14, 0x8c, - 0x7a, 0xa4, 0x2b, 0x22, 0x32, 0x62, 0xc6, 0x9f, 0xe8, 0x1e, 0x5c, 0xef, 0x0a, 0x90, 0xda, 0xe8, - 0x9c, 0xb6, 0x30, 0x66, 0xaa, 0x91, 0xbe, 0x04, 0x0b, 0x22, 0xe9, 0xbe, 0x27, 0xea, 0xd8, 0x01, - 0x25, 0xc1, 0xf3, 0xb8, 0x8a, 0x6d, 0x8a, 0xba, 0x12, 0x05, 0xe9, 0x7d, 0xd5, 0x7f, 0xab, 0xc1, - 0xe2, 0x25, 0x94, 0x55, 0x94, 0x7c, 0xa8, 0x95, 0x15, 0x47, 0x95, 0x07, 0x46, 0x41, 0xd8, 0x86, - 0x41, 0xab, 0xf0, 0xdc, 0x25, 0x45, 0x3a, 0xfa, 0x22, 0x3c, 0x16, 0xe4, 0x36, 0xe2, 0xa4, 0x31, - 0x31, 0x27, 0xe5, 0x8e, 0xfc, 0x46, 0x53, 0x5e, 0x0f, 0xd5, 0x55, 0x7e, 0x9c, 0xc0, 0x3b, 0x25, - 0x17, 0x87, 0x72, 0xa3, 0x59, 0xe0, 0xc6, 0x10, 0x60, 0xe5, 0x85, 0x4c, 0xee, 0x01, 0x15, 0xfd, - 0x10, 0xde, 0x15, 0xc4, 0xf6, 0x39, 0xe6, 0xe4, 0x28, 0x72, 0x3f, 0x89, 0x2f, 0x8b, 0xe4, 0x5c, - 0xad, 0xc1, 0xb8, 0xb8, 0x3c, 0x92, 0x3d, 0xaf, 0xae, 0xd6, 0x0b, 0x96, 0x16, 0x26, 0x3b, 0x4e, - 0x92, 0x4b, 0x4c, 0x0e, 0xf5, 0x3f, 0x6b, 0x50, 0x2f, 0x82, 0x56, 0x5e, 0x1e, 0xc2, 0x5b, 0x12, - 0xbb, 0xe3, 0x62, 0x9b, 0x78, 0xc4, 0xe7, 0x6a, 0x89, 0xc5, 0x82, 0x25, 0x9e, 0x33, 0xbf, 0x7d, - 0x40, 0x02, 0x4f, 0x40, 0xec, 0x25, 0x06, 0x6a, 0xc5, 0x5b, 0x2c, 0x23, 0x45, 0xb3, 0x50, 0x3d, - 0xa2, 0xae, 0x6b, 0x61, 0x2f, 0x2e, 0xfc, 0x22, 0x27, 0xc7, 0x4c, 0x88, 0x45, 0xeb, 0x42, 0x82, - 0xa6, 0x61, 0x82, 0x07, 0xb4, 0xdd, 0x26, 0x01, 0x71, 0x44, 0x76, 0x8e, 0x9b, 0x7d, 0x81, 0xfe, - 0x18, 0x1e, 0x09, 0xda, 0xcf, 0x53, 0xd7, 0x5e, 0xe1, 0xa6, 0x7e, 0xa9, 0xc1, 0xfc, 0x45, 0x9a, - 0xca, 0xd9, 0x2f, 0xe0, 0x4e, 0xc1, 0x2d, 0xaa, 0x1c, 0x7e, 0x54, 0xe4, 0x70, 0x0e, 0x52, 0x39, - 0x8b, 0xdc, 0xdc, 0x8c, 0xfe, 0x47, 0x0d, 0x66, 0xf6, 0xc5, 0x1d, 0x26, 0xe2, 0xd3, 0x62, 0xec, - 0xe4, 0x33, 0x79, 0x95, 0x26, 0x1b, 0x99, 0x3f, 0xc0, 0xa3, 0x03, 0x07, 0x78, 0x17, 0x6e, 0xf5, - 0x2f, 0x4b, 0x8b, 0x3a, 0x71, 0x75, 0x1b, 0xcd, 0x97, 0xce, 0xd4, 0xe5, 0xda, 0xdc, 0xef, 0x7d, - 0xef, 0x38, 0xe6, 0x64, 0x98, 0x1a, 0x85, 0x68, 0x06, 0xc0, 0xc3, 0xc1, 0x09, 0x91, 0x50, 0xa3, - 0x62, 0xb9, 0x09, 0x29, 0xd9, 0x71, 0x42, 0x1d, 0x43, 0xa3, 0x8c, 0xb0, 0x8a, 0xd8, 0x77, 0xe0, - 0x86, 0x6a, 0x07, 0x54, 0xc9, 0x9b, 0x2d, 0x88, 0x92, 0xc4, 0x90, 0xa6, 0x49, 0xfa, 0x29, 0x2b, - 0xfd, 0xff, 0xa3, 0x70, 0x33, 0x3d, 0x8f, 0x1e, 0xc0, 0x4d, 0x79, 0xac, 0x8e, 0x09, 0x6d, 0x1f, - 0x73, 0x55, 0xc4, 0xaa, 0x42, 0xb6, 0x2d, 0x44, 0xe8, 0x3e, 0x4c, 0x90, 0x33, 0x62, 0x5b, 0x1e, - 0x73, 0x88, 0xc8, 0x9b, 0x49, 0x73, 0x3c, 0x16, 0xec, 0x32, 0x87, 0xa0, 0xcf, 0x60, 0x8a, 0x25, - 0x6c, 0x55, 0xab, 0x22, 0x92, 0xa7, 0xba, 0xba, 0x50, 0x4a, 0x6d, 0xc0, 0xbd, 0xed, 0x8a, 0xf9, - 0x16, 0xcb, 0x8a, 0xe2, 0x8b, 0x52, 0x9e, 0x83, 0x38, 0x41, 0x6b, 0x63, 0xa5, 0xf7, 0xd5, 0x00, - 0xe0, 0x16, 0x75, 0xdd, 0xed, 0x8a, 0x39, 0x21, 0x6c, 0xe3, 0x01, 0xda, 0x82, 0x2a, 0xc7, 0x27, - 0x24, 0xb0, 0x84, 0xa8, 0x76, 0x4d, 0x20, 0x3d, 0x2c, 0x45, 0x3a, 0x88, 0x75, 0x05, 0xdc, 0x76, - 0xc5, 0x04, 0xde, 0x1b, 0x21, 0x0b, 0x6e, 0xa7, 0x32, 0x41, 0x39, 0x7a, 0x5d, 0xa0, 0x2d, 0x0f, - 0x49, 0x06, 0x01, 0xda, 0x4f, 0x89, 0x9e, 0xc3, 0x53, 0xe1, 0x80, 0x0c, 0x7d, 0x1f, 0x6e, 0x8a, - 0xc6, 0x2b, 0xc1, 0xbe, 0x51, 0xe4, 0xb3, 0x6c, 0xcd, 0x14, 0xec, 0x5e, 0x3c, 0xe8, 0x21, 0x56, - 0x3b, 0xfd, 0xe1, 0xc6, 0x14, 0xdc, 0x92, 0x30, 0x96, 0x47, 0xc2, 0x10, 0xb7, 0x89, 0xfe, 0x4b, - 0x0d, 0xee, 0x16, 0x46, 0x1f, 0xd5, 0x61, 0x3c, 0xf4, 0x71, 0x27, 0x3c, 0x66, 0x72, 0xf7, 0xc7, - 0xcd, 0xde, 0x18, 0x1d, 0xf6, 0xf3, 0x4d, 0x26, 0xfe, 0x47, 0x59, 0x3e, 0xaa, 0x7f, 0x6d, 0xe6, - 0xbb, 0xd5, 0x4f, 0x8e, 0x8e, 0x36, 0x63, 0x81, 0x5c, 0xe4, 0xc5, 0xca, 0x60, 0x22, 0xfe, 0x41, - 0x83, 0x3b, 0x05, 0x9b, 0x87, 0xd6, 0x40, 0x9c, 0x3f, 0xd9, 0xaa, 0xa8, 0x52, 0x30, 0x5d, 0xd2, - 0x62, 0x89, 0x56, 0xc4, 0x14, 0x1d, 0x99, 0xf8, 0x44, 0x1f, 0xc2, 0x75, 0xb1, 0xcd, 0x09, 0xdb, - 0x5a, 0x59, 0x5d, 0x56, 0x6c, 0x94, 0x76, 0x7c, 0x08, 0x52, 0xb5, 0x51, 0x9e, 0xcc, 0x31, 0xb3, - 0xda, 0x2f, 0x8e, 0xa1, 0xfe, 0xe5, 0x08, 0x4c, 0x0d, 0xa6, 0x08, 0x5a, 0x86, 0x6b, 0x32, 0xad, - 0x24, 0xcf, 0xd2, 0xe5, 0xb6, 0x2b, 0xa6, 0x54, 0x44, 0x87, 0x70, 0x3b, 0x55, 0xaa, 0x54, 0x52, - 0x8e, 0x94, 0x56, 0x78, 0xb9, 0x62, 0xaa, 0xec, 0x25, 0x70, 0x53, 0xee, 0x80, 0x0c, 0x7d, 0x0e, - 0x28, 0x95, 0xe8, 0x56, 0xc8, 0x31, 0x8f, 0x42, 0x75, 0x14, 0x17, 0x2f, 0x91, 0xef, 0xfb, 0xc2, - 0xc0, 0x9c, 0xe2, 0x03, 0x92, 0x8d, 0xc9, 0xcc, 0x09, 0xd2, 0xff, 0xa4, 0xc1, 0xbd, 0x62, 0xdb, - 0x38, 0x8c, 0x99, 0xc5, 0x55, 0x2d, 0x61, 0x29, 0x95, 0x27, 0x80, 0x02, 0xe2, 0x61, 0xea, 0x53, - 0xbf, 0x6d, 0x9d, 0x46, 0xd8, 0xe7, 0x91, 0x17, 0xaa, 0xcb, 0xe8, 0x76, 0x6f, 0xe6, 0x53, 0x35, - 0x81, 0xbe, 0x0b, 0x0d, 0xd6, 0xe1, 0xd4, 0xa3, 0x21, 0xa7, 0x36, 0x76, 0xdd, 0x73, 0x51, 0x0f, - 0x88, 0xd3, 0x37, 0x95, 0x6d, 0xd4, 0x74, 0x56, 0x6b, 0x4b, 0x28, 0x25, 0x28, 0xab, 0xbf, 0x03, - 0xb8, 0x26, 0xae, 0x24, 0xf4, 0x73, 0x0d, 0xc6, 0x93, 0xe6, 0x1c, 0x2d, 0x15, 0x44, 0xa5, 0xe4, - 0x85, 0x53, 0x5f, 0x28, 0xd3, 0x1d, 0x7c, 0xe2, 0xe8, 0x8b, 0x3f, 0xfb, 0xc7, 0x7f, 0x7f, 0x3d, - 0xf2, 0x10, 0x3d, 0x30, 0x86, 0x3c, 0x64, 0x8d, 0x1f, 0x53, 0xe7, 0x27, 0xe8, 0x17, 0x1a, 0x54, - 0x53, 0xaf, 0x8c, 0x72, 0x42, 0xf9, 0xe7, 0x4e, 0xfd, 0xbd, 0x8b, 0x08, 0xa5, 0x9e, 0x2d, 0xfa, - 0x37, 0x04, 0xa7, 0x06, 0x9a, 0x1e, 0xc6, 0x09, 0xfd, 0x55, 0x83, 0x5a, 0x59, 0xbb, 0x8c, 0x56, - 0xdf, 0xa8, 0xb7, 0x96, 0x1c, 0xdf, 0xbf, 0x42, 0x3f, 0xae, 0x3f, 0x15, 0x5c, 0x3f, 0x78, 0xaa, - 0x2d, 0xe9, 0x86, 0x51, 0xf8, 0x92, 0xb6, 0x7c, 0xe6, 0x10, 0x8b, 0x33, 0xf9, 0xdf, 0x4e, 0x91, - 0xfc, 0xbb, 0x06, 0xd3, 0xc3, 0x3a, 0x57, 0xb4, 0x56, 0x16, 0xb5, 0x4b, 0xf4, 0xdd, 0xf5, 0x6f, - 0x5f, 0xcd, 0x58, 0xf9, 0x35, 0x2f, 0xfc, 0x9a, 0x43, 0x0d, 0x63, 0xe8, 0xaf, 0x17, 0xe8, 0x2f, - 0x1a, 0xdc, 0x1f, 0xd2, 0xb6, 0xa2, 0xa7, 0x65, 0x2c, 0x2e, 0x6e, 0xb8, 0xeb, 0x6b, 0x57, 0xb2, - 0x55, 0x0e, 0x3c, 0x12, 0x0e, 0xcc, 0xa2, 0x99, 0xa1, 0x3f, 0xe9, 0xa0, 0xbf, 0x69, 0xf0, 0x6e, - 0x69, 0xeb, 0x87, 0x3e, 0x2a, 0x63, 0x70, 0x51, 0x5f, 0x59, 0xff, 0xd6, 0x15, 0x2c, 0x15, 0xf3, - 0xa6, 0x60, 0xbe, 0x80, 0xe6, 0x8d, 0x4b, 0xfd, 0x8c, 0x83, 0x7c, 0x98, 0xcc, 0x74, 0xe7, 0xe8, - 0x9b, 0x65, 0x6b, 0x17, 0xbd, 0x0f, 0xea, 0x4f, 0x2e, 0xa9, 0xad, 0xd8, 0x55, 0xd0, 0x4f, 0x93, - 0x8a, 0x3a, 0xd8, 0xf7, 0xa1, 0xe5, 0xcb, 0xf6, 0x50, 0x49, 0x4f, 0x5b, 0x5f, 0x79, 0x03, 0x0b, - 0x49, 0x60, 0x59, 0xdb, 0xd8, 0xfb, 0xea, 0x55, 0x43, 0x7b, 0xf9, 0xaa, 0xa1, 0xfd, 0xe7, 0x55, - 0x43, 0xfb, 0xd5, 0xeb, 0x46, 0xe5, 0xe5, 0xeb, 0x46, 0xe5, 0x9f, 0xaf, 0x1b, 0x95, 0x1f, 0x7e, - 0xd8, 0xa6, 0xfc, 0x38, 0x6a, 0x35, 0x6d, 0xe6, 0x65, 0x83, 0xd7, 0xfd, 0xe0, 0x89, 0xb8, 0xf0, - 0x8d, 0x9e, 0xe4, 0x4c, 0x06, 0x94, 0x9f, 0x77, 0x48, 0xd8, 0xba, 0x2e, 0xc4, 0xef, 0x7f, 0x1d, - 0x00, 0x00, 0xff, 0xff, 0x04, 0xfd, 0x8b, 0xa4, 0x91, 0x14, 0x00, 0x00, + // 1770 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x58, 0x4d, 0x6c, 0xdc, 0xc6, + 0x15, 0x5e, 0x4a, 0xb2, 0x2d, 0xbd, 0xb5, 0x14, 0x69, 0x1c, 0x3b, 0x9b, 0x95, 0xbc, 0x92, 0xe9, + 0x58, 0xd6, 0x3a, 0xf1, 0x52, 0x56, 0x82, 0x20, 0xb5, 0x8b, 0x14, 0x96, 0x5b, 0x59, 0x42, 0xad, + 0x44, 0xa1, 0x14, 0x47, 0x68, 0x03, 0x10, 0xb3, 0xe4, 0x68, 0x35, 0x10, 0xc9, 0x59, 0x91, 0xc3, + 0x85, 0x84, 0xa2, 0x28, 0xd0, 0x43, 0x2e, 0x6d, 0x81, 0x02, 0x3d, 0xf4, 0x50, 0xf4, 0xd4, 0x73, + 0xd1, 0x5e, 0x7a, 0xec, 0xdf, 0x2d, 0x47, 0x03, 0xbd, 0xf4, 0x50, 0x14, 0x85, 0xdd, 0x73, 0x8f, + 0x3d, 0x07, 0x9c, 0x19, 0xee, 0x92, 0x4b, 0x72, 0x25, 0xeb, 0x22, 0x71, 0xde, 0xbc, 0xf7, 0xcd, + 0xf7, 0x66, 0xde, 0xbc, 0xf7, 0x66, 0xe1, 0xa6, 0x73, 0xea, 0x9c, 0x74, 0x03, 0xc6, 0x99, 0xcd, + 0x5c, 0xc3, 0x76, 0x59, 0xdb, 0x38, 0x8e, 0x48, 0x70, 0xda, 0x12, 0x32, 0x34, 0x97, 0x9e, 0x6e, + 0xc5, 0xd3, 0xf5, 0x37, 0x3b, 0xac, 0xc3, 0x84, 0xc8, 0x88, 0xbf, 0xa4, 0x62, 0x7d, 0xa1, 0xc3, + 0x58, 0xc7, 0x25, 0x06, 0xee, 0x52, 0x03, 0xfb, 0x3e, 0xe3, 0x98, 0x53, 0xe6, 0x87, 0x6a, 0xf6, + 0x9e, 0xcd, 0x42, 0x8f, 0x85, 0x46, 0x1b, 0x87, 0x44, 0xe2, 0x1b, 0xbd, 0x07, 0x6d, 0xc2, 0xf1, + 0x03, 0xa3, 0x8b, 0x3b, 0xd4, 0x17, 0xca, 0x4a, 0xd7, 0xc8, 0x33, 0x6a, 0xbb, 0xcc, 0x3e, 0xb2, + 0x02, 0xcc, 0x89, 0xe5, 0x52, 0x8f, 0x72, 0xcb, 0x66, 0xfe, 0x01, 0xed, 0x28, 0x83, 0x5b, 0x79, + 0x83, 0xf8, 0x8f, 0xd5, 0xc5, 0x34, 0x50, 0x2a, 0xab, 0x79, 0x15, 0x72, 0x1c, 0x51, 0x7e, 0x6a, + 0x71, 0x4a, 0x82, 0x22, 0xd0, 0x82, 0x7d, 0x61, 0x81, 0x43, 0x12, 0xc0, 0xc5, 0xfc, 0xb4, 0x87, + 0xb9, 0x7d, 0x48, 0x12, 0x8f, 0xdf, 0xcd, 0x2b, 0xb8, 0xf4, 0x38, 0xa2, 0x8e, 0xdc, 0x97, 0xec, + 0x62, 0xf3, 0x05, 0x68, 0xa4, 0xa7, 0x26, 0x3f, 0xce, 0x4c, 0x52, 0xdf, 0x21, 0x27, 0x24, 0x30, + 0xd8, 0xc1, 0x81, 0x65, 0x1f, 0x62, 0xea, 0x5b, 0x51, 0xd7, 0xc1, 0x9c, 0x84, 0x79, 0x89, 0xb2, + 0x5f, 0xc9, 0xd8, 0x87, 0x51, 0x1b, 0xdb, 0x36, 0x8b, 0x7c, 0x1e, 0x1a, 0x21, 0x0f, 0x08, 0xf6, + 0xa8, 0x9f, 0xd0, 0x68, 0x96, 0x6b, 0xf6, 0xbf, 0x95, 0xea, 0xed, 0x8c, 0x6a, 0x37, 0xa0, 0x36, + 0xc9, 0xe1, 0xe9, 0x4d, 0x78, 0xeb, 0xb3, 0xf8, 0xac, 0x9f, 0x12, 0xfe, 0xc4, 0x65, 0xed, 0x1d, + 0x4c, 0x03, 0x93, 0x1c, 0x47, 0x24, 0xe4, 0x68, 0x06, 0xc6, 0xa8, 0x53, 0xd3, 0x96, 0xb4, 0x95, + 0x69, 0x73, 0x8c, 0x3a, 0xfa, 0x17, 0x70, 0x5d, 0xa8, 0x0e, 0xf4, 0xc2, 0x2e, 0xf3, 0x43, 0x82, + 0x3e, 0x86, 0xa9, 0xfe, 0x61, 0x0a, 0xfd, 0xea, 0xda, 0x7c, 0x2b, 0x17, 0x94, 0xad, 0xc4, 0x6e, + 0x7d, 0xe2, 0xeb, 0x7f, 0x2f, 0x56, 0xcc, 0x49, 0x5b, 0x8d, 0x75, 0xac, 0x38, 0x3c, 0x76, 0xdd, + 0x61, 0x0e, 0x1b, 0x00, 0x83, 0xe0, 0x53, 0xd8, 0xcb, 0x2d, 0x19, 0xa9, 0xad, 0x38, 0x52, 0x5b, + 0xf2, 0x26, 0xa8, 0x48, 0x6d, 0xed, 0xe0, 0x0e, 0x51, 0xb6, 0x66, 0xca, 0x52, 0xff, 0x9d, 0x06, + 0xb5, 0x0c, 0xf9, 0xc7, 0xae, 0x5b, 0xc6, 0x7f, 0xfc, 0x35, 0xf9, 0xa3, 0xa7, 0x19, 0x92, 0x63, + 0x82, 0xe4, 0xdd, 0x33, 0x49, 0xca, 0xc5, 0x33, 0x2c, 0xff, 0xa5, 0xc1, 0xe2, 0x36, 0xe9, 0x7d, + 0xc2, 0x1c, 0xb2, 0xc7, 0xe2, 0xbf, 0x4f, 0xb0, 0x6b, 0x47, 0xae, 0x98, 0x4c, 0x76, 0xe4, 0x4b, + 0xb8, 0x21, 0xaf, 0x5a, 0x37, 0x60, 0x5d, 0x16, 0x92, 0xc0, 0x52, 0x41, 0xdd, 0xdf, 0x9d, 0x3c, + 0xf3, 0xe7, 0xd8, 0x8d, 0x83, 0x9a, 0x05, 0xdb, 0xa4, 0xb7, 0x2d, 0xb5, 0xcd, 0x37, 0x05, 0xca, + 0x8e, 0x02, 0x51, 0x52, 0xf4, 0x43, 0xb8, 0xde, 0x4b, 0x94, 0x2d, 0x8f, 0xf4, 0x2c, 0x8f, 0xf0, + 0x80, 0xda, 0x61, 0xdf, 0xab, 0x3c, 0x78, 0x86, 0xf0, 0xb6, 0x54, 0x37, 0xaf, 0xf5, 0xd2, 0x4b, + 0x4a, 0xa1, 0xfe, 0x3f, 0x0d, 0x96, 0xca, 0xdd, 0x53, 0x87, 0xd1, 0x81, 0x2b, 0x01, 0x09, 0x23, + 0x97, 0x87, 0xea, 0x28, 0x9e, 0x9e, 0xb5, 0x66, 0x01, 0x4a, 0xac, 0xf0, 0xd8, 0x77, 0x9e, 0x33, + 0x37, 0xf2, 0xc8, 0x0e, 0x09, 0xe2, 0xa3, 0x53, 0xc7, 0x96, 0xa0, 0xd7, 0x31, 0x5c, 0x2b, 0xd0, + 0x42, 0x4b, 0x70, 0xb5, 0x1f, 0x0c, 0x56, 0x3f, 0xfe, 0x21, 0x39, 0xec, 0x2d, 0x07, 0xcd, 0xc2, + 0xb8, 0x47, 0x7a, 0x62, 0x47, 0xc6, 0xcc, 0xf8, 0x13, 0xdd, 0x80, 0xcb, 0x3d, 0x01, 0x52, 0x1b, + 0x5f, 0xd2, 0x56, 0x26, 0x4c, 0x35, 0xd2, 0xef, 0xc1, 0x8a, 0x08, 0xba, 0xef, 0x89, 0x3c, 0xb6, + 0x47, 0x49, 0xf0, 0x2c, 0xce, 0x62, 0x4f, 0x44, 0x5e, 0x89, 0x82, 0xf4, 0xb9, 0xea, 0xbf, 0xd1, + 0xa0, 0x79, 0x0e, 0x65, 0xb5, 0x4b, 0x3e, 0xd4, 0xca, 0x92, 0xa3, 0x8a, 0x03, 0xa3, 0x60, 0xdb, + 0x46, 0x41, 0xab, 0xed, 0xb9, 0x4e, 0x8a, 0x74, 0xf4, 0x26, 0xdc, 0x15, 0xe4, 0xd6, 0xe3, 0xa0, + 0x31, 0x31, 0x27, 0xe5, 0x8e, 0xfc, 0x5a, 0x53, 0x5e, 0x8f, 0xd4, 0x55, 0x7e, 0x1c, 0xc1, 0x5b, + 0x25, 0x85, 0x43, 0xb9, 0xd1, 0x2a, 0x70, 0x63, 0x04, 0xb0, 0xf2, 0x42, 0x06, 0xf7, 0x90, 0x8a, + 0xbe, 0x0f, 0x6f, 0x0b, 0x62, 0xbb, 0x1c, 0x73, 0x72, 0x10, 0xb9, 0x9f, 0xc6, 0xc5, 0x22, 0xb9, + 0x57, 0x8f, 0x60, 0x52, 0x14, 0x8f, 0xe4, 0xcc, 0xab, 0x6b, 0xf5, 0x82, 0xa5, 0x85, 0xc9, 0x96, + 0x93, 0xc4, 0x12, 0x93, 0x43, 0xfd, 0x4f, 0x1a, 0xd4, 0x8b, 0xa0, 0x95, 0x97, 0xfb, 0xf0, 0x86, + 0xc4, 0xee, 0xba, 0xd8, 0x26, 0x1e, 0xf1, 0xb9, 0x5a, 0xa2, 0x59, 0xb0, 0xc4, 0x33, 0xe6, 0x77, + 0xf6, 0x48, 0xe0, 0x09, 0x88, 0x9d, 0xc4, 0x40, 0xad, 0x38, 0xc3, 0x32, 0x52, 0xb4, 0x08, 0xd5, + 0x03, 0xea, 0xba, 0x16, 0xf6, 0xe2, 0xc4, 0x2f, 0x62, 0x72, 0xc2, 0x84, 0x58, 0xf4, 0x58, 0x48, + 0xd0, 0x02, 0x4c, 0xf1, 0x80, 0x76, 0x3a, 0x24, 0x20, 0x8e, 0x88, 0xce, 0x49, 0x73, 0x20, 0xd0, + 0xef, 0xc2, 0x1d, 0x41, 0xfb, 0x59, 0xaa, 0xec, 0x15, 0x1e, 0xea, 0x57, 0x1a, 0x2c, 0x9f, 0xa5, + 0xa9, 0x9c, 0xfd, 0x12, 0xae, 0x15, 0x54, 0x51, 0xe5, 0xf0, 0x9d, 0x22, 0x87, 0x73, 0x90, 0xca, + 0x59, 0xe4, 0xe6, 0x66, 0xf4, 0x05, 0xb5, 0xd1, 0x9f, 0x90, 0x93, 0x7e, 0xc1, 0xda, 0x72, 0x12, + 0x9a, 0x9b, 0x30, 0x5f, 0x38, 0xab, 0xa8, 0x35, 0x61, 0xce, 0x27, 0x27, 0xdc, 0x2a, 0xb8, 0xe0, + 0x33, 0x7e, 0xc6, 0x44, 0xff, 0x83, 0x06, 0x37, 0x77, 0x45, 0xad, 0x14, 0xe7, 0xd0, 0x66, 0xec, + 0xe8, 0x73, 0x59, 0xb2, 0x93, 0x80, 0xc9, 0x27, 0x8a, 0xf1, 0xa1, 0x44, 0xb1, 0x0d, 0x33, 0x83, + 0xa2, 0x6c, 0x51, 0x27, 0xce, 0xa2, 0xe3, 0xf9, 0x14, 0x9d, 0x2a, 0xe2, 0xad, 0xdd, 0xfe, 0xf7, + 0x96, 0x63, 0x4e, 0x87, 0xa9, 0x51, 0x88, 0x6e, 0x02, 0x78, 0x38, 0x38, 0x22, 0x12, 0x6a, 0x5c, + 0x2c, 0x37, 0x25, 0x25, 0x5b, 0x4e, 0xa8, 0x63, 0x68, 0x94, 0x11, 0x56, 0xee, 0x7f, 0x07, 0xae, + 0xa8, 0xb6, 0x43, 0xa5, 0xd6, 0xc5, 0x82, 0xd3, 0x90, 0x18, 0xd2, 0x34, 0x09, 0x73, 0x65, 0xa5, + 0xff, 0x7f, 0x1c, 0xae, 0xa6, 0xe7, 0xd1, 0x2d, 0xb8, 0x2a, 0xaf, 0xef, 0x21, 0xa1, 0x9d, 0x43, + 0xae, 0xf6, 0xb2, 0x2a, 0x64, 0x9b, 0x42, 0x84, 0xe6, 0x61, 0x8a, 0x9c, 0x10, 0xdb, 0xf2, 0x98, + 0x43, 0x44, 0x7c, 0x4e, 0x9b, 0x93, 0xb1, 0x60, 0x9b, 0x39, 0x04, 0x7d, 0x0e, 0xb3, 0x2c, 0x61, + 0xab, 0x5a, 0x22, 0x11, 0xa4, 0xd5, 0xb5, 0x95, 0x52, 0x6a, 0x43, 0xee, 0x6d, 0x56, 0xcc, 0x37, + 0x58, 0x56, 0x14, 0x17, 0x64, 0x79, 0xdf, 0xe2, 0x8b, 0x50, 0x9b, 0x28, 0xad, 0x8b, 0x43, 0x80, + 0x1b, 0xd4, 0x75, 0x37, 0x2b, 0xe6, 0x94, 0xb0, 0x8d, 0x07, 0x68, 0x03, 0xaa, 0x1c, 0x1f, 0x91, + 0xc0, 0x12, 0xa2, 0xda, 0x25, 0x81, 0x74, 0xbb, 0x14, 0x69, 0x2f, 0xd6, 0x15, 0x70, 0x9b, 0x15, + 0x13, 0x78, 0x7f, 0x84, 0x2c, 0x98, 0x4b, 0x45, 0x82, 0x72, 0xf4, 0xb2, 0x40, 0x5b, 0x1d, 0x11, + 0x0c, 0x02, 0x74, 0x10, 0x12, 0x7d, 0x87, 0x67, 0xc3, 0x21, 0x19, 0xfa, 0x3e, 0x5c, 0x15, 0x0d, + 0x5e, 0x82, 0x7d, 0xa5, 0xc8, 0x67, 0xd9, 0x02, 0x2a, 0xd8, 0x9d, 0x78, 0xd0, 0x47, 0xac, 0x76, + 0x07, 0xc3, 0xf5, 0x59, 0x98, 0x91, 0x30, 0x96, 0x47, 0xc2, 0x10, 0x77, 0x88, 0xfe, 0x0b, 0x0d, + 0xae, 0x17, 0xee, 0x3e, 0xaa, 0xc3, 0x64, 0xe8, 0xe3, 0x6e, 0x78, 0xc8, 0xe4, 0xe9, 0x4f, 0x9a, + 0xfd, 0x31, 0xda, 0x1f, 0xc4, 0x9b, 0x0c, 0xfc, 0x8f, 0xb2, 0x7c, 0x54, 0x9f, 0xdc, 0xca, 0x77, + 0xc5, 0x9f, 0x1e, 0x1c, 0x3c, 0x89, 0x05, 0x72, 0x91, 0xe7, 0x0f, 0x86, 0x03, 0xf1, 0xf7, 0x1a, + 0x5c, 0x2b, 0x38, 0x3c, 0xf4, 0x08, 0xc4, 0xfd, 0x93, 0x2d, 0x91, 0x4a, 0x39, 0x0b, 0x25, 0xad, + 0x9c, 0x68, 0x79, 0x4c, 0xd1, 0xf9, 0x89, 0x4f, 0xf4, 0x21, 0x5c, 0x16, 0xc7, 0x9c, 0xb0, 0xad, + 0x95, 0xe5, 0x7f, 0xc5, 0x46, 0x69, 0xc7, 0x97, 0x20, 0x95, 0x83, 0xe5, 0xcd, 0x9c, 0x30, 0xab, + 0x83, 0x24, 0x1c, 0xea, 0x5f, 0x8d, 0xc1, 0xec, 0x70, 0x88, 0xa0, 0x55, 0xb8, 0x24, 0xc3, 0x4a, + 0xf2, 0x2c, 0x5d, 0x6e, 0xb3, 0x62, 0x4a, 0x45, 0xb4, 0x0f, 0x73, 0xa9, 0x94, 0xa8, 0x82, 0x72, + 0xac, 0xb4, 0x92, 0xc8, 0x15, 0x53, 0xe9, 0x35, 0x81, 0x9b, 0x75, 0x87, 0x64, 0xe8, 0x0b, 0x40, + 0xa9, 0x40, 0xb7, 0x42, 0x8e, 0x79, 0x14, 0xaa, 0xab, 0xd8, 0x3c, 0x47, 0xbc, 0xef, 0x0a, 0x03, + 0x73, 0x96, 0x0f, 0x49, 0xd6, 0xa7, 0x33, 0x37, 0x48, 0xff, 0xa3, 0x06, 0x37, 0x8a, 0x6d, 0xe3, + 0x6d, 0xcc, 0x2c, 0xae, 0x72, 0x09, 0x4b, 0xa9, 0xdc, 0x07, 0x14, 0x10, 0x0f, 0x53, 0x9f, 0xfa, + 0x1d, 0xeb, 0x38, 0xc2, 0x3e, 0x8f, 0xbc, 0x50, 0x15, 0xbd, 0xb9, 0xfe, 0xcc, 0x67, 0x6a, 0x02, + 0x7d, 0x17, 0x1a, 0xac, 0xcb, 0xa9, 0x47, 0x43, 0x4e, 0x6d, 0xec, 0xba, 0xa7, 0x22, 0x1f, 0x10, + 0x67, 0x60, 0x2a, 0xdb, 0xb5, 0x85, 0xac, 0xd6, 0x86, 0x50, 0x4a, 0x50, 0xd6, 0xfe, 0x52, 0x85, + 0x4b, 0xa2, 0xa8, 0xa0, 0x9f, 0x69, 0x30, 0x99, 0x94, 0x08, 0x74, 0xaf, 0x60, 0x57, 0x4a, 0x5e, + 0x52, 0xf5, 0x95, 0x32, 0xdd, 0xe1, 0xa7, 0x94, 0xde, 0xfc, 0xe9, 0x3f, 0xfe, 0xfb, 0xab, 0xb1, + 0xdb, 0xe8, 0x96, 0x31, 0xe2, 0xc1, 0x6c, 0xfc, 0x88, 0x3a, 0x3f, 0x46, 0x3f, 0xd7, 0xa0, 0x9a, + 0x7a, 0xcd, 0x94, 0x13, 0xca, 0x3f, 0xab, 0xea, 0xef, 0x9e, 0x45, 0x28, 0xf5, 0x3c, 0xd2, 0xdf, + 0x11, 0x9c, 0x1a, 0x68, 0x61, 0x14, 0x27, 0xf4, 0x57, 0x0d, 0x6a, 0x65, 0x6d, 0x39, 0x5a, 0x7b, + 0xad, 0x1e, 0x5e, 0x72, 0x7c, 0xff, 0x02, 0x7d, 0xbf, 0xfe, 0x50, 0x70, 0xfd, 0xe0, 0xa1, 0x76, + 0x4f, 0x37, 0x8c, 0xc2, 0x17, 0xbb, 0xe5, 0x33, 0x87, 0x58, 0x9c, 0xc9, 0xff, 0x76, 0x8a, 0xe4, + 0xdf, 0x35, 0x58, 0x18, 0xd5, 0x21, 0xa3, 0x47, 0x65, 0xbb, 0x76, 0x8e, 0xfe, 0xbe, 0xfe, 0xed, + 0x8b, 0x19, 0x2b, 0xbf, 0x96, 0x85, 0x5f, 0x4b, 0xa8, 0x61, 0x8c, 0xfc, 0x95, 0x04, 0xfd, 0x59, + 0x83, 0xf9, 0x11, 0xed, 0x31, 0x7a, 0x58, 0xc6, 0xe2, 0xec, 0xc6, 0xbe, 0xfe, 0xe8, 0x42, 0xb6, + 0xca, 0x81, 0x3b, 0xc2, 0x81, 0x45, 0x74, 0x73, 0xe4, 0x4f, 0x47, 0xe8, 0x6f, 0x1a, 0xbc, 0x5d, + 0xda, 0x62, 0xa2, 0x8f, 0xca, 0x18, 0x9c, 0xd5, 0xbf, 0xd6, 0xbf, 0x75, 0x01, 0x4b, 0xc5, 0xbc, + 0x25, 0x98, 0xaf, 0xa0, 0x65, 0xe3, 0x5c, 0x3f, 0x17, 0x21, 0x1f, 0xa6, 0x33, 0xaf, 0x00, 0xf4, + 0x5e, 0xd9, 0xda, 0x45, 0xef, 0x90, 0xfa, 0xfd, 0x73, 0x6a, 0x2b, 0x76, 0x15, 0xf4, 0x5b, 0x0d, + 0x66, 0xb2, 0xfd, 0x2e, 0x2a, 0xc5, 0x28, 0xec, 0x9a, 0xeb, 0xad, 0xf3, 0xaa, 0xab, 0x35, 0xdf, + 0x13, 0x3b, 0xb2, 0x8c, 0xde, 0x29, 0xd8, 0x91, 0x5c, 0x7f, 0x8d, 0x7e, 0x92, 0x64, 0xfc, 0xe1, + 0xbe, 0x14, 0xad, 0x9e, 0xb7, 0xc7, 0x4b, 0x7a, 0xee, 0xfa, 0x83, 0xd7, 0xb0, 0x90, 0x64, 0x57, + 0xb5, 0xf5, 0x9d, 0xaf, 0x5f, 0x36, 0xb4, 0x17, 0x2f, 0x1b, 0xda, 0x7f, 0x5e, 0x36, 0xb4, 0x5f, + 0xbe, 0x6a, 0x54, 0x5e, 0xbc, 0x6a, 0x54, 0xfe, 0xf9, 0xaa, 0x51, 0xf9, 0xc1, 0x87, 0x1d, 0xca, + 0x0f, 0xa3, 0x76, 0xcb, 0x66, 0x5e, 0xd6, 0x95, 0xde, 0x07, 0xf7, 0x45, 0x43, 0x62, 0xf4, 0x25, + 0x27, 0xd2, 0x3d, 0x7e, 0xda, 0x25, 0x61, 0xfb, 0xb2, 0x10, 0xbf, 0xff, 0x4d, 0x00, 0x00, 0x00, + 0xff, 0xff, 0x9d, 0x29, 0x28, 0xfb, 0x99, 0x15, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -1492,6 +1580,8 @@ type QueryClient interface { 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) + // Queries the next clob pair id. + NextClobPairId(ctx context.Context, in *QueryNextClobPairIdRequest, opts ...grpc.CallOption) (*QueryNextClobPairIdResponse, 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) @@ -1568,6 +1658,15 @@ func (c *queryClient) StatefulOrder(ctx context.Context, in *QueryStatefulOrderR return out, nil } +func (c *queryClient) NextClobPairId(ctx context.Context, in *QueryNextClobPairIdRequest, opts ...grpc.CallOption) (*QueryNextClobPairIdResponse, error) { + out := new(QueryNextClobPairIdResponse) + err := c.cc.Invoke(ctx, "/dydxprotocol.clob.Query/NextClobPairId", 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 { @@ -1616,6 +1715,8 @@ type QueryServer interface { LiquidationsConfiguration(context.Context, *QueryLiquidationsConfigurationRequest) (*QueryLiquidationsConfigurationResponse, error) // Queries the stateful order for a given order id. StatefulOrder(context.Context, *QueryStatefulOrderRequest) (*QueryStatefulOrderResponse, error) + // Queries the next clob pair id. + NextClobPairId(context.Context, *QueryNextClobPairIdRequest) (*QueryNextClobPairIdResponse, error) // Streams orderbook updates. Updates contain orderbook data // such as order placements, updates, and fills. StreamOrderbookUpdates(*StreamOrderbookUpdatesRequest, Query_StreamOrderbookUpdatesServer) error @@ -1646,6 +1747,9 @@ func (*UnimplementedQueryServer) LiquidationsConfiguration(ctx context.Context, func (*UnimplementedQueryServer) StatefulOrder(ctx context.Context, req *QueryStatefulOrderRequest) (*QueryStatefulOrderResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method StatefulOrder not implemented") } +func (*UnimplementedQueryServer) NextClobPairId(ctx context.Context, req *QueryNextClobPairIdRequest) (*QueryNextClobPairIdResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method NextClobPairId not implemented") +} func (*UnimplementedQueryServer) StreamOrderbookUpdates(req *StreamOrderbookUpdatesRequest, srv Query_StreamOrderbookUpdatesServer) error { return status.Errorf(codes.Unimplemented, "method StreamOrderbookUpdates not implemented") } @@ -1780,6 +1884,24 @@ func _Query_StatefulOrder_Handler(srv interface{}, ctx context.Context, dec func return interceptor(ctx, in, info, handler) } +func _Query_NextClobPairId_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(QueryNextClobPairIdRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(QueryServer).NextClobPairId(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/dydxprotocol.clob.Query/NextClobPairId", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(QueryServer).NextClobPairId(ctx, req.(*QueryNextClobPairIdRequest)) + } + 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 { @@ -1833,6 +1955,10 @@ var _Query_serviceDesc = grpc.ServiceDesc{ MethodName: "StatefulOrder", Handler: _Query_StatefulOrder_Handler, }, + { + MethodName: "NextClobPairId", + Handler: _Query_NextClobPairId_Handler, + }, }, Streams: []grpc.StreamDesc{ { @@ -2361,6 +2487,57 @@ func (m *QueryLiquidationsConfigurationResponse) MarshalToSizedBuffer(dAtA []byt return len(dAtA) - i, nil } +func (m *QueryNextClobPairIdRequest) 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 *QueryNextClobPairIdRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryNextClobPairIdRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + return len(dAtA) - i, nil +} + +func (m *QueryNextClobPairIdResponse) 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 *QueryNextClobPairIdResponse) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryNextClobPairIdResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.NextClobPairId != 0 { + i = encodeVarintQuery(dAtA, i, uint64(m.NextClobPairId)) + i-- + dAtA[i] = 0x8 + } + return len(dAtA) - i, nil +} + func (m *StreamOrderbookUpdatesRequest) Marshal() (dAtA []byte, err error) { size := m.Size() dAtA = make([]byte, size) @@ -3060,6 +3237,27 @@ func (m *QueryLiquidationsConfigurationResponse) Size() (n int) { return n } +func (m *QueryNextClobPairIdRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n +} + +func (m *QueryNextClobPairIdResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.NextClobPairId != 0 { + n += 1 + sovQuery(uint64(m.NextClobPairId)) + } + return n +} + func (m *StreamOrderbookUpdatesRequest) Size() (n int) { if m == nil { return 0 @@ -4557,6 +4755,125 @@ func (m *QueryLiquidationsConfigurationResponse) Unmarshal(dAtA []byte) error { } return nil } +func (m *QueryNextClobPairIdRequest) 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: QueryNextClobPairIdRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: QueryNextClobPairIdRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + default: + iNdEx = preIndex + skippy, err := skipQuery(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthQuery + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *QueryNextClobPairIdResponse) 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: QueryNextClobPairIdResponse: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: QueryNextClobPairIdResponse: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field NextClobPairId", wireType) + } + m.NextClobPairId = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.NextClobPairId |= uint32(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipQuery(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthQuery + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func (m *StreamOrderbookUpdatesRequest) Unmarshal(dAtA []byte) error { l := len(dAtA) iNdEx := 0 diff --git a/protocol/x/clob/types/query.pb.gw.go b/protocol/x/clob/types/query.pb.gw.go index b11d7c9bc3..a7f5cf7e95 100644 --- a/protocol/x/clob/types/query.pb.gw.go +++ b/protocol/x/clob/types/query.pb.gw.go @@ -211,6 +211,24 @@ func local_request_Query_LiquidationsConfiguration_0(ctx context.Context, marsha } +func request_Query_NextClobPairId_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq QueryNextClobPairIdRequest + var metadata runtime.ServerMetadata + + msg, err := client.NextClobPairId(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_Query_NextClobPairId_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq QueryNextClobPairIdRequest + var metadata runtime.ServerMetadata + + msg, err := server.NextClobPairId(ctx, &protoReq) + return msg, metadata, err + +} + // RegisterQueryHandlerServer registers the http handlers for service Query to "mux". // UnaryRPC :call QueryServer directly. // StreamingRPC :currently unsupported pending https://github.com/grpc/grpc-go/issues/906. @@ -355,6 +373,29 @@ func RegisterQueryHandlerServer(ctx context.Context, mux *runtime.ServeMux, serv }) + mux.Handle("GET", pattern_Query_NextClobPairId_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + var stream runtime.ServerTransportStream + ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_Query_NextClobPairId_0(rctx, inboundMarshaler, server, req, pathParams) + md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_Query_NextClobPairId_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + return nil } @@ -516,6 +557,26 @@ func RegisterQueryHandlerClient(ctx context.Context, mux *runtime.ServeMux, clie }) + mux.Handle("GET", pattern_Query_NextClobPairId_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_Query_NextClobPairId_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_Query_NextClobPairId_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + return nil } @@ -531,6 +592,8 @@ var ( pattern_Query_BlockRateLimitConfiguration_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"dydxprotocol", "clob", "block_rate"}, "", runtime.AssumeColonVerbOpt(false))) pattern_Query_LiquidationsConfiguration_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"dydxprotocol", "clob", "liquidations_config"}, "", runtime.AssumeColonVerbOpt(false))) + + pattern_Query_NextClobPairId_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"dydxprotocol", "clob", "next_clob_pair_id"}, "", runtime.AssumeColonVerbOpt(false))) ) var ( @@ -545,4 +608,6 @@ var ( forward_Query_BlockRateLimitConfiguration_0 = runtime.ForwardResponseMessage forward_Query_LiquidationsConfiguration_0 = runtime.ForwardResponseMessage + + forward_Query_NextClobPairId_0 = runtime.ForwardResponseMessage ) diff --git a/protocol/x/perpetuals/keeper/grpc_query_perpetual.go b/protocol/x/perpetuals/keeper/grpc_query_perpetual.go index 124660d6ff..87e381f4b6 100644 --- a/protocol/x/perpetuals/keeper/grpc_query_perpetual.go +++ b/protocol/x/perpetuals/keeper/grpc_query_perpetual.go @@ -71,3 +71,17 @@ func (k Keeper) Perpetual(c context.Context, req *types.QueryPerpetualRequest) ( return &types.QueryPerpetualResponse{Perpetual: val}, nil } + +func (k Keeper) NextPerpetualId( + c context.Context, + req *types.QueryNextPerpetualIdRequest, +) ( + *types.QueryNextPerpetualIdResponse, + error, +) { + ctx := lib.UnwrapSDKContext(c, types.ModuleName) + + return &types.QueryNextPerpetualIdResponse{ + NextPerpetualId: k.GetNextPerpetualID(ctx), + }, nil +} diff --git a/protocol/x/perpetuals/types/query.pb.go b/protocol/x/perpetuals/types/query.pb.go index b2e55e80e7..831f4f58c1 100644 --- a/protocol/x/perpetuals/types/query.pb.go +++ b/protocol/x/perpetuals/types/query.pb.go @@ -566,6 +566,88 @@ func (m *QueryParamsResponse) GetParams() Params { return Params{} } +// QueryNextPerpetualIdRequest is the request type for the NextPerpetualId RPC +type QueryNextPerpetualIdRequest struct { +} + +func (m *QueryNextPerpetualIdRequest) Reset() { *m = QueryNextPerpetualIdRequest{} } +func (m *QueryNextPerpetualIdRequest) String() string { return proto.CompactTextString(m) } +func (*QueryNextPerpetualIdRequest) ProtoMessage() {} +func (*QueryNextPerpetualIdRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_13b6d29860ccef6b, []int{12} +} +func (m *QueryNextPerpetualIdRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *QueryNextPerpetualIdRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_QueryNextPerpetualIdRequest.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 *QueryNextPerpetualIdRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_QueryNextPerpetualIdRequest.Merge(m, src) +} +func (m *QueryNextPerpetualIdRequest) XXX_Size() int { + return m.Size() +} +func (m *QueryNextPerpetualIdRequest) XXX_DiscardUnknown() { + xxx_messageInfo_QueryNextPerpetualIdRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_QueryNextPerpetualIdRequest proto.InternalMessageInfo + +// QueryNextPerpetualIdResponse is the response type for the NextPerpetualId RPC +type QueryNextPerpetualIdResponse struct { + NextPerpetualId uint32 `protobuf:"varint,1,opt,name=next_perpetual_id,json=nextPerpetualId,proto3" json:"next_perpetual_id,omitempty"` +} + +func (m *QueryNextPerpetualIdResponse) Reset() { *m = QueryNextPerpetualIdResponse{} } +func (m *QueryNextPerpetualIdResponse) String() string { return proto.CompactTextString(m) } +func (*QueryNextPerpetualIdResponse) ProtoMessage() {} +func (*QueryNextPerpetualIdResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_13b6d29860ccef6b, []int{13} +} +func (m *QueryNextPerpetualIdResponse) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *QueryNextPerpetualIdResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_QueryNextPerpetualIdResponse.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 *QueryNextPerpetualIdResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_QueryNextPerpetualIdResponse.Merge(m, src) +} +func (m *QueryNextPerpetualIdResponse) XXX_Size() int { + return m.Size() +} +func (m *QueryNextPerpetualIdResponse) XXX_DiscardUnknown() { + xxx_messageInfo_QueryNextPerpetualIdResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_QueryNextPerpetualIdResponse proto.InternalMessageInfo + +func (m *QueryNextPerpetualIdResponse) GetNextPerpetualId() uint32 { + if m != nil { + return m.NextPerpetualId + } + return 0 +} + func init() { proto.RegisterType((*QueryPerpetualRequest)(nil), "dydxprotocol.perpetuals.QueryPerpetualRequest") proto.RegisterType((*QueryPerpetualResponse)(nil), "dydxprotocol.perpetuals.QueryPerpetualResponse") @@ -579,6 +661,8 @@ func init() { proto.RegisterType((*QueryPremiumSamplesResponse)(nil), "dydxprotocol.perpetuals.QueryPremiumSamplesResponse") proto.RegisterType((*QueryParamsRequest)(nil), "dydxprotocol.perpetuals.QueryParamsRequest") proto.RegisterType((*QueryParamsResponse)(nil), "dydxprotocol.perpetuals.QueryParamsResponse") + proto.RegisterType((*QueryNextPerpetualIdRequest)(nil), "dydxprotocol.perpetuals.QueryNextPerpetualIdRequest") + proto.RegisterType((*QueryNextPerpetualIdResponse)(nil), "dydxprotocol.perpetuals.QueryNextPerpetualIdResponse") } func init() { @@ -586,52 +670,56 @@ func init() { } var fileDescriptor_13b6d29860ccef6b = []byte{ - // 716 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x96, 0xbf, 0x53, 0x13, 0x41, - 0x14, 0xc7, 0xb3, 0x51, 0x71, 0x78, 0x42, 0x18, 0x57, 0x54, 0x3c, 0xf1, 0xd0, 0x13, 0x09, 0xa2, - 0xde, 0x4a, 0x60, 0xb4, 0xd1, 0x42, 0x0a, 0x6c, 0x2c, 0x30, 0x22, 0x85, 0x0d, 0x5e, 0x92, 0x9d, - 0x63, 0x67, 0xee, 0xb2, 0xc7, 0xdd, 0x86, 0x21, 0xe3, 0xd8, 0x58, 0x5b, 0x38, 0x63, 0x6d, 0xa7, - 0x25, 0xad, 0xb5, 0x25, 0x25, 0x33, 0x36, 0x56, 0x8e, 0x03, 0xd6, 0xfe, 0x0d, 0x4e, 0x76, 0xf7, - 0x92, 0x3b, 0xc8, 0x91, 0x84, 0xa1, 0xcb, 0xec, 0xfb, 0xf1, 0xfd, 0xec, 0xf7, 0xf6, 0xbd, 0x09, - 0xdc, 0xae, 0x35, 0x6b, 0xdb, 0x41, 0xc8, 0x05, 0xaf, 0x72, 0x8f, 0x04, 0x34, 0x0c, 0xa8, 0x68, - 0x38, 0x5e, 0x44, 0x36, 0x1b, 0x34, 0x6c, 0xda, 0x32, 0x82, 0xaf, 0x26, 0x93, 0xec, 0x4e, 0x92, - 0x31, 0xee, 0x72, 0x97, 0xcb, 0x00, 0x69, 0xfd, 0x52, 0xe9, 0xc6, 0xa4, 0xcb, 0xb9, 0xeb, 0x51, - 0xe2, 0x04, 0x8c, 0x38, 0xf5, 0x3a, 0x17, 0x8e, 0x60, 0xbc, 0x1e, 0xe9, 0xe8, 0x5c, 0x95, 0x47, - 0x3e, 0x8f, 0x48, 0xc5, 0x89, 0xa8, 0x52, 0x21, 0x5b, 0xf3, 0x15, 0x2a, 0x9c, 0x79, 0x12, 0x38, - 0x2e, 0xab, 0xcb, 0x64, 0x9d, 0x3b, 0x9d, 0x45, 0x17, 0x38, 0xa1, 0xe3, 0xc7, 0x1d, 0x8b, 0x99, - 0x59, 0xf1, 0x4f, 0x95, 0x68, 0x15, 0xe1, 0xf2, 0xcb, 0x96, 0xe0, 0x4a, 0x7c, 0x5e, 0xa6, 0x9b, - 0x0d, 0x1a, 0x09, 0x5c, 0x80, 0x3c, 0xab, 0x4d, 0xa0, 0x9b, 0x68, 0x76, 0xb4, 0x9c, 0x67, 0x35, - 0xeb, 0x2d, 0x5c, 0x39, 0x9c, 0x18, 0x05, 0xbc, 0x1e, 0x51, 0xbc, 0x0c, 0xc3, 0xed, 0xae, 0xb2, - 0xe0, 0x42, 0xc9, 0xb2, 0x33, 0xec, 0xb1, 0xdb, 0xe5, 0x4b, 0x67, 0x77, 0x7f, 0x4f, 0xe5, 0xca, - 0x9d, 0x52, 0xab, 0x0a, 0xd7, 0xa4, 0xc2, 0x33, 0xcf, 0x6b, 0x67, 0x45, 0x31, 0xce, 0x32, 0x40, - 0xc7, 0x0a, 0xad, 0x32, 0x63, 0x2b, 0xdf, 0xec, 0x96, 0x6f, 0xb6, 0xfa, 0x3a, 0xda, 0x37, 0x7b, - 0xc5, 0x71, 0xa9, 0xae, 0x2d, 0x27, 0x2a, 0xad, 0x1d, 0x04, 0x46, 0x37, 0x95, 0xee, 0x77, 0x39, - 0x73, 0xc2, 0xbb, 0xe0, 0xe7, 0x29, 0xdc, 0xbc, 0xc4, 0x2d, 0xf6, 0xc4, 0x55, 0x10, 0x29, 0x5e, - 0x17, 0x6e, 0xc4, 0xb8, 0x2f, 0xd8, 0x66, 0x83, 0xd5, 0x98, 0x68, 0xae, 0x32, 0x1a, 0x9e, 0xba, - 0x31, 0x3f, 0x10, 0x98, 0x59, 0x4a, 0xda, 0x9c, 0xd7, 0x30, 0xe6, 0xc5, 0x91, 0x75, 0xd1, 0x0a, - 0x69, 0x8b, 0x66, 0x32, 0x2d, 0x4a, 0x75, 0xd2, 0x36, 0x15, 0xbc, 0x54, 0xfb, 0xd3, 0xf3, 0xca, - 0x80, 0x09, 0xf5, 0x44, 0x43, 0xea, 0xb3, 0x86, 0xbf, 0xc6, 0x05, 0x8d, 0x6d, 0xb2, 0x7c, 0xfd, - 0xb8, 0xd2, 0x31, 0x7d, 0xb1, 0x15, 0x18, 0x0d, 0xd4, 0xf9, 0xfa, 0x56, 0x2b, 0xa0, 0x6d, 0xbc, - 0x93, 0xfd, 0xe5, 0x55, 0xf6, 0x2b, 0xc1, 0x43, 0xaa, 0x6f, 0x35, 0x12, 0x24, 0x3a, 0x5b, 0x93, - 0xfa, 0x95, 0xc5, 0x89, 0x8e, 0x1f, 0x78, 0x1d, 0x98, 0x08, 0xae, 0x77, 0x8d, 0x6a, 0x9c, 0x55, - 0x18, 0x8b, 0x71, 0x22, 0x15, 0x3a, 0x09, 0x50, 0x21, 0x48, 0x75, 0xb7, 0xc6, 0x01, 0x2b, 0x51, - 0xb9, 0x27, 0x62, 0x94, 0x55, 0xb8, 0x94, 0x3a, 0xd5, 0x08, 0x4f, 0x61, 0x48, 0xed, 0x13, 0xad, - 0x3c, 0x95, 0xad, 0x2c, 0xd3, 0xb4, 0xa6, 0x2e, 0x2a, 0xfd, 0x3b, 0x0f, 0xe7, 0x64, 0x5b, 0xfc, - 0x05, 0xc1, 0x70, 0x7b, 0x4e, 0xb0, 0x9d, 0xd9, 0xa6, 0xeb, 0x12, 0x32, 0x48, 0xdf, 0xf9, 0x8a, - 0xdb, 0x22, 0x1f, 0x7e, 0xfe, 0xfd, 0x9c, 0xbf, 0x8b, 0x8b, 0xa4, 0xe7, 0x02, 0x24, 0xef, 0x58, - 0xed, 0x3d, 0xfe, 0x8a, 0x60, 0x34, 0xb5, 0x0a, 0x70, 0xe9, 0x78, 0xcd, 0x6e, 0xdb, 0xc9, 0x58, - 0x18, 0xa8, 0x46, 0xb3, 0xce, 0x49, 0xd6, 0x69, 0x6c, 0xf5, 0x66, 0xc5, 0xdf, 0x11, 0x5c, 0x3c, - 0x32, 0x98, 0xf8, 0x51, 0x4f, 0xd9, 0xae, 0x3b, 0xc3, 0x78, 0x3c, 0x70, 0x9d, 0x46, 0x7e, 0x28, - 0x91, 0xe7, 0xf0, 0x6c, 0x26, 0xf2, 0xa1, 0x05, 0x81, 0xbf, 0x21, 0x18, 0x49, 0xce, 0x1c, 0x9e, - 0xef, 0xf1, 0x49, 0x8f, 0xce, 0xae, 0x51, 0x1a, 0xa4, 0x44, 0x93, 0xda, 0x92, 0x74, 0x16, 0xcf, - 0x64, 0x9b, 0x9b, 0x9c, 0x78, 0xbc, 0x83, 0xa0, 0x90, 0x1e, 0x47, 0xbc, 0xd0, 0x97, 0x6c, 0x7a, - 0xb4, 0x8d, 0xc5, 0xc1, 0x8a, 0xfa, 0xf6, 0xf5, 0xd0, 0x42, 0xc0, 0x1f, 0x11, 0x0c, 0xa9, 0xd1, - 0xc3, 0xf7, 0x7a, 0x48, 0x26, 0xe7, 0xdd, 0xb8, 0xdf, 0x5f, 0xb2, 0xe6, 0x2a, 0x4a, 0xae, 0x5b, - 0x78, 0x8a, 0x1c, 0xff, 0xaf, 0x63, 0x69, 0x6d, 0x77, 0xdf, 0x44, 0x7b, 0xfb, 0x26, 0xfa, 0xb3, - 0x6f, 0xa2, 0x4f, 0x07, 0x66, 0x6e, 0xef, 0xc0, 0xcc, 0xfd, 0x3a, 0x30, 0x73, 0x6f, 0x9e, 0xb8, - 0x4c, 0x6c, 0x34, 0x2a, 0x76, 0x95, 0xfb, 0xe9, 0x26, 0x5b, 0x8b, 0x0f, 0xaa, 0x1b, 0x0e, 0xab, - 0x93, 0xf6, 0xc9, 0x76, 0xb2, 0xb1, 0x68, 0x06, 0x34, 0xaa, 0x0c, 0xc9, 0xe0, 0xc2, 0xff, 0x00, - 0x00, 0x00, 0xff, 0xff, 0xd7, 0x45, 0x0d, 0x89, 0x94, 0x09, 0x00, 0x00, + // 780 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x96, 0xbf, 0x6f, 0xd3, 0x4c, + 0x1c, 0xc6, 0xe3, 0xbc, 0x2f, 0x95, 0xfa, 0xa5, 0x4d, 0xd4, 0xa3, 0x40, 0x31, 0x6d, 0x0a, 0xa6, + 0x34, 0x25, 0x14, 0x1f, 0x4d, 0x0b, 0x2c, 0x30, 0xd0, 0xa1, 0x08, 0x84, 0x50, 0x09, 0xa5, 0x03, + 0x4b, 0x70, 0x92, 0x93, 0x6b, 0xc9, 0xf1, 0xb9, 0xf1, 0xa5, 0x4a, 0x84, 0x58, 0x98, 0x19, 0x90, + 0x98, 0x99, 0x80, 0xb1, 0x0b, 0x03, 0x33, 0x63, 0xc7, 0x4a, 0x2c, 0x4c, 0x08, 0xb5, 0xfc, 0x21, + 0x28, 0x77, 0x67, 0x27, 0x4e, 0xed, 0x3a, 0xa9, 0xba, 0x45, 0xfe, 0xfe, 0x78, 0x3e, 0xf7, 0xd8, + 0xf7, 0x28, 0x70, 0xad, 0xd6, 0xae, 0xb5, 0xdc, 0x06, 0x65, 0xb4, 0x4a, 0x6d, 0xec, 0x92, 0x86, + 0x4b, 0x58, 0xd3, 0xb0, 0x3d, 0xbc, 0xdd, 0x24, 0x8d, 0xb6, 0xce, 0x2b, 0xe8, 0x62, 0x6f, 0x93, + 0xde, 0x6d, 0x52, 0x27, 0x4d, 0x6a, 0x52, 0x5e, 0xc0, 0x9d, 0x5f, 0xa2, 0x5d, 0x9d, 0x36, 0x29, + 0x35, 0x6d, 0x82, 0x0d, 0xd7, 0xc2, 0x86, 0xe3, 0x50, 0x66, 0x30, 0x8b, 0x3a, 0x9e, 0xac, 0x16, + 0xaa, 0xd4, 0xab, 0x53, 0x0f, 0x57, 0x0c, 0x8f, 0x08, 0x15, 0xbc, 0xb3, 0x54, 0x21, 0xcc, 0x58, + 0xc2, 0xae, 0x61, 0x5a, 0x0e, 0x6f, 0x96, 0xbd, 0x73, 0x71, 0x74, 0xae, 0xd1, 0x30, 0xea, 0xfe, + 0xc6, 0x7c, 0x6c, 0x97, 0xff, 0x53, 0x34, 0x6a, 0x79, 0x38, 0xff, 0xbc, 0x23, 0xb8, 0xee, 0x3f, + 0x2f, 0x91, 0xed, 0x26, 0xf1, 0x18, 0xca, 0x40, 0xda, 0xaa, 0x4d, 0x29, 0x57, 0x94, 0x85, 0xf1, + 0x52, 0xda, 0xaa, 0x69, 0xaf, 0xe1, 0x42, 0x7f, 0xa3, 0xe7, 0x52, 0xc7, 0x23, 0x68, 0x0d, 0x46, + 0x83, 0xad, 0x7c, 0xe0, 0x6c, 0x51, 0xd3, 0x63, 0xec, 0xd1, 0x83, 0xf1, 0xd5, 0xff, 0xf7, 0x7e, + 0xcf, 0xa6, 0x4a, 0xdd, 0x51, 0xad, 0x0a, 0x97, 0xb8, 0xc2, 0x43, 0xdb, 0x0e, 0xba, 0x3c, 0x1f, + 0x67, 0x0d, 0xa0, 0x6b, 0x85, 0x54, 0x99, 0xd7, 0x85, 0x6f, 0x7a, 0xc7, 0x37, 0x5d, 0xbc, 0x1d, + 0xe9, 0x9b, 0xbe, 0x6e, 0x98, 0x44, 0xce, 0x96, 0x7a, 0x26, 0xb5, 0x5d, 0x05, 0xd4, 0x28, 0x95, + 0xe8, 0xb3, 0xfc, 0x77, 0xc2, 0xb3, 0xa0, 0x47, 0x21, 0xdc, 0x34, 0xc7, 0xcd, 0x27, 0xe2, 0x0a, + 0x88, 0x10, 0xaf, 0x09, 0x33, 0x3e, 0xee, 0x53, 0x6b, 0xbb, 0x69, 0xd5, 0x2c, 0xd6, 0xde, 0xb0, + 0x48, 0xe3, 0xd4, 0x8d, 0xf9, 0xa1, 0x40, 0x2e, 0x4e, 0x49, 0x9a, 0xf3, 0x12, 0xb2, 0xb6, 0x5f, + 0x29, 0xb3, 0x4e, 0x49, 0x5a, 0x34, 0x1f, 0x6b, 0x51, 0x68, 0x93, 0xb4, 0x29, 0x63, 0x87, 0xd6, + 0x9f, 0x9e, 0x57, 0x2a, 0x4c, 0x89, 0x4f, 0xb4, 0x41, 0xea, 0x56, 0xb3, 0xbe, 0x49, 0x19, 0xf1, + 0x6d, 0xd2, 0xea, 0xf2, 0xe3, 0x0a, 0xd7, 0xe4, 0xc1, 0xd6, 0x61, 0xdc, 0x15, 0xcf, 0xcb, 0x3b, + 0x9d, 0x82, 0xb4, 0xf1, 0x7a, 0xfc, 0x9b, 0x17, 0xdd, 0x2f, 0x18, 0x6d, 0x10, 0x79, 0xaa, 0x31, + 0xb7, 0x67, 0xb3, 0x36, 0x2d, 0xbf, 0x32, 0xbf, 0xd1, 0xa8, 0xbb, 0x76, 0x17, 0xc6, 0x83, 0xcb, + 0x91, 0x55, 0x89, 0xb3, 0x01, 0x59, 0x1f, 0xc7, 0x13, 0xa5, 0x93, 0x00, 0x65, 0xdc, 0xd0, 0x76, + 0x6d, 0x12, 0x90, 0x10, 0xe5, 0x39, 0xe1, 0xa3, 0x6c, 0xc0, 0xb9, 0xd0, 0x53, 0x89, 0xf0, 0x00, + 0x46, 0x44, 0x9e, 0x48, 0xe5, 0xd9, 0x78, 0x65, 0xde, 0x26, 0x35, 0xe5, 0x90, 0x36, 0x23, 0x0f, + 0xf8, 0x8c, 0xb4, 0x58, 0x70, 0x4b, 0x1e, 0xd7, 0x7c, 0xd1, 0x27, 0x30, 0x1d, 0x5d, 0x96, 0xea, + 0x05, 0x98, 0x70, 0x48, 0x8b, 0x95, 0x03, 0x99, 0x72, 0x10, 0x45, 0x59, 0x27, 0x3c, 0x53, 0xfc, + 0x3c, 0x0a, 0x67, 0xf8, 0x32, 0xf4, 0x49, 0x81, 0xd1, 0xa0, 0x82, 0xf4, 0x58, 0xe2, 0xc8, 0xbc, + 0x53, 0xf1, 0xc0, 0xfd, 0x02, 0x52, 0xc3, 0xef, 0x7e, 0xfe, 0xfd, 0x98, 0xbe, 0x81, 0xf2, 0x38, + 0x31, 0x6b, 0xf1, 0x1b, 0xab, 0xf6, 0x16, 0x7d, 0x51, 0x60, 0x3c, 0x94, 0x3a, 0xa8, 0x78, 0xbc, + 0x66, 0x54, 0x10, 0xaa, 0xcb, 0x43, 0xcd, 0x48, 0xd6, 0x02, 0x67, 0x9d, 0x43, 0x5a, 0x32, 0x2b, + 0xfa, 0xae, 0xc0, 0xc4, 0x91, 0x0c, 0x40, 0x77, 0x13, 0x65, 0x23, 0xe3, 0x49, 0xbd, 0x37, 0xf4, + 0x9c, 0x44, 0xbe, 0xcd, 0x91, 0x0b, 0x68, 0x21, 0x16, 0xb9, 0x2f, 0x8b, 0xd0, 0x57, 0x05, 0xc6, + 0x7a, 0xaf, 0x37, 0x5a, 0x4a, 0x78, 0xa5, 0x47, 0x63, 0x42, 0x2d, 0x0e, 0x33, 0x22, 0x49, 0x75, + 0x4e, 0xba, 0x80, 0xe6, 0xe3, 0xcd, 0xed, 0x0d, 0x17, 0xb4, 0xab, 0x40, 0x26, 0x7c, 0xf3, 0xd1, + 0xf2, 0x40, 0xb2, 0xe1, 0x14, 0x51, 0x57, 0x86, 0x1b, 0x1a, 0xd8, 0xd7, 0xbe, 0xec, 0x41, 0xef, + 0x15, 0x18, 0x11, 0xb7, 0x1c, 0xdd, 0x4c, 0x90, 0xec, 0x8d, 0x16, 0x75, 0x71, 0xb0, 0x66, 0xc9, + 0x95, 0xe7, 0x5c, 0x57, 0xd1, 0x2c, 0x3e, 0xfe, 0x0f, 0x0e, 0xfa, 0xa6, 0x40, 0xb6, 0x2f, 0x38, + 0x50, 0x82, 0x15, 0xd1, 0x31, 0xa4, 0xde, 0x19, 0x72, 0x4a, 0x92, 0x16, 0x39, 0xe9, 0x22, 0x2a, + 0xc4, 0x92, 0x1e, 0x09, 0xaf, 0xd5, 0xcd, 0xbd, 0x83, 0x9c, 0xb2, 0x7f, 0x90, 0x53, 0xfe, 0x1c, + 0xe4, 0x94, 0x0f, 0x87, 0xb9, 0xd4, 0xfe, 0x61, 0x2e, 0xf5, 0xeb, 0x30, 0x97, 0x7a, 0x75, 0xdf, + 0xb4, 0xd8, 0x56, 0xb3, 0xa2, 0x57, 0x69, 0x3d, 0xbc, 0x6f, 0x67, 0xe5, 0x56, 0x75, 0xcb, 0xb0, + 0x1c, 0x1c, 0x3c, 0x69, 0xf5, 0x6a, 0xb0, 0xb6, 0x4b, 0xbc, 0xca, 0x08, 0x2f, 0x2e, 0xff, 0x0b, + 0x00, 0x00, 0xff, 0xff, 0x50, 0x66, 0xce, 0xd7, 0xb4, 0x0a, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -658,6 +746,8 @@ type QueryClient interface { PremiumSamples(ctx context.Context, in *QueryPremiumSamplesRequest, opts ...grpc.CallOption) (*QueryPremiumSamplesResponse, error) // Queries the perpetual params. Params(ctx context.Context, in *QueryParamsRequest, opts ...grpc.CallOption) (*QueryParamsResponse, error) + // Queries the next perpetual id. + NextPerpetualId(ctx context.Context, in *QueryNextPerpetualIdRequest, opts ...grpc.CallOption) (*QueryNextPerpetualIdResponse, error) } type queryClient struct { @@ -722,6 +812,15 @@ func (c *queryClient) Params(ctx context.Context, in *QueryParamsRequest, opts . return out, nil } +func (c *queryClient) NextPerpetualId(ctx context.Context, in *QueryNextPerpetualIdRequest, opts ...grpc.CallOption) (*QueryNextPerpetualIdResponse, error) { + out := new(QueryNextPerpetualIdResponse) + err := c.cc.Invoke(ctx, "/dydxprotocol.perpetuals.Query/NextPerpetualId", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + // QueryServer is the server API for Query service. type QueryServer interface { // Queries a Perpetual by id. @@ -736,6 +835,8 @@ type QueryServer interface { PremiumSamples(context.Context, *QueryPremiumSamplesRequest) (*QueryPremiumSamplesResponse, error) // Queries the perpetual params. Params(context.Context, *QueryParamsRequest) (*QueryParamsResponse, error) + // Queries the next perpetual id. + NextPerpetualId(context.Context, *QueryNextPerpetualIdRequest) (*QueryNextPerpetualIdResponse, error) } // UnimplementedQueryServer can be embedded to have forward compatible implementations. @@ -760,6 +861,9 @@ func (*UnimplementedQueryServer) PremiumSamples(ctx context.Context, req *QueryP func (*UnimplementedQueryServer) Params(ctx context.Context, req *QueryParamsRequest) (*QueryParamsResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method Params not implemented") } +func (*UnimplementedQueryServer) NextPerpetualId(ctx context.Context, req *QueryNextPerpetualIdRequest) (*QueryNextPerpetualIdResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method NextPerpetualId not implemented") +} func RegisterQueryServer(s grpc1.Server, srv QueryServer) { s.RegisterService(&_Query_serviceDesc, srv) @@ -873,6 +977,24 @@ func _Query_Params_Handler(srv interface{}, ctx context.Context, dec func(interf return interceptor(ctx, in, info, handler) } +func _Query_NextPerpetualId_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(QueryNextPerpetualIdRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(QueryServer).NextPerpetualId(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/dydxprotocol.perpetuals.Query/NextPerpetualId", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(QueryServer).NextPerpetualId(ctx, req.(*QueryNextPerpetualIdRequest)) + } + return interceptor(ctx, in, info, handler) +} + var _Query_serviceDesc = grpc.ServiceDesc{ ServiceName: "dydxprotocol.perpetuals.Query", HandlerType: (*QueryServer)(nil), @@ -901,6 +1023,10 @@ var _Query_serviceDesc = grpc.ServiceDesc{ MethodName: "Params", Handler: _Query_Params_Handler, }, + { + MethodName: "NextPerpetualId", + Handler: _Query_NextPerpetualId_Handler, + }, }, Streams: []grpc.StreamDesc{}, Metadata: "dydxprotocol/perpetuals/query.proto", @@ -1303,6 +1429,57 @@ func (m *QueryParamsResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { return len(dAtA) - i, nil } +func (m *QueryNextPerpetualIdRequest) 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 *QueryNextPerpetualIdRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryNextPerpetualIdRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + return len(dAtA) - i, nil +} + +func (m *QueryNextPerpetualIdResponse) 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 *QueryNextPerpetualIdResponse) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryNextPerpetualIdResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.NextPerpetualId != 0 { + i = encodeVarintQuery(dAtA, i, uint64(m.NextPerpetualId)) + i-- + dAtA[i] = 0x8 + } + return len(dAtA) - i, nil +} + func encodeVarintQuery(dAtA []byte, offset int, v uint64) int { offset -= sovQuery(v) base := offset @@ -1461,6 +1638,27 @@ func (m *QueryParamsResponse) Size() (n int) { return n } +func (m *QueryNextPerpetualIdRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n +} + +func (m *QueryNextPerpetualIdResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.NextPerpetualId != 0 { + n += 1 + sovQuery(uint64(m.NextPerpetualId)) + } + return n +} + func sovQuery(x uint64) (n int) { return (math_bits.Len64(x|1) + 6) / 7 } @@ -2430,6 +2628,125 @@ func (m *QueryParamsResponse) Unmarshal(dAtA []byte) error { } return nil } +func (m *QueryNextPerpetualIdRequest) 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: QueryNextPerpetualIdRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: QueryNextPerpetualIdRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + default: + iNdEx = preIndex + skippy, err := skipQuery(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthQuery + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *QueryNextPerpetualIdResponse) 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: QueryNextPerpetualIdResponse: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: QueryNextPerpetualIdResponse: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field NextPerpetualId", wireType) + } + m.NextPerpetualId = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.NextPerpetualId |= uint32(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipQuery(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthQuery + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func skipQuery(dAtA []byte) (n int, err error) { l := len(dAtA) iNdEx := 0 diff --git a/protocol/x/perpetuals/types/query.pb.gw.go b/protocol/x/perpetuals/types/query.pb.gw.go index 21cbd1bbde..62a41fc9fa 100644 --- a/protocol/x/perpetuals/types/query.pb.gw.go +++ b/protocol/x/perpetuals/types/query.pb.gw.go @@ -213,6 +213,24 @@ func local_request_Query_Params_0(ctx context.Context, marshaler runtime.Marshal } +func request_Query_NextPerpetualId_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq QueryNextPerpetualIdRequest + var metadata runtime.ServerMetadata + + msg, err := client.NextPerpetualId(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_Query_NextPerpetualId_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq QueryNextPerpetualIdRequest + var metadata runtime.ServerMetadata + + msg, err := server.NextPerpetualId(ctx, &protoReq) + return msg, metadata, err + +} + // RegisterQueryHandlerServer registers the http handlers for service Query to "mux". // UnaryRPC :call QueryServer directly. // StreamingRPC :currently unsupported pending https://github.com/grpc/grpc-go/issues/906. @@ -357,6 +375,29 @@ func RegisterQueryHandlerServer(ctx context.Context, mux *runtime.ServeMux, serv }) + mux.Handle("GET", pattern_Query_NextPerpetualId_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + var stream runtime.ServerTransportStream + ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_Query_NextPerpetualId_0(rctx, inboundMarshaler, server, req, pathParams) + md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_Query_NextPerpetualId_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + return nil } @@ -518,6 +559,26 @@ func RegisterQueryHandlerClient(ctx context.Context, mux *runtime.ServeMux, clie }) + mux.Handle("GET", pattern_Query_NextPerpetualId_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_Query_NextPerpetualId_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_Query_NextPerpetualId_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + return nil } @@ -533,6 +594,8 @@ var ( pattern_Query_PremiumSamples_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"dydxprotocol", "perpetuals", "premium_samples"}, "", runtime.AssumeColonVerbOpt(false))) pattern_Query_Params_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"dydxprotocol", "perpetuals", "params"}, "", runtime.AssumeColonVerbOpt(false))) + + pattern_Query_NextPerpetualId_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"dydxprotocol", "perpetuals", "next_perpetual_id"}, "", runtime.AssumeColonVerbOpt(false))) ) var ( @@ -547,4 +610,6 @@ var ( forward_Query_PremiumSamples_0 = runtime.ForwardResponseMessage forward_Query_Params_0 = runtime.ForwardResponseMessage + + forward_Query_NextPerpetualId_0 = runtime.ForwardResponseMessage ) diff --git a/protocol/x/perpetuals/types/types.go b/protocol/x/perpetuals/types/types.go index 7268ec81a9..0e6d28da92 100644 --- a/protocol/x/perpetuals/types/types.go +++ b/protocol/x/perpetuals/types/types.go @@ -118,6 +118,7 @@ type PerpetualsKeeper interface { ctx sdk.Context, perpetual Perpetual, ) error + SetNextPerpetualID(ctx sdk.Context, nextID uint32) } // OpenInterestDelta represents a (perpId, openInterestDelta) tuple. diff --git a/protocol/x/prices/keeper/grpc_query_market.go b/protocol/x/prices/keeper/grpc_query_market.go index 11edcf7b67..fe3c2976f5 100644 --- a/protocol/x/prices/keeper/grpc_query_market.go +++ b/protocol/x/prices/keeper/grpc_query_market.go @@ -121,3 +121,14 @@ func (k Keeper) MarketParam( return &types.QueryMarketParamResponse{MarketParam: val}, nil } + +func (k Keeper) NextMarketId( + c context.Context, + req *types.QueryNextMarketIdRequest, +) ( + *types.QueryNextMarketIdResponse, + error, +) { + ctx := lib.UnwrapSDKContext(c, types.ModuleName) + return &types.QueryNextMarketIdResponse{NextMarketId: k.GetNextMarketID(ctx)}, nil +} diff --git a/protocol/x/prices/types/query.pb.go b/protocol/x/prices/types/query.pb.go index d3579b3997..dabafa6197 100644 --- a/protocol/x/prices/types/query.pb.go +++ b/protocol/x/prices/types/query.pb.go @@ -414,6 +414,89 @@ func (m *QueryAllMarketParamsResponse) GetPagination() *query.PageResponse { return nil } +// QueryNextMarketIdRequest is request type for the Query/Params `NextMarketId` +type QueryNextMarketIdRequest struct { +} + +func (m *QueryNextMarketIdRequest) Reset() { *m = QueryNextMarketIdRequest{} } +func (m *QueryNextMarketIdRequest) String() string { return proto.CompactTextString(m) } +func (*QueryNextMarketIdRequest) ProtoMessage() {} +func (*QueryNextMarketIdRequest) Descriptor() ([]byte, []int) { + return fileDescriptor_c306b315383f34f4, []int{8} +} +func (m *QueryNextMarketIdRequest) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *QueryNextMarketIdRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_QueryNextMarketIdRequest.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 *QueryNextMarketIdRequest) XXX_Merge(src proto.Message) { + xxx_messageInfo_QueryNextMarketIdRequest.Merge(m, src) +} +func (m *QueryNextMarketIdRequest) XXX_Size() int { + return m.Size() +} +func (m *QueryNextMarketIdRequest) XXX_DiscardUnknown() { + xxx_messageInfo_QueryNextMarketIdRequest.DiscardUnknown(m) +} + +var xxx_messageInfo_QueryNextMarketIdRequest proto.InternalMessageInfo + +// QueryNextMarketIdResponse is response type for the Query/Params +// `NextMarketId` +type QueryNextMarketIdResponse struct { + NextMarketId uint32 `protobuf:"varint,1,opt,name=next_market_id,json=nextMarketId,proto3" json:"next_market_id,omitempty"` +} + +func (m *QueryNextMarketIdResponse) Reset() { *m = QueryNextMarketIdResponse{} } +func (m *QueryNextMarketIdResponse) String() string { return proto.CompactTextString(m) } +func (*QueryNextMarketIdResponse) ProtoMessage() {} +func (*QueryNextMarketIdResponse) Descriptor() ([]byte, []int) { + return fileDescriptor_c306b315383f34f4, []int{9} +} +func (m *QueryNextMarketIdResponse) XXX_Unmarshal(b []byte) error { + return m.Unmarshal(b) +} +func (m *QueryNextMarketIdResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { + if deterministic { + return xxx_messageInfo_QueryNextMarketIdResponse.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 *QueryNextMarketIdResponse) XXX_Merge(src proto.Message) { + xxx_messageInfo_QueryNextMarketIdResponse.Merge(m, src) +} +func (m *QueryNextMarketIdResponse) XXX_Size() int { + return m.Size() +} +func (m *QueryNextMarketIdResponse) XXX_DiscardUnknown() { + xxx_messageInfo_QueryNextMarketIdResponse.DiscardUnknown(m) +} + +var xxx_messageInfo_QueryNextMarketIdResponse proto.InternalMessageInfo + +func (m *QueryNextMarketIdResponse) GetNextMarketId() uint32 { + if m != nil { + return m.NextMarketId + } + return 0 +} + func init() { proto.RegisterType((*QueryMarketPriceRequest)(nil), "dydxprotocol.prices.QueryMarketPriceRequest") proto.RegisterType((*QueryMarketPriceResponse)(nil), "dydxprotocol.prices.QueryMarketPriceResponse") @@ -423,47 +506,53 @@ func init() { proto.RegisterType((*QueryMarketParamResponse)(nil), "dydxprotocol.prices.QueryMarketParamResponse") proto.RegisterType((*QueryAllMarketParamsRequest)(nil), "dydxprotocol.prices.QueryAllMarketParamsRequest") proto.RegisterType((*QueryAllMarketParamsResponse)(nil), "dydxprotocol.prices.QueryAllMarketParamsResponse") + proto.RegisterType((*QueryNextMarketIdRequest)(nil), "dydxprotocol.prices.QueryNextMarketIdRequest") + proto.RegisterType((*QueryNextMarketIdResponse)(nil), "dydxprotocol.prices.QueryNextMarketIdResponse") } func init() { proto.RegisterFile("dydxprotocol/prices/query.proto", fileDescriptor_c306b315383f34f4) } var fileDescriptor_c306b315383f34f4 = []byte{ - // 556 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x54, 0xcd, 0x6e, 0x13, 0x31, - 0x10, 0xce, 0x86, 0xc2, 0xc1, 0x49, 0x41, 0x32, 0x48, 0x44, 0x69, 0xd9, 0x46, 0x06, 0xf5, 0x4f, - 0xd4, 0x26, 0x85, 0x03, 0x57, 0x7a, 0x00, 0x21, 0x84, 0x54, 0x72, 0xe4, 0x82, 0x9c, 0x5d, 0x6b, - 0x6b, 0x91, 0x5d, 0x6f, 0xd7, 0x9b, 0xaa, 0x11, 0xe2, 0xc2, 0x13, 0x20, 0xc1, 0x8d, 0x1b, 0xcf, - 0xc0, 0x43, 0xf4, 0x58, 0x89, 0x0b, 0x27, 0x84, 0x12, 0xde, 0x03, 0x64, 0x7b, 0x43, 0xbd, 0xc9, - 0x86, 0xba, 0x12, 0xe2, 0x96, 0xcc, 0x7c, 0xe3, 0xf9, 0xe6, 0xfb, 0x66, 0x16, 0xac, 0x85, 0xa3, - 0xf0, 0x38, 0xcd, 0x44, 0x2e, 0x02, 0x31, 0x20, 0x69, 0xc6, 0x03, 0x26, 0xc9, 0xe1, 0x90, 0x65, - 0x23, 0xac, 0xa3, 0xf0, 0xba, 0x0d, 0xc0, 0x06, 0xd0, 0xbe, 0x11, 0x89, 0x48, 0xe8, 0x20, 0x51, - 0xbf, 0x0c, 0xb4, 0xbd, 0x1a, 0x09, 0x11, 0x0d, 0x18, 0xa1, 0x29, 0x27, 0x34, 0x49, 0x44, 0x4e, - 0x73, 0x2e, 0x12, 0x59, 0x64, 0xb7, 0x03, 0x21, 0x63, 0x21, 0x49, 0x9f, 0x4a, 0x66, 0x3a, 0x90, - 0xa3, 0x6e, 0x9f, 0xe5, 0xb4, 0x4b, 0x52, 0x1a, 0xf1, 0x44, 0x83, 0x0b, 0xec, 0x7a, 0x15, 0xab, - 0x98, 0x66, 0xaf, 0x59, 0xfe, 0x2a, 0xa5, 0x19, 0x8d, 0x5d, 0x70, 0xea, 0x9f, 0xc1, 0xa1, 0x2d, - 0x70, 0xf3, 0x85, 0xea, 0xf8, 0x5c, 0xa7, 0xf6, 0x55, 0xa6, 0xc7, 0x0e, 0x87, 0x4c, 0xe6, 0xf0, - 0x2a, 0xa8, 0xf3, 0xb0, 0xe5, 0x75, 0xbc, 0xcd, 0xe5, 0x5e, 0x9d, 0x87, 0x88, 0x81, 0xd6, 0x3c, - 0x54, 0xa6, 0x22, 0x91, 0x0c, 0x3e, 0x05, 0x4d, 0xfb, 0x71, 0x5d, 0xd5, 0xd8, 0xed, 0xe0, 0x0a, - 0x89, 0xb0, 0x55, 0xbf, 0xb7, 0x74, 0xf2, 0x7d, 0xad, 0xd6, 0x6b, 0xc4, 0x67, 0x21, 0xc4, 0xc0, - 0x8a, 0x6e, 0xf3, 0x68, 0x30, 0xb0, 0x90, 0x72, 0xca, 0xea, 0x31, 0x00, 0x67, 0xa2, 0x14, 0x7d, - 0xd6, 0xb1, 0x51, 0x10, 0x2b, 0x05, 0xb1, 0xf1, 0xa8, 0x50, 0x10, 0xef, 0xd3, 0x68, 0x3a, 0x51, - 0xcf, 0xaa, 0x44, 0x5f, 0x3c, 0xb0, 0x5a, 0xdd, 0xa7, 0x18, 0xe9, 0x19, 0x58, 0xb6, 0x47, 0x92, - 0x2d, 0xaf, 0x73, 0xe9, 0x02, 0x33, 0x35, 0xad, 0x99, 0x24, 0x7c, 0x52, 0x62, 0x5d, 0xd7, 0xac, - 0x37, 0xce, 0x65, 0x6d, 0x98, 0x94, 0x68, 0xcf, 0xf8, 0xa5, 0x1c, 0x77, 0xf4, 0xcb, 0x40, 0xe7, - 0xfd, 0x52, 0x71, 0x17, 0xbf, 0x14, 0x6e, 0xc6, 0x2f, 0x15, 0xaa, 0xf0, 0x4b, 0x85, 0xff, 0x87, - 0x5f, 0x45, 0x9f, 0x79, 0xbf, 0x74, 0xc2, 0xc5, 0x2f, 0x6b, 0xa6, 0xa6, 0x35, 0xd3, 0xbf, 0xf3, - 0x6b, 0xf7, 0xd7, 0x12, 0xb8, 0xac, 0x69, 0xc3, 0x8f, 0x1e, 0x68, 0x58, 0x6b, 0x02, 0xef, 0x56, - 0x12, 0x5b, 0x70, 0x8c, 0xed, 0x1d, 0x47, 0xb4, 0xa1, 0x80, 0x36, 0xdf, 0x7d, 0xfd, 0xf9, 0xa1, - 0x8e, 0x60, 0x87, 0x2c, 0xfe, 0x0e, 0x90, 0x37, 0x3c, 0x7c, 0x0b, 0x3f, 0x79, 0xe0, 0xda, 0xcc, - 0x09, 0xc0, 0x7b, 0x8b, 0x9b, 0x55, 0x5f, 0x65, 0xbb, 0x7b, 0x81, 0x8a, 0x82, 0xe2, 0x6d, 0x4d, - 0xf1, 0x16, 0x5c, 0xf9, 0x0b, 0x45, 0xc5, 0xae, 0x61, 0x79, 0xe5, 0x20, 0x9a, 0x75, 0x11, 0x0e, - 0xa2, 0xd9, 0x47, 0x81, 0x88, 0x66, 0xb4, 0x05, 0x37, 0x2a, 0x19, 0x99, 0xad, 0x2a, 0x69, 0xf7, - 0xb9, 0xa4, 0x9d, 0xd9, 0x1c, 0x27, 0xed, 0xec, 0x0b, 0x71, 0xd3, 0xae, 0xb4, 0xeb, 0x68, 0x5b, - 0x33, 0xbd, 0x03, 0xd1, 0xf9, 0x4c, 0xf7, 0x7a, 0x27, 0x63, 0xdf, 0x3b, 0x1d, 0xfb, 0xde, 0x8f, - 0xb1, 0xef, 0xbd, 0x9f, 0xf8, 0xb5, 0xd3, 0x89, 0x5f, 0xfb, 0x36, 0xf1, 0x6b, 0x2f, 0x1f, 0x46, - 0x3c, 0x3f, 0x18, 0xf6, 0x71, 0x20, 0xe2, 0xf2, 0x3b, 0x47, 0x0f, 0x76, 0x82, 0x03, 0xca, 0x13, - 0xf2, 0x27, 0x72, 0x3c, 0x7d, 0x3b, 0x1f, 0xa5, 0x4c, 0xf6, 0xaf, 0xe8, 0xc4, 0xfd, 0xdf, 0x01, - 0x00, 0x00, 0xff, 0xff, 0xe8, 0x38, 0x1f, 0x8e, 0x24, 0x07, 0x00, 0x00, + // 616 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xbc, 0x54, 0x4d, 0x4f, 0x13, 0x41, + 0x18, 0xee, 0x56, 0xe5, 0x30, 0x2d, 0x98, 0x8c, 0x26, 0xd6, 0x05, 0x97, 0x66, 0x41, 0xbe, 0x94, + 0x1d, 0x8b, 0x1e, 0xbc, 0xc2, 0x41, 0x43, 0x8c, 0x06, 0x7b, 0xf4, 0x42, 0xa6, 0xdd, 0xc9, 0xb2, + 0xb1, 0xdd, 0x59, 0x3a, 0x5b, 0xd2, 0xc6, 0x78, 0xf1, 0x17, 0x98, 0xe8, 0x49, 0x3d, 0xf9, 0x1b, + 0xfc, 0x11, 0x1c, 0x49, 0xbc, 0x78, 0x32, 0xa6, 0xf5, 0x87, 0x98, 0xf9, 0x28, 0xcc, 0xb6, 0x53, + 0x18, 0x12, 0xc3, 0xad, 0x7d, 0xdf, 0x67, 0xe6, 0x7d, 0x3e, 0xe6, 0x5d, 0xb0, 0x18, 0xf6, 0xc3, + 0x5e, 0xda, 0xa1, 0x19, 0x6d, 0xd2, 0x16, 0x4a, 0x3b, 0x71, 0x93, 0x30, 0x74, 0xd8, 0x25, 0x9d, + 0x7e, 0x20, 0xaa, 0xf0, 0x96, 0x0e, 0x08, 0x24, 0xc0, 0xbd, 0x1d, 0xd1, 0x88, 0x8a, 0x22, 0xe2, + 0xbf, 0x24, 0xd4, 0x5d, 0x88, 0x28, 0x8d, 0x5a, 0x04, 0xe1, 0x34, 0x46, 0x38, 0x49, 0x68, 0x86, + 0xb3, 0x98, 0x26, 0x4c, 0x75, 0x37, 0x9a, 0x94, 0xb5, 0x29, 0x43, 0x0d, 0xcc, 0x88, 0x9c, 0x80, + 0x8e, 0x6a, 0x0d, 0x92, 0xe1, 0x1a, 0x4a, 0x71, 0x14, 0x27, 0x02, 0xac, 0xb0, 0x2b, 0x26, 0x56, + 0x6d, 0xdc, 0x79, 0x4b, 0xb2, 0xfd, 0x14, 0x77, 0x70, 0xdb, 0x06, 0xc7, 0xff, 0x49, 0x9c, 0xbf, + 0x0e, 0xee, 0xbc, 0xe6, 0x13, 0x5f, 0x8a, 0xd6, 0x1e, 0xef, 0xd4, 0xc9, 0x61, 0x97, 0xb0, 0x0c, + 0xce, 0x81, 0x62, 0x1c, 0x56, 0x9c, 0xaa, 0xb3, 0x36, 0x5b, 0x2f, 0xc6, 0xa1, 0x4f, 0x40, 0x65, + 0x12, 0xca, 0x52, 0x9a, 0x30, 0x02, 0x77, 0x41, 0x59, 0xbf, 0x5c, 0x9c, 0x2a, 0x6d, 0x55, 0x03, + 0x83, 0x45, 0x81, 0x76, 0x7e, 0xe7, 0xfa, 0xf1, 0xef, 0xc5, 0x42, 0xbd, 0xd4, 0x3e, 0x2b, 0xf9, + 0x04, 0xcc, 0x8b, 0x31, 0xdb, 0xad, 0x96, 0x86, 0x64, 0x23, 0x56, 0xcf, 0x00, 0x38, 0x33, 0x45, + 0xcd, 0x59, 0x09, 0xa4, 0x83, 0x01, 0x77, 0x30, 0x90, 0x19, 0x29, 0x07, 0x83, 0x3d, 0x1c, 0x8d, + 0x14, 0xd5, 0xb5, 0x93, 0xfe, 0x0f, 0x07, 0x2c, 0x98, 0xe7, 0x28, 0x49, 0x2f, 0xc0, 0xac, 0x2e, + 0x89, 0x55, 0x9c, 0xea, 0xb5, 0x4b, 0x68, 0x2a, 0x6b, 0x9a, 0x18, 0x7c, 0x9e, 0x63, 0x5d, 0x14, + 0xac, 0x57, 0x2f, 0x64, 0x2d, 0x99, 0xe4, 0x68, 0x8f, 0xe5, 0xc5, 0x13, 0xb7, 0xcc, 0x4b, 0x42, + 0x27, 0xf3, 0xe2, 0x75, 0x9b, 0xbc, 0x38, 0x6e, 0x2c, 0x2f, 0x5e, 0x32, 0xe4, 0xc5, 0xcb, 0x57, + 0x91, 0x97, 0x9a, 0x33, 0x99, 0x97, 0x68, 0xd8, 0xe4, 0xa5, 0x69, 0x2a, 0x6b, 0x9a, 0xfe, 0x63, + 0x5e, 0xae, 0x0a, 0xe1, 0x15, 0xe9, 0x65, 0x72, 0xe8, 0x6e, 0xa8, 0xe4, 0xf9, 0xdb, 0xe0, 0xae, + 0xa1, 0xa7, 0xe4, 0x2c, 0x83, 0xb9, 0x84, 0xf4, 0xb2, 0x7d, 0xa5, 0xe9, 0x34, 0xd9, 0x72, 0xa2, + 0xa1, 0xb7, 0xbe, 0xcd, 0x80, 0x1b, 0xe2, 0x0e, 0xf8, 0xd9, 0x01, 0x25, 0xed, 0x15, 0xc2, 0x87, + 0x46, 0xdd, 0x53, 0x76, 0xdd, 0xdd, 0xb4, 0x44, 0x4b, 0x72, 0xfe, 0xda, 0x87, 0x9f, 0x7f, 0x3f, + 0x15, 0x7d, 0x58, 0x45, 0xd3, 0x3f, 0x33, 0xe8, 0x5d, 0x1c, 0xbe, 0x87, 0x5f, 0x1d, 0x70, 0x73, + 0x6c, 0xc3, 0xe0, 0xa3, 0xe9, 0xc3, 0xcc, 0x4b, 0xef, 0xd6, 0x2e, 0x71, 0x42, 0x51, 0x5c, 0x12, + 0x14, 0xef, 0xc1, 0xf9, 0x73, 0x28, 0x72, 0x76, 0x25, 0xed, 0x29, 0x58, 0x98, 0xa6, 0x2d, 0x9c, + 0x85, 0x69, 0xfa, 0xce, 0xf9, 0x48, 0x30, 0x5a, 0x87, 0xab, 0x46, 0x46, 0xf2, 0xd1, 0xe6, 0xbc, + 0xfb, 0x9e, 0xf3, 0x4e, 0x3e, 0x4c, 0x2b, 0xef, 0xf4, 0x05, 0xb4, 0xf3, 0x2e, 0xb7, 0x4a, 0xfe, + 0x86, 0x60, 0xba, 0x0c, 0xfd, 0x8b, 0x99, 0xc2, 0x2f, 0x0e, 0x28, 0xeb, 0x0f, 0x18, 0x9e, 0xe3, + 0x8a, 0x61, 0x09, 0xdc, 0xc0, 0x16, 0xae, 0xb8, 0x3d, 0x10, 0xdc, 0xee, 0xc3, 0x25, 0x23, 0xb7, + 0xfc, 0xca, 0xec, 0xd4, 0x8f, 0x07, 0x9e, 0x73, 0x32, 0xf0, 0x9c, 0x3f, 0x03, 0xcf, 0xf9, 0x38, + 0xf4, 0x0a, 0x27, 0x43, 0xaf, 0xf0, 0x6b, 0xe8, 0x15, 0xde, 0x3c, 0x8d, 0xe2, 0xec, 0xa0, 0xdb, + 0x08, 0x9a, 0xb4, 0x9d, 0xbf, 0xe8, 0xe8, 0xc9, 0x66, 0xf3, 0x00, 0xc7, 0x09, 0x3a, 0xad, 0xf4, + 0x46, 0x97, 0x67, 0xfd, 0x94, 0xb0, 0xc6, 0x8c, 0x68, 0x3c, 0xfe, 0x17, 0x00, 0x00, 0xff, 0xff, + 0x50, 0x4b, 0x00, 0xa4, 0x20, 0x08, 0x00, 0x00, } // Reference imports to suppress errors if they are not otherwise used. @@ -486,6 +575,8 @@ type QueryClient interface { MarketParam(ctx context.Context, in *QueryMarketParamRequest, opts ...grpc.CallOption) (*QueryMarketParamResponse, error) // Queries a list of MarketParam items. AllMarketParams(ctx context.Context, in *QueryAllMarketParamsRequest, opts ...grpc.CallOption) (*QueryAllMarketParamsResponse, error) + // Queries the next market id. + NextMarketId(ctx context.Context, in *QueryNextMarketIdRequest, opts ...grpc.CallOption) (*QueryNextMarketIdResponse, error) } type queryClient struct { @@ -532,6 +623,15 @@ func (c *queryClient) AllMarketParams(ctx context.Context, in *QueryAllMarketPar return out, nil } +func (c *queryClient) NextMarketId(ctx context.Context, in *QueryNextMarketIdRequest, opts ...grpc.CallOption) (*QueryNextMarketIdResponse, error) { + out := new(QueryNextMarketIdResponse) + err := c.cc.Invoke(ctx, "/dydxprotocol.prices.Query/NextMarketId", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + // QueryServer is the server API for Query service. type QueryServer interface { // Queries a MarketPrice by id. @@ -542,6 +642,8 @@ type QueryServer interface { MarketParam(context.Context, *QueryMarketParamRequest) (*QueryMarketParamResponse, error) // Queries a list of MarketParam items. AllMarketParams(context.Context, *QueryAllMarketParamsRequest) (*QueryAllMarketParamsResponse, error) + // Queries the next market id. + NextMarketId(context.Context, *QueryNextMarketIdRequest) (*QueryNextMarketIdResponse, error) } // UnimplementedQueryServer can be embedded to have forward compatible implementations. @@ -560,6 +662,9 @@ func (*UnimplementedQueryServer) MarketParam(ctx context.Context, req *QueryMark func (*UnimplementedQueryServer) AllMarketParams(ctx context.Context, req *QueryAllMarketParamsRequest) (*QueryAllMarketParamsResponse, error) { return nil, status.Errorf(codes.Unimplemented, "method AllMarketParams not implemented") } +func (*UnimplementedQueryServer) NextMarketId(ctx context.Context, req *QueryNextMarketIdRequest) (*QueryNextMarketIdResponse, error) { + return nil, status.Errorf(codes.Unimplemented, "method NextMarketId not implemented") +} func RegisterQueryServer(s grpc1.Server, srv QueryServer) { s.RegisterService(&_Query_serviceDesc, srv) @@ -637,6 +742,24 @@ func _Query_AllMarketParams_Handler(srv interface{}, ctx context.Context, dec fu return interceptor(ctx, in, info, handler) } +func _Query_NextMarketId_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(QueryNextMarketIdRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(QueryServer).NextMarketId(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/dydxprotocol.prices.Query/NextMarketId", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(QueryServer).NextMarketId(ctx, req.(*QueryNextMarketIdRequest)) + } + return interceptor(ctx, in, info, handler) +} + var _Query_serviceDesc = grpc.ServiceDesc{ ServiceName: "dydxprotocol.prices.Query", HandlerType: (*QueryServer)(nil), @@ -657,6 +780,10 @@ var _Query_serviceDesc = grpc.ServiceDesc{ MethodName: "AllMarketParams", Handler: _Query_AllMarketParams_Handler, }, + { + MethodName: "NextMarketId", + Handler: _Query_NextMarketId_Handler, + }, }, Streams: []grpc.StreamDesc{}, Metadata: "dydxprotocol/prices/query.proto", @@ -952,6 +1079,57 @@ func (m *QueryAllMarketParamsResponse) MarshalToSizedBuffer(dAtA []byte) (int, e return len(dAtA) - i, nil } +func (m *QueryNextMarketIdRequest) 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 *QueryNextMarketIdRequest) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryNextMarketIdRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + return len(dAtA) - i, nil +} + +func (m *QueryNextMarketIdResponse) 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 *QueryNextMarketIdResponse) MarshalTo(dAtA []byte) (int, error) { + size := m.Size() + return m.MarshalToSizedBuffer(dAtA[:size]) +} + +func (m *QueryNextMarketIdResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) { + i := len(dAtA) + _ = i + var l int + _ = l + if m.NextMarketId != 0 { + i = encodeVarintQuery(dAtA, i, uint64(m.NextMarketId)) + i-- + dAtA[i] = 0x8 + } + return len(dAtA) - i, nil +} + func encodeVarintQuery(dAtA []byte, offset int, v uint64) int { offset -= sovQuery(v) base := offset @@ -1073,6 +1251,27 @@ func (m *QueryAllMarketParamsResponse) Size() (n int) { return n } +func (m *QueryNextMarketIdRequest) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + return n +} + +func (m *QueryNextMarketIdResponse) Size() (n int) { + if m == nil { + return 0 + } + var l int + _ = l + if m.NextMarketId != 0 { + n += 1 + sovQuery(uint64(m.NextMarketId)) + } + return n +} + func sovQuery(x uint64) (n int) { return (math_bits.Len64(x|1) + 6) / 7 } @@ -1795,6 +1994,125 @@ func (m *QueryAllMarketParamsResponse) Unmarshal(dAtA []byte) error { } return nil } +func (m *QueryNextMarketIdRequest) 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: QueryNextMarketIdRequest: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: QueryNextMarketIdRequest: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + default: + iNdEx = preIndex + skippy, err := skipQuery(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthQuery + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} +func (m *QueryNextMarketIdResponse) 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: QueryNextMarketIdResponse: wiretype end group for non-group") + } + if fieldNum <= 0 { + return fmt.Errorf("proto: QueryNextMarketIdResponse: illegal tag %d (wire type %d)", fieldNum, wire) + } + switch fieldNum { + case 1: + if wireType != 0 { + return fmt.Errorf("proto: wrong wireType = %d for field NextMarketId", wireType) + } + m.NextMarketId = 0 + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowQuery + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + m.NextMarketId |= uint32(b&0x7F) << shift + if b < 0x80 { + break + } + } + default: + iNdEx = preIndex + skippy, err := skipQuery(dAtA[iNdEx:]) + if err != nil { + return err + } + if (skippy < 0) || (iNdEx+skippy) < 0 { + return ErrInvalidLengthQuery + } + if (iNdEx + skippy) > l { + return io.ErrUnexpectedEOF + } + iNdEx += skippy + } + } + + if iNdEx > l { + return io.ErrUnexpectedEOF + } + return nil +} func skipQuery(dAtA []byte) (n int, err error) { l := len(dAtA) iNdEx := 0 diff --git a/protocol/x/prices/types/query.pb.gw.go b/protocol/x/prices/types/query.pb.gw.go index 401252770f..2e78d40c06 100644 --- a/protocol/x/prices/types/query.pb.gw.go +++ b/protocol/x/prices/types/query.pb.gw.go @@ -213,6 +213,24 @@ func local_request_Query_AllMarketParams_0(ctx context.Context, marshaler runtim } +func request_Query_NextMarketId_0(ctx context.Context, marshaler runtime.Marshaler, client QueryClient, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq QueryNextMarketIdRequest + var metadata runtime.ServerMetadata + + msg, err := client.NextMarketId(ctx, &protoReq, grpc.Header(&metadata.HeaderMD), grpc.Trailer(&metadata.TrailerMD)) + return msg, metadata, err + +} + +func local_request_Query_NextMarketId_0(ctx context.Context, marshaler runtime.Marshaler, server QueryServer, req *http.Request, pathParams map[string]string) (proto.Message, runtime.ServerMetadata, error) { + var protoReq QueryNextMarketIdRequest + var metadata runtime.ServerMetadata + + msg, err := server.NextMarketId(ctx, &protoReq) + return msg, metadata, err + +} + // RegisterQueryHandlerServer registers the http handlers for service Query to "mux". // UnaryRPC :call QueryServer directly. // StreamingRPC :currently unsupported pending https://github.com/grpc/grpc-go/issues/906. @@ -311,6 +329,29 @@ func RegisterQueryHandlerServer(ctx context.Context, mux *runtime.ServeMux, serv }) + mux.Handle("GET", pattern_Query_NextMarketId_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + var stream runtime.ServerTransportStream + ctx = grpc.NewContextWithServerTransportStream(ctx, &stream) + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateIncomingContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := local_request_Query_NextMarketId_0(rctx, inboundMarshaler, server, req, pathParams) + md.HeaderMD, md.TrailerMD = metadata.Join(md.HeaderMD, stream.Header()), metadata.Join(md.TrailerMD, stream.Trailer()) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_Query_NextMarketId_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + return nil } @@ -432,6 +473,26 @@ func RegisterQueryHandlerClient(ctx context.Context, mux *runtime.ServeMux, clie }) + mux.Handle("GET", pattern_Query_NextMarketId_0, func(w http.ResponseWriter, req *http.Request, pathParams map[string]string) { + ctx, cancel := context.WithCancel(req.Context()) + defer cancel() + inboundMarshaler, outboundMarshaler := runtime.MarshalerForRequest(mux, req) + rctx, err := runtime.AnnotateContext(ctx, mux, req) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + resp, md, err := request_Query_NextMarketId_0(rctx, inboundMarshaler, client, req, pathParams) + ctx = runtime.NewServerMetadataContext(ctx, md) + if err != nil { + runtime.HTTPError(ctx, mux, outboundMarshaler, w, req, err) + return + } + + forward_Query_NextMarketId_0(ctx, mux, outboundMarshaler, w, req, resp, mux.GetForwardResponseOptions()...) + + }) + return nil } @@ -443,6 +504,8 @@ var ( pattern_Query_MarketParam_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3, 1, 0, 4, 1, 5, 4}, []string{"dydxprotocol", "prices", "params", "market", "id"}, "", runtime.AssumeColonVerbOpt(false))) pattern_Query_AllMarketParams_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2, 2, 3}, []string{"dydxprotocol", "prices", "params", "market"}, "", runtime.AssumeColonVerbOpt(false))) + + pattern_Query_NextMarketId_0 = runtime.MustPattern(runtime.NewPattern(1, []int{2, 0, 2, 1, 2, 2}, []string{"dydxprotocol", "prices", "next_market_id"}, "", runtime.AssumeColonVerbOpt(false))) ) var ( @@ -453,4 +516,6 @@ var ( forward_Query_MarketParam_0 = runtime.ForwardResponseMessage forward_Query_AllMarketParams_0 = runtime.ForwardResponseMessage + + forward_Query_NextMarketId_0 = runtime.ForwardResponseMessage ) diff --git a/protocol/x/prices/types/types.go b/protocol/x/prices/types/types.go index 87d9fec885..8f225e7580 100644 --- a/protocol/x/prices/types/types.go +++ b/protocol/x/prices/types/types.go @@ -57,4 +57,6 @@ type PricesKeeper interface { GetCurrencyPairFromID(ctx context.Context, id uint64) (cp slinkytypes.CurrencyPair, found bool) GetIDForCurrencyPair(ctx context.Context, cp slinkytypes.CurrencyPair) (uint64, bool) GetPriceForCurrencyPair(ctx context.Context, cp slinkytypes.CurrencyPair) (oracletypes.QuotePrice, error) + + SetNextMarketID(ctx sdk.Context, nextID uint32) }