@sonarwatch/portfolio-plugins 0.14.109 → 0.14.111

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 (57) hide show
  1. package/CHANGELOG.md +2036 -2028
  2. package/README.md +3 -3
  3. package/package.json +3 -3
  4. package/src/AirdropFetcher.js +1 -0
  5. package/src/AirdropFetcher.js.map +1 -1
  6. package/src/index.js +4 -0
  7. package/src/index.js.map +1 -1
  8. package/src/plugins/balancer/helpers/pools.js +21 -21
  9. package/src/plugins/drift/depositsFetcher.js +2 -0
  10. package/src/plugins/drift/depositsFetcher.js.map +1 -1
  11. package/src/plugins/drift/perpHelpers/getOraclePrice.d.ts +1 -1
  12. package/src/plugins/drift/perpHelpers/getOraclePrice.js +9 -3
  13. package/src/plugins/drift/perpHelpers/getOraclePrice.js.map +1 -1
  14. package/src/plugins/drift/perpHelpers/pyth.d.ts +1 -0
  15. package/src/plugins/drift/perpHelpers/pyth.js +12 -1
  16. package/src/plugins/drift/perpHelpers/pyth.js.map +1 -1
  17. package/src/plugins/drift/struct.d.ts +12 -1
  18. package/src/plugins/drift/struct.js +11 -1
  19. package/src/plugins/drift/struct.js.map +1 -1
  20. package/src/plugins/jupiter/governance/constants.d.ts +2 -0
  21. package/src/plugins/jupiter/governance/constants.js +20 -1
  22. package/src/plugins/jupiter/governance/constants.js.map +1 -1
  23. package/src/plugins/jupiter/governance/index.d.ts +2 -0
  24. package/src/plugins/jupiter/governance/index.js +7 -1
  25. package/src/plugins/jupiter/governance/index.js.map +1 -1
  26. package/src/plugins/jupiter/index.js +2 -0
  27. package/src/plugins/jupiter/index.js.map +1 -1
  28. package/src/plugins/pluto/constants.d.ts +2 -0
  29. package/src/plugins/pluto/constants.js +3 -1
  30. package/src/plugins/pluto/constants.js.map +1 -1
  31. package/src/plugins/pluto/index.js +6 -1
  32. package/src/plugins/pluto/index.js.map +1 -1
  33. package/src/plugins/pluto/leverageFetcher.js +24 -17
  34. package/src/plugins/pluto/leverageFetcher.js.map +1 -1
  35. package/src/plugins/pluto/leverageVaultsApiJob.d.ts +3 -0
  36. package/src/plugins/pluto/leverageVaultsApiJob.js +33 -0
  37. package/src/plugins/pluto/leverageVaultsApiJob.js.map +1 -0
  38. package/src/plugins/pluto/types.d.ts +32 -0
  39. package/src/plugins/pluto/types.js +3 -0
  40. package/src/plugins/pluto/types.js.map +1 -0
  41. package/src/plugins/sushiswap/helpers.js +24 -24
  42. package/src/plugins/triad/constants.d.ts +7 -0
  43. package/src/plugins/triad/constants.js +14 -0
  44. package/src/plugins/triad/constants.js.map +1 -0
  45. package/src/plugins/triad/index.d.ts +6 -0
  46. package/src/plugins/triad/index.js +12 -0
  47. package/src/plugins/triad/index.js.map +1 -0
  48. package/src/plugins/triad/stakingFetcher.d.ts +3 -0
  49. package/src/plugins/triad/stakingFetcher.js +70 -0
  50. package/src/plugins/triad/stakingFetcher.js.map +1 -0
  51. package/src/plugins/triad/structs.d.ts +23 -0
  52. package/src/plugins/triad/structs.js +23 -0
  53. package/src/plugins/triad/structs.js.map +1 -0
  54. package/src/plugins/uniswap-v2/helpers.js +22 -22
  55. package/src/plugins/zeta/airdropFetcher.js +14 -14
  56. package/src/utils/sei/constants.js +8 -8
  57. package/src/utils/sei/getQueryBalanceByOwner.js +4 -4
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.leveragesVaultKey = exports.earnVaultsKey = exports.leverageObligationDataSize = exports.leverageVaultDataSize = exports.earnLenderDataSize = exports.earnVaultDataSize = exports.plutoProgramId = exports.platform = exports.platformId = void 0;
3
+ exports.leverageVaultsApiUrl = exports.leveragesVaultApiKey = exports.leveragesVaultKey = exports.earnVaultsKey = exports.leverageObligationDataSize = exports.leverageVaultDataSize = exports.earnLenderDataSize = exports.earnVaultDataSize = exports.plutoProgramId = exports.platform = exports.platformId = void 0;
4
4
  const web3_js_1 = require("@solana/web3.js");
5
5
  exports.platformId = 'pluto';
6
6
  exports.platform = {
@@ -18,4 +18,6 @@ exports.leverageVaultDataSize = 1496;
18
18
  exports.leverageObligationDataSize = 6696;
19
19
  exports.earnVaultsKey = 'earn-vaults';
20
20
  exports.leveragesVaultKey = 'leverage-vaults';
21
+ exports.leveragesVaultApiKey = 'leverage-vaults-api';
22
+ exports.leverageVaultsApiUrl = 'https://storage.googleapis.com/plutoso/accounts.json';
21
23
  //# sourceMappingURL=constants.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/pluto/constants.ts"],"names":[],"mappings":";;;AACA,6CAA4C;AAE/B,QAAA,UAAU,GAAG,OAAO,CAAC;AACrB,QAAA,QAAQ,GAAa;IAChC,EAAE,EAAE,kBAAU;IACd,IAAI,EAAE,OAAO;IACb,KAAK,EAAE,8CAA8C;IACrD,OAAO,EAAE,mBAAmB;IAC5B,OAAO,EAAE,6BAA6B;IACtC,OAAO,EAAE,0CAA0C;CACpD,CAAC;AAEW,QAAA,cAAc,GAAG,IAAI,mBAAS,CACzC,8CAA8C,CAC/C,CAAC;AAEW,QAAA,iBAAiB,GAAG,IAAI,CAAC;AACzB,QAAA,kBAAkB,GAAG,GAAG,CAAC;AACzB,QAAA,qBAAqB,GAAG,IAAI,CAAC;AAC7B,QAAA,0BAA0B,GAAG,IAAI,CAAC;AAElC,QAAA,aAAa,GAAG,aAAa,CAAC;AAC9B,QAAA,iBAAiB,GAAG,iBAAiB,CAAC"}
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/pluto/constants.ts"],"names":[],"mappings":";;;AACA,6CAA4C;AAE/B,QAAA,UAAU,GAAG,OAAO,CAAC;AACrB,QAAA,QAAQ,GAAa;IAChC,EAAE,EAAE,kBAAU;IACd,IAAI,EAAE,OAAO;IACb,KAAK,EAAE,8CAA8C;IACrD,OAAO,EAAE,mBAAmB;IAC5B,OAAO,EAAE,6BAA6B;IACtC,OAAO,EAAE,0CAA0C;CACpD,CAAC;AAEW,QAAA,cAAc,GAAG,IAAI,mBAAS,CACzC,8CAA8C,CAC/C,CAAC;AAEW,QAAA,iBAAiB,GAAG,IAAI,CAAC;AACzB,QAAA,kBAAkB,GAAG,GAAG,CAAC;AACzB,QAAA,qBAAqB,GAAG,IAAI,CAAC;AAC7B,QAAA,0BAA0B,GAAG,IAAI,CAAC;AAElC,QAAA,aAAa,GAAG,aAAa,CAAC;AAC9B,QAAA,iBAAiB,GAAG,iBAAiB,CAAC;AACtC,QAAA,oBAAoB,GAAG,qBAAqB,CAAC;AAE7C,QAAA,oBAAoB,GAC/B,sDAAsD,CAAC"}
@@ -9,7 +9,12 @@ const leverageFetcher_1 = __importDefault(require("./leverageFetcher"));
9
9
  const earnFetcher_1 = __importDefault(require("./earnFetcher"));
10
10
  const earnVaultsJob_1 = __importDefault(require("./earnVaultsJob"));
11
11
  const leverageVaultsJob_1 = __importDefault(require("./leverageVaultsJob"));
12
+ const leverageVaultsApiJob_1 = __importDefault(require("./leverageVaultsApiJob"));
12
13
  exports.platforms = [constants_1.platform];
13
- exports.jobs = [earnVaultsJob_1.default, leverageVaultsJob_1.default];
14
+ exports.jobs = [
15
+ earnVaultsJob_1.default,
16
+ leverageVaultsJob_1.default,
17
+ leverageVaultsApiJob_1.default,
18
+ ];
14
19
  exports.fetchers = [earnFetcher_1.default, leverageFetcher_1.default];
15
20
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/pluto/index.ts"],"names":[],"mappings":";;;;;;AAGA,2CAAuC;AAEvC,wEAAgD;AAChD,gEAAwC;AACxC,oEAA4C;AAC5C,4EAAoD;AAEvC,QAAA,SAAS,GAAe,CAAC,oBAAQ,CAAC,CAAC;AACnC,QAAA,IAAI,GAAU,CAAC,uBAAa,EAAE,2BAAiB,CAAC,CAAC;AACjD,QAAA,QAAQ,GAAc,CAAC,qBAAW,EAAE,yBAAe,CAAC,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/pluto/index.ts"],"names":[],"mappings":";;;;;;AAGA,2CAAuC;AAEvC,wEAAgD;AAChD,gEAAwC;AACxC,oEAA4C;AAC5C,4EAAoD;AACpD,kFAA0D;AAE7C,QAAA,SAAS,GAAe,CAAC,oBAAQ,CAAC,CAAC;AACnC,QAAA,IAAI,GAAU;IACzB,uBAAa;IACb,2BAAiB;IACjB,8BAAoB;CACrB,CAAC;AACW,QAAA,QAAQ,GAAc,CAAC,qBAAW,EAAE,yBAAe,CAAC,CAAC"}
@@ -19,6 +19,10 @@ const leverageVaultsMemo = new MemoizedCache_1.MemoizedCache(constants_1.leverag
19
19
  prefix: constants_1.platformId,
20
20
  networkId: portfolio_core_1.NetworkId.solana,
21
21
  });
22
+ const leverageVaultsApiMemo = new MemoizedCache_1.MemoizedCache(constants_1.leveragesVaultApiKey, {
23
+ prefix: constants_1.platformId,
24
+ networkId: portfolio_core_1.NetworkId.solana,
25
+ });
22
26
  const executor = (owner, cache) => __awaiter(void 0, void 0, void 0, function* () {
23
27
  const client = (0, clients_1.getClientSolana)();
24
28
  const accounts = yield (0, helper_1.getLeverageObligations)(client, owner);
@@ -27,13 +31,16 @@ const executor = (owner, cache) => __awaiter(void 0, void 0, void 0, function* (
27
31
  const vaults = yield leverageVaultsMemo.getItem(cache);
28
32
  if (!vaults.length)
29
33
  return [];
34
+ // used only for vault name, non necessary
35
+ const vaultsApi = yield leverageVaultsApiMemo.getItem(cache);
30
36
  const elementRegistry = new ElementRegistry_1.ElementRegistry(portfolio_core_1.NetworkId.solana, constants_1.platformId);
31
37
  accounts.forEach((acc) => {
32
- const vault = vaults.find((v) => v.protocol.toString() === acc.protocol.toString());
38
+ const vault = vaults.find((v) => v.pubkey.toString() === acc.vault.toString());
33
39
  if (!vault)
34
40
  return;
41
+ const vaultFromApi = vaultsApi.find((v) => v.leverageVault === vault.pubkey.toString());
35
42
  const element = elementRegistry.addElementBorrowlend({
36
- name: `Leverage`,
43
+ name: `Leverage ${vaultFromApi ? vaultFromApi.leverageName.replace('-', '/') : ''}`,
37
44
  label: 'Leverage',
38
45
  ref: acc.pubkey,
39
46
  sourceRefs: [
@@ -48,12 +55,14 @@ const executor = (owner, cache) => __awaiter(void 0, void 0, void 0, function* (
48
55
  if (position.unit.toString() === '0') {
49
56
  continue;
50
57
  }
51
- const unit = position.unit.toNumber() / 1e8;
52
- const borrowingUnit = position.borrowing_unit.toNumber() / 1e8;
53
- const borrowingIndex = vault.borrowingIndex / 1e12;
54
- const borrowingAmount = borrowingUnit * borrowingIndex;
55
- const index = vault.index / 1e12;
56
- const amount = unit * index;
58
+ const amount = position.token_collateral_amount
59
+ .shiftedBy(-vault.tokenCollateralTokenDecimal)
60
+ .toNumber();
61
+ element.addSuppliedAsset({
62
+ address: vault.tokenCollateralTokenMint.toString(),
63
+ amount,
64
+ alreadyShifted: true,
65
+ });
57
66
  const apy = Number(vault.apy.ema7d / 1e5);
58
67
  element.addSuppliedYield([
59
68
  {
@@ -61,23 +70,21 @@ const executor = (owner, cache) => __awaiter(void 0, void 0, void 0, function* (
61
70
  apr: (0, portfolio_core_1.apyToApr)(apy),
62
71
  },
63
72
  ]);
64
- element.addSuppliedAsset({
65
- address: vault.nativeCollateralTokenMint.toString(),
66
- amount,
73
+ const borrowingUnit = position.borrowing_unit.toNumber() / 1e8;
74
+ const borrowingIndex = vault.borrowingIndex / 1e12;
75
+ const borrowingAmount = borrowingUnit * borrowingIndex;
76
+ const borrowingApy = Number(vault.borrowingApy.ema7d / 1e5);
77
+ element.addBorrowedAsset({
78
+ address: vault.tokenCollateralTokenMint.toString(),
79
+ amount: borrowingAmount,
67
80
  alreadyShifted: true,
68
81
  });
69
- const borrowingApy = Number(vault.borrowingApy.ema7d / 1e5);
70
82
  element.addBorrowedYield([
71
83
  {
72
84
  apy: borrowingApy,
73
85
  apr: (0, portfolio_core_1.apyToApr)(borrowingApy),
74
86
  },
75
87
  ]);
76
- element.addBorrowedAsset({
77
- address: vault.tokenCollateralTokenMint.toString(),
78
- amount: borrowingAmount,
79
- alreadyShifted: true,
80
- });
81
88
  }
82
89
  });
83
90
  return elementRegistry.getElements(cache);
@@ -1 +1 @@
1
- {"version":3,"file":"leverageFetcher.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/pluto/leverageFetcher.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"leverageFetcher.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/pluto/leverageFetcher.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Job } from '../../Job';
2
+ declare const job: Job;
3
+ export default job;
@@ -0,0 +1,33 @@
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 axios_1 = __importDefault(require("axios"));
17
+ const constants_1 = require("./constants");
18
+ const executor = (cache) => __awaiter(void 0, void 0, void 0, function* () {
19
+ const vaults = yield axios_1.default
20
+ .get(constants_1.leverageVaultsApiUrl)
21
+ .then((response) => response.data);
22
+ yield cache.setItem(constants_1.leveragesVaultApiKey, Object.values(vaults.production), {
23
+ prefix: constants_1.platformId,
24
+ networkId: portfolio_core_1.NetworkId.solana,
25
+ });
26
+ });
27
+ const job = {
28
+ id: `${constants_1.platformId}-leverage-vaults-api`,
29
+ executor,
30
+ label: 'normal',
31
+ };
32
+ exports.default = job;
33
+ //# sourceMappingURL=leverageVaultsApiJob.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"leverageVaultsApiJob.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/pluto/leverageVaultsApiJob.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,+DAAuD;AACvD,kDAA0B;AAG1B,2CAIqB;AAGrB,MAAM,QAAQ,GAAgB,CAAO,KAAY,EAAE,EAAE;IACnD,MAAM,MAAM,GAAG,MAAM,eAAK;SACvB,GAAG,CACF,gCAAoB,CACrB;SACA,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAErC,MAAM,KAAK,CAAC,OAAO,CAAC,gCAAoB,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE;QAC1E,MAAM,EAAE,sBAAU;QAClB,SAAS,EAAE,0BAAS,CAAC,MAAM;KAC5B,CAAC,CAAC;AACL,CAAC,CAAA,CAAC;AAEF,MAAM,GAAG,GAAQ;IACf,EAAE,EAAE,GAAG,sBAAU,sBAAsB;IACvC,QAAQ;IACR,KAAK,EAAE,QAAQ;CAChB,CAAC;AACF,kBAAe,GAAG,CAAC"}
@@ -0,0 +1,32 @@
1
+ export type LeverageVaultAddress = {
2
+ earnName: string;
3
+ leverageName: string;
4
+ programId: string;
5
+ protocol: string;
6
+ indexer: string;
7
+ keeper: string;
8
+ feeVault: string;
9
+ tokenProgramA: string;
10
+ tokenMintA: string;
11
+ tokenDecimalA: number;
12
+ tokenCollateralPriceOracle: string;
13
+ tokenCollateralPriceFeed: string;
14
+ tokenProgramB: string;
15
+ tokenMintB: string;
16
+ tokenDecimalB: number;
17
+ nativeCollateralPriceOracle: string;
18
+ nativeCollateralPriceFeed: string;
19
+ earnConfig: string;
20
+ earnStats: string;
21
+ earnVaultAuthority: string;
22
+ earnVault: string;
23
+ earnVaultLiquidity: string;
24
+ leverageConfig: string;
25
+ leverageStats: string;
26
+ leverageVaultAuthority: string;
27
+ leverageVault: string;
28
+ leverageVaultTokenCollateralLiquidity: string;
29
+ leverageVaultNativeCollateralLiquidity: string;
30
+ lookupTable: string;
31
+ lookupTableGeneric: string;
32
+ };
@@ -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/pluto/types.ts"],"names":[],"mappings":""}
@@ -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;
@@ -0,0 +1,7 @@
1
+ /// <reference types="@drift-labs/sdk/node_modules/@solana/web3.js" />
2
+ /// <reference types="jito-ts/node_modules/@solana/web3.js" />
3
+ import { Platform } from '@sonarwatch/portfolio-core';
4
+ import { PublicKey } from '@solana/web3.js';
5
+ export declare const platformId = "triad";
6
+ export declare const platform: Platform;
7
+ export declare const programId: PublicKey;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.programId = exports.platform = exports.platformId = void 0;
4
+ const web3_js_1 = require("@solana/web3.js");
5
+ exports.platformId = 'triad';
6
+ exports.platform = {
7
+ id: exports.platformId,
8
+ name: 'Triad',
9
+ image: 'https://sonar.watch/img/platforms/triad.webp',
10
+ website: 'https://app.triadfi.co/',
11
+ twitter: 'https://x.com/triadfi',
12
+ };
13
+ exports.programId = new web3_js_1.PublicKey('TRDwq3BN4mP3m9KsuNUWSN6QDff93VKGSwE95Jbr9Ss');
14
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/triad/constants.ts"],"names":[],"mappings":";;;AACA,6CAA4C;AAE/B,QAAA,UAAU,GAAG,OAAO,CAAC;AACrB,QAAA,QAAQ,GAAa;IAChC,EAAE,EAAE,kBAAU;IACd,IAAI,EAAE,OAAO;IACb,KAAK,EAAE,8CAA8C;IACrD,OAAO,EAAE,yBAAyB;IAClC,OAAO,EAAE,uBAAuB;CACjC,CAAC;AAEW,QAAA,SAAS,GAAG,IAAI,mBAAS,CACpC,6CAA6C,CAC9C,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 stakingFetcher_1 = __importDefault(require("./stakingFetcher"));
9
+ exports.platforms = [constants_1.platform];
10
+ exports.jobs = [];
11
+ exports.fetchers = [stakingFetcher_1.default];
12
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/triad/index.ts"],"names":[],"mappings":";;;;;;AAGA,2CAAuC;AACvC,sEAA8C;AAEjC,QAAA,SAAS,GAAe,CAAC,oBAAQ,CAAC,CAAC;AACnC,QAAA,IAAI,GAAU,EAAE,CAAC;AACjB,QAAA,QAAQ,GAAc,CAAC,wBAAc,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Fetcher } from '../../Fetcher';
2
+ declare const fetcher: Fetcher;
3
+ export default fetcher;
@@ -0,0 +1,70 @@
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 clients_1 = require("../../utils/clients");
15
+ const solana_1 = require("../../utils/solana");
16
+ const structs_1 = require("./structs");
17
+ const ElementRegistry_1 = require("../../utils/elementbuilder/ElementRegistry");
18
+ const executor = (owner, cache) => __awaiter(void 0, void 0, void 0, function* () {
19
+ const connection = (0, clients_1.getClientSolana)();
20
+ const accounts = yield (0, solana_1.getParsedProgramAccounts)(connection, structs_1.stakeV2Struct, constants_1.programId, [
21
+ {
22
+ memcmp: {
23
+ bytes: 'bgtkjcD34Si',
24
+ offset: 0,
25
+ },
26
+ },
27
+ {
28
+ memcmp: {
29
+ bytes: owner,
30
+ offset: 9,
31
+ },
32
+ },
33
+ {
34
+ dataSize: 184,
35
+ },
36
+ ]);
37
+ if (accounts.length === 0)
38
+ return [];
39
+ const elementRegistry = new ElementRegistry_1.ElementRegistry(portfolio_core_1.NetworkId.solana, constants_1.platformId);
40
+ accounts.forEach((acc) => {
41
+ const element = elementRegistry.addElementMultiple({
42
+ label: 'Staked',
43
+ ref: acc.pubkey,
44
+ sourceRefs: [
45
+ {
46
+ name: 'Vault',
47
+ address: acc.stake_vault.toString(),
48
+ },
49
+ ],
50
+ link: 'https://app.triadfi.co/staking',
51
+ });
52
+ const attributes = {};
53
+ if (acc.withdraw_ts.isGreaterThan(0)) {
54
+ attributes.lockedUntil = new Date(acc.withdraw_ts.times(1000).toNumber()).getTime();
55
+ }
56
+ element.addAsset({
57
+ address: acc.mint,
58
+ amount: acc.available.toNumber(),
59
+ attributes,
60
+ });
61
+ });
62
+ return elementRegistry.getElements(cache);
63
+ });
64
+ const fetcher = {
65
+ id: `${constants_1.platformId}-staking`,
66
+ networkId: portfolio_core_1.NetworkId.solana,
67
+ executor,
68
+ };
69
+ exports.default = fetcher;
70
+ //# sourceMappingURL=stakingFetcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stakingFetcher.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/triad/stakingFetcher.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,+DAGoC;AAEpC,2CAAoD;AAEpD,iDAAsD;AACtD,+CAA8D;AAC9D,uCAA0C;AAC1C,gFAA6E;AAE7E,MAAM,QAAQ,GAAoB,CAAO,KAAa,EAAE,KAAY,EAAE,EAAE;IACtE,MAAM,UAAU,GAAG,IAAA,yBAAe,GAAE,CAAC;IAErC,MAAM,QAAQ,GAAG,MAAM,IAAA,iCAAwB,EAC7C,UAAU,EACV,uBAAa,EACb,qBAAS,EACT;QACE;YACE,MAAM,EAAE;gBACN,KAAK,EAAE,aAAa;gBACpB,MAAM,EAAE,CAAC;aACV;SACF;QACD;YACE,MAAM,EAAE;gBACN,KAAK,EAAE,KAAK;gBACZ,MAAM,EAAE,CAAC;aACV;SACF;QACD;YACE,QAAQ,EAAE,GAAG;SACd;KACF,CACF,CAAC;IACF,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IAErC,MAAM,eAAe,GAAG,IAAI,iCAAe,CAAC,0BAAS,CAAC,MAAM,EAAE,sBAAU,CAAC,CAAC;IAE1E,QAAQ,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;QACvB,MAAM,OAAO,GAAG,eAAe,CAAC,kBAAkB,CAAC;YACjD,KAAK,EAAE,QAAQ;YACf,GAAG,EAAE,GAAG,CAAC,MAAM;YACf,UAAU,EAAE;gBACV;oBACE,IAAI,EAAE,OAAO;oBACb,OAAO,EAAE,GAAG,CAAC,WAAW,CAAC,QAAQ,EAAE;iBACpC;aACF;YACD,IAAI,EAAE,gCAAgC;SACvC,CAAC,CAAC;QAEH,MAAM,UAAU,GAA6B,EAAE,CAAC;QAChD,IAAI,GAAG,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC;YACrC,UAAU,CAAC,WAAW,GAAG,IAAI,IAAI,CAC/B,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,CACvC,CAAC,OAAO,EAAE,CAAC;QACd,CAAC;QAED,OAAO,CAAC,QAAQ,CAAC;YACf,OAAO,EAAE,GAAG,CAAC,IAAI;YACjB,MAAM,EAAE,GAAG,CAAC,SAAS,CAAC,QAAQ,EAAE;YAChC,UAAU;SACX,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;AAC5C,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"}
@@ -0,0 +1,23 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="@drift-labs/sdk/node_modules/@solana/web3.js" />
3
+ /// <reference types="jito-ts/node_modules/@solana/web3.js" />
4
+ import { FixableBeetStruct } from '@metaplex-foundation/beet';
5
+ import { PublicKey } from '@solana/web3.js';
6
+ import BigNumber from 'bignumber.js';
7
+ export type StakeV2 = {
8
+ buffer: Buffer;
9
+ bump: number;
10
+ authority: PublicKey;
11
+ init_ts: BigNumber;
12
+ withdraw_ts: BigNumber;
13
+ claimed_ts: BigNumber;
14
+ name: number[];
15
+ mint: PublicKey;
16
+ boost: boolean;
17
+ stake_vault: PublicKey;
18
+ claimCount: BigNumber;
19
+ claimed: BigNumber;
20
+ available: BigNumber;
21
+ amount: BigNumber;
22
+ };
23
+ export declare const stakeV2Struct: FixableBeetStruct<StakeV2, Partial<StakeV2>>;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.stakeV2Struct = 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.stakeV2Struct = new beet_1.FixableBeetStruct([
8
+ ['buffer', (0, solana_1.blob)(8)],
9
+ ['bump', beet_1.u8],
10
+ ['authority', beet_solana_1.publicKey],
11
+ ['init_ts', solana_1.i64],
12
+ ['withdraw_ts', solana_1.i64],
13
+ ['claimed_ts', solana_1.i64],
14
+ ['name', (0, beet_1.uniformFixedSizeArray)(beet_1.u8, 12)],
15
+ ['mint', beet_solana_1.publicKey],
16
+ ['boost', beet_1.bool],
17
+ ['stake_vault', beet_solana_1.publicKey],
18
+ ['claimCount', solana_1.u64],
19
+ ['claimed', solana_1.u64],
20
+ ['available', solana_1.u64],
21
+ ['amount', solana_1.u64],
22
+ ], (args) => args);
23
+ //# sourceMappingURL=structs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"structs.js","sourceRoot":"","sources":["../../../../../../packages/plugins/src/plugins/triad/structs.ts"],"names":[],"mappings":";;;AAAA,oDAKmC;AACnC,kEAA6D;AAG7D,+CAAoD;AAmBvC,QAAA,aAAa,GAAG,IAAI,wBAAiB,CAChD;IACE,CAAC,QAAQ,EAAE,IAAA,aAAI,EAAC,CAAC,CAAC,CAAC;IACnB,CAAC,MAAM,EAAE,SAAE,CAAC;IACZ,CAAC,WAAW,EAAE,uBAAS,CAAC;IACxB,CAAC,SAAS,EAAE,YAAG,CAAC;IAChB,CAAC,aAAa,EAAE,YAAG,CAAC;IACpB,CAAC,YAAY,EAAE,YAAG,CAAC;IACnB,CAAC,MAAM,EAAE,IAAA,4BAAqB,EAAC,SAAE,EAAE,EAAE,CAAC,CAAC;IACvC,CAAC,MAAM,EAAE,uBAAS,CAAC;IACnB,CAAC,OAAO,EAAE,WAAI,CAAC;IACf,CAAC,aAAa,EAAE,uBAAS,CAAC;IAC1B,CAAC,YAAY,EAAE,YAAG,CAAC;IACnB,CAAC,SAAS,EAAE,YAAG,CAAC;IAChB,CAAC,WAAW,EAAE,YAAG,CAAC;IAClB,CAAC,QAAQ,EAAE,YAAG,CAAC;CAChB,EACD,CAAC,IAAI,EAAE,EAAE,CAAC,IAAe,CAC1B,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;
@@ -40,20 +40,20 @@ const clients_1 = require("../../utils/clients");
40
40
  const getMultipleAccountsInfoSafe_1 = require("../../utils/solana/getMultipleAccountsInfoSafe");
41
41
  const helpers_1 = require("./helpers");
42
42
  const AirdropFetcher_1 = require("../../AirdropFetcher");
43
- const query = (0, graphql_request_1.gql) `
44
- query GetAirdropFinalFrontend($authority: String!) {
45
- getAirdropFinalFrontend(authority: $authority) {
46
- authority
47
- community_allocation
48
- eligibility
49
- main_allocation
50
- og_allocation
51
- s1_allocation
52
- s2_allocation
53
- total_allocation
54
- __typename
55
- }
56
- }
43
+ const query = (0, graphql_request_1.gql) `
44
+ query GetAirdropFinalFrontend($authority: String!) {
45
+ getAirdropFinalFrontend(authority: $authority) {
46
+ authority
47
+ community_allocation
48
+ eligibility
49
+ main_allocation
50
+ og_allocation
51
+ s1_allocation
52
+ s2_allocation
53
+ total_allocation
54
+ __typename
55
+ }
56
+ }
57
57
  `;
58
58
  const networkId = portfolio_core_1.NetworkId.solana;
59
59
  const executor = (owner) => __awaiter(void 0, void 0, void 0, function* () {
@@ -1,16 +1,16 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.poolQueryMsg = exports.minterQueryMsg = exports.tokenInfoQueryMsg = exports.infoQueryMsg = void 0;
4
- exports.infoQueryMsg = JSON.parse(`{
5
- "info": {}
4
+ exports.infoQueryMsg = JSON.parse(`{
5
+ "info": {}
6
6
  }`);
7
- exports.tokenInfoQueryMsg = JSON.parse(`{
8
- "token_info": {}
7
+ exports.tokenInfoQueryMsg = JSON.parse(`{
8
+ "token_info": {}
9
9
  }`);
10
- exports.minterQueryMsg = JSON.parse(`{
11
- "minter": {}
10
+ exports.minterQueryMsg = JSON.parse(`{
11
+ "minter": {}
12
12
  }`);
13
- exports.poolQueryMsg = JSON.parse(`{
14
- "pool": {}
13
+ exports.poolQueryMsg = JSON.parse(`{
14
+ "pool": {}
15
15
  }`);
16
16
  //# sourceMappingURL=constants.js.map
@@ -1,10 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  function getQueryBalanceByOwner(owner) {
4
- return JSON.parse(`{
5
- "balance": {
6
- "address": "${owner}"
7
- }
4
+ return JSON.parse(`{
5
+ "balance": {
6
+ "address": "${owner}"
7
+ }
8
8
  }`);
9
9
  }
10
10
  exports.default = getQueryBalanceByOwner;