@defisaver/positions-sdk 2.1.48 → 2.1.49-aave-v4-dev-1-dev

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 (66) hide show
  1. package/cjs/aaveV4/index.d.ts +7 -0
  2. package/cjs/aaveV4/index.js +167 -0
  3. package/cjs/config/contracts.d.ts +1277 -0
  4. package/cjs/config/contracts.js +9 -0
  5. package/cjs/contracts.d.ts +23120 -0
  6. package/cjs/contracts.js +2 -1
  7. package/cjs/helpers/aaveV4Helpers/index.d.ts +9 -0
  8. package/cjs/helpers/aaveV4Helpers/index.js +57 -0
  9. package/cjs/helpers/index.d.ts +1 -0
  10. package/cjs/helpers/index.js +2 -1
  11. package/cjs/index.d.ts +2 -1
  12. package/cjs/index.js +3 -1
  13. package/cjs/markets/aave/marketAssets.js +1 -1
  14. package/cjs/markets/aaveV4/index.d.ts +7 -0
  15. package/cjs/markets/aaveV4/index.js +22 -0
  16. package/cjs/markets/index.d.ts +1 -0
  17. package/cjs/markets/index.js +3 -1
  18. package/cjs/moneymarket/moneymarketCommonService.js +1 -1
  19. package/cjs/portfolio/index.js +20 -0
  20. package/cjs/staking/staking.js +5 -1
  21. package/cjs/types/aaveV4.d.ts +129 -0
  22. package/cjs/types/aaveV4.js +11 -0
  23. package/cjs/types/index.d.ts +1 -0
  24. package/cjs/types/index.js +1 -0
  25. package/cjs/types/portfolio.d.ts +4 -0
  26. package/esm/aaveV4/index.d.ts +7 -0
  27. package/esm/aaveV4/index.js +158 -0
  28. package/esm/config/contracts.d.ts +1277 -0
  29. package/esm/config/contracts.js +8 -0
  30. package/esm/contracts.d.ts +23120 -0
  31. package/esm/contracts.js +1 -0
  32. package/esm/helpers/aaveV4Helpers/index.d.ts +9 -0
  33. package/esm/helpers/aaveV4Helpers/index.js +49 -0
  34. package/esm/helpers/index.d.ts +1 -0
  35. package/esm/helpers/index.js +1 -0
  36. package/esm/index.d.ts +2 -1
  37. package/esm/index.js +2 -1
  38. package/esm/markets/aave/marketAssets.js +1 -1
  39. package/esm/markets/aaveV4/index.d.ts +7 -0
  40. package/esm/markets/aaveV4/index.js +16 -0
  41. package/esm/markets/index.d.ts +1 -0
  42. package/esm/markets/index.js +1 -0
  43. package/esm/moneymarket/moneymarketCommonService.js +1 -1
  44. package/esm/portfolio/index.js +21 -1
  45. package/esm/staking/staking.js +5 -1
  46. package/esm/types/aaveV4.d.ts +129 -0
  47. package/esm/types/aaveV4.js +8 -0
  48. package/esm/types/index.d.ts +1 -0
  49. package/esm/types/index.js +1 -0
  50. package/esm/types/portfolio.d.ts +4 -0
  51. package/package.json +2 -2
  52. package/src/aaveV4/index.ts +169 -0
  53. package/src/config/contracts.ts +8 -0
  54. package/src/contracts.ts +3 -1
  55. package/src/helpers/aaveV4Helpers/index.ts +69 -0
  56. package/src/helpers/index.ts +1 -0
  57. package/src/index.ts +2 -0
  58. package/src/markets/aave/marketAssets.ts +1 -1
  59. package/src/markets/aaveV4/index.ts +19 -0
  60. package/src/markets/index.ts +1 -0
  61. package/src/moneymarket/moneymarketCommonService.ts +1 -1
  62. package/src/portfolio/index.ts +20 -0
  63. package/src/staking/staking.ts +3 -1
  64. package/src/types/aaveV4.ts +142 -0
  65. package/src/types/index.ts +2 -1
  66. package/src/types/portfolio.ts +4 -0
package/cjs/contracts.js CHANGED
@@ -34,7 +34,7 @@ var __importStar = (this && this.__importStar) || (function () {
34
34
  })();
35
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
36
  exports.AaveRewardsControllerViem = exports.SparkRewardsControllerViem = exports.UUPSViem = exports.LiquityStabilityPoolViem = exports.LiquityLQTYStakingViem = exports.AaveUmbrellaViewViem = exports.AaveIncentivesControllerViem = exports.FluidViewContractViem = exports.LiquityV2LegacyViewContractViem = exports.LiquityV2ViewContractViem = exports.LiquityActivePoolContractViem = exports.LiquityPriceFeedContractViem = exports.LiquityTroveManagerContractViem = exports.LiquityCollSurplusPoolContractViem = exports.LiquityViewContractViem = exports.BTCPriceFeedContractViem = exports.WeETHPriceFeedContractViem = exports.ComptrollerContractViem = exports.CompoundLoanInfoContractViem = exports.McdJugContractViem = exports.McdDogContractViem = exports.McdSpotterContractViem = exports.McdVatContractViem = exports.McdViewContractViem = exports.McdGetCdpsContractViem = exports.LlamaLendViewContractViem = exports.CrvUSDFactoryContractViem = exports.CrvUSDViewContractViem = exports.EulerV2ViewContractViem = exports.SparkIncentiveDataProviderContractViem = exports.SparkViewContractViem = exports.CompV3ViewContractViem = exports.WstETHPriceFeedContractViem = exports.USDCPriceFeedContractViem = exports.ETHPriceFeedContractViem = exports.COMPPriceFeedContractViem = exports.DFSFeedRegistryContractViem = exports.FeedRegistryContractViem = exports.AaveIncentiveDataProviderV3ContractViem = exports.AaveV3ViewContractViem = exports.AaveLoanInfoV2ContractViem = exports.MorphoBlueViewContractViem = exports.getYearnV3VaultContractViem = exports.getErc20ContractViem = exports.getSparkSavingsVaultContractViem = exports.getYearnVaultContractViem = exports.getMorphoVaultContractViem = exports.createViemContractFromConfigFunc = exports.getConfigContractAbi = exports.getConfigContractAddress = void 0;
37
- exports.SkySavingsContractView = exports.MakerDsrContractViem = exports.YearnViewContractViem = exports.StkAAVEViem = exports.LiquityV2sBoldVaultViem = void 0;
37
+ exports.AaveV4ViewContractViem = exports.SkySavingsContractView = exports.MakerDsrContractViem = exports.YearnViewContractViem = exports.StkAAVEViem = exports.LiquityV2sBoldVaultViem = void 0;
38
38
  const viem_1 = require("viem");
39
39
  const configRaw = __importStar(require("./config/contracts"));
40
40
  // @ts-ignore
@@ -177,3 +177,4 @@ exports.StkAAVEViem = (0, exports.createViemContractFromConfigFunc)('StkAAVE');
177
177
  exports.YearnViewContractViem = (0, exports.createViemContractFromConfigFunc)('YearnView');
178
178
  exports.MakerDsrContractViem = (0, exports.createViemContractFromConfigFunc)('MakerDsr');
179
179
  exports.SkySavingsContractView = (0, exports.createViemContractFromConfigFunc)('SkySavings');
180
+ exports.AaveV4ViewContractViem = (0, exports.createViemContractFromConfigFunc)('AaveV4View');
@@ -0,0 +1,9 @@
1
+ import { AaveV4AggregatedPositionData, AaveV4AssetsData, AaveV4ReserveAssetData, AaveV4UsedReserveAsset, AaveV4UsedReserveAssets } from '../../types';
2
+ import { NetworkNumber } from '../../types/common';
3
+ export declare const aaveV4GetCollateralFactor: (assetData: AaveV4ReserveAssetData, usedAssetData: AaveV4UsedReserveAsset, useUserCollateralFactor?: boolean) => number;
4
+ export declare const aaveV4GetAggregatedPositionData: ({ usedAssets, assetsData, network, useUserCollateralFactor, }: {
5
+ usedAssets: AaveV4UsedReserveAssets;
6
+ assetsData: AaveV4AssetsData;
7
+ network: NetworkNumber;
8
+ useUserCollateralFactor?: boolean;
9
+ }) => AaveV4AggregatedPositionData;
@@ -0,0 +1,57 @@
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.aaveV4GetAggregatedPositionData = exports.aaveV4GetCollateralFactor = void 0;
7
+ const decimal_js_1 = __importDefault(require("decimal.js"));
8
+ const moneymarket_1 = require("../../moneymarket");
9
+ const aaveV4GetCollateralFactor = (assetData, usedAssetData, useUserCollateralFactor = false) => (useUserCollateralFactor ? usedAssetData.collateralFactor : assetData.collateralFactor);
10
+ exports.aaveV4GetCollateralFactor = aaveV4GetCollateralFactor;
11
+ const aaveV4GetAggregatedPositionData = ({ usedAssets, assetsData, network, useUserCollateralFactor = false, }) => {
12
+ var _a;
13
+ const payload = {};
14
+ payload.suppliedUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied }) => isSupplied, ({ suppliedUsd }) => suppliedUsd);
15
+ payload.suppliedCollateralUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied, collateral }) => isSupplied && collateral, ({ suppliedUsd }) => suppliedUsd);
16
+ payload.borrowLimitUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied, collateral }) => isSupplied && collateral, ({ symbol, suppliedUsd, reserveId }) => new decimal_js_1.default(suppliedUsd).mul((0, exports.aaveV4GetCollateralFactor)(assetsData[`${symbol}-${reserveId}`], usedAssets[`${symbol}-${reserveId}`], useUserCollateralFactor)));
17
+ payload.liquidationLimitUsd = payload.borrowLimitUsd;
18
+ payload.borrowedUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isBorrowed }) => isBorrowed, ({ borrowedUsd }) => borrowedUsd);
19
+ payload.drawnUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isBorrowed }) => isBorrowed, ({ drawnUsd }) => drawnUsd);
20
+ payload.premiumUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isBorrowed }) => isBorrowed, ({ premiumUsd }) => premiumUsd);
21
+ const leftToBorrowUsd = new decimal_js_1.default(payload.borrowLimitUsd).sub(payload.borrowedUsd);
22
+ payload.leftToBorrowUsd = leftToBorrowUsd.lte('0') ? '0' : leftToBorrowUsd.toString();
23
+ payload.ratio = +payload.suppliedUsd ? new decimal_js_1.default(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
24
+ payload.collRatio = +payload.suppliedUsd ? new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
25
+ payload.liqRatio = new decimal_js_1.default(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).toString();
26
+ payload.liqPercent = new decimal_js_1.default(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).mul(100).toString();
27
+ const { leveragedType, leveragedAsset } = (0, moneymarket_1.isLeveragedPos)(usedAssets);
28
+ payload.leveragedType = leveragedType;
29
+ payload.leveragedAsset = leveragedAsset;
30
+ payload.liquidationPrice = '';
31
+ if (leveragedType !== '') {
32
+ const leveragedAssetData = Object.values(assetsData).find((asset) => asset.symbol === leveragedAsset);
33
+ let assetPrice = (leveragedAssetData === null || leveragedAssetData === void 0 ? void 0 : leveragedAssetData.price) || '0';
34
+ if (leveragedType === 'lsd-leverage') {
35
+ // Treat ETH like a stablecoin in a long stETH position
36
+ const ethPrice = ((_a = Object.values(assetsData).find((asset) => asset.symbol === 'ETH')) === null || _a === void 0 ? void 0 : _a.price) || '0';
37
+ payload.leveragedLsdAssetRatio = new decimal_js_1.default((leveragedAssetData === null || leveragedAssetData === void 0 ? void 0 : leveragedAssetData.price) || '0').div(ethPrice).toDP(18).toString();
38
+ assetPrice = new decimal_js_1.default(assetPrice).div(ethPrice).toString();
39
+ }
40
+ payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
41
+ }
42
+ payload.minCollRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowLimitUsd).mul(100).toString();
43
+ payload.collLiquidationRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.liquidationLimitUsd).mul(100).toString();
44
+ // payload.healthRatio = new Dec(payload.liquidationLimitUsd).div(payload.borrowedUsd).toDP(4).toString();
45
+ payload.minHealthRatio = new decimal_js_1.default(payload.liquidationLimitUsd).div(payload.borrowLimitUsd).toDP(4).toString();
46
+ // TODO: Re-implement netApy calculation
47
+ // const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy({
48
+ // usedAssets,
49
+ // assetsData,
50
+ // optionalData: { healthRatio: payload.healthRatio },
51
+ // });
52
+ payload.netApy = '0';
53
+ payload.incentiveUsd = '0';
54
+ payload.totalInterestUsd = '0';
55
+ return payload;
56
+ };
57
+ exports.aaveV4GetAggregatedPositionData = aaveV4GetAggregatedPositionData;
@@ -8,3 +8,4 @@ export * as llamaLendHelpers from './llamaLendHelpers';
8
8
  export * as liquityV2Helpers from './liquityV2Helpers';
9
9
  export * as eulerV2Helpers from './eulerHelpers';
10
10
  export * as fluidHelpers from './fluidHelpers';
11
+ export * as aaveV4Helpers from './aaveV4Helpers';
@@ -33,7 +33,7 @@ var __importStar = (this && this.__importStar) || (function () {
33
33
  };
34
34
  })();
35
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.fluidHelpers = exports.eulerV2Helpers = exports.liquityV2Helpers = exports.llamaLendHelpers = exports.morphoBlueHelpers = exports.makerHelpers = exports.curveUsdHelpers = exports.sparkHelpers = exports.compoundHelpers = exports.aaveHelpers = void 0;
36
+ exports.aaveV4Helpers = exports.fluidHelpers = exports.eulerV2Helpers = exports.liquityV2Helpers = exports.llamaLendHelpers = exports.morphoBlueHelpers = exports.makerHelpers = exports.curveUsdHelpers = exports.sparkHelpers = exports.compoundHelpers = exports.aaveHelpers = void 0;
37
37
  exports.aaveHelpers = __importStar(require("./aaveHelpers"));
38
38
  exports.compoundHelpers = __importStar(require("./compoundHelpers"));
39
39
  exports.sparkHelpers = __importStar(require("./sparkHelpers"));
@@ -44,3 +44,4 @@ exports.llamaLendHelpers = __importStar(require("./llamaLendHelpers"));
44
44
  exports.liquityV2Helpers = __importStar(require("./liquityV2Helpers"));
45
45
  exports.eulerV2Helpers = __importStar(require("./eulerHelpers"));
46
46
  exports.fluidHelpers = __importStar(require("./fluidHelpers"));
47
+ exports.aaveV4Helpers = __importStar(require("./aaveV4Helpers"));
package/cjs/index.d.ts CHANGED
@@ -1,5 +1,6 @@
1
1
  import './setup';
2
2
  import * as fluid from './fluid';
3
+ import * as aaveV4 from './aaveV4';
3
4
  import * as aaveV3 from './aaveV3';
4
5
  import * as aaveV2 from './aaveV2';
5
6
  import * as compoundV3 from './compoundV3';
@@ -21,4 +22,4 @@ import * as portfolio from './portfolio';
21
22
  import * as claiming from './claiming';
22
23
  import * as savings from './savings';
23
24
  export * from './types';
24
- export { aaveV2, aaveV3, compoundV2, compoundV3, spark, curveUsd, liquity, liquityV2, maker, exchange, staking, moneymarket, markets, helpers, morphoBlue, llamaLend, eulerV2, fluid, portfolio, claiming, savings, };
25
+ export { aaveV2, aaveV3, aaveV4, compoundV2, compoundV3, spark, curveUsd, liquity, liquityV2, maker, exchange, staking, moneymarket, markets, helpers, morphoBlue, llamaLend, eulerV2, fluid, portfolio, claiming, savings, };
package/cjs/index.js CHANGED
@@ -36,10 +36,12 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
36
36
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
37
37
  };
38
38
  Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.savings = exports.claiming = exports.portfolio = exports.fluid = exports.eulerV2 = exports.llamaLend = exports.morphoBlue = exports.helpers = exports.markets = exports.moneymarket = exports.staking = exports.exchange = exports.maker = exports.liquityV2 = exports.liquity = exports.curveUsd = exports.spark = exports.compoundV3 = exports.compoundV2 = exports.aaveV3 = exports.aaveV2 = void 0;
39
+ exports.savings = exports.claiming = exports.portfolio = exports.fluid = exports.eulerV2 = exports.llamaLend = exports.morphoBlue = exports.helpers = exports.markets = exports.moneymarket = exports.staking = exports.exchange = exports.maker = exports.liquityV2 = exports.liquity = exports.curveUsd = exports.spark = exports.compoundV3 = exports.compoundV2 = exports.aaveV4 = exports.aaveV3 = exports.aaveV2 = void 0;
40
40
  require("./setup");
41
41
  const fluid = __importStar(require("./fluid"));
42
42
  exports.fluid = fluid;
43
+ const aaveV4 = __importStar(require("./aaveV4"));
44
+ exports.aaveV4 = aaveV4;
43
45
  const aaveV3 = __importStar(require("./aaveV3"));
44
46
  exports.aaveV3 = aaveV3;
45
47
  const aaveV2 = __importStar(require("./aaveV2"));
@@ -18,7 +18,7 @@ exports.aaveV3AssetsDefaultMarketOpt = [
18
18
  exports.aaveV3AssetsDefaultMarketArb = ['DAI', 'LINK', 'USDC.e', 'WBTC', 'ETH', 'USDT', 'AAVE', 'EURS', 'wstETH', 'MAI', 'rETH', 'LUSD', 'USDC', 'FRAX', 'ARB', 'weETH', 'GHO', 'ezETH', 'rsETH', 'tBTC'];
19
19
  exports.aaveV3AssetsDefaultMarketBase = ['ETH', 'cbETH', 'USDbC', 'wstETH', 'USDC', 'weETH', 'cbBTC', 'ezETH', 'GHO', 'wrsETH', 'LBTC', 'EURC', 'AAVE', 'tBTC'];
20
20
  exports.aaveV3AssetsDefaultMarketLinea = ['ETH', 'USDC', 'weETH', 'ezETH', 'USDT', 'wstETH', 'wrsETH', 'WBTC', 'mUSD'];
21
- exports.aaveV3AssetsDefaultMarketPlasma = ['ETH', 'USDT', 'sUSDe', 'USDe', 'weETH', 'XAUt', 'PT USDe Jan', 'PT sUSDe Jan', 'wrsETH', 'wstETH', 'syrupUSDT', 'XPL'];
21
+ exports.aaveV3AssetsDefaultMarketPlasma = ['ETH', 'USDT', 'sUSDe', 'USDe', 'weETH', 'XAUt', 'PT USDe Jan', 'PT sUSDe Jan', 'wrsETH', 'wstETH', 'syrupUSDT', 'XPL', 'PT USDe Apr', 'PT sUSDe Apr'];
22
22
  // @dev Keep assets in array, do not assign directly, so we can parse it and edit it programmatically with `scripts/updateMarkets`
23
23
  exports.aaveV3AssetsDefaultMarket = {
24
24
  [common_1.NetworkNumber.Eth]: exports.aaveV3AssetsDefaultMarketEth,
@@ -0,0 +1,7 @@
1
+ import { AaveV4SpokeInfo, AaveV4SpokesType } from '../../types';
2
+ import { NetworkNumber } from '../../types/common';
3
+ export declare const AAVE_V4_CORE_SPOKE: (networkId: NetworkNumber) => AaveV4SpokeInfo;
4
+ export declare const AaveV4Spokes: (networkId: NetworkNumber) => {
5
+ readonly aave_v4_core_spoke: AaveV4SpokeInfo;
6
+ };
7
+ export declare const getAaveV4SpokeTypeInfo: (type: AaveV4SpokesType, network?: NetworkNumber) => AaveV4SpokeInfo;
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getAaveV4SpokeTypeInfo = exports.AaveV4Spokes = exports.AAVE_V4_CORE_SPOKE = void 0;
4
+ const types_1 = require("../../types");
5
+ const common_1 = require("../../types/common");
6
+ const AAVE_V4_CORE_SPOKE = (networkId) => ({
7
+ chainIds: [common_1.NetworkNumber.Eth],
8
+ label: 'Core Spoke',
9
+ value: types_1.AaveV4SpokesType.AaveV4CoreSpoke,
10
+ url: 'core',
11
+ address: '0xBa97c5E52cd5BC3D7950Ae70779F8FfE92d40CdC',
12
+ hubs: [
13
+ '0xaD905aD5EA5B98cD50AE40Cfe368344686a21366',
14
+ ],
15
+ });
16
+ exports.AAVE_V4_CORE_SPOKE = AAVE_V4_CORE_SPOKE;
17
+ const AaveV4Spokes = (networkId) => ({
18
+ [types_1.AaveV4SpokesType.AaveV4CoreSpoke]: (0, exports.AAVE_V4_CORE_SPOKE)(networkId),
19
+ });
20
+ exports.AaveV4Spokes = AaveV4Spokes;
21
+ const getAaveV4SpokeTypeInfo = (type, network) => (Object.assign({}, (0, exports.AaveV4Spokes)(network !== null && network !== void 0 ? network : common_1.NetworkNumber.Eth))[type]);
22
+ exports.getAaveV4SpokeTypeInfo = getAaveV4SpokeTypeInfo;
@@ -7,3 +7,4 @@ export { LlamaLendMarkets } from './llamaLend';
7
7
  export { LiquityV2Markets, findLiquityV2MarketByAddress } from './liquityV2';
8
8
  export { EulerV2Markets } from './euler';
9
9
  export { FluidMarkets, getFluidVersionsDataForNetwork, getFluidMarketInfoById, getFTokenAddress, getFluidMarketInfoByAddress, } from './fluid';
10
+ export { AaveV4Spokes } from './aaveV4';
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getFluidMarketInfoByAddress = exports.getFTokenAddress = exports.getFluidMarketInfoById = exports.getFluidVersionsDataForNetwork = exports.FluidMarkets = exports.EulerV2Markets = exports.findLiquityV2MarketByAddress = exports.LiquityV2Markets = exports.LlamaLendMarkets = exports.findMorphoBlueMarket = exports.MorphoBlueMarkets = exports.CrvUsdMarkets = exports.SparkMarkets = exports.v3USDTCollAssets = exports.v3USDCeCollAssets = exports.v3USDCCollAssets = exports.v3USDbCCollAssets = exports.v3ETHCollAssets = exports.compoundV2CollateralAssets = exports.CompoundMarkets = exports.getAaveV3MarketByMarketAddress = exports.aaveV3AssetsDefaultMarket = exports.aaveV2AssetsDefaultMarket = exports.aaveV1AssetsDefaultMarket = exports.AaveMarkets = void 0;
3
+ exports.AaveV4Spokes = exports.getFluidMarketInfoByAddress = exports.getFTokenAddress = exports.getFluidMarketInfoById = exports.getFluidVersionsDataForNetwork = exports.FluidMarkets = exports.EulerV2Markets = exports.findLiquityV2MarketByAddress = exports.LiquityV2Markets = exports.LlamaLendMarkets = exports.findMorphoBlueMarket = exports.MorphoBlueMarkets = exports.CrvUsdMarkets = exports.SparkMarkets = exports.v3USDTCollAssets = exports.v3USDCeCollAssets = exports.v3USDCCollAssets = exports.v3USDbCCollAssets = exports.v3ETHCollAssets = exports.compoundV2CollateralAssets = exports.CompoundMarkets = exports.getAaveV3MarketByMarketAddress = exports.aaveV3AssetsDefaultMarket = exports.aaveV2AssetsDefaultMarket = exports.aaveV1AssetsDefaultMarket = exports.AaveMarkets = void 0;
4
4
  var aave_1 = require("./aave");
5
5
  Object.defineProperty(exports, "AaveMarkets", { enumerable: true, get: function () { return aave_1.AaveMarkets; } });
6
6
  Object.defineProperty(exports, "aaveV1AssetsDefaultMarket", { enumerable: true, get: function () { return aave_1.aaveV1AssetsDefaultMarket; } });
@@ -35,3 +35,5 @@ Object.defineProperty(exports, "getFluidVersionsDataForNetwork", { enumerable: t
35
35
  Object.defineProperty(exports, "getFluidMarketInfoById", { enumerable: true, get: function () { return fluid_1.getFluidMarketInfoById; } });
36
36
  Object.defineProperty(exports, "getFTokenAddress", { enumerable: true, get: function () { return fluid_1.getFTokenAddress; } });
37
37
  Object.defineProperty(exports, "getFluidMarketInfoByAddress", { enumerable: true, get: function () { return fluid_1.getFluidMarketInfoByAddress; } });
38
+ var aaveV4_1 = require("./aaveV4");
39
+ Object.defineProperty(exports, "AaveV4Spokes", { enumerable: true, get: function () { return aaveV4_1.AaveV4Spokes; } });
@@ -31,7 +31,7 @@ exports.STABLE_ASSETS = [
31
31
  'DAI', 'USDC', 'USDT', 'TUSD', 'USDP', 'GUSD', 'BUSD', 'SUSD', 'FRAX', 'LUSD', 'USDC.e', 'GHO', 'sDAI', 'USDA',
32
32
  'USDe', 'sUSDe', 'USDS', 'sUSDS', 'USR', 'EURC', 'BOLD', 'BOLD Legacy', 'RLUSD', 'PT sUSDe July', 'PT eUSDe May',
33
33
  'USDtb', 'eUSDe', 'PT USDe July', 'PT eUSDe Aug', 'PT sUSDe Sep', 'PT USDe Sep', 'PT sUSDe Nov', 'PT USDe Nov', 'PT sUSDe Jan', 'PT USDe Jan',
34
- 'PT sUSDe Feb', 'PT USDe Feb',
34
+ 'PT sUSDe Feb', 'PT USDe Feb', 'PT USDe Apr', 'PT sUSDe Apr',
35
35
  ];
36
36
  const isLeveragedPos = (usedAssets, dustLimit = 5) => {
37
37
  let borrowUnstable = 0;
@@ -40,6 +40,7 @@ const spark_2 = require("../claiming/spark");
40
40
  const morphoBlue_2 = require("../claiming/morphoBlue");
41
41
  const king_1 = require("../claiming/king");
42
42
  const ethena_1 = require("../claiming/ethena");
43
+ const aaveV4_1 = require("../aaveV4");
43
44
  function getPortfolioData(provider, network, defaultProvider, addresses, summerFiAddresses) {
44
45
  return __awaiter(this, void 0, void 0, function* () {
45
46
  const isMainnet = network === common_1.NetworkNumber.Eth;
@@ -56,6 +57,7 @@ function getPortfolioData(provider, network, defaultProvider, addresses, summerF
56
57
  const llamaLendMarkets = [common_1.NetworkNumber.Eth, common_1.NetworkNumber.Arb].includes(network) ? Object.values((0, markets_1.LlamaLendMarkets)(network)).filter((market) => market.chainIds.includes(network)) : [];
57
58
  const liquityV2Markets = [common_1.NetworkNumber.Eth].includes(network) ? Object.values((0, markets_1.LiquityV2Markets)(network)) : [];
58
59
  const liquityV2MarketsStaking = [common_1.NetworkNumber.Eth].includes(network) ? Object.values((0, markets_1.LiquityV2Markets)(network)).filter(market => !market.isLegacy) : [];
60
+ const aaveV4Spokes = Object.values((0, markets_1.AaveV4Spokes)(network)).filter((market) => market.chainIds.includes(network));
59
61
  const client = (0, viem_1.getViemProvider)(provider, network, {
60
62
  batch: {
61
63
  multicall: {
@@ -81,6 +83,7 @@ function getPortfolioData(provider, network, defaultProvider, addresses, summerF
81
83
  const crvUsdMarketsData = {};
82
84
  const llamaLendMarketsData = {};
83
85
  const liquityV2MarketsData = {};
86
+ const aaveV4SpokesData = {};
84
87
  const markets = {
85
88
  morphoMarketsData,
86
89
  compoundV3MarketsData,
@@ -92,6 +95,7 @@ function getPortfolioData(provider, network, defaultProvider, addresses, summerF
92
95
  crvUsdMarketsData,
93
96
  llamaLendMarketsData,
94
97
  liquityV2MarketsData,
98
+ aaveV4SpokesData,
95
99
  };
96
100
  const positions = {};
97
101
  const stakingPositions = {};
@@ -100,6 +104,7 @@ function getPortfolioData(provider, network, defaultProvider, addresses, summerF
100
104
  for (const address of allAddresses) {
101
105
  positions[address.toLowerCase()] = {
102
106
  aaveV3: {},
107
+ aaveV4: {},
103
108
  morphoBlue: {},
104
109
  compoundV3: {},
105
110
  spark: {},
@@ -165,6 +170,10 @@ function getPortfolioData(provider, network, defaultProvider, addresses, summerF
165
170
  const marketData = yield (0, aaveV3_1._getAaveV3MarketData)(client, network, market);
166
171
  aaveV3MarketsData[market.value] = marketData;
167
172
  })),
173
+ ...aaveV4Spokes.map((spoke) => __awaiter(this, void 0, void 0, function* () {
174
+ const spokeData = yield (0, aaveV4_1._getAaveV4SpokeData)(client, network, spoke);
175
+ aaveV4SpokesData[spoke.value] = spokeData;
176
+ })),
168
177
  ...aaveV2Markets.map((market) => __awaiter(this, void 0, void 0, function* () {
169
178
  const marketData = yield (0, aaveV2_1._getAaveV2MarketsData)(client, network, market);
170
179
  aaveV2MarketsData[market.value] = marketData;
@@ -434,6 +443,17 @@ function getPortfolioData(provider, network, defaultProvider, addresses, summerF
434
443
  positions[address.toLowerCase()].aaveV3[market.value] = { error: `Error fetching AaveV3 account data for address ${address} on market ${market.value}`, data: null };
435
444
  }
436
445
  }))).flat(),
446
+ ...aaveV4Spokes.map((spoke) => allAddresses.map((address) => __awaiter(this, void 0, void 0, function* () {
447
+ try {
448
+ const accData = yield (0, aaveV4_1._getAaveV4AccountData)(client, network, aaveV4SpokesData[spoke.value], address);
449
+ if (new decimal_js_1.default(accData.suppliedUsd).gt(0))
450
+ positions[address.toLowerCase()].aaveV4[spoke.value] = { error: '', data: accData };
451
+ }
452
+ catch (error) {
453
+ console.error(`Error fetching AaveV4 account data for address ${address} on spoke ${spoke.value}:`, error);
454
+ positions[address.toLowerCase()].aaveV4[spoke.value] = { error: `Error fetching AaveV4 account data for address ${address} on spoke ${spoke.value}`, data: null };
455
+ }
456
+ }))).flat(),
437
457
  ...morphoMarkets.map((market) => addresses.map((address) => __awaiter(this, void 0, void 0, function* () {
438
458
  try {
439
459
  const [accDataPromise, earnDataPromise] = yield Promise.allSettled([
@@ -72,7 +72,7 @@ exports.STAKING_ASSETS = [
72
72
  'cbETH', 'wstETH', 'cbETH', 'rETH', 'sDAI', 'weETH', 'sUSDe', 'osETH',
73
73
  'ezETH', 'ETHx', 'rsETH', 'pufETH', 'wrsETH', 'wsuperOETHb', 'sUSDS', 'tETH', 'PT sUSDe Sep', 'PT USDe Sep',
74
74
  'PT sUSDe Nov', 'PT USDe Nov', 'PT USDe Jan', 'PT sUSDe Jan', 'wrsETH', 'wstETH', 'syrupUSDT', 'syrupUSDC', 'wstUSR',
75
- 'PT sUSDe Feb', 'PT USDe Feb',
75
+ 'PT sUSDe Feb', 'PT USDe Feb', 'PT USDe Apr', 'PT sUSDe Apr',
76
76
  ];
77
77
  exports.getStakingApy = (0, memoizee_1.default)((asset_1, ...args_1) => __awaiter(void 0, [asset_1, ...args_1], void 0, function* (asset, network = common_1.NetworkNumber.Eth) {
78
78
  try {
@@ -136,6 +136,10 @@ exports.getStakingApy = (0, memoizee_1.default)((asset_1, ...args_1) => __awaite
136
136
  return yield getApyFromDfsApi('PT sUSDe Feb', network);
137
137
  if (asset === 'PT USDe Feb')
138
138
  return yield getApyFromDfsApi('PT USDe Feb', network);
139
+ if (asset === 'PT sUSDe Apr')
140
+ return yield getApyFromDfsApi('PT sUSDe Apr', network);
141
+ if (asset === 'PT USDe Apr')
142
+ return yield getApyFromDfsApi('PT USDe Apr', network);
139
143
  }
140
144
  catch (e) {
141
145
  console.error(`Failed to fetch APY for ${asset}`);
@@ -0,0 +1,129 @@
1
+ import { EthAddress, IncentiveData, NetworkNumber } from './common';
2
+ export declare enum AaveV4SpokesType {
3
+ AaveV4CoreSpoke = "aave_v4_core_spoke"
4
+ }
5
+ export declare enum AaveV4HubsType {
6
+ AaveV4CoreHub = "aave_v4_core_hub"
7
+ }
8
+ export interface AaveV4SpokeInfo {
9
+ chainIds: NetworkNumber[];
10
+ label: string;
11
+ value: AaveV4SpokesType;
12
+ url: string;
13
+ address: EthAddress;
14
+ hubs: EthAddress[];
15
+ }
16
+ export interface AaveV4HubAssetOnChainData {
17
+ assetId: number;
18
+ drawnRate: bigint;
19
+ }
20
+ export interface AaveV4HubOnChainData {
21
+ assets: Record<number, AaveV4HubAssetOnChainData>;
22
+ }
23
+ export interface AaveV4ReserveAssetOnChain {
24
+ underlying: EthAddress;
25
+ hub: EthAddress;
26
+ assetId: number;
27
+ decimals: number;
28
+ paused: boolean;
29
+ frozen: boolean;
30
+ borrowable: boolean;
31
+ collateralRisk: number;
32
+ collateralFactor: number;
33
+ maxLiquidationBonus: number;
34
+ liquidationFee: number;
35
+ price: bigint;
36
+ totalSupplied: bigint;
37
+ totalDrawn: bigint;
38
+ totalPremium: bigint;
39
+ totalDebt: bigint;
40
+ supplyCap: bigint;
41
+ borrowCap: bigint;
42
+ deficitRay: bigint;
43
+ spokeActive: boolean;
44
+ spokePaused: boolean;
45
+ }
46
+ export interface AaveV4ReserveAssetData {
47
+ symbol: string;
48
+ underlying: EthAddress;
49
+ hub: EthAddress;
50
+ assetId: number;
51
+ reserveId: number;
52
+ paused: boolean;
53
+ frozen: boolean;
54
+ borrowable: boolean;
55
+ collateralRisk: number;
56
+ collateralFactor: number;
57
+ liquidationFee: number;
58
+ price: string;
59
+ totalSupplied: string;
60
+ totalDrawn: string;
61
+ totalPremium: string;
62
+ totalDebt: string;
63
+ supplyCap: string;
64
+ borrowCap: string;
65
+ spokeActive: boolean;
66
+ spokePaused: boolean;
67
+ drawnRate: string;
68
+ supplyRate: string;
69
+ supplyIncentives: IncentiveData[];
70
+ borrowIncentives: IncentiveData[];
71
+ canBeBorrowed: boolean;
72
+ canBeSupplied: boolean;
73
+ canBeWithdrawn: boolean;
74
+ canBePayBacked: boolean;
75
+ utilization: string;
76
+ }
77
+ export type AaveV4AssetsData = Record<string, AaveV4ReserveAssetData>;
78
+ export interface AaveV4SpokeData {
79
+ assetsData: AaveV4AssetsData;
80
+ oracle: EthAddress;
81
+ oracleDecimals: number;
82
+ address: EthAddress;
83
+ }
84
+ export interface AaveV4UsedReserveAsset {
85
+ symbol: string;
86
+ assetId: number;
87
+ reserveId: number;
88
+ supplied: string;
89
+ suppliedUsd: string;
90
+ drawn: string;
91
+ drawnUsd: string;
92
+ premium: string;
93
+ premiumUsd: string;
94
+ borrowed: string;
95
+ borrowedUsd: string;
96
+ isSupplied: boolean;
97
+ isBorrowed: boolean;
98
+ collateral: boolean;
99
+ collateralFactor: number;
100
+ }
101
+ export interface AaveV4AggregatedPositionData {
102
+ suppliedUsd: string;
103
+ suppliedCollateralUsd: string;
104
+ borrowLimitUsd: string;
105
+ liquidationLimitUsd: string;
106
+ borrowedUsd: string;
107
+ drawnUsd: string;
108
+ premiumUsd: string;
109
+ leftToBorrowUsd: string;
110
+ ratio: string;
111
+ collRatio: string;
112
+ liqRatio: string;
113
+ liqPercent: string;
114
+ leveragedType: string;
115
+ leveragedAsset: string;
116
+ liquidationPrice: string;
117
+ leveragedLsdAssetRatio?: string;
118
+ minCollRatio: string;
119
+ collLiquidationRatio: string;
120
+ minHealthRatio: string;
121
+ netApy: string;
122
+ incentiveUsd: string;
123
+ totalInterestUsd: string;
124
+ }
125
+ export type AaveV4UsedReserveAssets = Record<string, AaveV4UsedReserveAsset>;
126
+ export interface AaveV4AccountData extends AaveV4AggregatedPositionData {
127
+ usedAssets: AaveV4UsedReserveAssets;
128
+ healthFactor: string;
129
+ }
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AaveV4HubsType = exports.AaveV4SpokesType = void 0;
4
+ var AaveV4SpokesType;
5
+ (function (AaveV4SpokesType) {
6
+ AaveV4SpokesType["AaveV4CoreSpoke"] = "aave_v4_core_spoke";
7
+ })(AaveV4SpokesType || (exports.AaveV4SpokesType = AaveV4SpokesType = {}));
8
+ var AaveV4HubsType;
9
+ (function (AaveV4HubsType) {
10
+ AaveV4HubsType["AaveV4CoreHub"] = "aave_v4_core_hub";
11
+ })(AaveV4HubsType || (exports.AaveV4HubsType = AaveV4HubsType = {}));
@@ -13,3 +13,4 @@ export * from './portfolio';
13
13
  export * from './merit';
14
14
  export * from './merkl';
15
15
  export * from './savings';
16
+ export * from './aaveV4';
@@ -29,3 +29,4 @@ __exportStar(require("./portfolio"), exports);
29
29
  __exportStar(require("./merit"), exports);
30
30
  __exportStar(require("./merkl"), exports);
31
31
  __exportStar(require("./savings"), exports);
32
+ __exportStar(require("./aaveV4"), exports);
@@ -1,4 +1,5 @@
1
1
  import { AaveV2PositionData, AaveV3PositionData, AaveVersions } from './aave';
2
+ import { AaveV4AccountData, AaveV4SpokesType } from './aaveV4';
2
3
  import { EthAddress } from './common';
3
4
  import { CompoundV2PositionData, CompoundV3PositionData, CompoundVersions } from './compound';
4
5
  import { CrvUSDUserData, CrvUSDVersions } from './curveUsd';
@@ -51,6 +52,9 @@ export interface PortfolioPositionsDataForAddress {
51
52
  [key: string]: FluidVaultData;
52
53
  };
53
54
  };
55
+ aaveV4: {
56
+ [key in AaveV4SpokesType]?: PortfolioProtocolData<AaveV4AccountData>;
57
+ };
54
58
  }
55
59
  export interface PortfolioPositionsData {
56
60
  [key: EthAddress]: PortfolioPositionsDataForAddress;
@@ -0,0 +1,7 @@
1
+ import { Client } from 'viem';
2
+ import { AaveV4AccountData, AaveV4SpokeData, AaveV4SpokeInfo } from '../types';
3
+ import { EthAddress, EthereumProvider, NetworkNumber } from '../types/common';
4
+ export declare function _getAaveV4SpokeData(provider: Client, network: NetworkNumber, market: AaveV4SpokeInfo, blockNumber?: 'latest' | number): Promise<AaveV4SpokeData>;
5
+ export declare function getAaveV4SpokeData(provider: EthereumProvider, network: NetworkNumber, spoke: AaveV4SpokeInfo, blockNumber?: 'latest' | number): Promise<AaveV4SpokeData>;
6
+ export declare function _getAaveV4AccountData(provider: Client, network: NetworkNumber, spokeData: AaveV4SpokeData, address: EthAddress, blockNumber?: 'latest' | number): Promise<AaveV4AccountData>;
7
+ export declare function getAaveV4AccountData(provider: EthereumProvider, network: NetworkNumber, marketData: AaveV4SpokeData, address: EthAddress, blockNumber?: 'latest' | number): Promise<any>;