@gainsnetwork/sdk 0.0.49 → 0.0.51-multi-collat-rc1

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 (122) hide show
  1. package/README.md +11 -11
  2. package/lib/constants.d.ts +220 -221
  3. package/lib/constants.js +238 -239
  4. package/lib/contracts/addresses.d.ts +2 -2
  5. package/lib/contracts/addresses.js +19 -15
  6. package/lib/contracts/addresses.json +60 -35
  7. package/lib/contracts/index.d.ts +6 -6
  8. package/lib/contracts/index.js +34 -35
  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 -1341
  12. package/lib/contracts/types/generated/GNSBorrowingFees.js +2 -2
  13. package/lib/contracts/types/generated/GNSMultiCollatDiamond.d.ts +1740 -0
  14. package/lib/contracts/types/generated/{GNSPairsStorageV6.js → 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 -0
  20. package/lib/contracts/types/generated/{GNSBorrowingFeesV6_4.js → GNSTrading.js} +2 -2
  21. package/lib/contracts/types/generated/{GNSTradingCallbacksV6_4.d.ts → GNSTradingCallbacks.d.ts} +875 -821
  22. package/lib/contracts/types/generated/{GNSTradingCallbacksV6_4.js → GNSTradingCallbacks.js} +2 -2
  23. package/lib/contracts/types/generated/GNSTradingStorage.d.ts +1387 -0
  24. package/lib/contracts/types/generated/{GNSPairInfosV6_1.js → GNSTradingStorage.js} +2 -2
  25. package/lib/contracts/types/generated/GTokenOpenPnlFeed.d.ts +557 -557
  26. package/lib/contracts/types/generated/GTokenOpenPnlFeed.js +2 -2
  27. package/lib/contracts/types/generated/GTokenV6_3_2.d.ts +1838 -1838
  28. package/lib/contracts/types/generated/GTokenV6_3_2.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 -128
  34. package/lib/contracts/types/generated/factories/GNSBorrowingFees__factory.js +1789 -2206
  35. package/lib/contracts/types/generated/factories/GNSMultiCollatDiamond__factory.d.ts +144 -0
  36. package/lib/contracts/types/generated/factories/GNSMultiCollatDiamond__factory.js +3094 -0
  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 -0
  42. package/lib/contracts/types/generated/factories/GNSTradingCallbacks__factory.js +1428 -0
  43. package/lib/contracts/types/generated/factories/GNSTradingStorage__factory.d.ts +96 -0
  44. package/lib/contracts/types/generated/factories/GNSTradingStorage__factory.js +2241 -0
  45. package/lib/contracts/types/generated/factories/GNSTrading__factory.d.ts +95 -0
  46. package/lib/contracts/types/generated/factories/GNSTrading__factory.js +1071 -0
  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/GTokenV6_3_2__factory.d.ts +110 -110
  50. package/lib/contracts/types/generated/factories/GTokenV6_3_2__factory.js +2682 -2682
  51. package/lib/contracts/types/generated/factories/index.d.ts +10 -9
  52. package/lib/contracts/types/generated/factories/index.js +26 -24
  53. package/lib/contracts/types/generated/index.d.ts +21 -19
  54. package/lib/contracts/types/generated/index.js +47 -45
  55. package/lib/contracts/types/index.d.ts +27 -23
  56. package/lib/contracts/types/index.js +10 -2
  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 +186 -172
  65. package/lib/contracts/utils/pairs.d.ts +6 -7
  66. package/lib/contracts/utils/pairs.js +94 -115
  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 +2 -2
  74. package/lib/markets/forex.js +38 -38
  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 +3 -16
  88. package/lib/trade/fees/index.js +29 -60
  89. package/lib/trade/index.d.ts +8 -8
  90. package/lib/trade/index.js +24 -24
  91. package/lib/trade/liquidation.d.ts +7 -7
  92. package/lib/trade/liquidation.js +16 -18
  93. package/lib/trade/oiWindows.d.ts +3 -3
  94. package/lib/trade/oiWindows.js +20 -19
  95. package/lib/trade/openLimitOrder.d.ts +2 -2
  96. package/lib/trade/openLimitOrder.js +23 -24
  97. package/lib/trade/pnl.d.ts +9 -9
  98. package/lib/trade/pnl.js +33 -44
  99. package/lib/trade/spread.d.ts +2 -3
  100. package/lib/trade/spread.js +22 -32
  101. package/lib/trade/types.d.ts +178 -185
  102. package/lib/trade/types.js +14 -14
  103. package/lib/utils/index.d.ts +1 -1
  104. package/lib/utils/index.js +17 -17
  105. package/lib/utils/packing.d.ts +2 -2
  106. package/lib/utils/packing.js +39 -39
  107. package/lib/vault/index.d.ts +8 -7
  108. package/lib/vault/index.js +10 -11
  109. package/package.json +104 -104
  110. package/lib/contracts/types/generated/GNSBorrowingFeesV6_4.d.ts +0 -1058
  111. package/lib/contracts/types/generated/GNSPairInfosV6_1.d.ts +0 -911
  112. package/lib/contracts/types/generated/GNSPairsStorageV6.d.ts +0 -660
  113. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_4__factory.d.ts +0 -113
  114. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_4__factory.js +0 -1742
  115. package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.d.ts +0 -98
  116. package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.js +0 -1485
  117. package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.d.ts +0 -117
  118. package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.js +0 -1265
  119. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_4__factory.d.ts +0 -82
  120. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_4__factory.js +0 -1326
  121. package/lib/trade/fees.d.ts +0 -15
  122. package/lib/trade/fees.js +0 -45
@@ -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,172 +1,186 @@
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
- return rawTrades.map(rawTrade => _prepareTradeContainer(rawTrade.trade, rawTrade.tradeInfo, rawTrade.initialAccFees));
20
- });
21
- exports.fetchOpenPairTrades = fetchOpenPairTrades;
22
- const fetchOpenPairTradesRaw = (contracts, overrides = {}) => __awaiter(void 0, void 0, void 0, function* () {
23
- if (!contracts) {
24
- return [];
25
- }
26
- const { pairBatchSize = 10, useMulticall = false, blockTag = "latest", } = overrides;
27
- const { gnsPairsStorageV6: pairsStorageContract } = contracts;
28
- try {
29
- const totalPairIndexes = (yield pairsStorageContract.pairsCount({ blockTag })).toNumber() - 1;
30
- let allOpenPairTrades = [];
31
- for (let batchStartPairIndex = 0; batchStartPairIndex < totalPairIndexes; batchStartPairIndex += pairBatchSize) {
32
- const batchEndPairIndex = Math.min(batchStartPairIndex + pairBatchSize - 1, totalPairIndexes);
33
- const openPairTradesBatch = useMulticall
34
- ? yield fetchOpenPairTradesBatchMulticall(contracts, batchStartPairIndex, batchEndPairIndex, blockTag)
35
- : yield fetchOpenPairTradesBatch(contracts, batchStartPairIndex, batchEndPairIndex);
36
- allOpenPairTrades = allOpenPairTrades.concat(openPairTradesBatch);
37
- }
38
- return allOpenPairTrades;
39
- }
40
- catch (error) {
41
- console.error(`Unexpected error while fetching open pair trades!`);
42
- throw error;
43
- }
44
- });
45
- exports.fetchOpenPairTradesRaw = fetchOpenPairTradesRaw;
46
- const fetchOpenPairTradesBatch = (contracts, startPairIndex, endPairIndex) => __awaiter(void 0, void 0, void 0, function* () {
47
- const { gfarmTradingStorageV5: storageContract, gnsBorrowingFees: borrowingFeesContract, } = contracts;
48
- const maxTradesPerPair = (yield storageContract.maxTradesPerPair()).toNumber();
49
- const pairIndexesToFetch = Array.from({ length: endPairIndex - startPairIndex + 1 }, (_, i) => i + startPairIndex);
50
- const rawTrades = yield Promise.all(pairIndexesToFetch.map((pairIndex) => __awaiter(void 0, void 0, void 0, function* () {
51
- const pairTraderAddresses = yield storageContract.pairTradersArray(pairIndex);
52
- if (pairTraderAddresses.length === 0) {
53
- return [];
54
- }
55
- const openTradesForPairTraders = yield Promise.all(pairTraderAddresses.map((pairTraderAddress) => __awaiter(void 0, void 0, void 0, function* () {
56
- const openTradesCalls = new Array(maxTradesPerPair);
57
- for (let pairTradeIndex = 0; pairTradeIndex < maxTradesPerPair; pairTradeIndex++) {
58
- openTradesCalls[pairTradeIndex] = storageContract.openTrades(pairTraderAddress, pairIndex, pairTradeIndex);
59
- }
60
- const openTradesForTraderAddress = yield Promise.all(openTradesCalls);
61
- // Filter out any of the trades that aren't *really* open (NOTE: these will have an empty trader address, so just test against that)
62
- const actualOpenTradesForTrader = openTradesForTraderAddress.filter(openTrade => openTrade.trader === pairTraderAddress);
63
- const [actualOpenTradesTradeInfos, actualOpenTradesInitialAccFees] = yield Promise.all([
64
- Promise.all(actualOpenTradesForTrader.map(aot => storageContract.openTradesInfo(aot.trader, aot.pairIndex, aot.index))),
65
- Promise.all(actualOpenTradesForTrader.map(aot => borrowingFeesContract.getTradeInitialAccFees(aot.trader, aot.pairIndex, aot.index))),
66
- ]);
67
- const finalOpenTradesForTrader = new Array(actualOpenTradesForTrader.length);
68
- for (let tradeIndex = 0; tradeIndex < actualOpenTradesForTrader.length; tradeIndex++) {
69
- const tradeInfo = actualOpenTradesTradeInfos[tradeIndex];
70
- if (tradeInfo === undefined) {
71
- continue;
72
- }
73
- if (actualOpenTradesInitialAccFees[tradeIndex] === undefined) {
74
- continue;
75
- }
76
- const tradeInitialAccFees = Object.assign(Object.assign({}, actualOpenTradesInitialAccFees[tradeIndex].otherFees), { borrowing: actualOpenTradesInitialAccFees[tradeIndex].borrowingFees });
77
- const trade = actualOpenTradesForTrader[tradeIndex];
78
- finalOpenTradesForTrader[tradeIndex] = {
79
- trade,
80
- tradeInfo,
81
- initialAccFees: tradeInitialAccFees,
82
- };
83
- }
84
- return finalOpenTradesForTrader;
85
- })));
86
- return openTradesForPairTraders;
87
- })));
88
- const perPairTrades = rawTrades.reduce((a, b) => a.concat(b), []);
89
- return perPairTrades.reduce((a, b) => a.concat(b), []);
90
- });
91
- const fetchOpenPairTradesBatchMulticall = (contracts, startPairIndex, endPairIndex, blockTag) => __awaiter(void 0, void 0, void 0, function* () {
92
- const { gfarmTradingStorageV5: storageContract, gnsBorrowingFees: borrowingFeesContract, } = contracts;
93
- // Convert to Multicall for efficient RPC usage
94
- const multicallProvider = new ethcall_1.Provider();
95
- yield multicallProvider.init(storageContract.provider);
96
- const storageContractMulticall = new ethcall_1.Contract(storageContract.address, [
97
- ...storageContract.interface.fragments,
98
- ]);
99
- const borrowingFeesContractMulticall = new ethcall_1.Contract(borrowingFeesContract.address, [...borrowingFeesContract.interface.fragments]);
100
- const maxTradesPerPair = (yield storageContract.maxTradesPerPair()).toNumber();
101
- const pairIndexesToFetch = Array.from({ length: endPairIndex - startPairIndex + 1 }, (_, i) => i + startPairIndex);
102
- const mcPairTraderAddresses = yield multicallProvider.all(pairIndexesToFetch.map(pairIndex => storageContractMulticall.pairTradersArray(pairIndex)), blockTag);
103
- const mcFlatOpenTrades = yield multicallProvider.all(mcPairTraderAddresses
104
- .map((pairTraderAddresses, _ix) => {
105
- return pairTraderAddresses
106
- .map((pairTraderAddress) => {
107
- const openTradesCalls = new Array(maxTradesPerPair);
108
- for (let pairTradeIndex = 0; pairTradeIndex < maxTradesPerPair; pairTradeIndex++) {
109
- openTradesCalls[pairTradeIndex] =
110
- storageContractMulticall.openTrades(pairTraderAddress, _ix + startPairIndex, pairTradeIndex);
111
- }
112
- return openTradesCalls;
113
- })
114
- .reduce((acc, val) => acc.concat(val), []);
115
- })
116
- .reduce((acc, val) => acc.concat(val), []), blockTag);
117
- const openTrades = mcFlatOpenTrades.filter(openTrade => openTrade[0] !== "0x0000000000000000000000000000000000000000");
118
- const [openTradesTradeInfos, openTradesInitialAccFees] = yield Promise.all([
119
- multicallProvider.all(openTrades.map(openTrade => storageContractMulticall.openTradesInfo(openTrade.trader, openTrade.pairIndex, openTrade.index)), blockTag),
120
- multicallProvider.all(openTrades.map(openTrade => borrowingFeesContractMulticall.getTradeInitialAccFees(openTrade.trader, openTrade.pairIndex, openTrade.index)), blockTag),
121
- ]);
122
- const finalTrades = new Array(openTrades.length);
123
- for (let tradeIndex = 0; tradeIndex < openTradesTradeInfos.length; tradeIndex++) {
124
- const tradeInfo = openTradesTradeInfos[tradeIndex];
125
- if (tradeInfo === undefined) {
126
- console.error("No trade info found for open trade while fetching open trades!", { trade: openTradesTradeInfos[tradeIndex] });
127
- continue;
128
- }
129
- if (openTradesInitialAccFees[tradeIndex] === undefined) {
130
- console.error("No initial fees found for open trade while fetching open trades!", { trade: openTrades[tradeIndex] });
131
- continue;
132
- }
133
- const tradeInitialAccFees = Object.assign(Object.assign({}, openTradesInitialAccFees[tradeIndex].otherFees), { borrowing: openTradesInitialAccFees[tradeIndex].borrowingFees });
134
- const trade = openTrades[tradeIndex];
135
- finalTrades[tradeIndex] = {
136
- trade,
137
- tradeInfo,
138
- initialAccFees: tradeInitialAccFees,
139
- };
140
- }
141
- return finalTrades.filter(trade => trade !== undefined);
142
- });
143
- const _prepareTradeContainer = (trade, tradeInfo, tradeInitialAccFees) => ({
144
- trade: {
145
- trader: trade.trader,
146
- pairIndex: parseInt(trade.pairIndex.toString()),
147
- index: parseInt(trade.index.toString()),
148
- initialPosToken: parseFloat(trade.initialPosToken.toString()) / 1e18,
149
- openPrice: parseFloat(trade.openPrice.toString()) / 1e10,
150
- buy: trade.buy.toString() === "true",
151
- leverage: parseInt(trade.leverage.toString()),
152
- tp: parseFloat(trade.tp.toString()) / 1e10,
153
- sl: parseFloat(trade.sl.toString()) / 1e10,
154
- },
155
- tradeInfo: {
156
- beingMarketClosed: tradeInfo.beingMarketClosed.toString() === "true",
157
- tokenPriceDai: parseFloat(tradeInfo.tokenPriceDai.toString()) / 1e10,
158
- openInterestDai: parseFloat(tradeInfo.openInterestDai.toString()) / 1e18,
159
- tpLastUpdated: tradeInfo.tpLastUpdated,
160
- slLastUpdated: tradeInfo.slLastUpdated,
161
- },
162
- initialAccFees: {
163
- rollover: parseFloat(tradeInitialAccFees.rollover.toString()) / 1e18,
164
- funding: parseFloat(tradeInitialAccFees.funding.toString()) / 1e18,
165
- openedAfterUpdate: tradeInitialAccFees.openedAfterUpdate.toString() === "true",
166
- borrowing: {
167
- accPairFee: parseFloat(tradeInitialAccFees.borrowing.accPairFee.toString()) / 1e10,
168
- accGroupFee: parseFloat(tradeInitialAccFees.borrowing.accGroupFee.toString()) / 1e10,
169
- block: parseFloat(tradeInitialAccFees.borrowing.block.toString()),
170
- },
171
- },
172
- });
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
+ return rawTrades.map(rawTrade => _prepareTradeContainer(rawTrade.trade, rawTrade.tradeInfo, rawTrade.initialAccFees, rawTrade.tradeData));
20
+ });
21
+ exports.fetchOpenPairTrades = fetchOpenPairTrades;
22
+ const fetchOpenPairTradesRaw = (contracts, overrides = {}) => __awaiter(void 0, void 0, void 0, function* () {
23
+ if (!contracts) {
24
+ return [];
25
+ }
26
+ const { pairBatchSize = 10, useMulticall = false, blockTag = "latest", } = overrides;
27
+ const { gnsMultiCollatDiamond: multiCollatDiamondContract } = contracts;
28
+ try {
29
+ const totalPairIndexes = (yield multiCollatDiamondContract.pairsCount({ blockTag })).toNumber() -
30
+ 1;
31
+ let allOpenPairTrades = [];
32
+ for (let batchStartPairIndex = 0; batchStartPairIndex < totalPairIndexes; batchStartPairIndex += pairBatchSize) {
33
+ const batchEndPairIndex = Math.min(batchStartPairIndex + pairBatchSize - 1, totalPairIndexes);
34
+ const openPairTradesBatch = useMulticall
35
+ ? yield fetchOpenPairTradesBatchMulticall(contracts, batchStartPairIndex, batchEndPairIndex, blockTag)
36
+ : yield fetchOpenPairTradesBatch(contracts, batchStartPairIndex, batchEndPairIndex);
37
+ allOpenPairTrades = allOpenPairTrades.concat(openPairTradesBatch);
38
+ }
39
+ return allOpenPairTrades;
40
+ }
41
+ catch (error) {
42
+ console.error(`Unexpected error while fetching open pair trades!`);
43
+ throw error;
44
+ }
45
+ });
46
+ exports.fetchOpenPairTradesRaw = fetchOpenPairTradesRaw;
47
+ const fetchOpenPairTradesBatch = (contracts, startPairIndex, endPairIndex) => __awaiter(void 0, void 0, void 0, function* () {
48
+ const { gfarmTradingStorageV5: storageContract, gnsBorrowingFees: borrowingFeesContract, gnsTradingCallbacks: callbacksContract, } = contracts;
49
+ const maxTradesPerPair = (yield storageContract.maxTradesPerPair()).toNumber();
50
+ const pairIndexesToFetch = Array.from({ length: endPairIndex - startPairIndex + 1 }, (_, i) => i + startPairIndex);
51
+ const rawTrades = yield Promise.all(pairIndexesToFetch.map((pairIndex) => __awaiter(void 0, void 0, void 0, function* () {
52
+ const pairTraderAddresses = yield storageContract.pairTradersArray(pairIndex);
53
+ if (pairTraderAddresses.length === 0) {
54
+ return [];
55
+ }
56
+ const openTradesForPairTraders = yield Promise.all(pairTraderAddresses.map((pairTraderAddress) => __awaiter(void 0, void 0, void 0, function* () {
57
+ const openTradesCalls = new Array(maxTradesPerPair);
58
+ for (let pairTradeIndex = 0; pairTradeIndex < maxTradesPerPair; pairTradeIndex++) {
59
+ openTradesCalls[pairTradeIndex] = storageContract.openTrades(pairTraderAddress, pairIndex, pairTradeIndex);
60
+ }
61
+ const openTradesForTraderAddress = yield Promise.all(openTradesCalls);
62
+ // Filter out any of the trades that aren't *really* open (NOTE: these will have an empty trader address, so just test against that)
63
+ const actualOpenTradesForTrader = openTradesForTraderAddress.filter(openTrade => openTrade.trader === pairTraderAddress);
64
+ const [actualOpenTradesTradeInfos, actualOpenTradesInitialAccFees, actualOpenTradesTradeData,] = yield Promise.all([
65
+ Promise.all(actualOpenTradesForTrader.map(aot => storageContract.openTradesInfo(aot.trader, aot.pairIndex, aot.index))),
66
+ Promise.all(actualOpenTradesForTrader.map(aot => borrowingFeesContract.initialAccFees(aot.trader, aot.pairIndex, aot.index))),
67
+ Promise.all(actualOpenTradesForTrader.map(aot => callbacksContract.tradeData(aot.trader, aot.pairIndex, aot.index, 0))),
68
+ ]);
69
+ const finalOpenTradesForTrader = new Array(actualOpenTradesForTrader.length);
70
+ for (let tradeIndex = 0; tradeIndex < actualOpenTradesForTrader.length; tradeIndex++) {
71
+ const tradeInfo = actualOpenTradesTradeInfos[tradeIndex];
72
+ if (tradeInfo === undefined) {
73
+ continue;
74
+ }
75
+ if (actualOpenTradesInitialAccFees[tradeIndex] === undefined) {
76
+ continue;
77
+ }
78
+ const trade = actualOpenTradesForTrader[tradeIndex];
79
+ const tradeData = actualOpenTradesTradeData[tradeIndex];
80
+ finalOpenTradesForTrader[tradeIndex] = {
81
+ trade,
82
+ tradeInfo,
83
+ initialAccFees: {
84
+ borrowing: actualOpenTradesInitialAccFees[tradeIndex],
85
+ },
86
+ tradeData,
87
+ };
88
+ }
89
+ return finalOpenTradesForTrader;
90
+ })));
91
+ return openTradesForPairTraders;
92
+ })));
93
+ const perPairTrades = rawTrades.reduce((a, b) => a.concat(b), []);
94
+ return perPairTrades.reduce((a, b) => a.concat(b), []);
95
+ });
96
+ const fetchOpenPairTradesBatchMulticall = (contracts, startPairIndex, endPairIndex, blockTag) => __awaiter(void 0, void 0, void 0, function* () {
97
+ const { gfarmTradingStorageV5: storageContract, gnsBorrowingFees: borrowingFeesContract, gnsTradingCallbacks: callbacksContract, } = contracts;
98
+ // Convert to Multicall for efficient RPC usage
99
+ const multicallProvider = new ethcall_1.Provider();
100
+ yield multicallProvider.init(storageContract.provider);
101
+ const storageContractMulticall = new ethcall_1.Contract(storageContract.address, [
102
+ ...storageContract.interface.fragments,
103
+ ]);
104
+ const borrowingFeesContractMulticall = new ethcall_1.Contract(borrowingFeesContract.address, [...borrowingFeesContract.interface.fragments]);
105
+ const callbacksContractMulticall = new ethcall_1.Contract(callbacksContract.address, [
106
+ ...callbacksContract.interface.fragments,
107
+ ]);
108
+ const maxTradesPerPair = (yield storageContract.maxTradesPerPair()).toNumber();
109
+ const pairIndexesToFetch = Array.from({ length: endPairIndex - startPairIndex + 1 }, (_, i) => i + startPairIndex);
110
+ const mcPairTraderAddresses = yield multicallProvider.all(pairIndexesToFetch.map(pairIndex => storageContractMulticall.pairTradersArray(pairIndex)), blockTag);
111
+ const mcFlatOpenTrades = yield multicallProvider.all(mcPairTraderAddresses
112
+ .map((pairTraderAddresses, _ix) => {
113
+ return pairTraderAddresses
114
+ .map((pairTraderAddress) => {
115
+ const openTradesCalls = new Array(maxTradesPerPair);
116
+ for (let pairTradeIndex = 0; pairTradeIndex < maxTradesPerPair; pairTradeIndex++) {
117
+ openTradesCalls[pairTradeIndex] =
118
+ storageContractMulticall.openTrades(pairTraderAddress, _ix + startPairIndex, pairTradeIndex);
119
+ }
120
+ return openTradesCalls;
121
+ })
122
+ .reduce((acc, val) => acc.concat(val), []);
123
+ })
124
+ .reduce((acc, val) => acc.concat(val), []), blockTag);
125
+ const openTrades = mcFlatOpenTrades.filter(openTrade => openTrade[0] !== "0x0000000000000000000000000000000000000000");
126
+ const [openTradesTradeInfos, openTradesInitialAccFees, openTradesTradeData] = yield Promise.all([
127
+ multicallProvider.all(openTrades.map(openTrade => storageContractMulticall.openTradesInfo(openTrade.trader, openTrade.pairIndex, openTrade.index)), blockTag),
128
+ multicallProvider.all(openTrades.map(openTrade => borrowingFeesContractMulticall.initialAccFees(openTrade.trader, openTrade.pairIndex, openTrade.index)), blockTag),
129
+ multicallProvider.all(openTrades.map(openTrade => callbacksContractMulticall.tradeData(openTrade.trader, openTrade.pairIndex, openTrade.index, 0)), blockTag),
130
+ ]);
131
+ const finalTrades = new Array(openTrades.length);
132
+ for (let tradeIndex = 0; tradeIndex < openTradesTradeInfos.length; tradeIndex++) {
133
+ const tradeInfo = openTradesTradeInfos[tradeIndex];
134
+ if (tradeInfo === undefined) {
135
+ console.error("No trade info found for open trade while fetching open trades!", { trade: openTradesTradeInfos[tradeIndex] });
136
+ continue;
137
+ }
138
+ if (openTradesInitialAccFees[tradeIndex] === undefined) {
139
+ console.error("No initial fees found for open trade while fetching open trades!", { trade: openTrades[tradeIndex] });
140
+ continue;
141
+ }
142
+ const trade = openTrades[tradeIndex];
143
+ const tradeData = openTradesTradeData[tradeIndex];
144
+ finalTrades[tradeIndex] = {
145
+ trade,
146
+ tradeInfo,
147
+ initialAccFees: {
148
+ borrowing: openTradesInitialAccFees[tradeIndex],
149
+ },
150
+ tradeData,
151
+ };
152
+ }
153
+ return finalTrades.filter(trade => trade !== undefined);
154
+ });
155
+ const _prepareTradeContainer = (trade, tradeInfo, tradeInitialAccFees, tradeData) => ({
156
+ trade: {
157
+ trader: trade.trader,
158
+ pairIndex: parseInt(trade.pairIndex.toString()),
159
+ index: parseInt(trade.index.toString()),
160
+ initialPosToken: parseFloat(trade.initialPosToken.toString()) / 1e18,
161
+ openPrice: parseFloat(trade.openPrice.toString()) / 1e10,
162
+ buy: trade.buy.toString() === "true",
163
+ leverage: parseInt(trade.leverage.toString()),
164
+ tp: parseFloat(trade.tp.toString()) / 1e10,
165
+ sl: parseFloat(trade.sl.toString()) / 1e10,
166
+ },
167
+ tradeInfo: {
168
+ beingMarketClosed: tradeInfo.beingMarketClosed.toString() === "true",
169
+ tokenPriceDai: parseFloat(tradeInfo.tokenPriceDai.toString()) / 1e10,
170
+ openInterestDai: parseFloat(tradeInfo.openInterestDai.toString()) / 1e18,
171
+ tpLastUpdated: tradeInfo.tpLastUpdated,
172
+ slLastUpdated: tradeInfo.slLastUpdated,
173
+ },
174
+ tradeData: {
175
+ maxSlippageP: parseFloat(tradeData.maxSlippageP.toString()) / 1e10,
176
+ lastOiUpdateTs: parseFloat(tradeData.lastOiUpdateTs),
177
+ collateralPriceUsd: parseFloat(tradeData.collateralPriceUsd.toString()) / 1e8,
178
+ },
179
+ initialAccFees: {
180
+ borrowing: {
181
+ accPairFee: parseFloat(tradeInitialAccFees.borrowing.accPairFee.toString()) / 1e10,
182
+ accGroupFee: parseFloat(tradeInitialAccFees.borrowing.accGroupFee.toString()) / 1e10,
183
+ block: parseFloat(tradeInitialAccFees.borrowing.block.toString()),
184
+ },
185
+ },
186
+ });
@@ -1,7 +1,6 @@
1
- import { Pair, PairParams, PairRolloverFees, Fee, OpenInterest } from "@/trade/types";
2
- import { Contracts } from "@/contracts/types";
3
- export declare const fetchPairs: (contracts: Contracts, pairIxs: number[]) => Promise<Pair[]>;
4
- export declare const fetchPairsParams: (contracts: Contracts, pairIxs: number[]) => Promise<PairParams[]>;
5
- export declare const fetchPairsRolloverFees: (contracts: Contracts, pairIxs: number[]) => Promise<PairRolloverFees[]>;
6
- export declare const fetchFees: (contracts: Contracts, feeIxs: number[]) => Promise<Fee[]>;
7
- export declare const fetchOpenInterest: (contracts: Contracts, pairIxs: number[]) => Promise<OpenInterest[]>;
1
+ import { Pair, Fee, OpenInterest, PairDepth } from "@/trade/types";
2
+ import { Contracts } from "@/contracts/types";
3
+ export declare const fetchPairs: (contracts: Contracts, pairIxs: number[]) => Promise<Pair[]>;
4
+ export declare const fetchPairDepths: (contracts: Contracts, pairIxs: number[]) => Promise<PairDepth[]>;
5
+ export declare const fetchFees: (contracts: Contracts, feeIxs: number[]) => Promise<Fee[]>;
6
+ export declare const fetchOpenInterest: (contracts: Contracts, pairIxs: number[]) => Promise<OpenInterest[]>;
@@ -1,115 +1,94 @@
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.fetchOpenInterest = exports.fetchFees = exports.fetchPairsRolloverFees = exports.fetchPairsParams = exports.fetchPairs = void 0;
13
- const fetchPairs = (contracts, pairIxs) => __awaiter(void 0, void 0, void 0, function* () {
14
- if (!contracts) {
15
- return [];
16
- }
17
- const { gnsPairsStorageV6: pairsStorageContract } = contracts;
18
- try {
19
- const pairs = yield Promise.all(pairIxs.map(pairIndex => pairsStorageContract.pairs(pairIndex)));
20
- return pairs.map((pair, index) => {
21
- return {
22
- name: pair.from + "/" + pair.to,
23
- from: pair.from,
24
- to: pair.to,
25
- feeIndex: parseInt(pair.feeIndex.toString()),
26
- groupIndex: parseInt(pair.groupIndex.toString()),
27
- pairIndex: pairIxs[index],
28
- spreadP: parseFloat(pair.spreadP.toString()) / 1e12,
29
- };
30
- });
31
- }
32
- catch (error) {
33
- console.error(`Unexpected error while fetching pairs!`);
34
- throw error;
35
- }
36
- });
37
- exports.fetchPairs = fetchPairs;
38
- const fetchPairsParams = (contracts, pairIxs) => __awaiter(void 0, void 0, void 0, function* () {
39
- if (!contracts) {
40
- return [];
41
- }
42
- const { gnsPairInfosV6_1: pairInfosContract } = contracts;
43
- try {
44
- const pairParams = yield Promise.all(pairIxs.map(pairIndex => pairInfosContract.pairParams(pairIndex)));
45
- return pairParams.map(pair => {
46
- return {
47
- onePercentDepthAbove: parseFloat(pair.onePercentDepthAbove.toString()),
48
- onePercentDepthBelow: parseFloat(pair.onePercentDepthBelow.toString()),
49
- rolloverFeePerBlockP: parseFloat(pair.rolloverFeePerBlockP.toString()) / 1e12,
50
- fundingFeePerBlockP: parseFloat(pair.fundingFeePerBlockP.toString()) / 1e12,
51
- };
52
- });
53
- }
54
- catch (error) {
55
- console.error(`Unexpected error while fetching pairs!`);
56
- throw error;
57
- }
58
- });
59
- exports.fetchPairsParams = fetchPairsParams;
60
- const fetchPairsRolloverFees = (contracts, pairIxs) => __awaiter(void 0, void 0, void 0, function* () {
61
- if (!contracts) {
62
- return [];
63
- }
64
- const { gnsPairInfosV6_1: pairInfosContract } = contracts;
65
- try {
66
- const pairsRolloverFees = yield Promise.all(pairIxs.map(pairIndex => pairInfosContract.pairRolloverFees(pairIndex)));
67
- return pairsRolloverFees.map(pairData => {
68
- return {
69
- accPerCollateral: parseFloat(pairData.accPerCollateral.toString()) / 1e18,
70
- lastUpdateBlock: parseInt(pairData.lastUpdateBlock.toString()),
71
- };
72
- });
73
- }
74
- catch (error) {
75
- console.error(`Unexpected error while fetching pairs!`);
76
- throw error;
77
- }
78
- });
79
- exports.fetchPairsRolloverFees = fetchPairsRolloverFees;
80
- const fetchFees = (contracts, feeIxs) => __awaiter(void 0, void 0, void 0, function* () {
81
- if (!contracts) {
82
- return [];
83
- }
84
- const { gnsPairsStorageV6: pairsStorageContract } = contracts;
85
- try {
86
- const fees = yield Promise.all(feeIxs.map(pairIndex => pairsStorageContract.fees(pairIndex)));
87
- return fees.map(fee => {
88
- return {
89
- closeFeeP: parseFloat(fee.closeFeeP.toString()) / 1e12,
90
- minLevPosDai: parseFloat(fee.minLevPosDai.toString()) / 1e12,
91
- nftLimitOrderFeeP: parseFloat(fee.nftLimitOrderFeeP.toString()) / 1e12,
92
- openFeeP: parseFloat(fee.openFeeP.toString()) / 1e12,
93
- referralFeeP: parseFloat(fee.referralFeeP.toString()) / 1e12,
94
- };
95
- });
96
- }
97
- catch (error) {
98
- console.error(`Unexpected error while fetching pairs!`);
99
- throw error;
100
- }
101
- });
102
- exports.fetchFees = fetchFees;
103
- const fetchOpenInterest = (contracts, pairIxs) => __awaiter(void 0, void 0, void 0, function* () {
104
- const openInterests = yield Promise.all(pairIxs.map(pairIndex => Promise.all([
105
- contracts.gfarmTradingStorageV5.openInterestDai(pairIndex, 0),
106
- contracts.gfarmTradingStorageV5.openInterestDai(pairIndex, 1),
107
- contracts.gnsBorrowingFees.getPairMaxOi(pairIndex),
108
- ])));
109
- return openInterests.map(openInterest => ({
110
- long: parseFloat(openInterest[0].toString()) / 1e18,
111
- short: parseFloat(openInterest[1].toString()) / 1e18,
112
- max: parseFloat(openInterest[2].toString()) / 1e10,
113
- }));
114
- });
115
- exports.fetchOpenInterest = fetchOpenInterest;
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.fetchOpenInterest = exports.fetchFees = exports.fetchPairDepths = exports.fetchPairs = void 0;
13
+ const fetchPairs = (contracts, pairIxs) => __awaiter(void 0, void 0, void 0, function* () {
14
+ if (!contracts) {
15
+ return [];
16
+ }
17
+ const { gnsMultiCollatDiamond: multiCollatContract } = contracts;
18
+ try {
19
+ const pairs = yield Promise.all(pairIxs.map(pairIndex => multiCollatContract.pairs(pairIndex)));
20
+ return pairs.map((pair, index) => {
21
+ return {
22
+ name: pair.from + "/" + pair.to,
23
+ from: pair.from,
24
+ to: pair.to,
25
+ feeIndex: parseInt(pair.feeIndex.toString()),
26
+ groupIndex: parseInt(pair.groupIndex.toString()),
27
+ pairIndex: pairIxs[index],
28
+ spreadP: parseFloat(pair.spreadP.toString()) / 1e12,
29
+ };
30
+ });
31
+ }
32
+ catch (error) {
33
+ console.error(`Unexpected error while fetching pairs!`);
34
+ throw error;
35
+ }
36
+ });
37
+ exports.fetchPairs = fetchPairs;
38
+ const fetchPairDepths = (contracts, pairIxs) => __awaiter(void 0, void 0, void 0, function* () {
39
+ if (!contracts) {
40
+ return [];
41
+ }
42
+ const { gnsMultiCollatDiamond: multiCollatContract } = contracts;
43
+ try {
44
+ const pairParams = yield multiCollatContract.getPairDepths(pairIxs);
45
+ return pairParams.map(pair => {
46
+ return {
47
+ onePercentDepthAboveUsd: parseFloat(pair.onePercentDepthAboveUsd.toString()),
48
+ onePercentDepthBelowUsd: parseFloat(pair.onePercentDepthBelowUsd.toString()),
49
+ };
50
+ });
51
+ }
52
+ catch (error) {
53
+ console.error(`Unexpected error while fetching pairs!`);
54
+ throw error;
55
+ }
56
+ });
57
+ exports.fetchPairDepths = fetchPairDepths;
58
+ const fetchFees = (contracts, feeIxs) => __awaiter(void 0, void 0, void 0, function* () {
59
+ if (!contracts) {
60
+ return [];
61
+ }
62
+ const { gnsMultiCollatDiamond: multiCollatContract } = contracts;
63
+ try {
64
+ const fees = yield Promise.all(feeIxs.map(pairIndex => multiCollatContract.fees(pairIndex)));
65
+ return fees.map(fee => {
66
+ return {
67
+ closeFeeP: parseFloat(fee.closeFeeP.toString()) / 1e12,
68
+ minLevPosUsd: parseFloat(fee.minLevPosUsd.toString()) / 1e18,
69
+ nftLimitOrderFeeP: parseFloat(fee.nftLimitOrderFeeP.toString()) / 1e12,
70
+ openFeeP: parseFloat(fee.openFeeP.toString()) / 1e12,
71
+ };
72
+ });
73
+ }
74
+ catch (error) {
75
+ console.error(`Unexpected error while fetching pairs!`);
76
+ throw error;
77
+ }
78
+ });
79
+ exports.fetchFees = fetchFees;
80
+ const fetchOpenInterest = (contracts, pairIxs) => __awaiter(void 0, void 0, void 0, function* () {
81
+ const { precision: collateralPrecision } = yield contracts.gnsBorrowingFees.collateralConfig();
82
+ const openInterests = yield Promise.all(pairIxs.map(pairIndex => Promise.all([
83
+ contracts.gfarmTradingStorageV5.openInterestDai(pairIndex, 0),
84
+ contracts.gfarmTradingStorageV5.openInterestDai(pairIndex, 1),
85
+ contracts.gnsBorrowingFees.getPairMaxOi(pairIndex),
86
+ ])));
87
+ const precision = parseFloat(collateralPrecision.toString());
88
+ return openInterests.map(openInterest => ({
89
+ long: parseFloat(openInterest[0].toString()) / precision,
90
+ short: parseFloat(openInterest[1].toString()) / precision,
91
+ max: parseFloat(openInterest[2].toString()) / 1e10,
92
+ }));
93
+ });
94
+ exports.fetchOpenInterest = fetchOpenInterest;