@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.
Files changed (44) hide show
  1. package/CHANGELOG.md +9 -1
  2. package/package.json +1 -1
  3. package/src/index.js +4 -0
  4. package/src/index.js.map +1 -1
  5. package/src/plugins/debridge/airdropFetcher.d.ts +6 -3
  6. package/src/plugins/debridge/airdropFetcher.js +59 -71
  7. package/src/plugins/debridge/airdropFetcher.js.map +1 -1
  8. package/src/plugins/debridge/constants.d.ts +1 -2
  9. package/src/plugins/debridge/constants.js +3 -10
  10. package/src/plugins/debridge/constants.js.map +1 -1
  11. package/src/plugins/debridge/distributions.json +1 -0
  12. package/src/plugins/debridge/index.js +9 -3
  13. package/src/plugins/debridge/index.js.map +1 -1
  14. package/src/plugins/fragmetric/constants.d.ts +9 -0
  15. package/src/plugins/fragmetric/constants.js +17 -0
  16. package/src/plugins/fragmetric/constants.js.map +1 -0
  17. package/src/plugins/fragmetric/index.d.ts +6 -0
  18. package/src/plugins/fragmetric/index.js +12 -0
  19. package/src/plugins/fragmetric/index.js.map +1 -0
  20. package/src/plugins/fragmetric/pricingJob.d.ts +3 -0
  21. package/src/plugins/fragmetric/pricingJob.js +112 -0
  22. package/src/plugins/fragmetric/pricingJob.js.map +1 -0
  23. package/src/plugins/fragmetric/structs.d.ts +23 -0
  24. package/src/plugins/fragmetric/structs.js +23 -0
  25. package/src/plugins/fragmetric/structs.js.map +1 -0
  26. package/src/plugins/fragmetric/types.d.ts +5 -0
  27. package/src/plugins/fragmetric/types.js +3 -0
  28. package/src/plugins/fragmetric/types.js.map +1 -0
  29. package/src/plugins/jito/constants.d.ts +9 -0
  30. package/src/plugins/jito/constants.js +26 -1
  31. package/src/plugins/jito/constants.js.map +1 -1
  32. package/src/plugins/jito/index.js +5 -3
  33. package/src/plugins/jito/index.js.map +1 -1
  34. package/src/plugins/jito/structs.d.ts +58 -0
  35. package/src/plugins/jito/structs.js +56 -1
  36. package/src/plugins/jito/structs.js.map +1 -1
  37. package/src/plugins/jito/ticketFetcher.d.ts +3 -0
  38. package/src/plugins/jito/ticketFetcher.js +64 -0
  39. package/src/plugins/jito/ticketFetcher.js.map +1 -0
  40. package/src/plugins/jito/types.d.ts +5 -0
  41. package/src/plugins/jito/vaultsJob.d.ts +3 -0
  42. package/src/plugins/jito/vaultsJob.js +40 -0
  43. package/src/plugins/jito/vaultsJob.js.map +1 -0
  44. 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 = [dlmmVaultsFetcher_1.default, airdropFetcher_1.fetcher];
13
+ exports.fetchers = [
14
+ dlmmVaultsFetcher_1.default,
15
+ airdropFetcher_1.dis1Fetcher,
16
+ airdropFetcher_1.dis2Fetcher,
17
+ ];
14
18
  exports.airdropFetchers = [
15
- airdropFetcher_1.airdropFetcherEvm,
16
- airdropFetcher_1.airdropFetcherSolana,
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,qDAI0B;AAE1B,oEAA4C;AAC5C,4EAAoD;AAEvC,QAAA,SAAS,GAAe,CAAC,oBAAQ,CAAC,CAAC;AACnC,QAAA,IAAI,GAAU,CAAC,uBAAa,CAAC,CAAC;AAC9B,QAAA,QAAQ,GAAc,CAAC,2BAAiB,EAAE,wBAAO,CAAC,CAAC;AACnD,QAAA,eAAe,GAAqB;IAC/C,kCAAiB;IACjB,qCAAoB;CACrB,CAAC"}
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,6 @@
1
+ import { Platform } from '@sonarwatch/portfolio-core';
2
+ import { Fetcher } from '../../Fetcher';
3
+ import { Job } from '../../Job';
4
+ export declare const platforms: Platform[];
5
+ export declare const jobs: Job[];
6
+ export declare const fetchers: Fetcher[];
@@ -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,3 @@
1
+ import { Job } from '../../Job';
2
+ declare const job: Job;
3
+ export default job;
@@ -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,5 @@
1
+ import { ID } from '../../utils/sui/types/id';
2
+ export type Receipt = {
3
+ id: ID;
4
+ amountDeposited: string;
5
+ };
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -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":";;;AAEa,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,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"}
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
- exports.platforms = [constants_1.platform];
10
- exports.jobs = [];
11
- exports.fetchers = [airdropFetcher_1.default];
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,2CAAuC;AACvC,sEAA6C;AAEhC,QAAA,SAAS,GAAe,CAAC,oBAAQ,CAAC,CAAC;AACnC,QAAA,IAAI,GAAU,EAAE,CAAC;AACjB,QAAA,QAAQ,GAAc,CAAC,wBAAa,CAAC,CAAC"}
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,oDAAuD;AAGvD,kEAA6D;AAC7D,+CAA+C;AAUlC,QAAA,iBAAiB,GAAG,IAAI,iBAAU,CAC7C;IACE,CAAC,QAAQ,EAAE,IAAA,aAAI,EAAC,CAAC,CAAC,CAAC;IACnB,CAAC,UAAU,EAAE,uBAAS,CAAC;IACvB,CAAC,cAAc,EAAE,YAAG,CAAC;IACrB,CAAC,uBAAuB,EAAE,YAAG,CAAC;IAC9B,CAAC,gBAAgB,EAAE,YAAG,CAAC;CACxB,EACD,CAAC,IAAI,EAAE,EAAE,CAAC,IAAmB,CAC9B,CAAC"}
1
+ {"version":3,"file":"structs.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/jito/structs.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Fetcher } from '../../Fetcher';
2
+ declare const fetcher: Fetcher;
3
+ export default fetcher;
@@ -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"}
@@ -9,3 +9,8 @@ export type ClaimStatus = {
9
9
  amount_locked_withdrawable: number;
10
10
  amount_locked_withdrawn: number;
11
11
  };
12
+ export type RestakingVaultInfo = {
13
+ pubkey: string;
14
+ vrtMint: string;
15
+ platformId?: string;
16
+ };
@@ -0,0 +1,3 @@
1
+ import { Job } from '../../Job';
2
+ declare const job: Job;
3
+ export default job;