@gainsnetwork/sdk 0.0.40 → 0.0.41-rc2

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 (119) hide show
  1. package/README.md +11 -11
  2. package/lib/constants.d.ts +174 -174
  3. package/lib/constants.js +186 -186
  4. package/lib/contracts/addresses.d.ts +2 -2
  5. package/lib/contracts/addresses.js +15 -15
  6. package/lib/contracts/addresses.json +35 -35
  7. package/lib/contracts/index.d.ts +6 -6
  8. package/lib/contracts/index.js +35 -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 +1341 -0
  12. package/lib/contracts/types/generated/GNSBorrowingFees.js +2 -0
  13. package/lib/contracts/types/generated/GNSBorrowingFeesV6_3_2.d.ts +979 -0
  14. package/lib/contracts/types/generated/GNSBorrowingFeesV6_3_2.js +2 -0
  15. package/lib/contracts/types/generated/GNSBorrowingFeesV6_4.d.ts +1058 -1058
  16. package/lib/contracts/types/generated/GNSBorrowingFeesV6_4.js +2 -2
  17. package/lib/contracts/types/generated/GNSNftRewardsV6.d.ts +533 -533
  18. package/lib/contracts/types/generated/GNSNftRewardsV6.js +2 -2
  19. package/lib/contracts/types/generated/GNSNftRewardsV6_3_1.d.ts +613 -613
  20. package/lib/contracts/types/generated/GNSNftRewardsV6_3_1.js +2 -2
  21. package/lib/contracts/types/generated/GNSPairInfosV6_1.d.ts +911 -911
  22. package/lib/contracts/types/generated/GNSPairInfosV6_1.js +2 -2
  23. package/lib/contracts/types/generated/GNSPairsStorageV6.d.ts +660 -660
  24. package/lib/contracts/types/generated/GNSPairsStorageV6.js +2 -2
  25. package/lib/contracts/types/generated/GNSTradingCallbacksV6_3_2.d.ts +806 -0
  26. package/lib/contracts/types/generated/GNSTradingCallbacksV6_3_2.js +2 -0
  27. package/lib/contracts/types/generated/GNSTradingCallbacksV6_4.d.ts +821 -821
  28. package/lib/contracts/types/generated/GNSTradingCallbacksV6_4.js +2 -2
  29. package/lib/contracts/types/generated/GTokenOpenPnlFeed.d.ts +557 -557
  30. package/lib/contracts/types/generated/GTokenOpenPnlFeed.js +2 -2
  31. package/lib/contracts/types/generated/GTokenV6_3_2.d.ts +1838 -1838
  32. package/lib/contracts/types/generated/GTokenV6_3_2.js +2 -2
  33. package/lib/contracts/types/generated/common.d.ts +22 -22
  34. package/lib/contracts/types/generated/common.js +2 -2
  35. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.d.ts +83 -83
  36. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.js +2691 -2691
  37. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_3_2__factory.d.ts +88 -0
  38. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_3_2__factory.js +1654 -0
  39. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_4__factory.d.ts +113 -113
  40. package/lib/contracts/types/generated/factories/GNSBorrowingFeesV6_4__factory.js +1742 -1742
  41. package/lib/contracts/types/generated/factories/GNSBorrowingFees__factory.d.ts +128 -0
  42. package/lib/contracts/types/generated/factories/GNSBorrowingFees__factory.js +2206 -0
  43. package/lib/contracts/types/generated/factories/GNSNftRewardsV6_3_1__factory.d.ts +100 -100
  44. package/lib/contracts/types/generated/factories/GNSNftRewardsV6_3_1__factory.js +1116 -1116
  45. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.d.ts +100 -100
  46. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.js +1003 -1003
  47. package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.d.ts +98 -98
  48. package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.js +1485 -1485
  49. package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.d.ts +117 -117
  50. package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.js +1265 -1265
  51. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_3_2__factory.d.ts +82 -0
  52. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_3_2__factory.js +1273 -0
  53. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_4__factory.d.ts +82 -82
  54. package/lib/contracts/types/generated/factories/GNSTradingCallbacksV6_4__factory.js +1326 -1326
  55. package/lib/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.d.ts +59 -59
  56. package/lib/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.js +765 -765
  57. package/lib/contracts/types/generated/factories/GTokenV6_3_2__factory.d.ts +110 -110
  58. package/lib/contracts/types/generated/factories/GTokenV6_3_2__factory.js +2682 -2682
  59. package/lib/contracts/types/generated/factories/index.d.ts +9 -9
  60. package/lib/contracts/types/generated/factories/index.js +24 -24
  61. package/lib/contracts/types/generated/index.d.ts +19 -19
  62. package/lib/contracts/types/generated/index.js +45 -45
  63. package/lib/contracts/types/index.d.ts +23 -23
  64. package/lib/contracts/types/index.js +2 -2
  65. package/lib/contracts/utils/borrowingFees.d.ts +8 -8
  66. package/lib/contracts/utils/borrowingFees.js +28 -28
  67. package/lib/contracts/utils/index.d.ts +4 -4
  68. package/lib/contracts/utils/index.js +20 -20
  69. package/lib/contracts/utils/openLimitOrders.d.ts +8 -8
  70. package/lib/contracts/utils/openLimitOrders.js +88 -88
  71. package/lib/contracts/utils/openTrades.d.ts +9 -9
  72. package/lib/contracts/utils/openTrades.js +172 -172
  73. package/lib/contracts/utils/pairs.d.ts +7 -7
  74. package/lib/contracts/utils/pairs.js +115 -115
  75. package/lib/index.d.ts +7 -7
  76. package/lib/index.js +24 -24
  77. package/lib/markets/commodities.d.ts +1 -1
  78. package/lib/markets/commodities.js +31 -31
  79. package/lib/markets/crypto.d.ts +1 -1
  80. package/lib/markets/crypto.js +6 -6
  81. package/lib/markets/forex.d.ts +2 -2
  82. package/lib/markets/forex.js +38 -38
  83. package/lib/markets/index.d.ts +5 -5
  84. package/lib/markets/index.js +21 -21
  85. package/lib/markets/indices.d.ts +1 -1
  86. package/lib/markets/indices.js +6 -6
  87. package/lib/markets/stocks.d.ts +3 -3
  88. package/lib/markets/stocks.js +54 -54
  89. package/lib/trade/fees/borrowing/converter.d.ts +13 -13
  90. package/lib/trade/fees/borrowing/converter.js +41 -41
  91. package/lib/trade/fees/borrowing/index.d.ts +55 -55
  92. package/lib/trade/fees/borrowing/index.js +171 -171
  93. package/lib/trade/fees/borrowing/types.d.ts +36 -36
  94. package/lib/trade/fees/borrowing/types.js +2 -2
  95. package/lib/trade/fees/index.d.ts +16 -16
  96. package/lib/trade/fees/index.js +60 -60
  97. package/lib/trade/index.d.ts +8 -7
  98. package/lib/trade/index.js +24 -23
  99. package/lib/trade/liquidation.d.ts +7 -7
  100. package/lib/trade/liquidation.js +18 -18
  101. package/lib/trade/oiWindows.d.ts +3 -0
  102. package/lib/trade/oiWindows.js +19 -0
  103. package/lib/trade/openLimitOrder.d.ts +2 -2
  104. package/lib/trade/openLimitOrder.js +24 -24
  105. package/lib/trade/pnl.d.ts +9 -9
  106. package/lib/trade/pnl.js +44 -44
  107. package/lib/trade/spread.d.ts +3 -3
  108. package/lib/trade/spread.js +32 -30
  109. package/lib/trade/types.d.ts +185 -176
  110. package/lib/trade/types.js +14 -14
  111. package/lib/utils/index.d.ts +1 -1
  112. package/lib/utils/index.js +17 -17
  113. package/lib/utils/packing.d.ts +2 -2
  114. package/lib/utils/packing.js +39 -39
  115. package/lib/vault/index.d.ts +7 -7
  116. package/lib/vault/index.js +11 -11
  117. package/package.json +104 -104
  118. package/lib/trade/fees.d.ts +0 -15
  119. package/lib/trade/fees.js +0 -45
@@ -1,7 +1,7 @@
1
- import { GetFundingFeeContext, GetRolloverFeeContext, GetBorrowingFeeContext } from "./fees";
2
- import { Trade, TradeInfo, TradeInitialAccFees } from "./types";
3
- export type GetLiqPriceContext = GetFundingFeeContext & GetRolloverFeeContext & GetBorrowingFeeContext & {
4
- currentBlock: number;
5
- currentL1Block: number;
6
- };
7
- export declare const getLiquidationPrice: (trade: Trade, tradeInfo: TradeInfo, initialAccFees: TradeInitialAccFees, context: GetLiqPriceContext) => number;
1
+ import { GetFundingFeeContext, GetRolloverFeeContext, GetBorrowingFeeContext } from "./fees";
2
+ import { Trade, TradeInfo, TradeInitialAccFees } from "./types";
3
+ export type GetLiqPriceContext = GetFundingFeeContext & GetRolloverFeeContext & GetBorrowingFeeContext & {
4
+ currentBlock: number;
5
+ currentL1Block: number;
6
+ };
7
+ export declare const getLiquidationPrice: (trade: Trade, tradeInfo: TradeInfo, initialAccFees: TradeInitialAccFees, context: GetLiqPriceContext) => number;
@@ -1,18 +1,18 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getLiquidationPrice = void 0;
4
- const fees_1 = require("./fees");
5
- const getLiquidationPrice = (trade, tradeInfo, initialAccFees, context) => {
6
- const posDai = trade.initialPosToken * tradeInfo.tokenPriceDai;
7
- const liqPriceDistance = (trade.openPrice *
8
- (posDai * 0.9 -
9
- (0, fees_1.getRolloverFee)(posDai, initialAccFees.rollover, initialAccFees.openedAfterUpdate, Object.assign(Object.assign({}, context), { currentBlock: context.currentL1Block })) -
10
- (0, fees_1.getBorrowingFee)(posDai * trade.leverage, trade.pairIndex, trade.buy, initialAccFees.borrowing, context) -
11
- (0, fees_1.getFundingFee)(posDai * trade.leverage, initialAccFees.funding, trade.buy, initialAccFees.openedAfterUpdate, Object.assign(Object.assign({}, context), { currentBlock: context.currentL1Block })))) /
12
- posDai /
13
- trade.leverage;
14
- return trade.buy
15
- ? Math.max(trade.openPrice - liqPriceDistance, 0)
16
- : Math.max(trade.openPrice + liqPriceDistance, 0);
17
- };
18
- exports.getLiquidationPrice = getLiquidationPrice;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getLiquidationPrice = void 0;
4
+ const fees_1 = require("./fees");
5
+ const getLiquidationPrice = (trade, tradeInfo, initialAccFees, context) => {
6
+ const posDai = trade.initialPosToken * tradeInfo.tokenPriceDai;
7
+ const liqPriceDistance = (trade.openPrice *
8
+ (posDai * 0.9 -
9
+ (0, fees_1.getRolloverFee)(posDai, initialAccFees.rollover, initialAccFees.openedAfterUpdate, Object.assign(Object.assign({}, context), { currentBlock: context.currentL1Block })) -
10
+ (0, fees_1.getBorrowingFee)(posDai * trade.leverage, trade.pairIndex, trade.buy, initialAccFees.borrowing, context) -
11
+ (0, fees_1.getFundingFee)(posDai * trade.leverage, initialAccFees.funding, trade.buy, initialAccFees.openedAfterUpdate, Object.assign(Object.assign({}, context), { currentBlock: context.currentL1Block })))) /
12
+ posDai /
13
+ trade.leverage;
14
+ return trade.buy
15
+ ? Math.max(trade.openPrice - liqPriceDistance, 0)
16
+ : Math.max(trade.openPrice + liqPriceDistance, 0);
17
+ };
18
+ exports.getLiquidationPrice = getLiquidationPrice;
@@ -0,0 +1,3 @@
1
+ import { OiWindows, OiWindowsSettings } from "@/trade/types";
2
+ export declare const getCurrentOiWindowId: (oiWindowSettings: OiWindowsSettings) => number;
3
+ export declare const getActiveOi: (currentOiWindowId: number, windowsCount: number, oiWindows: OiWindows | undefined, buy: boolean) => number;
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getActiveOi = exports.getCurrentOiWindowId = void 0;
4
+ const getCurrentOiWindowId = (oiWindowSettings) => {
5
+ return Math.floor((Math.floor(Date.now() / 1000) - oiWindowSettings.startTs) /
6
+ oiWindowSettings.windowsDuration);
7
+ };
8
+ exports.getCurrentOiWindowId = getCurrentOiWindowId;
9
+ const getActiveOi = (currentOiWindowId, windowsCount, oiWindows, buy) => {
10
+ var _a, _b;
11
+ if (oiWindows === undefined)
12
+ return 0;
13
+ let activeOi = 0;
14
+ for (let id = currentOiWindowId - windowsCount; id <= currentOiWindowId; id++) {
15
+ activeOi += (buy ? (_a = oiWindows === null || oiWindows === void 0 ? void 0 : oiWindows[id]) === null || _a === void 0 ? void 0 : _a.long : (_b = oiWindows === null || oiWindows === void 0 ? void 0 : oiWindows[id]) === null || _b === void 0 ? void 0 : _b.short) || 0;
16
+ }
17
+ return activeOi;
18
+ };
19
+ exports.getActiveOi = getActiveOi;
@@ -1,2 +1,2 @@
1
- import { LimitOrder, OpenInterest, Pair, PairParams } from "./types";
2
- export declare const getFulfillmentPrice: (order: LimitOrder, pair: Pair, pairParams: PairParams, openInterest: OpenInterest) => number;
1
+ import { LimitOrder, OpenInterest, Pair, PairParams, OiWindowsSettings, OiWindows } from "./types";
2
+ export declare const getFulfillmentPrice: (order: LimitOrder, pair: Pair, pairParams: PairParams, openInterest: OpenInterest, oiWindowsSettings?: OiWindowsSettings, oiWindows?: OiWindows) => number;
@@ -1,24 +1,24 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getFulfillmentPrice = void 0;
4
- const spread_1 = require("./spread");
5
- const types_1 = require("./types");
6
- const getFulfillmentPrice = (order, pair, pairParams, openInterest) => {
7
- if (!order || !pair) {
8
- return 0;
9
- }
10
- // Get spread percentage
11
- const baseSpreadP = (0, spread_1.getBaseSpreadP)(pair.spreadP, order.spreadReductionP);
12
- const spreadWithPriceImpactP = (0, spread_1.getSpreadWithPriceImpactP)(baseSpreadP, order.buy, order.positionSize, order.leverage, pairParams, openInterest);
13
- if (spreadWithPriceImpactP === 0) {
14
- return 0;
15
- }
16
- const askingPrice = (order.buy && order.type === types_1.OpenLimitOrderType.REVERSAL) ||
17
- (!order.buy && order.type === types_1.OpenLimitOrderType.MOMENTUM)
18
- ? order.maxPrice
19
- : order.minPrice;
20
- return order.buy
21
- ? askingPrice * (1 + spreadWithPriceImpactP)
22
- : askingPrice * (1 - spreadWithPriceImpactP);
23
- };
24
- exports.getFulfillmentPrice = getFulfillmentPrice;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getFulfillmentPrice = void 0;
4
+ const spread_1 = require("./spread");
5
+ const types_1 = require("./types");
6
+ const getFulfillmentPrice = (order, pair, pairParams, openInterest, oiWindowsSettings, oiWindows) => {
7
+ if (!order || !pair) {
8
+ return 0;
9
+ }
10
+ // Get spread percentage
11
+ const baseSpreadP = (0, spread_1.getBaseSpreadP)(pair.spreadP, order.spreadReductionP);
12
+ const spreadWithPriceImpactP = (0, spread_1.getSpreadWithPriceImpactP)(baseSpreadP, order.buy, order.positionSize, order.leverage, pairParams, openInterest, oiWindowsSettings, oiWindows);
13
+ if (spreadWithPriceImpactP === 0) {
14
+ return 0;
15
+ }
16
+ const askingPrice = (order.buy && order.type === types_1.OpenLimitOrderType.REVERSAL) ||
17
+ (!order.buy && order.type === types_1.OpenLimitOrderType.MOMENTUM)
18
+ ? order.maxPrice
19
+ : order.minPrice;
20
+ return order.buy
21
+ ? askingPrice * (1 + spreadWithPriceImpactP)
22
+ : askingPrice * (1 - spreadWithPriceImpactP);
23
+ };
24
+ exports.getFulfillmentPrice = getFulfillmentPrice;
@@ -1,9 +1,9 @@
1
- import { GetBorrowingFeeContext, GetFundingFeeContext, GetRolloverFeeContext } from "./fees";
2
- import { Fee, Trade, TradeInfo, TradeInitialAccFees } from "./types";
3
- export type GetPnlContext = GetRolloverFeeContext & GetFundingFeeContext & GetBorrowingFeeContext & {
4
- currentBlock: number;
5
- currentL1Block: number;
6
- fee: Fee | undefined;
7
- maxGainP: number | undefined;
8
- };
9
- export declare const getPnl: (price: number | undefined, trade: Trade, tradeInfo: TradeInfo, initialAccFees: TradeInitialAccFees, useFees: boolean, context: GetPnlContext) => number[] | undefined;
1
+ import { GetBorrowingFeeContext, GetFundingFeeContext, GetRolloverFeeContext } from "./fees";
2
+ import { Fee, Trade, TradeInfo, TradeInitialAccFees } from "./types";
3
+ export type GetPnlContext = GetRolloverFeeContext & GetFundingFeeContext & GetBorrowingFeeContext & {
4
+ currentBlock: number;
5
+ currentL1Block: number;
6
+ fee: Fee | undefined;
7
+ maxGainP: number | undefined;
8
+ };
9
+ export declare const getPnl: (price: number | undefined, trade: Trade, tradeInfo: TradeInfo, initialAccFees: TradeInitialAccFees, useFees: boolean, context: GetPnlContext) => number[] | undefined;
package/lib/trade/pnl.js CHANGED
@@ -1,44 +1,44 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getPnl = void 0;
4
- const fees_1 = require("./fees");
5
- const getPnl = (price, trade, tradeInfo, initialAccFees, useFees, context) => {
6
- if (!price) {
7
- return;
8
- }
9
- const posDai = trade.initialPosToken * tradeInfo.tokenPriceDai;
10
- const { openPrice, leverage } = trade;
11
- const { maxGainP, pairParams, pairRolloverFees, pairFundingFees, openInterest, fee, currentL1Block, } = context;
12
- const maxGain = maxGainP === undefined ? Infinity : (maxGainP / 100) * posDai;
13
- let pnlDai = trade.buy
14
- ? ((price - openPrice) / openPrice) * leverage * posDai
15
- : ((openPrice - price) / openPrice) * leverage * posDai;
16
- pnlDai = pnlDai > maxGain ? maxGain : pnlDai;
17
- if (useFees) {
18
- pnlDai -= (0, fees_1.getRolloverFee)(posDai, initialAccFees.rollover, initialAccFees.openedAfterUpdate, {
19
- currentBlock: currentL1Block,
20
- pairParams,
21
- pairRolloverFees,
22
- });
23
- pnlDai -= (0, fees_1.getFundingFee)(posDai * trade.leverage, initialAccFees.funding, trade.buy, initialAccFees.openedAfterUpdate, {
24
- currentBlock: currentL1Block,
25
- pairParams,
26
- pairFundingFees,
27
- openInterest,
28
- });
29
- pnlDai -= (0, fees_1.getBorrowingFee)(posDai * trade.leverage, trade.pairIndex, trade.buy, initialAccFees.borrowing, context);
30
- }
31
- let pnlPercentage = (pnlDai / posDai) * 100;
32
- // Can be liquidated
33
- if (pnlPercentage <= -90) {
34
- pnlPercentage = -100;
35
- }
36
- else {
37
- pnlDai -= (0, fees_1.getClosingFee)(posDai, trade.leverage, trade.pairIndex, fee);
38
- pnlPercentage = (pnlDai / posDai) * 100;
39
- }
40
- pnlPercentage = pnlPercentage < -100 ? -100 : pnlPercentage;
41
- pnlDai = (posDai * pnlPercentage) / 100;
42
- return [pnlDai, pnlPercentage];
43
- };
44
- exports.getPnl = getPnl;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getPnl = void 0;
4
+ const fees_1 = require("./fees");
5
+ const getPnl = (price, trade, tradeInfo, initialAccFees, useFees, context) => {
6
+ if (!price) {
7
+ return;
8
+ }
9
+ const posDai = trade.initialPosToken * tradeInfo.tokenPriceDai;
10
+ const { openPrice, leverage } = trade;
11
+ const { maxGainP, pairParams, pairRolloverFees, pairFundingFees, openInterest, fee, currentL1Block, } = context;
12
+ const maxGain = maxGainP === undefined ? Infinity : (maxGainP / 100) * posDai;
13
+ let pnlDai = trade.buy
14
+ ? ((price - openPrice) / openPrice) * leverage * posDai
15
+ : ((openPrice - price) / openPrice) * leverage * posDai;
16
+ pnlDai = pnlDai > maxGain ? maxGain : pnlDai;
17
+ if (useFees) {
18
+ pnlDai -= (0, fees_1.getRolloverFee)(posDai, initialAccFees.rollover, initialAccFees.openedAfterUpdate, {
19
+ currentBlock: currentL1Block,
20
+ pairParams,
21
+ pairRolloverFees,
22
+ });
23
+ pnlDai -= (0, fees_1.getFundingFee)(posDai * trade.leverage, initialAccFees.funding, trade.buy, initialAccFees.openedAfterUpdate, {
24
+ currentBlock: currentL1Block,
25
+ pairParams,
26
+ pairFundingFees,
27
+ openInterest,
28
+ });
29
+ pnlDai -= (0, fees_1.getBorrowingFee)(posDai * trade.leverage, trade.pairIndex, trade.buy, initialAccFees.borrowing, context);
30
+ }
31
+ let pnlPercentage = (pnlDai / posDai) * 100;
32
+ // Can be liquidated
33
+ if (pnlPercentage <= -90) {
34
+ pnlPercentage = -100;
35
+ }
36
+ else {
37
+ pnlDai -= (0, fees_1.getClosingFee)(posDai, trade.leverage, trade.pairIndex, fee);
38
+ pnlPercentage = (pnlDai / posDai) * 100;
39
+ }
40
+ pnlPercentage = pnlPercentage < -100 ? -100 : pnlPercentage;
41
+ pnlDai = (posDai * pnlPercentage) / 100;
42
+ return [pnlDai, pnlPercentage];
43
+ };
44
+ exports.getPnl = getPnl;
@@ -1,3 +1,3 @@
1
- import { OpenInterest, PairParams } from "./types";
2
- export declare const getBaseSpreadP: (pairSpreadP: number | undefined, spreadReductionP: number | undefined) => number;
3
- export declare const getSpreadWithPriceImpactP: (baseSpreadP: number, buy: boolean, collateral: number, leverage: number, pairParams: PairParams | undefined, openInterest: OpenInterest | undefined) => number;
1
+ import { OiWindows, OiWindowsSettings, OpenInterest, PairParams } from "./types";
2
+ export declare const getBaseSpreadP: (pairSpreadP: number | undefined, spreadReductionP: number | undefined) => number;
3
+ export declare const getSpreadWithPriceImpactP: (baseSpreadP: number, buy: boolean, collateral: number, leverage: number, pairParams: PairParams | undefined, openInterest: OpenInterest | undefined, oiWindowsSettings?: OiWindowsSettings | undefined, oiWindows?: OiWindows | undefined) => number;
@@ -1,30 +1,32 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getSpreadWithPriceImpactP = exports.getBaseSpreadP = void 0;
4
- const getBaseSpreadP = (pairSpreadP, spreadReductionP) => {
5
- if (!pairSpreadP) {
6
- return 0;
7
- }
8
- if (!spreadReductionP) {
9
- return pairSpreadP;
10
- }
11
- return (pairSpreadP * (100 - spreadReductionP)) / 100;
12
- };
13
- exports.getBaseSpreadP = getBaseSpreadP;
14
- const getSpreadWithPriceImpactP = (baseSpreadP, buy, collateral, leverage, pairParams, openInterest) => {
15
- if (baseSpreadP === undefined) {
16
- return 0;
17
- }
18
- const onePercentDepth = buy
19
- ? pairParams === null || pairParams === void 0 ? void 0 : pairParams.onePercentDepthAbove
20
- : pairParams === null || pairParams === void 0 ? void 0 : pairParams.onePercentDepthBelow;
21
- const existingOi = buy ? openInterest === null || openInterest === void 0 ? void 0 : openInterest.long : openInterest === null || openInterest === void 0 ? void 0 : openInterest.short;
22
- if (!onePercentDepth ||
23
- existingOi === undefined ||
24
- collateral === undefined) {
25
- return baseSpreadP;
26
- }
27
- return (baseSpreadP +
28
- (existingOi + (collateral * leverage) / 2) / onePercentDepth / 100);
29
- };
30
- exports.getSpreadWithPriceImpactP = getSpreadWithPriceImpactP;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getSpreadWithPriceImpactP = exports.getBaseSpreadP = void 0;
4
+ const oiWindows_1 = require("./oiWindows");
5
+ const getBaseSpreadP = (pairSpreadP, spreadReductionP) => {
6
+ if (!pairSpreadP) {
7
+ return 0;
8
+ }
9
+ if (!spreadReductionP) {
10
+ return pairSpreadP;
11
+ }
12
+ return (pairSpreadP * (100 - spreadReductionP)) / 100;
13
+ };
14
+ exports.getBaseSpreadP = getBaseSpreadP;
15
+ const getSpreadWithPriceImpactP = (baseSpreadP, buy, collateral, leverage, pairParams, openInterest, oiWindowsSettings, oiWindows) => {
16
+ if (baseSpreadP === undefined) {
17
+ return 0;
18
+ }
19
+ const onePercentDepth = buy
20
+ ? pairParams === null || pairParams === void 0 ? void 0 : pairParams.onePercentDepthAbove
21
+ : pairParams === null || pairParams === void 0 ? void 0 : pairParams.onePercentDepthBelow;
22
+ let activeOi = buy ? openInterest === null || openInterest === void 0 ? void 0 : openInterest.long : openInterest === null || openInterest === void 0 ? void 0 : openInterest.short;
23
+ if (oiWindowsSettings !== undefined && (oiWindowsSettings === null || oiWindowsSettings === void 0 ? void 0 : oiWindowsSettings.windowsCount) > 0) {
24
+ activeOi = (0, oiWindows_1.getActiveOi)((0, oiWindows_1.getCurrentOiWindowId)(oiWindowsSettings), oiWindowsSettings.windowsCount, oiWindows, buy);
25
+ }
26
+ if (!onePercentDepth || activeOi === undefined || collateral === undefined) {
27
+ return baseSpreadP;
28
+ }
29
+ return (baseSpreadP +
30
+ (activeOi + (collateral * leverage) / 2) / onePercentDepth / 100);
31
+ };
32
+ exports.getSpreadWithPriceImpactP = getSpreadWithPriceImpactP;