@defisaver/positions-sdk 2.1.42 → 2.1.43-aave-v4-dev-2

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 (60) hide show
  1. package/cjs/aaveV4/index.d.ts +7 -0
  2. package/cjs/aaveV4/index.js +156 -0
  3. package/cjs/config/contracts.d.ts +1069 -0
  4. package/cjs/config/contracts.js +9 -0
  5. package/cjs/contracts.d.ts +18265 -0
  6. package/cjs/contracts.js +2 -1
  7. package/cjs/helpers/aaveV4Helpers/index.d.ts +7 -0
  8. package/cjs/helpers/aaveV4Helpers/index.js +54 -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/aaveV4/index.d.ts +6 -0
  14. package/cjs/markets/aaveV4/index.js +20 -0
  15. package/cjs/markets/index.d.ts +1 -0
  16. package/cjs/markets/index.js +3 -1
  17. package/cjs/portfolio/index.js +20 -0
  18. package/cjs/savings/morphoVaults/options.js +1 -1
  19. package/cjs/types/aaveV4.d.ts +120 -0
  20. package/cjs/types/aaveV4.js +11 -0
  21. package/cjs/types/index.d.ts +1 -0
  22. package/cjs/types/index.js +1 -0
  23. package/cjs/types/portfolio.d.ts +4 -0
  24. package/esm/aaveV4/index.d.ts +7 -0
  25. package/esm/aaveV4/index.js +147 -0
  26. package/esm/config/contracts.d.ts +1069 -0
  27. package/esm/config/contracts.js +8 -0
  28. package/esm/contracts.d.ts +18265 -0
  29. package/esm/contracts.js +1 -0
  30. package/esm/helpers/aaveV4Helpers/index.d.ts +7 -0
  31. package/esm/helpers/aaveV4Helpers/index.js +47 -0
  32. package/esm/helpers/index.d.ts +1 -0
  33. package/esm/helpers/index.js +1 -0
  34. package/esm/index.d.ts +2 -1
  35. package/esm/index.js +2 -1
  36. package/esm/markets/aaveV4/index.d.ts +6 -0
  37. package/esm/markets/aaveV4/index.js +15 -0
  38. package/esm/markets/index.d.ts +1 -0
  39. package/esm/markets/index.js +1 -0
  40. package/esm/portfolio/index.js +21 -1
  41. package/esm/savings/morphoVaults/options.js +1 -1
  42. package/esm/types/aaveV4.d.ts +120 -0
  43. package/esm/types/aaveV4.js +8 -0
  44. package/esm/types/index.d.ts +1 -0
  45. package/esm/types/index.js +1 -0
  46. package/esm/types/portfolio.d.ts +4 -0
  47. package/package.json +2 -2
  48. package/src/aaveV4/index.ts +159 -0
  49. package/src/config/contracts.ts +8 -0
  50. package/src/contracts.ts +3 -1
  51. package/src/helpers/aaveV4Helpers/index.ts +66 -0
  52. package/src/helpers/index.ts +1 -0
  53. package/src/index.ts +2 -0
  54. package/src/markets/aaveV4/index.ts +17 -0
  55. package/src/markets/index.ts +1 -0
  56. package/src/portfolio/index.ts +20 -0
  57. package/src/savings/morphoVaults/options.ts +1 -1
  58. package/src/types/aaveV4.ts +133 -0
  59. package/src/types/index.ts +2 -1
  60. 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,7 @@
1
+ import { AaveV4AggregatedPositionData, AaveV4AssetsData, AaveV4UsedReserveAssets } from '../../types';
2
+ import { NetworkNumber } from '../../types/common';
3
+ export declare const aaveV4GetAggregatedPositionData: ({ usedAssets, assetsData, network, }: {
4
+ usedAssets: AaveV4UsedReserveAssets;
5
+ assetsData: AaveV4AssetsData;
6
+ network: NetworkNumber;
7
+ }) => AaveV4AggregatedPositionData;
@@ -0,0 +1,54 @@
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 = void 0;
7
+ const decimal_js_1 = __importDefault(require("decimal.js"));
8
+ const moneymarket_1 = require("../../moneymarket");
9
+ const aaveV4GetAggregatedPositionData = ({ usedAssets, assetsData, network, }) => {
10
+ const payload = {};
11
+ payload.suppliedUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied }) => isSupplied, ({ suppliedUsd }) => suppliedUsd);
12
+ payload.suppliedCollateralUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied, collateral }) => isSupplied && collateral, ({ suppliedUsd }) => suppliedUsd);
13
+ payload.borrowLimitUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied, collateral }) => isSupplied && collateral, ({ symbol, suppliedUsd }) => new decimal_js_1.default(suppliedUsd).mul(assetsData[symbol].collateralFactor));
14
+ payload.liquidationLimitUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isSupplied, collateral }) => isSupplied && collateral,
15
+ // TODO: Verify if liquidation factor is available in Aave V4, currently using collateralFactor as placeholder
16
+ ({ symbol, suppliedUsd }) => new decimal_js_1.default(suppliedUsd).mul(assetsData[symbol].collateralFactor));
17
+ payload.borrowedUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isBorrowed }) => isBorrowed, ({ borrowedUsd }) => borrowedUsd);
18
+ payload.drawnUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isBorrowed }) => isBorrowed, ({ drawnUsd }) => drawnUsd);
19
+ payload.premiumUsd = (0, moneymarket_1.getAssetsTotal)(usedAssets, ({ isBorrowed }) => isBorrowed, ({ premiumUsd }) => premiumUsd);
20
+ const leftToBorrowUsd = new decimal_js_1.default(payload.borrowLimitUsd).sub(payload.borrowedUsd);
21
+ payload.leftToBorrowUsd = leftToBorrowUsd.lte('0') ? '0' : leftToBorrowUsd.toString();
22
+ payload.ratio = +payload.suppliedUsd ? new decimal_js_1.default(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
23
+ payload.collRatio = +payload.suppliedUsd ? new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
24
+ payload.liqRatio = new decimal_js_1.default(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).toString();
25
+ payload.liqPercent = new decimal_js_1.default(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).mul(100).toString();
26
+ const { leveragedType, leveragedAsset } = (0, moneymarket_1.isLeveragedPos)(usedAssets);
27
+ payload.leveragedType = leveragedType;
28
+ payload.leveragedAsset = leveragedAsset;
29
+ payload.liquidationPrice = '';
30
+ if (leveragedType !== '') {
31
+ let assetPrice = assetsData[leveragedAsset].price;
32
+ if (leveragedType === 'lsd-leverage') {
33
+ // Treat ETH like a stablecoin in a long stETH position
34
+ payload.leveragedLsdAssetRatio = new decimal_js_1.default(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
35
+ assetPrice = new decimal_js_1.default(assetPrice).div(assetsData.ETH.price).toString();
36
+ }
37
+ payload.liquidationPrice = (0, moneymarket_1.calcLeverageLiqPrice)(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
38
+ }
39
+ payload.minCollRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.borrowLimitUsd).mul(100).toString();
40
+ payload.collLiquidationRatio = new decimal_js_1.default(payload.suppliedCollateralUsd).div(payload.liquidationLimitUsd).mul(100).toString();
41
+ // payload.healthRatio = new Dec(payload.liquidationLimitUsd).div(payload.borrowedUsd).toDP(4).toString();
42
+ payload.minHealthRatio = new decimal_js_1.default(payload.liquidationLimitUsd).div(payload.borrowLimitUsd).toDP(4).toString();
43
+ // TODO: Re-implement netApy calculation
44
+ // const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy({
45
+ // usedAssets,
46
+ // assetsData,
47
+ // optionalData: { healthRatio: payload.healthRatio },
48
+ // });
49
+ payload.netApy = '0';
50
+ payload.incentiveUsd = '0';
51
+ payload.totalInterestUsd = '0';
52
+ return payload;
53
+ };
54
+ 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"));
@@ -0,0 +1,6 @@
1
+ import { AaveV4SpokeInfo } 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
+ };
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ 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;
@@ -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; } });
@@ -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([
@@ -118,7 +118,7 @@ exports.MORPHO_VAULT_STEAKHOUSE_ETH = {
118
118
  exports.MORPHO_VAULT_STEAKHOUSE_PYUSD = {
119
119
  type: types_1.MorphoVaultType.MorphoVaultSteakhousePYUSD,
120
120
  name: 'Steakhouse PYUSD',
121
- address: '0xBEEF01735c132Ada46AA9aA4c54623cAA92A64CB',
121
+ address: '0xbEEF02e5E13584ab96848af90261f0C8Ee04722a',
122
122
  asset: 'PYUSD',
123
123
  deploymentBlock: 19043398,
124
124
  isLegacy: false,
@@ -0,0 +1,120 @@
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
+ paused: boolean;
52
+ frozen: boolean;
53
+ borrowable: boolean;
54
+ collateralRisk: number;
55
+ collateralFactor: number;
56
+ liquidationFee: number;
57
+ price: string;
58
+ totalSupplied: string;
59
+ totalDrawn: string;
60
+ totalPremium: string;
61
+ totalDebt: string;
62
+ supplyCap: string;
63
+ borrowCap: string;
64
+ spokeActive: boolean;
65
+ spokePaused: boolean;
66
+ drawnRate: string;
67
+ supplyRate: string;
68
+ supplyIncentives: IncentiveData[];
69
+ borrowIncentives: IncentiveData[];
70
+ }
71
+ export type AaveV4AssetsData = Record<string, AaveV4ReserveAssetData>;
72
+ export interface AaveV4SpokeData {
73
+ assetsData: AaveV4AssetsData;
74
+ oracle: EthAddress;
75
+ oracleDecimals: number;
76
+ address: EthAddress;
77
+ }
78
+ export interface AaveV4UsedReserveAsset {
79
+ symbol: string;
80
+ supplied: string;
81
+ suppliedUsd: string;
82
+ drawn: string;
83
+ drawnUsd: string;
84
+ premium: string;
85
+ premiumUsd: string;
86
+ borrowed: string;
87
+ borrowedUsd: string;
88
+ isSupplied: boolean;
89
+ isBorrowed: boolean;
90
+ collateral: boolean;
91
+ }
92
+ export interface AaveV4AggregatedPositionData {
93
+ suppliedUsd: string;
94
+ suppliedCollateralUsd: string;
95
+ borrowLimitUsd: string;
96
+ liquidationLimitUsd: string;
97
+ borrowedUsd: string;
98
+ drawnUsd: string;
99
+ premiumUsd: string;
100
+ leftToBorrowUsd: string;
101
+ ratio: string;
102
+ collRatio: string;
103
+ liqRatio: string;
104
+ liqPercent: string;
105
+ leveragedType: string;
106
+ leveragedAsset: string;
107
+ liquidationPrice: string;
108
+ leveragedLsdAssetRatio?: string;
109
+ minCollRatio: string;
110
+ collLiquidationRatio: string;
111
+ minHealthRatio: string;
112
+ netApy: string;
113
+ incentiveUsd: string;
114
+ totalInterestUsd: string;
115
+ }
116
+ export type AaveV4UsedReserveAssets = Record<string, AaveV4UsedReserveAsset>;
117
+ export interface AaveV4AccountData extends AaveV4AggregatedPositionData {
118
+ usedAssets: AaveV4UsedReserveAssets;
119
+ healthFactor: string;
120
+ }
@@ -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>;
@@ -0,0 +1,147 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import Dec from 'decimal.js';
11
+ import { assetAmountInEth, getAssetInfoByAddress } from '@defisaver/tokens';
12
+ import { getViemProvider } from '../services/viem';
13
+ import { IncentiveKind, } from '../types/common';
14
+ import { AaveV4ViewContractViem } from '../contracts';
15
+ import { getStakingApy, STAKING_ASSETS } from '../staking';
16
+ import { wethToEth } from '../services/utils';
17
+ import { aaveV4GetAggregatedPositionData } from '../helpers/aaveV4Helpers';
18
+ const fetchHubData = (viewContract, hubAddress) => __awaiter(void 0, void 0, void 0, function* () {
19
+ const hubData = yield viewContract.read.getHubAllAssetsData([hubAddress]);
20
+ return {
21
+ assets: hubData.reduce((acc, assetOnChainData) => {
22
+ acc[assetOnChainData.assetId] = {
23
+ assetId: assetOnChainData.assetId,
24
+ drawnRate: assetOnChainData.drawnRate,
25
+ };
26
+ return acc;
27
+ }, {}),
28
+ };
29
+ });
30
+ const formatReserveAsset = (reserveAsset, hubAsset, oracleDecimals, network) => __awaiter(void 0, void 0, void 0, function* () {
31
+ const assetInfo = getAssetInfoByAddress(reserveAsset.underlying, network);
32
+ const symbol = wethToEth(assetInfo.symbol);
33
+ const isStakingAsset = STAKING_ASSETS.includes(symbol);
34
+ const supplyIncentives = [];
35
+ const borrowIncentives = [];
36
+ if (isStakingAsset) {
37
+ const yieldApy = yield getStakingApy(symbol, network);
38
+ supplyIncentives.push({
39
+ apy: yieldApy,
40
+ token: symbol,
41
+ incentiveKind: IncentiveKind.Staking,
42
+ description: `Native ${symbol} yield.`,
43
+ });
44
+ if (reserveAsset.borrowable) {
45
+ // when borrowing assets whose value increases over time
46
+ borrowIncentives.push({
47
+ apy: new Dec(yieldApy).mul(-1).toString(),
48
+ token: symbol,
49
+ incentiveKind: IncentiveKind.Reward,
50
+ description: `Due to the native yield of ${symbol}, the value of the debt would increase over time.`,
51
+ });
52
+ }
53
+ }
54
+ return ({
55
+ symbol,
56
+ underlying: reserveAsset.underlying,
57
+ hub: reserveAsset.hub,
58
+ assetId: reserveAsset.assetId,
59
+ paused: reserveAsset.paused,
60
+ frozen: reserveAsset.frozen,
61
+ borrowable: reserveAsset.borrowable,
62
+ collateralRisk: new Dec(reserveAsset.collateralRisk).div(10000).toNumber(),
63
+ collateralFactor: new Dec(reserveAsset.collateralFactor).div(10000).toNumber(),
64
+ liquidationFee: new Dec(reserveAsset.liquidationFee).div(10000).toNumber(),
65
+ price: new Dec(reserveAsset.price).div(new Dec(10).pow(oracleDecimals)).toString(),
66
+ totalSupplied: assetAmountInEth(reserveAsset.totalSupplied.toString(), symbol),
67
+ totalDrawn: assetAmountInEth(reserveAsset.totalDrawn.toString(), symbol),
68
+ totalPremium: assetAmountInEth(reserveAsset.totalPremium.toString(), symbol),
69
+ totalDebt: assetAmountInEth(reserveAsset.totalDebt.toString(), symbol),
70
+ supplyCap: assetAmountInEth(reserveAsset.supplyCap.toString(), symbol),
71
+ borrowCap: assetAmountInEth(reserveAsset.borrowCap.toString(), symbol),
72
+ spokeActive: reserveAsset.spokeActive,
73
+ spokePaused: reserveAsset.spokePaused,
74
+ drawnRate: new Dec(hubAsset.drawnRate).div(new Dec(10).pow(27)).toString(),
75
+ supplyRate: '0', // To be implemented
76
+ supplyIncentives,
77
+ borrowIncentives,
78
+ });
79
+ });
80
+ export function _getAaveV4SpokeData(provider_1, network_1, market_1) {
81
+ return __awaiter(this, arguments, void 0, function* (provider, network, market, blockNumber = 'latest') {
82
+ const viewContract = AaveV4ViewContractViem(provider, network, blockNumber);
83
+ const hubsData = {};
84
+ const [spokeData] = yield Promise.all([
85
+ viewContract.read.getSpokeDataFull([market.address]),
86
+ ...market.hubs.map((hubAddress) => __awaiter(this, void 0, void 0, function* () {
87
+ hubsData[hubAddress] = yield fetchHubData(viewContract, hubAddress);
88
+ })),
89
+ ]);
90
+ const reserveAssetsArray = yield Promise.all(spokeData[1].map((reserveAssetOnChain) => __awaiter(this, void 0, void 0, function* () { return formatReserveAsset(reserveAssetOnChain, hubsData[reserveAssetOnChain.hub].assets[reserveAssetOnChain.assetId], +spokeData[0].oracleDecimals.toString(), network); })));
91
+ return {
92
+ assetsData: reserveAssetsArray.reduce((acc, reserveAsset) => {
93
+ acc[reserveAsset.symbol] = reserveAsset;
94
+ return acc;
95
+ }, {}),
96
+ oracle: spokeData[0].oracle,
97
+ oracleDecimals: +spokeData[0].oracleDecimals.toString(),
98
+ address: market.address,
99
+ };
100
+ });
101
+ }
102
+ export function getAaveV4SpokeData(provider_1, network_1, spoke_1) {
103
+ return __awaiter(this, arguments, void 0, function* (provider, network, spoke, blockNumber = 'latest') {
104
+ return _getAaveV4SpokeData(getViemProvider(provider, network), network, spoke, blockNumber);
105
+ });
106
+ }
107
+ export function _getAaveV4AccountData(provider_1, network_1, spokeData_1, address_1) {
108
+ return __awaiter(this, arguments, void 0, function* (provider, network, spokeData, address, blockNumber = 'latest') {
109
+ const viewContract = AaveV4ViewContractViem(provider, network, blockNumber);
110
+ const loanData = yield viewContract.read.getLoanData([spokeData.address, address]);
111
+ const healthFactor = new Dec(loanData.healthFactor).div(1e18).toString();
112
+ const usedAssets = loanData.reserves.reduce((acc, usedReserveAsset) => {
113
+ const reserveData = spokeData.assetsData[wethToEth(getAssetInfoByAddress(usedReserveAsset.underlying, network).symbol)];
114
+ const price = reserveData.price;
115
+ const supplied = assetAmountInEth(usedReserveAsset.supplied.toString(), reserveData.symbol);
116
+ const drawn = assetAmountInEth(usedReserveAsset.drawn.toString(), reserveData.symbol);
117
+ const premium = assetAmountInEth(usedReserveAsset.premium.toString(), reserveData.symbol);
118
+ const borrowed = assetAmountInEth(usedReserveAsset.totalDebt.toString(), reserveData.symbol);
119
+ acc[reserveData.symbol] = {
120
+ symbol: reserveData.symbol,
121
+ supplied,
122
+ suppliedUsd: new Dec(supplied).mul(price).toString(),
123
+ drawn,
124
+ drawnUsd: new Dec(drawn).mul(price).toString(),
125
+ premium,
126
+ premiumUsd: new Dec(premium).mul(price).toString(),
127
+ borrowed,
128
+ borrowedUsd: new Dec(borrowed).mul(price).toString(),
129
+ isSupplied: !new Dec(supplied).eq(0),
130
+ isBorrowed: usedReserveAsset.isBorrowing,
131
+ collateral: usedReserveAsset.isUsingAsCollateral,
132
+ };
133
+ return acc;
134
+ }, {});
135
+ return Object.assign({ usedAssets,
136
+ healthFactor }, aaveV4GetAggregatedPositionData({
137
+ usedAssets,
138
+ assetsData: spokeData.assetsData,
139
+ network,
140
+ }));
141
+ });
142
+ }
143
+ export function getAaveV4AccountData(provider_1, network_1, marketData_1, address_1) {
144
+ return __awaiter(this, arguments, void 0, function* (provider, network, marketData, address, blockNumber = 'latest') {
145
+ return _getAaveV4AccountData(getViemProvider(provider, network), network, marketData, address, blockNumber);
146
+ });
147
+ }