@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.
- package/cjs/aaveV4/index.d.ts +7 -0
- package/cjs/aaveV4/index.js +156 -0
- package/cjs/config/contracts.d.ts +1069 -0
- package/cjs/config/contracts.js +9 -0
- package/cjs/contracts.d.ts +18265 -0
- package/cjs/contracts.js +2 -1
- package/cjs/helpers/aaveV4Helpers/index.d.ts +7 -0
- package/cjs/helpers/aaveV4Helpers/index.js +54 -0
- package/cjs/helpers/index.d.ts +1 -0
- package/cjs/helpers/index.js +2 -1
- package/cjs/index.d.ts +2 -1
- package/cjs/index.js +3 -1
- package/cjs/markets/aaveV4/index.d.ts +6 -0
- package/cjs/markets/aaveV4/index.js +20 -0
- package/cjs/markets/index.d.ts +1 -0
- package/cjs/markets/index.js +3 -1
- package/cjs/portfolio/index.js +20 -0
- package/cjs/savings/morphoVaults/options.js +1 -1
- package/cjs/types/aaveV4.d.ts +120 -0
- package/cjs/types/aaveV4.js +11 -0
- package/cjs/types/index.d.ts +1 -0
- package/cjs/types/index.js +1 -0
- package/cjs/types/portfolio.d.ts +4 -0
- package/esm/aaveV4/index.d.ts +7 -0
- package/esm/aaveV4/index.js +147 -0
- package/esm/config/contracts.d.ts +1069 -0
- package/esm/config/contracts.js +8 -0
- package/esm/contracts.d.ts +18265 -0
- package/esm/contracts.js +1 -0
- package/esm/helpers/aaveV4Helpers/index.d.ts +7 -0
- package/esm/helpers/aaveV4Helpers/index.js +47 -0
- package/esm/helpers/index.d.ts +1 -0
- package/esm/helpers/index.js +1 -0
- package/esm/index.d.ts +2 -1
- package/esm/index.js +2 -1
- package/esm/markets/aaveV4/index.d.ts +6 -0
- package/esm/markets/aaveV4/index.js +15 -0
- package/esm/markets/index.d.ts +1 -0
- package/esm/markets/index.js +1 -0
- package/esm/portfolio/index.js +21 -1
- package/esm/savings/morphoVaults/options.js +1 -1
- package/esm/types/aaveV4.d.ts +120 -0
- package/esm/types/aaveV4.js +8 -0
- package/esm/types/index.d.ts +1 -0
- package/esm/types/index.js +1 -0
- package/esm/types/portfolio.d.ts +4 -0
- package/package.json +2 -2
- package/src/aaveV4/index.ts +159 -0
- package/src/config/contracts.ts +8 -0
- package/src/contracts.ts +3 -1
- package/src/helpers/aaveV4Helpers/index.ts +66 -0
- package/src/helpers/index.ts +1 -0
- package/src/index.ts +2 -0
- package/src/markets/aaveV4/index.ts +17 -0
- package/src/markets/index.ts +1 -0
- package/src/portfolio/index.ts +20 -0
- package/src/savings/morphoVaults/options.ts +1 -1
- package/src/types/aaveV4.ts +133 -0
- package/src/types/index.ts +2 -1
- 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;
|
package/cjs/helpers/index.d.ts
CHANGED
package/cjs/helpers/index.js
CHANGED
|
@@ -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;
|
package/cjs/markets/index.d.ts
CHANGED
|
@@ -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';
|
package/cjs/markets/index.js
CHANGED
|
@@ -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; } });
|
package/cjs/portfolio/index.js
CHANGED
|
@@ -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: '
|
|
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 = {}));
|
package/cjs/types/index.d.ts
CHANGED
package/cjs/types/index.js
CHANGED
package/cjs/types/portfolio.d.ts
CHANGED
|
@@ -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
|
+
}
|