@gainsnetwork/sdk 0.1.29-rc3 → 0.1.29-rc4

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.
Files changed (135) hide show
  1. package/README.md +11 -11
  2. package/lib/constants.d.ts +261 -261
  3. package/lib/constants.js +277 -277
  4. package/lib/contracts/addresses.d.ts +3 -3
  5. package/lib/contracts/addresses.js +31 -31
  6. package/lib/contracts/addresses.json +89 -89
  7. package/lib/contracts/index.d.ts +8 -8
  8. package/lib/contracts/index.js +40 -40
  9. package/lib/contracts/types/generated/GFarmTradingStorageV5.d.ts +1911 -1911
  10. package/lib/contracts/types/generated/GFarmTradingStorageV5.js +2 -2
  11. package/lib/contracts/types/generated/GNSBorrowingFees.d.ts +1067 -1067
  12. package/lib/contracts/types/generated/GNSBorrowingFees.js +2 -2
  13. package/lib/contracts/types/generated/GNSMultiCollatDiamond.d.ts +1740 -1740
  14. package/lib/contracts/types/generated/GNSMultiCollatDiamond.js +2 -2
  15. package/lib/contracts/types/generated/GNSNftRewardsV6.d.ts +533 -533
  16. package/lib/contracts/types/generated/GNSNftRewardsV6.js +2 -2
  17. package/lib/contracts/types/generated/GNSNftRewardsV6_3_1.d.ts +613 -613
  18. package/lib/contracts/types/generated/GNSNftRewardsV6_3_1.js +2 -2
  19. package/lib/contracts/types/generated/GNSTrading.d.ts +758 -758
  20. package/lib/contracts/types/generated/GNSTrading.js +2 -2
  21. package/lib/contracts/types/generated/GNSTradingCallbacks.d.ts +875 -875
  22. package/lib/contracts/types/generated/GNSTradingCallbacks.js +2 -2
  23. package/lib/contracts/types/generated/GNSTradingStorage.d.ts +1387 -1387
  24. package/lib/contracts/types/generated/GNSTradingStorage.js +2 -2
  25. package/lib/contracts/types/generated/GToken.d.ts +1946 -1946
  26. package/lib/contracts/types/generated/GToken.js +2 -2
  27. package/lib/contracts/types/generated/GTokenOpenPnlFeed.d.ts +557 -557
  28. package/lib/contracts/types/generated/GTokenOpenPnlFeed.js +2 -2
  29. package/lib/contracts/types/generated/common.d.ts +22 -22
  30. package/lib/contracts/types/generated/common.js +2 -2
  31. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.d.ts +83 -83
  32. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.js +2691 -2691
  33. package/lib/contracts/types/generated/factories/GNSBorrowingFees__factory.d.ts +124 -124
  34. package/lib/contracts/types/generated/factories/GNSBorrowingFees__factory.js +1784 -1784
  35. package/lib/contracts/types/generated/factories/GNSMultiCollatDiamond__factory.d.ts +144 -144
  36. package/lib/contracts/types/generated/factories/GNSMultiCollatDiamond__factory.js +3094 -3094
  37. package/lib/contracts/types/generated/factories/GNSNftRewardsV6_3_1__factory.d.ts +100 -100
  38. package/lib/contracts/types/generated/factories/GNSNftRewardsV6_3_1__factory.js +1116 -1116
  39. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.d.ts +100 -100
  40. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.js +1003 -1003
  41. package/lib/contracts/types/generated/factories/GNSTradingCallbacks__factory.d.ts +113 -113
  42. package/lib/contracts/types/generated/factories/GNSTradingCallbacks__factory.js +1428 -1428
  43. package/lib/contracts/types/generated/factories/GNSTradingStorage__factory.d.ts +96 -96
  44. package/lib/contracts/types/generated/factories/GNSTradingStorage__factory.js +2241 -2241
  45. package/lib/contracts/types/generated/factories/GNSTrading__factory.d.ts +95 -95
  46. package/lib/contracts/types/generated/factories/GNSTrading__factory.js +1071 -1071
  47. package/lib/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.d.ts +59 -59
  48. package/lib/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.js +765 -765
  49. package/lib/contracts/types/generated/factories/GToken__factory.d.ts +121 -121
  50. package/lib/contracts/types/generated/factories/GToken__factory.js +2944 -2944
  51. package/lib/contracts/types/generated/factories/index.d.ts +10 -10
  52. package/lib/contracts/types/generated/factories/index.js +26 -26
  53. package/lib/contracts/types/generated/index.d.ts +21 -21
  54. package/lib/contracts/types/generated/index.js +47 -47
  55. package/lib/contracts/types/index.d.ts +27 -27
  56. package/lib/contracts/types/index.js +10 -10
  57. package/lib/contracts/utils/borrowingFees.d.ts +8 -8
  58. package/lib/contracts/utils/borrowingFees.js +28 -28
  59. package/lib/contracts/utils/index.d.ts +4 -4
  60. package/lib/contracts/utils/index.js +20 -20
  61. package/lib/contracts/utils/openLimitOrders.d.ts +8 -8
  62. package/lib/contracts/utils/openLimitOrders.js +88 -88
  63. package/lib/contracts/utils/openTrades.d.ts +9 -9
  64. package/lib/contracts/utils/openTrades.js +188 -188
  65. package/lib/contracts/utils/pairs.d.ts +7 -7
  66. package/lib/contracts/utils/pairs.js +337 -337
  67. package/lib/index.d.ts +7 -7
  68. package/lib/index.js +24 -24
  69. package/lib/markets/commodities.d.ts +1 -1
  70. package/lib/markets/commodities.js +31 -31
  71. package/lib/markets/crypto.d.ts +1 -1
  72. package/lib/markets/crypto.js +6 -6
  73. package/lib/markets/forex.d.ts +3 -3
  74. package/lib/markets/forex.js +45 -45
  75. package/lib/markets/index.d.ts +5 -5
  76. package/lib/markets/index.js +21 -21
  77. package/lib/markets/indices.d.ts +1 -1
  78. package/lib/markets/indices.js +6 -6
  79. package/lib/markets/stocks.d.ts +3 -3
  80. package/lib/markets/stocks.js +54 -54
  81. package/lib/trade/fees/borrowing/converter.d.ts +13 -13
  82. package/lib/trade/fees/borrowing/converter.js +41 -41
  83. package/lib/trade/fees/borrowing/index.d.ts +55 -55
  84. package/lib/trade/fees/borrowing/index.js +171 -171
  85. package/lib/trade/fees/borrowing/types.d.ts +36 -36
  86. package/lib/trade/fees/borrowing/types.js +2 -2
  87. package/lib/trade/fees/index.d.ts +4 -4
  88. package/lib/trade/fees/index.js +30 -30
  89. package/lib/trade/fees/tiers/index.d.ts +12 -12
  90. package/lib/trade/fees/tiers/index.js +51 -51
  91. package/lib/trade/fees/tiers/types.d.ts +8 -8
  92. package/lib/trade/fees/tiers/types.js +2 -2
  93. package/lib/trade/index.d.ts +8 -8
  94. package/lib/trade/index.js +24 -24
  95. package/lib/trade/liquidation.d.ts +3 -3
  96. package/lib/trade/liquidation.js +16 -16
  97. package/lib/trade/oiWindows.d.ts +3 -3
  98. package/lib/trade/oiWindows.js +20 -20
  99. package/lib/trade/openLimitOrder.d.ts +2 -2
  100. package/lib/trade/openLimitOrder.js +23 -23
  101. package/lib/trade/pnl.d.ts +7 -7
  102. package/lib/trade/pnl.js +33 -33
  103. package/lib/trade/spread.d.ts +2 -2
  104. package/lib/trade/spread.js +22 -22
  105. package/lib/trade/types.d.ts +429 -429
  106. package/lib/trade/types.js +249 -249
  107. package/lib/utils/index.d.ts +1 -1
  108. package/lib/utils/index.js +17 -17
  109. package/lib/utils/packing.d.ts +2 -2
  110. package/lib/utils/packing.js +39 -39
  111. package/lib/vault/index.d.ts +8 -8
  112. package/lib/vault/index.js +10 -10
  113. package/package.json +105 -105
  114. package/lib/contracts/types/generated/GNSBorrowingFeesV6_4.d.ts +0 -1058
  115. package/lib/contracts/types/generated/GNSBorrowingFeesV6_4.js +0 -2
  116. package/lib/contracts/types/generated/GNSPairInfosV6_1.d.ts +0 -911
  117. package/lib/contracts/types/generated/GNSPairInfosV6_1.js +0 -2
  118. package/lib/contracts/types/generated/GNSPairsStorageV6.d.ts +0 -660
  119. package/lib/contracts/types/generated/GNSPairsStorageV6.js +0 -2
  120. package/lib/contracts/types/generated/GNSTradingCallbacksV6_4.d.ts +0 -821
  121. package/lib/contracts/types/generated/GNSTradingCallbacksV6_4.js +0 -2
  122. package/lib/contracts/types/generated/GTokenV6_3_2.d.ts +0 -1838
  123. package/lib/contracts/types/generated/GTokenV6_3_2.js +0 -2
  124. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_4__factory.d.ts +0 -113
  125. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_4__factory.js +0 -1742
  126. package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.d.ts +0 -98
  127. package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.js +0 -1485
  128. package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.d.ts +0 -117
  129. package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.js +0 -1265
  130. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_4__factory.d.ts +0 -82
  131. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_4__factory.js +0 -1326
  132. package/lib/contracts/types/generated/factories/GTokenV6_3_2__factory.d.ts +0 -110
  133. package/lib/contracts/types/generated/factories/GTokenV6_3_2__factory.js +0 -2682
  134. package/lib/trade/fees.d.ts +0 -15
  135. package/lib/trade/fees.js +0 -45
@@ -1,88 +1,88 @@
1
- "use strict";
2
- /* eslint-disable @typescript-eslint/no-unsafe-call */
3
- /* eslint-disable @typescript-eslint/no-unsafe-return */
4
- /* eslint-disable @typescript-eslint/no-unsafe-member-access */
5
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
6
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
7
- return new (P || (P = Promise))(function (resolve, reject) {
8
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
9
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
10
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
11
- step((generator = generator.apply(thisArg, _arguments || [])).next());
12
- });
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.fetchOpenLimitOrdersRaw = exports.fetchOpenLimitOrders = void 0;
16
- const ethcall_1 = require("ethcall");
17
- const fetchOpenLimitOrders = (contracts, overrides = {}) => __awaiter(void 0, void 0, void 0, function* () {
18
- const openLimitOrdersRaw = yield (0, exports.fetchOpenLimitOrdersRaw)(contracts, overrides);
19
- return openLimitOrdersRaw.map((order) => ({
20
- block: parseInt(order.block.toString()),
21
- buy: order.buy,
22
- index: parseInt(order.index.toString()),
23
- leverage: parseInt(order.leverage.toString()),
24
- maxPrice: parseFloat(order.maxPrice.toString()) / 1e10,
25
- minPrice: parseFloat(order.minPrice.toString()) / 1e10,
26
- pairIndex: parseInt(order.pairIndex.toString()),
27
- positionSize: parseFloat(order.positionSize.toString()) / 1e18,
28
- sl: parseFloat(order.sl.toString()) / 1e10,
29
- spreadReductionP: parseInt(order.spreadReductionP.toString()) / 100,
30
- tp: parseFloat(order.tp.toString()) / 1e10,
31
- trader: order.trader,
32
- type: parseInt(order.type.toString()),
33
- maxSlippageP: parseFloat(order.maxSlippageP.toString()) / 1e10,
34
- }));
35
- });
36
- exports.fetchOpenLimitOrders = fetchOpenLimitOrders;
37
- const fetchOpenLimitOrdersRaw = (contracts, overrides = {}) => __awaiter(void 0, void 0, void 0, function* () {
38
- if (!contracts) {
39
- return [];
40
- }
41
- console.time("fetchOpenLimitOrdersRaw");
42
- const { useMulticall = false, blockTag = "latest" } = overrides;
43
- const { gfarmTradingStorageV5: storageContract, gnsNftRewards: nftRewards, gnsTradingCallbacks: callbacks, } = contracts;
44
- const openLimitOrders = yield storageContract.getOpenLimitOrders({
45
- blockTag,
46
- });
47
- let openLimitOrderTypes = [];
48
- let openLimitOrderTradeData = [];
49
- if (useMulticall) {
50
- const multicallProvider = new ethcall_1.Provider();
51
- yield multicallProvider.init(storageContract.provider);
52
- const nftRewardsContractMulticall = new ethcall_1.Contract(nftRewards.address, [
53
- ...nftRewards.interface.fragments,
54
- ]);
55
- const callbacksContractMulticall = new ethcall_1.Contract(callbacks.address, [
56
- ...callbacks.interface.fragments,
57
- ]);
58
- openLimitOrderTypes = yield multicallProvider.all(openLimitOrders.map(order => nftRewardsContractMulticall.openLimitOrderTypes(order.trader, order.pairIndex, order.index)), blockTag);
59
- openLimitOrderTradeData = yield multicallProvider.all(openLimitOrders.map(order => callbacksContractMulticall.tradeData(order.trader, order.pairIndex, order.index, 1)), blockTag);
60
- }
61
- else {
62
- openLimitOrderTypes = yield Promise.all(openLimitOrders.map(order => nftRewards.openLimitOrderTypes(order.trader, order.pairIndex, order.index, { blockTag })));
63
- openLimitOrderTradeData = yield Promise.all(openLimitOrders.map(order => callbacks.tradeData(order.trader, order.pairIndex, order.index, 1, {
64
- blockTag,
65
- })));
66
- }
67
- return openLimitOrderTypes.map((openLimitOrderType, index) => {
68
- const openLimitOrder = openLimitOrders[index];
69
- const tradeData = openLimitOrderTradeData[index];
70
- return {
71
- trader: openLimitOrder.trader,
72
- pairIndex: openLimitOrder.pairIndex,
73
- index: openLimitOrder.index,
74
- positionSize: openLimitOrder.positionSize,
75
- spreadReductionP: openLimitOrder.spreadReductionP,
76
- buy: openLimitOrder.buy,
77
- leverage: openLimitOrder.leverage,
78
- tp: openLimitOrder.tp,
79
- sl: openLimitOrder.sl,
80
- minPrice: openLimitOrder.minPrice,
81
- maxPrice: openLimitOrder.maxPrice,
82
- block: openLimitOrder.block,
83
- type: openLimitOrderType,
84
- maxSlippageP: tradeData.maxSlippageP,
85
- };
86
- });
87
- });
88
- exports.fetchOpenLimitOrdersRaw = fetchOpenLimitOrdersRaw;
1
+ "use strict";
2
+ /* eslint-disable @typescript-eslint/no-unsafe-call */
3
+ /* eslint-disable @typescript-eslint/no-unsafe-return */
4
+ /* eslint-disable @typescript-eslint/no-unsafe-member-access */
5
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
6
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
7
+ return new (P || (P = Promise))(function (resolve, reject) {
8
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
9
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
10
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
11
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
12
+ });
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.fetchOpenLimitOrdersRaw = exports.fetchOpenLimitOrders = void 0;
16
+ const ethcall_1 = require("ethcall");
17
+ const fetchOpenLimitOrders = (contracts, overrides = {}) => __awaiter(void 0, void 0, void 0, function* () {
18
+ const openLimitOrdersRaw = yield (0, exports.fetchOpenLimitOrdersRaw)(contracts, overrides);
19
+ return openLimitOrdersRaw.map((order) => ({
20
+ block: parseInt(order.block.toString()),
21
+ buy: order.buy,
22
+ index: parseInt(order.index.toString()),
23
+ leverage: parseInt(order.leverage.toString()),
24
+ maxPrice: parseFloat(order.maxPrice.toString()) / 1e10,
25
+ minPrice: parseFloat(order.minPrice.toString()) / 1e10,
26
+ pairIndex: parseInt(order.pairIndex.toString()),
27
+ positionSize: parseFloat(order.positionSize.toString()) / 1e18,
28
+ sl: parseFloat(order.sl.toString()) / 1e10,
29
+ spreadReductionP: parseInt(order.spreadReductionP.toString()) / 100,
30
+ tp: parseFloat(order.tp.toString()) / 1e10,
31
+ trader: order.trader,
32
+ type: parseInt(order.type.toString()),
33
+ maxSlippageP: parseFloat(order.maxSlippageP.toString()) / 1e10,
34
+ }));
35
+ });
36
+ exports.fetchOpenLimitOrders = fetchOpenLimitOrders;
37
+ const fetchOpenLimitOrdersRaw = (contracts, overrides = {}) => __awaiter(void 0, void 0, void 0, function* () {
38
+ if (!contracts) {
39
+ return [];
40
+ }
41
+ console.time("fetchOpenLimitOrdersRaw");
42
+ const { useMulticall = false, blockTag = "latest" } = overrides;
43
+ const { gfarmTradingStorageV5: storageContract, gnsNftRewards: nftRewards, gnsTradingCallbacks: callbacks, } = contracts;
44
+ const openLimitOrders = yield storageContract.getOpenLimitOrders({
45
+ blockTag,
46
+ });
47
+ let openLimitOrderTypes = [];
48
+ let openLimitOrderTradeData = [];
49
+ if (useMulticall) {
50
+ const multicallProvider = new ethcall_1.Provider();
51
+ yield multicallProvider.init(storageContract.provider);
52
+ const nftRewardsContractMulticall = new ethcall_1.Contract(nftRewards.address, [
53
+ ...nftRewards.interface.fragments,
54
+ ]);
55
+ const callbacksContractMulticall = new ethcall_1.Contract(callbacks.address, [
56
+ ...callbacks.interface.fragments,
57
+ ]);
58
+ openLimitOrderTypes = yield multicallProvider.all(openLimitOrders.map(order => nftRewardsContractMulticall.openLimitOrderTypes(order.trader, order.pairIndex, order.index)), blockTag);
59
+ openLimitOrderTradeData = yield multicallProvider.all(openLimitOrders.map(order => callbacksContractMulticall.tradeData(order.trader, order.pairIndex, order.index, 1)), blockTag);
60
+ }
61
+ else {
62
+ openLimitOrderTypes = yield Promise.all(openLimitOrders.map(order => nftRewards.openLimitOrderTypes(order.trader, order.pairIndex, order.index, { blockTag })));
63
+ openLimitOrderTradeData = yield Promise.all(openLimitOrders.map(order => callbacks.tradeData(order.trader, order.pairIndex, order.index, 1, {
64
+ blockTag,
65
+ })));
66
+ }
67
+ return openLimitOrderTypes.map((openLimitOrderType, index) => {
68
+ const openLimitOrder = openLimitOrders[index];
69
+ const tradeData = openLimitOrderTradeData[index];
70
+ return {
71
+ trader: openLimitOrder.trader,
72
+ pairIndex: openLimitOrder.pairIndex,
73
+ index: openLimitOrder.index,
74
+ positionSize: openLimitOrder.positionSize,
75
+ spreadReductionP: openLimitOrder.spreadReductionP,
76
+ buy: openLimitOrder.buy,
77
+ leverage: openLimitOrder.leverage,
78
+ tp: openLimitOrder.tp,
79
+ sl: openLimitOrder.sl,
80
+ minPrice: openLimitOrder.minPrice,
81
+ maxPrice: openLimitOrder.maxPrice,
82
+ block: openLimitOrder.block,
83
+ type: openLimitOrderType,
84
+ maxSlippageP: tradeData.maxSlippageP,
85
+ };
86
+ });
87
+ });
88
+ exports.fetchOpenLimitOrdersRaw = fetchOpenLimitOrdersRaw;
@@ -1,9 +1,9 @@
1
- import { TradeContainer, TradeContainerRaw } from "../../trade/types";
2
- import { Contracts, BlockTag } from "../../contracts/types";
3
- export type FetchOpenPairTradesOverrides = {
4
- pairBatchSize?: number;
5
- useMulticall?: boolean;
6
- blockTag?: BlockTag;
7
- };
8
- export declare const fetchOpenPairTrades: (contracts: Contracts, overrides?: FetchOpenPairTradesOverrides) => Promise<TradeContainer[]>;
9
- export declare const fetchOpenPairTradesRaw: (contracts: Contracts, overrides?: FetchOpenPairTradesOverrides) => Promise<TradeContainerRaw[]>;
1
+ import { TradeContainer, TradeContainerRaw } from "../../trade/types";
2
+ import { Contracts, BlockTag } from "../../contracts/types";
3
+ export type FetchOpenPairTradesOverrides = {
4
+ pairBatchSize?: number;
5
+ useMulticall?: boolean;
6
+ blockTag?: BlockTag;
7
+ };
8
+ export declare const fetchOpenPairTrades: (contracts: Contracts, overrides?: FetchOpenPairTradesOverrides) => Promise<TradeContainer[]>;
9
+ export declare const fetchOpenPairTradesRaw: (contracts: Contracts, overrides?: FetchOpenPairTradesOverrides) => Promise<TradeContainerRaw[]>;
@@ -1,188 +1,188 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.fetchOpenPairTradesRaw = exports.fetchOpenPairTrades = void 0;
13
- /* eslint-disable @typescript-eslint/no-unsafe-call */
14
- /* eslint-disable @typescript-eslint/no-unsafe-return */
15
- /* eslint-disable @typescript-eslint/no-unsafe-member-access */
16
- const ethcall_1 = require("ethcall");
17
- const fetchOpenPairTrades = (contracts, overrides = {}) => __awaiter(void 0, void 0, void 0, function* () {
18
- const rawTrades = yield (0, exports.fetchOpenPairTradesRaw)(contracts, overrides);
19
- const { precision: collateralPrecision } = yield contracts.gnsBorrowingFees.collateralConfig();
20
- return rawTrades.map(rawTrade => _prepareTradeContainer(rawTrade.trade, rawTrade.tradeInfo, rawTrade.initialAccFees, rawTrade.tradeData, collateralPrecision));
21
- });
22
- exports.fetchOpenPairTrades = fetchOpenPairTrades;
23
- const fetchOpenPairTradesRaw = (contracts, overrides = {}) => __awaiter(void 0, void 0, void 0, function* () {
24
- if (!contracts) {
25
- return [];
26
- }
27
- const { pairBatchSize = 10, useMulticall = false, blockTag = "latest", } = overrides;
28
- const { gnsMultiCollatDiamond: multiCollatDiamondContract } = contracts;
29
- try {
30
- const totalPairIndexes = (yield multiCollatDiamondContract.pairsCount({ blockTag })).toNumber() -
31
- 1;
32
- let allOpenPairTrades = [];
33
- for (let batchStartPairIndex = 0; batchStartPairIndex < totalPairIndexes; batchStartPairIndex += pairBatchSize) {
34
- const batchEndPairIndex = Math.min(batchStartPairIndex + pairBatchSize - 1, totalPairIndexes);
35
- const openPairTradesBatch = useMulticall
36
- ? yield fetchOpenPairTradesBatchMulticall(contracts, batchStartPairIndex, batchEndPairIndex, blockTag)
37
- : yield fetchOpenPairTradesBatch(contracts, batchStartPairIndex, batchEndPairIndex);
38
- allOpenPairTrades = allOpenPairTrades.concat(openPairTradesBatch);
39
- }
40
- return allOpenPairTrades;
41
- }
42
- catch (error) {
43
- console.error(`Unexpected error while fetching open pair trades!`);
44
- throw error;
45
- }
46
- });
47
- exports.fetchOpenPairTradesRaw = fetchOpenPairTradesRaw;
48
- const fetchOpenPairTradesBatch = (contracts, startPairIndex, endPairIndex) => __awaiter(void 0, void 0, void 0, function* () {
49
- const { gfarmTradingStorageV5: storageContract, gnsBorrowingFees: borrowingFeesContract, gnsTradingCallbacks: callbacksContract, } = contracts;
50
- const maxTradesPerPair = (yield storageContract.maxTradesPerPair()).toNumber();
51
- const pairIndexesToFetch = Array.from({ length: endPairIndex - startPairIndex + 1 }, (_, i) => i + startPairIndex);
52
- const rawTrades = yield Promise.all(pairIndexesToFetch.map((pairIndex) => __awaiter(void 0, void 0, void 0, function* () {
53
- const pairTraderAddresses = yield storageContract.pairTradersArray(pairIndex);
54
- if (pairTraderAddresses.length === 0) {
55
- return [];
56
- }
57
- const openTradesForPairTraders = yield Promise.all(pairTraderAddresses.map((pairTraderAddress) => __awaiter(void 0, void 0, void 0, function* () {
58
- const openTradesCalls = new Array(maxTradesPerPair);
59
- for (let pairTradeIndex = 0; pairTradeIndex < maxTradesPerPair; pairTradeIndex++) {
60
- openTradesCalls[pairTradeIndex] = storageContract.openTrades(pairTraderAddress, pairIndex, pairTradeIndex);
61
- }
62
- const openTradesForTraderAddress = yield Promise.all(openTradesCalls);
63
- // Filter out any of the trades that aren't *really* open (NOTE: these will have an empty trader address, so just test against that)
64
- const actualOpenTradesForTrader = openTradesForTraderAddress.filter(openTrade => openTrade.trader === pairTraderAddress);
65
- const [actualOpenTradesTradeInfos, actualOpenTradesInitialAccFees, actualOpenTradesTradeData,] = yield Promise.all([
66
- Promise.all(actualOpenTradesForTrader.map(aot => storageContract.openTradesInfo(aot.trader, aot.pairIndex, aot.index))),
67
- Promise.all(actualOpenTradesForTrader.map(aot => borrowingFeesContract.initialAccFees(aot.trader, aot.pairIndex, aot.index))),
68
- Promise.all(actualOpenTradesForTrader.map(aot => callbacksContract.tradeData(aot.trader, aot.pairIndex, aot.index, 0))),
69
- ]);
70
- const finalOpenTradesForTrader = new Array(actualOpenTradesForTrader.length);
71
- for (let tradeIndex = 0; tradeIndex < actualOpenTradesForTrader.length; tradeIndex++) {
72
- const tradeInfo = actualOpenTradesTradeInfos[tradeIndex];
73
- if (tradeInfo === undefined) {
74
- continue;
75
- }
76
- if (actualOpenTradesInitialAccFees[tradeIndex] === undefined) {
77
- continue;
78
- }
79
- const trade = actualOpenTradesForTrader[tradeIndex];
80
- const tradeData = actualOpenTradesTradeData[tradeIndex];
81
- finalOpenTradesForTrader[tradeIndex] = {
82
- trade,
83
- tradeInfo,
84
- initialAccFees: {
85
- borrowing: actualOpenTradesInitialAccFees[tradeIndex],
86
- },
87
- tradeData,
88
- };
89
- }
90
- return finalOpenTradesForTrader;
91
- })));
92
- return openTradesForPairTraders;
93
- })));
94
- const perPairTrades = rawTrades.reduce((a, b) => a.concat(b), []);
95
- return perPairTrades.reduce((a, b) => a.concat(b), []);
96
- });
97
- const fetchOpenPairTradesBatchMulticall = (contracts, startPairIndex, endPairIndex, blockTag) => __awaiter(void 0, void 0, void 0, function* () {
98
- const { gfarmTradingStorageV5: storageContract, gnsBorrowingFees: borrowingFeesContract, gnsTradingCallbacks: callbacksContract, } = contracts;
99
- // Convert to Multicall for efficient RPC usage
100
- const multicallProvider = new ethcall_1.Provider();
101
- yield multicallProvider.init(storageContract.provider);
102
- const storageContractMulticall = new ethcall_1.Contract(storageContract.address, [
103
- ...storageContract.interface.fragments,
104
- ]);
105
- const borrowingFeesContractMulticall = new ethcall_1.Contract(borrowingFeesContract.address, [...borrowingFeesContract.interface.fragments]);
106
- const callbacksContractMulticall = new ethcall_1.Contract(callbacksContract.address, [
107
- ...callbacksContract.interface.fragments,
108
- ]);
109
- const maxTradesPerPair = (yield storageContract.maxTradesPerPair()).toNumber();
110
- const pairIndexesToFetch = Array.from({ length: endPairIndex - startPairIndex + 1 }, (_, i) => i + startPairIndex);
111
- const mcPairTraderAddresses = yield multicallProvider.all(pairIndexesToFetch.map(pairIndex => storageContractMulticall.pairTradersArray(pairIndex)), blockTag);
112
- const mcFlatOpenTrades = yield multicallProvider.all(mcPairTraderAddresses
113
- .map((pairTraderAddresses, _ix) => {
114
- return pairTraderAddresses
115
- .map((pairTraderAddress) => {
116
- const openTradesCalls = new Array(maxTradesPerPair);
117
- for (let pairTradeIndex = 0; pairTradeIndex < maxTradesPerPair; pairTradeIndex++) {
118
- openTradesCalls[pairTradeIndex] =
119
- storageContractMulticall.openTrades(pairTraderAddress, _ix + startPairIndex, pairTradeIndex);
120
- }
121
- return openTradesCalls;
122
- })
123
- .reduce((acc, val) => acc.concat(val), []);
124
- })
125
- .reduce((acc, val) => acc.concat(val), []), blockTag);
126
- const openTrades = mcFlatOpenTrades.filter(openTrade => openTrade[0] !== "0x0000000000000000000000000000000000000000");
127
- const [openTradesTradeInfos, openTradesInitialAccFees, openTradesTradeData] = yield Promise.all([
128
- multicallProvider.all(openTrades.map(openTrade => storageContractMulticall.openTradesInfo(openTrade.trader, openTrade.pairIndex, openTrade.index)), blockTag),
129
- multicallProvider.all(openTrades.map(openTrade => borrowingFeesContractMulticall.initialAccFees(openTrade.trader, openTrade.pairIndex, openTrade.index)), blockTag),
130
- multicallProvider.all(openTrades.map(openTrade => callbacksContractMulticall.tradeData(openTrade.trader, openTrade.pairIndex, openTrade.index, 0)), blockTag),
131
- ]);
132
- const finalTrades = new Array(openTrades.length);
133
- for (let tradeIndex = 0; tradeIndex < openTradesTradeInfos.length; tradeIndex++) {
134
- const tradeInfo = openTradesTradeInfos[tradeIndex];
135
- if (tradeInfo === undefined) {
136
- console.error("No trade info found for open trade while fetching open trades!", { trade: openTradesTradeInfos[tradeIndex] });
137
- continue;
138
- }
139
- if (openTradesInitialAccFees[tradeIndex] === undefined) {
140
- console.error("No initial fees found for open trade while fetching open trades!", { trade: openTrades[tradeIndex] });
141
- continue;
142
- }
143
- const trade = openTrades[tradeIndex];
144
- const tradeData = openTradesTradeData[tradeIndex];
145
- finalTrades[tradeIndex] = {
146
- trade,
147
- tradeInfo,
148
- initialAccFees: {
149
- borrowing: openTradesInitialAccFees[tradeIndex],
150
- },
151
- tradeData,
152
- };
153
- }
154
- return finalTrades.filter(trade => trade !== undefined);
155
- });
156
- const _prepareTradeContainer = (trade, tradeInfo, tradeInitialAccFees, tradeData, collateralPrecision) => ({
157
- trade: {
158
- trader: trade.trader,
159
- pairIndex: parseInt(trade.pairIndex.toString()),
160
- index: parseInt(trade.index.toString()),
161
- initialPosToken: parseFloat(trade.initialPosToken.toString()) / 1e18,
162
- openPrice: parseFloat(trade.openPrice.toString()) / 1e10,
163
- buy: trade.buy.toString() === "true",
164
- leverage: parseInt(trade.leverage.toString()),
165
- tp: parseFloat(trade.tp.toString()) / 1e10,
166
- sl: parseFloat(trade.sl.toString()) / 1e10,
167
- },
168
- tradeInfo: {
169
- beingMarketClosed: tradeInfo.beingMarketClosed.toString() === "true",
170
- tokenPriceDai: parseFloat(tradeInfo.tokenPriceDai.toString()) / 1e10,
171
- openInterestDai: parseFloat(tradeInfo.openInterestDai.toString()) /
172
- parseFloat(collateralPrecision.toString()),
173
- tpLastUpdated: tradeInfo.tpLastUpdated,
174
- slLastUpdated: tradeInfo.slLastUpdated,
175
- },
176
- tradeData: {
177
- maxSlippageP: parseFloat(tradeData.maxSlippageP.toString()) / 1e10,
178
- lastOiUpdateTs: parseFloat(tradeData.lastOiUpdateTs),
179
- collateralPriceUsd: parseFloat(tradeData.collateralPriceUsd.toString()) / 1e8,
180
- },
181
- initialAccFees: {
182
- borrowing: {
183
- accPairFee: parseFloat(tradeInitialAccFees.borrowing.accPairFee.toString()) / 1e10,
184
- accGroupFee: parseFloat(tradeInitialAccFees.borrowing.accGroupFee.toString()) / 1e10,
185
- block: parseFloat(tradeInitialAccFees.borrowing.block.toString()),
186
- },
187
- },
188
- });
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.fetchOpenPairTradesRaw = exports.fetchOpenPairTrades = void 0;
13
+ /* eslint-disable @typescript-eslint/no-unsafe-call */
14
+ /* eslint-disable @typescript-eslint/no-unsafe-return */
15
+ /* eslint-disable @typescript-eslint/no-unsafe-member-access */
16
+ const ethcall_1 = require("ethcall");
17
+ const fetchOpenPairTrades = (contracts, overrides = {}) => __awaiter(void 0, void 0, void 0, function* () {
18
+ const rawTrades = yield (0, exports.fetchOpenPairTradesRaw)(contracts, overrides);
19
+ const { precision: collateralPrecision } = yield contracts.gnsBorrowingFees.collateralConfig();
20
+ return rawTrades.map(rawTrade => _prepareTradeContainer(rawTrade.trade, rawTrade.tradeInfo, rawTrade.initialAccFees, rawTrade.tradeData, collateralPrecision));
21
+ });
22
+ exports.fetchOpenPairTrades = fetchOpenPairTrades;
23
+ const fetchOpenPairTradesRaw = (contracts, overrides = {}) => __awaiter(void 0, void 0, void 0, function* () {
24
+ if (!contracts) {
25
+ return [];
26
+ }
27
+ const { pairBatchSize = 10, useMulticall = false, blockTag = "latest", } = overrides;
28
+ const { gnsMultiCollatDiamond: multiCollatDiamondContract } = contracts;
29
+ try {
30
+ const totalPairIndexes = (yield multiCollatDiamondContract.pairsCount({ blockTag })).toNumber() -
31
+ 1;
32
+ let allOpenPairTrades = [];
33
+ for (let batchStartPairIndex = 0; batchStartPairIndex < totalPairIndexes; batchStartPairIndex += pairBatchSize) {
34
+ const batchEndPairIndex = Math.min(batchStartPairIndex + pairBatchSize - 1, totalPairIndexes);
35
+ const openPairTradesBatch = useMulticall
36
+ ? yield fetchOpenPairTradesBatchMulticall(contracts, batchStartPairIndex, batchEndPairIndex, blockTag)
37
+ : yield fetchOpenPairTradesBatch(contracts, batchStartPairIndex, batchEndPairIndex);
38
+ allOpenPairTrades = allOpenPairTrades.concat(openPairTradesBatch);
39
+ }
40
+ return allOpenPairTrades;
41
+ }
42
+ catch (error) {
43
+ console.error(`Unexpected error while fetching open pair trades!`);
44
+ throw error;
45
+ }
46
+ });
47
+ exports.fetchOpenPairTradesRaw = fetchOpenPairTradesRaw;
48
+ const fetchOpenPairTradesBatch = (contracts, startPairIndex, endPairIndex) => __awaiter(void 0, void 0, void 0, function* () {
49
+ const { gfarmTradingStorageV5: storageContract, gnsBorrowingFees: borrowingFeesContract, gnsTradingCallbacks: callbacksContract, } = contracts;
50
+ const maxTradesPerPair = (yield storageContract.maxTradesPerPair()).toNumber();
51
+ const pairIndexesToFetch = Array.from({ length: endPairIndex - startPairIndex + 1 }, (_, i) => i + startPairIndex);
52
+ const rawTrades = yield Promise.all(pairIndexesToFetch.map((pairIndex) => __awaiter(void 0, void 0, void 0, function* () {
53
+ const pairTraderAddresses = yield storageContract.pairTradersArray(pairIndex);
54
+ if (pairTraderAddresses.length === 0) {
55
+ return [];
56
+ }
57
+ const openTradesForPairTraders = yield Promise.all(pairTraderAddresses.map((pairTraderAddress) => __awaiter(void 0, void 0, void 0, function* () {
58
+ const openTradesCalls = new Array(maxTradesPerPair);
59
+ for (let pairTradeIndex = 0; pairTradeIndex < maxTradesPerPair; pairTradeIndex++) {
60
+ openTradesCalls[pairTradeIndex] = storageContract.openTrades(pairTraderAddress, pairIndex, pairTradeIndex);
61
+ }
62
+ const openTradesForTraderAddress = yield Promise.all(openTradesCalls);
63
+ // Filter out any of the trades that aren't *really* open (NOTE: these will have an empty trader address, so just test against that)
64
+ const actualOpenTradesForTrader = openTradesForTraderAddress.filter(openTrade => openTrade.trader === pairTraderAddress);
65
+ const [actualOpenTradesTradeInfos, actualOpenTradesInitialAccFees, actualOpenTradesTradeData,] = yield Promise.all([
66
+ Promise.all(actualOpenTradesForTrader.map(aot => storageContract.openTradesInfo(aot.trader, aot.pairIndex, aot.index))),
67
+ Promise.all(actualOpenTradesForTrader.map(aot => borrowingFeesContract.initialAccFees(aot.trader, aot.pairIndex, aot.index))),
68
+ Promise.all(actualOpenTradesForTrader.map(aot => callbacksContract.tradeData(aot.trader, aot.pairIndex, aot.index, 0))),
69
+ ]);
70
+ const finalOpenTradesForTrader = new Array(actualOpenTradesForTrader.length);
71
+ for (let tradeIndex = 0; tradeIndex < actualOpenTradesForTrader.length; tradeIndex++) {
72
+ const tradeInfo = actualOpenTradesTradeInfos[tradeIndex];
73
+ if (tradeInfo === undefined) {
74
+ continue;
75
+ }
76
+ if (actualOpenTradesInitialAccFees[tradeIndex] === undefined) {
77
+ continue;
78
+ }
79
+ const trade = actualOpenTradesForTrader[tradeIndex];
80
+ const tradeData = actualOpenTradesTradeData[tradeIndex];
81
+ finalOpenTradesForTrader[tradeIndex] = {
82
+ trade,
83
+ tradeInfo,
84
+ initialAccFees: {
85
+ borrowing: actualOpenTradesInitialAccFees[tradeIndex],
86
+ },
87
+ tradeData,
88
+ };
89
+ }
90
+ return finalOpenTradesForTrader;
91
+ })));
92
+ return openTradesForPairTraders;
93
+ })));
94
+ const perPairTrades = rawTrades.reduce((a, b) => a.concat(b), []);
95
+ return perPairTrades.reduce((a, b) => a.concat(b), []);
96
+ });
97
+ const fetchOpenPairTradesBatchMulticall = (contracts, startPairIndex, endPairIndex, blockTag) => __awaiter(void 0, void 0, void 0, function* () {
98
+ const { gfarmTradingStorageV5: storageContract, gnsBorrowingFees: borrowingFeesContract, gnsTradingCallbacks: callbacksContract, } = contracts;
99
+ // Convert to Multicall for efficient RPC usage
100
+ const multicallProvider = new ethcall_1.Provider();
101
+ yield multicallProvider.init(storageContract.provider);
102
+ const storageContractMulticall = new ethcall_1.Contract(storageContract.address, [
103
+ ...storageContract.interface.fragments,
104
+ ]);
105
+ const borrowingFeesContractMulticall = new ethcall_1.Contract(borrowingFeesContract.address, [...borrowingFeesContract.interface.fragments]);
106
+ const callbacksContractMulticall = new ethcall_1.Contract(callbacksContract.address, [
107
+ ...callbacksContract.interface.fragments,
108
+ ]);
109
+ const maxTradesPerPair = (yield storageContract.maxTradesPerPair()).toNumber();
110
+ const pairIndexesToFetch = Array.from({ length: endPairIndex - startPairIndex + 1 }, (_, i) => i + startPairIndex);
111
+ const mcPairTraderAddresses = yield multicallProvider.all(pairIndexesToFetch.map(pairIndex => storageContractMulticall.pairTradersArray(pairIndex)), blockTag);
112
+ const mcFlatOpenTrades = yield multicallProvider.all(mcPairTraderAddresses
113
+ .map((pairTraderAddresses, _ix) => {
114
+ return pairTraderAddresses
115
+ .map((pairTraderAddress) => {
116
+ const openTradesCalls = new Array(maxTradesPerPair);
117
+ for (let pairTradeIndex = 0; pairTradeIndex < maxTradesPerPair; pairTradeIndex++) {
118
+ openTradesCalls[pairTradeIndex] =
119
+ storageContractMulticall.openTrades(pairTraderAddress, _ix + startPairIndex, pairTradeIndex);
120
+ }
121
+ return openTradesCalls;
122
+ })
123
+ .reduce((acc, val) => acc.concat(val), []);
124
+ })
125
+ .reduce((acc, val) => acc.concat(val), []), blockTag);
126
+ const openTrades = mcFlatOpenTrades.filter(openTrade => openTrade[0] !== "0x0000000000000000000000000000000000000000");
127
+ const [openTradesTradeInfos, openTradesInitialAccFees, openTradesTradeData] = yield Promise.all([
128
+ multicallProvider.all(openTrades.map(openTrade => storageContractMulticall.openTradesInfo(openTrade.trader, openTrade.pairIndex, openTrade.index)), blockTag),
129
+ multicallProvider.all(openTrades.map(openTrade => borrowingFeesContractMulticall.initialAccFees(openTrade.trader, openTrade.pairIndex, openTrade.index)), blockTag),
130
+ multicallProvider.all(openTrades.map(openTrade => callbacksContractMulticall.tradeData(openTrade.trader, openTrade.pairIndex, openTrade.index, 0)), blockTag),
131
+ ]);
132
+ const finalTrades = new Array(openTrades.length);
133
+ for (let tradeIndex = 0; tradeIndex < openTradesTradeInfos.length; tradeIndex++) {
134
+ const tradeInfo = openTradesTradeInfos[tradeIndex];
135
+ if (tradeInfo === undefined) {
136
+ console.error("No trade info found for open trade while fetching open trades!", { trade: openTradesTradeInfos[tradeIndex] });
137
+ continue;
138
+ }
139
+ if (openTradesInitialAccFees[tradeIndex] === undefined) {
140
+ console.error("No initial fees found for open trade while fetching open trades!", { trade: openTrades[tradeIndex] });
141
+ continue;
142
+ }
143
+ const trade = openTrades[tradeIndex];
144
+ const tradeData = openTradesTradeData[tradeIndex];
145
+ finalTrades[tradeIndex] = {
146
+ trade,
147
+ tradeInfo,
148
+ initialAccFees: {
149
+ borrowing: openTradesInitialAccFees[tradeIndex],
150
+ },
151
+ tradeData,
152
+ };
153
+ }
154
+ return finalTrades.filter(trade => trade !== undefined);
155
+ });
156
+ const _prepareTradeContainer = (trade, tradeInfo, tradeInitialAccFees, tradeData, collateralPrecision) => ({
157
+ trade: {
158
+ trader: trade.trader,
159
+ pairIndex: parseInt(trade.pairIndex.toString()),
160
+ index: parseInt(trade.index.toString()),
161
+ initialPosToken: parseFloat(trade.initialPosToken.toString()) / 1e18,
162
+ openPrice: parseFloat(trade.openPrice.toString()) / 1e10,
163
+ buy: trade.buy.toString() === "true",
164
+ leverage: parseInt(trade.leverage.toString()),
165
+ tp: parseFloat(trade.tp.toString()) / 1e10,
166
+ sl: parseFloat(trade.sl.toString()) / 1e10,
167
+ },
168
+ tradeInfo: {
169
+ beingMarketClosed: tradeInfo.beingMarketClosed.toString() === "true",
170
+ tokenPriceDai: parseFloat(tradeInfo.tokenPriceDai.toString()) / 1e10,
171
+ openInterestDai: parseFloat(tradeInfo.openInterestDai.toString()) /
172
+ parseFloat(collateralPrecision.toString()),
173
+ tpLastUpdated: tradeInfo.tpLastUpdated,
174
+ slLastUpdated: tradeInfo.slLastUpdated,
175
+ },
176
+ tradeData: {
177
+ maxSlippageP: parseFloat(tradeData.maxSlippageP.toString()) / 1e10,
178
+ lastOiUpdateTs: parseFloat(tradeData.lastOiUpdateTs),
179
+ collateralPriceUsd: parseFloat(tradeData.collateralPriceUsd.toString()) / 1e8,
180
+ },
181
+ initialAccFees: {
182
+ borrowing: {
183
+ accPairFee: parseFloat(tradeInitialAccFees.borrowing.accPairFee.toString()) / 1e10,
184
+ accGroupFee: parseFloat(tradeInitialAccFees.borrowing.accGroupFee.toString()) / 1e10,
185
+ block: parseFloat(tradeInitialAccFees.borrowing.block.toString()),
186
+ },
187
+ },
188
+ });
@@ -1,7 +1,7 @@
1
- import { Pair, Fee, OpenInterest, PairDepth, PairIndex } from "../../trade/types";
2
- import { Contracts } from "../../contracts/types";
3
- export declare const fetchPairs: (contracts: Contracts, pairIxs: PairIndex[]) => Promise<Pair[]>;
4
- export declare const fetchPairDepths: (contracts: Contracts, pairIxs: number[]) => Promise<PairDepth[]>;
5
- export declare const fetchFees: (contracts: Contracts, feeIxs: PairIndex[]) => Promise<Fee[]>;
6
- export declare const fetchOpenInterest: (contracts: Contracts, pairIxs: number[]) => Promise<OpenInterest[]>;
7
- export declare const getPairDescription: (pairIndex: PairIndex) => string;
1
+ import { Pair, Fee, OpenInterest, PairDepth, PairIndex } from "../../trade/types";
2
+ import { Contracts } from "../../contracts/types";
3
+ export declare const fetchPairs: (contracts: Contracts, pairIxs: PairIndex[]) => Promise<Pair[]>;
4
+ export declare const fetchPairDepths: (contracts: Contracts, pairIxs: number[]) => Promise<PairDepth[]>;
5
+ export declare const fetchFees: (contracts: Contracts, feeIxs: PairIndex[]) => Promise<Fee[]>;
6
+ export declare const fetchOpenInterest: (contracts: Contracts, pairIxs: number[]) => Promise<OpenInterest[]>;
7
+ export declare const getPairDescription: (pairIndex: PairIndex) => string;