@gearbox-protocol/sdk 3.0.0-next.8 → 3.0.0-next.80
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/contracts/index.sol +35 -4
- package/lib/apy/curveAPY.js +2 -1
- package/lib/apy/index.d.ts +2 -2
- package/lib/apy/yearnAPY.js +1 -1
- package/lib/core/assets.d.ts +4 -4
- package/lib/core/assets.js +28 -17
- package/lib/core/creditAccount.d.ts +33 -9
- package/lib/core/creditAccount.js +102 -46
- package/lib/core/creditAccount.spec.js +703 -10
- package/lib/core/creditManager.d.ts +13 -3
- package/lib/core/creditManager.js +48 -9
- package/lib/core/events.js +16 -16
- package/lib/core/gauge.d.ts +26 -0
- package/lib/core/gauge.js +63 -0
- package/lib/core/gaugeMath.d.ts +40 -0
- package/lib/core/gaugeMath.js +108 -0
- package/lib/core/gaugeMath.spec.d.ts +1 -0
- package/lib/core/gaugeMath.spec.js +388 -0
- package/lib/core/{pool/data.d.ts → pool.d.ts} +18 -10
- package/lib/core/{pool/data.js → pool.js} +68 -24
- package/lib/core/strategy.d.ts +5 -4
- package/lib/core/strategy.js +16 -15
- package/lib/core/strategy.spec.js +69 -19
- package/lib/core/trade.d.ts +9 -8
- package/lib/core/trade.js +32 -25
- package/lib/core/transactions.d.ts +65 -3
- package/lib/core/transactions.js +165 -108
- package/lib/index.d.ts +3 -0
- package/lib/index.js +3 -0
- package/lib/parsers/abstractParser.js +1 -2
- package/lib/parsers/convexBaseRewardPoolAdapterParser.js +10 -8
- package/lib/parsers/convexBaseRewardPoolAdapterParser.spec.js +9 -6
- package/lib/parsers/convexBoosterAdapterParser.js +6 -6
- package/lib/parsers/convexBoosterAdapterParser.spec.js +4 -4
- package/lib/parsers/creditFacadeParser.d.ts +2 -1
- package/lib/parsers/creditFacadeParser.js +44 -5
- package/lib/parsers/creditFacadeParser.spec.js +3 -4
- package/lib/parsers/curveAdapterParser.js +10 -11
- package/lib/parsers/curveAdapterParser.spec.js +6 -2
- package/lib/parsers/lidoAdapterParser.js +3 -2
- package/lib/parsers/lidoAdapterParser.spec.js +2 -2
- package/lib/parsers/txParser.d.ts +1 -1
- package/lib/parsers/txParser.js +9 -3
- package/lib/parsers/uniV2AdapterParser.js +5 -4
- package/lib/parsers/uniV2AdapterParser.spec.js +3 -2
- package/lib/parsers/uniV3AdapterParser.js +9 -7
- package/lib/parsers/uniV3AdapterParser.spec.js +3 -2
- package/lib/parsers/wstETHAdapterParser.js +6 -4
- package/lib/parsers/wstETHAdapterParser.spec.js +4 -4
- package/lib/parsers/yearnAdapterParser.spec.js +4 -4
- package/lib/parsers/yearnV2AdapterParser.js +13 -3
- package/lib/pathfinder/core.d.ts +8 -9
- package/lib/pathfinder/pathOptions.d.ts +2 -1
- package/lib/pathfinder/pathOptions.js +20 -1
- package/lib/pathfinder/pathOptions.spec.js +2 -2
- package/lib/pathfinder/pathfinder.d.ts +44 -16
- package/lib/pathfinder/pathfinder.js +58 -39
- package/lib/pathfinder/pathfinder.spec.js +7 -3
- package/lib/payload/creditAccount.d.ts +3 -4
- package/lib/payload/gauge.d.ts +12 -0
- package/lib/payload/pool.d.ts +7 -1
- package/lib/types/CalldataExtractor.d.ts +44 -0
- package/lib/types/FarmAccounting.d.ts +27 -0
- package/lib/types/IAaveV2_LendingPoolAdapter.d.ts +171 -0
- package/lib/types/IAaveV2_WrappedATokenAdapter.d.ts +290 -0
- package/lib/types/IBalancerV2Vault.sol/IBalancerV2Vault.d.ts +308 -0
- package/lib/types/IBalancerV2Vault.sol/IBalancerV2VaultGetters.d.ts +112 -0
- package/lib/types/IBalancerV2Vault.sol/index.d.ts +2 -0
- package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter.d.ts +466 -0
- package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents.d.ts +43 -0
- package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions.d.ts +27 -0
- package/lib/types/IBalancerV2VaultAdapter.sol/index.d.ts +3 -0
- package/lib/types/IBotListV3.sol/IBotListV3.d.ts +286 -0
- package/lib/types/IBotListV3.sol/IBotListV3Events.d.ts +103 -0
- package/lib/types/IBotListV3.sol/index.d.ts +2 -0
- package/lib/types/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter.d.ts +216 -0
- package/lib/types/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions.d.ts +27 -0
- package/lib/types/ICompoundV2_CTokenAdapter.sol/index.d.ts +2 -0
- package/lib/types/IContractsRegister.sol/IContractsRegister.d.ts +128 -0
- package/lib/types/IContractsRegister.sol/IContractsRegisterEvents.d.ts +50 -0
- package/lib/types/IContractsRegister.sol/index.d.ts +2 -0
- package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3.d.ts +504 -0
- package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3Events.d.ts +82 -0
- package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3Events.js +2 -0
- package/lib/types/IControllerTimelockV3.sol/index.d.ts +2 -0
- package/lib/types/IControllerTimelockV3.sol/index.js +2 -0
- package/lib/types/IConvexToken.d.ts +9 -1
- package/lib/types/IConvexV1BaseRewardPoolAdapter.d.ts +46 -30
- package/lib/types/{IConvexV1BoosterAdapter.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter.d.ts} +40 -21
- package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter.js +2 -0
- package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents.d.ts +43 -0
- package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents.js +2 -0
- package/lib/types/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
- package/lib/types/IConvexV1BoosterAdapter.sol/index.js +2 -0
- package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3.d.ts +716 -0
- package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3.js +2 -0
- package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events.d.ts +275 -0
- package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events.js +2 -0
- package/lib/types/ICreditConfiguratorV3.sol/index.d.ts +2 -0
- package/lib/types/ICreditConfiguratorV3.sol/index.js +2 -0
- package/lib/types/ICreditFacadeV2.sol/ICreditFacadeV2Extended.d.ts +7 -11
- package/lib/types/ICreditFacadeV3.sol/ICreditFacadeV3.d.ts +193 -96
- package/lib/types/ICreditFacadeV3.sol/ICreditFacadeV3Events.d.ts +31 -35
- package/lib/types/ICreditFacadeV3Multicall.d.ts +91 -60
- package/lib/types/ICreditManagerV3.sol/ICreditManagerV3.d.ts +360 -106
- package/lib/types/ICurveV1Adapter.d.ts +41 -105
- package/lib/types/ICurveV1_2AssetsAdapter.d.ts +41 -105
- package/lib/types/ICurveV1_3AssetsAdapter.d.ts +41 -105
- package/lib/types/ICurveV1_4AssetsAdapter.d.ts +41 -105
- package/lib/types/IDataCompressorV2_10.d.ts +44 -39
- package/lib/types/IDataCompressorV3_00.d.ts +141 -40
- package/lib/types/IDegenNFTV2.sol/IDegenNFTV2.d.ts +339 -0
- package/lib/types/IDegenNFTV2.sol/IDegenNFTV2.js +2 -0
- package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Events.d.ts +61 -0
- package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Events.js +2 -0
- package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Exceptions.d.ts +27 -0
- package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Exceptions.js +2 -0
- package/lib/types/IDegenNFTV2.sol/index.d.ts +3 -0
- package/lib/types/IDegenNFTV2.sol/index.js +2 -0
- package/lib/types/IERC165.d.ts +42 -0
- package/lib/types/IERC165.js +2 -0
- package/lib/types/{draft-IERC20Permit.sol/IERC20Permit.d.ts → IERC20Permit.d.ts} +1 -1
- package/lib/types/IERC20Permit.js +2 -0
- package/lib/types/IERC20ZapperDeposits.d.ts +117 -0
- package/lib/types/IERC20ZapperDeposits.js +2 -0
- package/lib/types/IERC4626Adapter.d.ts +238 -0
- package/lib/types/IERC4626Adapter.js +2 -0
- package/lib/types/IERC721.d.ts +220 -0
- package/lib/types/IERC721.js +2 -0
- package/lib/types/IERC721Metadata.d.ts +244 -0
- package/lib/types/IERC721Metadata.js +2 -0
- package/lib/types/IETHZapperDeposits.d.ts +66 -0
- package/lib/types/IETHZapperDeposits.js +2 -0
- package/lib/types/{AaveV2_WrappedAToken.sol/WrappedAToken.d.ts → IFarmingPool.d.ts} +131 -145
- package/lib/types/IFarmingPool.js +2 -0
- package/lib/types/IGasPricer.d.ts +44 -0
- package/lib/types/IGasPricer.js +2 -0
- package/lib/types/IGaugeV3.sol/IGaugeV3.d.ts +366 -0
- package/lib/types/IGaugeV3.sol/IGaugeV3.js +2 -0
- package/lib/types/IGaugeV3.sol/IGaugeV3Events.d.ts +114 -0
- package/lib/types/IGaugeV3.sol/IGaugeV3Events.js +2 -0
- package/lib/types/IGaugeV3.sol/index.d.ts +2 -0
- package/lib/types/IGaugeV3.sol/index.js +2 -0
- package/lib/types/IGearStakingV3.sol/IGearStakingV3.d.ts +408 -0
- package/lib/types/IGearStakingV3.sol/IGearStakingV3.js +2 -0
- package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.d.ts +117 -0
- package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.js +2 -0
- package/lib/types/IGearStakingV3.sol/index.d.ts +2 -0
- package/lib/types/IGearStakingV3.sol/index.js +2 -0
- package/lib/types/ILPPriceFeed.sol/ILPPriceFeed.d.ts +285 -0
- package/lib/types/ILPPriceFeed.sol/ILPPriceFeed.js +2 -0
- package/lib/types/ILPPriceFeed.sol/ILPPriceFeedEvents.d.ts +54 -0
- package/lib/types/ILPPriceFeed.sol/ILPPriceFeedEvents.js +2 -0
- package/lib/types/ILPPriceFeed.sol/ILPPriceFeedExceptions.d.ts +27 -0
- package/lib/types/ILPPriceFeed.sol/ILPPriceFeedExceptions.js +2 -0
- package/lib/types/ILPPriceFeed.sol/index.d.ts +3 -0
- package/lib/types/ILPPriceFeed.sol/index.js +2 -0
- package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.d.ts → ILidoV1Adapter.d.ts} +13 -48
- package/lib/types/ILidoV1Adapter.js +2 -0
- package/lib/types/ILinearInterestRateModelV3.d.ts +120 -0
- package/lib/types/ILinearInterestRateModelV3.js +2 -0
- package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3.d.ts +473 -0
- package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3.js +2 -0
- package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events.d.ts +113 -0
- package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events.js +2 -0
- package/lib/types/IPoolQuotaKeeperV3.sol/index.d.ts +2 -0
- package/lib/types/IPoolQuotaKeeperV3.sol/index.js +2 -0
- package/lib/types/IPoolV3.sol/IPoolV3.d.ts +43 -11
- package/lib/types/IPoolV3.sol/index.d.ts +0 -1
- package/lib/types/IPriceFeed.sol/IPriceFeed.d.ts +109 -0
- package/lib/types/IPriceFeed.sol/IPriceFeed.js +2 -0
- package/lib/types/IPriceFeed.sol/IUpdatablePriceFeed.d.ts +133 -0
- package/lib/types/IPriceFeed.sol/IUpdatablePriceFeed.js +2 -0
- package/lib/types/IPriceFeed.sol/index.d.ts +2 -0
- package/lib/types/IPriceFeed.sol/index.js +2 -0
- package/lib/types/IPriceOracle.sol/IPriceOracleV2.d.ts +166 -0
- package/lib/types/IPriceOracle.sol/IPriceOracleV2.js +2 -0
- package/lib/types/IPriceOracle.sol/IPriceOracleV2Events.d.ts +43 -0
- package/lib/types/IPriceOracle.sol/IPriceOracleV2Events.js +2 -0
- package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.d.ts → IPriceOracle.sol/IPriceOracleV2Exceptions.d.ts} +3 -3
- package/lib/types/IPriceOracle.sol/IPriceOracleV2Exceptions.js +2 -0
- package/lib/types/IPriceOracle.sol/IPriceOracleV2Ext.d.ts +182 -0
- package/lib/types/IPriceOracle.sol/IPriceOracleV2Ext.js +2 -0
- package/lib/types/IPriceOracle.sol/index.d.ts +4 -0
- package/lib/types/IPriceOracle.sol/index.js +2 -0
- package/lib/types/IPriceOracleV3.sol/IPriceOracleV3.d.ts +272 -0
- package/lib/types/IPriceOracleV3.sol/IPriceOracleV3.js +2 -0
- package/lib/types/IPriceOracleV3.sol/IPriceOracleV3Events.d.ts +79 -0
- package/lib/types/IPriceOracleV3.sol/IPriceOracleV3Events.js +2 -0
- package/lib/types/IPriceOracleV3.sol/index.d.ts +2 -0
- package/lib/types/IPriceOracleV3.sol/index.js +2 -0
- package/lib/types/{IRouter.d.ts → IRouterV3.d.ts} +50 -37
- package/lib/types/IRouterV3.js +2 -0
- package/lib/types/IUniswapV2Adapter.sol/IUniswapV2Adapter.d.ts +10 -9
- package/lib/types/IUniswapV3Adapter.sol/IUniswapV3Adapter.d.ts +27 -21
- package/lib/types/IVotingContractV3.d.ts +74 -0
- package/lib/types/IVotingContractV3.js +2 -0
- package/lib/types/IYearnV2Adapter.d.ts +22 -22
- package/lib/types/IZapper.d.ts +125 -0
- package/lib/types/IZapper.js +2 -0
- package/lib/types/IZapperRegister.d.ts +62 -0
- package/lib/types/IZapperRegister.js +2 -0
- package/lib/types/IwstETHV1Adapter.d.ts +17 -17
- package/lib/types/NumericArrayLib.d.ts +27 -0
- package/lib/types/NumericArrayLib.js +2 -0
- package/lib/types/RedstoneConstants.d.ts +27 -0
- package/lib/types/RedstoneConstants.js +2 -0
- package/lib/types/RedstoneConsumerBase.d.ts +84 -0
- package/lib/types/RedstoneConsumerBase.js +2 -0
- package/lib/types/RedstoneConsumerNumericBase.d.ts +84 -0
- package/lib/types/RedstoneConsumerNumericBase.js +2 -0
- package/lib/types/RedstoneDefaultsLib.d.ts +27 -0
- package/lib/types/RedstoneDefaultsLib.js +2 -0
- package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.d.ts → RedstonePriceFeed.sol/IRedstonePriceFeedEvents.d.ts} +11 -11
- package/lib/types/RedstonePriceFeed.sol/IRedstonePriceFeedEvents.js +2 -0
- package/lib/types/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions.d.ts +27 -0
- package/lib/types/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions.js +2 -0
- package/lib/types/RedstonePriceFeed.sol/RedstonePriceFeed.d.ts +279 -0
- package/lib/types/RedstonePriceFeed.sol/RedstonePriceFeed.js +2 -0
- package/lib/types/RedstonePriceFeed.sol/index.d.ts +3 -0
- package/lib/types/RedstonePriceFeed.sol/index.js +2 -0
- package/lib/types/factories/AddressProvider__factory.d.ts +1 -1
- package/lib/types/factories/AddressProvider__factory.js +1 -1
- package/lib/types/factories/Balances.sol/BalanceOps__factory.d.ts +1 -1
- package/lib/types/factories/Balances.sol/BalanceOps__factory.js +1 -1
- package/lib/types/factories/CalldataExtractor__factory.d.ts +87 -0
- package/lib/types/factories/CalldataExtractor__factory.js +127 -0
- package/lib/types/factories/Claimable__factory.d.ts +1 -1
- package/lib/types/factories/Claimable__factory.js +1 -1
- package/lib/types/factories/ERC20__factory.d.ts +1 -1
- package/lib/types/factories/ERC20__factory.js +1 -1
- package/lib/types/factories/Errors__factory.d.ts +1 -1
- package/lib/types/factories/Errors__factory.js +1 -1
- package/lib/types/factories/FarmAccounting__factory.d.ts +33 -0
- package/lib/types/factories/FarmAccounting__factory.js +57 -0
- package/lib/types/factories/IAaveV2_LendingPoolAdapter__factory.d.ts +158 -0
- package/lib/types/factories/IAaveV2_LendingPoolAdapter__factory.js +215 -0
- package/lib/types/factories/IAaveV2_WrappedATokenAdapter__factory.d.ts +252 -0
- package/lib/types/factories/IAaveV2_WrappedATokenAdapter__factory.js +341 -0
- package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2VaultGetters__factory.d.ts +78 -0
- package/lib/types/factories/{ZapperBase__factory.js → IBalancerV2Vault.sol/IBalancerV2VaultGetters__factory.js} +54 -31
- package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2Vault__factory.d.ts +360 -0
- package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2Vault__factory.js +475 -0
- package/lib/types/factories/IBalancerV2Vault.sol/index.d.ts +2 -0
- package/lib/types/factories/IBalancerV2Vault.sol/index.js +10 -0
- package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents__factory.d.ts +23 -0
- package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents__factory.js +38 -0
- package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions__factory.d.ts +12 -0
- package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions__factory.js} +4 -4
- package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter__factory.d.ts +514 -0
- package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter__factory.js +675 -0
- package/lib/types/factories/IBalancerV2VaultAdapter.sol/index.d.ts +3 -0
- package/lib/types/factories/IBalancerV2VaultAdapter.sol/index.js +12 -0
- package/lib/types/factories/IBotListV3.sol/IBotListV3Events__factory.d.ts +103 -0
- package/lib/types/factories/IBotListV3.sol/IBotListV3Events__factory.js +138 -0
- package/lib/types/factories/IBotListV3.sol/IBotListV3__factory.d.ts +315 -0
- package/lib/types/factories/IBotListV3.sol/IBotListV3__factory.js +416 -0
- package/lib/types/factories/IBotListV3.sol/index.d.ts +2 -0
- package/lib/types/factories/IBotListV3.sol/index.js +10 -0
- package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter__factory.d.ts +196 -0
- package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter__factory.js +267 -0
- package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions__factory.d.ts +16 -0
- package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions__factory.js +30 -0
- package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/index.d.ts +2 -0
- package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/index.js +10 -0
- package/lib/types/factories/IContractsRegister.sol/IContractsRegisterEvents__factory.d.ts +28 -0
- package/lib/types/factories/IContractsRegister.sol/IContractsRegisterEvents__factory.js +45 -0
- package/lib/types/factories/IContractsRegister.sol/IContractsRegister__factory.d.ts +134 -0
- package/lib/types/factories/IContractsRegister.sol/IContractsRegister__factory.js +186 -0
- package/lib/types/factories/IContractsRegister.sol/index.d.ts +2 -0
- package/lib/types/factories/IContractsRegister.sol/index.js +10 -0
- package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3Events__factory.d.ts +73 -0
- package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3Events__factory.js +101 -0
- package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3__factory.d.ts +427 -0
- package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3__factory.js +556 -0
- package/lib/types/factories/IControllerTimelockV3.sol/index.d.ts +2 -0
- package/lib/types/factories/IControllerTimelockV3.sol/index.js +10 -0
- package/lib/types/factories/IConvexToken__factory.d.ts +10 -0
- package/lib/types/factories/IConvexToken__factory.js +13 -0
- package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.d.ts +38 -6
- package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.js +48 -6
- package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.d.ts +23 -0
- package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.js +38 -0
- package/lib/types/factories/{IConvexV1BoosterAdapter__factory.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.d.ts} +26 -3
- package/lib/types/factories/{IConvexV1BoosterAdapter__factory.js → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.js} +31 -2
- package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
- package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.js +10 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.d.ts +273 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.js +357 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.d.ts +605 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.js +785 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/index.d.ts +2 -0
- package/lib/types/factories/ICreditConfiguratorV3.sol/index.js +10 -0
- package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.d.ts +0 -4
- package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.js +0 -5
- package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.d.ts +19 -29
- package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.js +21 -33
- package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.d.ts +141 -77
- package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.js +176 -91
- package/lib/types/factories/ICreditFacadeV3Multicall__factory.d.ts +77 -43
- package/lib/types/factories/ICreditFacadeV3Multicall__factory.js +96 -54
- package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.d.ts +337 -155
- package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.js +423 -189
- package/lib/types/factories/ICurveV1Adapter__factory.d.ts +13 -71
- package/lib/types/factories/ICurveV1Adapter__factory.js +14 -91
- package/lib/types/factories/ICurveV1_2AssetsAdapter__factory.d.ts +13 -71
- package/lib/types/factories/ICurveV1_2AssetsAdapter__factory.js +14 -91
- package/lib/types/factories/ICurveV1_3AssetsAdapter__factory.d.ts +13 -71
- package/lib/types/factories/ICurveV1_3AssetsAdapter__factory.js +14 -91
- package/lib/types/factories/ICurveV1_4AssetsAdapter__factory.d.ts +13 -71
- package/lib/types/factories/ICurveV1_4AssetsAdapter__factory.js +14 -91
- package/lib/types/factories/IDataCompressorV2_10__factory.d.ts +110 -62
- package/lib/types/factories/IDataCompressorV2_10__factory.js +138 -78
- package/lib/types/factories/IDataCompressorV3_00__factory.d.ts +375 -91
- package/lib/types/factories/IDataCompressorV3_00__factory.js +476 -115
- package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Events__factory.d.ts +38 -0
- package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Events__factory.js +58 -0
- package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Exceptions__factory.d.ts +24 -0
- package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Exceptions__factory.js +39 -0
- package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3__factory.d.ts → IDegenNFTV2.sol/IDegenNFTV2__factory.d.ts} +190 -180
- package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3__factory.js → IDegenNFTV2.sol/IDegenNFTV2__factory.js} +212 -195
- package/lib/types/factories/IDegenNFTV2.sol/index.d.ts +3 -0
- package/lib/types/factories/IDegenNFTV2.sol/index.js +12 -0
- package/lib/types/factories/IERC165__factory.d.ts +22 -0
- package/lib/types/factories/IERC165__factory.js +38 -0
- package/lib/types/factories/{draft-IERC20Permit.sol/IERC20Permit__factory.d.ts → IERC20Permit__factory.d.ts} +1 -1
- package/lib/types/factories/IERC20ZapperDeposits__factory.d.ts +120 -0
- package/lib/types/factories/IERC20ZapperDeposits__factory.js +165 -0
- package/lib/types/factories/IERC4626Adapter__factory.d.ts +220 -0
- package/lib/types/factories/IERC4626Adapter__factory.js +297 -0
- package/lib/types/factories/IERC721Metadata__factory.d.ts +262 -0
- package/lib/types/factories/IERC721Metadata__factory.js +349 -0
- package/lib/types/factories/IERC721__factory.d.ts +228 -0
- package/lib/types/factories/IERC721__factory.js +304 -0
- package/lib/types/factories/IETHZapperDeposits__factory.d.ts +40 -0
- package/lib/types/factories/{AaveV2_WrappedAToken.sol/IWrappedATokenEvents__factory.js → IETHZapperDeposits__factory.js} +18 -25
- package/lib/types/factories/IFarmingPool__factory.d.ts +299 -0
- package/lib/types/factories/IFarmingPool__factory.js +396 -0
- package/lib/types/factories/IGasPricer__factory.d.ts +22 -0
- package/lib/types/factories/IGasPricer__factory.js +38 -0
- package/lib/types/factories/IGaugeV3.sol/IGaugeV3Events__factory.d.ts +118 -0
- package/lib/types/factories/IGaugeV3.sol/IGaugeV3Events__factory.js +157 -0
- package/lib/types/factories/IGaugeV3.sol/IGaugeV3__factory.d.ts +342 -0
- package/lib/types/factories/IGaugeV3.sol/IGaugeV3__factory.js +448 -0
- package/lib/types/factories/IGaugeV3.sol/index.d.ts +2 -0
- package/lib/types/factories/IGaugeV3.sol/index.js +10 -0
- package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events__factory.d.ts → IGearStakingV3.sol/IGearStakingV3Events__factory.d.ts} +33 -63
- package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events__factory.js → IGearStakingV3.sol/IGearStakingV3Events__factory.js} +34 -70
- package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.d.ts +504 -0
- package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.js +660 -0
- package/lib/types/factories/IGearStakingV3.sol/index.d.ts +2 -0
- package/lib/types/factories/IGearStakingV3.sol/index.js +10 -0
- package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedEvents__factory.d.ts +33 -0
- package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedEvents__factory.js +51 -0
- package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedExceptions__factory.d.ts +28 -0
- package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedExceptions__factory.js +44 -0
- package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeed__factory.d.ts +261 -0
- package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeed__factory.js +344 -0
- package/lib/types/factories/ILPPriceFeed.sol/index.d.ts +3 -0
- package/lib/types/factories/ILPPriceFeed.sol/index.js +12 -0
- package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.d.ts → ILidoV1Adapter__factory.d.ts} +7 -37
- package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.js → ILidoV1Adapter__factory.js} +8 -46
- package/lib/types/factories/ILinearInterestRateModelV3__factory.d.ts +98 -0
- package/lib/types/factories/ILinearInterestRateModelV3__factory.js +136 -0
- package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events__factory.d.ts +103 -0
- package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events__factory.js +140 -0
- package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3__factory.d.ts +441 -0
- package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3__factory.js +580 -0
- package/lib/types/factories/IPoolQuotaKeeperV3.sol/index.d.ts +2 -0
- package/lib/types/factories/IPoolQuotaKeeperV3.sol/index.js +10 -0
- package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.d.ts +62 -14
- package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.js +79 -17
- package/lib/types/factories/IPoolV3.sol/index.d.ts +0 -1
- package/lib/types/factories/IPoolV3.sol/index.js +1 -3
- package/lib/types/factories/{IPoolV3.sol/IPoolBase__factory.d.ts → IPriceFeed.sol/IPriceFeed__factory.d.ts} +39 -35
- package/lib/types/factories/{IPoolV3.sol/IPoolBase__factory.js → IPriceFeed.sol/IPriceFeed__factory.js} +40 -35
- package/lib/types/factories/IPriceFeed.sol/IUpdatablePriceFeed__factory.d.ts +104 -0
- package/lib/types/factories/IPriceFeed.sol/IUpdatablePriceFeed__factory.js +143 -0
- package/lib/types/factories/IPriceFeed.sol/index.d.ts +2 -0
- package/lib/types/factories/IPriceFeed.sol/index.js +10 -0
- package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Events__factory.d.ts +23 -0
- package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Events__factory.js +38 -0
- package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Exceptions__factory.d.ts +20 -0
- package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Exceptions__factory.js +34 -0
- package/lib/types/factories/{IAToken__factory.d.ts → IPriceOracle.sol/IPriceOracleV2Ext__factory.d.ts} +98 -99
- package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Ext__factory.js +267 -0
- package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2__factory.d.ts +183 -0
- package/lib/types/factories/{IAToken__factory.js → IPriceOracle.sol/IPriceOracleV2__factory.js} +94 -112
- package/lib/types/factories/IPriceOracle.sol/index.d.ts +4 -0
- package/lib/types/factories/IPriceOracle.sol/index.js +14 -0
- package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3Events__factory.d.ts +78 -0
- package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3Events__factory.js +106 -0
- package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3__factory.d.ts +326 -0
- package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3__factory.js +433 -0
- package/lib/types/factories/IPriceOracleV3.sol/index.d.ts +2 -0
- package/lib/types/factories/IPriceOracleV3.sol/index.js +10 -0
- package/lib/types/factories/{IRouter__factory.d.ts → IRouterV3__factory.d.ts} +78 -9
- package/lib/types/factories/{IRouter__factory.js → IRouterV3__factory.js} +99 -9
- package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2Adapter__factory.d.ts +5 -1
- package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2Adapter__factory.js +6 -1
- package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3Adapter__factory.d.ts +12 -4
- package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3Adapter__factory.js +14 -4
- package/lib/types/factories/IVotingContractV3__factory.d.ts +44 -0
- package/lib/types/factories/IVotingContractV3__factory.js +65 -0
- package/lib/types/factories/IYearnV2Adapter__factory.d.ts +21 -13
- package/lib/types/factories/IYearnV2Adapter__factory.js +27 -15
- package/lib/types/factories/IZapperRegister__factory.d.ts +42 -0
- package/lib/types/factories/IZapperRegister__factory.js +64 -0
- package/lib/types/factories/{WERC20ZapperBase__factory.d.ts → IZapper__factory.d.ts} +52 -64
- package/lib/types/factories/{WERC20ZapperBase__factory.js → IZapper__factory.js} +58 -74
- package/lib/types/factories/IwstETHV1Adapter__factory.d.ts +12 -4
- package/lib/types/factories/IwstETHV1Adapter__factory.js +16 -4
- package/lib/types/factories/NumericArrayLib__factory.d.ts +25 -0
- package/lib/types/factories/NumericArrayLib__factory.js +47 -0
- package/lib/types/factories/RedstoneConstants__factory.d.ts +65 -0
- package/lib/types/factories/RedstoneConstants__factory.js +99 -0
- package/lib/types/factories/RedstoneConsumerBase__factory.d.ts +164 -0
- package/lib/types/factories/RedstoneConsumerBase__factory.js +223 -0
- package/lib/types/factories/RedstoneConsumerNumericBase__factory.d.ts +164 -0
- package/lib/types/factories/RedstoneConsumerNumericBase__factory.js +223 -0
- package/lib/types/factories/RedstoneDefaultsLib__factory.d.ts +45 -0
- package/lib/types/factories/RedstoneDefaultsLib__factory.js +74 -0
- package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.d.ts → RedstonePriceFeed.sol/IRedstonePriceFeedEvents__factory.d.ts} +6 -6
- package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.js → RedstonePriceFeed.sol/IRedstonePriceFeedEvents__factory.js} +5 -5
- package/lib/types/factories/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions__factory.d.ts +28 -0
- package/lib/types/factories/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions__factory.js +44 -0
- package/lib/types/factories/RedstonePriceFeed.sol/RedstonePriceFeed__factory.d.ts +443 -0
- package/lib/types/factories/RedstonePriceFeed.sol/RedstonePriceFeed__factory.js +589 -0
- package/lib/types/factories/RedstonePriceFeed.sol/index.d.ts +3 -0
- package/lib/types/factories/RedstonePriceFeed.sol/index.js +12 -0
- package/lib/types/factories/SafeERC20__factory.d.ts +1 -1
- package/lib/types/factories/SafeERC20__factory.js +1 -1
- package/lib/types/factories/index.d.ts +41 -13
- package/lib/types/factories/index.js +67 -24
- package/lib/types/index.d.ts +163 -44
- package/lib/types/index.js +131 -36
- package/lib/utils/formatter.d.ts +0 -3
- package/lib/utils/formatter.js +1 -67
- package/lib/utils/math.d.ts +2 -0
- package/lib/utils/math.js +2 -0
- package/lib/utils/types.d.ts +1 -0
- package/lib/watchers/creditAccountWatcher.d.ts +3 -2
- package/lib/watchers/creditAccountWatcher.js +19 -13
- package/lib/watchers/creditAccountWatcher.spec.js +18 -18
- package/lib/watchers/creditManagerWatcher.d.ts +5 -3
- package/lib/watchers/creditManagerWatcher.js +32 -10
- package/lib/watchers/creditManagerWatcher.spec.js +12 -4
- package/package.json +12 -9
- package/contracts/IRouter.sol +0 -100
- package/lib/core/pool/index.d.ts +0 -1
- package/lib/core/pool/index.js +0 -17
- package/lib/types/AaveV2_WrappedAToken.sol/IWrappedATokenEvents.d.ts +0 -60
- package/lib/types/AaveV2_WrappedAToken.sol/index.d.ts +0 -2
- package/lib/types/IAToken.d.ts +0 -182
- package/lib/types/ILendingPool.d.ts +0 -140
- package/lib/types/ILidoV1Adapter.sol/index.d.ts +0 -3
- package/lib/types/IPoolV3.sol/IPoolBase.d.ts +0 -102
- package/lib/types/IWithdrawalManagerV3.sol/IWithdrawalManagerV3.d.ts +0 -370
- package/lib/types/IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events.d.ts +0 -133
- package/lib/types/IWithdrawalManagerV3.sol/index.d.ts +0 -2
- package/lib/types/WATokenZapper.d.ts +0 -134
- package/lib/types/WERC20ZapperBase.d.ts +0 -134
- package/lib/types/WETHZapper.d.ts +0 -122
- package/lib/types/WstETHZapper.d.ts +0 -134
- package/lib/types/ZapperBase.d.ts +0 -70
- package/lib/types/draft-IERC20Permit.sol/index.d.ts +0 -1
- package/lib/types/factories/AaveV2_WrappedAToken.sol/IWrappedATokenEvents__factory.d.ts +0 -48
- package/lib/types/factories/AaveV2_WrappedAToken.sol/WrappedAToken__factory.d.ts +0 -397
- package/lib/types/factories/AaveV2_WrappedAToken.sol/WrappedAToken__factory.js +0 -535
- package/lib/types/factories/AaveV2_WrappedAToken.sol/index.d.ts +0 -2
- package/lib/types/factories/AaveV2_WrappedAToken.sol/index.js +0 -10
- package/lib/types/factories/ILendingPool__factory.d.ts +0 -134
- package/lib/types/factories/ILendingPool__factory.js +0 -183
- package/lib/types/factories/ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.d.ts +0 -12
- package/lib/types/factories/ILidoV1Adapter.sol/index.d.ts +0 -3
- package/lib/types/factories/ILidoV1Adapter.sol/index.js +0 -12
- package/lib/types/factories/IWithdrawalManagerV3.sol/index.d.ts +0 -2
- package/lib/types/factories/IWithdrawalManagerV3.sol/index.js +0 -10
- package/lib/types/factories/WATokenZapper__factory.d.ts +0 -161
- package/lib/types/factories/WATokenZapper__factory.js +0 -227
- package/lib/types/factories/WETHZapper__factory.d.ts +0 -138
- package/lib/types/factories/WETHZapper__factory.js +0 -198
- package/lib/types/factories/WstETHZapper__factory.d.ts +0 -161
- package/lib/types/factories/WstETHZapper__factory.js +0 -227
- package/lib/types/factories/ZapperBase__factory.d.ts +0 -60
- package/lib/types/factories/draft-IERC20Permit.sol/index.d.ts +0 -1
- package/lib/types/factories/draft-IERC20Permit.sol/index.js +0 -8
- /package/lib/{types/AaveV2_WrappedAToken.sol/IWrappedATokenEvents.js → payload/gauge.js} +0 -0
- /package/lib/types/{AaveV2_WrappedAToken.sol/WrappedAToken.js → CalldataExtractor.js} +0 -0
- /package/lib/types/{AaveV2_WrappedAToken.sol/index.js → FarmAccounting.js} +0 -0
- /package/lib/types/{IAToken.js → IAaveV2_LendingPoolAdapter.js} +0 -0
- /package/lib/types/{IConvexV1BoosterAdapter.js → IAaveV2_WrappedATokenAdapter.js} +0 -0
- /package/lib/types/{ILendingPool.js → IBalancerV2Vault.sol/IBalancerV2Vault.js} +0 -0
- /package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.js → IBalancerV2Vault.sol/IBalancerV2VaultGetters.js} +0 -0
- /package/lib/types/{ILidoV1Adapter.sol → IBalancerV2Vault.sol}/index.js +0 -0
- /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter.js} +0 -0
- /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents.js} +0 -0
- /package/lib/types/{IPoolV3.sol/IPoolBase.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions.js} +0 -0
- /package/lib/types/{IWithdrawalManagerV3.sol → IBalancerV2VaultAdapter.sol}/index.js +0 -0
- /package/lib/types/{IRouter.js → IBotListV3.sol/IBotListV3.js} +0 -0
- /package/lib/types/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3.js → IBotListV3.sol/IBotListV3Events.js} +0 -0
- /package/lib/types/{draft-IERC20Permit.sol → IBotListV3.sol}/index.js +0 -0
- /package/lib/types/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events.js → ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter.js} +0 -0
- /package/lib/types/{WATokenZapper.js → ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions.js} +0 -0
- /package/lib/types/{WERC20ZapperBase.js → ICompoundV2_CTokenAdapter.sol/index.js} +0 -0
- /package/lib/types/{WETHZapper.js → IContractsRegister.sol/IContractsRegister.js} +0 -0
- /package/lib/types/{WstETHZapper.js → IContractsRegister.sol/IContractsRegisterEvents.js} +0 -0
- /package/lib/types/{ZapperBase.js → IContractsRegister.sol/index.js} +0 -0
- /package/lib/types/{draft-IERC20Permit.sol/IERC20Permit.js → IControllerTimelockV3.sol/IControllerTimelockV3.js} +0 -0
- /package/lib/types/factories/{draft-IERC20Permit.sol/IERC20Permit__factory.js → IERC20Permit__factory.js} +0 -0
package/contracts/index.sol
CHANGED
|
@@ -7,16 +7,35 @@ pragma solidity ^0.8.10;
|
|
|
7
7
|
import {IDataCompressorV2_10} from "@gearbox-protocol/periphery-v3/contracts/interfaces/IDataCompressorV2_10.sol";
|
|
8
8
|
import {IDataCompressorV3_00} from "@gearbox-protocol/periphery-v3/contracts/interfaces/IDataCompressorV3_00.sol";
|
|
9
9
|
import {IAddressProviderV3} from "@gearbox-protocol/core-v3/contracts/interfaces/IAddressProviderV3.sol";
|
|
10
|
+
import {IContractsRegister} from "@gearbox-protocol/core-v2/contracts/interfaces/IContractsRegister.sol";
|
|
10
11
|
import {IPoolV3} from "@gearbox-protocol/core-v3/contracts/interfaces/IPoolV3.sol";
|
|
12
|
+
import {ILinearInterestRateModelV3} from "@gearbox-protocol/core-v3/contracts/interfaces/ILinearInterestRateModelV3.sol";
|
|
13
|
+
import {IPoolQuotaKeeperV3} from "@gearbox-protocol/core-v3/contracts/interfaces/IPoolQuotaKeeperV3.sol";
|
|
14
|
+
import {IGaugeV3} from "@gearbox-protocol/core-v3/contracts/interfaces/IGaugeV3.sol";
|
|
11
15
|
import {ICreditFacadeV3} from "@gearbox-protocol/core-v3/contracts/interfaces/ICreditFacadeV3.sol";
|
|
12
16
|
import {IPoolService} from "@gearbox-protocol/core-v2/contracts/interfaces/IPoolService.sol";
|
|
13
17
|
import {ICreditFacadeV2} from "@gearbox-protocol/core-v2/contracts/interfaces/ICreditFacadeV2.sol";
|
|
14
18
|
import {ICreditConfiguratorV2} from "@gearbox-protocol/core-v2/contracts/interfaces/ICreditConfiguratorV2.sol";
|
|
15
|
-
import {
|
|
16
|
-
|
|
17
|
-
import {
|
|
19
|
+
import {IERC20ZapperDeposits} from
|
|
20
|
+
"@gearbox-protocol/integrations-v3/contracts/interfaces/zappers/IERC20ZapperDeposits.sol";
|
|
21
|
+
import {IETHZapperDeposits} from "@gearbox-protocol/integrations-v3/contracts/interfaces/zappers/IETHZapperDeposits.sol";
|
|
22
|
+
import {IZapper} from "@gearbox-protocol/integrations-v3/contracts/interfaces/zappers/IZapper.sol";
|
|
23
|
+
import {IZapperRegister} from "@gearbox-protocol/periphery-v3/contracts/interfaces/IZapperRegister.sol";
|
|
24
|
+
import {IDegenNFTV2} from "@gearbox-protocol/core-v2/contracts/interfaces/IDegenNFTV2.sol";
|
|
25
|
+
import {IBotListV3} from "@gearbox-protocol/core-v3/contracts/interfaces/IBotListV3.sol";
|
|
26
|
+
|
|
27
|
+
import {IGearStakingV3} from "@gearbox-protocol/core-v3/contracts/interfaces/IGearStakingV3.sol";
|
|
28
|
+
import {IControllerTimelockV3} from "@gearbox-protocol/core-v3/contracts/interfaces/IControllerTimelockV3.sol";
|
|
18
29
|
|
|
19
30
|
// Adapters
|
|
31
|
+
import {IAaveV2_LendingPoolAdapter} from
|
|
32
|
+
"@gearbox-protocol/integrations-v3/contracts/interfaces/aave/IAaveV2_LendingPoolAdapter.sol";
|
|
33
|
+
import {IAaveV2_WrappedATokenAdapter} from
|
|
34
|
+
"@gearbox-protocol/integrations-v3/contracts/interfaces/aave/IAaveV2_WrappedATokenAdapter.sol";
|
|
35
|
+
import {IBalancerV2VaultAdapter} from
|
|
36
|
+
"@gearbox-protocol/integrations-v3/contracts/interfaces/balancer/IBalancerV2VaultAdapter.sol";
|
|
37
|
+
import {ICompoundV2_CTokenAdapter} from
|
|
38
|
+
"@gearbox-protocol/integrations-v3/contracts/interfaces/compound/ICompoundV2_CTokenAdapter.sol";
|
|
20
39
|
import {ILidoV1Adapter} from "@gearbox-protocol/integrations-v3/contracts/interfaces/lido/ILidoV1Adapter.sol";
|
|
21
40
|
import {IBaseRewardPool} from "@gearbox-protocol/integrations-v3/contracts/integrations/convex/IBaseRewardPool.sol";
|
|
22
41
|
import {IConvexToken} from "@gearbox-protocol/integrations-v3/contracts/integrations/convex/IConvexToken.sol";
|
|
@@ -25,6 +44,7 @@ import {IConvexV1BaseRewardPoolAdapter} from
|
|
|
25
44
|
"@gearbox-protocol/integrations-v3/contracts/interfaces/convex/IConvexV1BaseRewardPoolAdapter.sol";
|
|
26
45
|
import {IConvexV1BoosterAdapter} from
|
|
27
46
|
"@gearbox-protocol/integrations-v3/contracts/interfaces/convex/IConvexV1BoosterAdapter.sol";
|
|
47
|
+
import {IERC4626Adapter} from "@gearbox-protocol/integrations-v3/contracts/interfaces/erc4626/IERC4626Adapter.sol";
|
|
28
48
|
|
|
29
49
|
import {IInterestRateModel} from "@gearbox-protocol/core-v2/contracts/interfaces/IInterestRateModel.sol";
|
|
30
50
|
import {IUniswapV2Adapter} from "@gearbox-protocol/integrations-v3/contracts/interfaces/uniswap/IUniswapV2Adapter.sol";
|
|
@@ -34,7 +54,13 @@ import {IYearnV2Adapter} from "@gearbox-protocol/integrations-v3/contracts/inter
|
|
|
34
54
|
|
|
35
55
|
import {IwstETHV1Adapter} from "@gearbox-protocol/integrations-v3/contracts/interfaces/lido/IwstETHV1Adapter.sol";
|
|
36
56
|
import {IstETH} from "@gearbox-protocol/integrations-v3/contracts/integrations/lido/IstETH.sol";
|
|
57
|
+
import {IwstETH} from "@gearbox-protocol/integrations-v3/contracts/integrations/lido/IwstETH.sol";
|
|
37
58
|
import {IPriceOracleBase} from "@gearbox-protocol/core-v2/contracts/interfaces/IPriceOracleBase.sol";
|
|
59
|
+
import {IPriceOracleV2} from "@gearbox-protocol/core-v2/contracts/interfaces/IPriceOracle.sol";
|
|
60
|
+
import {IPriceOracleV3} from "@gearbox-protocol/core-v3/contracts/interfaces/IPriceOracleV3.sol";
|
|
61
|
+
import {IPriceFeed} from "@gearbox-protocol/core-v2/contracts/interfaces/IPriceFeed.sol";
|
|
62
|
+
import {ILPPriceFeed} from "@gearbox-protocol/oracles-v3/contracts/interfaces/ILPPriceFeed.sol";
|
|
63
|
+
import {RedstonePriceFeed} from "@gearbox-protocol/oracles-v3/contracts/oracles/updatable/RedstonePriceFeed.sol";
|
|
38
64
|
|
|
39
65
|
import {ICurveV1_2AssetsAdapter} from
|
|
40
66
|
"@gearbox-protocol/integrations-v3/contracts/interfaces/curve/ICurveV1_2AssetsAdapter.sol";
|
|
@@ -45,4 +71,9 @@ import {ICurveV1_3AssetsAdapter} from
|
|
|
45
71
|
import {ICurveV1_4AssetsAdapter} from
|
|
46
72
|
"@gearbox-protocol/integrations-v3/contracts/interfaces/curve/ICurveV1_4AssetsAdapter.sol";
|
|
47
73
|
|
|
48
|
-
import {
|
|
74
|
+
import {IRouterV3} from "@gearbox-protocol/router-v3/contracts/interfaces/IRouterV3.sol";
|
|
75
|
+
|
|
76
|
+
import {IFarmingPool} from "@1inch/farming/contracts/interfaces/IFarmingPool.sol";
|
|
77
|
+
|
|
78
|
+
import {IFarmingPool} from "@1inch/farming/contracts/interfaces/IFarmingPool.sol";
|
|
79
|
+
|
package/lib/apy/curveAPY.js
CHANGED
|
@@ -25,7 +25,8 @@ const APY_DICTIONARY = {
|
|
|
25
25
|
crvUSDUSDC: "factory-crvusd-0",
|
|
26
26
|
crvUSDUSDT: "factory-crvusd-1",
|
|
27
27
|
crvUSDFRAX: "factory-crvusd-4",
|
|
28
|
-
crvUSDETHCRV: "factory-tricrypto-4",
|
|
28
|
+
crvUSDETHCRV: "factory-tricrypto-4",
|
|
29
|
+
rETH_f: "factory-crypto-210", // 0x0f3159811670c117c372428D4E69AC32325e4D0F
|
|
29
30
|
};
|
|
30
31
|
const CRV_APY_RESPONSE_DECIMALS = 100;
|
|
31
32
|
// const CRYPTO = "https://api.curve.fi/api/getPools/ethereum/crypto";
|
package/lib/apy/index.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { LPTokens, SupportedToken } from "@gearbox-protocol/sdk-gov";
|
|
1
|
+
import { LPTokens, PartialRecord, SupportedToken } from "@gearbox-protocol/sdk-gov";
|
|
2
2
|
export type AdditionalTokenWithAPY = Extract<SupportedToken, "STETH">;
|
|
3
3
|
export declare const additionalTokensWIthAPY: Record<AdditionalTokenWithAPY, true>;
|
|
4
4
|
export type TokensWithAPY = LPTokens | Extract<SupportedToken, "STETH">;
|
|
5
|
-
export type LpTokensAPY =
|
|
5
|
+
export type LpTokensAPY = PartialRecord<TokensWithAPY, number>;
|
|
6
6
|
export declare const isTokenWithAPY: (t: unknown) => t is TokensWithAPY;
|
|
7
7
|
export * from "./convexAPY";
|
|
8
8
|
export * from "./curveAPY";
|
package/lib/apy/yearnAPY.js
CHANGED
|
@@ -8,7 +8,7 @@ const sdk_gov_1 = require("@gearbox-protocol/sdk-gov");
|
|
|
8
8
|
const axios_1 = __importDefault(require("axios"));
|
|
9
9
|
const formatter_1 = require("../utils/formatter");
|
|
10
10
|
const RESPONSE_DECIMALS = 1;
|
|
11
|
-
const URL = "https://api.
|
|
11
|
+
const URL = "https://api.yexporter.io/v1/chains/1/vaults/all";
|
|
12
12
|
const transformSymbol = (s) => s.replaceAll("_", "-").toLowerCase();
|
|
13
13
|
async function getYearnAPY() {
|
|
14
14
|
try {
|
package/lib/core/assets.d.ts
CHANGED
|
@@ -16,20 +16,20 @@ interface NextAssetProps<T extends Asset> {
|
|
|
16
16
|
tokensList: Record<string, TokenData>;
|
|
17
17
|
prices?: Record<string, bigint>;
|
|
18
18
|
}
|
|
19
|
-
export type WrapResult
|
|
19
|
+
export type WrapResult = [Array<Asset>, bigint, bigint];
|
|
20
20
|
export declare class AssetUtils {
|
|
21
21
|
static nextAsset<T extends Asset>({ allowedTokens, selectedAssets, balances, tokensList, prices, }: NextAssetProps<T>): string | undefined;
|
|
22
22
|
static getBalances(allowedTokens: Array<string>, externalBalances: Record<string, bigint>): Record<string, bigint>;
|
|
23
23
|
static constructAssetRecord<A extends Asset>(a: Array<A>): Record<string, A>;
|
|
24
|
-
static
|
|
24
|
+
static memoWrap: (unwrappedAddress: string, wrappedAddress: string, prices: Record<string, bigint>, tokensList: Record<string, TokenData>) => (assets: Array<Asset>) => WrapResult;
|
|
25
25
|
/**
|
|
26
26
|
* Sums the the second assets list into the first assets list
|
|
27
|
-
* Creates new assets.
|
|
27
|
+
* Balances cant be negative; Creates new assets.
|
|
28
28
|
*/
|
|
29
29
|
static sumAssets<A extends Asset, B extends Asset>(a: Array<A>, b: Array<B>): Array<A | B>;
|
|
30
30
|
/**
|
|
31
31
|
* Subtracts the the second assets list from the first assets list
|
|
32
|
-
*
|
|
32
|
+
* Balances cant be negative; doesn't create new assets.
|
|
33
33
|
*/
|
|
34
34
|
static subAssets<A extends Asset, B extends Asset>(a: Array<A>, b: Array<B>): Array<A>;
|
|
35
35
|
}
|
package/lib/core/assets.js
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.AssetUtils = void 0;
|
|
4
4
|
const math_1 = require("../utils/math");
|
|
5
|
+
const price_1 = require("../utils/price");
|
|
5
6
|
const creditAccount_1 = require("./creditAccount");
|
|
6
7
|
class AssetUtils {
|
|
7
8
|
static nextAsset({ allowedTokens, selectedAssets, balances, tokensList, prices = {}, }) {
|
|
@@ -33,28 +34,38 @@ class AssetUtils {
|
|
|
33
34
|
}, {});
|
|
34
35
|
return record;
|
|
35
36
|
}
|
|
36
|
-
static
|
|
37
|
+
static memoWrap = (unwrappedAddress, wrappedAddress, prices, tokensList) => function wrap(assets) {
|
|
37
38
|
const assetsRecord = AssetUtils.constructAssetRecord(assets);
|
|
38
|
-
const
|
|
39
|
-
const
|
|
40
|
-
const
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
39
|
+
const unwrapped = assetsRecord[unwrappedAddress];
|
|
40
|
+
const wrapped = assetsRecord[wrappedAddress];
|
|
41
|
+
const { balance: wrappedAmount = 0n } = wrapped || {};
|
|
42
|
+
// if there unwrapped token
|
|
43
|
+
if (unwrapped) {
|
|
44
|
+
const { balance: unwrappedAmount = 0n } = unwrapped || {};
|
|
45
|
+
const unwrappedToken = tokensList[unwrappedAddress];
|
|
46
|
+
const unwrappedPrice = prices[unwrappedAddress] || 0n;
|
|
47
|
+
const wrappedToken = tokensList[wrappedAddress];
|
|
48
|
+
const wrappedPrice = prices[wrappedAddress] || 0n;
|
|
49
|
+
// convert unwrapped into wrapped by price
|
|
50
|
+
const unwrappedInWrapped = price_1.PriceUtils.convertByPrice(price_1.PriceUtils.calcTotalPrice(unwrappedPrice, (0, math_1.nonNegativeBn)(unwrappedAmount), unwrappedToken.decimals), {
|
|
51
|
+
price: wrappedPrice,
|
|
52
|
+
decimals: wrappedToken.decimals,
|
|
53
|
+
});
|
|
54
|
+
// sum them
|
|
55
|
+
assetsRecord[wrappedAddress] = {
|
|
56
|
+
token: wrappedAddress,
|
|
57
|
+
balance: (0, math_1.nonNegativeBn)(wrappedAmount) + unwrappedInWrapped,
|
|
48
58
|
};
|
|
59
|
+
// remove unwrapped
|
|
60
|
+
delete assetsRecord[unwrappedAddress];
|
|
61
|
+
return [Object.values(assetsRecord), unwrappedInWrapped, wrappedAmount];
|
|
49
62
|
}
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
}
|
|
53
|
-
return [Object.values(assetsRecord), ethAmount, wethAmount];
|
|
63
|
+
// else no actions needed
|
|
64
|
+
return [Object.values(assetsRecord), 0n, wrappedAmount];
|
|
54
65
|
};
|
|
55
66
|
/**
|
|
56
67
|
* Sums the the second assets list into the first assets list
|
|
57
|
-
* Creates new assets.
|
|
68
|
+
* Balances cant be negative; Creates new assets.
|
|
58
69
|
*/
|
|
59
70
|
static sumAssets(a, b) {
|
|
60
71
|
const aRecord = AssetUtils.constructAssetRecord(a);
|
|
@@ -73,7 +84,7 @@ class AssetUtils {
|
|
|
73
84
|
}
|
|
74
85
|
/**
|
|
75
86
|
* Subtracts the the second assets list from the first assets list
|
|
76
|
-
*
|
|
87
|
+
* Balances cant be negative; doesn't create new assets.
|
|
77
88
|
*/
|
|
78
89
|
static subAssets(a, b) {
|
|
79
90
|
const bRecord = AssetUtils.constructAssetRecord(b);
|
|
@@ -1,24 +1,48 @@
|
|
|
1
1
|
import { LpTokensAPY } from "../apy";
|
|
2
|
-
import { CaTokenBalance, CreditAccountDataPayload
|
|
2
|
+
import { CaTokenBalance, CreditAccountDataPayload } from "../payload/creditAccount";
|
|
3
|
+
import { QuotaInfo } from "../payload/creditManager";
|
|
3
4
|
import { TokenData } from "../tokens/tokenData";
|
|
4
|
-
import { Asset } from "./assets";
|
|
5
|
+
import { Asset, AssetWithAmountInTarget } from "./assets";
|
|
5
6
|
export interface CalcOverallAPYProps {
|
|
6
7
|
caAssets: Array<Asset>;
|
|
7
8
|
lpAPY: LpTokensAPY | undefined;
|
|
9
|
+
quotas: Record<string, Asset>;
|
|
10
|
+
quotaRates: Record<string, Pick<QuotaInfo, "isActive" | "rate">>;
|
|
8
11
|
prices: Record<string, bigint>;
|
|
9
12
|
totalValue: bigint | undefined;
|
|
10
13
|
debt: bigint | undefined;
|
|
11
|
-
|
|
14
|
+
baseBorrowRate: number;
|
|
12
15
|
underlyingToken: string;
|
|
13
16
|
}
|
|
14
17
|
export interface CalcHealthFactorProps {
|
|
15
18
|
assets: Array<Asset>;
|
|
19
|
+
quotas: Record<string, Asset>;
|
|
20
|
+
quotasInfo: Record<string, Pick<QuotaInfo, "isActive">>;
|
|
16
21
|
prices: Record<string, bigint>;
|
|
17
22
|
liquidationThresholds: Record<string, bigint>;
|
|
18
23
|
underlyingToken: string;
|
|
19
24
|
borrowed: bigint;
|
|
20
25
|
}
|
|
26
|
+
export interface CalcQuotaUpdateProps {
|
|
27
|
+
quotas: Record<string, Pick<QuotaInfo, "isActive" | "token">>;
|
|
28
|
+
initialQuotas: Record<string, Pick<CaTokenBalance, "quota">>;
|
|
29
|
+
assetsAfterUpdate: Record<string, AssetWithAmountInTarget>;
|
|
30
|
+
allowedToSpend: Record<string, {}>;
|
|
31
|
+
allowedToObtain: Record<string, {}>;
|
|
32
|
+
quotaReserve: bigint;
|
|
33
|
+
}
|
|
34
|
+
interface CalcQuotaUpdateReturnType {
|
|
35
|
+
desiredQuota: Record<string, Asset>;
|
|
36
|
+
quotaIncrease: Array<Asset>;
|
|
37
|
+
quotaDecrease: Array<Asset>;
|
|
38
|
+
}
|
|
39
|
+
export interface CalcQuotaBorrowRateProps {
|
|
40
|
+
quotas: Record<string, Asset>;
|
|
41
|
+
quotaRates: Record<string, Pick<QuotaInfo, "isActive" | "rate">>;
|
|
42
|
+
borrowAmount: bigint;
|
|
43
|
+
}
|
|
21
44
|
export declare class CreditAccountData {
|
|
45
|
+
readonly isSuccessful: boolean;
|
|
22
46
|
readonly addr: string;
|
|
23
47
|
readonly borrower: string;
|
|
24
48
|
readonly creditManager: string;
|
|
@@ -27,6 +51,7 @@ export declare class CreditAccountData {
|
|
|
27
51
|
readonly since: number;
|
|
28
52
|
readonly expirationDate: number;
|
|
29
53
|
readonly version: number;
|
|
54
|
+
readonly cmName: string;
|
|
30
55
|
readonly enabledTokenMask: bigint;
|
|
31
56
|
readonly healthFactor: number;
|
|
32
57
|
isDeleting: boolean;
|
|
@@ -40,20 +65,16 @@ export declare class CreditAccountData {
|
|
|
40
65
|
readonly totalValue: bigint;
|
|
41
66
|
readonly totalValueUSD: bigint;
|
|
42
67
|
readonly twvUSD: bigint;
|
|
43
|
-
readonly cumulativeIndexNow: bigint;
|
|
44
68
|
readonly cumulativeIndexLastUpdate: bigint;
|
|
45
69
|
readonly cumulativeQuotaInterest: bigint;
|
|
46
70
|
readonly activeBots: string[];
|
|
47
|
-
readonly maxApprovedBots: bigint;
|
|
48
71
|
readonly balances: Record<string, bigint>;
|
|
49
72
|
readonly collateralTokens: Array<string>;
|
|
50
73
|
readonly allBalances: Record<string, CaTokenBalance>;
|
|
51
74
|
readonly forbiddenTokens: Record<string, true>;
|
|
52
75
|
readonly quotedTokens: Record<string, true>;
|
|
53
|
-
readonly schedultedWithdrawals: Array<ScheduledWithdrawal>;
|
|
54
76
|
constructor(payload: CreditAccountDataPayload);
|
|
55
77
|
setDeleteInProgress(d: boolean): void;
|
|
56
|
-
balancesSorted(prices: Record<string, bigint>, tokens: Record<string, TokenData>): Array<Asset>;
|
|
57
78
|
static sortBalances(balances: Record<string, bigint>, prices: Record<string, bigint>, tokens: Record<string, TokenData>): Array<[string, bigint]>;
|
|
58
79
|
static tokensAbcComparator(t1?: TokenData, t2?: TokenData): 1 | -1;
|
|
59
80
|
static amountAbcComparator(t1: bigint, t2: bigint): 1 | -1;
|
|
@@ -62,8 +83,11 @@ export declare class CreditAccountData {
|
|
|
62
83
|
isTokenEnabled(index: number): boolean;
|
|
63
84
|
static isTokenEnabled(index: number, enabledTokenMask: bigint): boolean;
|
|
64
85
|
static calcMaxDebtIncrease(healthFactor: number, borrowAmountPlusInterest: bigint, underlyingLT: number, minHf?: number): bigint;
|
|
65
|
-
static calcOverallAPY({ caAssets, lpAPY, prices, totalValue, debt,
|
|
86
|
+
static calcOverallAPY({ caAssets, lpAPY, prices, quotas, quotaRates, totalValue, debt, baseBorrowRate, underlyingToken, }: CalcOverallAPYProps): bigint | undefined;
|
|
66
87
|
hash(): string;
|
|
67
88
|
static hash(creditManager: string, borrower: string): string;
|
|
68
|
-
static calcHealthFactor({ assets,
|
|
89
|
+
static calcHealthFactor({ assets, quotas, quotasInfo, liquidationThresholds, underlyingToken, borrowed, prices, }: CalcHealthFactorProps): number;
|
|
90
|
+
static calcQuotaUpdate({ quotas, initialQuotas, assetsAfterUpdate, allowedToSpend, allowedToObtain, quotaReserve, }: CalcQuotaUpdateProps): CalcQuotaUpdateReturnType;
|
|
91
|
+
static calcQuotaBorrowRate({ quotas, quotaRates, borrowAmount, }: CalcQuotaBorrowRateProps): number;
|
|
69
92
|
}
|
|
93
|
+
export {};
|
|
@@ -2,10 +2,11 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.CreditAccountData = void 0;
|
|
4
4
|
const sdk_gov_1 = require("@gearbox-protocol/sdk-gov");
|
|
5
|
-
const apy_1 = require("../apy");
|
|
6
5
|
const formatter_1 = require("../utils/formatter");
|
|
6
|
+
const math_1 = require("../utils/math");
|
|
7
7
|
const price_1 = require("../utils/price");
|
|
8
8
|
class CreditAccountData {
|
|
9
|
+
isSuccessful;
|
|
9
10
|
addr;
|
|
10
11
|
borrower;
|
|
11
12
|
creditManager;
|
|
@@ -14,6 +15,7 @@ class CreditAccountData {
|
|
|
14
15
|
since;
|
|
15
16
|
expirationDate;
|
|
16
17
|
version;
|
|
18
|
+
cmName;
|
|
17
19
|
enabledTokenMask;
|
|
18
20
|
healthFactor;
|
|
19
21
|
isDeleting;
|
|
@@ -27,18 +29,16 @@ class CreditAccountData {
|
|
|
27
29
|
totalValue;
|
|
28
30
|
totalValueUSD;
|
|
29
31
|
twvUSD;
|
|
30
|
-
cumulativeIndexNow;
|
|
31
32
|
cumulativeIndexLastUpdate;
|
|
32
33
|
cumulativeQuotaInterest;
|
|
33
34
|
activeBots;
|
|
34
|
-
maxApprovedBots;
|
|
35
35
|
balances = {};
|
|
36
36
|
collateralTokens = [];
|
|
37
37
|
allBalances = {};
|
|
38
38
|
forbiddenTokens = {};
|
|
39
39
|
quotedTokens = {};
|
|
40
|
-
schedultedWithdrawals;
|
|
41
40
|
constructor(payload) {
|
|
41
|
+
this.isSuccessful = payload.isSuccessful;
|
|
42
42
|
this.addr = payload.addr.toLowerCase();
|
|
43
43
|
this.borrower = payload.borrower.toLowerCase();
|
|
44
44
|
this.creditManager = payload.creditManager.toLowerCase();
|
|
@@ -47,16 +47,17 @@ class CreditAccountData {
|
|
|
47
47
|
this.since = Number((0, sdk_gov_1.toBigInt)(payload.since));
|
|
48
48
|
this.expirationDate = Number((0, sdk_gov_1.toBigInt)(payload.expirationDate));
|
|
49
49
|
this.version = payload.cfVersion?.toNumber();
|
|
50
|
-
this.
|
|
50
|
+
this.cmName = payload.cmName;
|
|
51
|
+
this.healthFactor = Number((0, sdk_gov_1.toBigInt)(payload.healthFactor || 0n));
|
|
51
52
|
this.enabledTokenMask = (0, sdk_gov_1.toBigInt)(payload.enabledTokensMask);
|
|
52
53
|
this.isDeleting = false;
|
|
53
54
|
this.borrowedAmount = (0, sdk_gov_1.toBigInt)(payload.debt);
|
|
54
|
-
this.accruedInterest = (0, sdk_gov_1.toBigInt)(payload.accruedInterest);
|
|
55
|
-
this.accruedFees = (0, sdk_gov_1.toBigInt)(payload.accruedFees);
|
|
55
|
+
this.accruedInterest = (0, sdk_gov_1.toBigInt)(payload.accruedInterest || 0n);
|
|
56
|
+
this.accruedFees = (0, sdk_gov_1.toBigInt)(payload.accruedFees || 0n);
|
|
56
57
|
this.borrowedAmountPlusInterestAndFees =
|
|
57
58
|
this.borrowedAmount + this.accruedInterest + this.accruedFees;
|
|
58
59
|
this.totalDebtUSD = (0, sdk_gov_1.toBigInt)(payload.totalDebtUSD);
|
|
59
|
-
this.totalValue = (0, sdk_gov_1.toBigInt)(payload.totalValue);
|
|
60
|
+
this.totalValue = (0, sdk_gov_1.toBigInt)(payload.totalValue || 0n);
|
|
60
61
|
this.totalValueUSD = (0, sdk_gov_1.toBigInt)(payload.totalValueUSD);
|
|
61
62
|
this.twvUSD = (0, sdk_gov_1.toBigInt)(payload.twvUSD);
|
|
62
63
|
this.baseBorrowRate = (0, formatter_1.rayToNumber)((0, sdk_gov_1.toBigInt)(payload.baseBorrowRate) *
|
|
@@ -65,11 +66,9 @@ class CreditAccountData {
|
|
|
65
66
|
this.borrowRate = (0, formatter_1.rayToNumber)((0, sdk_gov_1.toBigInt)(payload.aggregatedBorrowRate) *
|
|
66
67
|
sdk_gov_1.PERCENTAGE_DECIMALS *
|
|
67
68
|
sdk_gov_1.PERCENTAGE_FACTOR);
|
|
68
|
-
this.cumulativeIndexNow = (0, sdk_gov_1.toBigInt)(payload.cumulativeIndexNow);
|
|
69
69
|
this.cumulativeIndexLastUpdate = (0, sdk_gov_1.toBigInt)(payload.cumulativeIndexLastUpdate);
|
|
70
70
|
this.cumulativeQuotaInterest = (0, sdk_gov_1.toBigInt)(payload.cumulativeQuotaInterest);
|
|
71
71
|
this.activeBots = payload.activeBots.map(b => b.toLowerCase());
|
|
72
|
-
this.maxApprovedBots = (0, sdk_gov_1.toBigInt)(payload.maxApprovedBots);
|
|
73
72
|
payload.balances.forEach(b => {
|
|
74
73
|
const token = b.token.toLowerCase();
|
|
75
74
|
const balance = {
|
|
@@ -79,7 +78,8 @@ class CreditAccountData {
|
|
|
79
78
|
isEnabled: b.isEnabled,
|
|
80
79
|
isQuoted: b.isQuoted,
|
|
81
80
|
quota: (0, sdk_gov_1.toBigInt)(b.quota),
|
|
82
|
-
quotaRate: b.quotaRate,
|
|
81
|
+
quotaRate: Number((0, sdk_gov_1.toBigInt)(b.quotaRate) * sdk_gov_1.PERCENTAGE_DECIMALS),
|
|
82
|
+
quotaCumulativeIndexLU: (0, sdk_gov_1.toBigInt)(b.quotaCumulativeIndexLU),
|
|
83
83
|
};
|
|
84
84
|
if (!b.isForbidden) {
|
|
85
85
|
this.balances[token] = balance.balance;
|
|
@@ -93,19 +93,10 @@ class CreditAccountData {
|
|
|
93
93
|
}
|
|
94
94
|
this.allBalances[token] = balance;
|
|
95
95
|
});
|
|
96
|
-
this.schedultedWithdrawals = payload.schedultedWithdrawals.map(w => ({
|
|
97
|
-
tokenIndex: w.tokenIndex,
|
|
98
|
-
maturity: w.maturity,
|
|
99
|
-
token: w.token.toLowerCase(),
|
|
100
|
-
amount: (0, sdk_gov_1.toBigInt)(w.amount),
|
|
101
|
-
}));
|
|
102
96
|
}
|
|
103
97
|
setDeleteInProgress(d) {
|
|
104
98
|
this.isDeleting = d;
|
|
105
99
|
}
|
|
106
|
-
balancesSorted(prices, tokens) {
|
|
107
|
-
return CreditAccountData.sortBalances(this.balances, prices, tokens).map(([token, balance]) => ({ token, balance }));
|
|
108
|
-
}
|
|
109
100
|
static sortBalances(balances, prices, tokens) {
|
|
110
101
|
return Object.entries(balances).sort(([addr1, amount1], [addr2, amount2]) => {
|
|
111
102
|
const addr1Lc = addr1.toLowerCase();
|
|
@@ -147,41 +138,42 @@ class CreditAccountData {
|
|
|
147
138
|
static calcMaxDebtIncrease(healthFactor, borrowAmountPlusInterest, underlyingLT, minHf = Number(sdk_gov_1.PERCENTAGE_FACTOR)) {
|
|
148
139
|
const result = (borrowAmountPlusInterest * BigInt(healthFactor - minHf)) /
|
|
149
140
|
BigInt(minHf - underlyingLT);
|
|
150
|
-
return
|
|
141
|
+
return math_1.BigIntMath.max(0n, result);
|
|
151
142
|
}
|
|
152
|
-
static calcOverallAPY({ caAssets, lpAPY, prices, totalValue, debt,
|
|
143
|
+
static calcOverallAPY({ caAssets, lpAPY, prices, quotas, quotaRates, totalValue, debt, baseBorrowRate, underlyingToken, }) {
|
|
153
144
|
if (!lpAPY ||
|
|
154
145
|
!totalValue ||
|
|
155
146
|
totalValue <= 0n ||
|
|
156
147
|
!debt ||
|
|
157
148
|
totalValue <= debt)
|
|
158
149
|
return undefined;
|
|
150
|
+
const underlyingTokenAddressLC = underlyingToken.toLowerCase();
|
|
151
|
+
const underlyingTokenSymbol = sdk_gov_1.tokenSymbolByAddress[underlyingTokenAddressLC] || "";
|
|
152
|
+
const underlyingTokenDecimals = sdk_gov_1.decimals[underlyingTokenSymbol] || 18;
|
|
153
|
+
const underlyingPrice = prices[underlyingTokenAddressLC];
|
|
159
154
|
const assetAPYMoney = caAssets.reduce((acc, { token: tokenAddress, balance: amount }) => {
|
|
160
155
|
const tokenAddressLC = tokenAddress.toLowerCase();
|
|
161
|
-
const symbol = sdk_gov_1.tokenSymbolByAddress[tokenAddressLC];
|
|
162
|
-
if (!(0, apy_1.isTokenWithAPY)(symbol))
|
|
163
|
-
return acc;
|
|
156
|
+
const symbol = sdk_gov_1.tokenSymbolByAddress[tokenAddressLC] || "";
|
|
164
157
|
const apy = lpAPY[symbol] || 0;
|
|
165
158
|
const price = prices[tokenAddressLC] || 0n;
|
|
166
159
|
const tokenDecimals = sdk_gov_1.decimals[symbol];
|
|
167
160
|
const money = price_1.PriceUtils.calcTotalPrice(price, amount, tokenDecimals);
|
|
168
161
|
const apyMoney = money * BigInt(apy);
|
|
169
|
-
|
|
162
|
+
const { rate: quotaAPY = 0, isActive = false } = quotaRates?.[tokenAddressLC] || {};
|
|
163
|
+
const { balance: quotaBalance = 0n } = quotas[tokenAddressLC] || {};
|
|
164
|
+
const quotaAmount = isActive ? quotaBalance : 0n;
|
|
165
|
+
const quotaMoney = price_1.PriceUtils.calcTotalPrice(underlyingPrice || 0n, quotaAmount, underlyingTokenDecimals);
|
|
166
|
+
const quotaAPYMoney = quotaMoney * BigInt(quotaAPY);
|
|
167
|
+
return acc + apyMoney - quotaAPYMoney;
|
|
170
168
|
}, 0n);
|
|
171
|
-
const underlyingTokenAddressLC = underlyingToken.toLowerCase();
|
|
172
|
-
const underlyingTokenSymbol = sdk_gov_1.tokenSymbolByAddress[underlyingTokenAddressLC] || "";
|
|
173
|
-
const underlyingTokenDecimals = sdk_gov_1.decimals[underlyingTokenSymbol] || 18;
|
|
174
|
-
const underlyingPrice = prices[underlyingTokenAddressLC] || sdk_gov_1.PRICE_DECIMALS;
|
|
175
169
|
const assetAPYAmountInUnderlying = price_1.PriceUtils.convertByPrice(assetAPYMoney, {
|
|
176
|
-
price: underlyingPrice,
|
|
170
|
+
price: underlyingPrice || sdk_gov_1.PRICE_DECIMALS,
|
|
177
171
|
decimals: underlyingTokenDecimals,
|
|
178
172
|
});
|
|
179
|
-
const debtAPY = debt * BigInt(
|
|
173
|
+
const debtAPY = debt * BigInt(baseBorrowRate);
|
|
180
174
|
const yourAssets = totalValue - debt;
|
|
181
|
-
const apyInPercent = (
|
|
182
|
-
|
|
183
|
-
sdk_gov_1.PERCENTAGE_FACTOR;
|
|
184
|
-
return Number((0, formatter_1.toSignificant)(apyInPercent, sdk_gov_1.WAD_DECIMALS_POW));
|
|
175
|
+
const apyInPercent = (assetAPYAmountInUnderlying - debtAPY) / yourAssets;
|
|
176
|
+
return apyInPercent;
|
|
185
177
|
}
|
|
186
178
|
hash() {
|
|
187
179
|
return CreditAccountData.hash(this.creditManager, this.borrower);
|
|
@@ -189,22 +181,86 @@ class CreditAccountData {
|
|
|
189
181
|
static hash(creditManager, borrower) {
|
|
190
182
|
return `${creditManager.toLowerCase()}:${borrower.toLowerCase()}`;
|
|
191
183
|
}
|
|
192
|
-
static calcHealthFactor({ assets,
|
|
184
|
+
static calcHealthFactor({ assets, quotas, quotasInfo, liquidationThresholds, underlyingToken, borrowed, prices, }) {
|
|
185
|
+
const [, underlyingDecimals] = (0, sdk_gov_1.extractTokenData)(underlyingToken);
|
|
186
|
+
const underlyingPrice = prices[underlyingToken] || 0n;
|
|
193
187
|
const assetLTMoney = assets.reduce((acc, { token: tokenAddress, balance: amount }) => {
|
|
194
|
-
const
|
|
195
|
-
const
|
|
196
|
-
const
|
|
197
|
-
const
|
|
198
|
-
const
|
|
188
|
+
const [, tokenDecimals] = (0, sdk_gov_1.extractTokenData)(tokenAddress);
|
|
189
|
+
const lt = liquidationThresholds[tokenAddress] || 0n;
|
|
190
|
+
const price = prices[tokenAddress] || 0n;
|
|
191
|
+
const tokenMoney = price_1.PriceUtils.calcTotalPrice(price, amount, tokenDecimals);
|
|
192
|
+
const { isActive = false } = quotasInfo?.[tokenAddress] || {};
|
|
193
|
+
const quota = quotas[tokenAddress];
|
|
194
|
+
const quotaBalance = isActive ? quota?.balance || 0n : 0n;
|
|
195
|
+
const quotaMoney = price_1.PriceUtils.calcTotalPrice(underlyingPrice, quotaBalance, underlyingDecimals);
|
|
196
|
+
// if quota is undefined, then it is not a quoted token
|
|
197
|
+
const money = quota
|
|
198
|
+
? math_1.BigIntMath.min(quotaMoney, tokenMoney)
|
|
199
|
+
: tokenMoney;
|
|
199
200
|
const ltMoney = money * lt;
|
|
200
201
|
return acc + ltMoney;
|
|
201
202
|
}, 0n);
|
|
202
|
-
const
|
|
203
|
-
const underlyingDecimals = sdk_gov_1.decimals[underlyingSymbol];
|
|
204
|
-
const underlyingPrice = prices[underlyingToken.toLowerCase()] || sdk_gov_1.PRICE_DECIMALS;
|
|
205
|
-
const borrowedMoney = price_1.PriceUtils.calcTotalPrice(underlyingPrice, borrowed, underlyingDecimals);
|
|
203
|
+
const borrowedMoney = price_1.PriceUtils.calcTotalPrice(underlyingPrice || sdk_gov_1.PRICE_DECIMALS, borrowed, underlyingDecimals);
|
|
206
204
|
const hfInPercent = borrowedMoney > 0n ? assetLTMoney / borrowedMoney : 0n;
|
|
207
205
|
return Number(hfInPercent);
|
|
208
206
|
}
|
|
207
|
+
static calcQuotaUpdate({ quotas, initialQuotas, assetsAfterUpdate, allowedToSpend, allowedToObtain, quotaReserve, }) {
|
|
208
|
+
const r = Object.values(quotas).reduce((acc, cmQuota) => {
|
|
209
|
+
const { token, isActive } = cmQuota;
|
|
210
|
+
const { quota: initialQuota = 0n } = initialQuotas[token] || {};
|
|
211
|
+
if (!isActive) {
|
|
212
|
+
acc.desiredQuota[token] = {
|
|
213
|
+
balance: initialQuota,
|
|
214
|
+
token,
|
|
215
|
+
};
|
|
216
|
+
return acc;
|
|
217
|
+
}
|
|
218
|
+
const after = assetsAfterUpdate[token];
|
|
219
|
+
const { amountInTarget = 0n } = after || {};
|
|
220
|
+
const desiredQuota = (amountInTarget * (sdk_gov_1.PERCENTAGE_FACTOR + quotaReserve)) /
|
|
221
|
+
sdk_gov_1.PERCENTAGE_FACTOR;
|
|
222
|
+
const quotaChange = desiredQuota - initialQuota;
|
|
223
|
+
const correctIncrease = after && allowedToObtain[token] && quotaChange > 0;
|
|
224
|
+
const correctDecrease = after && allowedToSpend[token] && quotaChange < 0;
|
|
225
|
+
if (correctIncrease || correctDecrease) {
|
|
226
|
+
acc.desiredQuota[token] = {
|
|
227
|
+
balance: desiredQuota,
|
|
228
|
+
token,
|
|
229
|
+
};
|
|
230
|
+
}
|
|
231
|
+
else {
|
|
232
|
+
acc.desiredQuota[token] = {
|
|
233
|
+
balance: initialQuota,
|
|
234
|
+
token,
|
|
235
|
+
};
|
|
236
|
+
}
|
|
237
|
+
if (correctIncrease) {
|
|
238
|
+
acc.quotaIncrease.push({
|
|
239
|
+
balance: quotaChange,
|
|
240
|
+
token,
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
if (correctDecrease) {
|
|
244
|
+
acc.quotaDecrease.push({
|
|
245
|
+
balance: quotaChange,
|
|
246
|
+
token,
|
|
247
|
+
});
|
|
248
|
+
}
|
|
249
|
+
return acc;
|
|
250
|
+
}, { desiredQuota: {}, quotaIncrease: [], quotaDecrease: [] });
|
|
251
|
+
return r;
|
|
252
|
+
}
|
|
253
|
+
static calcQuotaBorrowRate({ quotas, quotaRates, borrowAmount, }) {
|
|
254
|
+
if (borrowAmount <= 0)
|
|
255
|
+
return 0;
|
|
256
|
+
const totalRateBalance = Object.values(quotas).reduce((acc, { token, balance }) => {
|
|
257
|
+
const { rate = 0, isActive = false } = quotaRates?.[token] || {};
|
|
258
|
+
const quotaBalance = isActive ? balance : 0n;
|
|
259
|
+
const rateBalance = quotaBalance * BigInt(rate);
|
|
260
|
+
return acc + rateBalance;
|
|
261
|
+
}, 0n);
|
|
262
|
+
const quotaBorrowRate = Number(totalRateBalance / borrowAmount);
|
|
263
|
+
return quotaBorrowRate;
|
|
264
|
+
}
|
|
209
265
|
}
|
|
210
266
|
exports.CreditAccountData = CreditAccountData;
|