@sonarwatch/portfolio-plugins 0.8.100 → 0.8.102
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/CHANGELOG.md +25 -17
- package/package.json +2 -2
- package/src/plugins/01/depostisFetcher.js +2 -0
- package/src/plugins/01/depostisFetcher.js.map +1 -1
- package/src/plugins/atrix/poolsV1Job.js +7 -7
- package/src/plugins/atrix/poolsV1Job.js.map +1 -1
- package/src/plugins/balancer/helpers/pools.js +21 -21
- package/src/plugins/goosefx/constants.d.ts +2 -0
- package/src/plugins/goosefx/constants.js +3 -1
- package/src/plugins/goosefx/constants.js.map +1 -1
- package/src/plugins/goosefx/filters.d.ts +1 -0
- package/src/plugins/goosefx/filters.js +11 -1
- package/src/plugins/goosefx/filters.js.map +1 -1
- package/src/plugins/goosefx/index.js +2 -1
- package/src/plugins/goosefx/index.js.map +1 -1
- package/src/plugins/goosefx/stakingFetcher.d.ts +3 -0
- package/src/plugins/goosefx/stakingFetcher.js +63 -0
- package/src/plugins/goosefx/stakingFetcher.js.map +1 -0
- package/src/plugins/goosefx/structs.d.ts +16 -0
- package/src/plugins/goosefx/structs.js +15 -1
- package/src/plugins/goosefx/structs.js.map +1 -1
- package/src/plugins/sushiswap/helpers.js +24 -24
- package/src/plugins/tokens/fetchers/solana-cnfts.js +10 -5
- package/src/plugins/tokens/fetchers/solana-cnfts.js.map +1 -1
- package/src/plugins/uniswap-v2/helpers.js +22 -22
- package/src/utils/solana/{getAssetsByOwner.d.ts → getAssetsByOwnerDas.d.ts} +19 -1
- package/src/utils/solana/{getAssetsByOwner.js → getAssetsByOwnerDas.js} +9 -4
- package/src/utils/solana/getAssetsByOwnerDas.js.map +1 -0
- package/src/utils/solana/getAssetsByOwner.js.map +0 -1
package/CHANGELOG.md
CHANGED
@@ -2,26 +2,34 @@
|
|
2
2
|
|
3
3
|
This file was generated using [@jscutlery/semver](https://github.com/jscutlery/semver).
|
4
4
|
|
5
|
-
## [0.8.
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
## [0.8.99](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.98...plugins-0.8.99) (2023-11-23)
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
## [0.8.98](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.97...plugins-0.8.98) (2023-11-22)
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
## [0.8.97](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.96...plugins-0.8.97) (2023-11-22)
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
## [0.8.96](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.95...plugins-0.8.96) (2023-11-22)
|
5
|
+
## [0.8.102](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.101...plugins-0.8.102) (2023-11-25)
|
22
6
|
|
23
7
|
|
24
8
|
|
9
|
+
## [0.8.101](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.100...plugins-0.8.101) (2023-11-24)
|
10
|
+
|
11
|
+
|
12
|
+
|
13
|
+
## [0.8.100](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.99...plugins-0.8.100) (2023-11-24)
|
14
|
+
|
15
|
+
|
16
|
+
|
17
|
+
## [0.8.99](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.98...plugins-0.8.99) (2023-11-23)
|
18
|
+
|
19
|
+
|
20
|
+
|
21
|
+
## [0.8.98](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.97...plugins-0.8.98) (2023-11-22)
|
22
|
+
|
23
|
+
|
24
|
+
|
25
|
+
## [0.8.97](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.96...plugins-0.8.97) (2023-11-22)
|
26
|
+
|
27
|
+
|
28
|
+
|
29
|
+
## [0.8.96](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.95...plugins-0.8.96) (2023-11-22)
|
30
|
+
|
31
|
+
|
32
|
+
|
25
33
|
## [0.8.95](https://github.com/sonarwatch/portfolio/compare/plugins-0.8.94...plugins-0.8.95) (2023-11-22)
|
26
34
|
|
27
35
|
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@sonarwatch/portfolio-plugins",
|
3
|
-
"version": "0.8.
|
3
|
+
"version": "0.8.102",
|
4
4
|
"type": "commonjs",
|
5
5
|
"generators": "./generators.json",
|
6
6
|
"dependencies": {
|
@@ -40,7 +40,7 @@
|
|
40
40
|
"web3-v1": "npm:web3@^1.5.0"
|
41
41
|
},
|
42
42
|
"peerDependencies": {
|
43
|
-
"@sonarwatch/portfolio-core": "0.8.
|
43
|
+
"@sonarwatch/portfolio-core": "0.8.102"
|
44
44
|
},
|
45
45
|
"main": "./src/index.js",
|
46
46
|
"types": "./src/index.d.ts"
|
@@ -51,6 +51,8 @@ const executor = (owner, cache) => __awaiter(void 0, void 0, void 0, function* (
|
|
51
51
|
suppliedAssets.push((0, tokenPriceToAssetToken_1.default)(mint, amount.toNumber(), portfolio_core_1.NetworkId.solana, tokenPrice));
|
52
52
|
}
|
53
53
|
const elements = [];
|
54
|
+
if (suppliedAssets.length === 0)
|
55
|
+
return [];
|
54
56
|
const { borrowedValue, collateralRatio, suppliedValue, value } = (0, portfolio_core_1.getElementLendingValues)(suppliedAssets, borrowedAssets, rewardAssets);
|
55
57
|
elements.push();
|
56
58
|
return [
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"depostisFetcher.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/01/depostisFetcher.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,+DAOoC;AACpC,6CAA4C;AAG5C,2CAAgD;AAChD,uCAAmC;AACnC,kFAA+E;AAC/E,qCAAwC;AACxC,iDAAsD;AACtD,iDAA+D;AAC/D,qGAA6E;AAE7E,MAAM,QAAQ,GAAoB,CAAO,KAAa,EAAE,KAAY,EAAE,EAAE;IACtE,MAAM,MAAM,GAAG,IAAA,yBAAe,GAAE,CAAC;IACjC,MAAM,GAAG,GAAG,IAAA,gBAAM,EAAC,IAAI,mBAAS,CAAC,KAAK,CAAC,CAAC,CAAC;IACzC,MAAM,OAAO,GAAG,MAAM,IAAA,2CAAoB,EAAC,MAAM,EAAE,qBAAY,EAAE,GAAG,CAAC,CAAC;IAEtE,IAAI,CAAC,OAAO;QAAE,OAAO,EAAE,CAAC;
|
1
|
+
{"version":3,"file":"depostisFetcher.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/01/depostisFetcher.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,+DAOoC;AACpC,6CAA4C;AAG5C,2CAAgD;AAChD,uCAAmC;AACnC,kFAA+E;AAC/E,qCAAwC;AACxC,iDAAsD;AACtD,iDAA+D;AAC/D,qGAA6E;AAE7E,MAAM,QAAQ,GAAoB,CAAO,KAAa,EAAE,KAAY,EAAE,EAAE;IACtE,MAAM,MAAM,GAAG,IAAA,yBAAe,GAAE,CAAC;IACjC,MAAM,GAAG,GAAG,IAAA,gBAAM,EAAC,IAAI,mBAAS,CAAC,KAAK,CAAC,CAAC,CAAC;IACzC,MAAM,OAAO,GAAG,MAAM,IAAA,2CAAoB,EAAC,MAAM,EAAE,qBAAY,EAAE,GAAG,CAAC,CAAC;IAEtE,IAAI,CAAC,OAAO;QAAE,OAAO,EAAE,CAAC;IAExB,MAAM,cAAc,GAAqB,EAAE,CAAC;IAC5C,MAAM,cAAc,GAAc,EAAE,CAAC;IACrC,MAAM,cAAc,GAAqB,EAAE,CAAC;IAC5C,MAAM,cAAc,GAAc,EAAE,CAAC;IACrC,MAAM,YAAY,GAAqB,EAAE,CAAC;IAC1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAClD,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,SAAS,GAAG,IAAA,kCAAwB,EAAC,UAAU,CAAC,CAAC;QACvD,IAAI,SAAS,CAAC,mBAAmB,CAAC,CAAC,CAAC;YAAE,SAAS;QAE/C,MAAM,IAAI,GAAG,iBAAK,CAAC,CAAC,CAAC,CAAC;QACtB,IAAI,IAAI,KAAK,6CAA6C;YAAE,SAAS;QAErE,MAAM,MAAM,GACV,IAAI;YACJ,CAAC,6CAA6C;gBAC5C,6CAA6C,CAAC;YAC9C,CAAC,CAAC,SAAS;YACX,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAEhC,IAAI,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC;YAAE,SAAS;QAE1C,MAAM,UAAU,GAAG,MAAM,KAAK,CAAC,aAAa,CAAC,IAAI,EAAE,0BAAS,CAAC,MAAM,CAAC,CAAC;QAErE,cAAc,CAAC,IAAI,CACjB,IAAA,gCAAsB,EACpB,IAAI,EACJ,MAAM,CAAC,QAAQ,EAAE,EACjB,0BAAS,CAAC,MAAM,EAChB,UAAU,CACX,CACF,CAAC;KACH;IACD,MAAM,QAAQ,GAAuB,EAAE,CAAC;IAExC,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IAE3C,MAAM,EAAE,aAAa,EAAE,eAAe,EAAE,aAAa,EAAE,KAAK,EAAE,GAC5D,IAAA,wCAAuB,EAAC,cAAc,EAAE,cAAc,EAAE,YAAY,CAAC,CAAC;IACxE,QAAQ,CAAC,IAAI,EAAE,CAAC;IAChB,OAAO;QACL;YACE,IAAI,EAAE,qCAAoB,CAAC,UAAU;YACrC,SAAS,EAAE,0BAAS,CAAC,MAAM;YAC3B,UAAU,EAAV,sBAAU;YACV,KAAK,EAAE,SAAS;YAChB,KAAK;YACL,IAAI,EAAE;gBACJ,cAAc;gBACd,aAAa;gBACb,cAAc;gBACd,cAAc;gBACd,aAAa;gBACb,cAAc;gBACd,eAAe;gBACf,YAAY;gBACZ,KAAK;aACN;SACF;KACF,CAAC;AACJ,CAAC,CAAA,CAAC;AAEF,MAAM,OAAO,GAAY;IACvB,EAAE,EAAE,GAAG,sBAAU,WAAW;IAC5B,SAAS,EAAE,0BAAS,CAAC,MAAM;IAC3B,QAAQ;CACT,CAAC;AAEF,kBAAe,OAAO,CAAC"}
|
@@ -68,18 +68,18 @@ const executor = (cache) => __awaiter(void 0, void 0, void 0, function* () {
|
|
68
68
|
continue;
|
69
69
|
const { supply, decimals } = supplyAndDecimals;
|
70
70
|
const poolUnderlyings = [
|
71
|
-
{
|
72
|
-
address: pool.pcMint.toString(),
|
73
|
-
reserveAmountRaw: pcAccount.amount.plus(baseTokenTotal),
|
74
|
-
price: pcTokenPrice.price,
|
75
|
-
decimals: pcTokenPrice.decimals,
|
76
|
-
},
|
77
71
|
{
|
78
72
|
address: pool.coinMint.toString(),
|
79
|
-
reserveAmountRaw: coinAccount.amount.plus(
|
73
|
+
reserveAmountRaw: coinAccount.amount.plus(baseTokenTotal),
|
80
74
|
price: coinTokenPrice.price,
|
81
75
|
decimals: coinTokenPrice.decimals,
|
82
76
|
},
|
77
|
+
{
|
78
|
+
address: pool.pcMint.toString(),
|
79
|
+
reserveAmountRaw: pcAccount.amount.plus(quoteTokenTotal),
|
80
|
+
price: pcTokenPrice.price,
|
81
|
+
decimals: pcTokenPrice.decimals,
|
82
|
+
},
|
83
83
|
];
|
84
84
|
const lpDetailsRaw = {
|
85
85
|
address: pool.lpMint.toString(),
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"poolsV1Job.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/atrix/poolsV1Job.ts"],"names":[],"mappings":"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
|
1
|
+
{"version":3,"file":"poolsV1Job.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/atrix/poolsV1Job.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AACA,+DAAmE;AACnE,gEAAqC;AAGrC,iDAAsD;AACtD,+CAK4B;AAC5B,4DAGwC;AACxC,2CAAkD;AAClD,uCAAuC;AACvC,+FAAuE;AACvE,gGAA6F;AAE7F,MAAM,QAAQ,GAAgB,CAAO,KAAY,EAAE,EAAE;IACnD,MAAM,MAAM,GAAG,IAAA,yBAAe,GAAE,CAAC;IAEjC,MAAM,aAAa,GAAG,MAAM,IAAA,iCAAwB,EAClD,MAAM,EACN,oBAAU,EACV,mBAAO,CACR,CAAC;IAEF,MAAM,uBAAuB,GAAgB,EAAE,CAAC;IAChD,MAAM,uBAAuB,GAAgB,EAAE,CAAC;IAChD,MAAM,eAAe,GAAgB,IAAI,GAAG,EAAE,CAAC;IAE/C,aAAa,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;QAC7B,IACE,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,KAAK,kCAAkC;YACtE,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,KAAK,kCAAkC;YAEpE,OAAO;QACT,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5C,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC9C,uBAAuB,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;QAC5E,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,MAAM,cAAc,GAAG,MAAM,IAAA,sCAA6B,EACxD,MAAM,EACN,2BAAkB,EAClB,uBAAuB,CACxB,CAAC;IAEF,MAAM,gBAAgB,GAA8B,IAAI,GAAG,EAAE,CAAC;IAC9D,cAAc,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE,CAC5B,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CACzD,CAAC;IAEF,MAAM,kBAAkB,GAAG,MAAM,IAAA,sCAA6B,EAC5D,MAAM,EACN,4BAAkB,EAClB,uBAAuB,CACxB,CAAC;IAEF,MAAM,gBAAgB,GAA8B,IAAI,GAAG,EAAE,CAAC;IAC9D,kBAAkB,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CACrC,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CACxE,CAAC;IAEF,MAAM,YAAY,GAAG,MAAM,KAAK,CAAC,cAAc,CAC7C,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,EAC3B,0BAAS,CAAC,MAAM,CACjB,CAAC;IACF,MAAM,cAAc,GAA4B,IAAI,GAAG,EAAE,CAAC;IAC1D,YAAY,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAE7E,MAAM,eAAe,GAAG,EAAE,CAAC;IAC3B,KAAK,MAAM,IAAI,IAAI,aAAa,EAAE;QAChC,MAAM,CAAC,WAAW,EAAE,SAAS,EAAE,gBAAgB,CAAC,GAAG;YACjD,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;YACrD,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;YACnD,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;SACjD,CAAC;QAEF,MAAM,CAAC,cAAc,EAAE,YAAY,CAAC,GAAG;YACrC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;YAC5C,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;SAC3C,CAAC;QAEF,IACE,CAAC,WAAW;YACZ,CAAC,SAAS;YACV,CAAC,cAAc;YACf,CAAC,YAAY;YACb,CAAC,gBAAgB;YAEjB,SAAS;QAEX,MAAM,EAAE,cAAc,EAAE,eAAe,EAAE,GAAG,gBAAgB,CAAC;QAC7D,MAAM,iBAAiB,GAAG,MAAM,IAAA,yDAA2B,EACzD,IAAI,CAAC,MAAM,EACX,MAAM,CACP,CAAC;QAEF,IAAI,CAAC,iBAAiB;YAAE,SAAS;QAEjC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,iBAAiB,CAAC;QAE/C,MAAM,eAAe,GAAG;YACtB;gBACE,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE;gBACjC,gBAAgB,EAAE,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC;gBACzD,KAAK,EAAE,cAAc,CAAC,KAAK;gBAC3B,QAAQ,EAAE,cAAc,CAAC,QAAQ;aAClC;YACD;gBACE,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;gBAC/B,gBAAgB,EAAE,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC;gBACxD,KAAK,EAAE,YAAY,CAAC,KAAK;gBACzB,QAAQ,EAAE,YAAY,CAAC,QAAQ;aAChC;SACF,CAAC;QAEF,MAAM,YAAY,GAAG;YACnB,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;YAC/B,QAAQ;YACR,SAAS,EAAE,IAAI,sBAAS,CAAC,MAAM,CAAC;SACjC,CAAC;QAEF,MAAM,MAAM,GAAG,IAAA,6BAAmB,EAChC,0BAAS,CAAC,MAAM,EAChB,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,EACtB,sBAAU,EACV,iBAAiB,EACjB,YAAY,EACZ,eAAe,CAChB,CAAC;QACF,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC;KACzD;IAED,MAAM,OAAO,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;AAC5C,CAAC,CAAA,CAAC;AAEF,MAAM,GAAG,GAAQ;IACf,EAAE,EAAE,GAAG,sBAAU,WAAW;IAC5B,QAAQ;CACT,CAAC;AACF,kBAAe,GAAG,CAAC"}
|
@@ -36,27 +36,27 @@ exports.getBalancerPoolsV2 = void 0;
|
|
36
36
|
const graphql_request_1 = __importStar(require("graphql-request"));
|
37
37
|
function getBalancerPoolsV2(url) {
|
38
38
|
return __awaiter(this, void 0, void 0, function* () {
|
39
|
-
const query = (0, graphql_request_1.gql) `
|
40
|
-
query pools {
|
41
|
-
pools(
|
42
|
-
first: 1000
|
43
|
-
orderBy: totalLiquidity
|
44
|
-
orderDirection: desc
|
45
|
-
where: { totalLiquidity_gt: "500" }
|
46
|
-
) {
|
47
|
-
id
|
48
|
-
address
|
49
|
-
symbol
|
50
|
-
totalLiquidity
|
51
|
-
totalShares
|
52
|
-
tokens {
|
53
|
-
balance
|
54
|
-
decimals
|
55
|
-
symbol
|
56
|
-
address
|
57
|
-
}
|
58
|
-
}
|
59
|
-
}
|
39
|
+
const query = (0, graphql_request_1.gql) `
|
40
|
+
query pools {
|
41
|
+
pools(
|
42
|
+
first: 1000
|
43
|
+
orderBy: totalLiquidity
|
44
|
+
orderDirection: desc
|
45
|
+
where: { totalLiquidity_gt: "500" }
|
46
|
+
) {
|
47
|
+
id
|
48
|
+
address
|
49
|
+
symbol
|
50
|
+
totalLiquidity
|
51
|
+
totalShares
|
52
|
+
tokens {
|
53
|
+
balance
|
54
|
+
decimals
|
55
|
+
symbol
|
56
|
+
address
|
57
|
+
}
|
58
|
+
}
|
59
|
+
}
|
60
60
|
`;
|
61
61
|
const res = yield (0, graphql_request_1.default)(url, query);
|
62
62
|
const pools = res.pools;
|
@@ -3,3 +3,5 @@ import { Platform } from '@sonarwatch/portfolio-core';
|
|
3
3
|
export declare const platformId = "goosefx";
|
4
4
|
export declare const platform: Platform;
|
5
5
|
export declare const programId: PublicKey;
|
6
|
+
export declare const stakerProgramId: PublicKey;
|
7
|
+
export declare const gofxMint = "GFX1ZjR2P15tmrSwow6FjyDYcEkoFb4p4gJCpLBjaxHD";
|
@@ -1,6 +1,6 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.programId = exports.platform = exports.platformId = void 0;
|
3
|
+
exports.gofxMint = exports.stakerProgramId = exports.programId = exports.platform = exports.platformId = void 0;
|
4
4
|
const web3_js_1 = require("@solana/web3.js");
|
5
5
|
exports.platformId = 'goosefx';
|
6
6
|
exports.platform = {
|
@@ -12,4 +12,6 @@ exports.platform = {
|
|
12
12
|
// twitter: 'https://twitter.com/myplatform',
|
13
13
|
};
|
14
14
|
exports.programId = new web3_js_1.PublicKey('GFXsSL5sSaDfNFQUYsHekbWBW1TsFdjDYzACh62tEHxn');
|
15
|
+
exports.stakerProgramId = new web3_js_1.PublicKey('STKRWxT4irmTthSJydggspWmkc3ovYHx62DHLPVv1f1');
|
16
|
+
exports.gofxMint = 'GFX1ZjR2P15tmrSwow6FjyDYcEkoFb4p4gJCpLBjaxHD';
|
15
17
|
//# sourceMappingURL=constants.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/goosefx/constants.ts"],"names":[],"mappings":";;;AAAA,6CAA4C;AAG/B,QAAA,UAAU,GAAG,SAAS,CAAC;AACvB,QAAA,QAAQ,GAAa;IAChC,EAAE,EAAE,kBAAU;IACd,IAAI,EAAE,SAAS;IACf,KAAK,EAAE,+CAA+C;IACtD,WAAW,EAAE,SAAS;IACtB,OAAO,EAAE,6BAA6B;IACtC,6CAA6C;CAC9C,CAAC;AAEW,QAAA,SAAS,GAAG,IAAI,mBAAS,CACpC,8CAA8C,CAC/C,CAAC"}
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/goosefx/constants.ts"],"names":[],"mappings":";;;AAAA,6CAA4C;AAG/B,QAAA,UAAU,GAAG,SAAS,CAAC;AACvB,QAAA,QAAQ,GAAa;IAChC,EAAE,EAAE,kBAAU;IACd,IAAI,EAAE,SAAS;IACf,KAAK,EAAE,+CAA+C;IACtD,WAAW,EAAE,SAAS;IACtB,OAAO,EAAE,6BAA6B;IACtC,6CAA6C;CAC9C,CAAC;AAEW,QAAA,SAAS,GAAG,IAAI,mBAAS,CACpC,8CAA8C,CAC/C,CAAC;AAEW,QAAA,eAAe,GAAG,IAAI,mBAAS,CAC1C,6CAA6C,CAC9C,CAAC;AAEW,QAAA,QAAQ,GAAG,8CAA8C,CAAC"}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.liquidityAccountFilter = void 0;
|
3
|
+
exports.stakingAccountFilter = exports.liquidityAccountFilter = void 0;
|
4
4
|
const structs_1 = require("./structs");
|
5
5
|
const liquidityAccountFilter = (owner) => [
|
6
6
|
{
|
@@ -12,4 +12,14 @@ const liquidityAccountFilter = (owner) => [
|
|
12
12
|
{ dataSize: structs_1.liquidityStruct.byteSize },
|
13
13
|
];
|
14
14
|
exports.liquidityAccountFilter = liquidityAccountFilter;
|
15
|
+
const stakingAccountFilter = (owner) => [
|
16
|
+
{
|
17
|
+
memcmp: {
|
18
|
+
offset: 8,
|
19
|
+
bytes: owner,
|
20
|
+
},
|
21
|
+
},
|
22
|
+
{ dataSize: structs_1.userMetadataStruct.byteSize },
|
23
|
+
];
|
24
|
+
exports.stakingAccountFilter = stakingAccountFilter;
|
15
25
|
//# sourceMappingURL=filters.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"filters.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/goosefx/filters.ts"],"names":[],"mappings":";;;AACA,
|
1
|
+
{"version":3,"file":"filters.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/goosefx/filters.ts"],"names":[],"mappings":";;;AACA,uCAAgE;AAEzD,MAAM,sBAAsB,GAAG,CACpC,KAAa,EACe,EAAE,CAAC;IAC/B;QACE,MAAM,EAAE;YACN,MAAM,EAAE,EAAE;YACV,KAAK,EAAE,KAAK;SACb;KACF;IACD,EAAE,QAAQ,EAAE,yBAAe,CAAC,QAAQ,EAAE;CACvC,CAAC;AAVW,QAAA,sBAAsB,0BAUjC;AAEK,MAAM,oBAAoB,GAAG,CAClC,KAAa,EACe,EAAE,CAAC;IAC/B;QACE,MAAM,EAAE;YACN,MAAM,EAAE,CAAC;YACT,KAAK,EAAE,KAAK;SACb;KACF;IACD,EAAE,QAAQ,EAAE,4BAAkB,CAAC,QAAQ,EAAE;CAC1C,CAAC;AAVW,QAAA,oBAAoB,wBAU/B"}
|
@@ -6,7 +6,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.fetchers = exports.jobs = exports.platforms = void 0;
|
7
7
|
const constants_1 = require("./constants");
|
8
8
|
const poolsFetcher_1 = __importDefault(require("./poolsFetcher"));
|
9
|
+
const stakingFetcher_1 = __importDefault(require("./stakingFetcher"));
|
9
10
|
exports.platforms = [constants_1.platform];
|
10
11
|
exports.jobs = [];
|
11
|
-
exports.fetchers = [poolsFetcher_1.default];
|
12
|
+
exports.fetchers = [poolsFetcher_1.default, stakingFetcher_1.default];
|
12
13
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/goosefx/index.ts"],"names":[],"mappings":";;;;;;AAGA,2CAAuC;AACvC,kEAA8C;AAEjC,QAAA,SAAS,GAAe,CAAC,oBAAQ,CAAC,CAAC;AACnC,QAAA,IAAI,GAAU,EAAE,CAAC;AACjB,QAAA,QAAQ,GAAc,CAAC,sBAAgB,CAAC,CAAC"}
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/goosefx/index.ts"],"names":[],"mappings":";;;;;;AAGA,2CAAuC;AACvC,kEAA8C;AAC9C,sEAA8C;AAEjC,QAAA,SAAS,GAAe,CAAC,oBAAQ,CAAC,CAAC;AACnC,QAAA,IAAI,GAAU,EAAE,CAAC;AACjB,QAAA,QAAQ,GAAc,CAAC,sBAAgB,EAAE,wBAAc,CAAC,CAAC"}
|
@@ -0,0 +1,63 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9
|
+
});
|
10
|
+
};
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
13
|
+
};
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
15
|
+
const portfolio_core_1 = require("@sonarwatch/portfolio-core");
|
16
|
+
const constants_1 = require("./constants");
|
17
|
+
const clients_1 = require("../../utils/clients");
|
18
|
+
const solana_1 = require("../../utils/solana");
|
19
|
+
const structs_1 = require("./structs");
|
20
|
+
const filters_1 = require("./filters");
|
21
|
+
const tokenPriceToAssetToken_1 = __importDefault(require("../../utils/misc/tokenPriceToAssetToken"));
|
22
|
+
const sevenDays = 7 * 1000 * 60 * 60 * 24;
|
23
|
+
const executor = (owner, cache) => __awaiter(void 0, void 0, void 0, function* () {
|
24
|
+
const client = (0, clients_1.getClientSolana)();
|
25
|
+
const accounts = yield (0, solana_1.getParsedProgramAccounts)(client, structs_1.userMetadataStruct, constants_1.stakerProgramId, (0, filters_1.stakingAccountFilter)(owner));
|
26
|
+
const gofxTokenPrice = yield cache.getTokenPrice(constants_1.gofxMint, portfolio_core_1.NetworkId.solana);
|
27
|
+
if (!gofxTokenPrice)
|
28
|
+
return [];
|
29
|
+
const assets = [];
|
30
|
+
for (const account of accounts) {
|
31
|
+
let totalAmount = account.totalStaked;
|
32
|
+
for (const ticket of account.unstakingTickets) {
|
33
|
+
const unlockStartedAt = new Date(ticket.createdAt.times(1000).toNumber());
|
34
|
+
const unlockingAt = new Date(unlockStartedAt.getTime() + sevenDays);
|
35
|
+
if (Date.now() < unlockingAt.getTime())
|
36
|
+
totalAmount = totalAmount.plus(ticket.totalUnstaked);
|
37
|
+
}
|
38
|
+
if (totalAmount.isZero())
|
39
|
+
continue;
|
40
|
+
const { decimals } = gofxTokenPrice;
|
41
|
+
const amount = totalAmount.dividedBy(Math.pow(10, decimals)).toNumber();
|
42
|
+
assets.push((0, tokenPriceToAssetToken_1.default)(constants_1.gofxMint, amount, portfolio_core_1.NetworkId.solana, gofxTokenPrice));
|
43
|
+
}
|
44
|
+
if (assets.length === 0)
|
45
|
+
return [];
|
46
|
+
return [
|
47
|
+
{
|
48
|
+
type: portfolio_core_1.PortfolioElementType.multiple,
|
49
|
+
label: 'Staked',
|
50
|
+
networkId: portfolio_core_1.NetworkId.solana,
|
51
|
+
platformId: constants_1.platformId,
|
52
|
+
data: { assets },
|
53
|
+
value: (0, portfolio_core_1.getUsdValueSum)(assets.map((asset) => asset.value)),
|
54
|
+
},
|
55
|
+
];
|
56
|
+
});
|
57
|
+
const fetcher = {
|
58
|
+
id: `${constants_1.platformId}-staking`,
|
59
|
+
networkId: portfolio_core_1.NetworkId.solana,
|
60
|
+
executor,
|
61
|
+
};
|
62
|
+
exports.default = fetcher;
|
63
|
+
//# sourceMappingURL=stakingFetcher.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"stakingFetcher.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/goosefx/stakingFetcher.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,+DAKoC;AAGpC,2CAAoE;AACpE,iDAAsD;AACtD,+CAA8D;AAC9D,uCAA+C;AAC/C,uCAAiD;AACjD,qGAA6E;AAE7E,MAAM,SAAS,GAAG,CAAC,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAE1C,MAAM,QAAQ,GAAoB,CAAO,KAAa,EAAE,KAAY,EAAE,EAAE;IACtE,MAAM,MAAM,GAAG,IAAA,yBAAe,GAAE,CAAC;IAEjC,MAAM,QAAQ,GAAG,MAAM,IAAA,iCAAwB,EAC7C,MAAM,EACN,4BAAkB,EAClB,2BAAe,EACf,IAAA,8BAAoB,EAAC,KAAK,CAAC,CAC5B,CAAC;IAEF,MAAM,cAAc,GAAG,MAAM,KAAK,CAAC,aAAa,CAAC,oBAAQ,EAAE,0BAAS,CAAC,MAAM,CAAC,CAAC;IAC7E,IAAI,CAAC,cAAc;QAAE,OAAO,EAAE,CAAC;IAE/B,MAAM,MAAM,GAAqB,EAAE,CAAC;IACpC,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE;QAC9B,IAAI,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;QACtC,KAAK,MAAM,MAAM,IAAI,OAAO,CAAC,gBAAgB,EAAE;YAC7C,MAAM,eAAe,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC1E,MAAM,WAAW,GAAG,IAAI,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,SAAS,CAAC,CAAC;YACpE,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,WAAW,CAAC,OAAO,EAAE;gBACpC,WAAW,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;SACxD;QACD,IAAI,WAAW,CAAC,MAAM,EAAE;YAAE,SAAS;QAEnC,MAAM,EAAE,QAAQ,EAAE,GAAG,cAAc,CAAC;QACpC,MAAM,MAAM,GAAG,WAAW,CAAC,SAAS,CAAC,SAAA,EAAE,EAAI,QAAQ,CAAA,CAAC,CAAC,QAAQ,EAAE,CAAC;QAEhE,MAAM,CAAC,IAAI,CACT,IAAA,gCAAsB,EAAC,oBAAQ,EAAE,MAAM,EAAE,0BAAS,CAAC,MAAM,EAAE,cAAc,CAAC,CAC3E,CAAC;KACH;IAED,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IAEnC,OAAO;QACL;YACE,IAAI,EAAE,qCAAoB,CAAC,QAAQ;YACnC,KAAK,EAAE,QAAQ;YACf,SAAS,EAAE,0BAAS,CAAC,MAAM;YAC3B,UAAU,EAAV,sBAAU;YACV,IAAI,EAAE,EAAE,MAAM,EAAE;YAChB,KAAK,EAAE,IAAA,+BAAc,EAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;SAC1D;KACF,CAAC;AACJ,CAAC,CAAA,CAAC;AAEF,MAAM,OAAO,GAAY;IACvB,EAAE,EAAE,GAAG,sBAAU,UAAU;IAC3B,SAAS,EAAE,0BAAS,CAAC,MAAM;IAC3B,QAAQ;CACT,CAAC;AAEF,kBAAe,OAAO,CAAC"}
|
@@ -15,3 +15,19 @@ export type Liquidity = {
|
|
15
15
|
space: number[];
|
16
16
|
};
|
17
17
|
export declare const liquidityStruct: BeetStruct<Liquidity, Partial<Liquidity>>;
|
18
|
+
export type UnstakingTicket = {
|
19
|
+
totalUnstaked: BigNumber;
|
20
|
+
createdAt: BigNumber;
|
21
|
+
};
|
22
|
+
export declare const unstakingTicketStruct: BeetStruct<UnstakingTicket, Partial<UnstakingTicket>>;
|
23
|
+
export type UserMetadata = {
|
24
|
+
buffer: Buffer;
|
25
|
+
owner: PublicKey;
|
26
|
+
accountOpenedAt: BigNumber;
|
27
|
+
totalStaked: BigNumber;
|
28
|
+
lastObservedTap: BigNumber;
|
29
|
+
lastClaimed: BigNumber;
|
30
|
+
totalEarned: BigNumber;
|
31
|
+
unstakingTickets: UnstakingTicket[];
|
32
|
+
};
|
33
|
+
export declare const userMetadataStruct: BeetStruct<UserMetadata, Partial<UserMetadata>>;
|
@@ -1,6 +1,6 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.liquidityStruct = void 0;
|
3
|
+
exports.userMetadataStruct = exports.unstakingTicketStruct = exports.liquidityStruct = void 0;
|
4
4
|
const beet_1 = require("@metaplex-foundation/beet");
|
5
5
|
const beet_solana_1 = require("@metaplex-foundation/beet-solana");
|
6
6
|
const solana_1 = require("../../utils/solana");
|
@@ -16,4 +16,18 @@ exports.liquidityStruct = new beet_1.BeetStruct([
|
|
16
16
|
['createdAt', solana_1.i64],
|
17
17
|
['space', (0, beet_1.uniformFixedSizeArray)(beet_1.u8, 128)],
|
18
18
|
], (args) => args);
|
19
|
+
exports.unstakingTicketStruct = new beet_1.BeetStruct([
|
20
|
+
['totalUnstaked', solana_1.u64],
|
21
|
+
['createdAt', solana_1.i64],
|
22
|
+
], (args) => args);
|
23
|
+
exports.userMetadataStruct = new beet_1.BeetStruct([
|
24
|
+
['buffer', (0, solana_1.blob)(8)],
|
25
|
+
['owner', beet_solana_1.publicKey],
|
26
|
+
['accountOpenedAt', solana_1.i64],
|
27
|
+
['totalStaked', solana_1.u64],
|
28
|
+
['lastObservedTap', solana_1.u64],
|
29
|
+
['lastClaimed', solana_1.i64],
|
30
|
+
['totalEarned', solana_1.u64],
|
31
|
+
['unstakingTickets', (0, beet_1.uniformFixedSizeArray)(exports.unstakingTicketStruct, 64)],
|
32
|
+
], (args) => args);
|
19
33
|
//# sourceMappingURL=structs.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"structs.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/goosefx/structs.ts"],"names":[],"mappings":";;;AAAA,oDAImC;AACnC,kEAA6D;AAG7D,+CAAoD;AAevC,QAAA,eAAe,GAAG,IAAI,iBAAU,CAC3C;IACE,CAAC,QAAQ,EAAE,IAAA,aAAI,EAAC,CAAC,CAAC,CAAC;IACnB,CAAC,cAAc,EAAE,uBAAS,CAAC;IAC3B,CAAC,MAAM,EAAE,uBAAS,CAAC;IACnB,CAAC,OAAO,EAAE,uBAAS,CAAC;IACpB,CAAC,iBAAiB,EAAE,YAAG,CAAC;IACxB,CAAC,iBAAiB,EAAE,YAAG,CAAC;IACxB,CAAC,aAAa,EAAE,YAAG,CAAC;IACpB,CAAC,aAAa,EAAE,YAAG,CAAC;IACpB,CAAC,WAAW,EAAE,YAAG,CAAC;IAClB,CAAC,OAAO,EAAE,IAAA,4BAAqB,EAAC,SAAE,EAAE,GAAG,CAAC,CAAC;CAC1C,EACD,CAAC,IAAI,EAAE,EAAE,CAAC,IAAiB,CAC5B,CAAC"}
|
1
|
+
{"version":3,"file":"structs.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/goosefx/structs.ts"],"names":[],"mappings":";;;AAAA,oDAImC;AACnC,kEAA6D;AAG7D,+CAAoD;AAevC,QAAA,eAAe,GAAG,IAAI,iBAAU,CAC3C;IACE,CAAC,QAAQ,EAAE,IAAA,aAAI,EAAC,CAAC,CAAC,CAAC;IACnB,CAAC,cAAc,EAAE,uBAAS,CAAC;IAC3B,CAAC,MAAM,EAAE,uBAAS,CAAC;IACnB,CAAC,OAAO,EAAE,uBAAS,CAAC;IACpB,CAAC,iBAAiB,EAAE,YAAG,CAAC;IACxB,CAAC,iBAAiB,EAAE,YAAG,CAAC;IACxB,CAAC,aAAa,EAAE,YAAG,CAAC;IACpB,CAAC,aAAa,EAAE,YAAG,CAAC;IACpB,CAAC,WAAW,EAAE,YAAG,CAAC;IAClB,CAAC,OAAO,EAAE,IAAA,4BAAqB,EAAC,SAAE,EAAE,GAAG,CAAC,CAAC;CAC1C,EACD,CAAC,IAAI,EAAE,EAAE,CAAC,IAAiB,CAC5B,CAAC;AAOW,QAAA,qBAAqB,GAAG,IAAI,iBAAU,CACjD;IACE,CAAC,eAAe,EAAE,YAAG,CAAC;IACtB,CAAC,WAAW,EAAE,YAAG,CAAC;CACnB,EACD,CAAC,IAAI,EAAE,EAAE,CAAC,IAAuB,CAClC,CAAC;AAaW,QAAA,kBAAkB,GAAG,IAAI,iBAAU,CAC9C;IACE,CAAC,QAAQ,EAAE,IAAA,aAAI,EAAC,CAAC,CAAC,CAAC;IACnB,CAAC,OAAO,EAAE,uBAAS,CAAC;IACpB,CAAC,iBAAiB,EAAE,YAAG,CAAC;IACxB,CAAC,aAAa,EAAE,YAAG,CAAC;IACpB,CAAC,iBAAiB,EAAE,YAAG,CAAC;IACxB,CAAC,aAAa,EAAE,YAAG,CAAC;IACpB,CAAC,aAAa,EAAE,YAAG,CAAC;IACpB,CAAC,kBAAkB,EAAE,IAAA,4BAAqB,EAAC,6BAAqB,EAAE,EAAE,CAAC,CAAC;CACvE,EACD,CAAC,IAAI,EAAE,EAAE,CAAC,IAAoB,CAC/B,CAAC"}
|
@@ -54,30 +54,30 @@ function sushiV3PairToUniV2(pair) {
|
|
54
54
|
}
|
55
55
|
function getV3PairsAddresses(url, length = 300) {
|
56
56
|
return __awaiter(this, void 0, void 0, function* () {
|
57
|
-
const query = (0, graphql_request_1.gql) `
|
58
|
-
{
|
59
|
-
pools(
|
60
|
-
orderBy: totalValueLockedUSD
|
61
|
-
first: ${length}
|
62
|
-
orderDirection: desc
|
63
|
-
where: { volumeUSD_not: "0", liquidity_not: "0" }
|
64
|
-
) {
|
65
|
-
id
|
66
|
-
token0Price
|
67
|
-
token1Price
|
68
|
-
liquidity
|
69
|
-
token0 {
|
70
|
-
id
|
71
|
-
totalSupply
|
72
|
-
decimals
|
73
|
-
}
|
74
|
-
token1 {
|
75
|
-
id
|
76
|
-
totalSupply
|
77
|
-
decimals
|
78
|
-
}
|
79
|
-
}
|
80
|
-
}
|
57
|
+
const query = (0, graphql_request_1.gql) `
|
58
|
+
{
|
59
|
+
pools(
|
60
|
+
orderBy: totalValueLockedUSD
|
61
|
+
first: ${length}
|
62
|
+
orderDirection: desc
|
63
|
+
where: { volumeUSD_not: "0", liquidity_not: "0" }
|
64
|
+
) {
|
65
|
+
id
|
66
|
+
token0Price
|
67
|
+
token1Price
|
68
|
+
liquidity
|
69
|
+
token0 {
|
70
|
+
id
|
71
|
+
totalSupply
|
72
|
+
decimals
|
73
|
+
}
|
74
|
+
token1 {
|
75
|
+
id
|
76
|
+
totalSupply
|
77
|
+
decimals
|
78
|
+
}
|
79
|
+
}
|
80
|
+
}
|
81
81
|
`;
|
82
82
|
const res = yield (0, graphql_request_1.default)(url, query);
|
83
83
|
const pools = res.pools;
|
@@ -10,16 +10,21 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
10
10
|
};
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
12
12
|
const portfolio_core_1 = require("@sonarwatch/portfolio-core");
|
13
|
-
const
|
13
|
+
const getAssetsByOwnerDas_1 = require("../../../utils/solana/getAssetsByOwnerDas");
|
14
14
|
const constants_1 = require("../constants");
|
15
15
|
const constants_2 = require("../../../utils/clients/constants");
|
16
16
|
const executor = (owner) => __awaiter(void 0, void 0, void 0, function* () {
|
17
17
|
const rpcEndpoint = (0, constants_2.getRpcEndpoint)(portfolio_core_1.NetworkId.solana);
|
18
|
-
const list = yield (0,
|
19
|
-
const
|
20
|
-
const
|
18
|
+
const list = yield (0, getAssetsByOwnerDas_1.getAssetsByOwnerDas)(rpcEndpoint, owner);
|
19
|
+
const assets = [];
|
20
|
+
const items = list.items.filter((i) => {
|
21
|
+
const isCompressed = i.compression.compressed;
|
22
|
+
const isSplNft = i.spl20 === null && i.inscription !== null;
|
23
|
+
return isCompressed || isSplNft;
|
24
|
+
});
|
25
|
+
items.forEach((i) => {
|
21
26
|
var _a;
|
22
|
-
|
27
|
+
assets.push({
|
23
28
|
networkId: portfolio_core_1.NetworkId.solana,
|
24
29
|
type: portfolio_core_1.PortfolioAssetType.collectible,
|
25
30
|
value: null,
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"solana-cnfts.js","sourceRoot":"","sources":["../../../../../../../packages/plugins/src/plugins/tokens/fetchers/solana-cnfts.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,+DAMoC;AAEpC,
|
1
|
+
{"version":3,"file":"solana-cnfts.js","sourceRoot":"","sources":["../../../../../../../packages/plugins/src/plugins/tokens/fetchers/solana-cnfts.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,+DAMoC;AAEpC,mFAAgF;AAChF,4CAAwE;AACxE,gEAAkE;AAElE,MAAM,QAAQ,GAAoB,CAAO,KAAa,EAAE,EAAE;IACxD,MAAM,WAAW,GAAG,IAAA,0BAAc,EAAC,0BAAS,CAAC,MAAM,CAAC,CAAC;IACrD,MAAM,IAAI,GAAG,MAAM,IAAA,yCAAmB,EAAC,WAAW,EAAE,KAAK,CAAC,CAAC;IAE3D,MAAM,MAAM,GAAgC,EAAE,CAAC;IAC/C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE;QACpC,MAAM,YAAY,GAAG,CAAC,CAAC,WAAW,CAAC,UAAU,CAAC;QAC9C,MAAM,QAAQ,GAAG,CAAC,CAAC,KAAK,KAAK,IAAI,IAAI,CAAC,CAAC,WAAW,KAAK,IAAI,CAAC;QAC5D,OAAO,YAAY,IAAI,QAAQ,CAAC;IAClC,CAAC,CAAC,CAAC;IACH,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;;QAClB,MAAM,CAAC,IAAI,CAAC;YACV,SAAS,EAAE,0BAAS,CAAC,MAAM;YAC3B,IAAI,EAAE,mCAAkB,CAAC,WAAW;YACpC,KAAK,EAAE,IAAI;YACX,IAAI,EAAE;gBACJ,OAAO,EAAE,CAAC,CAAC,EAAE;gBACb,MAAM,EAAE,CAAC;gBACT,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAC7B,QAAQ,EAAE,MAAA,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,WACnC,OAAA,MAAA,CAAC,CAAC,IAAI,0CAAE,iBAAiB,GAAG,UAAU,CAAC,OAAO,CAAC,CAAA,EAAA,CAChD,0CAAE,GAAG;gBACN,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ;aAC5B;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IACH,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IACnC,MAAM,OAAO,GAA6B;QACxC,IAAI,EAAE,qCAAoB,CAAC,QAAQ;QACnC,SAAS,EAAE,0BAAS,CAAC,MAAM;QAC3B,UAAU,EAAE,8BAAkB,CAAC,EAAE;QACjC,KAAK,EAAE,QAAQ;QACf,KAAK,EAAE,IAAI;QACX,IAAI,EAAE;YACJ,MAAM;SACP;KACF,CAAC;IACF,OAAO,CAAC,OAAO,CAAC,CAAC;AACnB,CAAC,CAAA,CAAC;AAEF,MAAM,OAAO,GAAY;IACvB,EAAE,EAAE,GAAG,gCAAoB,CAAC,EAAE,eAAe;IAC7C,SAAS,EAAE,0BAAS,CAAC,MAAM;IAC3B,QAAQ;CACT,CAAC;AAEF,kBAAe,OAAO,CAAC"}
|
@@ -40,28 +40,28 @@ function getPairKey(version) {
|
|
40
40
|
exports.getPairKey = getPairKey;
|
41
41
|
function getPairsV2FromTheGraph(url, length = 300) {
|
42
42
|
return __awaiter(this, void 0, void 0, function* () {
|
43
|
-
const query = (0, graphql_request_1.gql) `
|
44
|
-
{
|
45
|
-
pairs(
|
46
|
-
orderBy: reserveUSD
|
47
|
-
first: ${length}
|
48
|
-
orderDirection: desc
|
49
|
-
where: { trackedReserveETH_not: "0" }
|
50
|
-
) {
|
51
|
-
id
|
52
|
-
reserve0
|
53
|
-
reserve1
|
54
|
-
totalSupply
|
55
|
-
token0 {
|
56
|
-
id
|
57
|
-
decimals
|
58
|
-
}
|
59
|
-
token1 {
|
60
|
-
id
|
61
|
-
decimals
|
62
|
-
}
|
63
|
-
}
|
64
|
-
}
|
43
|
+
const query = (0, graphql_request_1.gql) `
|
44
|
+
{
|
45
|
+
pairs(
|
46
|
+
orderBy: reserveUSD
|
47
|
+
first: ${length}
|
48
|
+
orderDirection: desc
|
49
|
+
where: { trackedReserveETH_not: "0" }
|
50
|
+
) {
|
51
|
+
id
|
52
|
+
reserve0
|
53
|
+
reserve1
|
54
|
+
totalSupply
|
55
|
+
token0 {
|
56
|
+
id
|
57
|
+
decimals
|
58
|
+
}
|
59
|
+
token1 {
|
60
|
+
id
|
61
|
+
decimals
|
62
|
+
}
|
63
|
+
}
|
64
|
+
}
|
65
65
|
`;
|
66
66
|
const res = yield (0, graphql_request_1.default)(url, query);
|
67
67
|
const pairs = res.pairs;
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { RpcEndpoint } from '@sonarwatch/portfolio-core';
|
2
|
-
export declare function
|
2
|
+
export declare function getAssetsByOwnerDas(rpcEndpoint: RpcEndpoint, owner: string): Promise<HeliusAssetList>;
|
3
3
|
export type GetAssetsByOwnerOutput = {
|
4
4
|
jsonrpc: string;
|
5
5
|
result: HeliusAssetList;
|
@@ -24,6 +24,24 @@ export type HeliusAsset = {
|
|
24
24
|
supply: Supply | null;
|
25
25
|
mutable: boolean;
|
26
26
|
burnt: boolean;
|
27
|
+
inscription: Inscription | null;
|
28
|
+
spl20: Spl20 | null;
|
29
|
+
};
|
30
|
+
export type Inscription = {
|
31
|
+
order: number;
|
32
|
+
size: number;
|
33
|
+
contentType: string;
|
34
|
+
encoding: string;
|
35
|
+
validationHash: string;
|
36
|
+
inscriptionDataAccount: string;
|
37
|
+
};
|
38
|
+
export type Spl20 = {
|
39
|
+
p: string;
|
40
|
+
op: string;
|
41
|
+
tick: string;
|
42
|
+
max?: string;
|
43
|
+
lim?: string;
|
44
|
+
amt?: string;
|
27
45
|
};
|
28
46
|
export type Authority = {
|
29
47
|
address: string;
|
@@ -12,10 +12,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
12
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
13
13
|
};
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
15
|
-
exports.
|
15
|
+
exports.getAssetsByOwnerDas = void 0;
|
16
16
|
const axios_1 = __importDefault(require("axios"));
|
17
17
|
const getBasicAuthHeaders_1 = require("../misc/getBasicAuthHeaders");
|
18
|
-
function
|
18
|
+
function getAssetsByOwnerDas(rpcEndpoint, owner) {
|
19
19
|
return __awaiter(this, void 0, void 0, function* () {
|
20
20
|
const httpHeaders = rpcEndpoint.basicAuth
|
21
21
|
? (0, getBasicAuthHeaders_1.getBasicAuthHeaders)(rpcEndpoint.basicAuth.username, rpcEndpoint.basicAuth.password)
|
@@ -33,6 +33,11 @@ function getAssetsByOwner(rpcEndpoint, owner) {
|
|
33
33
|
sortBy: 'created',
|
34
34
|
sortDirection: 'asc',
|
35
35
|
},
|
36
|
+
displayOptions: {
|
37
|
+
showFungible: false,
|
38
|
+
showNativeBalance: false,
|
39
|
+
showInscription: true,
|
40
|
+
},
|
36
41
|
},
|
37
42
|
}, {
|
38
43
|
headers: Object.assign({ 'Content-Type': 'application/json' }, httpHeaders),
|
@@ -40,5 +45,5 @@ function getAssetsByOwner(rpcEndpoint, owner) {
|
|
40
45
|
.then((res) => res.data.result);
|
41
46
|
});
|
42
47
|
}
|
43
|
-
exports.
|
44
|
-
//# sourceMappingURL=
|
48
|
+
exports.getAssetsByOwnerDas = getAssetsByOwnerDas;
|
49
|
+
//# sourceMappingURL=getAssetsByOwnerDas.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"getAssetsByOwnerDas.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/utils/solana/getAssetsByOwnerDas.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,kDAA6C;AAC7C,qEAAkE;AAElE,SAAsB,mBAAmB,CACvC,WAAwB,EACxB,KAAa;;QAEb,MAAM,WAAW,GAAG,WAAW,CAAC,SAAS;YACvC,CAAC,CAAC,IAAA,yCAAmB,EACjB,WAAW,CAAC,SAAS,CAAC,QAAQ,EAC9B,WAAW,CAAC,SAAS,CAAC,QAAQ,CAC/B;YACH,CAAC,CAAC,SAAS,CAAC;QAEd,OAAO,eAAK;aACT,IAAI,CACH,WAAW,CAAC,GAAG,EACf;YACE,OAAO,EAAE,KAAK;YACd,EAAE,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAC5B,MAAM,EAAE,kBAAkB;YAC1B,MAAM,EAAE;gBACN,YAAY,EAAE,KAAK;gBACnB,IAAI,EAAE,CAAC;gBACP,KAAK,EAAE,IAAI;gBACX,MAAM,EAAE;oBACN,MAAM,EAAE,SAAS;oBACjB,aAAa,EAAE,KAAK;iBACrB;gBACD,cAAc,EAAE;oBACd,YAAY,EAAE,KAAK;oBACnB,iBAAiB,EAAE,KAAK;oBACxB,eAAe,EAAE,IAAI;iBACtB;aACF;SACF,EACD;YACE,OAAO,kBACL,cAAc,EAAE,kBAAkB,IAC/B,WAAW,CACf;SACF,CACF;aACA,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;CAAA;AAzCD,kDAyCC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"getAssetsByOwner.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/utils/solana/getAssetsByOwner.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,kDAA6C;AAC7C,qEAAkE;AAElE,SAAsB,gBAAgB,CACpC,WAAwB,EACxB,KAAa;;QAEb,MAAM,WAAW,GAAG,WAAW,CAAC,SAAS;YACvC,CAAC,CAAC,IAAA,yCAAmB,EACjB,WAAW,CAAC,SAAS,CAAC,QAAQ,EAC9B,WAAW,CAAC,SAAS,CAAC,QAAQ,CAC/B;YACH,CAAC,CAAC,SAAS,CAAC;QAEd,OAAO,eAAK;aACT,IAAI,CACH,WAAW,CAAC,GAAG,EACf;YACE,OAAO,EAAE,KAAK;YACd,EAAE,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;YAC5B,MAAM,EAAE,kBAAkB;YAC1B,MAAM,EAAE;gBACN,YAAY,EAAE,KAAK;gBACnB,IAAI,EAAE,CAAC;gBACP,KAAK,EAAE,IAAI;gBACX,MAAM,EAAE;oBACN,MAAM,EAAE,SAAS;oBACjB,aAAa,EAAE,KAAK;iBACrB;aACF;SACF,EACD;YACE,OAAO,kBACL,cAAc,EAAE,kBAAkB,IAC/B,WAAW,CACf;SACF,CACF;aACA,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;CAAA;AApCD,4CAoCC"}
|