@gainsnetwork/sdk 0.1.17-rc2 → 0.1.19-rc1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -214,6 +214,10 @@ export declare const pairs: {
214
214
  "ETHFI/USD": string;
215
215
  "METIS/USD": string;
216
216
  "AEVO/USD": string;
217
+ "ONDO/USD": string;
218
+ "MNT/USD": string;
219
+ "KAS/USD": string;
220
+ "RON/USD": string;
217
221
  };
218
222
  export declare const getAssetClassFromGroupIndex: (groupIndex: number) => string | undefined;
219
223
  export declare const tickerChanges: {
package/lib/constants.js CHANGED
@@ -222,6 +222,10 @@ exports.pairs = {
222
222
  "ETHFI/USD": CRYPTO,
223
223
  "METIS/USD": CRYPTO,
224
224
  "AEVO/USD": CRYPTO,
225
+ "ONDO/USD": CRYPTO,
226
+ "MNT/USD": CRYPTO,
227
+ "KAS/USD": CRYPTO,
228
+ "RON/USD": CRYPTO,
225
229
  };
226
230
  const getAssetClassFromGroupIndex = (groupIndex) => {
227
231
  switch (groupIndex) {
@@ -256,6 +260,6 @@ exports.delistedPairIxs = new Set([
256
260
  6, 31, 36, 42, 45, 48, 50, 51, 54, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68,
257
261
  69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87,
258
262
  88, 89, 97, 99, 101, 106, 107, 108, 52, 131, 147, 157, 160, 179, 182, 183,
259
- 190, 194,
263
+ 190, 194, 215, 216, 217, 218
260
264
  ]);
261
265
  exports.delistedGroupsIxs = new Set([6, 7]);
@@ -317,4 +317,8 @@ const PAIR_INDEX_TO_DESCRIPTION = {
317
317
  [types_1.PairIndex.ETHFIUSD]: "EtherFi to US Dollar",
318
318
  [types_1.PairIndex.METISUSD]: "Metis to US Dollar",
319
319
  [types_1.PairIndex.AEVOUSD]: "Aevo to US Dollar",
320
+ [types_1.PairIndex.ONDOUSD]: "Ondo to US Dollar",
321
+ [types_1.PairIndex.MNTUSD]: "Mantle to US Dollar",
322
+ [types_1.PairIndex.KASUSD]: "Kaspa to US Dollar",
323
+ [types_1.PairIndex.RONUSD]: "Ronin to US Dollar",
320
324
  };
@@ -1,3 +1,4 @@
1
1
  import { Fee, PairIndex } from "../types";
2
2
  export declare const getClosingFee: (posDai: number, leverage: number, pairIndex: PairIndex, pairFee: Fee | undefined) => number;
3
3
  export * from "./borrowing";
4
+ export * from "./tiers";
@@ -27,3 +27,4 @@ const getClosingFee = (posDai, leverage, pairIndex, pairFee) => {
27
27
  };
28
28
  exports.getClosingFee = getClosingFee;
29
29
  __exportStar(require("./borrowing"), exports);
30
+ __exportStar(require("./tiers"), exports);
@@ -0,0 +1,7 @@
1
+ import { FeeTier, TraderDailyInfo, TraderInfo } from "./types";
2
+ export declare const TRAILING_PERIOD_DAYS = 30;
3
+ export declare const FEE_MULTIPLIER_SCALE = 1;
4
+ export declare const MAX_FEE_TIERS = 8;
5
+ export declare const getCurrentDay: () => number;
6
+ export declare const getFeeTiersCount: (feeTiers: FeeTier[]) => number;
7
+ export declare const computeFeeMulitplier: (traderInfo: TraderInfo, traderDailyInfo: Record<number, TraderDailyInfo>, feeTiers: FeeTier[]) => number;
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.computeFeeMulitplier = exports.getFeeTiersCount = exports.getCurrentDay = exports.MAX_FEE_TIERS = exports.FEE_MULTIPLIER_SCALE = exports.TRAILING_PERIOD_DAYS = void 0;
4
+ exports.TRAILING_PERIOD_DAYS = 30;
5
+ exports.FEE_MULTIPLIER_SCALE = 1;
6
+ exports.MAX_FEE_TIERS = 8;
7
+ const getCurrentDay = () => Math.floor(Date.now() / 1000 / 60 / 60 / 24);
8
+ exports.getCurrentDay = getCurrentDay;
9
+ const getFeeTiersCount = (feeTiers) => {
10
+ for (let i = exports.MAX_FEE_TIERS; i > 0; --i) {
11
+ if (feeTiers[i - 1].feeMultiplier > 0) {
12
+ return i;
13
+ }
14
+ }
15
+ return 0;
16
+ };
17
+ exports.getFeeTiersCount = getFeeTiersCount;
18
+ const computeFeeMulitplier = (traderInfo, traderDailyInfo, feeTiers) => {
19
+ const currentDay = (0, exports.getCurrentDay)();
20
+ if (currentDay > traderInfo.lastDayUpdated) {
21
+ let curTrailingPoints = 0;
22
+ const earliestActiveDay = currentDay - exports.TRAILING_PERIOD_DAYS;
23
+ if (traderInfo.lastDayUpdated >= earliestActiveDay) {
24
+ curTrailingPoints =
25
+ traderInfo.trailingPoints +
26
+ traderDailyInfo[traderInfo.lastDayUpdated].points;
27
+ const earliestOutdatedDay = traderInfo.lastDayUpdated - exports.TRAILING_PERIOD_DAYS;
28
+ const lastOutdatedDay = earliestActiveDay - 1;
29
+ let expiredTrailingPoints = 0;
30
+ for (let i = earliestOutdatedDay; i <= lastOutdatedDay; ++i) {
31
+ expiredTrailingPoints += traderDailyInfo[i].points;
32
+ }
33
+ curTrailingPoints -= expiredTrailingPoints;
34
+ }
35
+ let newFeeMultiplier = exports.FEE_MULTIPLIER_SCALE;
36
+ for (let i = (0, exports.getFeeTiersCount)(feeTiers); i > 0; --i) {
37
+ const feeTier = feeTiers[i - 1];
38
+ if (curTrailingPoints >= feeTier.pointsThreshold) {
39
+ newFeeMultiplier = feeTier.feeMultiplier;
40
+ break;
41
+ }
42
+ }
43
+ return newFeeMultiplier;
44
+ }
45
+ return exports.FEE_MULTIPLIER_SCALE;
46
+ };
47
+ exports.computeFeeMulitplier = computeFeeMulitplier;
@@ -0,0 +1,12 @@
1
+ export type FeeTier = {
2
+ feeMultiplier: number;
3
+ pointsThreshold: number;
4
+ };
5
+ export type TraderInfo = {
6
+ lastDayUpdated: number;
7
+ trailingPoints: number;
8
+ };
9
+ export type TraderDailyInfo = {
10
+ feeMultiplierCache: number;
11
+ points: number;
12
+ };
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -2,6 +2,7 @@ import { GFarmTradingStorageV5 } from "../contracts/types/generated";
2
2
  import { IGNSTradingCallbacks } from "../contracts/types/generated/GNSTradingCallbacks";
3
3
  import { BigNumber } from "ethers";
4
4
  import { BorrowingFee } from "./fees/borrowing";
5
+ import { FeeTier, TraderInfo } from "./fees/tiers/types";
5
6
  export type PairIndexes = {
6
7
  [key: string]: PairIndex;
7
8
  };
@@ -180,6 +181,17 @@ export type CollateralConfig = {
180
181
  precisionDelta: number;
181
182
  decimals?: number;
182
183
  };
184
+ export type FeeTiers = {
185
+ tiers: FeeTier[];
186
+ multipliers: number[];
187
+ currentDay: number;
188
+ };
189
+ export type TraderFeeTiers = {
190
+ traderInfo: TraderInfo;
191
+ inboundPoints: number;
192
+ outboundPoints: number;
193
+ expiredPoints: number[];
194
+ };
183
195
  export declare enum PairIndex {
184
196
  BTCUSD = 0,
185
197
  ETHUSD = 1,
@@ -395,5 +407,9 @@ export declare enum PairIndex {
395
407
  BOMEUSD = 211,
396
408
  ETHFIUSD = 212,
397
409
  METISUSD = 213,
398
- AEVOUSD = 214
410
+ AEVOUSD = 214,
411
+ ONDOUSD = 215,
412
+ MNTUSD = 216,
413
+ KASUSD = 217,
414
+ RONUSD = 218
399
415
  }
@@ -229,4 +229,8 @@ var PairIndex;
229
229
  PairIndex[PairIndex["ETHFIUSD"] = 212] = "ETHFIUSD";
230
230
  PairIndex[PairIndex["METISUSD"] = 213] = "METISUSD";
231
231
  PairIndex[PairIndex["AEVOUSD"] = 214] = "AEVOUSD";
232
+ PairIndex[PairIndex["ONDOUSD"] = 215] = "ONDOUSD";
233
+ PairIndex[PairIndex["MNTUSD"] = 216] = "MNTUSD";
234
+ PairIndex[PairIndex["KASUSD"] = 217] = "KASUSD";
235
+ PairIndex[PairIndex["RONUSD"] = 218] = "RONUSD";
232
236
  })(PairIndex = exports.PairIndex || (exports.PairIndex = {}));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gainsnetwork/sdk",
3
- "version": "0.1.17-rc2",
3
+ "version": "0.1.19-rc1",
4
4
  "description": "Gains Network SDK",
5
5
  "main": "./lib/index.js",
6
6
  "files": [