@defisaver/positions-sdk 0.0.1
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/aaveV2/index.d.ts +9 -0
- package/cjs/aaveV2/index.js +184 -0
- package/cjs/aaveV3/index.d.ts +33 -0
- package/cjs/aaveV3/index.js +395 -0
- package/cjs/assets/index.d.ts +4 -0
- package/cjs/assets/index.js +54 -0
- package/cjs/chickenBonds/index.d.ts +3 -0
- package/cjs/chickenBonds/index.js +24 -0
- package/cjs/compoundV2/index.d.ts +21 -0
- package/cjs/compoundV2/index.js +168 -0
- package/cjs/compoundV3/index.d.ts +37 -0
- package/cjs/compoundV3/index.js +208 -0
- package/cjs/config/contracts.d.ts +3028 -0
- package/cjs/config/contracts.js +596 -0
- package/cjs/constants/index.d.ts +4 -0
- package/cjs/constants/index.js +7 -0
- package/cjs/contracts.d.ts +40 -0
- package/cjs/contracts.js +65 -0
- package/cjs/curveUsd/index.d.ts +7 -0
- package/cjs/curveUsd/index.js +199 -0
- package/cjs/exchange/index.d.ts +3 -0
- package/cjs/exchange/index.js +23 -0
- package/cjs/helpers/aaveHelpers/index.d.ts +37 -0
- package/cjs/helpers/aaveHelpers/index.js +118 -0
- package/cjs/helpers/compoundHelpers/index.d.ts +20 -0
- package/cjs/helpers/compoundHelpers/index.js +141 -0
- package/cjs/helpers/curveUsdHelpers/index.d.ts +8 -0
- package/cjs/helpers/curveUsdHelpers/index.js +42 -0
- package/cjs/helpers/index.d.ts +5 -0
- package/cjs/helpers/index.js +31 -0
- package/cjs/helpers/makerHelpers/index.d.ts +5 -0
- package/cjs/helpers/makerHelpers/index.js +100 -0
- package/cjs/helpers/sparkHelpers/index.d.ts +21 -0
- package/cjs/helpers/sparkHelpers/index.js +96 -0
- package/cjs/index.d.ts +19 -0
- package/cjs/index.js +64 -0
- package/cjs/liquity/index.d.ts +7 -0
- package/cjs/liquity/index.js +103 -0
- package/cjs/maker/index.d.ts +5 -0
- package/cjs/maker/index.js +103 -0
- package/cjs/markets/aave/index.d.ts +12 -0
- package/cjs/markets/aave/index.js +76 -0
- package/cjs/markets/aave/marketAssets.d.ts +9 -0
- package/cjs/markets/aave/marketAssets.js +31 -0
- package/cjs/markets/compound/index.d.ts +12 -0
- package/cjs/markets/compound/index.js +85 -0
- package/cjs/markets/compound/marketsAssets.d.ts +19 -0
- package/cjs/markets/compound/marketsAssets.js +35 -0
- package/cjs/markets/curveUsd/index.d.ts +10 -0
- package/cjs/markets/curveUsd/index.js +47 -0
- package/cjs/markets/index.d.ts +4 -0
- package/cjs/markets/index.js +11 -0
- package/cjs/markets/spark/index.d.ts +9 -0
- package/cjs/markets/spark/index.js +31 -0
- package/cjs/markets/spark/marketAssets.d.ts +6 -0
- package/cjs/markets/spark/marketAssets.js +12 -0
- package/cjs/moneymarket/index.d.ts +1 -0
- package/cjs/moneymarket/index.js +17 -0
- package/cjs/moneymarket/moneymarketCommonService.d.ts +12 -0
- package/cjs/moneymarket/moneymarketCommonService.js +83 -0
- package/cjs/morphoAaveV2/index.d.ts +7 -0
- package/cjs/morphoAaveV2/index.js +209 -0
- package/cjs/morphoAaveV3/index.d.ts +7 -0
- package/cjs/morphoAaveV3/index.js +442 -0
- package/cjs/multicall/index.d.ts +3 -0
- package/cjs/multicall/index.js +31 -0
- package/cjs/services/dsrService.d.ts +3 -0
- package/cjs/services/dsrService.js +28 -0
- package/cjs/services/utils.d.ts +16 -0
- package/cjs/services/utils.js +41 -0
- package/cjs/spark/index.d.ts +34 -0
- package/cjs/spark/index.js +337 -0
- package/cjs/staking/index.d.ts +1 -0
- package/cjs/staking/index.js +17 -0
- package/cjs/staking/staking.d.ts +15 -0
- package/cjs/staking/staking.js +162 -0
- package/cjs/types/aave.d.ts +229 -0
- package/cjs/types/aave.js +10 -0
- package/cjs/types/common.d.ts +77 -0
- package/cjs/types/common.js +10 -0
- package/cjs/types/compound.d.ts +109 -0
- package/cjs/types/compound.js +10 -0
- package/cjs/types/contracts/generated/AaveLendingPoolV2.d.ts +312 -0
- package/cjs/types/contracts/generated/AaveLendingPoolV2.js +5 -0
- package/cjs/types/contracts/generated/AaveLoanInfoV2.d.ts +137 -0
- package/cjs/types/contracts/generated/AaveLoanInfoV2.js +5 -0
- package/cjs/types/contracts/generated/AaveProtocolDataProvider.d.ts +110 -0
- package/cjs/types/contracts/generated/AaveProtocolDataProvider.js +5 -0
- package/cjs/types/contracts/generated/AaveUiIncentiveDataProviderV3.d.ts +196 -0
- package/cjs/types/contracts/generated/AaveUiIncentiveDataProviderV3.js +5 -0
- package/cjs/types/contracts/generated/AaveV3LendingPool.d.ts +429 -0
- package/cjs/types/contracts/generated/AaveV3LendingPool.js +5 -0
- package/cjs/types/contracts/generated/AaveV3PoolAddressesProvider.d.ts +169 -0
- package/cjs/types/contracts/generated/AaveV3PoolAddressesProvider.js +5 -0
- package/cjs/types/contracts/generated/AaveV3ProtocolDataProvider.d.ts +131 -0
- package/cjs/types/contracts/generated/AaveV3ProtocolDataProvider.js +5 -0
- package/cjs/types/contracts/generated/AaveV3View.d.ts +301 -0
- package/cjs/types/contracts/generated/AaveV3View.js +5 -0
- package/cjs/types/contracts/generated/BalanceScanner.d.ts +37 -0
- package/cjs/types/contracts/generated/BalanceScanner.js +5 -0
- package/cjs/types/contracts/generated/CETHv3.d.ts +441 -0
- package/cjs/types/contracts/generated/CETHv3.js +5 -0
- package/cjs/types/contracts/generated/CUSDCv3.d.ts +441 -0
- package/cjs/types/contracts/generated/CUSDCv3.js +5 -0
- package/cjs/types/contracts/generated/CUSDbCv3.d.ts +441 -0
- package/cjs/types/contracts/generated/CUSDbCv3.js +5 -0
- package/cjs/types/contracts/generated/CbEth.d.ts +20 -0
- package/cjs/types/contracts/generated/CbEth.js +5 -0
- package/cjs/types/contracts/generated/ChickenBondsView.d.ts +67 -0
- package/cjs/types/contracts/generated/ChickenBondsView.js +5 -0
- package/cjs/types/contracts/generated/CollSurplusPool.d.ts +85 -0
- package/cjs/types/contracts/generated/CollSurplusPool.js +5 -0
- package/cjs/types/contracts/generated/CompV3ETHBulker.d.ts +45 -0
- package/cjs/types/contracts/generated/CompV3ETHBulker.js +5 -0
- package/cjs/types/contracts/generated/CompV3USDCBulker.d.ts +31 -0
- package/cjs/types/contracts/generated/CompV3USDCBulker.js +5 -0
- package/cjs/types/contracts/generated/CompV3USDbCBulker.d.ts +41 -0
- package/cjs/types/contracts/generated/CompV3USDbCBulker.js +5 -0
- package/cjs/types/contracts/generated/CompV3View.d.ts +249 -0
- package/cjs/types/contracts/generated/CompV3View.js +5 -0
- package/cjs/types/contracts/generated/CompoundLoanInfo.d.ts +128 -0
- package/cjs/types/contracts/generated/CompoundLoanInfo.js +5 -0
- package/cjs/types/contracts/generated/Comptroller.d.ts +317 -0
- package/cjs/types/contracts/generated/Comptroller.js +5 -0
- package/cjs/types/contracts/generated/CrvUSDETHAmm.d.ts +139 -0
- package/cjs/types/contracts/generated/CrvUSDETHAmm.js +5 -0
- package/cjs/types/contracts/generated/CrvUSDETHController.d.ts +204 -0
- package/cjs/types/contracts/generated/CrvUSDETHController.js +5 -0
- package/cjs/types/contracts/generated/CrvUSDFactory.d.ts +117 -0
- package/cjs/types/contracts/generated/CrvUSDFactory.js +5 -0
- package/cjs/types/contracts/generated/CrvUSDView.d.ts +209 -0
- package/cjs/types/contracts/generated/CrvUSDView.js +5 -0
- package/cjs/types/contracts/generated/CrvUSDWBTCAmm.d.ts +139 -0
- package/cjs/types/contracts/generated/CrvUSDWBTCAmm.js +5 -0
- package/cjs/types/contracts/generated/CrvUSDWBTCController.d.ts +204 -0
- package/cjs/types/contracts/generated/CrvUSDWBTCController.js +5 -0
- package/cjs/types/contracts/generated/CrvUSDwstETHAmm.d.ts +139 -0
- package/cjs/types/contracts/generated/CrvUSDwstETHAmm.js +5 -0
- package/cjs/types/contracts/generated/CrvUSDwstETHController.d.ts +204 -0
- package/cjs/types/contracts/generated/CrvUSDwstETHController.js +5 -0
- package/cjs/types/contracts/generated/Erc20.d.ts +119 -0
- package/cjs/types/contracts/generated/Erc20.js +5 -0
- package/cjs/types/contracts/generated/GHO.d.ts +136 -0
- package/cjs/types/contracts/generated/GHO.js +5 -0
- package/cjs/types/contracts/generated/GhoDiscountRateStrategy.d.ts +25 -0
- package/cjs/types/contracts/generated/GhoDiscountRateStrategy.js +5 -0
- package/cjs/types/contracts/generated/IAToken.d.ts +21 -0
- package/cjs/types/contracts/generated/IAToken.js +5 -0
- package/cjs/types/contracts/generated/IVariableDebtToken.d.ts +21 -0
- package/cjs/types/contracts/generated/IVariableDebtToken.js +5 -0
- package/cjs/types/contracts/generated/LendingPoolAddressesProvider.d.ts +135 -0
- package/cjs/types/contracts/generated/LendingPoolAddressesProvider.js +5 -0
- package/cjs/types/contracts/generated/Lido.d.ts +38 -0
- package/cjs/types/contracts/generated/Lido.js +5 -0
- package/cjs/types/contracts/generated/LiquityActivePool.d.ts +21 -0
- package/cjs/types/contracts/generated/LiquityActivePool.js +5 -0
- package/cjs/types/contracts/generated/LiquityView.d.ts +51 -0
- package/cjs/types/contracts/generated/LiquityView.js +5 -0
- package/cjs/types/contracts/generated/McdDog.d.ts +134 -0
- package/cjs/types/contracts/generated/McdDog.js +5 -0
- package/cjs/types/contracts/generated/McdJug.d.ts +50 -0
- package/cjs/types/contracts/generated/McdJug.js +5 -0
- package/cjs/types/contracts/generated/McdSpotter.d.ts +27 -0
- package/cjs/types/contracts/generated/McdSpotter.js +5 -0
- package/cjs/types/contracts/generated/McdVat.d.ts +78 -0
- package/cjs/types/contracts/generated/McdVat.js +5 -0
- package/cjs/types/contracts/generated/McdView.d.ts +61 -0
- package/cjs/types/contracts/generated/McdView.js +5 -0
- package/cjs/types/contracts/generated/MorphoAaveV2Proxy.d.ts +418 -0
- package/cjs/types/contracts/generated/MorphoAaveV2Proxy.js +5 -0
- package/cjs/types/contracts/generated/MorphoAaveV2View.d.ts +274 -0
- package/cjs/types/contracts/generated/MorphoAaveV2View.js +5 -0
- package/cjs/types/contracts/generated/MorphoAaveV3ProxyEthMarket.d.ts +202 -0
- package/cjs/types/contracts/generated/MorphoAaveV3ProxyEthMarket.js +5 -0
- package/cjs/types/contracts/generated/Pot.d.ts +49 -0
- package/cjs/types/contracts/generated/Pot.js +5 -0
- package/cjs/types/contracts/generated/PriceFeed.d.ts +61 -0
- package/cjs/types/contracts/generated/PriceFeed.js +5 -0
- package/cjs/types/contracts/generated/REth.d.ts +20 -0
- package/cjs/types/contracts/generated/REth.js +5 -0
- package/cjs/types/contracts/generated/SparkIncentiveDataProvider.d.ts +200 -0
- package/cjs/types/contracts/generated/SparkIncentiveDataProvider.js +5 -0
- package/cjs/types/contracts/generated/SparkLendingPool.d.ts +420 -0
- package/cjs/types/contracts/generated/SparkLendingPool.js +5 -0
- package/cjs/types/contracts/generated/SparkPoolAddressesProvider.d.ts +169 -0
- package/cjs/types/contracts/generated/SparkPoolAddressesProvider.js +5 -0
- package/cjs/types/contracts/generated/SparkProtocolDataProvider.d.ts +132 -0
- package/cjs/types/contracts/generated/SparkProtocolDataProvider.js +5 -0
- package/cjs/types/contracts/generated/SparkView.d.ts +300 -0
- package/cjs/types/contracts/generated/SparkView.js +5 -0
- package/cjs/types/contracts/generated/TroveManager.d.ts +346 -0
- package/cjs/types/contracts/generated/TroveManager.js +5 -0
- package/cjs/types/contracts/generated/UniMulticall.d.ts +55 -0
- package/cjs/types/contracts/generated/UniMulticall.js +5 -0
- package/cjs/types/contracts/generated/WstETH.d.ts +65 -0
- package/cjs/types/contracts/generated/WstETH.js +5 -0
- package/cjs/types/contracts/generated/index.d.ts +57 -0
- package/cjs/types/contracts/generated/index.js +2 -0
- package/cjs/types/contracts/generated/types.d.ts +54 -0
- package/cjs/types/contracts/generated/types.js +2 -0
- package/cjs/types/curveUsd.d.ts +101 -0
- package/cjs/types/curveUsd.js +17 -0
- package/cjs/types/index.d.ts +6 -0
- package/cjs/types/index.js +22 -0
- package/cjs/types/liquity.d.ts +28 -0
- package/cjs/types/liquity.js +18 -0
- package/cjs/types/maker.d.ts +49 -0
- package/cjs/types/maker.js +2 -0
- package/cjs/types/spark.d.ts +100 -0
- package/cjs/types/spark.js +7 -0
- package/esm/aaveV2/index.d.ts +9 -0
- package/esm/aaveV2/index.js +174 -0
- package/esm/aaveV3/index.d.ts +33 -0
- package/esm/aaveV3/index.js +382 -0
- package/esm/assets/index.d.ts +4 -0
- package/esm/assets/index.js +49 -0
- package/esm/chickenBonds/index.d.ts +3 -0
- package/esm/chickenBonds/index.js +20 -0
- package/esm/compoundV2/index.d.ts +21 -0
- package/esm/compoundV2/index.js +157 -0
- package/esm/compoundV3/index.d.ts +37 -0
- package/esm/compoundV3/index.js +198 -0
- package/esm/config/contracts.d.ts +3028 -0
- package/esm/config/contracts.js +595 -0
- package/esm/constants/index.d.ts +4 -0
- package/esm/constants/index.js +4 -0
- package/esm/contracts.d.ts +40 -0
- package/esm/contracts.js +55 -0
- package/esm/curveUsd/index.d.ts +7 -0
- package/esm/curveUsd/index.js +189 -0
- package/esm/exchange/index.d.ts +3 -0
- package/esm/exchange/index.js +19 -0
- package/esm/helpers/aaveHelpers/index.d.ts +37 -0
- package/esm/helpers/aaveHelpers/index.js +101 -0
- package/esm/helpers/compoundHelpers/index.d.ts +20 -0
- package/esm/helpers/compoundHelpers/index.js +130 -0
- package/esm/helpers/curveUsdHelpers/index.d.ts +8 -0
- package/esm/helpers/curveUsdHelpers/index.js +35 -0
- package/esm/helpers/index.d.ts +5 -0
- package/esm/helpers/index.js +5 -0
- package/esm/helpers/makerHelpers/index.d.ts +5 -0
- package/esm/helpers/makerHelpers/index.js +92 -0
- package/esm/helpers/sparkHelpers/index.d.ts +21 -0
- package/esm/helpers/sparkHelpers/index.js +84 -0
- package/esm/index.d.ts +19 -0
- package/esm/index.js +19 -0
- package/esm/liquity/index.d.ts +7 -0
- package/esm/liquity/index.js +95 -0
- package/esm/maker/index.d.ts +5 -0
- package/esm/maker/index.js +95 -0
- package/esm/markets/aave/index.d.ts +12 -0
- package/esm/markets/aave/index.js +70 -0
- package/esm/markets/aave/marketAssets.d.ts +9 -0
- package/esm/markets/aave/marketAssets.js +28 -0
- package/esm/markets/compound/index.d.ts +12 -0
- package/esm/markets/compound/index.js +78 -0
- package/esm/markets/compound/marketsAssets.d.ts +19 -0
- package/esm/markets/compound/marketsAssets.js +32 -0
- package/esm/markets/curveUsd/index.d.ts +10 -0
- package/esm/markets/curveUsd/index.js +40 -0
- package/esm/markets/index.d.ts +4 -0
- package/esm/markets/index.js +4 -0
- package/esm/markets/spark/index.d.ts +9 -0
- package/esm/markets/spark/index.js +26 -0
- package/esm/markets/spark/marketAssets.d.ts +6 -0
- package/esm/markets/spark/marketAssets.js +9 -0
- package/esm/moneymarket/index.d.ts +1 -0
- package/esm/moneymarket/index.js +1 -0
- package/esm/moneymarket/moneymarketCommonService.d.ts +12 -0
- package/esm/moneymarket/moneymarketCommonService.js +70 -0
- package/esm/morphoAaveV2/index.d.ts +7 -0
- package/esm/morphoAaveV2/index.js +199 -0
- package/esm/morphoAaveV3/index.d.ts +7 -0
- package/esm/morphoAaveV3/index.js +432 -0
- package/esm/multicall/index.d.ts +3 -0
- package/esm/multicall/index.js +27 -0
- package/esm/services/dsrService.d.ts +3 -0
- package/esm/services/dsrService.js +21 -0
- package/esm/services/utils.d.ts +16 -0
- package/esm/services/utils.js +21 -0
- package/esm/spark/index.d.ts +34 -0
- package/esm/spark/index.js +326 -0
- package/esm/staking/index.d.ts +1 -0
- package/esm/staking/index.js +1 -0
- package/esm/staking/staking.d.ts +15 -0
- package/esm/staking/staking.js +147 -0
- package/esm/types/aave.d.ts +229 -0
- package/esm/types/aave.js +7 -0
- package/esm/types/common.d.ts +77 -0
- package/esm/types/common.js +7 -0
- package/esm/types/compound.d.ts +109 -0
- package/esm/types/compound.js +7 -0
- package/esm/types/contracts/generated/AaveLendingPoolV2.d.ts +312 -0
- package/esm/types/contracts/generated/AaveLendingPoolV2.js +4 -0
- package/esm/types/contracts/generated/AaveLoanInfoV2.d.ts +137 -0
- package/esm/types/contracts/generated/AaveLoanInfoV2.js +4 -0
- package/esm/types/contracts/generated/AaveProtocolDataProvider.d.ts +110 -0
- package/esm/types/contracts/generated/AaveProtocolDataProvider.js +4 -0
- package/esm/types/contracts/generated/AaveUiIncentiveDataProviderV3.d.ts +196 -0
- package/esm/types/contracts/generated/AaveUiIncentiveDataProviderV3.js +4 -0
- package/esm/types/contracts/generated/AaveV3LendingPool.d.ts +429 -0
- package/esm/types/contracts/generated/AaveV3LendingPool.js +4 -0
- package/esm/types/contracts/generated/AaveV3PoolAddressesProvider.d.ts +169 -0
- package/esm/types/contracts/generated/AaveV3PoolAddressesProvider.js +4 -0
- package/esm/types/contracts/generated/AaveV3ProtocolDataProvider.d.ts +131 -0
- package/esm/types/contracts/generated/AaveV3ProtocolDataProvider.js +4 -0
- package/esm/types/contracts/generated/AaveV3View.d.ts +301 -0
- package/esm/types/contracts/generated/AaveV3View.js +4 -0
- package/esm/types/contracts/generated/BalanceScanner.d.ts +37 -0
- package/esm/types/contracts/generated/BalanceScanner.js +4 -0
- package/esm/types/contracts/generated/CETHv3.d.ts +441 -0
- package/esm/types/contracts/generated/CETHv3.js +4 -0
- package/esm/types/contracts/generated/CUSDCv3.d.ts +441 -0
- package/esm/types/contracts/generated/CUSDCv3.js +4 -0
- package/esm/types/contracts/generated/CUSDbCv3.d.ts +441 -0
- package/esm/types/contracts/generated/CUSDbCv3.js +4 -0
- package/esm/types/contracts/generated/CbEth.d.ts +20 -0
- package/esm/types/contracts/generated/CbEth.js +4 -0
- package/esm/types/contracts/generated/ChickenBondsView.d.ts +67 -0
- package/esm/types/contracts/generated/ChickenBondsView.js +4 -0
- package/esm/types/contracts/generated/CollSurplusPool.d.ts +85 -0
- package/esm/types/contracts/generated/CollSurplusPool.js +4 -0
- package/esm/types/contracts/generated/CompV3ETHBulker.d.ts +45 -0
- package/esm/types/contracts/generated/CompV3ETHBulker.js +4 -0
- package/esm/types/contracts/generated/CompV3USDCBulker.d.ts +31 -0
- package/esm/types/contracts/generated/CompV3USDCBulker.js +4 -0
- package/esm/types/contracts/generated/CompV3USDbCBulker.d.ts +41 -0
- package/esm/types/contracts/generated/CompV3USDbCBulker.js +4 -0
- package/esm/types/contracts/generated/CompV3View.d.ts +249 -0
- package/esm/types/contracts/generated/CompV3View.js +4 -0
- package/esm/types/contracts/generated/CompoundLoanInfo.d.ts +128 -0
- package/esm/types/contracts/generated/CompoundLoanInfo.js +4 -0
- package/esm/types/contracts/generated/Comptroller.d.ts +317 -0
- package/esm/types/contracts/generated/Comptroller.js +4 -0
- package/esm/types/contracts/generated/CrvUSDETHAmm.d.ts +139 -0
- package/esm/types/contracts/generated/CrvUSDETHAmm.js +4 -0
- package/esm/types/contracts/generated/CrvUSDETHController.d.ts +204 -0
- package/esm/types/contracts/generated/CrvUSDETHController.js +4 -0
- package/esm/types/contracts/generated/CrvUSDFactory.d.ts +117 -0
- package/esm/types/contracts/generated/CrvUSDFactory.js +4 -0
- package/esm/types/contracts/generated/CrvUSDView.d.ts +209 -0
- package/esm/types/contracts/generated/CrvUSDView.js +4 -0
- package/esm/types/contracts/generated/CrvUSDWBTCAmm.d.ts +139 -0
- package/esm/types/contracts/generated/CrvUSDWBTCAmm.js +4 -0
- package/esm/types/contracts/generated/CrvUSDWBTCController.d.ts +204 -0
- package/esm/types/contracts/generated/CrvUSDWBTCController.js +4 -0
- package/esm/types/contracts/generated/CrvUSDwstETHAmm.d.ts +139 -0
- package/esm/types/contracts/generated/CrvUSDwstETHAmm.js +4 -0
- package/esm/types/contracts/generated/CrvUSDwstETHController.d.ts +204 -0
- package/esm/types/contracts/generated/CrvUSDwstETHController.js +4 -0
- package/esm/types/contracts/generated/Erc20.d.ts +119 -0
- package/esm/types/contracts/generated/Erc20.js +4 -0
- package/esm/types/contracts/generated/GHO.d.ts +136 -0
- package/esm/types/contracts/generated/GHO.js +4 -0
- package/esm/types/contracts/generated/GhoDiscountRateStrategy.d.ts +25 -0
- package/esm/types/contracts/generated/GhoDiscountRateStrategy.js +4 -0
- package/esm/types/contracts/generated/IAToken.d.ts +21 -0
- package/esm/types/contracts/generated/IAToken.js +4 -0
- package/esm/types/contracts/generated/IVariableDebtToken.d.ts +21 -0
- package/esm/types/contracts/generated/IVariableDebtToken.js +4 -0
- package/esm/types/contracts/generated/LendingPoolAddressesProvider.d.ts +135 -0
- package/esm/types/contracts/generated/LendingPoolAddressesProvider.js +4 -0
- package/esm/types/contracts/generated/Lido.d.ts +38 -0
- package/esm/types/contracts/generated/Lido.js +4 -0
- package/esm/types/contracts/generated/LiquityActivePool.d.ts +21 -0
- package/esm/types/contracts/generated/LiquityActivePool.js +4 -0
- package/esm/types/contracts/generated/LiquityView.d.ts +51 -0
- package/esm/types/contracts/generated/LiquityView.js +4 -0
- package/esm/types/contracts/generated/McdDog.d.ts +134 -0
- package/esm/types/contracts/generated/McdDog.js +4 -0
- package/esm/types/contracts/generated/McdJug.d.ts +50 -0
- package/esm/types/contracts/generated/McdJug.js +4 -0
- package/esm/types/contracts/generated/McdSpotter.d.ts +27 -0
- package/esm/types/contracts/generated/McdSpotter.js +4 -0
- package/esm/types/contracts/generated/McdVat.d.ts +78 -0
- package/esm/types/contracts/generated/McdVat.js +4 -0
- package/esm/types/contracts/generated/McdView.d.ts +61 -0
- package/esm/types/contracts/generated/McdView.js +4 -0
- package/esm/types/contracts/generated/MorphoAaveV2Proxy.d.ts +418 -0
- package/esm/types/contracts/generated/MorphoAaveV2Proxy.js +4 -0
- package/esm/types/contracts/generated/MorphoAaveV2View.d.ts +274 -0
- package/esm/types/contracts/generated/MorphoAaveV2View.js +4 -0
- package/esm/types/contracts/generated/MorphoAaveV3ProxyEthMarket.d.ts +202 -0
- package/esm/types/contracts/generated/MorphoAaveV3ProxyEthMarket.js +4 -0
- package/esm/types/contracts/generated/Pot.d.ts +49 -0
- package/esm/types/contracts/generated/Pot.js +4 -0
- package/esm/types/contracts/generated/PriceFeed.d.ts +61 -0
- package/esm/types/contracts/generated/PriceFeed.js +4 -0
- package/esm/types/contracts/generated/REth.d.ts +20 -0
- package/esm/types/contracts/generated/REth.js +4 -0
- package/esm/types/contracts/generated/SparkIncentiveDataProvider.d.ts +200 -0
- package/esm/types/contracts/generated/SparkIncentiveDataProvider.js +4 -0
- package/esm/types/contracts/generated/SparkLendingPool.d.ts +420 -0
- package/esm/types/contracts/generated/SparkLendingPool.js +4 -0
- package/esm/types/contracts/generated/SparkPoolAddressesProvider.d.ts +169 -0
- package/esm/types/contracts/generated/SparkPoolAddressesProvider.js +4 -0
- package/esm/types/contracts/generated/SparkProtocolDataProvider.d.ts +132 -0
- package/esm/types/contracts/generated/SparkProtocolDataProvider.js +4 -0
- package/esm/types/contracts/generated/SparkView.d.ts +300 -0
- package/esm/types/contracts/generated/SparkView.js +4 -0
- package/esm/types/contracts/generated/TroveManager.d.ts +346 -0
- package/esm/types/contracts/generated/TroveManager.js +4 -0
- package/esm/types/contracts/generated/UniMulticall.d.ts +55 -0
- package/esm/types/contracts/generated/UniMulticall.js +4 -0
- package/esm/types/contracts/generated/WstETH.d.ts +65 -0
- package/esm/types/contracts/generated/WstETH.js +4 -0
- package/esm/types/contracts/generated/index.d.ts +57 -0
- package/esm/types/contracts/generated/index.js +1 -0
- package/esm/types/contracts/generated/types.d.ts +54 -0
- package/esm/types/contracts/generated/types.js +1 -0
- package/esm/types/curveUsd.d.ts +101 -0
- package/esm/types/curveUsd.js +14 -0
- package/esm/types/index.d.ts +6 -0
- package/esm/types/index.js +6 -0
- package/esm/types/liquity.d.ts +28 -0
- package/esm/types/liquity.js +15 -0
- package/esm/types/maker.d.ts +49 -0
- package/esm/types/maker.js +1 -0
- package/esm/types/spark.d.ts +100 -0
- package/esm/types/spark.js +4 -0
- package/package.json +40 -0
- package/src/aaveV2/index.ts +219 -0
- package/src/aaveV3/index.ts +538 -0
- package/src/assets/index.ts +61 -0
- package/src/chickenBonds/index.ts +20 -0
- package/src/compoundV2/index.ts +207 -0
- package/src/compoundV3/index.ts +259 -0
- package/src/config/contracts.js +595 -0
- package/src/constants/index.ts +4 -0
- package/src/contracts.ts +95 -0
- package/src/curveUsd/index.ts +229 -0
- package/src/exchange/index.ts +17 -0
- package/src/helpers/aaveHelpers/index.ts +138 -0
- package/src/helpers/compoundHelpers/index.ts +178 -0
- package/src/helpers/curveUsdHelpers/index.ts +33 -0
- package/src/helpers/index.ts +5 -0
- package/src/helpers/makerHelpers/index.ts +95 -0
- package/src/helpers/sparkHelpers/index.ts +119 -0
- package/src/index.ts +40 -0
- package/src/liquity/index.ts +104 -0
- package/src/maker/index.ts +102 -0
- package/src/markets/aave/index.ts +80 -0
- package/src/markets/aave/marketAssets.ts +33 -0
- package/src/markets/compound/index.ts +86 -0
- package/src/markets/compound/marketsAssets.ts +36 -0
- package/src/markets/curveUsd/index.ts +43 -0
- package/src/markets/index.ts +4 -0
- package/src/markets/spark/index.ts +30 -0
- package/src/markets/spark/marketAssets.ts +10 -0
- package/src/moneymarket/index.ts +1 -0
- package/src/moneymarket/moneymarketCommonService.ts +76 -0
- package/src/morpho/markets.ts +39 -0
- package/src/morphoAaveV2/index.ts +253 -0
- package/src/morphoAaveV3/index.ts +615 -0
- package/src/multicall/index.ts +23 -0
- package/src/services/dsrService.ts +16 -0
- package/src/services/utils.ts +35 -0
- package/src/spark/index.ts +414 -0
- package/src/staking/index.ts +1 -0
- package/src/staking/staking.ts +157 -0
- package/src/types/aave.ts +256 -0
- package/src/types/common.ts +84 -0
- package/src/types/compound.ts +122 -0
- package/src/types/contracts/generated/AaveLendingPoolV2.ts +510 -0
- package/src/types/contracts/generated/AaveLoanInfoV2.ts +175 -0
- package/src/types/contracts/generated/AaveProtocolDataProvider.ts +152 -0
- package/src/types/contracts/generated/AaveUiIncentiveDataProviderV3.ts +254 -0
- package/src/types/contracts/generated/AaveV3LendingPool.ts +805 -0
- package/src/types/contracts/generated/AaveV3PoolAddressesProvider.ts +340 -0
- package/src/types/contracts/generated/AaveV3ProtocolDataProvider.ts +186 -0
- package/src/types/contracts/generated/AaveV3View.ts +402 -0
- package/src/types/contracts/generated/BalanceScanner.ts +71 -0
- package/src/types/contracts/generated/CETHv3.ts +685 -0
- package/src/types/contracts/generated/CUSDCv3.ts +688 -0
- package/src/types/contracts/generated/CUSDbCv3.ts +685 -0
- package/src/types/contracts/generated/CbEth.ts +37 -0
- package/src/types/contracts/generated/ChickenBondsView.ts +90 -0
- package/src/types/contracts/generated/CollSurplusPool.ts +185 -0
- package/src/types/contracts/generated/CompV3ETHBulker.ts +93 -0
- package/src/types/contracts/generated/CompV3USDCBulker.ts +63 -0
- package/src/types/contracts/generated/CompV3USDbCBulker.ts +85 -0
- package/src/types/contracts/generated/CompV3View.ts +325 -0
- package/src/types/contracts/generated/CompoundLoanInfo.ts +160 -0
- package/src/types/contracts/generated/Comptroller.ts +727 -0
- package/src/types/contracts/generated/CrvUSDETHAmm.ts +286 -0
- package/src/types/contracts/generated/CrvUSDETHController.ts +397 -0
- package/src/types/contracts/generated/CrvUSDFactory.ts +242 -0
- package/src/types/contracts/generated/CrvUSDView.ts +277 -0
- package/src/types/contracts/generated/CrvUSDWBTCAmm.ts +286 -0
- package/src/types/contracts/generated/CrvUSDWBTCController.ts +397 -0
- package/src/types/contracts/generated/CrvUSDwstETHAmm.ts +286 -0
- package/src/types/contracts/generated/CrvUSDwstETHController.ts +397 -0
- package/src/types/contracts/generated/Erc20.ts +216 -0
- package/src/types/contracts/generated/GHO.ts +274 -0
- package/src/types/contracts/generated/GhoDiscountRateStrategy.ts +48 -0
- package/src/types/contracts/generated/IAToken.ts +39 -0
- package/src/types/contracts/generated/IVariableDebtToken.ts +39 -0
- package/src/types/contracts/generated/LendingPoolAddressesProvider.ts +308 -0
- package/src/types/contracts/generated/Lido.ts +65 -0
- package/src/types/contracts/generated/LiquityActivePool.ts +39 -0
- package/src/types/contracts/generated/LiquityView.ts +66 -0
- package/src/types/contracts/generated/McdDog.ts +217 -0
- package/src/types/contracts/generated/McdJug.ts +86 -0
- package/src/types/contracts/generated/McdSpotter.ts +43 -0
- package/src/types/contracts/generated/McdVat.ts +170 -0
- package/src/types/contracts/generated/McdView.ts +100 -0
- package/src/types/contracts/generated/MorphoAaveV2Proxy.ts +870 -0
- package/src/types/contracts/generated/MorphoAaveV2View.ts +330 -0
- package/src/types/contracts/generated/MorphoAaveV3ProxyEthMarket.ts +338 -0
- package/src/types/contracts/generated/Pot.ts +88 -0
- package/src/types/contracts/generated/PriceFeed.ts +127 -0
- package/src/types/contracts/generated/REth.ts +37 -0
- package/src/types/contracts/generated/SparkIncentiveDataProvider.ts +264 -0
- package/src/types/contracts/generated/SparkLendingPool.ts +760 -0
- package/src/types/contracts/generated/SparkPoolAddressesProvider.ts +340 -0
- package/src/types/contracts/generated/SparkProtocolDataProvider.ts +188 -0
- package/src/types/contracts/generated/SparkView.ts +400 -0
- package/src/types/contracts/generated/TroveManager.ts +760 -0
- package/src/types/contracts/generated/UniMulticall.ts +83 -0
- package/src/types/contracts/generated/WstETH.ts +141 -0
- package/src/types/contracts/generated/index.ts +60 -0
- package/src/types/contracts/generated/types.ts +73 -0
- package/src/types/curveUsd.ts +111 -0
- package/src/types/index.ts +6 -0
- package/src/types/liquity.ts +30 -0
- package/src/types/maker.ts +51 -0
- package/src/types/spark.ts +107 -0
package/src/contracts.ts
ADDED
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import Web3 from 'web3';
|
|
2
|
+
import configRaw from './config/contracts';
|
|
3
|
+
import { BaseContract } from './types/contracts/generated/types';
|
|
4
|
+
import * as ContractTypes from './types/contracts/generated';
|
|
5
|
+
import { Blockish, EthAddress, NetworkNumber } from './types/common';
|
|
6
|
+
|
|
7
|
+
export type ConfigKey = keyof typeof configRaw;
|
|
8
|
+
|
|
9
|
+
declare type ContractConfig = {
|
|
10
|
+
abi: any[],
|
|
11
|
+
networks: Partial<Record<NetworkNumber, Network>>,
|
|
12
|
+
};
|
|
13
|
+
declare type Network = {
|
|
14
|
+
createdBlock?: number,
|
|
15
|
+
address: string,
|
|
16
|
+
oldVersions?: Record<string, EthAddress>,
|
|
17
|
+
};
|
|
18
|
+
const contractConfig:Record<ConfigKey, ContractConfig> = configRaw;
|
|
19
|
+
export const getConfigContractAddress = (name: ConfigKey, network: NetworkNumber, block?: Blockish): string => {
|
|
20
|
+
const networkData = contractConfig[name].networks[network];
|
|
21
|
+
const latestAddress = networkData?.address || '';
|
|
22
|
+
if (block && block !== 'latest') {
|
|
23
|
+
if (block >= (networkData?.createdBlock || 0)) {
|
|
24
|
+
return latestAddress;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
const oldVersions = networkData?.oldVersions || {};
|
|
28
|
+
for (const [createdBlock, address] of Object.entries(oldVersions).reverse()) {
|
|
29
|
+
if (block >= Number(createdBlock)) {
|
|
30
|
+
return address;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
return latestAddress;
|
|
35
|
+
};
|
|
36
|
+
export const getConfigContractAbi = (name: ConfigKey): any[] => contractConfig[name].abi;
|
|
37
|
+
|
|
38
|
+
const createContractFromConfigFunc = <T extends BaseContract>(name: ConfigKey, _address?: string) => (web3: Web3, network: NetworkNumber, block?: Blockish) => {
|
|
39
|
+
const address = _address || getConfigContractAddress(name, network, block);
|
|
40
|
+
return new web3.eth.Contract(contractConfig[name].abi, address) as any as T;
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
export const getErc20Contract = (address: string, web3: Web3) => (
|
|
44
|
+
new web3.eth.Contract(getConfigContractAbi('Erc20'), address)
|
|
45
|
+
);
|
|
46
|
+
|
|
47
|
+
export const createContractWrapper = (web3: Web3, network: NetworkNumber, name: ConfigKey, _address?: string, block?: Blockish) => (
|
|
48
|
+
createContractFromConfigFunc(name, _address)(web3, network, block)
|
|
49
|
+
);
|
|
50
|
+
|
|
51
|
+
export const UniMulticallContract = createContractFromConfigFunc<ContractTypes.UniMulticall>('UniMulticall');
|
|
52
|
+
|
|
53
|
+
export const AaveV3ViewContract = createContractFromConfigFunc<ContractTypes.AaveV3View>('AaveV3View');
|
|
54
|
+
export const AaveIncentiveDataProviderV3Contract = createContractFromConfigFunc<ContractTypes.AaveUiIncentiveDataProviderV3>('AaveUiIncentiveDataProviderV3');
|
|
55
|
+
|
|
56
|
+
export const GhoTokenContract = createContractFromConfigFunc<ContractTypes.GHO>('GHO');
|
|
57
|
+
|
|
58
|
+
export const LidoContract = createContractFromConfigFunc<ContractTypes.Lido>('Lido');
|
|
59
|
+
export const CbEthContract = createContractFromConfigFunc<ContractTypes.CbEth>('CbEth');
|
|
60
|
+
export const REthContract = createContractFromConfigFunc<ContractTypes.REth>('REth');
|
|
61
|
+
|
|
62
|
+
export const BalanceScannerContract = createContractFromConfigFunc<ContractTypes.BalanceScanner>('BalanceScanner');
|
|
63
|
+
|
|
64
|
+
export const CompV3ViewContract = createContractFromConfigFunc<ContractTypes.CompV3View>('CompV3View');
|
|
65
|
+
|
|
66
|
+
export const wstETHContract = createContractFromConfigFunc<ContractTypes.WstETH>('wstETH');
|
|
67
|
+
|
|
68
|
+
export const AaveLoanInfoV2Contract = createContractFromConfigFunc<ContractTypes.AaveLoanInfoV2>('AaveLoanInfoV2');
|
|
69
|
+
|
|
70
|
+
export const CompoundLoanInfoContract = createContractFromConfigFunc<ContractTypes.CompoundLoanInfo>('CompoundLoanInfo');
|
|
71
|
+
|
|
72
|
+
export const ComptrollerContract = createContractFromConfigFunc<ContractTypes.Comptroller>('Comptroller');
|
|
73
|
+
|
|
74
|
+
export const PotContract = createContractFromConfigFunc<ContractTypes.Pot>('Pot');
|
|
75
|
+
|
|
76
|
+
export const MorphoAaveV2ViewContract = createContractFromConfigFunc<ContractTypes.MorphoAaveV2View>('MorphoAaveV2View');
|
|
77
|
+
|
|
78
|
+
export const SparkIncentiveDataProviderContract = createContractFromConfigFunc<ContractTypes.SparkIncentiveDataProvider>('SparkIncentiveDataProvider');
|
|
79
|
+
export const SparkViewContract = createContractFromConfigFunc<ContractTypes.SparkView>('SparkView');
|
|
80
|
+
|
|
81
|
+
export const CrvUSDViewContract = createContractFromConfigFunc<ContractTypes.CrvUSDView>('crvUSDView');
|
|
82
|
+
export const CrvUSDFactoryContract = createContractFromConfigFunc<ContractTypes.CrvUSDFactory>('crvUSDFactory');
|
|
83
|
+
|
|
84
|
+
export const LiquityViewContract = createContractFromConfigFunc<ContractTypes.LiquityView>('LiquityView');
|
|
85
|
+
export const LiquityCollSurplusPoolContract = createContractFromConfigFunc<ContractTypes.CollSurplusPool>('CollSurplusPool');
|
|
86
|
+
export const LiquityTroveManagerContract = createContractFromConfigFunc<ContractTypes.TroveManager>('TroveManager');
|
|
87
|
+
export const LiquityPriceFeedContract = createContractFromConfigFunc<ContractTypes.PriceFeed>('PriceFeed');
|
|
88
|
+
export const LiquityActivePoolContract = createContractFromConfigFunc<ContractTypes.LiquityActivePool>('LiquityActivePool');
|
|
89
|
+
|
|
90
|
+
export const McdViewContract = createContractFromConfigFunc<ContractTypes.McdView>('McdView');
|
|
91
|
+
export const McdSpotterContract = createContractFromConfigFunc<ContractTypes.McdSpotter>('McdSpotter');
|
|
92
|
+
export const McdDogContract = createContractFromConfigFunc<ContractTypes.McdDog>('McdDog');
|
|
93
|
+
export const McdJugContract = createContractFromConfigFunc<ContractTypes.McdJug>('McdJug');
|
|
94
|
+
export const McdVatContract = createContractFromConfigFunc<ContractTypes.McdVat>('McdVat');
|
|
95
|
+
export const ChickenBondsViewContract = createContractFromConfigFunc<ContractTypes.ChickenBondsView>('ChickenBondsView');
|
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
import Dec from 'decimal.js';
|
|
2
|
+
import { assetAmountInEth, getAssetInfo } from '@defisaver/tokens';
|
|
3
|
+
import Web3 from 'web3';
|
|
4
|
+
import {
|
|
5
|
+
BandData, CrvUSDGlobalMarketData, CrvUSDMarketData, CrvUSDStatus, CrvUSDUsedAssets, CrvUSDUserData, CrvUSDVersions,
|
|
6
|
+
} from '../types';
|
|
7
|
+
import { multicall } from '../multicall';
|
|
8
|
+
import {
|
|
9
|
+
Blockish, EthAddress, NetworkNumber, PositionBalances,
|
|
10
|
+
} from '../types/common';
|
|
11
|
+
import { CrvUSDFactoryContract, CrvUSDViewContract } from '../contracts';
|
|
12
|
+
import { getCrvUsdAggregatedData } from '../helpers/curveUsdHelpers';
|
|
13
|
+
import { CrvUsdMarkets } from '../markets';
|
|
14
|
+
import { wethToEth } from '../services/utils';
|
|
15
|
+
|
|
16
|
+
const getAndFormatBands = async (web3: Web3, network: NetworkNumber, selectedMarket: CrvUSDMarketData, _minBand: string, _maxBand: string) => {
|
|
17
|
+
const contract = CrvUSDViewContract(web3, network);
|
|
18
|
+
const minBand = parseInt(_minBand, 10);
|
|
19
|
+
const maxBand = parseInt(_maxBand, 10);
|
|
20
|
+
const pivots: number[] = [];
|
|
21
|
+
|
|
22
|
+
// getBandsData uses a lot of gas to get all of the bands at once, so we use pagination and fetch 200 bands at a time
|
|
23
|
+
let i = minBand;
|
|
24
|
+
while (i < maxBand) {
|
|
25
|
+
i += 200;
|
|
26
|
+
if (i > maxBand) {
|
|
27
|
+
pivots.push(maxBand);
|
|
28
|
+
} else {
|
|
29
|
+
pivots.push(i);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
const bandsData = (await Promise.all(pivots.map(async (pivot, index) => {
|
|
34
|
+
let start = 0;
|
|
35
|
+
if (index === 0) {
|
|
36
|
+
start = minBand;
|
|
37
|
+
} else {
|
|
38
|
+
start = pivots[index - 1] + 1;
|
|
39
|
+
}
|
|
40
|
+
// @ts-ignore
|
|
41
|
+
const pivotedBandsData = await contract.methods.getBandsData(selectedMarket.controllerAddress, start, pivot).call();
|
|
42
|
+
return pivotedBandsData;
|
|
43
|
+
}))).flat();
|
|
44
|
+
|
|
45
|
+
return bandsData.map((band: BandData) => ({
|
|
46
|
+
id: band.id,
|
|
47
|
+
collAmount: assetAmountInEth(band.collAmount),
|
|
48
|
+
debtAmount: assetAmountInEth(band.debtAmount),
|
|
49
|
+
lowPrice: assetAmountInEth(band.lowPrice),
|
|
50
|
+
highPrice: assetAmountInEth(band.highPrice),
|
|
51
|
+
}));
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
export const getCurveUsdGlobalData = async (web3: Web3, network: NetworkNumber, selectedMarket: CrvUSDMarketData): Promise<CrvUSDGlobalMarketData> => {
|
|
55
|
+
const contract = CrvUSDViewContract(web3, network);
|
|
56
|
+
const factoryContract = CrvUSDFactoryContract(web3, network);
|
|
57
|
+
const collAsset = selectedMarket.collAsset;
|
|
58
|
+
const debtAsset = selectedMarket.baseAsset;
|
|
59
|
+
|
|
60
|
+
const multicallData = [
|
|
61
|
+
{
|
|
62
|
+
target: factoryContract.options.address,
|
|
63
|
+
abiItem: factoryContract.options.jsonInterface.find(({ name }) => name === 'debt_ceiling'),
|
|
64
|
+
params: [selectedMarket.controllerAddress],
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
target: factoryContract.options.address,
|
|
68
|
+
abiItem: factoryContract.options.jsonInterface.find(({ name }) => name === 'total_debt'),
|
|
69
|
+
params: [],
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
target: contract.options.address,
|
|
73
|
+
abiItem: contract.options.jsonInterface.find(({ name }) => name === 'globalData'),
|
|
74
|
+
params: [selectedMarket.controllerAddress],
|
|
75
|
+
},
|
|
76
|
+
];
|
|
77
|
+
const multiRes = await multicall(multicallData, web3, network);
|
|
78
|
+
const data = multiRes[2][0];
|
|
79
|
+
const debtCeiling = assetAmountInEth(multiRes[0][0], debtAsset);
|
|
80
|
+
|
|
81
|
+
// all prices are in 18 decimals
|
|
82
|
+
const totalDebt = assetAmountInEth(data.totalDebt, debtAsset);
|
|
83
|
+
const ammPrice = assetAmountInEth(data.ammPrice, debtAsset);
|
|
84
|
+
|
|
85
|
+
const rate = assetAmountInEth(data.ammRate);
|
|
86
|
+
const futureRate = assetAmountInEth(data.monetaryPolicyRate);
|
|
87
|
+
|
|
88
|
+
const exponentRate = new Dec(rate).mul(365).mul(86400);
|
|
89
|
+
const exponentFutureRate = new Dec(futureRate).mul(365).mul(86400);
|
|
90
|
+
const borrowRate = new Dec(new Dec(2.718281828459).pow(exponentRate).minus(1)).mul(100)
|
|
91
|
+
.toString();
|
|
92
|
+
const futureBorrowRate = new Dec(new Dec(2.718281828459).pow(exponentFutureRate).minus(1)).mul(100)
|
|
93
|
+
.toString();
|
|
94
|
+
|
|
95
|
+
const bandsData = await getAndFormatBands(web3, network, selectedMarket, data.minBand, data.maxBand);
|
|
96
|
+
|
|
97
|
+
const leftToBorrow = new Dec(debtCeiling).minus(totalDebt).toString();
|
|
98
|
+
return {
|
|
99
|
+
...data,
|
|
100
|
+
debtCeiling,
|
|
101
|
+
totalDebt,
|
|
102
|
+
ammPrice,
|
|
103
|
+
oraclePrice: assetAmountInEth(data.oraclePrice, debtAsset),
|
|
104
|
+
basePrice: assetAmountInEth(data.basePrice, debtAsset),
|
|
105
|
+
minted: assetAmountInEth(data.minted, debtAsset),
|
|
106
|
+
redeemed: assetAmountInEth(data.redeemed, debtAsset),
|
|
107
|
+
borrowRate,
|
|
108
|
+
futureBorrowRate,
|
|
109
|
+
bands: bandsData,
|
|
110
|
+
leftToBorrow,
|
|
111
|
+
};
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
const getStatusForUser = (bandRange: string[], activeBand: string, crvUSDSupplied: string, collSupplied: string) => {
|
|
115
|
+
// if bands are equal, that can only be [0,0] which means user doesn't have loan (min number of bands is 4)
|
|
116
|
+
if (new Dec(bandRange[0]).eq(bandRange[1])) return CrvUSDStatus.Nonexistant;
|
|
117
|
+
// if user doesn't have crvUSD as collateral, then his position is not in soft liquidation
|
|
118
|
+
if (new Dec(crvUSDSupplied).lte(0)) {
|
|
119
|
+
if (new Dec(bandRange[0]).minus(activeBand).lte(3)) return CrvUSDStatus.Risk; // if user band is less than 3 bands away from active band, his position is at risk
|
|
120
|
+
return CrvUSDStatus.Safe;
|
|
121
|
+
}
|
|
122
|
+
if (new Dec(bandRange[0]).lte(activeBand) && new Dec(bandRange[1]).gte(activeBand)) return CrvUSDStatus.SoftLiquidating; // user has crvUSD as coll so he is in soft liquidation
|
|
123
|
+
if (new Dec(collSupplied).lte(0) || new Dec(bandRange[1]).lte(activeBand)) return CrvUSDStatus.SoftLiquidated; // or is fully soft liquidated
|
|
124
|
+
return CrvUSDStatus.Nonexistant;
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
export const getCrvUsdAccountBalances = async (web3: Web3, network: NetworkNumber, block: Blockish, addressMapping: boolean, address: EthAddress, crvUsdVersion: CrvUSDVersions): Promise<PositionBalances> => {
|
|
128
|
+
let balances: PositionBalances = {
|
|
129
|
+
collateral: {},
|
|
130
|
+
debt: {},
|
|
131
|
+
};
|
|
132
|
+
|
|
133
|
+
if (!address) {
|
|
134
|
+
return balances;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
const contract = CrvUSDViewContract(web3, network, block);
|
|
138
|
+
const selectedMarket = CrvUsdMarkets(network)[crvUsdVersion];
|
|
139
|
+
|
|
140
|
+
const data = await contract.methods.userData(selectedMarket.controllerAddress, address).call({}, block);
|
|
141
|
+
|
|
142
|
+
balances = {
|
|
143
|
+
collateral: {
|
|
144
|
+
[addressMapping ? getAssetInfo(wethToEth(selectedMarket.collAsset), network).address.toLowerCase() : wethToEth(selectedMarket.collAsset)]: data.marketCollateralAmount,
|
|
145
|
+
},
|
|
146
|
+
debt: {
|
|
147
|
+
[addressMapping ? getAssetInfo(wethToEth(selectedMarket.baseAsset), network).address.toLowerCase() : wethToEth(selectedMarket.baseAsset)]: data.debtAmount,
|
|
148
|
+
},
|
|
149
|
+
};
|
|
150
|
+
|
|
151
|
+
return balances;
|
|
152
|
+
};
|
|
153
|
+
|
|
154
|
+
export const getCurveUsdUserData = async (web3: Web3, network: NetworkNumber, address: string, selectedMarket: CrvUSDMarketData, activeBand: string): Promise<CrvUSDUserData> => {
|
|
155
|
+
const contract = CrvUSDViewContract(web3, network);
|
|
156
|
+
|
|
157
|
+
const data = await contract.methods.userData(selectedMarket.controllerAddress, address).call();
|
|
158
|
+
const collAsset = selectedMarket.collAsset;
|
|
159
|
+
const debtAsset = selectedMarket.baseAsset;
|
|
160
|
+
|
|
161
|
+
const health = assetAmountInEth(data.health);
|
|
162
|
+
const healthPercent = new Dec(health).mul(100).toString();
|
|
163
|
+
const collPrice = assetAmountInEth(data.collateralPrice, debtAsset);
|
|
164
|
+
const collSupplied = assetAmountInEth(data.marketCollateralAmount, collAsset);
|
|
165
|
+
const collSuppliedUsd = new Dec(collSupplied).mul(collPrice).toString();
|
|
166
|
+
const crvUSDSupplied = assetAmountInEth(data.curveUsdCollateralAmount, debtAsset);
|
|
167
|
+
const debtBorrowed = assetAmountInEth(data.debtAmount, debtAsset);
|
|
168
|
+
const usedAssets: CrvUSDUsedAssets = data.loanExists ? {
|
|
169
|
+
[collAsset]: {
|
|
170
|
+
isSupplied: true,
|
|
171
|
+
supplied: collSupplied,
|
|
172
|
+
suppliedUsd: collSuppliedUsd, // need oracle price, or amm price
|
|
173
|
+
borrowed: '0',
|
|
174
|
+
borrowedUsd: '0',
|
|
175
|
+
isBorrowed: false,
|
|
176
|
+
symbol: collAsset,
|
|
177
|
+
collateral: true,
|
|
178
|
+
price: collPrice, // price_amm
|
|
179
|
+
},
|
|
180
|
+
[debtAsset]: {
|
|
181
|
+
isSupplied: new Dec(crvUSDSupplied).gt('0'),
|
|
182
|
+
collateral: new Dec(crvUSDSupplied).gt('0'),
|
|
183
|
+
supplied: crvUSDSupplied,
|
|
184
|
+
suppliedUsd: crvUSDSupplied,
|
|
185
|
+
borrowed: debtBorrowed,
|
|
186
|
+
borrowedUsd: debtBorrowed,
|
|
187
|
+
isBorrowed: new Dec(debtBorrowed).gt('0'),
|
|
188
|
+
symbol: 'crvUSD',
|
|
189
|
+
price: '1',
|
|
190
|
+
interestRate: '0',
|
|
191
|
+
},
|
|
192
|
+
} : {};
|
|
193
|
+
|
|
194
|
+
const priceHigh = assetAmountInEth(data.priceHigh);
|
|
195
|
+
const priceLow = assetAmountInEth(data.priceLow);
|
|
196
|
+
|
|
197
|
+
const _userBands = data.loanExists ? (await getAndFormatBands(web3, network, selectedMarket, data.bandRange[0], data.bandRange[1])) : [];
|
|
198
|
+
|
|
199
|
+
const status = data.loanExists ? getStatusForUser(data.bandRange, activeBand, crvUSDSupplied, collSupplied) : CrvUSDStatus.Nonexistant;
|
|
200
|
+
|
|
201
|
+
const userBands = _userBands.map((band, index) => ({
|
|
202
|
+
...band,
|
|
203
|
+
userDebtAmount: assetAmountInEth(data.usersBands[0][index], debtAsset),
|
|
204
|
+
userCollAmount: assetAmountInEth(data.usersBands[1][index], collAsset),
|
|
205
|
+
})).sort((a, b) => parseInt(b.id, 10) - parseInt(a.id, 10));
|
|
206
|
+
|
|
207
|
+
return {
|
|
208
|
+
...data,
|
|
209
|
+
debtAmount: assetAmountInEth(data.debtAmount, debtAsset),
|
|
210
|
+
health,
|
|
211
|
+
healthPercent,
|
|
212
|
+
priceHigh,
|
|
213
|
+
priceLow,
|
|
214
|
+
liquidationDiscount: assetAmountInEth(data.liquidationDiscount),
|
|
215
|
+
numOfBands: data.N,
|
|
216
|
+
usedAssets,
|
|
217
|
+
status,
|
|
218
|
+
...getCrvUsdAggregatedData({
|
|
219
|
+
loanExists: data.loanExists, usedAssets, network: NetworkNumber.Eth, selectedMarket,
|
|
220
|
+
}),
|
|
221
|
+
userBands,
|
|
222
|
+
};
|
|
223
|
+
};
|
|
224
|
+
|
|
225
|
+
export const getCurveUsdFullPositionData = async (web3: Web3, network: NetworkNumber, address: string, selectedMarket: CrvUSDMarketData): Promise<CrvUSDUserData> => {
|
|
226
|
+
const marketData = await getCurveUsdGlobalData(web3, network, selectedMarket);
|
|
227
|
+
const positionData = await getCurveUsdUserData(web3, network, address, selectedMarket, marketData.activeBand);
|
|
228
|
+
return positionData;
|
|
229
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import Web3 from 'web3';
|
|
2
|
+
|
|
3
|
+
import { assetAmountInWei, getAssetInfoByAddress } from '@defisaver/tokens';
|
|
4
|
+
import {
|
|
5
|
+
Blockish, NetworkNumber, PositionBalances,
|
|
6
|
+
} from '../types/common';
|
|
7
|
+
import { wethToEthByAddress } from '../services/utils';
|
|
8
|
+
|
|
9
|
+
export const getExchangeAccountBalances = async (web3: Web3, network: NetworkNumber, block: Blockish, addressMapping: boolean, subData: any): Promise<PositionBalances> => {
|
|
10
|
+
const fromToken = getAssetInfoByAddress(wethToEthByAddress(subData.fromToken, network), network);
|
|
11
|
+
|
|
12
|
+
return {
|
|
13
|
+
selling: {
|
|
14
|
+
[addressMapping ? fromToken.address.toLowerCase() : fromToken.symbol]: assetAmountInWei(subData.amount, fromToken.symbol),
|
|
15
|
+
},
|
|
16
|
+
};
|
|
17
|
+
};
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import Dec from 'decimal.js';
|
|
2
|
+
import {
|
|
3
|
+
AaveAssetData, AaveHelperCommon, AaveMarketInfo, AaveV3AggregatedPositionData, AaveV3AssetsData, AaveV3UsedAssets, AaveVersions,
|
|
4
|
+
} from '../../types';
|
|
5
|
+
import { wethToEth } from '../../services/utils';
|
|
6
|
+
import { calcLeverageLiqPrice, getAssetsTotal, isLeveragedPos } from '../../moneymarket';
|
|
7
|
+
import { calculateNetApy } from '../../staking';
|
|
8
|
+
|
|
9
|
+
export const isAaveV3 = ({ selectedMarket }: { selectedMarket: Partial<AaveMarketInfo> }) => selectedMarket.value === AaveVersions.AaveV3;
|
|
10
|
+
export const isMorphoAaveV2 = ({ selectedMarket }: { selectedMarket: Partial<AaveMarketInfo> }) => selectedMarket.value === AaveVersions.MorphoAaveV2;
|
|
11
|
+
export const isMorphoAaveV3 = ({ selectedMarket }: { selectedMarket: Partial<AaveMarketInfo> }) => selectedMarket.value === AaveVersions.MorphoAaveV3Eth;
|
|
12
|
+
export const isMorphoAave = ({ selectedMarket }: { selectedMarket: Partial<AaveMarketInfo> }) => isMorphoAaveV2({ selectedMarket }) || isMorphoAaveV3({ selectedMarket });
|
|
13
|
+
|
|
14
|
+
export const aaveV3IsInIsolationMode = ({ usedAssets, assetsData }: { usedAssets: AaveV3UsedAssets, assetsData: AaveV3AssetsData }) => Object.values(usedAssets).some(({ symbol, collateral }) => collateral && assetsData[symbol].isIsolated);
|
|
15
|
+
export const aaveV3IsInSiloedMode = ({ usedAssets, assetsData }: { usedAssets: AaveV3UsedAssets, assetsData: AaveV3AssetsData }) => Object.values(usedAssets).some(({ symbol, debt }) => debt && assetsData[symbol].isSiloed);
|
|
16
|
+
|
|
17
|
+
export const aaveAnyGetCollSuppliedAssets = ({ usedAssets }: { usedAssets: AaveV3UsedAssets }) => Object.values(usedAssets)
|
|
18
|
+
.filter(({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral);
|
|
19
|
+
|
|
20
|
+
export const aaveAnyGetSuppliableAssets = ({
|
|
21
|
+
usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest
|
|
22
|
+
}: AaveHelperCommon) => {
|
|
23
|
+
const data = {
|
|
24
|
+
usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest,
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
const collAccountAssets = aaveAnyGetCollSuppliedAssets(data);
|
|
28
|
+
const marketAssets = Object.values(assetsData) as AaveAssetData[];
|
|
29
|
+
|
|
30
|
+
if (isMorphoAave({ selectedMarket })) {
|
|
31
|
+
return marketAssets.filter(({ canBeSupplied }) => canBeSupplied,
|
|
32
|
+
).map(a => ({ ...a, canBeCollateral: new Dec(assetsData[a.symbol].collateralFactor).gt(0) }));
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
if (collAccountAssets.length === 0 || !isAaveV3(data)) return marketAssets.filter(({ canBeSupplied }) => canBeSupplied).map(({ symbol }) => ({ symbol, canBeCollateral: true }));
|
|
36
|
+
|
|
37
|
+
if (aaveV3IsInIsolationMode(data)) {
|
|
38
|
+
const collAsset = collAccountAssets[0].symbol;
|
|
39
|
+
return marketAssets.filter(d => d.canBeSupplied).map(({ symbol }) => ({ symbol, canBeCollateral: symbol === collAsset }));
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
return marketAssets.filter(d => d.canBeSupplied).map(({ symbol, isIsolated }) => ({ symbol, canBeCollateral: !isIsolated }));
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
export const aaveAnyGetSuppliableAsCollAssets = ({
|
|
46
|
+
usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest
|
|
47
|
+
}: AaveHelperCommon) => aaveAnyGetSuppliableAssets({
|
|
48
|
+
usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest,
|
|
49
|
+
}).filter(({ canBeCollateral }) => canBeCollateral);
|
|
50
|
+
|
|
51
|
+
export const aaveAnyGetEmodeMutableProps = (
|
|
52
|
+
{
|
|
53
|
+
usedAssets,
|
|
54
|
+
eModeCategory,
|
|
55
|
+
eModeCategories,
|
|
56
|
+
assetsData,
|
|
57
|
+
selectedMarket,
|
|
58
|
+
network,
|
|
59
|
+
...rest
|
|
60
|
+
}: AaveHelperCommon, _asset: string) => {
|
|
61
|
+
const data = {
|
|
62
|
+
usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest,
|
|
63
|
+
};
|
|
64
|
+
const asset = wethToEth(_asset);
|
|
65
|
+
const canSupplyAsColl = aaveAnyGetSuppliableAsCollAssets(data).some(({ symbol }: { symbol: string }) => symbol === asset);
|
|
66
|
+
|
|
67
|
+
// TODO remove dirty fix for Morpho V2
|
|
68
|
+
if (isMorphoAaveV2({ selectedMarket }) && !canSupplyAsColl) {
|
|
69
|
+
const { liquidationRatio, collateralFactor } = assetsData[asset];
|
|
70
|
+
return ({ liquidationRatio, collateralFactor });
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
if (!canSupplyAsColl) {
|
|
74
|
+
return ({ liquidationRatio: '0', collateralFactor: '0' });
|
|
75
|
+
}
|
|
76
|
+
const assetData = assetsData[asset];
|
|
77
|
+
if (
|
|
78
|
+
eModeCategory === 0
|
|
79
|
+
|| assetData.eModeCategory !== eModeCategory
|
|
80
|
+
|| new Dec(assetData?.eModeCategoryData?.collateralFactor || 0).eq(0)
|
|
81
|
+
) {
|
|
82
|
+
const { liquidationRatio, collateralFactor } = assetData;
|
|
83
|
+
return ({ liquidationRatio, collateralFactor });
|
|
84
|
+
}
|
|
85
|
+
const { liquidationRatio, collateralFactor } = assetData.eModeCategoryData;
|
|
86
|
+
return ({ liquidationRatio, collateralFactor });
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
export const aaveAnyGetAggregatedPositionData = ({
|
|
90
|
+
usedAssets,
|
|
91
|
+
eModeCategory,
|
|
92
|
+
eModeCategories,
|
|
93
|
+
assetsData,
|
|
94
|
+
selectedMarket,
|
|
95
|
+
network,
|
|
96
|
+
...rest
|
|
97
|
+
}: AaveHelperCommon): AaveV3AggregatedPositionData => {
|
|
98
|
+
const data = {
|
|
99
|
+
usedAssets, eModeCategory, eModeCategories, assetsData, selectedMarket, network, ...rest,
|
|
100
|
+
};
|
|
101
|
+
const payload = {} as AaveV3AggregatedPositionData;
|
|
102
|
+
payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
|
|
103
|
+
payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: string }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
|
|
104
|
+
payload.borrowLimitUsd = getAssetsTotal(
|
|
105
|
+
usedAssets,
|
|
106
|
+
({ isSupplied, collateral }: { isSupplied: boolean, collateral: string }) => isSupplied && collateral,
|
|
107
|
+
({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(aaveAnyGetEmodeMutableProps(data, symbol).collateralFactor),
|
|
108
|
+
);
|
|
109
|
+
payload.liquidationLimitUsd = getAssetsTotal(
|
|
110
|
+
usedAssets,
|
|
111
|
+
({ isSupplied, collateral }: { isSupplied: boolean, collateral: string }) => isSupplied && collateral,
|
|
112
|
+
({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(aaveAnyGetEmodeMutableProps(data, symbol).liquidationRatio),
|
|
113
|
+
);
|
|
114
|
+
payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
|
|
115
|
+
const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd);
|
|
116
|
+
payload.leftToBorrowUsd = leftToBorrowUsd.lte('0') ? '0' : leftToBorrowUsd.toString();
|
|
117
|
+
payload.ratio = +payload.suppliedUsd ? new Dec(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
|
|
118
|
+
payload.collRatio = +payload.suppliedUsd ? new Dec(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
|
|
119
|
+
const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData, isMorphoAave({ selectedMarket }));
|
|
120
|
+
payload.netApy = netApy;
|
|
121
|
+
payload.incentiveUsd = incentiveUsd;
|
|
122
|
+
payload.totalInterestUsd = totalInterestUsd;
|
|
123
|
+
payload.liqRatio = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).toString();
|
|
124
|
+
payload.liqPercent = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).mul(100).toString();
|
|
125
|
+
const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets);
|
|
126
|
+
payload.leveragedType = leveragedType;
|
|
127
|
+
if (leveragedType !== '') {
|
|
128
|
+
payload.leveragedAsset = leveragedAsset;
|
|
129
|
+
let assetPrice = data.assetsData[leveragedAsset].price;
|
|
130
|
+
if (leveragedType === 'lsd-leverage') {
|
|
131
|
+
// Treat ETH like a stablecoin in a long stETH position
|
|
132
|
+
payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toDP(18).toString();
|
|
133
|
+
assetPrice = new Dec(assetPrice).div(assetsData.ETH.price).toString();
|
|
134
|
+
}
|
|
135
|
+
payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
|
|
136
|
+
}
|
|
137
|
+
return payload;
|
|
138
|
+
};
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
import Dec from 'decimal.js';
|
|
2
|
+
import { getAssetInfoByAddress } from '@defisaver/tokens';
|
|
3
|
+
import {
|
|
4
|
+
BaseAdditionalAssetData, CompoundAggregatedPositionData, CompoundMarketData, CompoundV2AssetsData, CompoundV2UsedAssets, CompoundV3AssetData, CompoundV3AssetsData, CompoundV3UsedAssets, CompoundVersions,
|
|
5
|
+
} from '../../types';
|
|
6
|
+
import { getEthAmountForDecimals, handleWbtcLegacy, wethToEth } from '../../services/utils';
|
|
7
|
+
import { SECONDS_PER_YEAR } from '../../constants';
|
|
8
|
+
import {
|
|
9
|
+
aprToApy, calcLeverageLiqPrice, calculateBorrowingAssetLimit, getAssetsTotal, isLeveragedPos,
|
|
10
|
+
} from '../../moneymarket';
|
|
11
|
+
import { calculateNetApy } from '../../staking';
|
|
12
|
+
import { NetworkNumber } from '../../types/common';
|
|
13
|
+
|
|
14
|
+
export const formatMarketData = (data: any, network: NetworkNumber): CompoundV3AssetData => {
|
|
15
|
+
const assetInfo = getAssetInfoByAddress(data.tokenAddr, network);
|
|
16
|
+
const isWETH = assetInfo.symbol === 'WETH';
|
|
17
|
+
return ({
|
|
18
|
+
...data,
|
|
19
|
+
price: getEthAmountForDecimals(data.price, 8),
|
|
20
|
+
collateralFactor: getEthAmountForDecimals(data.borrowCollateralFactor, 18),
|
|
21
|
+
liquidationRatio: getEthAmountForDecimals(data.liquidateCollateralFactor, 18),
|
|
22
|
+
supplyCap: getEthAmountForDecimals(data.supplyCap, assetInfo.decimals),
|
|
23
|
+
totalSupply: getEthAmountForDecimals(data.totalSupply, assetInfo.decimals),
|
|
24
|
+
symbol: isWETH ? 'ETH' : assetInfo.symbol,
|
|
25
|
+
supplyRate: '0',
|
|
26
|
+
borrowRate: '0',
|
|
27
|
+
canBeBorrowed: false,
|
|
28
|
+
canBeSupplied: true,
|
|
29
|
+
});
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
// TODO: maybe not hardcode decimals
|
|
33
|
+
export const formatBaseData = (data: any, network: NetworkNumber): CompoundV3AssetData & BaseAdditionalAssetData => {
|
|
34
|
+
const assetInfo = getAssetInfoByAddress(data.tokenAddr, network);
|
|
35
|
+
const totalSupply = getEthAmountForDecimals(new Dec(data.totalSupply).mul(data.supplyIndex).toString(), 15 + assetInfo.decimals);
|
|
36
|
+
const totalBorrow = getEthAmountForDecimals(new Dec(data.totalBorrow).mul(data.borrowIndex).toString(), 15 + assetInfo.decimals);
|
|
37
|
+
return ({
|
|
38
|
+
...data,
|
|
39
|
+
supplyRate: aprToApy(new Dec(data.supplyRate).div(1e18).mul(SECONDS_PER_YEAR).mul(100)
|
|
40
|
+
.toString()),
|
|
41
|
+
borrowRate: aprToApy(new Dec(data.borrowRate).div(1e18).mul(SECONDS_PER_YEAR).mul(100)
|
|
42
|
+
.toString()),
|
|
43
|
+
utilization: getEthAmountForDecimals(data.utilization, 16), // utilization is totalSupply/totalBorrow in 1e18, but we need % so when we mul with 100 it's 16 decimals
|
|
44
|
+
totalSupply,
|
|
45
|
+
totalBorrow,
|
|
46
|
+
marketLiquidity: new Dec(totalSupply).minus(totalBorrow).toString(),
|
|
47
|
+
symbol: wethToEth(assetInfo.symbol),
|
|
48
|
+
price: getEthAmountForDecimals(data.price, 8),
|
|
49
|
+
collateralFactor: '0',
|
|
50
|
+
liquidationRatio: '0',
|
|
51
|
+
canBeBorrowed: true,
|
|
52
|
+
canBeSupplied: true,
|
|
53
|
+
supplyCap: '0',
|
|
54
|
+
rewardSupplySpeed: getEthAmountForDecimals(data.baseTrackingSupplyRewardsSpeed, 15),
|
|
55
|
+
rewardBorrowSpeed: getEthAmountForDecimals(data.baseTrackingBorrowRewardsSpeed, 15),
|
|
56
|
+
minDebt: getEthAmountForDecimals(data.baseBorrowMin, assetInfo.decimals),
|
|
57
|
+
isBase: true,
|
|
58
|
+
});
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
export const getIncentiveApys = (
|
|
62
|
+
baseData: CompoundV3AssetData & BaseAdditionalAssetData,
|
|
63
|
+
compPrice: string,
|
|
64
|
+
): {
|
|
65
|
+
incentiveSupplyApy: string,
|
|
66
|
+
incentiveBorrowApy: string,
|
|
67
|
+
incentiveSupplyToken: string,
|
|
68
|
+
incentiveBorrowToken: string,
|
|
69
|
+
} => {
|
|
70
|
+
const incentiveSupplyApy = aprToApy((100 * SECONDS_PER_YEAR * +baseData.rewardSupplySpeed * +compPrice) / +baseData.price / +baseData.totalSupply).toString();
|
|
71
|
+
const incentiveBorrowApy = aprToApy((100 * SECONDS_PER_YEAR * +baseData.rewardBorrowSpeed * +compPrice) / +baseData.price / +baseData.totalBorrow).toString();
|
|
72
|
+
return {
|
|
73
|
+
incentiveSupplyApy,
|
|
74
|
+
incentiveBorrowApy,
|
|
75
|
+
incentiveSupplyToken: 'COMP',
|
|
76
|
+
incentiveBorrowToken: 'COMP',
|
|
77
|
+
};
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
export const getCompoundV2AggregatedData = ({
|
|
81
|
+
usedAssets, assetsData, ...rest
|
|
82
|
+
}: { usedAssets: CompoundV2UsedAssets, assetsData: CompoundV2AssetsData }) => {
|
|
83
|
+
const payload = {} as CompoundAggregatedPositionData;
|
|
84
|
+
payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
|
|
85
|
+
payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
|
|
86
|
+
payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
|
|
87
|
+
payload.borrowLimitUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(assetsData[symbol].collateralFactor));
|
|
88
|
+
|
|
89
|
+
const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd).toString();
|
|
90
|
+
|
|
91
|
+
payload.leftToBorrowUsd = leftToBorrowUsd;
|
|
92
|
+
payload.borrowLimitUsd = new Dec(leftToBorrowUsd).add(payload.borrowedUsd).toString();
|
|
93
|
+
|
|
94
|
+
payload.liquidationLimitUsd = payload.borrowLimitUsd;
|
|
95
|
+
payload.ratio = payload.borrowedUsd && payload.borrowedUsd !== '0'
|
|
96
|
+
? new Dec(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString()
|
|
97
|
+
: '0';
|
|
98
|
+
payload.minRatio = '100';
|
|
99
|
+
payload.collRatio = payload.borrowedUsd && payload.borrowedUsd !== '0'
|
|
100
|
+
? new Dec(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString()
|
|
101
|
+
: '0';
|
|
102
|
+
|
|
103
|
+
// Calculate borrow limits per asset
|
|
104
|
+
Object.values(usedAssets).forEach((item) => {
|
|
105
|
+
if (item.isBorrowed) {
|
|
106
|
+
// eslint-disable-next-line no-param-reassign
|
|
107
|
+
item.limit = calculateBorrowingAssetLimit(item.borrowedUsd, payload.borrowLimitUsd);
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData);
|
|
112
|
+
payload.netApy = netApy;
|
|
113
|
+
payload.incentiveUsd = incentiveUsd;
|
|
114
|
+
payload.totalInterestUsd = totalInterestUsd;
|
|
115
|
+
|
|
116
|
+
const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets);
|
|
117
|
+
payload.leveragedType = leveragedType;
|
|
118
|
+
if (leveragedType !== '') {
|
|
119
|
+
payload.leveragedAsset = leveragedAsset;
|
|
120
|
+
const assetPrice = assetsData[handleWbtcLegacy(leveragedAsset)].price;
|
|
121
|
+
payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
return payload;
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
export const getCompoundV3AggregatedData = ({
|
|
128
|
+
usedAssets, assetsData, network, selectedMarket, ...rest
|
|
129
|
+
}: { usedAssets: CompoundV3UsedAssets, assetsData: CompoundV3AssetsData, network: NetworkNumber, selectedMarket: CompoundMarketData }) => {
|
|
130
|
+
const payload = {} as CompoundAggregatedPositionData;
|
|
131
|
+
payload.suppliedUsd = getAssetsTotal(usedAssets, ({ isSupplied }: { isSupplied: boolean }) => isSupplied, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
|
|
132
|
+
payload.suppliedCollateralUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ suppliedUsd }: { suppliedUsd: string }) => suppliedUsd);
|
|
133
|
+
payload.borrowedUsd = getAssetsTotal(usedAssets, ({ isBorrowed }: { isBorrowed: boolean }) => isBorrowed, ({ borrowedUsd }: { borrowedUsd: string }) => borrowedUsd);
|
|
134
|
+
payload.borrowLimitUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(assetsData[symbol].collateralFactor));
|
|
135
|
+
payload.liquidationLimitUsd = getAssetsTotal(usedAssets, ({ isSupplied, collateral }: { isSupplied: boolean, collateral: boolean }) => isSupplied && collateral, ({ symbol, suppliedUsd }: { symbol: string, suppliedUsd: string }) => new Dec(suppliedUsd).mul(assetsData[symbol].liquidationRatio));
|
|
136
|
+
payload.debtTooLow = new Dec(usedAssets[selectedMarket.baseAsset]?.borrowed || 0).gt(0) && new Dec(usedAssets[selectedMarket.baseAsset].borrowed).lt(assetsData[selectedMarket.baseAsset].minDebt);
|
|
137
|
+
const leftToBorrowUsd = new Dec(payload.borrowLimitUsd).sub(payload.borrowedUsd);
|
|
138
|
+
payload.leftToBorrowUsd = leftToBorrowUsd.lte('0') ? '0' : leftToBorrowUsd.toString();
|
|
139
|
+
payload.ratio = +payload.suppliedUsd ? new Dec(payload.borrowLimitUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
|
|
140
|
+
payload.collRatio = +payload.suppliedUsd ? new Dec(payload.suppliedCollateralUsd).div(payload.borrowedUsd).mul(100).toString() : '0';
|
|
141
|
+
const { netApy, incentiveUsd, totalInterestUsd } = calculateNetApy(usedAssets, assetsData);
|
|
142
|
+
payload.netApy = netApy;
|
|
143
|
+
payload.incentiveUsd = incentiveUsd;
|
|
144
|
+
payload.totalInterestUsd = totalInterestUsd;
|
|
145
|
+
payload.minRatio = '100';
|
|
146
|
+
payload.liqRatio = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).toString();
|
|
147
|
+
payload.liqPercent = new Dec(payload.borrowLimitUsd).div(payload.liquidationLimitUsd).mul(100).toString();
|
|
148
|
+
payload.minDebt = assetsData[selectedMarket.baseAsset].minDebt;
|
|
149
|
+
const { leveragedType, leveragedAsset } = isLeveragedPos(usedAssets, selectedMarket.value === CompoundVersions.CompoundV3ETH ? 0.001 : 5);
|
|
150
|
+
payload.leveragedType = leveragedType;
|
|
151
|
+
if (leveragedType !== '') {
|
|
152
|
+
payload.leveragedAsset = leveragedAsset;
|
|
153
|
+
const assetPrice = assetsData[leveragedAsset].price;
|
|
154
|
+
if (leveragedType === 'lsd-leverage') {
|
|
155
|
+
payload.leveragedLsdAssetRatio = new Dec(assetsData[leveragedAsset].price).div(assetsData.ETH.price).toString();
|
|
156
|
+
}
|
|
157
|
+
payload.liquidationPrice = calcLeverageLiqPrice(leveragedType, assetPrice, payload.borrowedUsd, payload.liquidationLimitUsd);
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
// TO DO: handle strategies
|
|
161
|
+
/* const subscribedStrategies = rest.compoundStrategies
|
|
162
|
+
? compoundV3GetSubscribedStrategies({ selectedMarket, compoundStrategies: rest.compoundStrategies })
|
|
163
|
+
: []; */
|
|
164
|
+
|
|
165
|
+
// TODO possibly move to global helper, since every protocol has the same graphData?
|
|
166
|
+
// payload.ratioTooLow = false;
|
|
167
|
+
// payload.ratioTooHigh = false;
|
|
168
|
+
|
|
169
|
+
// TO DO: handle strategies
|
|
170
|
+
/* if (subscribedStrategies.length) {
|
|
171
|
+
subscribedStrategies.forEach(({ graphData }) => {
|
|
172
|
+
payload.ratioTooLow = parseFloat(payload.ratio) < parseFloat(graphData.minRatio);
|
|
173
|
+
payload.ratioTooHigh = graphData.boostEnabled && parseFloat(payload.ratio) > parseFloat(graphData.maxRatio);
|
|
174
|
+
});
|
|
175
|
+
} */
|
|
176
|
+
|
|
177
|
+
return payload;
|
|
178
|
+
};
|