@1delta/margin-fetcher 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/dist/abis/aave/AToken.d.ts +526 -0
- package/dist/abis/aave/AToken.d.ts.map +1 -0
- package/dist/abis/aave/AToken.js +686 -0
- package/dist/abis/aave/AaveOracle.d.ts +40 -0
- package/dist/abis/aave/AaveOracle.d.ts.map +1 -0
- package/dist/abis/aave/AaveOracle.js +53 -0
- package/dist/abis/aave/AavePoolAndDataProvider.d.ts +1618 -0
- package/dist/abis/aave/AavePoolAndDataProvider.d.ts.map +1 -0
- package/dist/abis/aave/AavePoolAndDataProvider.js +2080 -0
- package/dist/abis/aave/AavePoolV3.d.ts +819 -0
- package/dist/abis/aave/AavePoolV3.d.ts.map +1 -0
- package/dist/abis/aave/AavePoolV3.js +1060 -0
- package/dist/abis/aave/AavePoolV3Upgraded.d.ts +1134 -0
- package/dist/abis/aave/AavePoolV3Upgraded.d.ts.map +1 -0
- package/dist/abis/aave/AavePoolV3Upgraded.js +1474 -0
- package/dist/abis/aave/AaveV3ProtocolDataProvider.d.ts +420 -0
- package/dist/abis/aave/AaveV3ProtocolDataProvider.d.ts.map +1 -0
- package/dist/abis/aave/AaveV3ProtocolDataProvider.js +553 -0
- package/dist/abis/aave/VariableDebtToken.d.ts +635 -0
- package/dist/abis/aave/VariableDebtToken.d.ts.map +1 -0
- package/dist/abis/aave/VariableDebtToken.js +820 -0
- package/dist/abis/aave-v2/ProtocolDataProvider.d.ts +238 -0
- package/dist/abis/aave-v2/ProtocolDataProvider.d.ts.map +1 -0
- package/dist/abis/aave-v2/ProtocolDataProvider.js +312 -0
- package/dist/abis/aave-v2/YLDR.d.ts +209 -0
- package/dist/abis/aave-v2/YLDR.d.ts.map +1 -0
- package/dist/abis/aave-v2/YLDR.js +199 -0
- package/dist/abis/aave-v3/AavePoolDataProviderLegacy.d.ts +406 -0
- package/dist/abis/aave-v3/AavePoolDataProviderLegacy.d.ts.map +1 -0
- package/dist/abis/aave-v3/AavePoolDataProviderLegacy.js +460 -0
- package/dist/abis/aave-v3/AavePoolLegacy.d.ts +819 -0
- package/dist/abis/aave-v3/AavePoolLegacy.d.ts.map +1 -0
- package/dist/abis/aave-v3/AavePoolLegacy.js +1060 -0
- package/dist/abis/aurelius/Rewarder.d.ts +90 -0
- package/dist/abis/aurelius/Rewarder.d.ts.map +1 -0
- package/dist/abis/aurelius/Rewarder.js +118 -0
- package/dist/abis/compound-v2/CompoundLens.d.ts +656 -0
- package/dist/abis/compound-v2/CompoundLens.d.ts.map +1 -0
- package/dist/abis/compound-v2/CompoundLens.js +851 -0
- package/dist/abis/compound-v2/Comptroller.d.ts +1615 -0
- package/dist/abis/compound-v2/Comptroller.d.ts.map +1 -0
- package/dist/abis/compound-v2/Comptroller.js +2104 -0
- package/dist/abis/compound-v3/Comet.d.ts +1402 -0
- package/dist/abis/compound-v3/Comet.d.ts.map +1 -0
- package/dist/abis/compound-v3/Comet.js +1829 -0
- package/dist/abis/compound-v3/CometExt.d.ts +411 -0
- package/dist/abis/compound-v3/CometExt.d.ts.map +1 -0
- package/dist/abis/compound-v3/CometExt.js +536 -0
- package/dist/abis/compound-v3/CometLens.d.ts +152 -0
- package/dist/abis/compound-v3/CometLens.d.ts.map +1 -0
- package/dist/abis/compound-v3/CometLens.js +194 -0
- package/dist/abis/compound-v3/CometRewards.d.ts +253 -0
- package/dist/abis/compound-v3/CometRewards.d.ts.map +1 -0
- package/dist/abis/compound-v3/CometRewards.js +330 -0
- package/dist/abis/compound-v3/IrGetter.d.ts +24 -0
- package/dist/abis/compound-v3/IrGetter.d.ts.map +1 -0
- package/dist/abis/compound-v3/IrGetter.js +31 -0
- package/dist/abis/flashloan-united/flashAbi.d.ts +54 -0
- package/dist/abis/flashloan-united/flashAbi.d.ts.map +1 -0
- package/dist/abis/flashloan-united/flashAbi.js +72 -0
- package/dist/abis/init/Core.d.ts +523 -0
- package/dist/abis/init/Core.d.ts.map +1 -0
- package/dist/abis/init/Core.js +681 -0
- package/dist/abis/init/InitFlashAggregator.d.ts +624 -0
- package/dist/abis/init/InitFlashAggregator.d.ts.map +1 -0
- package/dist/abis/init/InitFlashAggregator.js +795 -0
- package/dist/abis/init/InitLens.d.ts +158 -0
- package/dist/abis/init/InitLens.d.ts.map +1 -0
- package/dist/abis/init/InitLens.js +203 -0
- package/dist/abis/init/PosManager.d.ts +802 -0
- package/dist/abis/init/PosManager.d.ts.map +1 -0
- package/dist/abis/init/PosManager.js +1055 -0
- package/dist/abis/lendle/IncentivesController.d.ts +404 -0
- package/dist/abis/lendle/IncentivesController.d.ts.map +1 -0
- package/dist/abis/lendle/IncentivesController.js +525 -0
- package/dist/abis/lendle/MultiFeeDistribution.d.ts +624 -0
- package/dist/abis/lendle/MultiFeeDistribution.d.ts.map +1 -0
- package/dist/abis/lendle/MultiFeeDistribution.js +820 -0
- package/dist/abis/meridian/PullRewardsIncentivesController.d.ts +74 -0
- package/dist/abis/meridian/PullRewardsIncentivesController.d.ts.map +1 -0
- package/dist/abis/meridian/PullRewardsIncentivesController.js +98 -0
- package/dist/abis/multicall/Multicall.d.ts +80 -0
- package/dist/abis/multicall/Multicall.d.ts.map +1 -0
- package/dist/abis/multicall/Multicall.js +101 -0
- package/dist/abis/oracle/AaveOracle.d.ts +40 -0
- package/dist/abis/oracle/AaveOracle.d.ts.map +1 -0
- package/dist/abis/oracle/AaveOracle.js +53 -0
- package/dist/abis/oracle/Api3Oracle.d.ts +48 -0
- package/dist/abis/oracle/Api3Oracle.d.ts.map +1 -0
- package/dist/abis/oracle/Api3Oracle.js +62 -0
- package/dist/abis/oracle/ChainLinkAggregator.d.ts +372 -0
- package/dist/abis/oracle/ChainLinkAggregator.d.ts.map +1 -0
- package/dist/abis/oracle/ChainLinkAggregator.js +480 -0
- package/dist/abis/oracle/RWADynamicOracle.d.ts +12 -0
- package/dist/abis/oracle/RWADynamicOracle.d.ts.map +1 -0
- package/dist/abis/oracle/RWADynamicOracle.js +15 -0
- package/dist/abis/oracle/UniswapV2Pair.d.ts +513 -0
- package/dist/abis/oracle/UniswapV2Pair.d.ts.map +1 -0
- package/dist/abis/oracle/UniswapV2Pair.js +659 -0
- package/dist/abis/uniswap/FeeOnTransferDetector.d.ts +102 -0
- package/dist/abis/uniswap/FeeOnTransferDetector.d.ts.map +1 -0
- package/dist/abis/uniswap/FeeOnTransferDetector.js +133 -0
- package/dist/abis/uniswap/UniswapV2Pair.d.ts +513 -0
- package/dist/abis/uniswap/UniswapV2Pair.d.ts.map +1 -0
- package/dist/abis/uniswap/UniswapV2Pair.js +659 -0
- package/dist/assets/index.d.ts +20 -0
- package/dist/assets/index.d.ts.map +1 -0
- package/dist/assets/index.js +54 -0
- package/dist/flash-liquidity/assets.d.ts +21 -0
- package/dist/flash-liquidity/assets.d.ts.map +1 -0
- package/dist/flash-liquidity/assets.js +45 -0
- package/dist/flash-liquidity/fetchLiquidity.d.ts +4 -0
- package/dist/flash-liquidity/fetchLiquidity.d.ts.map +1 -0
- package/dist/flash-liquidity/fetchLiquidity.js +235 -0
- package/dist/flash-liquidity/index.d.ts +2 -0
- package/dist/flash-liquidity/index.d.ts.map +1 -0
- package/dist/flash-liquidity/index.js +1 -0
- package/dist/flash-liquidity/types.d.ts +23 -0
- package/dist/flash-liquidity/types.d.ts.map +1 -0
- package/dist/flash-liquidity/types.js +8 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/lending/aave-v2-type/misc.d.ts +14 -0
- package/dist/lending/aave-v2-type/misc.d.ts.map +1 -0
- package/dist/lending/aave-v2-type/misc.js +8 -0
- package/dist/lending/aave-v2-type/publicCallBuild.d.ts +7 -0
- package/dist/lending/aave-v2-type/publicCallBuild.d.ts.map +1 -0
- package/dist/lending/aave-v2-type/publicCallBuild.js +102 -0
- package/dist/lending/aave-v2-type/publicCallParse.d.ts +7 -0
- package/dist/lending/aave-v2-type/publicCallParse.d.ts.map +1 -0
- package/dist/lending/aave-v2-type/publicCallParse.js +254 -0
- package/dist/lending/aave-v2-type/types.d.ts +78 -0
- package/dist/lending/aave-v2-type/types.d.ts.map +1 -0
- package/dist/lending/aave-v2-type/types.js +46 -0
- package/dist/lending/aave-v3-type/publicCallBuild.d.ts +4 -0
- package/dist/lending/aave-v3-type/publicCallBuild.d.ts.map +1 -0
- package/dist/lending/aave-v3-type/publicCallBuild.js +123 -0
- package/dist/lending/aave-v3-type/publicCallParse.d.ts +8 -0
- package/dist/lending/aave-v3-type/publicCallParse.d.ts.map +1 -0
- package/dist/lending/aave-v3-type/publicCallParse.js +304 -0
- package/dist/lending/aave-v3-type/types.d.ts +149 -0
- package/dist/lending/aave-v3-type/types.d.ts.map +1 -0
- package/dist/lending/aave-v3-type/types.js +90 -0
- package/dist/lending/addresses/aave.d.ts +10 -0
- package/dist/lending/addresses/aave.d.ts.map +1 -0
- package/dist/lending/addresses/aave.js +10 -0
- package/dist/lending/addresses/aaveV2.d.ts +6 -0
- package/dist/lending/addresses/aaveV2.d.ts.map +1 -0
- package/dist/lending/addresses/aaveV2.js +6 -0
- package/dist/lending/addresses/aurelius.d.ts +12 -0
- package/dist/lending/addresses/aurelius.d.ts.map +1 -0
- package/dist/lending/addresses/aurelius.js +12 -0
- package/dist/lending/addresses/compoundV3.d.ts +10 -0
- package/dist/lending/addresses/compoundV3.d.ts.map +1 -0
- package/dist/lending/addresses/compoundV3.js +35 -0
- package/dist/lending/addresses/contracts.d.ts +5 -0
- package/dist/lending/addresses/contracts.d.ts.map +1 -0
- package/dist/lending/addresses/contracts.js +49 -0
- package/dist/lending/addresses/hana.d.ts +6 -0
- package/dist/lending/addresses/hana.d.ts.map +1 -0
- package/dist/lending/addresses/hana.js +6 -0
- package/dist/lending/addresses/index.d.ts +2 -0
- package/dist/lending/addresses/index.d.ts.map +1 -0
- package/dist/lending/addresses/index.js +1 -0
- package/dist/lending/addresses/init.d.ts +4 -0
- package/dist/lending/addresses/init.d.ts.map +1 -0
- package/dist/lending/addresses/init.js +33 -0
- package/dist/lending/addresses/lendle.d.ts +12 -0
- package/dist/lending/addresses/lendle.d.ts.map +1 -0
- package/dist/lending/addresses/lendle.js +12 -0
- package/dist/lending/addresses/meridian.d.ts +12 -0
- package/dist/lending/addresses/meridian.d.ts.map +1 -0
- package/dist/lending/addresses/meridian.js +12 -0
- package/dist/lending/addresses/takotako.d.ts +12 -0
- package/dist/lending/addresses/takotako.d.ts.map +1 -0
- package/dist/lending/addresses/takotako.js +12 -0
- package/dist/lending/compound-v3/publicCallBuild.d.ts +3 -0
- package/dist/lending/compound-v3/publicCallBuild.d.ts.map +1 -0
- package/dist/lending/compound-v3/publicCallBuild.js +63 -0
- package/dist/lending/compound-v3/publicCallParse.d.ts +7 -0
- package/dist/lending/compound-v3/publicCallParse.d.ts.map +1 -0
- package/dist/lending/compound-v3/publicCallParse.js +119 -0
- package/dist/lending/compound-v3/types.d.ts +30 -0
- package/dist/lending/compound-v3/types.d.ts.map +1 -0
- package/dist/lending/compound-v3/types.js +6 -0
- package/dist/lending/fetchLender.d.ts +8 -0
- package/dist/lending/fetchLender.d.ts.map +1 -0
- package/dist/lending/fetchLender.js +104 -0
- package/dist/lending/index.d.ts +3 -0
- package/dist/lending/index.d.ts.map +1 -0
- package/dist/lending/index.js +2 -0
- package/dist/lending/init/publicCallBuild.d.ts +7 -0
- package/dist/lending/init/publicCallBuild.d.ts.map +1 -0
- package/dist/lending/init/publicCallBuild.js +21 -0
- package/dist/lending/init/publicCallParse.d.ts +10 -0
- package/dist/lending/init/publicCallParse.d.ts.map +1 -0
- package/dist/lending/init/publicCallParse.js +75 -0
- package/dist/lending/init/types.d.ts +38 -0
- package/dist/lending/init/types.d.ts.map +1 -0
- package/dist/lending/init/types.js +6 -0
- package/dist/lending/user-data/aave-v2-type/userCallBuild.d.ts +4 -0
- package/dist/lending/user-data/aave-v2-type/userCallBuild.d.ts.map +1 -0
- package/dist/lending/user-data/aave-v2-type/userCallBuild.js +106 -0
- package/dist/lending/user-data/aave-v2-type/userCallParse.d.ts +8 -0
- package/dist/lending/user-data/aave-v2-type/userCallParse.d.ts.map +1 -0
- package/dist/lending/user-data/aave-v2-type/userCallParse.js +225 -0
- package/dist/lending/user-data/aave-v3-type/userCallBuild.d.ts +4 -0
- package/dist/lending/user-data/aave-v3-type/userCallBuild.d.ts.map +1 -0
- package/dist/lending/user-data/aave-v3-type/userCallBuild.js +41 -0
- package/dist/lending/user-data/aave-v3-type/userCallParse.d.ts +8 -0
- package/dist/lending/user-data/aave-v3-type/userCallParse.d.ts.map +1 -0
- package/dist/lending/user-data/aave-v3-type/userCallParse.js +76 -0
- package/dist/lending/user-data/abis.d.ts +8422 -0
- package/dist/lending/user-data/abis.d.ts.map +1 -0
- package/dist/lending/user-data/abis.js +46 -0
- package/dist/lending/user-data/compound-v3/addresses.d.ts +10 -0
- package/dist/lending/user-data/compound-v3/addresses.d.ts.map +1 -0
- package/dist/lending/user-data/compound-v3/addresses.js +32 -0
- package/dist/lending/user-data/compound-v3/index.d.ts +4 -0
- package/dist/lending/user-data/compound-v3/index.d.ts.map +1 -0
- package/dist/lending/user-data/compound-v3/index.js +3 -0
- package/dist/lending/user-data/compound-v3/userCallBuild.d.ts +4 -0
- package/dist/lending/user-data/compound-v3/userCallBuild.d.ts.map +1 -0
- package/dist/lending/user-data/compound-v3/userCallBuild.js +44 -0
- package/dist/lending/user-data/compound-v3/userCallParse.d.ts +8 -0
- package/dist/lending/user-data/compound-v3/userCallParse.d.ts.map +1 -0
- package/dist/lending/user-data/compound-v3/userCallParse.js +98 -0
- package/dist/lending/user-data/fetchUserData.d.ts +24 -0
- package/dist/lending/user-data/fetchUserData.d.ts.map +1 -0
- package/dist/lending/user-data/fetchUserData.js +76 -0
- package/dist/lending/user-data/index.d.ts +3 -0
- package/dist/lending/user-data/index.d.ts.map +1 -0
- package/dist/lending/user-data/index.js +2 -0
- package/dist/lending/user-data/init/userCallBuild.d.ts +8 -0
- package/dist/lending/user-data/init/userCallBuild.d.ts.map +1 -0
- package/dist/lending/user-data/init/userCallBuild.js +20 -0
- package/dist/lending/user-data/init/userCallParse.d.ts +8 -0
- package/dist/lending/user-data/init/userCallParse.d.ts.map +1 -0
- package/dist/lending/user-data/init/userCallParse.js +87 -0
- package/dist/lending/user-data/types.d.ts +218 -0
- package/dist/lending/user-data/types.d.ts.map +1 -0
- package/dist/lending/user-data/types.js +26 -0
- package/dist/lending/user-data/utils/createGeneralUserState.d.ts +45 -0
- package/dist/lending/user-data/utils/createGeneralUserState.d.ts.map +1 -0
- package/dist/lending/user-data/utils/createGeneralUserState.js +98 -0
- package/dist/lending/user-data/utils/createMultiAccountStyleUserState.d.ts +16 -0
- package/dist/lending/user-data/utils/createMultiAccountStyleUserState.d.ts.map +1 -0
- package/dist/lending/user-data/utils/createMultiAccountStyleUserState.js +96 -0
- package/dist/lending/user-data/utils/formatting/generalFormatters.d.ts +55 -0
- package/dist/lending/user-data/utils/formatting/generalFormatters.d.ts.map +1 -0
- package/dist/lending/user-data/utils/formatting/generalFormatters.js +109 -0
- package/dist/lending/user-data/utils/formatting/index.d.ts +2 -0
- package/dist/lending/user-data/utils/formatting/index.d.ts.map +1 -0
- package/dist/lending/user-data/utils/formatting/index.js +1 -0
- package/dist/lending/user-data/utils/index.d.ts +8 -0
- package/dist/lending/user-data/utils/index.d.ts.map +1 -0
- package/dist/lending/user-data/utils/index.js +17 -0
- package/dist/lending-pairs/computeLendingPairs.d.ts +30 -0
- package/dist/lending-pairs/computeLendingPairs.d.ts.map +1 -0
- package/dist/lending-pairs/computeLendingPairs.js +153 -0
- package/dist/lending-pairs/index.d.ts +2 -0
- package/dist/lending-pairs/index.d.ts.map +1 -0
- package/dist/lending-pairs/index.js +1 -0
- package/dist/prices/defillama/index.d.ts +3 -0
- package/dist/prices/defillama/index.d.ts.map +1 -0
- package/dist/prices/defillama/index.js +269 -0
- package/dist/prices/index.d.ts +3 -0
- package/dist/prices/index.d.ts.map +1 -0
- package/dist/prices/index.js +2 -0
- package/dist/prices/main-prices/addresses/aaveOracles.d.ts +279 -0
- package/dist/prices/main-prices/addresses/aaveOracles.d.ts.map +1 -0
- package/dist/prices/main-prices/addresses/aaveOracles.js +278 -0
- package/dist/prices/main-prices/addresses/api3.d.ts +6 -0
- package/dist/prices/main-prices/addresses/api3.d.ts.map +1 -0
- package/dist/prices/main-prices/addresses/api3.js +9 -0
- package/dist/prices/main-prices/addresses/chainlink.d.ts +740 -0
- package/dist/prices/main-prices/addresses/chainlink.d.ts.map +1 -0
- package/dist/prices/main-prices/addresses/chainlink.js +744 -0
- package/dist/prices/main-prices/fetchOracleData.d.ts +12 -0
- package/dist/prices/main-prices/fetchOracleData.d.ts.map +1 -0
- package/dist/prices/main-prices/fetchOracleData.js +308 -0
- package/dist/prices/main-prices/index.d.ts +2 -0
- package/dist/prices/main-prices/index.d.ts.map +1 -0
- package/dist/prices/main-prices/index.js +1 -0
- package/dist/types/apiReturnType.d.ts +74 -0
- package/dist/types/apiReturnType.d.ts.map +1 -0
- package/dist/types/apiReturnType.js +1 -0
- package/dist/types/index.d.ts +42 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +10 -0
- package/dist/types/providers.d.ts +12 -0
- package/dist/types/providers.d.ts.map +1 -0
- package/dist/types/providers.js +1 -0
- package/dist/utils/constants.d.ts +30 -0
- package/dist/utils/constants.d.ts.map +1 -0
- package/dist/utils/constants.js +97 -0
- package/dist/utils/index.d.ts +19 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +71 -0
- package/dist/utils/multicall.d.ts +5 -0
- package/dist/utils/multicall.d.ts.map +1 -0
- package/dist/utils/multicall.js +30 -0
- package/dist/utils/parsing.d.ts +14 -0
- package/dist/utils/parsing.d.ts.map +1 -0
- package/dist/utils/parsing.js +61 -0
- package/dist/yields/index.d.ts +21 -0
- package/dist/yields/index.d.ts.map +1 -0
- package/dist/yields/index.js +157 -0
- package/package.json +26 -0
- package/src/abis/aave/AToken.ts +686 -0
- package/src/abis/aave/AaveOracle.ts +53 -0
- package/src/abis/aave/AavePoolAndDataProvider.ts +2080 -0
- package/src/abis/aave/AavePoolV3.ts +1060 -0
- package/src/abis/aave/AavePoolV3Upgraded.ts +1474 -0
- package/src/abis/aave/AaveV3ProtocolDataProvider.ts +553 -0
- package/src/abis/aave/VariableDebtToken.ts +820 -0
- package/src/abis/aave-v2/ProtocolDataProvider.ts +312 -0
- package/src/abis/aave-v2/YLDR.ts +199 -0
- package/src/abis/aave-v3/AavePoolDataProviderLegacy.ts +459 -0
- package/src/abis/aave-v3/AavePoolLegacy.ts +1060 -0
- package/src/abis/aurelius/Rewarder.ts +118 -0
- package/src/abis/compound-v2/CompoundLens.ts +851 -0
- package/src/abis/compound-v2/Comptroller.ts +2104 -0
- package/src/abis/compound-v3/Comet.ts +1829 -0
- package/src/abis/compound-v3/CometExt.ts +536 -0
- package/src/abis/compound-v3/CometLens.ts +194 -0
- package/src/abis/compound-v3/CometRewards.ts +330 -0
- package/src/abis/compound-v3/IrGetter.ts +31 -0
- package/src/abis/flashloan-united/flashAbi.ts +72 -0
- package/src/abis/init/Core.ts +681 -0
- package/src/abis/init/InitFlashAggregator.ts +795 -0
- package/src/abis/init/InitLens.ts +203 -0
- package/src/abis/init/PosManager.ts +1055 -0
- package/src/abis/lendle/IncentivesController.ts +525 -0
- package/src/abis/lendle/MultiFeeDistribution.ts +820 -0
- package/src/abis/meridian/PullRewardsIncentivesController.ts +98 -0
- package/src/abis/multicall/Multicall.ts +101 -0
- package/src/abis/oracle/AaveOracle.ts +53 -0
- package/src/abis/oracle/Api3Oracle.ts +62 -0
- package/src/abis/oracle/ChainLinkAggregator.ts +480 -0
- package/src/abis/oracle/RWADynamicOracle.ts +15 -0
- package/src/abis/oracle/UniswapV2Pair.ts +659 -0
- package/src/abis/uniswap/FeeOnTransferDetector.ts +133 -0
- package/src/abis/uniswap/UniswapV2Pair.ts +659 -0
- package/src/assets/index.ts +82 -0
- package/src/flash-liquidity/assets.ts +61 -0
- package/src/flash-liquidity/fetchLiquidity.ts +300 -0
- package/src/flash-liquidity/index.ts +1 -0
- package/src/flash-liquidity/types.ts +20 -0
- package/src/index.ts +7 -0
- package/src/lending/aave-v2-type/misc.ts +9 -0
- package/src/lending/aave-v2-type/publicCallBuild.ts +105 -0
- package/src/lending/aave-v2-type/publicCallParse.ts +300 -0
- package/src/lending/aave-v2-type/types.ts +98 -0
- package/src/lending/aave-v3-type/publicCallBuild.ts +148 -0
- package/src/lending/aave-v3-type/publicCallParse.ts +373 -0
- package/src/lending/aave-v3-type/types.ts +181 -0
- package/src/lending/addresses/aave.ts +12 -0
- package/src/lending/addresses/aaveV2.ts +8 -0
- package/src/lending/addresses/aurelius.ts +13 -0
- package/src/lending/addresses/compoundV3.ts +42 -0
- package/src/lending/addresses/contracts.ts +54 -0
- package/src/lending/addresses/hana.ts +7 -0
- package/src/lending/addresses/index.ts +1 -0
- package/src/lending/addresses/init.ts +37 -0
- package/src/lending/addresses/lendle.ts +13 -0
- package/src/lending/addresses/meridian.ts +13 -0
- package/src/lending/addresses/takotako.ts +14 -0
- package/src/lending/compound-v3/publicCallBuild.ts +74 -0
- package/src/lending/compound-v3/publicCallParse.ts +143 -0
- package/src/lending/compound-v3/types.ts +43 -0
- package/src/lending/fetchLender.ts +138 -0
- package/src/lending/index.ts +2 -0
- package/src/lending/init/publicCallBuild.ts +29 -0
- package/src/lending/init/publicCallParse.ts +90 -0
- package/src/lending/init/types.ts +50 -0
- package/src/lending/user-data/aave-v2-type/userCallBuild.ts +142 -0
- package/src/lending/user-data/aave-v2-type/userCallParse.ts +328 -0
- package/src/lending/user-data/aave-v3-type/userCallBuild.ts +58 -0
- package/src/lending/user-data/aave-v3-type/userCallParse.ts +115 -0
- package/src/lending/user-data/abis.ts +45 -0
- package/src/lending/user-data/compound-v3/addresses.ts +40 -0
- package/src/lending/user-data/compound-v3/index.ts +3 -0
- package/src/lending/user-data/compound-v3/userCallBuild.ts +53 -0
- package/src/lending/user-data/compound-v3/userCallParse.ts +123 -0
- package/src/lending/user-data/fetchUserData.ts +121 -0
- package/src/lending/user-data/index.ts +2 -0
- package/src/lending/user-data/init/userCallBuild.ts +26 -0
- package/src/lending/user-data/init/userCallParse.ts +115 -0
- package/src/lending/user-data/types.ts +280 -0
- package/src/lending/user-data/utils/createGeneralUserState.ts +118 -0
- package/src/lending/user-data/utils/createMultiAccountStyleUserState.ts +113 -0
- package/src/lending/user-data/utils/formatting/generalFormatters.ts +121 -0
- package/src/lending/user-data/utils/formatting/index.ts +1 -0
- package/src/lending/user-data/utils/index.ts +19 -0
- package/src/lending-pairs/computeLendingPairs.ts +213 -0
- package/src/lending-pairs/index.ts +1 -0
- package/src/prices/defillama/index.ts +306 -0
- package/src/prices/index.ts +2 -0
- package/src/prices/main-prices/addresses/aaveOracles.ts +279 -0
- package/src/prices/main-prices/addresses/api3.ts +10 -0
- package/src/prices/main-prices/addresses/chainlink.ts +750 -0
- package/src/prices/main-prices/fetchOracleData.ts +406 -0
- package/src/prices/main-prices/index.ts +1 -0
- package/src/types/apiReturnType.ts +80 -0
- package/src/types/index.ts +38 -0
- package/src/types/providers.ts +26 -0
- package/src/utils/constants.ts +100 -0
- package/src/utils/index.ts +87 -0
- package/src/utils/multicall.ts +53 -0
- package/src/utils/parsing.ts +75 -0
- package/src/yields/index.ts +198 -0
- package/test/index.test.ts +104 -0
- package/test/lenderData.test.ts +13718 -0
- package/test/mainPrices.test.ts +35 -0
- package/test/userdata.test.ts +200 -0
- package/tsconfig.json +28 -0
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { AAVE_FORK_POOL_DATA, AAVE_STYLE_RESERVE_ASSETS, AAVE_STYLE_TOKENS, ASSET_META, COMPOUND_STYLE_RESERVE_ASSETS, COMPOUND_V2_STYLE_RESERVE_ASSETS, INIT_STYLE_RESERVE_ASSETS, Lender, SWAYLEND_RESERVE_ASSETS } from "@1delta/asset-registry"
|
|
2
|
+
import { isAaveType, isCompoundV3, isInit, isSwaylend } from "../utils"
|
|
3
|
+
|
|
4
|
+
/** No specific configuration */
|
|
5
|
+
export const LENDER_MODE_NO_MODE = 0
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
export function getAaveStyleProtocolTokenMap(chainId: string, lender: string) {
|
|
9
|
+
return AAVE_STYLE_TOKENS[lender]?.[chainId] as any
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
export const getAaveAssets = (
|
|
14
|
+
chainId: string | undefined,
|
|
15
|
+
lendingProtocol: string = Lender.AAVE_V3
|
|
16
|
+
): string[] => {
|
|
17
|
+
if (isAaveType(lendingProtocol)) return AAVE_STYLE_RESERVE_ASSETS[lendingProtocol]?.[chainId ?? "0"] ?? []
|
|
18
|
+
return []
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export const getInitAssets = (
|
|
22
|
+
chainId: string | undefined,
|
|
23
|
+
lendingProtocol = Lender.INIT
|
|
24
|
+
): string[] => {
|
|
25
|
+
if (isInit(lendingProtocol)) return INIT_STYLE_RESERVE_ASSETS[lendingProtocol]?.[chainId ?? "0"] ?? []
|
|
26
|
+
return []
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export const getCompoundV3Assets = (
|
|
30
|
+
chainId: string | undefined,
|
|
31
|
+
lendingProtocol = Lender.COMPOUND_V3_USDC_E
|
|
32
|
+
): string[] => {
|
|
33
|
+
if (isCompoundV3(lendingProtocol)) return COMPOUND_STYLE_RESERVE_ASSETS[lendingProtocol]?.[chainId ?? "0"] ?? []
|
|
34
|
+
return []
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
export const getCompoundV2Assets = (
|
|
38
|
+
chainId: string | undefined,
|
|
39
|
+
lendingProtocol = Lender.VENUS
|
|
40
|
+
): string[] => {
|
|
41
|
+
if (isCompoundV3(lendingProtocol)) return COMPOUND_V2_STYLE_RESERVE_ASSETS[lendingProtocol]?.[chainId ?? "0"] ?? []
|
|
42
|
+
return []
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
export const getSwaylendAssets = (
|
|
47
|
+
chainId: string | undefined,
|
|
48
|
+
lendingProtocol = Lender.SWAYLEND_USDC
|
|
49
|
+
): string[] => {
|
|
50
|
+
if (isSwaylend(lendingProtocol)) return SWAYLEND_RESERVE_ASSETS[lendingProtocol]?.[chainId ?? "0"] ?? []
|
|
51
|
+
return []
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export function getAaveTypePoolDataProviderAddress(chainId: string, lender: string) {
|
|
55
|
+
// @ts-ignore
|
|
56
|
+
return AAVE_FORK_POOL_DATA[lender]?.[chainId]?.protocolDataProvider
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
|
|
60
|
+
export function getAaveTypePoolAddress(chainId: string, lender: string): string {
|
|
61
|
+
// @ts-ignore
|
|
62
|
+
return AAVE_FORK_POOL_DATA[lender]?.[chainId]?.pool
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
export function getAssetMeta(chainId: string, asset: string | undefined) {
|
|
67
|
+
return ASSET_META[chainId ?? "0"]?.[asset?.toLowerCase() ?? ""] as any
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* Convert a string (asset symbol) to a Supported asset, considering also naming conflicts
|
|
73
|
+
* @param a string
|
|
74
|
+
* @returns SupportedAsset
|
|
75
|
+
*/
|
|
76
|
+
export const toOracleKey = (a: string) => {
|
|
77
|
+
return a?.toUpperCase()
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
export const toGenericPriceKey = (assetAddress: string, chainId: string) => {
|
|
81
|
+
return chainId + "-" + assetAddress
|
|
82
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { AAVE_STYLE_RESERVE_ASSETS, COMPOUND_STYLE_RESERVE_ASSETS, COMPOUND_V2_STYLE_RESERVE_ASSETS, MORPHO_BLUE_POOL_DATA } from "@1delta/asset-registry"
|
|
2
|
+
import { BALANCER_V2_FORKS, BALANCER_V3_FORKS, UNISWAP_V4_FORKS } from "@1delta/dex-registry"
|
|
3
|
+
import { uniq } from "lodash"
|
|
4
|
+
|
|
5
|
+
function createAssetArrayPerChain() {
|
|
6
|
+
let assetsPerChain: { [chainId: string]: string[] } = {}
|
|
7
|
+
Object.entries(COMPOUND_STYLE_RESERVE_ASSETS).forEach(([lender, data]) => {
|
|
8
|
+
|
|
9
|
+
Object.entries(data).forEach(([chainId, assetArray]) => {
|
|
10
|
+
if (!assetsPerChain[chainId]) assetsPerChain[chainId] = []
|
|
11
|
+
assetsPerChain[chainId] = uniq([...assetsPerChain[chainId], ...assetArray])
|
|
12
|
+
})
|
|
13
|
+
})
|
|
14
|
+
|
|
15
|
+
Object.entries(AAVE_STYLE_RESERVE_ASSETS).forEach(([lender, data]) => {
|
|
16
|
+
Object.entries(data).forEach(([chainId, assetArray]) => {
|
|
17
|
+
if (!assetsPerChain[chainId]) assetsPerChain[chainId] = []
|
|
18
|
+
assetsPerChain[chainId] = uniq([...assetsPerChain[chainId], ...assetArray])
|
|
19
|
+
})
|
|
20
|
+
})
|
|
21
|
+
|
|
22
|
+
Object.entries(COMPOUND_V2_STYLE_RESERVE_ASSETS).forEach(([lender, data]) => {
|
|
23
|
+
Object.entries(data).forEach(([chainId, assetArray]) => {
|
|
24
|
+
if (!assetsPerChain[chainId]) assetsPerChain[chainId] = []
|
|
25
|
+
assetsPerChain[chainId] = uniq([...assetsPerChain[chainId], ...assetArray])
|
|
26
|
+
})
|
|
27
|
+
})
|
|
28
|
+
return assetsPerChain
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export const RELEVANT_LENDING_ASSETS = createAssetArrayPerChain()
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
interface PoolData {
|
|
35
|
+
pool: string
|
|
36
|
+
address: string
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
function createSimpleArrayPerChain(fork: any, field: undefined | string = undefined) {
|
|
40
|
+
let pools: { [chainId: string]: PoolData[] } = {}
|
|
41
|
+
Object.entries(fork).forEach(([b2, data]: [string, any]) => {
|
|
42
|
+
// @ts-ignore
|
|
43
|
+
Object.entries(field ? data[field] : data).forEach(([chainId, address]: [string, any]) => {
|
|
44
|
+
if (!pools[chainId]) pools[chainId] = []
|
|
45
|
+
pools[chainId] = uniq([...pools[chainId], { address, pool: b2 }])
|
|
46
|
+
})
|
|
47
|
+
})
|
|
48
|
+
return pools
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
export const RELEVANT_BALANCER_V2_FORKS = createSimpleArrayPerChain(BALANCER_V2_FORKS)
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
export const RELEVANT_MORPHOB_FORKS = createSimpleArrayPerChain(MORPHO_BLUE_POOL_DATA)
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
export const RELEVANT_BALANCER_V3_FORKS = createSimpleArrayPerChain(BALANCER_V3_FORKS, "vault")
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
export const RELEVANT_UNISWAP_V4_FORKS = createSimpleArrayPerChain(UNISWAP_V4_FORKS, "pm")
|
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
import { getAaveStyleProtocolTokenMap, getAaveTypePoolAddress, getAssetMeta } from "../assets";
|
|
2
|
+
import { AAVES_PER_CHAIN } from "../utils";
|
|
3
|
+
import {
|
|
4
|
+
RELEVANT_BALANCER_V2_FORKS,
|
|
5
|
+
RELEVANT_BALANCER_V3_FORKS,
|
|
6
|
+
RELEVANT_LENDING_ASSETS,
|
|
7
|
+
RELEVANT_MORPHOB_FORKS,
|
|
8
|
+
RELEVANT_UNISWAP_V4_FORKS
|
|
9
|
+
} from "./assets";
|
|
10
|
+
import { Call } from "../utils/multicall";
|
|
11
|
+
import { MulticallRetryFunction } from "../types";
|
|
12
|
+
import { FlashAbi } from "../abis/flashloan-united/flashAbi";
|
|
13
|
+
import { FlashLiquiditiesOnChain, FlashLoanIds } from "./types";
|
|
14
|
+
import { FLASH_LOAN_IDS } from "@1delta/dex-registry";
|
|
15
|
+
import { formatUnits, zeroAddress } from "viem";
|
|
16
|
+
import { AAVE_V2_LENDERS, AAVE_V3_LENDERS } from "@1delta/asset-registry";
|
|
17
|
+
import _ from "lodash"
|
|
18
|
+
import { MULTICALL_ADDRESS } from "../utils/constants";
|
|
19
|
+
|
|
20
|
+
const DEFAULT_BATCH_SIZE = 4096;
|
|
21
|
+
|
|
22
|
+
enum BalanceFetchCall {
|
|
23
|
+
balanceOf = "balanceOf",
|
|
24
|
+
getEthBalance = "getEthBalance"
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// Aave V3 flash loan flag enabled flag
|
|
28
|
+
const FLASHLOAN_ENABLED_MASK = BigInt('0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF7FFFFFFFFFFFFFFF');
|
|
29
|
+
function getFlashLoanEnabled(data: bigint): boolean {
|
|
30
|
+
return (data & ~FLASHLOAN_ENABLED_MASK) !== BigInt(0);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
export async function fetchFlashLiquidityForChain(
|
|
34
|
+
chain: string,
|
|
35
|
+
multicallRetry: MulticallRetryFunction
|
|
36
|
+
) {
|
|
37
|
+
|
|
38
|
+
let callLengths: { [l: string]: number } = {}
|
|
39
|
+
let aaveAssets: { [l: string]: string[] } = {}
|
|
40
|
+
|
|
41
|
+
let aaveCalls: Call[] = []
|
|
42
|
+
|
|
43
|
+
const aaveProtocols = AAVES_PER_CHAIN[chain] ?? []
|
|
44
|
+
|
|
45
|
+
// we only ned to check aave flash liquidity for aave assets
|
|
46
|
+
aaveProtocols.forEach(aaveFork => {
|
|
47
|
+
const underlyingsAndATokens = Object.entries(getAaveStyleProtocolTokenMap(chain, aaveFork))
|
|
48
|
+
|
|
49
|
+
const pool = getAaveTypePoolAddress(chain, aaveFork)
|
|
50
|
+
|
|
51
|
+
const tokenCalls = underlyingsAndATokens
|
|
52
|
+
.map(([a, b]: [string, any]) => [
|
|
53
|
+
{ name: BalanceFetchCall.balanceOf, address: a, args: [b.aToken] },
|
|
54
|
+
{ name: "getConfiguration", address: pool, args: [a] }
|
|
55
|
+
])
|
|
56
|
+
.reduce((acc, b) => [...acc, ...b], [])
|
|
57
|
+
|
|
58
|
+
aaveAssets[aaveFork] = underlyingsAndATokens.map(a => a[0])
|
|
59
|
+
|
|
60
|
+
callLengths[aaveFork] = tokenCalls.length * 2 + 1
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
aaveCalls = [
|
|
64
|
+
...aaveCalls,
|
|
65
|
+
...tokenCalls,
|
|
66
|
+
{ name: "FLASHLOAN_PREMIUM_TOTAL", address: pool },
|
|
67
|
+
]
|
|
68
|
+
})
|
|
69
|
+
|
|
70
|
+
// @ts-ignore
|
|
71
|
+
const morphoBs = RELEVANT_MORPHOB_FORKS[chain] ?? []
|
|
72
|
+
|
|
73
|
+
const otherAssets = RELEVANT_LENDING_ASSETS[chain] ?? []
|
|
74
|
+
|
|
75
|
+
let morphoCalls: Call[] = []
|
|
76
|
+
|
|
77
|
+
if (morphoBs && morphoBs.length > 0) {
|
|
78
|
+
morphoBs.forEach(bFork => {
|
|
79
|
+
callLengths[bFork.pool] = otherAssets.length
|
|
80
|
+
morphoCalls = [
|
|
81
|
+
...morphoCalls,
|
|
82
|
+
...otherAssets.map(address => address === zeroAddress ? ({
|
|
83
|
+
name: BalanceFetchCall.getEthBalance,
|
|
84
|
+
address: MULTICALL_ADDRESS[chain],
|
|
85
|
+
args: [bFork.address],
|
|
86
|
+
}) : ({ name: BalanceFetchCall.balanceOf, address, args: [bFork.address] }))
|
|
87
|
+
]
|
|
88
|
+
})
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
const balancerV2s = RELEVANT_BALANCER_V2_FORKS[chain] ?? []
|
|
92
|
+
|
|
93
|
+
let balancerV2Calls: Call[] = []
|
|
94
|
+
if (balancerV2s && balancerV2s.length > 0) {
|
|
95
|
+
balancerV2s.forEach(bFork => {
|
|
96
|
+
callLengths[bFork.pool] = otherAssets.length
|
|
97
|
+
balancerV2Calls = [
|
|
98
|
+
...balancerV2Calls,
|
|
99
|
+
...otherAssets.map(address => address === zeroAddress ? ({
|
|
100
|
+
name: BalanceFetchCall.getEthBalance,
|
|
101
|
+
address: MULTICALL_ADDRESS[chain],
|
|
102
|
+
args: [bFork.address],
|
|
103
|
+
}) : ({ name: BalanceFetchCall.balanceOf, address, args: [bFork.address] }))
|
|
104
|
+
]
|
|
105
|
+
})
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
const balancerV3s = RELEVANT_BALANCER_V3_FORKS[chain] ?? []
|
|
109
|
+
let balancerV3Calls: Call[] = []
|
|
110
|
+
if (balancerV3s && balancerV3s.length > 0) {
|
|
111
|
+
balancerV3s.forEach(bFork => {
|
|
112
|
+
callLengths[bFork.pool] = otherAssets.length
|
|
113
|
+
balancerV3Calls = [
|
|
114
|
+
...balancerV3Calls,
|
|
115
|
+
...otherAssets.map(address => address === zeroAddress ? ({
|
|
116
|
+
name: BalanceFetchCall.getEthBalance,
|
|
117
|
+
address: MULTICALL_ADDRESS[chain],
|
|
118
|
+
args: [bFork.address],
|
|
119
|
+
}) : ({ name: BalanceFetchCall.balanceOf, address, args: [bFork.address] }))
|
|
120
|
+
]
|
|
121
|
+
})
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
const uniswapV4s = RELEVANT_UNISWAP_V4_FORKS[chain] ?? []
|
|
125
|
+
let uniswapV4Calls: Call[] = []
|
|
126
|
+
if (uniswapV4s && uniswapV4s.length > 0) {
|
|
127
|
+
uniswapV4s.forEach(u4Fork => {
|
|
128
|
+
callLengths[u4Fork.pool] = otherAssets.length
|
|
129
|
+
uniswapV4Calls = [
|
|
130
|
+
...uniswapV4Calls,
|
|
131
|
+
...otherAssets.map(address => address === zeroAddress ? ({
|
|
132
|
+
name: BalanceFetchCall.getEthBalance,
|
|
133
|
+
address: MULTICALL_ADDRESS[chain],
|
|
134
|
+
args: [u4Fork.address],
|
|
135
|
+
}) : ({ name: BalanceFetchCall.balanceOf, address, args: [u4Fork.address] }))
|
|
136
|
+
]
|
|
137
|
+
})
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
const calls = [
|
|
141
|
+
...aaveCalls,
|
|
142
|
+
...balancerV2Calls,
|
|
143
|
+
...morphoCalls,
|
|
144
|
+
...balancerV3Calls,
|
|
145
|
+
...uniswapV4Calls,
|
|
146
|
+
]
|
|
147
|
+
|
|
148
|
+
const rawResults = await multicallRetry(
|
|
149
|
+
chain,
|
|
150
|
+
calls,
|
|
151
|
+
FlashAbi,
|
|
152
|
+
DEFAULT_BATCH_SIZE,
|
|
153
|
+
3,
|
|
154
|
+
0,
|
|
155
|
+
false
|
|
156
|
+
)
|
|
157
|
+
|
|
158
|
+
let liquidity: FlashLiquiditiesOnChain = {}
|
|
159
|
+
|
|
160
|
+
let currentOffset = 0
|
|
161
|
+
aaveProtocols.forEach(aave => {
|
|
162
|
+
const callLen = aaveAssets[aave].length * 2 + 1
|
|
163
|
+
|
|
164
|
+
const data: any[] = rawResults.slice(currentOffset, callLen + currentOffset)
|
|
165
|
+
const fee = data[callLen - 1]
|
|
166
|
+
// update offset
|
|
167
|
+
currentOffset += callLen;
|
|
168
|
+
|
|
169
|
+
|
|
170
|
+
aaveAssets[aave].forEach((asset, i) => {
|
|
171
|
+
const decimals = getAssetMeta(chain, asset)?.decimals
|
|
172
|
+
const rawAmount = data[2 * i]
|
|
173
|
+
|
|
174
|
+
const config = data[2 * i + 1]
|
|
175
|
+
const enabled = !AAVE_V3_LENDERS.includes(aave as any) || getFlashLoanEnabled(config)
|
|
176
|
+
if (enabled && rawAmount > 0n) {
|
|
177
|
+
if (!liquidity[asset]) liquidity[asset] = []
|
|
178
|
+
liquidity[asset].push({
|
|
179
|
+
id: FLASH_LOAN_IDS[aave],
|
|
180
|
+
name: aave,
|
|
181
|
+
type: AAVE_V2_LENDERS.includes(aave as any) ? FlashLoanIds.AAVE_V2 : FlashLoanIds.AAVE_V3,
|
|
182
|
+
source: getAaveTypePoolAddress(chain, aave),
|
|
183
|
+
fee: fee.toString(),
|
|
184
|
+
availableRaw: rawAmount.toString(),
|
|
185
|
+
available: Number(formatUnits(rawAmount, decimals ?? 18))
|
|
186
|
+
})
|
|
187
|
+
}
|
|
188
|
+
})
|
|
189
|
+
})
|
|
190
|
+
|
|
191
|
+
|
|
192
|
+
balancerV2s.forEach(balancer => {
|
|
193
|
+
const callLen = otherAssets.length
|
|
194
|
+
|
|
195
|
+
const data: any[] = rawResults.slice(currentOffset, callLen + currentOffset)
|
|
196
|
+
// update offset
|
|
197
|
+
currentOffset += callLen;
|
|
198
|
+
|
|
199
|
+
|
|
200
|
+
otherAssets.forEach((asset, i) => {
|
|
201
|
+
const decimals = getAssetMeta(chain, asset)?.decimals
|
|
202
|
+
const rawAmount = data[i]
|
|
203
|
+
if (rawAmount > 0n) {
|
|
204
|
+
if (!liquidity[asset]) liquidity[asset] = []
|
|
205
|
+
liquidity[asset].push({
|
|
206
|
+
id: FLASH_LOAN_IDS[balancer.pool],
|
|
207
|
+
name: balancer.pool,
|
|
208
|
+
type: FlashLoanIds.BALANCER_V2,
|
|
209
|
+
source: balancer.address,
|
|
210
|
+
fee: "0",
|
|
211
|
+
availableRaw: rawAmount.toString(),
|
|
212
|
+
available: Number(formatUnits(rawAmount, decimals ?? 18))
|
|
213
|
+
})
|
|
214
|
+
}
|
|
215
|
+
})
|
|
216
|
+
})
|
|
217
|
+
|
|
218
|
+
|
|
219
|
+
|
|
220
|
+
morphoBs.forEach(morpho => {
|
|
221
|
+
const callLen = otherAssets.length
|
|
222
|
+
|
|
223
|
+
const data: any[] = rawResults.slice(currentOffset, callLen + currentOffset)
|
|
224
|
+
// update offset
|
|
225
|
+
currentOffset += callLen;
|
|
226
|
+
|
|
227
|
+
|
|
228
|
+
otherAssets.forEach((asset, i) => {
|
|
229
|
+
const decimals = getAssetMeta(chain, asset)?.decimals
|
|
230
|
+
const rawAmount = data[i]
|
|
231
|
+
if (rawAmount > 0n) {
|
|
232
|
+
if (!liquidity[asset]) liquidity[asset] = []
|
|
233
|
+
liquidity[asset].push({
|
|
234
|
+
id: FLASH_LOAN_IDS[morpho.pool],
|
|
235
|
+
name: morpho.pool,
|
|
236
|
+
type: FlashLoanIds.MORPHO,
|
|
237
|
+
source: morpho.address,
|
|
238
|
+
fee: "0",
|
|
239
|
+
availableRaw: rawAmount.toString(),
|
|
240
|
+
available: Number(formatUnits(rawAmount, decimals ?? 18))
|
|
241
|
+
})
|
|
242
|
+
}
|
|
243
|
+
})
|
|
244
|
+
})
|
|
245
|
+
|
|
246
|
+
balancerV3s.forEach(balancerV3 => {
|
|
247
|
+
const callLen = otherAssets.length
|
|
248
|
+
|
|
249
|
+
const data: any[] = rawResults.slice(currentOffset, callLen + currentOffset)
|
|
250
|
+
// update offset
|
|
251
|
+
currentOffset += callLen;
|
|
252
|
+
|
|
253
|
+
|
|
254
|
+
otherAssets.forEach((asset, i) => {
|
|
255
|
+
const decimals = getAssetMeta(chain, asset)?.decimals
|
|
256
|
+
const rawAmount = data[i]
|
|
257
|
+
if (rawAmount > 0n) {
|
|
258
|
+
if (!liquidity[asset]) liquidity[asset] = []
|
|
259
|
+
liquidity[asset].push({
|
|
260
|
+
id: FLASH_LOAN_IDS[balancerV3.pool],
|
|
261
|
+
name: balancerV3.pool,
|
|
262
|
+
type: FlashLoanIds.SINGLETON,
|
|
263
|
+
source: balancerV3.address,
|
|
264
|
+
fee: "0",
|
|
265
|
+
availableRaw: rawAmount.toString(),
|
|
266
|
+
available: Number(formatUnits(rawAmount, decimals ?? 18))
|
|
267
|
+
})
|
|
268
|
+
}
|
|
269
|
+
})
|
|
270
|
+
})
|
|
271
|
+
|
|
272
|
+
uniswapV4s.forEach(uniV4 => {
|
|
273
|
+
const callLen = otherAssets.length
|
|
274
|
+
|
|
275
|
+
const data: any[] = rawResults.slice(currentOffset, callLen + currentOffset)
|
|
276
|
+
// update offset
|
|
277
|
+
currentOffset += callLen;
|
|
278
|
+
|
|
279
|
+
|
|
280
|
+
otherAssets.forEach((asset, i) => {
|
|
281
|
+
const decimals = getAssetMeta(chain, asset)?.decimals
|
|
282
|
+
const rawAmount = data[i]
|
|
283
|
+
if (rawAmount > 0n) {
|
|
284
|
+
if (!liquidity[asset]) liquidity[asset] = []
|
|
285
|
+
liquidity[asset].push({
|
|
286
|
+
id: FLASH_LOAN_IDS[uniV4.pool],
|
|
287
|
+
name: uniV4.pool,
|
|
288
|
+
type: FlashLoanIds.SINGLETON,
|
|
289
|
+
source: uniV4.address,
|
|
290
|
+
fee: "0",
|
|
291
|
+
availableRaw: rawAmount.toString(),
|
|
292
|
+
available: Number(formatUnits(rawAmount, decimals ?? 18))
|
|
293
|
+
})
|
|
294
|
+
}
|
|
295
|
+
})
|
|
296
|
+
})
|
|
297
|
+
|
|
298
|
+
return liquidity;
|
|
299
|
+
|
|
300
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./fetchLiquidity"
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export enum FlashLoanIds {
|
|
2
|
+
MORPHO = 0,
|
|
3
|
+
BALANCER_V2 = 1,
|
|
4
|
+
AAVE_V3 = 2,
|
|
5
|
+
AAVE_V2 = 3,
|
|
6
|
+
SINGLETON = "SINGLETON"
|
|
7
|
+
}
|
|
8
|
+
export interface FlashLoanLiquidityForAsset {
|
|
9
|
+
id: number
|
|
10
|
+
type: FlashLoanIds
|
|
11
|
+
name: string
|
|
12
|
+
source: string
|
|
13
|
+
fee: string
|
|
14
|
+
availableRaw: string
|
|
15
|
+
available: number
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export type FlashLiquiditiesOnChain = { [asset: string]: FlashLoanLiquidityForAsset[] }
|
|
19
|
+
|
|
20
|
+
export type FlashLiquidity = { [chain: string]: FlashLiquiditiesOnChain }
|
package/src/index.ts
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from "./lending"
|
|
2
|
+
export * from "./lending-pairs"
|
|
3
|
+
export * from "./yields"
|
|
4
|
+
export * from "./prices"
|
|
5
|
+
export * from "./utils"
|
|
6
|
+
export * from "./flash-liquidity"
|
|
7
|
+
export type { MulticallRetryFunction, GetEvmClientFunction, ProviderDependencies, OptionalProviderDependencies } from "./types/providers"
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Chain, WRAPPED_NATIVE_INFO } from "@1delta/asset-registry";
|
|
2
|
+
|
|
3
|
+
export const AURELIUS_REWARD_ASSETS = [WRAPPED_NATIVE_INFO[Chain.MANTLE], {
|
|
4
|
+
chainId: Chain.MANTLE,
|
|
5
|
+
address: '0x6e20E155819f0ee08d1291b0b9889b0e011b8224',
|
|
6
|
+
decimals: 18,
|
|
7
|
+
symbol: 'oAU',
|
|
8
|
+
name: 'Aurelius Call Option Token',
|
|
9
|
+
}]
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
|
|
2
|
+
import { AURELIUS_REWARD_ASSETS } from "./misc";
|
|
3
|
+
import { getAaveAssets, getAaveStyleProtocolTokenMap, getAaveTypePoolDataProviderAddress } from "../../assets";
|
|
4
|
+
import { Lender } from "@1delta/asset-registry";
|
|
5
|
+
import { getAaveTypeIncentivesControllerAddress } from "../addresses";
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
export const buildAaveV2StyleLenderReserveCall = (chainId: string, lender: Lender) => {
|
|
9
|
+
const providerAddress = getAaveTypePoolDataProviderAddress(chainId, lender)
|
|
10
|
+
const underlyingTokensArray = getAaveAssets(chainId, lender)
|
|
11
|
+
switch (lender) {
|
|
12
|
+
case Lender.AURELIUS: {
|
|
13
|
+
const aaveprotocolTokens = getAaveStyleProtocolTokenMap(chainId, lender)
|
|
14
|
+
const incentivesController = getAaveTypeIncentivesControllerAddress(chainId, lender)
|
|
15
|
+
const [reward0, reward1] = AURELIUS_REWARD_ASSETS.map(t => t.address)
|
|
16
|
+
return [
|
|
17
|
+
...underlyingTokensArray.flatMap(asset => [
|
|
18
|
+
{
|
|
19
|
+
address: providerAddress,
|
|
20
|
+
name: 'getReserveData',
|
|
21
|
+
params: [asset],
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
address: providerAddress,
|
|
25
|
+
name: 'getReserveConfigurationData',
|
|
26
|
+
params: [asset],
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
address: incentivesController,
|
|
30
|
+
name: 'getRewardsData',
|
|
31
|
+
params: [aaveprotocolTokens[asset].aToken, reward0],
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
address: incentivesController,
|
|
35
|
+
name: 'getRewardsData',
|
|
36
|
+
params: [aaveprotocolTokens[asset].aToken, reward1],
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
address: incentivesController,
|
|
40
|
+
name: 'getRewardsData',
|
|
41
|
+
params: [aaveprotocolTokens[asset].vToken, reward0],
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
address: incentivesController,
|
|
45
|
+
name: 'getRewardsData',
|
|
46
|
+
params: [aaveprotocolTokens[asset].vToken, reward1],
|
|
47
|
+
},
|
|
48
|
+
]),
|
|
49
|
+
]
|
|
50
|
+
}
|
|
51
|
+
case Lender.LENDLE: {
|
|
52
|
+
const incentivesController = getAaveTypeIncentivesControllerAddress(chainId, lender)
|
|
53
|
+
const aaveprotocolTokens = getAaveStyleProtocolTokenMap(chainId, lender)
|
|
54
|
+
return [
|
|
55
|
+
...underlyingTokensArray.flatMap(asset => [
|
|
56
|
+
{
|
|
57
|
+
address: providerAddress,
|
|
58
|
+
name: 'getReserveData',
|
|
59
|
+
params: [asset],
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
address: providerAddress,
|
|
63
|
+
name: 'getReserveConfigurationData',
|
|
64
|
+
params: [asset],
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
address: incentivesController,
|
|
68
|
+
name: 'poolInfo',
|
|
69
|
+
params: [aaveprotocolTokens[asset].aToken],
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
address: incentivesController,
|
|
73
|
+
name: 'poolInfo',
|
|
74
|
+
params: [aaveprotocolTokens[asset].vToken],
|
|
75
|
+
}
|
|
76
|
+
]),
|
|
77
|
+
{
|
|
78
|
+
address: incentivesController,
|
|
79
|
+
name: 'rewardsPerSecond',
|
|
80
|
+
params: []
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
address: incentivesController,
|
|
84
|
+
name: 'totalAllocPoint',
|
|
85
|
+
params: []
|
|
86
|
+
},
|
|
87
|
+
]
|
|
88
|
+
}
|
|
89
|
+
default:
|
|
90
|
+
return [
|
|
91
|
+
...underlyingTokensArray.flatMap(tk => [
|
|
92
|
+
{
|
|
93
|
+
address: providerAddress,
|
|
94
|
+
name: 'getReserveData',
|
|
95
|
+
params: [tk],
|
|
96
|
+
},
|
|
97
|
+
{
|
|
98
|
+
address: providerAddress,
|
|
99
|
+
name: 'getReserveConfigurationData',
|
|
100
|
+
params: [tk],
|
|
101
|
+
},
|
|
102
|
+
]),
|
|
103
|
+
]
|
|
104
|
+
}
|
|
105
|
+
}
|