@gainsnetwork/sdk 0.0.16-rc1 → 0.0.17

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 (143) hide show
  1. package/README.md +11 -11
  2. package/lib/contracts/addresses.d.ts +2 -2
  3. package/lib/contracts/addresses.js +15 -15
  4. package/lib/contracts/addresses.json +23 -20
  5. package/lib/contracts/index.d.ts +6 -6
  6. package/lib/contracts/index.js +32 -31
  7. package/lib/contracts/types/generated/GFarmTradingStorageV5.d.ts +1911 -1911
  8. package/lib/contracts/types/generated/GFarmTradingStorageV5.js +2 -2
  9. package/lib/contracts/types/generated/GNSNftRewardsV6.d.ts +533 -0
  10. package/lib/contracts/types/{GNSPairsStorageV6.js → generated/GNSNftRewardsV6.js} +2 -2
  11. package/lib/contracts/types/generated/GNSPairInfosV6_1.d.ts +911 -911
  12. package/lib/contracts/types/generated/GNSPairInfosV6_1.js +2 -2
  13. package/lib/contracts/types/generated/GNSPairsStorageV6.d.ts +660 -660
  14. package/lib/contracts/types/generated/GNSPairsStorageV6.js +2 -2
  15. package/lib/contracts/types/generated/GTokenOpenPnlFeed.d.ts +557 -557
  16. package/lib/contracts/types/generated/GTokenOpenPnlFeed.js +2 -2
  17. package/lib/contracts/types/generated/common.d.ts +22 -22
  18. package/lib/contracts/types/generated/common.js +2 -2
  19. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.d.ts +83 -83
  20. package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.js +2691 -2691
  21. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.d.ts +100 -0
  22. package/lib/contracts/types/generated/factories/GNSNftRewardsV6__factory.js +1003 -0
  23. package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.d.ts +98 -98
  24. package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.js +1485 -1485
  25. package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.d.ts +117 -117
  26. package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.js +1265 -1265
  27. package/lib/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.d.ts +59 -59
  28. package/lib/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.js +765 -765
  29. package/lib/contracts/types/generated/factories/index.d.ts +5 -4
  30. package/lib/contracts/types/generated/factories/index.js +16 -14
  31. package/lib/contracts/types/generated/index.d.ts +11 -9
  32. package/lib/contracts/types/generated/index.js +37 -35
  33. package/lib/contracts/types/index.d.ts +16 -13
  34. package/lib/contracts/types/index.js +2 -2
  35. package/lib/contracts/utils/index.d.ts +3 -2
  36. package/lib/contracts/utils/index.js +19 -18
  37. package/lib/contracts/utils/openLimitOrders.d.ts +8 -0
  38. package/lib/contracts/utils/openLimitOrders.js +77 -0
  39. package/lib/contracts/utils/openTrades.d.ts +9 -3
  40. package/lib/contracts/utils/openTrades.js +193 -202
  41. package/lib/contracts/utils/pairs.d.ts +6 -6
  42. package/lib/contracts/utils/pairs.js +102 -102
  43. package/lib/index.d.ts +3 -3
  44. package/lib/index.js +19 -19
  45. package/lib/markets/commodities.d.ts +1 -1
  46. package/lib/markets/commodities.js +31 -31
  47. package/lib/markets/crypto.d.ts +1 -1
  48. package/lib/markets/crypto.js +6 -6
  49. package/lib/markets/forex.d.ts +2 -2
  50. package/lib/markets/forex.js +38 -38
  51. package/lib/markets/index.d.ts +5 -5
  52. package/lib/markets/index.js +21 -21
  53. package/lib/markets/indices.d.ts +1 -1
  54. package/lib/markets/indices.js +6 -6
  55. package/lib/markets/stocks.d.ts +3 -3
  56. package/lib/markets/stocks.js +54 -54
  57. package/lib/trade/fees.d.ts +15 -15
  58. package/lib/trade/fees.js +45 -45
  59. package/lib/trade/index.d.ts +2 -2
  60. package/lib/trade/index.js +18 -18
  61. package/lib/trade/pnl.d.ts +7 -7
  62. package/lib/trade/pnl.js +43 -43
  63. package/lib/trade/types.d.ts +157 -143
  64. package/lib/trade/types.js +8 -8
  65. package/package.json +104 -104
  66. package/lib/contracts/types/GFarmTradingStorageV5.d.ts +0 -1911
  67. package/lib/contracts/types/GFarmTradingStorageV5.js +0 -2
  68. package/lib/contracts/types/GNSPairInfosV6_1.d.ts +0 -911
  69. package/lib/contracts/types/GNSPairInfosV6_1.js +0 -2
  70. package/lib/contracts/types/GNSPairsStorageV6.d.ts +0 -660
  71. package/lib/contracts/types/common.d.ts +0 -22
  72. package/lib/contracts/types/common.js +0 -2
  73. package/lib/contracts/types/factories/GFarmTradingStorageV5__factory.d.ts +0 -83
  74. package/lib/contracts/types/factories/GFarmTradingStorageV5__factory.js +0 -2691
  75. package/lib/contracts/types/factories/GNSPairInfosV6_1__factory.d.ts +0 -98
  76. package/lib/contracts/types/factories/GNSPairInfosV6_1__factory.js +0 -1485
  77. package/lib/contracts/types/factories/GNSPairsStorageV6__factory.d.ts +0 -117
  78. package/lib/contracts/types/factories/GNSPairsStorageV6__factory.js +0 -1265
  79. package/lib/contracts/types/factories/index.d.ts +0 -3
  80. package/lib/contracts/types/factories/index.js +0 -12
  81. package/lib/contracts/utils/openTradesOriginal.d.ts +0 -3
  82. package/lib/contracts/utils/openTradesOriginal.js +0 -134
  83. package/lib/src/contracts/addresses.d.ts +0 -2
  84. package/lib/src/contracts/addresses.js +0 -15
  85. package/lib/src/contracts/addresses.json +0 -20
  86. package/lib/src/contracts/index.d.ts +0 -6
  87. package/lib/src/contracts/index.js +0 -31
  88. package/lib/src/contracts/types/generated/GFarmTradingStorageV5.d.ts +0 -1911
  89. package/lib/src/contracts/types/generated/GFarmTradingStorageV5.js +0 -2
  90. package/lib/src/contracts/types/generated/GNSPairInfosV6_1.d.ts +0 -911
  91. package/lib/src/contracts/types/generated/GNSPairInfosV6_1.js +0 -2
  92. package/lib/src/contracts/types/generated/GNSPairsStorageV6.d.ts +0 -660
  93. package/lib/src/contracts/types/generated/GNSPairsStorageV6.js +0 -2
  94. package/lib/src/contracts/types/generated/GTokenOpenPnlFeed.d.ts +0 -557
  95. package/lib/src/contracts/types/generated/GTokenOpenPnlFeed.js +0 -2
  96. package/lib/src/contracts/types/generated/common.d.ts +0 -22
  97. package/lib/src/contracts/types/generated/common.js +0 -2
  98. package/lib/src/contracts/types/generated/factories/GFarmTradingStorageV5__factory.d.ts +0 -83
  99. package/lib/src/contracts/types/generated/factories/GFarmTradingStorageV5__factory.js +0 -2691
  100. package/lib/src/contracts/types/generated/factories/GNSPairInfosV6_1__factory.d.ts +0 -98
  101. package/lib/src/contracts/types/generated/factories/GNSPairInfosV6_1__factory.js +0 -1485
  102. package/lib/src/contracts/types/generated/factories/GNSPairsStorageV6__factory.d.ts +0 -117
  103. package/lib/src/contracts/types/generated/factories/GNSPairsStorageV6__factory.js +0 -1265
  104. package/lib/src/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.d.ts +0 -59
  105. package/lib/src/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.js +0 -765
  106. package/lib/src/contracts/types/generated/factories/index.d.ts +0 -4
  107. package/lib/src/contracts/types/generated/factories/index.js +0 -14
  108. package/lib/src/contracts/types/generated/index.d.ts +0 -9
  109. package/lib/src/contracts/types/generated/index.js +0 -35
  110. package/lib/src/contracts/types/index.d.ts +0 -13
  111. package/lib/src/contracts/types/index.js +0 -2
  112. package/lib/src/contracts/utils/index.d.ts +0 -2
  113. package/lib/src/contracts/utils/index.js +0 -18
  114. package/lib/src/contracts/utils/openTrades.d.ts +0 -3
  115. package/lib/src/contracts/utils/openTrades.js +0 -107
  116. package/lib/src/contracts/utils/pairs.d.ts +0 -6
  117. package/lib/src/contracts/utils/pairs.js +0 -102
  118. package/lib/src/index.d.ts +0 -3
  119. package/lib/src/index.js +0 -19
  120. package/lib/src/markets/commodities.d.ts +0 -1
  121. package/lib/src/markets/commodities.js +0 -31
  122. package/lib/src/markets/crypto.d.ts +0 -1
  123. package/lib/src/markets/crypto.js +0 -6
  124. package/lib/src/markets/forex.d.ts +0 -2
  125. package/lib/src/markets/forex.js +0 -38
  126. package/lib/src/markets/index.d.ts +0 -5
  127. package/lib/src/markets/index.js +0 -21
  128. package/lib/src/markets/indices.d.ts +0 -1
  129. package/lib/src/markets/indices.js +0 -6
  130. package/lib/src/markets/stocks.d.ts +0 -3
  131. package/lib/src/markets/stocks.js +0 -54
  132. package/lib/src/trade/fees.d.ts +0 -15
  133. package/lib/src/trade/fees.js +0 -45
  134. package/lib/src/trade/index.d.ts +0 -2
  135. package/lib/src/trade/index.js +0 -18
  136. package/lib/src/trade/pnl.d.ts +0 -7
  137. package/lib/src/trade/pnl.js +0 -43
  138. package/lib/src/trade/types.d.ts +0 -143
  139. package/lib/src/trade/types.js +0 -8
  140. package/lib/test/index.d.ts +0 -1
  141. package/lib/test/index.js +0 -22
  142. package/lib/test.d.ts +0 -1
  143. package/lib/test.js +0 -27
@@ -1,15 +1,15 @@
1
- import { Fee, OpenInterest, PairFundingFees, PairParams, PairRolloverFees } from "./types";
2
- export declare const getClosingFee: (posDai: number, leverage: number, pairIndex: number, pairFee: Fee | undefined) => number;
3
- export type GetFundingFeeContext = {
4
- currentBlock?: number;
5
- pairParams?: PairParams;
6
- pairFundingFees?: PairFundingFees;
7
- openInterest?: OpenInterest;
8
- };
9
- export declare const getFundingFee: (leveragedPosDai: number, initialAccFundingFees: number, buy: boolean, openedAfterUpdate: boolean, context: GetFundingFeeContext) => number;
10
- export type GetRolloverFeeContext = {
11
- currentBlock?: number;
12
- pairParams?: PairParams;
13
- pairRolloverFees?: PairRolloverFees;
14
- };
15
- export declare const getRolloverFee: (posDai: number, initialAccRolloverFees: number, openedAfterUpdate: boolean, context: GetRolloverFeeContext) => number;
1
+ import { Fee, OpenInterest, PairFundingFees, PairParams, PairRolloverFees } from "./types";
2
+ export declare const getClosingFee: (posDai: number, leverage: number, pairIndex: number, pairFee: Fee | undefined) => number;
3
+ export type GetFundingFeeContext = {
4
+ currentBlock?: number;
5
+ pairParams?: PairParams;
6
+ pairFundingFees?: PairFundingFees;
7
+ openInterest?: OpenInterest;
8
+ };
9
+ export declare const getFundingFee: (leveragedPosDai: number, initialAccFundingFees: number, buy: boolean, openedAfterUpdate: boolean, context: GetFundingFeeContext) => number;
10
+ export type GetRolloverFeeContext = {
11
+ currentBlock?: number;
12
+ pairParams?: PairParams;
13
+ pairRolloverFees?: PairRolloverFees;
14
+ };
15
+ export declare const getRolloverFee: (posDai: number, initialAccRolloverFees: number, openedAfterUpdate: boolean, context: GetRolloverFeeContext) => number;
package/lib/trade/fees.js CHANGED
@@ -1,45 +1,45 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getRolloverFee = exports.getFundingFee = exports.getClosingFee = void 0;
4
- const getClosingFee = (posDai, leverage, pairIndex, pairFee) => {
5
- if (posDai === undefined ||
6
- leverage === undefined ||
7
- pairIndex === undefined ||
8
- pairFee === undefined) {
9
- return 0;
10
- }
11
- const { closeFeeP, nftLimitOrderFeeP } = pairFee;
12
- return (closeFeeP + nftLimitOrderFeeP) * posDai * leverage;
13
- };
14
- exports.getClosingFee = getClosingFee;
15
- const getFundingFee = (leveragedPosDai, initialAccFundingFees, buy, openedAfterUpdate, context) => {
16
- const { pairParams, pairFundingFees, openInterest, currentBlock } = context;
17
- if (!currentBlock ||
18
- !openedAfterUpdate ||
19
- pairParams === undefined ||
20
- pairFundingFees === undefined ||
21
- openInterest === undefined)
22
- return 0;
23
- const { accPerOiLong, accPerOiShort, lastUpdateBlock } = pairFundingFees;
24
- const { fundingFeePerBlockP } = pairParams;
25
- const { long: longOi, short: shortOi } = openInterest;
26
- const fundingFeesPaidByLongs = (longOi - shortOi) * fundingFeePerBlockP * (currentBlock - lastUpdateBlock);
27
- const pendingAccFundingFees = buy
28
- ? accPerOiLong + fundingFeesPaidByLongs / longOi
29
- : accPerOiShort + (fundingFeesPaidByLongs * -1) / shortOi;
30
- return leveragedPosDai * (pendingAccFundingFees - initialAccFundingFees);
31
- };
32
- exports.getFundingFee = getFundingFee;
33
- const getRolloverFee = (posDai, initialAccRolloverFees, openedAfterUpdate, context) => {
34
- const { pairParams, pairRolloverFees, currentBlock } = context;
35
- if (!currentBlock ||
36
- !openedAfterUpdate ||
37
- pairParams === undefined ||
38
- pairRolloverFees === undefined)
39
- return 0;
40
- const { accPerCollateral, lastUpdateBlock } = pairRolloverFees;
41
- const { rolloverFeePerBlockP } = pairParams;
42
- const pendingAccRolloverFees = accPerCollateral + (currentBlock - lastUpdateBlock) * rolloverFeePerBlockP;
43
- return posDai * (pendingAccRolloverFees - initialAccRolloverFees);
44
- };
45
- exports.getRolloverFee = getRolloverFee;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getRolloverFee = exports.getFundingFee = exports.getClosingFee = void 0;
4
+ const getClosingFee = (posDai, leverage, pairIndex, pairFee) => {
5
+ if (posDai === undefined ||
6
+ leverage === undefined ||
7
+ pairIndex === undefined ||
8
+ pairFee === undefined) {
9
+ return 0;
10
+ }
11
+ const { closeFeeP, nftLimitOrderFeeP } = pairFee;
12
+ return (closeFeeP + nftLimitOrderFeeP) * posDai * leverage;
13
+ };
14
+ exports.getClosingFee = getClosingFee;
15
+ const getFundingFee = (leveragedPosDai, initialAccFundingFees, buy, openedAfterUpdate, context) => {
16
+ const { pairParams, pairFundingFees, openInterest, currentBlock } = context;
17
+ if (!currentBlock ||
18
+ !openedAfterUpdate ||
19
+ pairParams === undefined ||
20
+ pairFundingFees === undefined ||
21
+ openInterest === undefined)
22
+ return 0;
23
+ const { accPerOiLong, accPerOiShort, lastUpdateBlock } = pairFundingFees;
24
+ const { fundingFeePerBlockP } = pairParams;
25
+ const { long: longOi, short: shortOi } = openInterest;
26
+ const fundingFeesPaidByLongs = (longOi - shortOi) * fundingFeePerBlockP * (currentBlock - lastUpdateBlock);
27
+ const pendingAccFundingFees = buy
28
+ ? accPerOiLong + fundingFeesPaidByLongs / longOi
29
+ : accPerOiShort + (fundingFeesPaidByLongs * -1) / shortOi;
30
+ return leveragedPosDai * (pendingAccFundingFees - initialAccFundingFees);
31
+ };
32
+ exports.getFundingFee = getFundingFee;
33
+ const getRolloverFee = (posDai, initialAccRolloverFees, openedAfterUpdate, context) => {
34
+ const { pairParams, pairRolloverFees, currentBlock } = context;
35
+ if (!currentBlock ||
36
+ !openedAfterUpdate ||
37
+ pairParams === undefined ||
38
+ pairRolloverFees === undefined)
39
+ return 0;
40
+ const { accPerCollateral, lastUpdateBlock } = pairRolloverFees;
41
+ const { rolloverFeePerBlockP } = pairParams;
42
+ const pendingAccRolloverFees = accPerCollateral + (currentBlock - lastUpdateBlock) * rolloverFeePerBlockP;
43
+ return posDai * (pendingAccRolloverFees - initialAccRolloverFees);
44
+ };
45
+ exports.getRolloverFee = getRolloverFee;
@@ -1,2 +1,2 @@
1
- export * from "./fees";
2
- export * from "./pnl";
1
+ export * from "./fees";
2
+ export * from "./pnl";
@@ -1,18 +1,18 @@
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("./fees"), exports);
18
- __exportStar(require("./pnl"), exports);
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("./fees"), exports);
18
+ __exportStar(require("./pnl"), exports);
@@ -1,7 +1,7 @@
1
- import { GetFundingFeeContext, GetRolloverFeeContext } from "./fees";
2
- import { Fee, Trade, TradeInfo, TradeInitialAccFees } from "./types";
3
- export type GetPnlContext = {
4
- fee: Fee | undefined;
5
- maxGainP: number | undefined;
6
- } & GetRolloverFeeContext & GetFundingFeeContext;
7
- export declare const getPnl: (price: number | undefined, trade: Trade, tradeInfo: TradeInfo, initialAccFees: TradeInitialAccFees, useFees: boolean, context: GetPnlContext) => number[] | undefined;
1
+ import { GetFundingFeeContext, GetRolloverFeeContext } from "./fees";
2
+ import { Fee, Trade, TradeInfo, TradeInitialAccFees } from "./types";
3
+ export type GetPnlContext = {
4
+ fee: Fee | undefined;
5
+ maxGainP: number | undefined;
6
+ } & GetRolloverFeeContext & GetFundingFeeContext;
7
+ 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,43 +1,43 @@
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, currentBlock, pairParams, pairRolloverFees, pairFundingFees, openInterest, fee, } = 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,
20
- pairParams,
21
- pairRolloverFees,
22
- });
23
- pnlDai -= (0, fees_1.getFundingFee)(posDai * trade.leverage, initialAccFees.funding, trade.buy, initialAccFees.openedAfterUpdate, {
24
- currentBlock,
25
- pairParams,
26
- pairFundingFees,
27
- openInterest,
28
- });
29
- }
30
- let pnlPercentage = (pnlDai / posDai) * 100;
31
- // Can be liquidated
32
- if (pnlPercentage <= -90) {
33
- pnlPercentage = -100;
34
- }
35
- else {
36
- pnlDai -= (0, fees_1.getClosingFee)(posDai, trade.leverage, trade.pairIndex, fee);
37
- pnlPercentage = (pnlDai / posDai) * 100;
38
- }
39
- pnlPercentage = pnlPercentage < -100 ? -100 : pnlPercentage;
40
- pnlDai = (posDai * pnlPercentage) / 100;
41
- return [pnlDai, pnlPercentage];
42
- };
43
- 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, currentBlock, pairParams, pairRolloverFees, pairFundingFees, openInterest, fee, } = 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,
20
+ pairParams,
21
+ pairRolloverFees,
22
+ });
23
+ pnlDai -= (0, fees_1.getFundingFee)(posDai * trade.leverage, initialAccFees.funding, trade.buy, initialAccFees.openedAfterUpdate, {
24
+ currentBlock,
25
+ pairParams,
26
+ pairFundingFees,
27
+ openInterest,
28
+ });
29
+ }
30
+ let pnlPercentage = (pnlDai / posDai) * 100;
31
+ // Can be liquidated
32
+ if (pnlPercentage <= -90) {
33
+ pnlPercentage = -100;
34
+ }
35
+ else {
36
+ pnlDai -= (0, fees_1.getClosingFee)(posDai, trade.leverage, trade.pairIndex, fee);
37
+ pnlPercentage = (pnlDai / posDai) * 100;
38
+ }
39
+ pnlPercentage = pnlPercentage < -100 ? -100 : pnlPercentage;
40
+ pnlDai = (posDai * pnlPercentage) / 100;
41
+ return [pnlDai, pnlPercentage];
42
+ };
43
+ exports.getPnl = getPnl;
@@ -1,143 +1,157 @@
1
- export type PairIndexes = {
2
- [key: string]: number;
3
- };
4
- export type TradeContainer = {
5
- trade: Trade;
6
- tradeInfo: TradeInfo;
7
- initialAccFees: TradeInitialAccFees;
8
- };
9
- export type Trade = {
10
- buy: boolean;
11
- index: number;
12
- initialPosToken: number;
13
- leverage: number;
14
- openPrice: number;
15
- pairIndex: number;
16
- sl: number;
17
- tp: number;
18
- trader: string;
19
- };
20
- export type TradeInfo = {
21
- openInterestDai: number;
22
- slLastUpdated: number;
23
- tokenPriceDai: number;
24
- tpLastUpdated: number;
25
- };
26
- export type TradeInitialAccFees = {
27
- rollover: number;
28
- funding: number;
29
- openedAfterUpdate: boolean;
30
- };
31
- export type TradingGroup = {
32
- maxCollateralP: number;
33
- maxLeverage: number;
34
- minLeverage: number;
35
- name: string;
36
- };
37
- export type LimitOrder = {
38
- block: number;
39
- buy: boolean;
40
- index: number;
41
- leverage: number;
42
- maxPrice: number;
43
- minPrice: number;
44
- pairIndex: number;
45
- positionSize: number;
46
- sl: number;
47
- spreadReductionP: number;
48
- tp: number;
49
- trader: string;
50
- type: number;
51
- };
52
- export type Fee = {
53
- closeFeeP: number;
54
- minLevPosDai: number;
55
- nftLimitOrderFeeP: number;
56
- openFeeP: number;
57
- referralFeeP: number;
58
- };
59
- export type OpenInterest = {
60
- long: number;
61
- max: number;
62
- short: number;
63
- };
64
- export type OpenCollateral = {
65
- long: number;
66
- short: number;
67
- };
68
- export type PairParams = {
69
- onePercentDepthAbove: number;
70
- onePercentDepthBelow: number;
71
- rolloverFeePerBlockP: number;
72
- fundingFeePerBlockP: number;
73
- };
74
- export type PairRolloverFees = {
75
- accPerCollateral: number;
76
- lastUpdateBlock: number;
77
- };
78
- export type PairFundingFees = {
79
- accPerOiLong: number;
80
- accPerOiShort: number;
81
- lastUpdateBlock: number;
82
- };
83
- export type Pair = {
84
- name: string;
85
- from: string;
86
- to: string;
87
- feeIndex: number;
88
- groupIndex: number;
89
- pairIndex: number;
90
- spreadP: number;
91
- };
92
- export type TradeHistoryRecord = {
93
- action: string;
94
- address: string;
95
- buy: number;
96
- date: string;
97
- leverage: number;
98
- pair: string;
99
- pnl_net: number;
100
- price: number;
101
- size: number;
102
- tx: string;
103
- };
104
- export type MarketOrder = {
105
- trader: string;
106
- pairIndex: number;
107
- index: number;
108
- block: number;
109
- open: boolean;
110
- };
111
- export type ChartBar = {
112
- close: number;
113
- high: number;
114
- isBarClosed: boolean;
115
- isLastBar: boolean;
116
- low: number;
117
- open: number;
118
- time: number;
119
- };
120
- export type LeaderboardTrader = {
121
- address: string;
122
- tradesCount: number;
123
- winrate: number;
124
- pnl: number;
125
- volume: number;
126
- score: number;
127
- };
128
- export type OpenTradeParams = [
129
- address: string,
130
- pairIndex: number,
131
- x1: number,
132
- x2: number,
133
- wei: number,
134
- price: string,
135
- buy: boolean,
136
- leverage: number,
137
- takeProfit: string,
138
- stopLoss: string
139
- ];
140
- export declare enum PositionType {
141
- LONG = "LONG",
142
- SHORT = "SHORT"
143
- }
1
+ import { GFarmTradingStorageV5 } from "@/contracts/types/generated";
2
+ import { BigNumber } from "ethers";
3
+ export type PairIndexes = {
4
+ [key: string]: number;
5
+ };
6
+ export type TradeContainer = {
7
+ trade: Trade;
8
+ tradeInfo: TradeInfo;
9
+ initialAccFees: TradeInitialAccFees;
10
+ };
11
+ export type Trade = {
12
+ buy: boolean;
13
+ index: number;
14
+ initialPosToken: number;
15
+ leverage: number;
16
+ openPrice: number;
17
+ pairIndex: number;
18
+ sl: number;
19
+ tp: number;
20
+ trader: string;
21
+ };
22
+ export type TradeInfo = {
23
+ openInterestDai: number;
24
+ slLastUpdated: number;
25
+ tokenPriceDai: number;
26
+ tpLastUpdated: number;
27
+ };
28
+ export type TradeInitialAccFees = {
29
+ rollover: number;
30
+ funding: number;
31
+ openedAfterUpdate: boolean;
32
+ };
33
+ export type TradingGroup = {
34
+ maxCollateralP: number;
35
+ maxLeverage: number;
36
+ minLeverage: number;
37
+ name: string;
38
+ };
39
+ export type LimitOrder = {
40
+ block: number;
41
+ buy: boolean;
42
+ index: number;
43
+ leverage: number;
44
+ maxPrice: number;
45
+ minPrice: number;
46
+ pairIndex: number;
47
+ positionSize: number;
48
+ sl: number;
49
+ spreadReductionP: number;
50
+ tp: number;
51
+ trader: string;
52
+ type: number;
53
+ };
54
+ export type LimitOrderRaw = GFarmTradingStorageV5.OpenLimitOrderStructOutput & {
55
+ type: number;
56
+ };
57
+ export type Fee = {
58
+ closeFeeP: number;
59
+ minLevPosDai: number;
60
+ nftLimitOrderFeeP: number;
61
+ openFeeP: number;
62
+ referralFeeP: number;
63
+ };
64
+ export type OpenInterest = {
65
+ long: number;
66
+ max: number;
67
+ short: number;
68
+ };
69
+ export type OpenCollateral = {
70
+ long: number;
71
+ short: number;
72
+ };
73
+ export type PairParams = {
74
+ onePercentDepthAbove: number;
75
+ onePercentDepthBelow: number;
76
+ rolloverFeePerBlockP: number;
77
+ fundingFeePerBlockP: number;
78
+ };
79
+ export type PairRolloverFees = {
80
+ accPerCollateral: number;
81
+ lastUpdateBlock: number;
82
+ };
83
+ export type PairFundingFees = {
84
+ accPerOiLong: number;
85
+ accPerOiShort: number;
86
+ lastUpdateBlock: number;
87
+ };
88
+ export type Pair = {
89
+ name: string;
90
+ from: string;
91
+ to: string;
92
+ feeIndex: number;
93
+ groupIndex: number;
94
+ pairIndex: number;
95
+ spreadP: number;
96
+ };
97
+ export type TradeHistoryRecord = {
98
+ action: string;
99
+ address: string;
100
+ buy: number;
101
+ date: string;
102
+ leverage: number;
103
+ pair: string;
104
+ pnl_net: number;
105
+ price: number;
106
+ size: number;
107
+ tx: string;
108
+ };
109
+ export type MarketOrder = {
110
+ trader: string;
111
+ pairIndex: number;
112
+ index: number;
113
+ block: number;
114
+ open: boolean;
115
+ };
116
+ export type ChartBar = {
117
+ close: number;
118
+ high: number;
119
+ isBarClosed: boolean;
120
+ isLastBar: boolean;
121
+ low: number;
122
+ open: number;
123
+ time: number;
124
+ };
125
+ export type LeaderboardTrader = {
126
+ address: string;
127
+ tradesCount: number;
128
+ winrate: number;
129
+ pnl: number;
130
+ volume: number;
131
+ score: number;
132
+ };
133
+ export type OpenTradeParams = [
134
+ address: string,
135
+ pairIndex: number,
136
+ x1: number,
137
+ x2: number,
138
+ wei: number,
139
+ price: string,
140
+ buy: boolean,
141
+ leverage: number,
142
+ takeProfit: string,
143
+ stopLoss: string
144
+ ];
145
+ export declare enum PositionType {
146
+ LONG = "LONG",
147
+ SHORT = "SHORT"
148
+ }
149
+ export type TradeContainerRaw = {
150
+ trade: GFarmTradingStorageV5.TradeStruct;
151
+ tradeInfo: GFarmTradingStorageV5.TradeInfoStruct;
152
+ initialAccFees: {
153
+ rollover: BigNumber;
154
+ funding: BigNumber;
155
+ openedAfterUpdate: boolean;
156
+ };
157
+ };
@@ -1,8 +1,8 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.PositionType = void 0;
4
- var PositionType;
5
- (function (PositionType) {
6
- PositionType["LONG"] = "LONG";
7
- PositionType["SHORT"] = "SHORT";
8
- })(PositionType = exports.PositionType || (exports.PositionType = {}));
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PositionType = void 0;
4
+ var PositionType;
5
+ (function (PositionType) {
6
+ PositionType["LONG"] = "LONG";
7
+ PositionType["SHORT"] = "SHORT";
8
+ })(PositionType = exports.PositionType || (exports.PositionType = {}));