@gainsnetwork/sdk 0.2.67-rc8 → 0.2.69

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 (136) hide show
  1. package/lib/contracts/addresses.json +20 -0
  2. package/lib/{trade/fees/borrowingV2/fetcher.d.ts → contracts/fetch/fees/borrowingFeesV2.d.ts} +3 -2
  3. package/lib/{trade/fees/borrowingV2/fetcher.js → contracts/fetch/fees/borrowingFeesV2.js} +14 -6
  4. package/lib/{trade/fees/fundingFees/fetcher.d.ts → contracts/fetch/fees/fundingFees.d.ts} +2 -2
  5. package/lib/{trade/priceImpact/skew/fetcher.d.ts → contracts/fetch/priceImpact/skew.d.ts} +2 -2
  6. package/lib/{trade/priceImpact/skew/fetcher.js → contracts/fetch/priceImpact/skew.js} +6 -6
  7. package/lib/contracts/index.js +3 -1
  8. package/lib/contracts/types/generated/GNSMultiCollatDiamond.d.ts +258 -2112
  9. package/lib/contracts/types/generated/GToken.d.ts +107 -78
  10. package/lib/contracts/types/generated/factories/GNSMultiCollatDiamond__factory.d.ts +53 -90
  11. package/lib/contracts/types/generated/factories/GNSMultiCollatDiamond__factory.js +421 -4496
  12. package/lib/contracts/types/generated/factories/GToken__factory.js +142 -65
  13. package/lib/contracts/types/index.d.ts +2 -1
  14. package/lib/contracts/types/index.js +1 -0
  15. package/lib/trade/fees/borrowingV2/converter.d.ts +3 -12
  16. package/lib/trade/fees/borrowingV2/converter.js +18 -29
  17. package/lib/trade/fees/borrowingV2/index.d.ts +17 -6
  18. package/lib/trade/fees/borrowingV2/index.js +37 -10
  19. package/lib/trade/fees/borrowingV2/types.d.ts +6 -22
  20. package/lib/trade/fees/fundingFees/index.d.ts +2 -13
  21. package/lib/trade/fees/fundingFees/index.js +3 -27
  22. package/lib/trade/fees/trading/index.d.ts +2 -30
  23. package/lib/trade/fees/trading/index.js +1 -52
  24. package/lib/trade/fees/trading/types.d.ts +0 -9
  25. package/lib/trade/priceImpact/index.d.ts +2 -6
  26. package/lib/trade/priceImpact/index.js +3 -30
  27. package/lib/trade/priceImpact/skew/index.d.ts +0 -1
  28. package/lib/trade/priceImpact/skew/index.js +0 -4
  29. package/package.json +1 -1
  30. package/lib/backend/globalTrades/index.d.ts +0 -11
  31. package/lib/backend/globalTrades/index.js +0 -69
  32. package/lib/backend/index.d.ts +0 -3
  33. package/lib/backend/index.js +0 -28
  34. package/lib/backend/tradingVariables/backend.types.d.ts +0 -312
  35. package/lib/backend/tradingVariables/backend.types.js +0 -2
  36. package/lib/backend/tradingVariables/converter.d.ts +0 -31
  37. package/lib/backend/tradingVariables/converter.js +0 -330
  38. package/lib/backend/tradingVariables/index.d.ts +0 -5
  39. package/lib/backend/tradingVariables/index.js +0 -95
  40. package/lib/backend/tradingVariables/types.d.ts +0 -109
  41. package/lib/backend/tradingVariables/types.js +0 -14
  42. package/lib/contracts/types/generated/GFarmTradingStorageV5.d.ts +0 -1911
  43. package/lib/contracts/types/generated/GFarmTradingStorageV5.js +0 -2
  44. package/lib/contracts/types/generated/GNSBorrowingFees.d.ts +0 -1067
  45. package/lib/contracts/types/generated/GNSBorrowingFees.js +0 -2
  46. package/lib/contracts/types/generated/GNSNftRewardsV6.d.ts +0 -533
  47. package/lib/contracts/types/generated/GNSNftRewardsV6.js +0 -2
  48. package/lib/contracts/types/generated/GNSNftRewardsV6_3_1.d.ts +0 -613
  49. package/lib/contracts/types/generated/GNSNftRewardsV6_3_1.js +0 -2
  50. package/lib/contracts/types/generated/GNSTrading.d.ts +0 -758
  51. package/lib/contracts/types/generated/GNSTrading.js +0 -2
  52. package/lib/contracts/types/generated/GNSTradingCallbacks.d.ts +0 -875
  53. package/lib/contracts/types/generated/GNSTradingCallbacks.js +0 -2
  54. package/lib/contracts/types/generated/GNSTradingStorage.d.ts +0 -1387
  55. package/lib/contracts/types/generated/GNSTradingStorage.js +0 -2
  56. package/lib/contracts/types/generated/GTokenV6_3_2.d.ts +0 -1838
  57. package/lib/contracts/types/generated/GTokenV6_3_2.js +0 -2
  58. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.d.ts +0 -83
  59. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.js +0 -2691
  60. package/lib/contracts/types/generated/factories/GNSBorrowingFees__factory.d.ts +0 -124
  61. package/lib/contracts/types/generated/factories/GNSBorrowingFees__factory.js +0 -1784
  62. package/lib/contracts/types/generated/factories/GNSNftRewardsV6_3_1__factory.d.ts +0 -100
  63. package/lib/contracts/types/generated/factories/GNSNftRewardsV6_3_1__factory.js +0 -1116
  64. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.d.ts +0 -100
  65. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.js +0 -1003
  66. package/lib/contracts/types/generated/factories/GNSTradingCallbacks__factory.d.ts +0 -113
  67. package/lib/contracts/types/generated/factories/GNSTradingCallbacks__factory.js +0 -1428
  68. package/lib/contracts/types/generated/factories/GNSTradingStorage__factory.d.ts +0 -96
  69. package/lib/contracts/types/generated/factories/GNSTradingStorage__factory.js +0 -2241
  70. package/lib/contracts/types/generated/factories/GNSTrading__factory.d.ts +0 -95
  71. package/lib/contracts/types/generated/factories/GNSTrading__factory.js +0 -1071
  72. package/lib/contracts/types/generated/factories/GTokenV6_3_2__factory.d.ts +0 -110
  73. package/lib/contracts/types/generated/factories/GTokenV6_3_2__factory.js +0 -2682
  74. package/lib/contracts/utils/openLimitOrders.d.ts +0 -8
  75. package/lib/contracts/utils/openLimitOrders.js +0 -88
  76. package/lib/markets/collateral/converter.d.ts +0 -5
  77. package/lib/markets/collateral/converter.js +0 -11
  78. package/lib/markets/collateral/index.d.ts +0 -1
  79. package/lib/markets/collateral/index.js +0 -17
  80. package/lib/markets/collateral/types.d.ts +0 -7
  81. package/lib/markets/collateral/types.js +0 -2
  82. package/lib/markets/oi/converter.d.ts +0 -63
  83. package/lib/markets/oi/converter.js +0 -103
  84. package/lib/markets/oi/fetcher.d.ts +0 -58
  85. package/lib/markets/oi/fetcher.js +0 -181
  86. package/lib/markets/oi/index.d.ts +0 -10
  87. package/lib/markets/oi/index.js +0 -37
  88. package/lib/markets/oi/types.d.ts +0 -82
  89. package/lib/markets/oi/types.js +0 -6
  90. package/lib/markets/oi/validation.d.ts +0 -80
  91. package/lib/markets/oi/validation.js +0 -172
  92. package/lib/trade/fees/borrowing/builder.d.ts +0 -14
  93. package/lib/trade/fees/borrowing/builder.js +0 -33
  94. package/lib/trade/fees/borrowingV2/builder.d.ts +0 -6
  95. package/lib/trade/fees/borrowingV2/builder.js +0 -24
  96. package/lib/trade/fees/converter.d.ts +0 -48
  97. package/lib/trade/fees/converter.js +0 -110
  98. package/lib/trade/fees/fundingFees/builder.d.ts +0 -9
  99. package/lib/trade/fees/fundingFees/builder.js +0 -35
  100. package/lib/trade/fees/fundingFees/pairContext.d.ts +0 -33
  101. package/lib/trade/fees/fundingFees/pairContext.js +0 -17
  102. package/lib/trade/fees/tiers/converter.d.ts +0 -54
  103. package/lib/trade/fees/tiers/converter.js +0 -81
  104. package/lib/trade/fees/trading/builder.d.ts +0 -18
  105. package/lib/trade/fees/trading/builder.js +0 -20
  106. package/lib/trade/liquidation/builder.d.ts +0 -25
  107. package/lib/trade/liquidation/builder.js +0 -59
  108. package/lib/trade/liquidation/converter.d.ts +0 -23
  109. package/lib/trade/liquidation/converter.js +0 -46
  110. package/lib/trade/liquidation/index.d.ts +0 -26
  111. package/lib/trade/liquidation/index.js +0 -142
  112. package/lib/trade/liquidation/types.d.ts +0 -59
  113. package/lib/trade/liquidation/types.js +0 -2
  114. package/lib/trade/openLimitOrder.d.ts +0 -2
  115. package/lib/trade/openLimitOrder.js +0 -23
  116. package/lib/trade/pnl/builder.d.ts +0 -16
  117. package/lib/trade/pnl/builder.js +0 -44
  118. package/lib/trade/pnl/converter.d.ts +0 -47
  119. package/lib/trade/pnl/converter.js +0 -72
  120. package/lib/trade/pnl/index.d.ts +0 -77
  121. package/lib/trade/pnl/index.js +0 -270
  122. package/lib/trade/pnl/types.d.ts +0 -114
  123. package/lib/trade/pnl/types.js +0 -5
  124. package/lib/trade/priceImpact/close/index.d.ts +0 -21
  125. package/lib/trade/priceImpact/close/index.js +0 -131
  126. package/lib/trade/priceImpact/close/types.d.ts +0 -43
  127. package/lib/trade/priceImpact/close/types.js +0 -5
  128. package/lib/trade/priceImpact/cumulVol/converter.d.ts +0 -31
  129. package/lib/trade/priceImpact/cumulVol/converter.js +0 -59
  130. package/lib/trade/priceImpact/cumulVol/index.d.ts +0 -107
  131. package/lib/trade/priceImpact/cumulVol/index.js +0 -228
  132. package/lib/trade/priceImpact/open/index.d.ts +0 -22
  133. package/lib/trade/priceImpact/open/index.js +0 -76
  134. package/lib/trade/priceImpact/open/types.d.ts +0 -41
  135. package/lib/trade/priceImpact/open/types.js +0 -5
  136. /package/lib/{trade/fees/fundingFees/fetcher.js → contracts/fetch/fees/fundingFees.js} +0 -0
@@ -1,8 +0,0 @@
1
- import { LimitOrder } from "@/trade/types";
2
- import { BlockTag, Contracts } from "../types";
3
- export type FetchOpenLimitOrdersOverrides = {
4
- blockTag?: BlockTag;
5
- useMulticall?: boolean;
6
- };
7
- export declare const fetchOpenLimitOrders: (contracts: Contracts, overrides?: FetchOpenLimitOrdersOverrides) => Promise<LimitOrder[]>;
8
- export declare const fetchOpenLimitOrdersRaw: (contracts: Contracts, overrides?: FetchOpenLimitOrdersOverrides) => Promise<any[]>;
@@ -1,88 +0,0 @@
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,5 +0,0 @@
1
- import { ITradingStorage } from "src/contracts/types/generated/GNSMultiCollatDiamond";
2
- import { CollateralConfig } from "./types";
3
- export declare const convertCollateralConfig: (collateral: ITradingStorage.CollateralStructOutput & {
4
- decimals: number;
5
- }) => CollateralConfig;
@@ -1,11 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.convertCollateralConfig = void 0;
4
- const convertCollateralConfig = (collateral) => ({
5
- collateral: collateral.collateral,
6
- isActive: collateral.isActive,
7
- precision: Number(collateral.precision),
8
- precisionDelta: Number(collateral.precisionDelta),
9
- decimals: collateral.decimals,
10
- });
11
- exports.convertCollateralConfig = convertCollateralConfig;
@@ -1 +0,0 @@
1
- export * from "./types";
@@ -1,17 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./types"), exports);
@@ -1,7 +0,0 @@
1
- export type CollateralConfig = {
2
- collateral: string;
3
- isActive: boolean;
4
- precision: number;
5
- precisionDelta: number;
6
- decimals?: number;
7
- };
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,63 +0,0 @@
1
- /**
2
- * @dev Converters for OI data between contract and SDK formats
3
- * @dev Handles the three OI storage systems and precision conversions
4
- */
5
- import { IBorrowingFees, IPriceImpact } from "../../contracts/types/generated/GNSMultiCollatDiamond";
6
- import { UnifiedPairOi, ComputedOi } from "./types";
7
- /**
8
- * @dev Converts pre-v10 OI from contract format
9
- * @param contractOi Contract OpenInterest struct from BorrowingFeesStorage
10
- * @param precision Collateral precision for conversion
11
- * @returns Normalized OI with long/short values
12
- */
13
- export declare const convertBeforeV10Collateral: (contractOi: IBorrowingFees.OpenInterestStructOutput, precision: number) => {
14
- long: number;
15
- short: number;
16
- };
17
- /**
18
- * @dev Converts post-v10 collateral OI from contract format
19
- * @param contractOi Contract PairOiCollateral struct
20
- * @param precision Collateral precision for conversion
21
- * @returns Normalized OI with long/short values
22
- */
23
- export declare const convertCollateralOi: (contractOi: IPriceImpact.PairOiCollateralStructOutput, precision: number) => {
24
- long: number;
25
- short: number;
26
- };
27
- /**
28
- * @dev Converts post-v10 token OI from contract format
29
- * @param contractOi Contract PairOiToken struct
30
- * @returns Normalized OI with long/short values (1e18 precision)
31
- */
32
- export declare const convertTokenOi: (contractOi: IPriceImpact.PairOiTokenStructOutput) => {
33
- long: number;
34
- short: number;
35
- };
36
- /**
37
- * @dev Converts all OI data for a pair into unified structure
38
- * @param beforeV10 Pre-v10 OI from BorrowingFeesStorage
39
- * @param afterV10Collateral Post-v10 collateral OI from PriceImpactStorage
40
- * @param afterV10Token Post-v10 token OI from PriceImpactStorage
41
- * @param maxOi Maximum OI allowed (from BorrowingFeesStorage)
42
- * @param collateralPrecision Precision for collateral conversions
43
- * @returns Unified PairOi structure
44
- */
45
- export declare const convertPairOi: (beforeV10: IBorrowingFees.OpenInterestStructOutput, afterV10Collateral: IPriceImpact.PairOiCollateralStructOutput, afterV10Token: IPriceImpact.PairOiTokenStructOutput, collateralPrecision: number) => UnifiedPairOi;
46
- /**
47
- * @dev Batch converter for multiple pairs
48
- * @param pairs Array of OI data for multiple pairs
49
- * @param collateralPrecision Precision for collateral conversions
50
- * @returns Array of unified PairOi structures
51
- */
52
- export declare const convertPairOiArray: (pairs: Array<{
53
- beforeV10: IBorrowingFees.OpenInterestStructOutput;
54
- collateral: IPriceImpact.PairOiCollateralStructOutput;
55
- token: IPriceImpact.PairOiTokenStructOutput;
56
- }>, collateralPrecision: number) => UnifiedPairOi[];
57
- /**
58
- * @dev Computes derived OI values from unified structure
59
- * @param pairOi Unified pair OI data
60
- * @param tokenPriceCollateral Current token price in collateral units
61
- * @returns Computed values including total OI and skew
62
- */
63
- export declare const computeOiValues: (pairOi: UnifiedPairOi, tokenPriceCollateral: number) => ComputedOi;
@@ -1,103 +0,0 @@
1
- "use strict";
2
- /**
3
- * @dev Converters for OI data between contract and SDK formats
4
- * @dev Handles the three OI storage systems and precision conversions
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.computeOiValues = exports.convertPairOiArray = exports.convertPairOi = exports.convertTokenOi = exports.convertCollateralOi = exports.convertBeforeV10Collateral = void 0;
8
- /**
9
- * @dev Converts pre-v10 OI from contract format
10
- * @param contractOi Contract OpenInterest struct from BorrowingFeesStorage
11
- * @param precision Collateral precision for conversion
12
- * @returns Normalized OI with long/short values
13
- */
14
- const convertBeforeV10Collateral = (contractOi, precision) => {
15
- return {
16
- long: Number(contractOi.long) / precision,
17
- short: Number(contractOi.short) / precision,
18
- };
19
- };
20
- exports.convertBeforeV10Collateral = convertBeforeV10Collateral;
21
- /**
22
- * @dev Converts post-v10 collateral OI from contract format
23
- * @param contractOi Contract PairOiCollateral struct
24
- * @param precision Collateral precision for conversion
25
- * @returns Normalized OI with long/short values
26
- */
27
- const convertCollateralOi = (contractOi, precision) => {
28
- return {
29
- long: Number(contractOi.oiLongCollateral) / precision,
30
- short: Number(contractOi.oiShortCollateral) / precision,
31
- };
32
- };
33
- exports.convertCollateralOi = convertCollateralOi;
34
- /**
35
- * @dev Converts post-v10 token OI from contract format
36
- * @param contractOi Contract PairOiToken struct
37
- * @returns Normalized OI with long/short values (1e18 precision)
38
- */
39
- const convertTokenOi = (contractOi) => {
40
- return {
41
- long: Number(contractOi.oiLongToken) / 1e18,
42
- short: Number(contractOi.oiShortToken) / 1e18,
43
- };
44
- };
45
- exports.convertTokenOi = convertTokenOi;
46
- /**
47
- * @dev Converts all OI data for a pair into unified structure
48
- * @param beforeV10 Pre-v10 OI from BorrowingFeesStorage
49
- * @param afterV10Collateral Post-v10 collateral OI from PriceImpactStorage
50
- * @param afterV10Token Post-v10 token OI from PriceImpactStorage
51
- * @param maxOi Maximum OI allowed (from BorrowingFeesStorage)
52
- * @param collateralPrecision Precision for collateral conversions
53
- * @returns Unified PairOi structure
54
- */
55
- const convertPairOi = (beforeV10, afterV10Collateral, afterV10Token, collateralPrecision) => {
56
- return {
57
- maxCollateral: Number(beforeV10.max) / collateralPrecision,
58
- beforeV10Collateral: (0, exports.convertBeforeV10Collateral)(beforeV10, collateralPrecision),
59
- collateral: (0, exports.convertCollateralOi)(afterV10Collateral, collateralPrecision),
60
- token: (0, exports.convertTokenOi)(afterV10Token),
61
- };
62
- };
63
- exports.convertPairOi = convertPairOi;
64
- /**
65
- * @dev Batch converter for multiple pairs
66
- * @param pairs Array of OI data for multiple pairs
67
- * @param collateralPrecision Precision for collateral conversions
68
- * @returns Array of unified PairOi structures
69
- */
70
- const convertPairOiArray = (pairs, collateralPrecision) => {
71
- return pairs.map(p => (0, exports.convertPairOi)(p.beforeV10, p.collateral, p.token, collateralPrecision));
72
- };
73
- exports.convertPairOiArray = convertPairOiArray;
74
- /**
75
- * @dev Computes derived OI values from unified structure
76
- * @param pairOi Unified pair OI data
77
- * @param tokenPriceCollateral Current token price in collateral units
78
- * @returns Computed values including total OI and skew
79
- */
80
- const computeOiValues = (pairOi, tokenPriceCollateral) => {
81
- // Static total (used for admin operations)
82
- const totalStaticLong = pairOi.beforeV10Collateral.long + pairOi.collateral.long;
83
- const totalStaticShort = pairOi.beforeV10Collateral.short + pairOi.collateral.short;
84
- // Dynamic total (used for real-time calculations)
85
- const tokenLongCollateral = pairOi.token.long * tokenPriceCollateral;
86
- const tokenShortCollateral = pairOi.token.short * tokenPriceCollateral;
87
- const totalDynamicLong = pairOi.beforeV10Collateral.long + tokenLongCollateral;
88
- const totalDynamicShort = pairOi.beforeV10Collateral.short + tokenShortCollateral;
89
- // Skew (v10+ only, in tokens)
90
- const skewToken = pairOi.token.long - pairOi.token.short;
91
- return {
92
- totalStaticCollateral: {
93
- long: totalStaticLong,
94
- short: totalStaticShort,
95
- },
96
- totalDynamicCollateral: {
97
- long: totalDynamicLong,
98
- short: totalDynamicShort,
99
- },
100
- skewToken,
101
- };
102
- };
103
- exports.computeOiValues = computeOiValues;
@@ -1,58 +0,0 @@
1
- /**
2
- * @dev Fetchers for retrieving OI data from contracts
3
- * @dev Consolidates the three OI storage systems into unified format
4
- */
5
- import { ethers } from "ethers";
6
- import { ChainId } from "../../contracts/types";
7
- import { UnifiedPairOi } from "./types";
8
- /**
9
- * @dev Fetches all OI data for a single pair
10
- * @param chainId Target chain
11
- * @param collateralIndex Collateral type
12
- * @param pairIndex Trading pair
13
- * @param signer Ethers signer
14
- * @returns Unified PairOi structure with all OI data
15
- */
16
- export declare function fetchPairOi(chainId: ChainId, collateralIndex: number, pairIndex: number, signer: ethers.Signer): Promise<UnifiedPairOi>;
17
- /**
18
- * @dev Fetches OI data for multiple pairs efficiently
19
- * @param chainId Target chain
20
- * @param collateralIndex Collateral type
21
- * @param pairIndices Array of trading pairs
22
- * @param signer Ethers signer
23
- * @returns Array of unified PairOi structures
24
- */
25
- export declare function fetchMultiplePairOi(chainId: ChainId, collateralIndex: number, pairIndices: number[], signer: ethers.Signer): Promise<UnifiedPairOi[]>;
26
- /**
27
- * @dev Creates OI context for fee calculations
28
- * @param chainId Target chain
29
- * @param collateralIndex Collateral type
30
- * @param pairIndex Trading pair
31
- * @param signer Ethers signer
32
- * @returns OI data formatted for SDK calculations
33
- */
34
- export declare function createOiContext(chainId: ChainId, collateralIndex: number, pairIndex: number, signer: ethers.Signer): Promise<{
35
- pairOi: UnifiedPairOi;
36
- currentPrice: number;
37
- computed: {
38
- totalDynamicOi: {
39
- long: number;
40
- short: number;
41
- };
42
- totalStaticOi: {
43
- long: number;
44
- short: number;
45
- };
46
- skew: number;
47
- };
48
- }>;
49
- /**
50
- * @dev Fetches only the OI data needed for specific use cases
51
- * @param chainId Target chain
52
- * @param collateralIndex Collateral type
53
- * @param pairIndex Trading pair
54
- * @param useCase Which OI systems to fetch
55
- * @param signer Ethers signer
56
- * @returns Partial OI data based on use case
57
- */
58
- export declare function fetchOiForUseCase(chainId: ChainId, collateralIndex: number, pairIndex: number, useCase: "skew" | "funding" | "borrowingV1" | "limits", signer: ethers.Signer): Promise<Partial<UnifiedPairOi>>;
@@ -1,181 +0,0 @@
1
- "use strict";
2
- /**
3
- * @dev Fetchers for retrieving OI data from contracts
4
- * @dev Consolidates the three OI storage systems into unified format
5
- */
6
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
7
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
8
- return new (P || (P = Promise))(function (resolve, reject) {
9
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
10
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
11
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
12
- step((generator = generator.apply(thisArg, _arguments || [])).next());
13
- });
14
- };
15
- Object.defineProperty(exports, "__esModule", { value: true });
16
- exports.fetchOiForUseCase = exports.createOiContext = exports.fetchMultiplePairOi = exports.fetchPairOi = void 0;
17
- const ethers_1 = require("ethers");
18
- const contracts_1 = require("../../contracts");
19
- const generated_1 = require("../../contracts/types/generated");
20
- const converter_1 = require("./converter");
21
- /**
22
- * @dev Fetches all OI data for a single pair
23
- * @param chainId Target chain
24
- * @param collateralIndex Collateral type
25
- * @param pairIndex Trading pair
26
- * @param signer Ethers signer
27
- * @returns Unified PairOi structure with all OI data
28
- */
29
- function fetchPairOi(chainId, collateralIndex, pairIndex, signer) {
30
- return __awaiter(this, void 0, void 0, function* () {
31
- const addresses = (0, contracts_1.getContractAddressesForChain)(chainId);
32
- const diamond = generated_1.GNSMultiCollatDiamond__factory.connect(addresses.gnsMultiCollatDiamond, signer);
33
- // Fetch all three OI types in parallel
34
- const [beforeV10Raw, afterV10Collateral, afterV10Token, maxOi, collateral] = yield Promise.all([
35
- diamond.getPairOisBeforeV10Collateral(collateralIndex, pairIndex),
36
- diamond.getPairOiAfterV10Collateral(collateralIndex, pairIndex),
37
- diamond.getPairOiAfterV10Token(collateralIndex, pairIndex),
38
- diamond.getPairMaxOi(collateralIndex, pairIndex),
39
- diamond.getCollateral(collateralIndex),
40
- ]);
41
- // Convert the beforeV10 format to match expected structure
42
- const beforeV10 = {
43
- long: beforeV10Raw.longOi,
44
- short: beforeV10Raw.shortOi,
45
- max: maxOi,
46
- __placeholder: ethers_1.ethers.BigNumber.from(0),
47
- };
48
- return (0, converter_1.convertPairOi)(beforeV10, afterV10Collateral, afterV10Token, Number(collateral.precision));
49
- });
50
- }
51
- exports.fetchPairOi = fetchPairOi;
52
- /**
53
- * @dev Fetches OI data for multiple pairs efficiently
54
- * @param chainId Target chain
55
- * @param collateralIndex Collateral type
56
- * @param pairIndices Array of trading pairs
57
- * @param signer Ethers signer
58
- * @returns Array of unified PairOi structures
59
- */
60
- function fetchMultiplePairOi(chainId, collateralIndex, pairIndices, signer) {
61
- return __awaiter(this, void 0, void 0, function* () {
62
- const addresses = (0, contracts_1.getContractAddressesForChain)(chainId);
63
- const diamond = generated_1.GNSMultiCollatDiamond__factory.connect(addresses.gnsMultiCollatDiamond, signer);
64
- // Get collateral precision once
65
- const collateral = yield diamond.getCollateral(collateralIndex);
66
- const precision = Number(collateral.precision);
67
- // Batch fetch all OI data
68
- const promises = pairIndices.map((pairIndex) => __awaiter(this, void 0, void 0, function* () {
69
- const [beforeV10Raw, afterV10Collateral, afterV10Token, maxOi] = yield Promise.all([
70
- diamond.getPairOisBeforeV10Collateral(collateralIndex, pairIndex),
71
- diamond.getPairOiAfterV10Collateral(collateralIndex, pairIndex),
72
- diamond.getPairOiAfterV10Token(collateralIndex, pairIndex),
73
- diamond.getPairMaxOi(collateralIndex, pairIndex),
74
- ]);
75
- // Convert the beforeV10 format to match expected structure
76
- const beforeV10 = {
77
- long: beforeV10Raw.longOi,
78
- short: beforeV10Raw.shortOi,
79
- max: maxOi,
80
- __placeholder: ethers_1.ethers.BigNumber.from(0),
81
- };
82
- return {
83
- beforeV10: beforeV10,
84
- collateral: afterV10Collateral,
85
- token: afterV10Token,
86
- };
87
- }));
88
- const results = yield Promise.all(promises);
89
- return (0, converter_1.convertPairOiArray)(results, precision);
90
- });
91
- }
92
- exports.fetchMultiplePairOi = fetchMultiplePairOi;
93
- /**
94
- * @dev Creates OI context for fee calculations
95
- * @param chainId Target chain
96
- * @param collateralIndex Collateral type
97
- * @param pairIndex Trading pair
98
- * @param signer Ethers signer
99
- * @returns OI data formatted for SDK calculations
100
- */
101
- function createOiContext(chainId, collateralIndex, pairIndex, signer) {
102
- return __awaiter(this, void 0, void 0, function* () {
103
- // Fetch OI data
104
- const pairOi = yield fetchPairOi(chainId, collateralIndex, pairIndex, signer);
105
- // For now, use a placeholder price - in real usage, this would come from price feeds
106
- // The actual price should be fetched from the price aggregator or oracle
107
- const currentPrice = 1; // Placeholder - replace with actual price fetching
108
- // Compute derived values
109
- const totalDynamicOi = {
110
- long: pairOi.beforeV10Collateral.long + pairOi.token.long * currentPrice,
111
- short: pairOi.beforeV10Collateral.short + pairOi.token.short * currentPrice,
112
- };
113
- const totalStaticOi = {
114
- long: pairOi.beforeV10Collateral.long + pairOi.collateral.long,
115
- short: pairOi.beforeV10Collateral.short + pairOi.collateral.short,
116
- };
117
- const skew = pairOi.token.long - pairOi.token.short;
118
- return {
119
- pairOi,
120
- currentPrice,
121
- computed: {
122
- totalDynamicOi,
123
- totalStaticOi,
124
- skew,
125
- },
126
- };
127
- });
128
- }
129
- exports.createOiContext = createOiContext;
130
- /**
131
- * @dev Fetches only the OI data needed for specific use cases
132
- * @param chainId Target chain
133
- * @param collateralIndex Collateral type
134
- * @param pairIndex Trading pair
135
- * @param useCase Which OI systems to fetch
136
- * @param signer Ethers signer
137
- * @returns Partial OI data based on use case
138
- */
139
- function fetchOiForUseCase(chainId, collateralIndex, pairIndex, useCase, signer) {
140
- return __awaiter(this, void 0, void 0, function* () {
141
- const addresses = (0, contracts_1.getContractAddressesForChain)(chainId);
142
- const diamond = generated_1.GNSMultiCollatDiamond__factory.connect(addresses.gnsMultiCollatDiamond, signer);
143
- switch (useCase) {
144
- case "skew":
145
- case "funding": {
146
- // Only need token OI
147
- const tokenOi = yield diamond.getPairOiAfterV10Token(collateralIndex, pairIndex);
148
- return {
149
- token: (0, converter_1.convertTokenOi)(tokenOi),
150
- };
151
- }
152
- case "borrowingV1": {
153
- // Need beforeV10 and token (for dynamic calculation)
154
- const [beforeV10Raw, tokenOi, collateral, maxOi] = yield Promise.all([
155
- diamond.getPairOisBeforeV10Collateral(collateralIndex, pairIndex),
156
- diamond.getPairOiAfterV10Token(collateralIndex, pairIndex),
157
- diamond.getCollateral(collateralIndex),
158
- diamond.getPairMaxOi(collateralIndex, pairIndex),
159
- ]);
160
- // Convert the beforeV10 format to match expected structure
161
- const beforeV10 = {
162
- long: beforeV10Raw.longOi,
163
- short: beforeV10Raw.shortOi,
164
- max: maxOi,
165
- __placeholder: ethers_1.ethers.BigNumber.from(0),
166
- };
167
- return {
168
- beforeV10Collateral: (0, converter_1.convertBeforeV10Collateral)(beforeV10, Number(collateral.precision)),
169
- token: (0, converter_1.convertTokenOi)(tokenOi),
170
- };
171
- }
172
- case "limits": {
173
- // Need all OI for limit checks
174
- return fetchPairOi(chainId, collateralIndex, pairIndex, signer);
175
- }
176
- default:
177
- throw new Error(`Unknown use case: ${String(useCase)}`);
178
- }
179
- });
180
- }
181
- exports.fetchOiForUseCase = fetchOiForUseCase;
@@ -1,10 +0,0 @@
1
- /**
2
- * @dev Main export file for OI module
3
- * @dev Provides unified Open Interest management functionality
4
- */
5
- export { UnifiedPairOi, GroupOi, OiUsageMetadata, ComputedOi } from "./types";
6
- export { convertBeforeV10Collateral, convertCollateralOi, convertTokenOi, convertPairOi, convertPairOiArray, computeOiValues, } from "./converter";
7
- export { fetchPairOi, fetchMultiplePairOi, createOiContext, fetchOiForUseCase, } from "./fetcher";
8
- export { withinMaxPairOi, calculateDynamicOi, getRemainingOiCapacity, withinMaxGroupOiDynamic, getGroupDynamicOi, validateOiLimits, } from "./validation";
9
- import { OiUsageMetadata } from "./types";
10
- export declare const OI_USAGE: OiUsageMetadata;
@@ -1,37 +0,0 @@
1
- "use strict";
2
- /**
3
- * @dev Main export file for OI module
4
- * @dev Provides unified Open Interest management functionality
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.OI_USAGE = exports.validateOiLimits = exports.getGroupDynamicOi = exports.withinMaxGroupOiDynamic = exports.getRemainingOiCapacity = exports.calculateDynamicOi = exports.withinMaxPairOi = exports.fetchOiForUseCase = exports.createOiContext = exports.fetchMultiplePairOi = exports.fetchPairOi = exports.computeOiValues = exports.convertPairOiArray = exports.convertPairOi = exports.convertTokenOi = exports.convertCollateralOi = exports.convertBeforeV10Collateral = void 0;
8
- // Converters
9
- var converter_1 = require("./converter");
10
- Object.defineProperty(exports, "convertBeforeV10Collateral", { enumerable: true, get: function () { return converter_1.convertBeforeV10Collateral; } });
11
- Object.defineProperty(exports, "convertCollateralOi", { enumerable: true, get: function () { return converter_1.convertCollateralOi; } });
12
- Object.defineProperty(exports, "convertTokenOi", { enumerable: true, get: function () { return converter_1.convertTokenOi; } });
13
- Object.defineProperty(exports, "convertPairOi", { enumerable: true, get: function () { return converter_1.convertPairOi; } });
14
- Object.defineProperty(exports, "convertPairOiArray", { enumerable: true, get: function () { return converter_1.convertPairOiArray; } });
15
- Object.defineProperty(exports, "computeOiValues", { enumerable: true, get: function () { return converter_1.computeOiValues; } });
16
- // Fetchers
17
- var fetcher_1 = require("./fetcher");
18
- Object.defineProperty(exports, "fetchPairOi", { enumerable: true, get: function () { return fetcher_1.fetchPairOi; } });
19
- Object.defineProperty(exports, "fetchMultiplePairOi", { enumerable: true, get: function () { return fetcher_1.fetchMultiplePairOi; } });
20
- Object.defineProperty(exports, "createOiContext", { enumerable: true, get: function () { return fetcher_1.createOiContext; } });
21
- Object.defineProperty(exports, "fetchOiForUseCase", { enumerable: true, get: function () { return fetcher_1.fetchOiForUseCase; } });
22
- // Validation
23
- var validation_1 = require("./validation");
24
- Object.defineProperty(exports, "withinMaxPairOi", { enumerable: true, get: function () { return validation_1.withinMaxPairOi; } });
25
- Object.defineProperty(exports, "calculateDynamicOi", { enumerable: true, get: function () { return validation_1.calculateDynamicOi; } });
26
- Object.defineProperty(exports, "getRemainingOiCapacity", { enumerable: true, get: function () { return validation_1.getRemainingOiCapacity; } });
27
- Object.defineProperty(exports, "withinMaxGroupOiDynamic", { enumerable: true, get: function () { return validation_1.withinMaxGroupOiDynamic; } });
28
- Object.defineProperty(exports, "getGroupDynamicOi", { enumerable: true, get: function () { return validation_1.getGroupDynamicOi; } });
29
- Object.defineProperty(exports, "validateOiLimits", { enumerable: true, get: function () { return validation_1.validateOiLimits; } });
30
- exports.OI_USAGE = {
31
- borrowingV1: ["beforeV10Collateral", "token"],
32
- fundingFees: ["token"],
33
- skewImpact: ["token"],
34
- maxPairOi: ["beforeV10Collateral", "token"],
35
- maxGroupOi: ["beforeV10Collateral", "token"],
36
- maxSkew: ["token"], // V10+ only: uses token OI
37
- };