@sonarwatch/portfolio-plugins 0.14.78 → 0.14.80
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 +9 -1
- package/package.json +1 -1
- package/src/index.js +4 -0
- package/src/index.js.map +1 -1
- package/src/plugins/debridge/airdropFetcher.d.ts +6 -3
- package/src/plugins/debridge/airdropFetcher.js +59 -71
- package/src/plugins/debridge/airdropFetcher.js.map +1 -1
- package/src/plugins/debridge/constants.d.ts +1 -2
- package/src/plugins/debridge/constants.js +3 -10
- package/src/plugins/debridge/constants.js.map +1 -1
- package/src/plugins/debridge/distributions.json +1 -0
- package/src/plugins/debridge/index.js +9 -3
- package/src/plugins/debridge/index.js.map +1 -1
- package/src/plugins/fragmetric/constants.d.ts +9 -0
- package/src/plugins/fragmetric/constants.js +17 -0
- package/src/plugins/fragmetric/constants.js.map +1 -0
- package/src/plugins/fragmetric/index.d.ts +6 -0
- package/src/plugins/fragmetric/index.js +12 -0
- package/src/plugins/fragmetric/index.js.map +1 -0
- package/src/plugins/fragmetric/pricingJob.d.ts +3 -0
- package/src/plugins/fragmetric/pricingJob.js +112 -0
- package/src/plugins/fragmetric/pricingJob.js.map +1 -0
- package/src/plugins/fragmetric/structs.d.ts +23 -0
- package/src/plugins/fragmetric/structs.js +23 -0
- package/src/plugins/fragmetric/structs.js.map +1 -0
- package/src/plugins/fragmetric/types.d.ts +5 -0
- package/src/plugins/fragmetric/types.js +3 -0
- package/src/plugins/fragmetric/types.js.map +1 -0
- package/src/plugins/jito/constants.d.ts +9 -0
- package/src/plugins/jito/constants.js +26 -1
- package/src/plugins/jito/constants.js.map +1 -1
- package/src/plugins/jito/index.js +5 -3
- package/src/plugins/jito/index.js.map +1 -1
- package/src/plugins/jito/structs.d.ts +58 -0
- package/src/plugins/jito/structs.js +56 -1
- package/src/plugins/jito/structs.js.map +1 -1
- package/src/plugins/jito/ticketFetcher.d.ts +3 -0
- package/src/plugins/jito/ticketFetcher.js +64 -0
- package/src/plugins/jito/ticketFetcher.js.map +1 -0
- package/src/plugins/jito/types.d.ts +5 -0
- package/src/plugins/jito/vaultsJob.d.ts +3 -0
- package/src/plugins/jito/vaultsJob.js +40 -0
- package/src/plugins/jito/vaultsJob.js.map +1 -0
- package/src/plugins/zeta/airdropFetcher.js +14 -14
@@ -10,9 +10,15 @@ const dlmmVaultsJob_1 = __importDefault(require("./dlmmVaultsJob"));
|
|
10
10
|
const dlmmVaultsFetcher_1 = __importDefault(require("./dlmmVaultsFetcher"));
|
11
11
|
exports.platforms = [constants_1.platform];
|
12
12
|
exports.jobs = [dlmmVaultsJob_1.default];
|
13
|
-
exports.fetchers = [
|
13
|
+
exports.fetchers = [
|
14
|
+
dlmmVaultsFetcher_1.default,
|
15
|
+
airdropFetcher_1.dis1Fetcher,
|
16
|
+
airdropFetcher_1.dis2Fetcher,
|
17
|
+
];
|
14
18
|
exports.airdropFetchers = [
|
15
|
-
airdropFetcher_1.
|
16
|
-
airdropFetcher_1.
|
19
|
+
airdropFetcher_1.dis1AirdropFetcherEvm,
|
20
|
+
airdropFetcher_1.dis1AirdropFetcherSolana,
|
21
|
+
airdropFetcher_1.dis2AirdropFetcherEvm,
|
22
|
+
airdropFetcher_1.dis2AirdropFetcherSolana,
|
17
23
|
];
|
18
24
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/debridge/index.ts"],"names":[],"mappings":";;;;;;AAGA,2CAAuC;AACvC,
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/debridge/index.ts"],"names":[],"mappings":";;;;;;AAGA,2CAAuC;AACvC,qDAO0B;AAE1B,oEAA4C;AAC5C,4EAAoD;AAEvC,QAAA,SAAS,GAAe,CAAC,oBAAQ,CAAC,CAAC;AACnC,QAAA,IAAI,GAAU,CAAC,uBAAa,CAAC,CAAC;AAC9B,QAAA,QAAQ,GAAc;IACjC,2BAAiB;IACjB,4BAAW;IACX,4BAAW;CACZ,CAAC;AACW,QAAA,eAAe,GAAqB;IAC/C,sCAAqB;IACrB,yCAAwB;IACxB,sCAAqB;IACrB,yCAAwB;CACzB,CAAC"}
|
@@ -0,0 +1,9 @@
|
|
1
|
+
/// <reference types="jito-ts/node_modules/@solana/web3.js" />
|
2
|
+
import { Platform } from '@sonarwatch/portfolio-core';
|
3
|
+
import { PublicKey } from '@solana/web3.js';
|
4
|
+
export declare const platformId = "fragmetric";
|
5
|
+
export declare const platform: Platform;
|
6
|
+
export declare const fragmetricPid: PublicKey;
|
7
|
+
export declare const nSOLReserve: PublicKey;
|
8
|
+
export declare const fragSOLMint: PublicKey;
|
9
|
+
export declare const nSOLMint = "nSoLnkrvh2aY792pgCNT6hzx84vYtkviRzxvhf3ws8e";
|
@@ -0,0 +1,17 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.nSOLMint = exports.fragSOLMint = exports.nSOLReserve = exports.fragmetricPid = exports.platform = exports.platformId = void 0;
|
4
|
+
const web3_js_1 = require("@solana/web3.js");
|
5
|
+
exports.platformId = 'fragmetric';
|
6
|
+
exports.platform = {
|
7
|
+
id: exports.platformId,
|
8
|
+
name: 'Fragmetric',
|
9
|
+
image: 'https://sonar.watch/img/platforms/fragmetric.webp',
|
10
|
+
website: 'https://fragmetric.xyz/',
|
11
|
+
twitter: 'https://x.com/fragmetric',
|
12
|
+
};
|
13
|
+
exports.fragmetricPid = new web3_js_1.PublicKey('fragnAis7Bp6FTsMoa6YcH8UffhEw43Ph79qAiK3iF3');
|
14
|
+
exports.nSOLReserve = new web3_js_1.PublicKey('4khv6c8D6SqJpi8tUNX5TyVFYKojbpgV1zSE4VAaT68T');
|
15
|
+
exports.fragSOLMint = new web3_js_1.PublicKey('FRAGSEthVFL7fdqM8hxfxkfCZzUvmg21cqPJVvC1qdbo');
|
16
|
+
exports.nSOLMint = 'nSoLnkrvh2aY792pgCNT6hzx84vYtkviRzxvhf3ws8e';
|
17
|
+
//# sourceMappingURL=constants.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/fragmetric/constants.ts"],"names":[],"mappings":";;;AACA,6CAA4C;AAE/B,QAAA,UAAU,GAAG,YAAY,CAAC;AAC1B,QAAA,QAAQ,GAAa;IAChC,EAAE,EAAE,kBAAU;IACd,IAAI,EAAE,YAAY;IAClB,KAAK,EAAE,mDAAmD;IAC1D,OAAO,EAAE,yBAAyB;IAClC,OAAO,EAAE,0BAA0B;CACpC,CAAC;AAEW,QAAA,aAAa,GAAG,IAAI,mBAAS,CACxC,6CAA6C,CAC9C,CAAC;AACW,QAAA,WAAW,GAAG,IAAI,mBAAS,CACtC,8CAA8C,CAC/C,CAAC;AACW,QAAA,WAAW,GAAG,IAAI,mBAAS,CACtC,8CAA8C,CAC/C,CAAC;AACW,QAAA,QAAQ,GAAG,6CAA6C,CAAC"}
|
@@ -0,0 +1,12 @@
|
|
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.fetchers = exports.jobs = exports.platforms = void 0;
|
7
|
+
const constants_1 = require("./constants");
|
8
|
+
const pricingJob_1 = __importDefault(require("./pricingJob"));
|
9
|
+
exports.platforms = [constants_1.platform];
|
10
|
+
exports.jobs = [pricingJob_1.default];
|
11
|
+
exports.fetchers = [];
|
12
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/fragmetric/index.ts"],"names":[],"mappings":";;;;;;AAGA,2CAAuC;AACvC,8DAAsC;AAEzB,QAAA,SAAS,GAAe,CAAC,oBAAQ,CAAC,CAAC;AACnC,QAAA,IAAI,GAAU,CAAC,oBAAU,CAAC,CAAC;AAC3B,QAAA,QAAQ,GAAc,EAAE,CAAC"}
|
@@ -0,0 +1,112 @@
|
|
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 bignumber_js_1 = __importDefault(require("bignumber.js"));
|
17
|
+
const constants_1 = require("./constants");
|
18
|
+
const structs_1 = require("./structs");
|
19
|
+
const solana_1 = require("../../utils/solana");
|
20
|
+
const clients_1 = require("../../utils/clients");
|
21
|
+
const getParsedAccountInfo_1 = require("../../utils/solana/getParsedAccountInfo");
|
22
|
+
const executor = (cache) => __awaiter(void 0, void 0, void 0, function* () {
|
23
|
+
const connection = (0, clients_1.getClientSolana)();
|
24
|
+
const normalizedPools = yield (0, solana_1.getParsedProgramAccounts)(connection, structs_1.normalizedTokenPoolStruct, constants_1.fragmetricPid, [
|
25
|
+
{
|
26
|
+
dataSize: 1887,
|
27
|
+
},
|
28
|
+
]);
|
29
|
+
const [tokenPriceById, tokenMintsAccounts, nSOLReserveAccount] = yield Promise.all([
|
30
|
+
cache.getTokenPricesAsMap(normalizedPools
|
31
|
+
.map((pool) => pool.supported_tokens.map((t) => t.mint.toString()))
|
32
|
+
.flat(), portfolio_core_1.NetworkId.solana),
|
33
|
+
(0, solana_1.getParsedMultipleAccountsInfo)(connection, solana_1.mintAccountStruct, [
|
34
|
+
...normalizedPools.map((pool) => pool.normalized_token_mint),
|
35
|
+
constants_1.fragSOLMint,
|
36
|
+
]),
|
37
|
+
(0, getParsedAccountInfo_1.getParsedAccountInfo)(connection, solana_1.tokenAccountStruct, constants_1.nSOLReserve),
|
38
|
+
]);
|
39
|
+
const sources = [];
|
40
|
+
for (const pool of normalizedPools) {
|
41
|
+
const address = pool.normalized_token_mint.toString();
|
42
|
+
const mintAccount = tokenMintsAccounts.find((acc) => (acc === null || acc === void 0 ? void 0 : acc.pubkey) === pool.normalized_token_mint);
|
43
|
+
if (!mintAccount)
|
44
|
+
continue;
|
45
|
+
const supply = mintAccount.supply.dividedBy(Math.pow(10, mintAccount.decimals));
|
46
|
+
let tvl = new bignumber_js_1.default(0);
|
47
|
+
let missingToken = false;
|
48
|
+
const underlyings = [];
|
49
|
+
for (const token of pool.supported_tokens) {
|
50
|
+
const tokenPrice = tokenPriceById.get(token.mint.toString());
|
51
|
+
if (token.locked_amount.isZero())
|
52
|
+
continue;
|
53
|
+
if (!tokenPrice) {
|
54
|
+
missingToken = true;
|
55
|
+
continue;
|
56
|
+
}
|
57
|
+
tvl = tvl.plus(token.locked_amount
|
58
|
+
.dividedBy(Math.pow(10, tokenPrice.decimals))
|
59
|
+
.times(tokenPrice.price));
|
60
|
+
underlyings.push({
|
61
|
+
address: token.mint.toString(),
|
62
|
+
amountPerLp: token.locked_amount
|
63
|
+
.dividedBy(Math.pow(10, tokenPrice.decimals))
|
64
|
+
.dividedBy(supply)
|
65
|
+
.toNumber(),
|
66
|
+
decimals: tokenPrice.decimals,
|
67
|
+
networkId: portfolio_core_1.NetworkId.solana,
|
68
|
+
price: tokenPrice.price,
|
69
|
+
});
|
70
|
+
}
|
71
|
+
if (missingToken)
|
72
|
+
continue;
|
73
|
+
sources.push({
|
74
|
+
address,
|
75
|
+
decimals: mintAccount.decimals,
|
76
|
+
id: pool.pubkey.toString(),
|
77
|
+
networkId: portfolio_core_1.NetworkId.solana,
|
78
|
+
platformId: portfolio_core_1.walletTokensPlatformId,
|
79
|
+
price: tvl.dividedBy(supply).toNumber(),
|
80
|
+
timestamp: Date.now(),
|
81
|
+
weight: 1,
|
82
|
+
underlyings,
|
83
|
+
});
|
84
|
+
}
|
85
|
+
// Price the fragSOL token which represent the nSOL deposit in jito vault
|
86
|
+
const nSOLPrice = sources.find((tP) => tP.address === constants_1.nSOLMint);
|
87
|
+
const fragSOLMintAccount = tokenMintsAccounts.find((acc) => (acc === null || acc === void 0 ? void 0 : acc.pubkey.toString()) === constants_1.fragSOLMint.toString());
|
88
|
+
if (nSOLPrice && fragSOLMintAccount && nSOLReserveAccount) {
|
89
|
+
const nSOLByfragSOL = nSOLReserveAccount.amount
|
90
|
+
.dividedBy(Math.pow(10, nSOLPrice.decimals))
|
91
|
+
.dividedBy(fragSOLMintAccount.supply.dividedBy(Math.pow(10, fragSOLMintAccount.decimals)));
|
92
|
+
const fragSOLPrice = nSOLByfragSOL.times(nSOLPrice.price);
|
93
|
+
sources.push({
|
94
|
+
address: constants_1.fragSOLMint.toString(),
|
95
|
+
decimals: fragSOLMintAccount.decimals,
|
96
|
+
id: portfolio_core_1.walletTokensPlatformId,
|
97
|
+
networkId: portfolio_core_1.NetworkId.solana,
|
98
|
+
platformId: constants_1.platformId,
|
99
|
+
price: fragSOLPrice.toNumber(),
|
100
|
+
timestamp: Date.now(),
|
101
|
+
weight: 1,
|
102
|
+
});
|
103
|
+
}
|
104
|
+
yield cache.setTokenPriceSources(sources);
|
105
|
+
});
|
106
|
+
const job = {
|
107
|
+
id: `${constants_1.platformId}-pricing`,
|
108
|
+
executor,
|
109
|
+
label: 'normal',
|
110
|
+
};
|
111
|
+
exports.default = job;
|
112
|
+
//# sourceMappingURL=pricingJob.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"pricingJob.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/fragmetric/pricingJob.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,23 @@
|
|
1
|
+
/// <reference types="node" />
|
2
|
+
/// <reference types="jito-ts/node_modules/@solana/web3.js" />
|
3
|
+
import { BeetStruct, FixableBeetStruct } from '@metaplex-foundation/beet';
|
4
|
+
import { PublicKey } from '@solana/web3.js';
|
5
|
+
import BigNumber from 'bignumber.js';
|
6
|
+
export type SupportedToken = {
|
7
|
+
mint: PublicKey;
|
8
|
+
program: PublicKey;
|
9
|
+
lock_account: PublicKey;
|
10
|
+
locked_amount: BigNumber;
|
11
|
+
_reserved: number[];
|
12
|
+
};
|
13
|
+
export declare const supportedTokenStruct: BeetStruct<SupportedToken, Partial<SupportedToken>>;
|
14
|
+
export type NormalizedTokenPool = {
|
15
|
+
buffer: Buffer;
|
16
|
+
data_version: number;
|
17
|
+
bump: number;
|
18
|
+
normalized_token_mint: PublicKey;
|
19
|
+
normalized_token_program: PublicKey;
|
20
|
+
supported_tokens: SupportedToken[];
|
21
|
+
_reserved: number[];
|
22
|
+
};
|
23
|
+
export declare const normalizedTokenPoolStruct: FixableBeetStruct<NormalizedTokenPool, Partial<NormalizedTokenPool>>;
|
@@ -0,0 +1,23 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.normalizedTokenPoolStruct = exports.supportedTokenStruct = void 0;
|
4
|
+
const beet_1 = require("@metaplex-foundation/beet");
|
5
|
+
const beet_solana_1 = require("@metaplex-foundation/beet-solana");
|
6
|
+
const solana_1 = require("../../utils/solana");
|
7
|
+
exports.supportedTokenStruct = new beet_1.BeetStruct([
|
8
|
+
['mint', beet_solana_1.publicKey],
|
9
|
+
['program', beet_solana_1.publicKey],
|
10
|
+
['lock_account', beet_solana_1.publicKey],
|
11
|
+
['locked_amount', solana_1.u64],
|
12
|
+
['_reserved', (0, beet_1.uniformFixedSizeArray)(beet_1.u8, 64)],
|
13
|
+
], (args) => args);
|
14
|
+
exports.normalizedTokenPoolStruct = new beet_1.FixableBeetStruct([
|
15
|
+
['buffer', (0, solana_1.blob)(8)],
|
16
|
+
['data_version', beet_1.u16],
|
17
|
+
['bump', beet_1.u8],
|
18
|
+
['normalized_token_mint', beet_solana_1.publicKey],
|
19
|
+
['normalized_token_program', beet_solana_1.publicKey],
|
20
|
+
['supported_tokens', (0, beet_1.array)(exports.supportedTokenStruct)],
|
21
|
+
['_reserved', (0, beet_1.uniformFixedSizeArray)(beet_1.u8, 128)],
|
22
|
+
], (args) => args);
|
23
|
+
//# sourceMappingURL=structs.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"structs.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/fragmetric/structs.ts"],"names":[],"mappings":";;;AAAA,oDAOmC;AACnC,kEAA6D;AAG7D,+CAA+C;AAUlC,QAAA,oBAAoB,GAAG,IAAI,iBAAU,CAChD;IACE,CAAC,MAAM,EAAE,uBAAS,CAAC;IACnB,CAAC,SAAS,EAAE,uBAAS,CAAC;IACtB,CAAC,cAAc,EAAE,uBAAS,CAAC;IAC3B,CAAC,eAAe,EAAE,YAAG,CAAC;IACtB,CAAC,WAAW,EAAE,IAAA,4BAAqB,EAAC,SAAE,EAAE,EAAE,CAAC,CAAC;CAC7C,EACD,CAAC,IAAI,EAAE,EAAE,CAAC,IAAsB,CACjC,CAAC;AAYW,QAAA,yBAAyB,GACpC,IAAI,wBAAiB,CACnB;IACE,CAAC,QAAQ,EAAE,IAAA,aAAI,EAAC,CAAC,CAAC,CAAC;IACnB,CAAC,cAAc,EAAE,UAAG,CAAC;IACrB,CAAC,MAAM,EAAE,SAAE,CAAC;IACZ,CAAC,uBAAuB,EAAE,uBAAS,CAAC;IACpC,CAAC,0BAA0B,EAAE,uBAAS,CAAC;IACvC,CAAC,kBAAkB,EAAE,IAAA,YAAK,EAAC,4BAAoB,CAAC,CAAC;IACjD,CAAC,WAAW,EAAE,IAAA,4BAAqB,EAAC,SAAE,EAAE,GAAG,CAAC,CAAC;CAC9C,EACD,CAAC,IAAI,EAAE,EAAE,CAAC,IAA2B,CACtC,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/fragmetric/types.ts"],"names":[],"mappings":""}
|
@@ -1,8 +1,17 @@
|
|
1
|
+
/// <reference types="jito-ts/node_modules/@solana/web3.js" />
|
2
|
+
import { PublicKey } from '@solana/web3.js';
|
1
3
|
import { Platform } from '@sonarwatch/portfolio-core';
|
2
4
|
export declare const platformId = "jito";
|
3
5
|
export declare const platform: Platform;
|
6
|
+
export declare const renzoPlatformId = "renzo";
|
7
|
+
export declare const renzoPlatform: Platform;
|
8
|
+
export declare const kyrosPlatformId = "kyros";
|
9
|
+
export declare const kyrosPlatform: Platform;
|
4
10
|
export declare const merkleTree = "HS8EQ8QkQSBJggY8r255AKdWbtYRtyNMoRt4LjNkkWm1";
|
5
11
|
export declare const merkleDistributor = "mERKcfxMC5SqJn4Ld4BUris3WKZZ1ojjWJ3A3J5CKxv";
|
6
12
|
export declare const jtoMint = "jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL";
|
7
13
|
export declare const jtoDecimals = 9;
|
8
14
|
export declare const airdropUrl = "https://airdrop.jito.network/status/";
|
15
|
+
export declare const restakingPid: PublicKey;
|
16
|
+
export declare const restakingVaultsKey = "restaking-vaults";
|
17
|
+
export declare const platformIdByVault: Map<string, string>;
|
@@ -1,6 +1,8 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.airdropUrl = exports.jtoDecimals = exports.jtoMint = exports.merkleDistributor = exports.merkleTree = exports.platform = exports.platformId = void 0;
|
3
|
+
exports.platformIdByVault = exports.restakingVaultsKey = exports.restakingPid = exports.airdropUrl = exports.jtoDecimals = exports.jtoMint = exports.merkleDistributor = exports.merkleTree = exports.kyrosPlatform = exports.kyrosPlatformId = exports.renzoPlatform = exports.renzoPlatformId = exports.platform = exports.platformId = void 0;
|
4
|
+
const web3_js_1 = require("@solana/web3.js");
|
5
|
+
const constants_1 = require("../fragmetric/constants");
|
4
6
|
exports.platformId = 'jito';
|
5
7
|
exports.platform = {
|
6
8
|
id: exports.platformId,
|
@@ -10,9 +12,32 @@ exports.platform = {
|
|
10
12
|
website: 'https://jito.network/harvest',
|
11
13
|
twitter: 'https://twitter.com/jito_sol',
|
12
14
|
};
|
15
|
+
exports.renzoPlatformId = 'renzo';
|
16
|
+
exports.renzoPlatform = {
|
17
|
+
id: exports.renzoPlatformId,
|
18
|
+
name: 'Renzo',
|
19
|
+
image: 'https://sonar.watch/img/platforms/renzo.webp',
|
20
|
+
website: 'https://app.renzoprotocol.com/discover',
|
21
|
+
twitter: 'https://x.com/RenzoProtocol',
|
22
|
+
};
|
23
|
+
exports.kyrosPlatformId = 'kyros';
|
24
|
+
exports.kyrosPlatform = {
|
25
|
+
id: exports.kyrosPlatformId,
|
26
|
+
name: 'Kyros',
|
27
|
+
image: 'https://sonar.watch/img/platforms/kyros.webp',
|
28
|
+
website: 'https://app.kyros.fi/',
|
29
|
+
twitter: 'https://x.com/kyrosfi',
|
30
|
+
};
|
13
31
|
exports.merkleTree = 'HS8EQ8QkQSBJggY8r255AKdWbtYRtyNMoRt4LjNkkWm1';
|
14
32
|
exports.merkleDistributor = 'mERKcfxMC5SqJn4Ld4BUris3WKZZ1ojjWJ3A3J5CKxv';
|
15
33
|
exports.jtoMint = 'jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL';
|
16
34
|
exports.jtoDecimals = 9;
|
17
35
|
exports.airdropUrl = 'https://airdrop.jito.network/status/';
|
36
|
+
exports.restakingPid = new web3_js_1.PublicKey('Vau1t6sLNxnzB7ZDsef8TLbPLfyZMYXH8WTNqUdm9g8');
|
37
|
+
exports.restakingVaultsKey = 'restaking-vaults';
|
38
|
+
exports.platformIdByVault = new Map([
|
39
|
+
['CugziSqZXcUStNPXbtRmq6atsrHqWY2fH2tAhsyApQrV', exports.renzoPlatformId],
|
40
|
+
['CQpvXgoaaawDCLh8FwMZEwQqnPakRUZ5BnzhjnEBPJv', exports.kyrosPlatformId],
|
41
|
+
['HR1ANmDHjaEhknvsTaK48M5xZtbBiwNdXM5NTiWhAb4S', constants_1.platformId],
|
42
|
+
]);
|
18
43
|
//# sourceMappingURL=constants.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/jito/constants.ts"],"names":[],"mappings":";;;
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/jito/constants.ts"],"names":[],"mappings":";;;AAAA,6CAA4C;AAE5C,uDAA6E;AAEhE,QAAA,UAAU,GAAG,MAAM,CAAC;AACpB,QAAA,QAAQ,GAAa;IAChC,EAAE,EAAE,kBAAU;IACd,IAAI,EAAE,MAAM;IACZ,KAAK,EAAE,6CAA6C;IACpD,WAAW,EAAE,MAAM;IACnB,OAAO,EAAE,8BAA8B;IACvC,OAAO,EAAE,8BAA8B;CACxC,CAAC;AAEW,QAAA,eAAe,GAAG,OAAO,CAAC;AAC1B,QAAA,aAAa,GAAa;IACrC,EAAE,EAAE,uBAAe;IACnB,IAAI,EAAE,OAAO;IACb,KAAK,EAAE,8CAA8C;IACrD,OAAO,EAAE,wCAAwC;IACjD,OAAO,EAAE,6BAA6B;CACvC,CAAC;AAEW,QAAA,eAAe,GAAG,OAAO,CAAC;AAC1B,QAAA,aAAa,GAAa;IACrC,EAAE,EAAE,uBAAe;IACnB,IAAI,EAAE,OAAO;IACb,KAAK,EAAE,8CAA8C;IACrD,OAAO,EAAE,uBAAuB;IAChC,OAAO,EAAE,uBAAuB;CACjC,CAAC;AAEW,QAAA,UAAU,GAAG,8CAA8C,CAAC;AAC5D,QAAA,iBAAiB,GAAG,6CAA6C,CAAC;AAClE,QAAA,OAAO,GAAG,6CAA6C,CAAC;AACxD,QAAA,WAAW,GAAG,CAAC,CAAC;AAChB,QAAA,UAAU,GAAG,sCAAsC,CAAC;AAEpD,QAAA,YAAY,GAAG,IAAI,mBAAS,CACvC,6CAA6C,CAC9C,CAAC;AACW,QAAA,kBAAkB,GAAG,kBAAkB,CAAC;AAExC,QAAA,iBAAiB,GAAG,IAAI,GAAG,CAAC;IACvC,CAAC,8CAA8C,EAAE,uBAAe,CAAC;IACjE,CAAC,6CAA6C,EAAE,uBAAe,CAAC;IAChE,CAAC,8CAA8C,EAAE,sBAAoB,CAAC;CACvE,CAAC,CAAC"}
|
@@ -6,7 +6,9 @@ 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 airdropFetcher_1 = __importDefault(require("./airdropFetcher"));
|
9
|
-
|
10
|
-
|
11
|
-
exports.
|
9
|
+
const vaultsJob_1 = __importDefault(require("./vaultsJob"));
|
10
|
+
const ticketFetcher_1 = __importDefault(require("./ticketFetcher"));
|
11
|
+
exports.platforms = [constants_1.platform, constants_1.renzoPlatform, constants_1.kyrosPlatform];
|
12
|
+
exports.jobs = [vaultsJob_1.default];
|
13
|
+
exports.fetchers = [airdropFetcher_1.default, ticketFetcher_1.default];
|
12
14
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/jito/index.ts"],"names":[],"mappings":";;;;;;AAGA,
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/jito/index.ts"],"names":[],"mappings":";;;;;;AAGA,2CAAqE;AACrE,sEAA6C;AAC7C,4DAAoC;AACpC,oEAA4C;AAE/B,QAAA,SAAS,GAAe,CAAC,oBAAQ,EAAE,yBAAa,EAAE,yBAAa,CAAC,CAAC;AACjE,QAAA,IAAI,GAAU,CAAC,mBAAS,CAAC,CAAC;AAC1B,QAAA,QAAQ,GAAc,CAAC,wBAAa,EAAE,uBAAa,CAAC,CAAC"}
|
@@ -11,3 +11,61 @@ export type ClaimStatus = {
|
|
11
11
|
unlockedAmount: BigNumber;
|
12
12
|
};
|
13
13
|
export declare const claimStatusStruct: BeetStruct<ClaimStatus, Partial<ClaimStatus>>;
|
14
|
+
export type VaultNcnTicket = {
|
15
|
+
buffer: Buffer;
|
16
|
+
vault: PublicKey;
|
17
|
+
staker: PublicKey;
|
18
|
+
base: PublicKey;
|
19
|
+
vrtAmount: BigNumber;
|
20
|
+
slotUnstaked: BigNumber;
|
21
|
+
bump: number;
|
22
|
+
reserved: number[];
|
23
|
+
};
|
24
|
+
export declare const vaultNcnTicketStruct: BeetStruct<VaultNcnTicket, Partial<VaultNcnTicket>>;
|
25
|
+
export type DelegationState = {
|
26
|
+
stakedAmount: BigNumber;
|
27
|
+
enqueuedForCooldownAmount: BigNumber;
|
28
|
+
coolingDownAmount: BigNumber;
|
29
|
+
reserved: number[];
|
30
|
+
};
|
31
|
+
export declare const delegationStateStruct: BeetStruct<DelegationState, Partial<DelegationState>>;
|
32
|
+
export type Vault = {
|
33
|
+
buffer: Buffer;
|
34
|
+
base: PublicKey;
|
35
|
+
vrtMint: PublicKey;
|
36
|
+
supportedMint: PublicKey;
|
37
|
+
vrtSupply: BigNumber;
|
38
|
+
tokensDeposited: BigNumber;
|
39
|
+
depositCapacity: BigNumber;
|
40
|
+
delegationState: DelegationState;
|
41
|
+
additionalAssetsNeedUnstaking: BigNumber;
|
42
|
+
vrtEnqueuedForCooldownAmount: BigNumber;
|
43
|
+
vrtCoolingDownAmount: BigNumber;
|
44
|
+
vrtReadyToClaimAmount: BigNumber;
|
45
|
+
admin: PublicKey;
|
46
|
+
delegationAdmin: PublicKey;
|
47
|
+
operatorAdmin: PublicKey;
|
48
|
+
ncnAdmin: PublicKey;
|
49
|
+
slasherAdmin: PublicKey;
|
50
|
+
capacityAdmin: PublicKey;
|
51
|
+
feeAdmin: PublicKey;
|
52
|
+
delegateAssetAdmin: PublicKey;
|
53
|
+
feeWallet: PublicKey;
|
54
|
+
mintBurnAdmin: PublicKey;
|
55
|
+
metadataAdmin: PublicKey;
|
56
|
+
vaultIndex: BigNumber;
|
57
|
+
ncnCount: BigNumber;
|
58
|
+
operatorCount: BigNumber;
|
59
|
+
slasherCount: BigNumber;
|
60
|
+
lastFeeChangeSlot: BigNumber;
|
61
|
+
lastFullStateUpdateSlot: BigNumber;
|
62
|
+
depositFeeBps: number;
|
63
|
+
withdrawalFeeBps: number;
|
64
|
+
nextWithdrawalFeeBps: number;
|
65
|
+
rewardFeeBps: number;
|
66
|
+
programFeeBps: number;
|
67
|
+
bump: number;
|
68
|
+
isPaused: boolean;
|
69
|
+
reserved: number[];
|
70
|
+
};
|
71
|
+
export declare const vaultStruct: BeetStruct<Vault, Partial<Vault>>;
|
@@ -1,6 +1,6 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.claimStatusStruct = void 0;
|
3
|
+
exports.vaultStruct = exports.delegationStateStruct = exports.vaultNcnTicketStruct = exports.claimStatusStruct = 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");
|
@@ -11,4 +11,59 @@ exports.claimStatusStruct = new beet_1.BeetStruct([
|
|
11
11
|
['lockedAmountWithdrawn', solana_1.u64],
|
12
12
|
['unlockedAmount', solana_1.u64],
|
13
13
|
], (args) => args);
|
14
|
+
exports.vaultNcnTicketStruct = new beet_1.BeetStruct([
|
15
|
+
['buffer', (0, solana_1.blob)(8)],
|
16
|
+
['vault', beet_solana_1.publicKey],
|
17
|
+
['staker', beet_solana_1.publicKey],
|
18
|
+
['base', beet_solana_1.publicKey],
|
19
|
+
['vrtAmount', solana_1.u64],
|
20
|
+
['slotUnstaked', solana_1.u64],
|
21
|
+
['bump', beet_1.u8],
|
22
|
+
['reserved', (0, beet_1.uniformFixedSizeArray)(beet_1.u8, 263)],
|
23
|
+
], (args) => args);
|
24
|
+
exports.delegationStateStruct = new beet_1.BeetStruct([
|
25
|
+
['stakedAmount', solana_1.u64],
|
26
|
+
['enqueuedForCooldownAmount', solana_1.u64],
|
27
|
+
['coolingDownAmount', solana_1.u64],
|
28
|
+
['reserved', (0, beet_1.uniformFixedSizeArray)(beet_1.u8, 256)],
|
29
|
+
], (args) => args);
|
30
|
+
exports.vaultStruct = new beet_1.BeetStruct([
|
31
|
+
['buffer', (0, solana_1.blob)(8)],
|
32
|
+
['base', beet_solana_1.publicKey],
|
33
|
+
['vrtMint', beet_solana_1.publicKey],
|
34
|
+
['supportedMint', beet_solana_1.publicKey],
|
35
|
+
['vrtSupply', solana_1.u64],
|
36
|
+
['tokensDeposited', solana_1.u64],
|
37
|
+
['depositCapacity', solana_1.u64],
|
38
|
+
['delegationState', exports.delegationStateStruct],
|
39
|
+
['additionalAssetsNeedUnstaking', solana_1.u64],
|
40
|
+
['vrtEnqueuedForCooldownAmount', solana_1.u64],
|
41
|
+
['vrtCoolingDownAmount', solana_1.u64],
|
42
|
+
['vrtReadyToClaimAmount', solana_1.u64],
|
43
|
+
['admin', beet_solana_1.publicKey],
|
44
|
+
['delegationAdmin', beet_solana_1.publicKey],
|
45
|
+
['operatorAdmin', beet_solana_1.publicKey],
|
46
|
+
['ncnAdmin', beet_solana_1.publicKey],
|
47
|
+
['slasherAdmin', beet_solana_1.publicKey],
|
48
|
+
['capacityAdmin', beet_solana_1.publicKey],
|
49
|
+
['feeAdmin', beet_solana_1.publicKey],
|
50
|
+
['delegateAssetAdmin', beet_solana_1.publicKey],
|
51
|
+
['feeWallet', beet_solana_1.publicKey],
|
52
|
+
['mintBurnAdmin', beet_solana_1.publicKey],
|
53
|
+
['metadataAdmin', beet_solana_1.publicKey],
|
54
|
+
['vaultIndex', solana_1.u64],
|
55
|
+
['ncnCount', solana_1.u64],
|
56
|
+
['operatorCount', solana_1.u64],
|
57
|
+
['slasherCount', solana_1.u64],
|
58
|
+
['lastFeeChangeSlot', solana_1.u64],
|
59
|
+
['lastFullStateUpdateSlot', solana_1.u64],
|
60
|
+
['depositFeeBps', beet_1.u16],
|
61
|
+
['withdrawalFeeBps', beet_1.u16],
|
62
|
+
['nextWithdrawalFeeBps', beet_1.u16],
|
63
|
+
['rewardFeeBps', beet_1.u16],
|
64
|
+
['programFeeBps', beet_1.u16],
|
65
|
+
['bump', beet_1.u8],
|
66
|
+
['isPaused', beet_1.bool],
|
67
|
+
['reserved', (0, beet_1.uniformFixedSizeArray)(beet_1.u8, 259)],
|
68
|
+
], (args) => args);
|
14
69
|
//# sourceMappingURL=structs.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"structs.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/jito/structs.ts"],"names":[],"mappings":";;;AAAA,
|
1
|
+
{"version":3,"file":"structs.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/jito/structs.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,64 @@
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
12
|
+
const portfolio_core_1 = require("@sonarwatch/portfolio-core");
|
13
|
+
const constants_1 = require("./constants");
|
14
|
+
const structs_1 = require("./structs");
|
15
|
+
const filters_1 = require("../../utils/solana/filters");
|
16
|
+
const clients_1 = require("../../utils/clients");
|
17
|
+
const solana_1 = require("../../utils/solana");
|
18
|
+
const ElementRegistry_1 = require("../../utils/elementbuilder/ElementRegistry");
|
19
|
+
const executor = (owner, cache) => __awaiter(void 0, void 0, void 0, function* () {
|
20
|
+
const client = (0, clients_1.getClientSolana)();
|
21
|
+
const [ticketsAccounts, vaultsInfo, slot] = yield Promise.all([
|
22
|
+
(0, solana_1.getParsedProgramAccounts)(client, structs_1.vaultNcnTicketStruct, constants_1.restakingPid, [
|
23
|
+
...(0, filters_1.dataSizeFilter)(structs_1.vaultNcnTicketStruct.byteSize),
|
24
|
+
{
|
25
|
+
memcmp: {
|
26
|
+
offset: 40,
|
27
|
+
bytes: owner,
|
28
|
+
},
|
29
|
+
},
|
30
|
+
]),
|
31
|
+
cache.getItem(constants_1.restakingVaultsKey, {
|
32
|
+
prefix: constants_1.platformId,
|
33
|
+
networkId: portfolio_core_1.NetworkId.solana,
|
34
|
+
}),
|
35
|
+
client.getSlot(),
|
36
|
+
]);
|
37
|
+
if (ticketsAccounts.length === 0 || !vaultsInfo)
|
38
|
+
return [];
|
39
|
+
const registry = new ElementRegistry_1.ElementRegistry(portfolio_core_1.NetworkId.solana, constants_1.platformId);
|
40
|
+
for (const ticket of ticketsAccounts) {
|
41
|
+
const vault = vaultsInfo.find((v) => v.pubkey === ticket.vault.toString());
|
42
|
+
if (!vault)
|
43
|
+
continue;
|
44
|
+
const element = registry.addElementMultiple({
|
45
|
+
platformId: vault.platformId,
|
46
|
+
label: 'Deposit',
|
47
|
+
});
|
48
|
+
element.addAsset({
|
49
|
+
address: vault.vrtMint,
|
50
|
+
amount: ticket.vrtAmount,
|
51
|
+
attributes: {
|
52
|
+
isClaimable: ticket.slotUnstaked.isLessThanOrEqualTo(slot),
|
53
|
+
},
|
54
|
+
});
|
55
|
+
}
|
56
|
+
return registry.getElements(cache);
|
57
|
+
});
|
58
|
+
const fetcher = {
|
59
|
+
id: `${constants_1.platformId}-restaking-tickets`,
|
60
|
+
networkId: portfolio_core_1.NetworkId.solana,
|
61
|
+
executor,
|
62
|
+
};
|
63
|
+
exports.default = fetcher;
|
64
|
+
//# sourceMappingURL=ticketFetcher.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ticketFetcher.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/jito/ticketFetcher.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,+DAAuD;AACvD,2CAA2E;AAC3E,uCAAiD;AACjD,wDAA4D;AAC5D,iDAAsD;AAEtD,+CAA8D;AAG9D,gFAA6E;AAE7E,MAAM,QAAQ,GAAoB,CAAO,KAAa,EAAE,KAAY,EAAE,EAAE;IACtE,MAAM,MAAM,GAAG,IAAA,yBAAe,GAAE,CAAC;IAEjC,MAAM,CAAC,eAAe,EAAE,UAAU,EAAE,IAAI,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QAC5D,IAAA,iCAAwB,EAAC,MAAM,EAAE,8BAAoB,EAAE,wBAAY,EAAE;YACnE,GAAG,IAAA,wBAAc,EAAC,8BAAoB,CAAC,QAAQ,CAAC;YAChD;gBACE,MAAM,EAAE;oBACN,MAAM,EAAE,EAAE;oBACV,KAAK,EAAE,KAAK;iBACb;aACF;SACF,CAAC;QACF,KAAK,CAAC,OAAO,CAAuB,8BAAkB,EAAE;YACtD,MAAM,EAAE,sBAAU;YAClB,SAAS,EAAE,0BAAS,CAAC,MAAM;SAC5B,CAAC;QACF,MAAM,CAAC,OAAO,EAAE;KACjB,CAAC,CAAC;IAEH,IAAI,eAAe,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,UAAU;QAAE,OAAO,EAAE,CAAC;IAE3D,MAAM,QAAQ,GAAG,IAAI,iCAAe,CAAC,0BAAS,CAAC,MAAM,EAAE,sBAAU,CAAC,CAAC;IAEnE,KAAK,MAAM,MAAM,IAAI,eAAe,EAAE,CAAC;QACrC,MAAM,KAAK,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC3E,IAAI,CAAC,KAAK;YAAE,SAAS;QAErB,MAAM,OAAO,GAAG,QAAQ,CAAC,kBAAkB,CAAC;YAC1C,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,KAAK,EAAE,SAAS;SACjB,CAAC,CAAC;QAEH,OAAO,CAAC,QAAQ,CAAC;YACf,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,MAAM,EAAE,MAAM,CAAC,SAAS;YACxB,UAAU,EAAE;gBACV,WAAW,EAAE,MAAM,CAAC,YAAY,CAAC,mBAAmB,CAAC,IAAI,CAAC;aAC3D;SACF,CAAC,CAAC;IACL,CAAC;IAED,OAAO,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;AACrC,CAAC,CAAA,CAAC;AAEF,MAAM,OAAO,GAAY;IACvB,EAAE,EAAE,GAAG,sBAAU,oBAAoB;IACrC,SAAS,EAAE,0BAAS,CAAC,MAAM;IAC3B,QAAQ;CACT,CAAC;AAEF,kBAAe,OAAO,CAAC"}
|