@dydxprotocol/v4-client-js 2.5.2 → 2.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +3 -3
- package/__tests__/helpers/constants.ts +31 -0
- package/build/cjs/__tests__/helpers/constants.js +30 -2
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.js +74 -2
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.lcd.js +7 -1
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.rpc.Query.js +10 -1
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.js +63 -2
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.lcd.js +7 -1
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.rpc.Query.js +10 -1
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/clob/order.js +176 -4
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/clob/query.js +11 -3
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/indexer/events/events.js +320 -4
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/indexer/protocol/v1/clob.js +124 -4
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.js +73 -2
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.lcd.js +7 -1
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.rpc.Query.js +10 -1
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/revshare.js +46 -2
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/tx.js +72 -2
- package/build/cjs/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/tx.rpc.msg.js +7 -1
- package/build/cjs/src/clients/modules/composer.js +5 -2
- package/build/cjs/src/clients/modules/post.js +6 -6
- package/build/cjs/src/clients/types.js +1 -1
- package/build/cjs/tsconfig.cjs.tsbuildinfo +1 -1
- package/build/esm/__tests__/helpers/constants.d.ts +3 -0
- package/build/esm/__tests__/helpers/constants.d.ts.map +1 -1
- package/build/esm/__tests__/helpers/constants.js +29 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.d.ts +38 -0
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.js +73 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.lcd.d.ts +2 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.lcd.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.lcd.js +7 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.rpc.Query.d.ts +5 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.rpc.Query.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/accountplus/query.rpc.Query.js +11 -2
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.d.ts +25 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.js +63 -2
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.lcd.d.ts +2 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.lcd.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.lcd.js +7 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.rpc.Query.d.ts +5 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.rpc.Query.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/blocktime/query.rpc.Query.js +11 -2
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/bundle.d.ts +91 -0
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/bundle.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/clob/order.d.ts +110 -8
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/clob/order.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/clob/order.js +175 -3
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/clob/query.d.ts +7 -0
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/clob/query.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/clob/query.js +11 -3
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/indexer/events/events.d.ts +190 -0
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/indexer/events/events.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/indexer/events/events.js +319 -3
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/indexer/protocol/v1/clob.d.ts +78 -8
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/indexer/protocol/v1/clob.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/indexer/protocol/v1/clob.js +123 -3
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/perpetuals/perpetual.d.ts +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.d.ts +27 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.js +73 -2
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.lcd.d.ts +2 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.lcd.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.lcd.js +7 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.rpc.Query.d.ts +5 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.rpc.Query.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/query.rpc.Query.js +11 -2
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/revshare.d.ts +17 -0
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/revshare.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/revshare.js +45 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/tx.d.ts +28 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/tx.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/tx.js +72 -2
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/tx.rpc.msg.d.ts +4 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/tx.rpc.msg.d.ts.map +1 -1
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/revshare/tx.rpc.msg.js +8 -2
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/rpc.query.d.ts +3 -0
- package/build/esm/node_modules/@dydxprotocol/v4-proto/src/codegen/dydxprotocol/rpc.query.d.ts.map +1 -1
- package/build/esm/src/clients/modules/composer.d.ts +2 -2
- package/build/esm/src/clients/modules/composer.d.ts.map +1 -1
- package/build/esm/src/clients/modules/composer.js +5 -2
- package/build/esm/src/clients/modules/post.d.ts +3 -3
- package/build/esm/src/clients/modules/post.d.ts.map +1 -1
- package/build/esm/src/clients/modules/post.js +6 -6
- package/build/esm/src/clients/types.d.ts +12 -0
- package/build/esm/src/clients/types.d.ts.map +1 -1
- package/build/esm/src/clients/types.js +1 -1
- package/build/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/src/clients/modules/composer.ts +7 -1
- package/src/clients/modules/post.ts +17 -0
- package/src/clients/types.ts +16 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dydxprotocol/v4-client-js",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.7.0",
|
|
4
4
|
"description": "General client library for the new dYdX system (v4 decentralized)",
|
|
5
5
|
"main": "build/cjs/src/index.js",
|
|
6
6
|
"module": "build/esm/src/index.js",
|
|
@@ -52,7 +52,7 @@
|
|
|
52
52
|
"@cosmjs/stargate": "^0.32.1",
|
|
53
53
|
"@cosmjs/tendermint-rpc": "^0.32.1",
|
|
54
54
|
"@cosmjs/utils": "^0.32.1",
|
|
55
|
-
"@dydxprotocol/v4-proto": "
|
|
55
|
+
"@dydxprotocol/v4-proto": "9.0.0",
|
|
56
56
|
"@osmonauts/lcd": "^0.6.0",
|
|
57
57
|
"@scure/bip32": "^1.1.5",
|
|
58
58
|
"@scure/bip39": "^1.1.1",
|
|
@@ -57,7 +57,7 @@ import {
|
|
|
57
57
|
TYPE_URL_MSG_REMOVE_AUTHENTICATOR,
|
|
58
58
|
AuthenticatorType,
|
|
59
59
|
} from '../constants';
|
|
60
|
-
import { DenomConfig } from '../types';
|
|
60
|
+
import { DenomConfig, ITwapParameters, IBuilderCodeParameters } from '../types';
|
|
61
61
|
import {
|
|
62
62
|
OrderId,
|
|
63
63
|
Order,
|
|
@@ -95,6 +95,9 @@ export class Composer {
|
|
|
95
95
|
clientMetadata: number,
|
|
96
96
|
conditionType: Order_ConditionType = Order_ConditionType.CONDITION_TYPE_UNSPECIFIED,
|
|
97
97
|
conditionalOrderTriggerSubticks: Long = Long.fromInt(0),
|
|
98
|
+
twapParameters?: ITwapParameters,
|
|
99
|
+
builderCodeParameters?: IBuilderCodeParameters,
|
|
100
|
+
orderRouterAddress: string = "",
|
|
98
101
|
): EncodeObject {
|
|
99
102
|
this.validateGoodTilBlockAndTime(orderFlags, goodTilBlock, goodTilBlockTime);
|
|
100
103
|
|
|
@@ -122,6 +125,9 @@ export class Composer {
|
|
|
122
125
|
clientMetadata: clientMetadata ?? 0,
|
|
123
126
|
conditionType,
|
|
124
127
|
conditionalOrderTriggerSubticks,
|
|
128
|
+
twapParameters,
|
|
129
|
+
builderCodeParameters,
|
|
130
|
+
orderRouterAddress,
|
|
125
131
|
};
|
|
126
132
|
const msg: MsgPlaceOrder = {
|
|
127
133
|
order,
|
|
@@ -21,6 +21,8 @@ import {
|
|
|
21
21
|
IPlaceOrder,
|
|
22
22
|
ICancelOrder,
|
|
23
23
|
DenomConfig,
|
|
24
|
+
ITwapParameters,
|
|
25
|
+
IBuilderCodeParameters,
|
|
24
26
|
} from '../types';
|
|
25
27
|
import { Composer } from './composer';
|
|
26
28
|
import { Get } from './get';
|
|
@@ -411,6 +413,9 @@ export class Post {
|
|
|
411
413
|
clientMetadata: number = 0,
|
|
412
414
|
conditionType: Order_ConditionType = Order_ConditionType.CONDITION_TYPE_UNSPECIFIED,
|
|
413
415
|
conditionalOrderTriggerSubticks: Long = Long.fromInt(0),
|
|
416
|
+
twapParameters?: ITwapParameters,
|
|
417
|
+
builderCodeParameters?: IBuilderCodeParameters,
|
|
418
|
+
orderRouterAddress?: string,
|
|
414
419
|
broadcastMode?: BroadcastMode,
|
|
415
420
|
): Promise<BroadcastTxAsyncResponse | BroadcastTxSyncResponse | IndexedTx> {
|
|
416
421
|
const msg = await this.placeOrderMsg(
|
|
@@ -429,6 +434,9 @@ export class Post {
|
|
|
429
434
|
clientMetadata,
|
|
430
435
|
conditionType,
|
|
431
436
|
conditionalOrderTriggerSubticks,
|
|
437
|
+
twapParameters,
|
|
438
|
+
builderCodeParameters,
|
|
439
|
+
orderRouterAddress,
|
|
432
440
|
);
|
|
433
441
|
const account: Promise<Account> = this.account(subaccount.address, orderFlags);
|
|
434
442
|
return this.send(
|
|
@@ -458,6 +466,9 @@ export class Post {
|
|
|
458
466
|
clientMetadata: number = 0,
|
|
459
467
|
conditionType: Order_ConditionType = Order_ConditionType.CONDITION_TYPE_UNSPECIFIED,
|
|
460
468
|
conditionalOrderTriggerSubticks: Long = Long.fromInt(0),
|
|
469
|
+
twapParameters?: ITwapParameters,
|
|
470
|
+
builderCodeParameters?: IBuilderCodeParameters,
|
|
471
|
+
orderRouterAddress?: string,
|
|
461
472
|
): Promise<EncodeObject> {
|
|
462
473
|
return new Promise((resolve) => {
|
|
463
474
|
const msg = this.composer.composeMsgPlaceOrder(
|
|
@@ -476,6 +487,9 @@ export class Post {
|
|
|
476
487
|
clientMetadata,
|
|
477
488
|
conditionType,
|
|
478
489
|
conditionalOrderTriggerSubticks,
|
|
490
|
+
twapParameters,
|
|
491
|
+
builderCodeParameters,
|
|
492
|
+
orderRouterAddress,
|
|
479
493
|
);
|
|
480
494
|
resolve(msg);
|
|
481
495
|
});
|
|
@@ -501,6 +515,9 @@ export class Post {
|
|
|
501
515
|
placeOrder.clientMetadata,
|
|
502
516
|
placeOrder.conditionType ?? Order_ConditionType.CONDITION_TYPE_UNSPECIFIED,
|
|
503
517
|
placeOrder.conditionalOrderTriggerSubticks ?? Long.fromInt(0),
|
|
518
|
+
placeOrder.twapParameters,
|
|
519
|
+
placeOrder.builderCodeParameters,
|
|
520
|
+
placeOrder.orderRouterAddress,
|
|
504
521
|
broadcastMode,
|
|
505
522
|
);
|
|
506
523
|
}
|
package/src/clients/types.ts
CHANGED
|
@@ -39,6 +39,19 @@ export enum OrderFlags {
|
|
|
39
39
|
CONDITIONAL = 32,
|
|
40
40
|
}
|
|
41
41
|
|
|
42
|
+
// TWAP order parameters
|
|
43
|
+
export interface ITwapParameters {
|
|
44
|
+
duration: number; // Duration in seconds [300, 86400]
|
|
45
|
+
interval: number; // Interval in seconds [30, 3600]
|
|
46
|
+
priceTolerance: number; // Price tolerance in ppm [0, 1_000_000)
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// Builder code parameters for partner/builder fees
|
|
50
|
+
export interface IBuilderCodeParameters {
|
|
51
|
+
builderAddress: string; // Address to receive the fee
|
|
52
|
+
feePpm: number; // Fee in parts per million
|
|
53
|
+
}
|
|
54
|
+
|
|
42
55
|
export interface IBasicOrder {
|
|
43
56
|
clientId: number;
|
|
44
57
|
orderFlags: OrderFlags;
|
|
@@ -56,6 +69,9 @@ export interface IPlaceOrder extends IBasicOrder {
|
|
|
56
69
|
clientMetadata: number;
|
|
57
70
|
conditionType?: Order_ConditionType;
|
|
58
71
|
conditionalOrderTriggerSubticks?: Long;
|
|
72
|
+
twapParameters?: ITwapParameters;
|
|
73
|
+
builderCodeParameters?: IBuilderCodeParameters;
|
|
74
|
+
orderRouterAddress?: string;
|
|
59
75
|
}
|
|
60
76
|
|
|
61
77
|
export interface ICancelOrder extends IBasicOrder {}
|