@gainsnetwork/sdk 0.0.13 → 0.0.14-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/README.md +11 -11
- package/lib/contracts/addresses.d.ts +2 -2
- package/lib/contracts/addresses.js +15 -15
- package/lib/contracts/addresses.json +20 -20
- package/lib/contracts/index.d.ts +6 -6
- package/lib/contracts/index.js +31 -31
- package/lib/contracts/types/GFarmTradingStorageV5.d.ts +1911 -0
- package/lib/contracts/types/GFarmTradingStorageV5.js +2 -0
- package/lib/contracts/types/GNSPairInfosV6_1.d.ts +911 -0
- package/lib/contracts/types/GNSPairInfosV6_1.js +2 -0
- package/lib/contracts/types/GNSPairsStorageV6.d.ts +660 -0
- package/lib/contracts/types/GNSPairsStorageV6.js +2 -0
- package/lib/contracts/types/common.d.ts +22 -0
- package/lib/contracts/types/common.js +2 -0
- package/lib/contracts/types/factories/GFarmTradingStorageV5__factory.d.ts +83 -0
- package/lib/contracts/types/factories/GFarmTradingStorageV5__factory.js +2691 -0
- package/lib/contracts/types/factories/GNSPairInfosV6_1__factory.d.ts +98 -0
- package/lib/contracts/types/factories/GNSPairInfosV6_1__factory.js +1485 -0
- package/lib/contracts/types/factories/GNSPairsStorageV6__factory.d.ts +117 -0
- package/lib/contracts/types/factories/GNSPairsStorageV6__factory.js +1265 -0
- package/lib/contracts/types/factories/index.d.ts +3 -0
- package/lib/contracts/types/factories/index.js +12 -0
- package/lib/contracts/types/generated/GFarmTradingStorageV5.d.ts +1911 -1911
- package/lib/contracts/types/generated/GFarmTradingStorageV5.js +2 -2
- package/lib/contracts/types/generated/GNSPairInfosV6_1.d.ts +911 -911
- package/lib/contracts/types/generated/GNSPairInfosV6_1.js +2 -2
- package/lib/contracts/types/generated/GNSPairsStorageV6.d.ts +660 -660
- package/lib/contracts/types/generated/GNSPairsStorageV6.js +2 -2
- package/lib/contracts/types/generated/GTokenOpenPnlFeed.d.ts +557 -557
- package/lib/contracts/types/generated/GTokenOpenPnlFeed.js +2 -2
- package/lib/contracts/types/generated/common.d.ts +22 -22
- package/lib/contracts/types/generated/common.js +2 -2
- package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.d.ts +83 -83
- package/lib/contracts/types/generated/factories/GFarmTradingStorageV5__factory.js +2691 -2691
- package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.d.ts +98 -98
- package/lib/contracts/types/generated/factories/GNSPairInfosV6_1__factory.js +1485 -1485
- package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.d.ts +117 -117
- package/lib/contracts/types/generated/factories/GNSPairsStorageV6__factory.js +1265 -1265
- package/lib/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.d.ts +59 -59
- package/lib/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.js +765 -765
- package/lib/contracts/types/generated/factories/index.d.ts +4 -4
- package/lib/contracts/types/generated/factories/index.js +14 -14
- package/lib/contracts/types/generated/index.d.ts +9 -9
- package/lib/contracts/types/generated/index.js +35 -35
- package/lib/contracts/types/index.d.ts +13 -13
- package/lib/contracts/types/index.js +2 -2
- package/lib/contracts/utils/index.d.ts +2 -2
- package/lib/contracts/utils/index.js +18 -18
- package/lib/contracts/utils/openTrades.d.ts +3 -3
- package/lib/contracts/utils/openTrades.js +202 -116
- package/lib/contracts/utils/openTradesOriginal.d.ts +3 -0
- package/lib/contracts/utils/openTradesOriginal.js +134 -0
- package/lib/contracts/utils/pairs.d.ts +6 -6
- package/lib/contracts/utils/pairs.js +102 -102
- package/lib/index.d.ts +3 -3
- package/lib/index.js +19 -19
- package/lib/markets/commodities.d.ts +1 -1
- package/lib/markets/commodities.js +31 -31
- package/lib/markets/crypto.d.ts +1 -1
- package/lib/markets/crypto.js +6 -6
- package/lib/markets/forex.d.ts +2 -2
- package/lib/markets/forex.js +38 -38
- package/lib/markets/index.d.ts +5 -5
- package/lib/markets/index.js +21 -21
- package/lib/markets/indices.d.ts +1 -1
- package/lib/markets/indices.js +6 -6
- package/lib/markets/stocks.d.ts +3 -3
- package/lib/markets/stocks.js +54 -54
- package/lib/src/contracts/addresses.d.ts +2 -0
- package/lib/src/contracts/addresses.js +15 -0
- package/lib/src/contracts/addresses.json +20 -0
- package/lib/src/contracts/index.d.ts +6 -0
- package/lib/src/contracts/index.js +31 -0
- package/lib/src/contracts/types/generated/GFarmTradingStorageV5.d.ts +1911 -0
- package/lib/src/contracts/types/generated/GFarmTradingStorageV5.js +2 -0
- package/lib/src/contracts/types/generated/GNSPairInfosV6_1.d.ts +911 -0
- package/lib/src/contracts/types/generated/GNSPairInfosV6_1.js +2 -0
- package/lib/src/contracts/types/generated/GNSPairsStorageV6.d.ts +660 -0
- package/lib/src/contracts/types/generated/GNSPairsStorageV6.js +2 -0
- package/lib/src/contracts/types/generated/GTokenOpenPnlFeed.d.ts +557 -0
- package/lib/src/contracts/types/generated/GTokenOpenPnlFeed.js +2 -0
- package/lib/src/contracts/types/generated/common.d.ts +22 -0
- package/lib/src/contracts/types/generated/common.js +2 -0
- package/lib/src/contracts/types/generated/factories/GFarmTradingStorageV5__factory.d.ts +83 -0
- package/lib/src/contracts/types/generated/factories/GFarmTradingStorageV5__factory.js +2691 -0
- package/lib/src/contracts/types/generated/factories/GNSPairInfosV6_1__factory.d.ts +98 -0
- package/lib/src/contracts/types/generated/factories/GNSPairInfosV6_1__factory.js +1485 -0
- package/lib/src/contracts/types/generated/factories/GNSPairsStorageV6__factory.d.ts +117 -0
- package/lib/src/contracts/types/generated/factories/GNSPairsStorageV6__factory.js +1265 -0
- package/lib/src/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.d.ts +59 -0
- package/lib/src/contracts/types/generated/factories/GTokenOpenPnlFeed__factory.js +765 -0
- package/lib/src/contracts/types/generated/factories/index.d.ts +4 -0
- package/lib/src/contracts/types/generated/factories/index.js +14 -0
- package/lib/src/contracts/types/generated/index.d.ts +9 -0
- package/lib/src/contracts/types/generated/index.js +35 -0
- package/lib/src/contracts/types/index.d.ts +13 -0
- package/lib/src/contracts/types/index.js +2 -0
- package/lib/src/contracts/utils/index.d.ts +2 -0
- package/lib/src/contracts/utils/index.js +18 -0
- package/lib/src/contracts/utils/openTrades.d.ts +3 -0
- package/lib/src/contracts/utils/openTrades.js +107 -0
- package/lib/src/contracts/utils/pairs.d.ts +6 -0
- package/lib/src/contracts/utils/pairs.js +102 -0
- package/lib/src/index.d.ts +3 -0
- package/lib/src/index.js +19 -0
- package/lib/src/markets/commodities.d.ts +1 -0
- package/lib/src/markets/commodities.js +31 -0
- package/lib/src/markets/crypto.d.ts +1 -0
- package/lib/src/markets/crypto.js +6 -0
- package/lib/src/markets/forex.d.ts +2 -0
- package/lib/src/markets/forex.js +38 -0
- package/lib/src/markets/index.d.ts +5 -0
- package/lib/src/markets/index.js +21 -0
- package/lib/src/markets/indices.d.ts +1 -0
- package/lib/src/markets/indices.js +6 -0
- package/lib/src/markets/stocks.d.ts +3 -0
- package/lib/src/markets/stocks.js +54 -0
- package/lib/src/trade/fees.d.ts +15 -0
- package/lib/src/trade/fees.js +45 -0
- package/lib/src/trade/index.d.ts +2 -0
- package/lib/src/trade/index.js +18 -0
- package/lib/src/trade/pnl.d.ts +7 -0
- package/lib/src/trade/pnl.js +43 -0
- package/lib/src/trade/types.d.ts +143 -0
- package/lib/src/trade/types.js +8 -0
- package/lib/test/index.d.ts +1 -0
- package/lib/test/index.js +22 -0
- package/lib/test.d.ts +1 -0
- package/lib/test.js +27 -0
- package/lib/trade/fees.d.ts +15 -15
- package/lib/trade/fees.js +45 -45
- package/lib/trade/index.d.ts +2 -2
- package/lib/trade/index.js +18 -18
- package/lib/trade/pnl.d.ts +7 -7
- package/lib/trade/pnl.js +43 -43
- package/lib/trade/types.d.ts +143 -143
- package/lib/trade/types.js +8 -8
- package/package.json +104 -103
package/lib/markets/indices.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.isIndicesOpen = void 0;
|
|
4
|
-
const stocks_1 = require("./stocks");
|
|
5
|
-
const isIndicesOpen = (dateToCheck) => (0, stocks_1.isStocksOpen)(dateToCheck);
|
|
6
|
-
exports.isIndicesOpen = isIndicesOpen;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isIndicesOpen = void 0;
|
|
4
|
+
const stocks_1 = require("./stocks");
|
|
5
|
+
const isIndicesOpen = (dateToCheck) => (0, stocks_1.isStocksOpen)(dateToCheck);
|
|
6
|
+
exports.isIndicesOpen = isIndicesOpen;
|
package/lib/markets/stocks.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { DateTime } from "luxon";
|
|
2
|
-
export declare const isStocksOpen: (dateToCheck: Date) => boolean;
|
|
3
|
-
export declare const getUSMarketsNow: () => DateTime;
|
|
1
|
+
import { DateTime } from "luxon";
|
|
2
|
+
export declare const isStocksOpen: (dateToCheck: Date) => boolean;
|
|
3
|
+
export declare const getUSMarketsNow: () => DateTime;
|
package/lib/markets/stocks.js
CHANGED
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getUSMarketsNow = exports.isStocksOpen = void 0;
|
|
4
|
-
/* eslint-disable @typescript-eslint/no-unsafe-call */
|
|
5
|
-
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
|
6
|
-
// @ts-ignore-file
|
|
7
|
-
const luxon_1 = require("luxon");
|
|
8
|
-
const STOCKS_MARKETS_TIME_ZONE_IANA = luxon_1.IANAZone.create("America/New_York");
|
|
9
|
-
const isStocksOpen = (dateToCheck) => {
|
|
10
|
-
const now = luxon_1.DateTime.fromJSDate(dateToCheck).setZone(STOCKS_MARKETS_TIME_ZONE_IANA);
|
|
11
|
-
const weekday = now.weekday;
|
|
12
|
-
const hour = now.hour;
|
|
13
|
-
const dayOfMonth = now.day;
|
|
14
|
-
const month = now.month;
|
|
15
|
-
const minute = now.minute;
|
|
16
|
-
const isClosed =
|
|
17
|
-
// New Year's 2023
|
|
18
|
-
(month === 1 && dayOfMonth === 2) ||
|
|
19
|
-
// Martin Luther King, Jr. Day 2023
|
|
20
|
-
(month === 1 && dayOfMonth === 16) ||
|
|
21
|
-
// Washington's Birthday 2023
|
|
22
|
-
(month === 2 && dayOfMonth === 20) ||
|
|
23
|
-
// Good Friday 2023
|
|
24
|
-
(month === 4 && dayOfMonth === 7) ||
|
|
25
|
-
// Memorial Day 2023
|
|
26
|
-
(month === 5 && dayOfMonth === 29) ||
|
|
27
|
-
// Juneteenth National Independence Day 2023
|
|
28
|
-
(month === 6 && dayOfMonth === 19) ||
|
|
29
|
-
// Independence Day 2023
|
|
30
|
-
(month === 7 && dayOfMonth === 4) ||
|
|
31
|
-
// Labor Day 2023
|
|
32
|
-
(month === 9 && dayOfMonth === 4) ||
|
|
33
|
-
// Thanksgiving Day 2022
|
|
34
|
-
(month === 11 && dayOfMonth === 23) ||
|
|
35
|
-
// Friday after Thanksgiving Day 2023 (closes early at 1PM)
|
|
36
|
-
(month === 11 && dayOfMonth === 24 && hour >= 13) ||
|
|
37
|
-
// Christmas Day 2023
|
|
38
|
-
(month === 12 && dayOfMonth === 25) ||
|
|
39
|
-
// Saturday
|
|
40
|
-
weekday === 6 ||
|
|
41
|
-
// Sunday
|
|
42
|
-
weekday === 7 ||
|
|
43
|
-
// Mo-Fr Daily Opening
|
|
44
|
-
hour < 9 ||
|
|
45
|
-
(hour === 9 && minute < 30) ||
|
|
46
|
-
// Mo-Fr Daily Closing
|
|
47
|
-
hour >= 16;
|
|
48
|
-
return !isClosed;
|
|
49
|
-
};
|
|
50
|
-
exports.isStocksOpen = isStocksOpen;
|
|
51
|
-
const getUSMarketsNow = () => {
|
|
52
|
-
return luxon_1.DateTime.now().setZone(STOCKS_MARKETS_TIME_ZONE_IANA);
|
|
53
|
-
};
|
|
54
|
-
exports.getUSMarketsNow = getUSMarketsNow;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getUSMarketsNow = exports.isStocksOpen = void 0;
|
|
4
|
+
/* eslint-disable @typescript-eslint/no-unsafe-call */
|
|
5
|
+
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
|
6
|
+
// @ts-ignore-file
|
|
7
|
+
const luxon_1 = require("luxon");
|
|
8
|
+
const STOCKS_MARKETS_TIME_ZONE_IANA = luxon_1.IANAZone.create("America/New_York");
|
|
9
|
+
const isStocksOpen = (dateToCheck) => {
|
|
10
|
+
const now = luxon_1.DateTime.fromJSDate(dateToCheck).setZone(STOCKS_MARKETS_TIME_ZONE_IANA);
|
|
11
|
+
const weekday = now.weekday;
|
|
12
|
+
const hour = now.hour;
|
|
13
|
+
const dayOfMonth = now.day;
|
|
14
|
+
const month = now.month;
|
|
15
|
+
const minute = now.minute;
|
|
16
|
+
const isClosed =
|
|
17
|
+
// New Year's 2023
|
|
18
|
+
(month === 1 && dayOfMonth === 2) ||
|
|
19
|
+
// Martin Luther King, Jr. Day 2023
|
|
20
|
+
(month === 1 && dayOfMonth === 16) ||
|
|
21
|
+
// Washington's Birthday 2023
|
|
22
|
+
(month === 2 && dayOfMonth === 20) ||
|
|
23
|
+
// Good Friday 2023
|
|
24
|
+
(month === 4 && dayOfMonth === 7) ||
|
|
25
|
+
// Memorial Day 2023
|
|
26
|
+
(month === 5 && dayOfMonth === 29) ||
|
|
27
|
+
// Juneteenth National Independence Day 2023
|
|
28
|
+
(month === 6 && dayOfMonth === 19) ||
|
|
29
|
+
// Independence Day 2023
|
|
30
|
+
(month === 7 && dayOfMonth === 4) ||
|
|
31
|
+
// Labor Day 2023
|
|
32
|
+
(month === 9 && dayOfMonth === 4) ||
|
|
33
|
+
// Thanksgiving Day 2022
|
|
34
|
+
(month === 11 && dayOfMonth === 23) ||
|
|
35
|
+
// Friday after Thanksgiving Day 2023 (closes early at 1PM)
|
|
36
|
+
(month === 11 && dayOfMonth === 24 && hour >= 13) ||
|
|
37
|
+
// Christmas Day 2023
|
|
38
|
+
(month === 12 && dayOfMonth === 25) ||
|
|
39
|
+
// Saturday
|
|
40
|
+
weekday === 6 ||
|
|
41
|
+
// Sunday
|
|
42
|
+
weekday === 7 ||
|
|
43
|
+
// Mo-Fr Daily Opening
|
|
44
|
+
hour < 9 ||
|
|
45
|
+
(hour === 9 && minute < 30) ||
|
|
46
|
+
// Mo-Fr Daily Closing
|
|
47
|
+
hour >= 16;
|
|
48
|
+
return !isClosed;
|
|
49
|
+
};
|
|
50
|
+
exports.isStocksOpen = isStocksOpen;
|
|
51
|
+
const getUSMarketsNow = () => {
|
|
52
|
+
return luxon_1.DateTime.now().setZone(STOCKS_MARKETS_TIME_ZONE_IANA);
|
|
53
|
+
};
|
|
54
|
+
exports.getUSMarketsNow = getUSMarketsNow;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.getContractAddressesForChain = void 0;
|
|
7
|
+
const addresses_json_1 = __importDefault(require("./addresses.json"));
|
|
8
|
+
const getContractAddressesForChain = (chainId) => {
|
|
9
|
+
const _addresses = addresses_json_1.default;
|
|
10
|
+
if (!_addresses[chainId]) {
|
|
11
|
+
throw new Error(`Unknown chain id (${chainId}). No known contracts have been deployed on this chain.`);
|
|
12
|
+
}
|
|
13
|
+
return _addresses[chainId];
|
|
14
|
+
};
|
|
15
|
+
exports.getContractAddressesForChain = getContractAddressesForChain;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
{
|
|
2
|
+
"137": {
|
|
3
|
+
"gfarmTradingStorageV5": "0xaee4d11a16B2bc65EDD6416Fb626EB404a6D65BD",
|
|
4
|
+
"gnsPairsStorageV6": "0x6e5326e944F528c243B9Ca5d14fe5C9269a8c922",
|
|
5
|
+
"gnsPairInfosV6_1": "0xEe7442aCcC1C27f2C69423576d3b1D25b563E977",
|
|
6
|
+
"gTokenOpenPnlFeed": "0x8d687276543b92819F2f2B5C3faad4AD27F4440c"
|
|
7
|
+
},
|
|
8
|
+
"42161": {
|
|
9
|
+
"gfarmTradingStorageV5": "0xcFa6ebD475d89dB04cAd5A756fff1cb2BC5bE33c",
|
|
10
|
+
"gnsPairsStorageV6": "0xf67Df2a4339eC1591615d94599081Dd037960d4b",
|
|
11
|
+
"gnsPairInfosV6_1": "0x04a5e3cf21B0080B72fAcDca634349A56982D497",
|
|
12
|
+
"gTokenOpenPnlFeed": "0x990BA9Edd8a9615A23E4c452E63A80e519A4a23D"
|
|
13
|
+
},
|
|
14
|
+
"80001": {
|
|
15
|
+
"gfarmTradingStorageV5": "0x4d2dF485c608aa55A23d8d98dD2B4FA24Ba0f2Cf",
|
|
16
|
+
"gnsPairsStorageV6": "0xF7F324bc1D659f01A9a8d00C40d65568b25b4007",
|
|
17
|
+
"gnsPairInfosV6_1": "0xe780bBf94b0257fEDccF4EAEcBC70722E6F5F574",
|
|
18
|
+
"gTokenOpenPnlFeed": "0xA7C829CB2346E12DC49Fd5ea8002Abaf48E9396C"
|
|
19
|
+
}
|
|
20
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Signer } from "ethers";
|
|
2
|
+
import type { Provider } from "@ethersproject/providers";
|
|
3
|
+
import { Contracts } from "./types";
|
|
4
|
+
export declare const getContractsForChain: (chainId: number, signerOrProvider?: Signer | Provider) => Contracts;
|
|
5
|
+
export * from "./utils";
|
|
6
|
+
export * from "./addresses";
|
|
@@ -0,0 +1,31 @@
|
|
|
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
|
+
exports.getContractsForChain = void 0;
|
|
18
|
+
const addresses_1 = require("./addresses");
|
|
19
|
+
const factories_1 = require("./types/generated/factories");
|
|
20
|
+
const getContractsForChain = (chainId, signerOrProvider) => {
|
|
21
|
+
const addresses = (0, addresses_1.getContractAddressesForChain)(chainId);
|
|
22
|
+
return {
|
|
23
|
+
gfarmTradingStorageV5: factories_1.GFarmTradingStorageV5__factory.connect(addresses.gfarmTradingStorageV5, signerOrProvider),
|
|
24
|
+
gnsPairInfosV6_1: factories_1.GNSPairInfosV6_1__factory.connect(addresses.gnsPairInfosV6_1, signerOrProvider),
|
|
25
|
+
gnsPairsStorageV6: factories_1.GNSPairsStorageV6__factory.connect(addresses.gnsPairsStorageV6, signerOrProvider),
|
|
26
|
+
gTokenOpenPnlFeed: factories_1.GTokenOpenPnlFeed__factory.connect(addresses.gTokenOpenPnlFeed, signerOrProvider),
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
exports.getContractsForChain = getContractsForChain;
|
|
30
|
+
__exportStar(require("./utils"), exports);
|
|
31
|
+
__exportStar(require("./addresses"), exports);
|