@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.
- package/lib/constants.d.ts +4 -0
- package/lib/constants.js +5 -1
- package/lib/contracts/utils/pairs.js +4 -0
- package/lib/trade/fees/index.d.ts +1 -0
- package/lib/trade/fees/index.js +1 -0
- package/lib/trade/fees/tiers/index.d.ts +7 -0
- package/lib/trade/fees/tiers/index.js +47 -0
- package/lib/trade/fees/tiers/types.d.ts +12 -0
- package/lib/trade/fees/tiers/types.js +2 -0
- package/lib/trade/types.d.ts +17 -1
- package/lib/trade/types.js +4 -0
- package/package.json +1 -1
package/lib/constants.d.ts
CHANGED
|
@@ -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
|
};
|
package/lib/trade/fees/index.js
CHANGED
|
@@ -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;
|
package/lib/trade/types.d.ts
CHANGED
|
@@ -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
|
}
|
package/lib/trade/types.js
CHANGED
|
@@ -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 = {}));
|