@gearbox-protocol/sdk 3.0.0-next.8 → 3.0.0-next.81
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
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import { MultiCall } from "../pathfinder/core";
|
|
2
2
|
import { ChartsCreditManagerPayload, CreditManagerDataPayload, QuotaInfo } from "../payload/creditManager";
|
|
3
3
|
import { LinearModel } from "../payload/pool";
|
|
4
|
+
import { Asset } from "./assets";
|
|
5
|
+
import { PoolType } from "./pool";
|
|
4
6
|
export declare class CreditManagerData {
|
|
5
7
|
readonly address: string;
|
|
8
|
+
readonly type: PoolType;
|
|
6
9
|
readonly underlyingToken: string;
|
|
7
10
|
readonly pool: string;
|
|
8
11
|
readonly creditFacade: string;
|
|
@@ -13,7 +16,8 @@ export declare class CreditManagerData {
|
|
|
13
16
|
readonly isPaused: boolean;
|
|
14
17
|
readonly forbiddenTokenMask: bigint;
|
|
15
18
|
readonly maxEnabledTokensLength: number;
|
|
16
|
-
readonly
|
|
19
|
+
readonly name: string;
|
|
20
|
+
readonly baseBorrowRate: number;
|
|
17
21
|
readonly minDebt: bigint;
|
|
18
22
|
readonly maxDebt: bigint;
|
|
19
23
|
readonly availableToBorrow: bigint;
|
|
@@ -31,8 +35,11 @@ export declare class CreditManagerData {
|
|
|
31
35
|
readonly quotas: Record<string, QuotaInfo>;
|
|
32
36
|
readonly interestModel: LinearModel;
|
|
33
37
|
constructor(payload: CreditManagerDataPayload);
|
|
34
|
-
|
|
38
|
+
get id(): string;
|
|
39
|
+
isQuoted(token: string): boolean;
|
|
40
|
+
encodeAddCollateralV2(tokenAddress: string, amount: bigint): MultiCall;
|
|
35
41
|
encodeAddCollateralV3(tokenAddress: string, amount: bigint): MultiCall;
|
|
42
|
+
encodeAddCollateralWithPermitV3(tokenAddress: string, amount: bigint, deadline: bigint, v: bigint | number, r: string, s: string): MultiCall;
|
|
36
43
|
encodeIncreaseDebtV2(amount: bigint): MultiCall;
|
|
37
44
|
encodeIncreaseDebtV3(amount: bigint): MultiCall;
|
|
38
45
|
encodeDecreaseDebtV2(amount: bigint): MultiCall;
|
|
@@ -41,8 +48,11 @@ export declare class CreditManagerData {
|
|
|
41
48
|
encodeEnableTokenV3(token: string): MultiCall;
|
|
42
49
|
encodeDisableTokenV2(token: string): MultiCall;
|
|
43
50
|
encodeDisableTokenV3(token: string): MultiCall;
|
|
51
|
+
encodeRevertIfReceivedLessThanV2(assets: Array<Asset>): MultiCall;
|
|
52
|
+
encodeUpdateQuotaV3(token: string, quotaChange: bigint, minQuota: bigint): MultiCall;
|
|
53
|
+
encodeWithdrawCollateralV3(token: string, amount: bigint, to: string): MultiCall;
|
|
44
54
|
static withdrawAllAndUnwrap_Convex(address: string, claim: boolean): MultiCall;
|
|
45
|
-
|
|
55
|
+
encodeOnDemandPriceUpdateV3(token: string, reserve: boolean, data: string): MultiCall;
|
|
46
56
|
}
|
|
47
57
|
export declare class ChartsCreditManagerData {
|
|
48
58
|
readonly id: string;
|
|
@@ -4,8 +4,10 @@ exports.ChartsCreditManagerData = exports.CreditManagerData = void 0;
|
|
|
4
4
|
const sdk_gov_1 = require("@gearbox-protocol/sdk-gov");
|
|
5
5
|
const txParser_1 = require("../parsers/txParser");
|
|
6
6
|
const types_1 = require("../types");
|
|
7
|
+
const pool_1 = require("./pool");
|
|
7
8
|
class CreditManagerData {
|
|
8
9
|
address;
|
|
10
|
+
type;
|
|
9
11
|
underlyingToken;
|
|
10
12
|
pool;
|
|
11
13
|
creditFacade; // V2 only: address of creditFacade
|
|
@@ -16,7 +18,8 @@ class CreditManagerData {
|
|
|
16
18
|
isPaused;
|
|
17
19
|
forbiddenTokenMask; // V2 only: mask which forbids some particular tokens
|
|
18
20
|
maxEnabledTokensLength;
|
|
19
|
-
|
|
21
|
+
name;
|
|
22
|
+
baseBorrowRate;
|
|
20
23
|
minDebt;
|
|
21
24
|
maxDebt;
|
|
22
25
|
availableToBorrow;
|
|
@@ -36,6 +39,8 @@ class CreditManagerData {
|
|
|
36
39
|
constructor(payload) {
|
|
37
40
|
this.address = payload.addr.toLowerCase();
|
|
38
41
|
this.underlyingToken = payload.underlying.toLowerCase();
|
|
42
|
+
this.type = pool_1.PoolData.getPoolType(payload.name || "");
|
|
43
|
+
this.name = payload.name;
|
|
39
44
|
this.pool = payload.pool.toLowerCase();
|
|
40
45
|
this.creditFacade = payload.creditFacade.toLowerCase();
|
|
41
46
|
this.creditConfigurator = payload.creditConfigurator.toLowerCase();
|
|
@@ -45,7 +50,7 @@ class CreditManagerData {
|
|
|
45
50
|
this.isPaused = payload.isPaused;
|
|
46
51
|
this.forbiddenTokenMask = (0, sdk_gov_1.toBigInt)(payload.forbiddenTokenMask);
|
|
47
52
|
this.maxEnabledTokensLength = payload.maxEnabledTokensLength;
|
|
48
|
-
this.
|
|
53
|
+
this.baseBorrowRate = Number(((0, sdk_gov_1.toBigInt)(payload.baseBorrowRate) *
|
|
49
54
|
((0, sdk_gov_1.toBigInt)(payload.feeInterest) + sdk_gov_1.PERCENTAGE_FACTOR) *
|
|
50
55
|
sdk_gov_1.PERCENTAGE_DECIMALS) /
|
|
51
56
|
sdk_gov_1.RAY);
|
|
@@ -78,7 +83,7 @@ class CreditManagerData {
|
|
|
78
83
|
q.token.toLowerCase(),
|
|
79
84
|
{
|
|
80
85
|
token: q.token.toLowerCase(),
|
|
81
|
-
rate: q.rate,
|
|
86
|
+
rate: Number((0, sdk_gov_1.toBigInt)(q.rate) * sdk_gov_1.PERCENTAGE_DECIMALS),
|
|
82
87
|
quotaIncreaseFee: q.quotaIncreaseFee,
|
|
83
88
|
totalQuoted: (0, sdk_gov_1.toBigInt)(q.totalQuoted),
|
|
84
89
|
limit: (0, sdk_gov_1.toBigInt)(q.limit),
|
|
@@ -94,20 +99,27 @@ class CreditManagerData {
|
|
|
94
99
|
R_slope2: payload.lirm.R_slope2,
|
|
95
100
|
R_slope3: payload.lirm.R_slope3,
|
|
96
101
|
version: payload?.lirm?.version?.toNumber(),
|
|
102
|
+
isBorrowingMoreU2Forbidden: payload?.lirm?.isBorrowingMoreU2Forbidden,
|
|
97
103
|
};
|
|
98
104
|
txParser_1.TxParser.addCreditManager(this.address, this.version);
|
|
99
105
|
if (this.creditFacade !== "" && this.creditFacade !== sdk_gov_1.ADDRESS_0X0) {
|
|
100
|
-
txParser_1.TxParser.addCreditFacade(this.creditFacade, sdk_gov_1.tokenSymbolByAddress[this.underlyingToken]);
|
|
106
|
+
txParser_1.TxParser.addCreditFacade(this.creditFacade, sdk_gov_1.tokenSymbolByAddress[this.underlyingToken], this.version);
|
|
101
107
|
txParser_1.TxParser.addAdapters(payload.adapters.map(a => ({
|
|
102
108
|
adapter: a.adapter,
|
|
103
109
|
contract: a.targetContract,
|
|
104
110
|
})));
|
|
105
111
|
}
|
|
106
112
|
}
|
|
107
|
-
|
|
113
|
+
get id() {
|
|
114
|
+
return this.address;
|
|
115
|
+
}
|
|
116
|
+
isQuoted(token) {
|
|
117
|
+
return !!this.quotas[token];
|
|
118
|
+
}
|
|
119
|
+
encodeAddCollateralV2(tokenAddress, amount) {
|
|
108
120
|
return {
|
|
109
121
|
target: this.creditFacade,
|
|
110
|
-
callData: types_1.ICreditFacadeV2Extended__factory.createInterface().encodeFunctionData("addCollateral", [
|
|
122
|
+
callData: types_1.ICreditFacadeV2Extended__factory.createInterface().encodeFunctionData("addCollateral", [tokenAddress, amount]),
|
|
111
123
|
};
|
|
112
124
|
}
|
|
113
125
|
encodeAddCollateralV3(tokenAddress, amount) {
|
|
@@ -116,6 +128,12 @@ class CreditManagerData {
|
|
|
116
128
|
callData: types_1.ICreditFacadeV3Multicall__factory.createInterface().encodeFunctionData("addCollateral", [tokenAddress, amount]),
|
|
117
129
|
};
|
|
118
130
|
}
|
|
131
|
+
encodeAddCollateralWithPermitV3(tokenAddress, amount, deadline, v, r, s) {
|
|
132
|
+
return {
|
|
133
|
+
target: this.creditFacade,
|
|
134
|
+
callData: types_1.ICreditFacadeV3Multicall__factory.createInterface().encodeFunctionData("addCollateralWithPermit", [tokenAddress, amount, deadline, v, r, s]),
|
|
135
|
+
};
|
|
136
|
+
}
|
|
119
137
|
encodeIncreaseDebtV2(amount) {
|
|
120
138
|
return {
|
|
121
139
|
target: this.creditFacade,
|
|
@@ -164,14 +182,35 @@ class CreditManagerData {
|
|
|
164
182
|
callData: types_1.ICreditFacadeV3Multicall__factory.createInterface().encodeFunctionData("disableToken", [token]),
|
|
165
183
|
};
|
|
166
184
|
}
|
|
185
|
+
encodeRevertIfReceivedLessThanV2(assets) {
|
|
186
|
+
return {
|
|
187
|
+
target: this.creditFacade,
|
|
188
|
+
callData: types_1.ICreditFacadeV2Extended__factory.createInterface().encodeFunctionData("revertIfReceivedLessThan", [assets]),
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
encodeUpdateQuotaV3(token, quotaChange, minQuota) {
|
|
192
|
+
return {
|
|
193
|
+
target: this.creditFacade,
|
|
194
|
+
callData: types_1.ICreditFacadeV3Multicall__factory.createInterface().encodeFunctionData("updateQuota", [token, quotaChange, minQuota]),
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
encodeWithdrawCollateralV3(token, amount, to) {
|
|
198
|
+
return {
|
|
199
|
+
target: this.creditFacade,
|
|
200
|
+
callData: types_1.ICreditFacadeV3Multicall__factory.createInterface().encodeFunctionData("withdrawCollateral", [token, amount, to]),
|
|
201
|
+
};
|
|
202
|
+
}
|
|
167
203
|
static withdrawAllAndUnwrap_Convex(address, claim) {
|
|
168
204
|
return {
|
|
169
205
|
target: address,
|
|
170
|
-
callData: types_1.IConvexV1BaseRewardPoolAdapter__factory.createInterface().encodeFunctionData("
|
|
206
|
+
callData: types_1.IConvexV1BaseRewardPoolAdapter__factory.createInterface().encodeFunctionData("withdrawDiffAndUnwrap", [1, claim]),
|
|
171
207
|
};
|
|
172
208
|
}
|
|
173
|
-
|
|
174
|
-
return
|
|
209
|
+
encodeOnDemandPriceUpdateV3(token, reserve, data) {
|
|
210
|
+
return {
|
|
211
|
+
target: this.creditFacade,
|
|
212
|
+
callData: types_1.ICreditFacadeV3Multicall__factory.createInterface().encodeFunctionData("onDemandPriceUpdate", [token, reserve, data]),
|
|
213
|
+
};
|
|
175
214
|
}
|
|
176
215
|
}
|
|
177
216
|
exports.CreditManagerData = CreditManagerData;
|
package/lib/core/events.js
CHANGED
|
@@ -124,7 +124,7 @@ class EventAddLiquidity extends eventOrTx_1.EVMEvent {
|
|
|
124
124
|
}
|
|
125
125
|
toString() {
|
|
126
126
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.underlyingToken);
|
|
127
|
-
return `Pool ${(0, contractsRegister_1.getContractName)(this.pool)}: Deposit ${(0,
|
|
127
|
+
return `Pool ${(0, contractsRegister_1.getContractName)(this.pool)}: Deposit ${(0, sdk_gov_1.formatBN)(this.amount, decimals)} ${symbol}`;
|
|
128
128
|
}
|
|
129
129
|
}
|
|
130
130
|
exports.EventAddLiquidity = EventAddLiquidity;
|
|
@@ -142,7 +142,7 @@ class EventRemoveLiquidity extends eventOrTx_1.EVMEvent {
|
|
|
142
142
|
}
|
|
143
143
|
toString() {
|
|
144
144
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.dieselToken);
|
|
145
|
-
return `Pool ${(0, contractsRegister_1.getContractName)(this.pool)}: withdraw ${(0,
|
|
145
|
+
return `Pool ${(0, contractsRegister_1.getContractName)(this.pool)}: withdraw ${(0, sdk_gov_1.formatBN)(this.amount, decimals)} ${symbol}`;
|
|
146
146
|
}
|
|
147
147
|
}
|
|
148
148
|
exports.EventRemoveLiquidity = EventRemoveLiquidity;
|
|
@@ -158,7 +158,7 @@ class EventOpenCreditAccount extends eventOrTx_1.EVMEvent {
|
|
|
158
158
|
}
|
|
159
159
|
toString() {
|
|
160
160
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.underlyingToken);
|
|
161
|
-
return `Credit
|
|
161
|
+
return `Credit Account ${(0, contractsRegister_1.getContractName)(this.creditManager)}: opened with debt ${(0, sdk_gov_1.formatBN)(this.amount, decimals)} ${symbol}`;
|
|
162
162
|
}
|
|
163
163
|
}
|
|
164
164
|
exports.EventOpenCreditAccount = EventOpenCreditAccount;
|
|
@@ -171,7 +171,7 @@ class EventCloseCreditAccount extends eventOrTx_1.EVMEvent {
|
|
|
171
171
|
this.creditManager = opts.creditManager;
|
|
172
172
|
}
|
|
173
173
|
toString() {
|
|
174
|
-
return `Credit
|
|
174
|
+
return `Credit Account ${(0, contractsRegister_1.getContractName)(this.creditManager)}: was closed`;
|
|
175
175
|
}
|
|
176
176
|
}
|
|
177
177
|
exports.EventCloseCreditAccount = EventCloseCreditAccount;
|
|
@@ -187,7 +187,7 @@ class EventLiquidateCreditAccount extends eventOrTx_1.EVMEvent {
|
|
|
187
187
|
}
|
|
188
188
|
toString() {
|
|
189
189
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.underlyingToken);
|
|
190
|
-
return `Credit
|
|
190
|
+
return `Credit Account ${(0, contractsRegister_1.getContractName)(this.creditManager)}: was liquidated. ${(0, sdk_gov_1.formatBN)(this.amount, decimals)} ${symbol} were paid back as remaining funds`;
|
|
191
191
|
}
|
|
192
192
|
}
|
|
193
193
|
exports.EventLiquidateCreditAccount = EventLiquidateCreditAccount;
|
|
@@ -200,7 +200,7 @@ class EventRepayCreditAccount extends eventOrTx_1.EVMEvent {
|
|
|
200
200
|
this.creditManager = opts.creditManager;
|
|
201
201
|
}
|
|
202
202
|
toString() {
|
|
203
|
-
return `Credit
|
|
203
|
+
return `Credit Account ${(0, contractsRegister_1.getContractName)(this.creditManager)}: was repaid`;
|
|
204
204
|
}
|
|
205
205
|
}
|
|
206
206
|
exports.EventRepayCreditAccount = EventRepayCreditAccount;
|
|
@@ -216,7 +216,7 @@ class EventAddCollateral extends eventOrTx_1.EVMEvent {
|
|
|
216
216
|
}
|
|
217
217
|
toString() {
|
|
218
218
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.addedToken);
|
|
219
|
-
return `Credit
|
|
219
|
+
return `Credit Account ${(0, contractsRegister_1.getContractName)(this.creditManager)}: added ${(0, sdk_gov_1.formatBN)(this.amount, decimals)} ${symbol} as collateral`;
|
|
220
220
|
}
|
|
221
221
|
}
|
|
222
222
|
exports.EventAddCollateral = EventAddCollateral;
|
|
@@ -232,7 +232,7 @@ class EventIncreaseBorrowAmount extends eventOrTx_1.EVMEvent {
|
|
|
232
232
|
}
|
|
233
233
|
toString() {
|
|
234
234
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.underlyingToken);
|
|
235
|
-
return `Credit
|
|
235
|
+
return `Credit Account ${(0, contractsRegister_1.getContractName)(this.creditManager)}: borrowed amount was increased for ${(0, sdk_gov_1.formatBN)(this.amount, decimals)} ${symbol}`;
|
|
236
236
|
}
|
|
237
237
|
}
|
|
238
238
|
exports.EventIncreaseBorrowAmount = EventIncreaseBorrowAmount;
|
|
@@ -248,7 +248,7 @@ class EventDecreaseBorrowAmount extends eventOrTx_1.EVMEvent {
|
|
|
248
248
|
}
|
|
249
249
|
toString() {
|
|
250
250
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.underlyingToken);
|
|
251
|
-
return `Credit
|
|
251
|
+
return `Credit Account ${(0, contractsRegister_1.getContractName)(this.creditManager)}: borrowed amount was decreased for ${(0, sdk_gov_1.formatBN)(this.amount, decimals)} ${symbol}`;
|
|
252
252
|
}
|
|
253
253
|
}
|
|
254
254
|
exports.EventDecreaseBorrowAmount = EventDecreaseBorrowAmount;
|
|
@@ -288,10 +288,10 @@ class EventCMNewParameters extends eventOrTx_1.EVMEvent {
|
|
|
288
288
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.underlyingToken);
|
|
289
289
|
let msg = `Credit manager ${(0, contractsRegister_1.getContractName)(this.creditManager)} updated: `;
|
|
290
290
|
if (this.minAmount !== this.prevMinAmount) {
|
|
291
|
-
msg += `min amount: ${(0,
|
|
291
|
+
msg += `min amount: ${(0, sdk_gov_1.formatBN)(this.prevMinAmount, decimals)} => ${(0, sdk_gov_1.formatBN)(this.minAmount, decimals)} ${symbol}, `;
|
|
292
292
|
}
|
|
293
293
|
if (this.maxAmount !== this.prevMaxAmount) {
|
|
294
|
-
msg += `max amount: ${(0,
|
|
294
|
+
msg += `max amount: ${(0, sdk_gov_1.formatBN)(this.prevMaxAmount, decimals)} => ${(0, sdk_gov_1.formatBN)(this.maxAmount, decimals)} ${symbol}, `;
|
|
295
295
|
}
|
|
296
296
|
if (this.maxLeverage !== this.prevMaxLeverage) {
|
|
297
297
|
msg += `max leverage: ${this.prevMaxLeverage / Number(sdk_gov_1.LEVERAGE_DECIMALS) + 1} => ${this.maxLeverage / Number(sdk_gov_1.LEVERAGE_DECIMALS) + 1}, `;
|
|
@@ -501,8 +501,8 @@ class EventNewExpectedLiquidityLimit extends eventOrTx_1.EVMEvent {
|
|
|
501
501
|
toString() {
|
|
502
502
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.underlyingToken);
|
|
503
503
|
return this.prevLimit === 0n
|
|
504
|
-
? `Pool ${(0, contractsRegister_1.getContractName)(this.pool)} updated: expected liquidity limit was set to ${(0,
|
|
505
|
-
: `Pool ${(0, contractsRegister_1.getContractName)(this.pool)} updated: expected liquidity limit was ${this.newLimit > this.prevLimit ? "increased" : "decreased"}: ${(0,
|
|
504
|
+
? `Pool ${(0, contractsRegister_1.getContractName)(this.pool)} updated: expected liquidity limit was set to ${(0, sdk_gov_1.formatBN)(this.newLimit, decimals)} ${symbol}`
|
|
505
|
+
: `Pool ${(0, contractsRegister_1.getContractName)(this.pool)} updated: expected liquidity limit was ${this.newLimit > this.prevLimit ? "increased" : "decreased"}: ${(0, sdk_gov_1.formatBN)(this.prevLimit, decimals)} ${symbol} => ${(0, sdk_gov_1.formatBN)(this.newLimit, decimals)} ${symbol}`;
|
|
506
506
|
}
|
|
507
507
|
}
|
|
508
508
|
exports.EventNewExpectedLiquidityLimit = EventNewExpectedLiquidityLimit;
|
|
@@ -680,10 +680,10 @@ class EventLimitsUpdated extends eventOrTx_1.EVMEvent {
|
|
|
680
680
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.underlyingToken);
|
|
681
681
|
let msg = `Credit manager ${(0, contractsRegister_1.getContractName)(this.creditManager)} updated: `;
|
|
682
682
|
if (this.minBorrowedAmount !== this.prevMinBorrowedAmount) {
|
|
683
|
-
msg += `min amount: ${(0,
|
|
683
|
+
msg += `min amount: ${(0, sdk_gov_1.formatBN)(this.prevMinBorrowedAmount, decimals)} => ${(0, sdk_gov_1.formatBN)(this.minBorrowedAmount, decimals)} ${symbol}, `;
|
|
684
684
|
}
|
|
685
685
|
if (this.maxBorrowedAmount !== this.prevMaxBorrowedAmount) {
|
|
686
|
-
msg += `max amount: ${(0,
|
|
686
|
+
msg += `max amount: ${(0, sdk_gov_1.formatBN)(this.prevMaxBorrowedAmount, decimals)} => ${(0, sdk_gov_1.formatBN)(this.maxBorrowedAmount, decimals)} ${symbol}, `;
|
|
687
687
|
}
|
|
688
688
|
return msg.slice(0, msg.length - 2);
|
|
689
689
|
}
|
|
@@ -838,7 +838,7 @@ class EventLimitPerBlockUpdated extends eventOrTx_1.EVMEvent {
|
|
|
838
838
|
}
|
|
839
839
|
toString() {
|
|
840
840
|
const [symbol, decimals = 18] = (0, sdk_gov_1.extractTokenData)(this.token);
|
|
841
|
-
return `Credit manager ${(0, contractsRegister_1.getContractName)(this.creditManager)}: Limit Per Block Updated ${(0,
|
|
841
|
+
return `Credit manager ${(0, contractsRegister_1.getContractName)(this.creditManager)}: Limit Per Block Updated ${(0, sdk_gov_1.formatBN)(this.prevLimit, decimals)} => ${(0, sdk_gov_1.formatBN)(this.limit, decimals)} ${symbol}`;
|
|
842
842
|
}
|
|
843
843
|
}
|
|
844
844
|
exports.EventLimitPerBlockUpdated = EventLimitPerBlockUpdated;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { GaugeDataPayload, GaugeQuotaParams, GaugeStakingDataPayload } from "../payload/gauge";
|
|
2
|
+
export declare class GaugeData {
|
|
3
|
+
readonly address: string;
|
|
4
|
+
readonly pool: string;
|
|
5
|
+
readonly poolUnderlying: string;
|
|
6
|
+
readonly name: string;
|
|
7
|
+
readonly symbol: string;
|
|
8
|
+
readonly currentEpoch: number;
|
|
9
|
+
readonly epochFrozen: boolean;
|
|
10
|
+
readonly quotaParams: Record<string, GaugeQuotaParams>;
|
|
11
|
+
constructor(payload: GaugeDataPayload);
|
|
12
|
+
}
|
|
13
|
+
interface WithDrawableGaugeItem {
|
|
14
|
+
amount: bigint;
|
|
15
|
+
epochsLeft: number;
|
|
16
|
+
}
|
|
17
|
+
export declare class GaugeStakingData {
|
|
18
|
+
readonly availableBalance: bigint;
|
|
19
|
+
readonly totalBalance: bigint;
|
|
20
|
+
readonly epoch: number;
|
|
21
|
+
readonly withdrawableNow: bigint;
|
|
22
|
+
readonly withdrawableInEpochsTotal: bigint;
|
|
23
|
+
readonly withdrawableInEpochs: Array<WithDrawableGaugeItem>;
|
|
24
|
+
constructor(payload: GaugeStakingDataPayload);
|
|
25
|
+
}
|
|
26
|
+
export {};
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GaugeStakingData = exports.GaugeData = void 0;
|
|
4
|
+
const sdk_gov_1 = require("@gearbox-protocol/sdk-gov");
|
|
5
|
+
class GaugeData {
|
|
6
|
+
address;
|
|
7
|
+
pool;
|
|
8
|
+
poolUnderlying;
|
|
9
|
+
name;
|
|
10
|
+
symbol;
|
|
11
|
+
currentEpoch;
|
|
12
|
+
epochFrozen;
|
|
13
|
+
quotaParams;
|
|
14
|
+
constructor(payload) {
|
|
15
|
+
this.address = payload.addr.toLowerCase();
|
|
16
|
+
this.pool = payload.pool.toLowerCase();
|
|
17
|
+
this.poolUnderlying = payload.underlying.toLowerCase();
|
|
18
|
+
this.name = payload.name;
|
|
19
|
+
this.symbol = payload.symbol;
|
|
20
|
+
this.currentEpoch = payload.currentEpoch;
|
|
21
|
+
this.epochFrozen = payload.epochFrozen;
|
|
22
|
+
this.quotaParams = Object.fromEntries(payload.quotaParams.map((q) => [
|
|
23
|
+
q.token.toLowerCase(),
|
|
24
|
+
{
|
|
25
|
+
token: q.token.toLowerCase(),
|
|
26
|
+
isActive: q.isActive,
|
|
27
|
+
rate: Number((0, sdk_gov_1.toBigInt)(q.rate) * sdk_gov_1.PERCENTAGE_DECIMALS),
|
|
28
|
+
minRate: Number((0, sdk_gov_1.toBigInt)(q.minRate) * sdk_gov_1.PERCENTAGE_DECIMALS),
|
|
29
|
+
maxRate: Number((0, sdk_gov_1.toBigInt)(q.maxRate) * sdk_gov_1.PERCENTAGE_DECIMALS),
|
|
30
|
+
quotaIncreaseFee: q.quotaIncreaseFee,
|
|
31
|
+
totalQuoted: (0, sdk_gov_1.toBigInt)(q.totalQuoted),
|
|
32
|
+
limit: (0, sdk_gov_1.toBigInt)(q.limit),
|
|
33
|
+
totalVotesLpSide: (0, sdk_gov_1.toBigInt)(q.totalVotesLpSide),
|
|
34
|
+
totalVotesCaSide: (0, sdk_gov_1.toBigInt)(q.totalVotesCaSide),
|
|
35
|
+
stakerVotesLpSide: (0, sdk_gov_1.toBigInt)(q.stakerVotesLpSide),
|
|
36
|
+
stakerVotesCaSide: (0, sdk_gov_1.toBigInt)(q.stakerVotesCaSide),
|
|
37
|
+
},
|
|
38
|
+
]));
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.GaugeData = GaugeData;
|
|
42
|
+
class GaugeStakingData {
|
|
43
|
+
availableBalance;
|
|
44
|
+
totalBalance;
|
|
45
|
+
epoch;
|
|
46
|
+
withdrawableNow;
|
|
47
|
+
withdrawableInEpochsTotal;
|
|
48
|
+
withdrawableInEpochs;
|
|
49
|
+
constructor(payload) {
|
|
50
|
+
this.availableBalance = (0, sdk_gov_1.toBigInt)(payload.availableBalance);
|
|
51
|
+
this.totalBalance = (0, sdk_gov_1.toBigInt)(payload.totalBalance);
|
|
52
|
+
this.epoch = payload.epoch;
|
|
53
|
+
this.withdrawableNow = (0, sdk_gov_1.toBigInt)(payload.withdrawableAmounts.withdrawableNow);
|
|
54
|
+
const { total, list } = payload.withdrawableAmounts.withdrawableInEpochs.reduce(({ total, list }, a, i) => {
|
|
55
|
+
const bn = (0, sdk_gov_1.toBigInt)(a);
|
|
56
|
+
list.push({ amount: bn, epochsLeft: i + 1 });
|
|
57
|
+
return { total: total + bn, list };
|
|
58
|
+
}, { total: 0n, list: [] });
|
|
59
|
+
this.withdrawableInEpochsTotal = total;
|
|
60
|
+
this.withdrawableInEpochs = list;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
exports.GaugeStakingData = GaugeStakingData;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { GaugeQuotaParams } from "../payload/gauge";
|
|
2
|
+
export type BaseVoteType = "raise" | "lower";
|
|
3
|
+
export type VoteType = BaseVoteType | "remove";
|
|
4
|
+
export interface BaseVote {
|
|
5
|
+
amount: bigint;
|
|
6
|
+
type: BaseVoteType;
|
|
7
|
+
}
|
|
8
|
+
export interface Vote {
|
|
9
|
+
amount: bigint;
|
|
10
|
+
type: VoteType;
|
|
11
|
+
}
|
|
12
|
+
export interface SingleVoteState {
|
|
13
|
+
available: bigint;
|
|
14
|
+
vote?: BaseVote;
|
|
15
|
+
voteCalls: Array<Vote>;
|
|
16
|
+
}
|
|
17
|
+
export interface VoteProps {
|
|
18
|
+
state: Omit<SingleVoteState, "voteCalls">;
|
|
19
|
+
change?: Vote;
|
|
20
|
+
}
|
|
21
|
+
interface UnvoteProps {
|
|
22
|
+
initialVote?: BaseVote;
|
|
23
|
+
balanceAfter: bigint;
|
|
24
|
+
nextVoteType: BaseVoteType;
|
|
25
|
+
voteAfter?: Omit<SingleVoteState, "available">;
|
|
26
|
+
}
|
|
27
|
+
export interface GetGaugeApyProps {
|
|
28
|
+
quota: Pick<GaugeQuotaParams, "totalVotesCaSide" | "totalVotesLpSide" | "stakerVotesCaSide" | "stakerVotesLpSide" | "minRate" | "maxRate"> | undefined;
|
|
29
|
+
vote?: BaseVote;
|
|
30
|
+
voteAfter?: Omit<SingleVoteState, "available">;
|
|
31
|
+
}
|
|
32
|
+
export declare class GaugeMath {
|
|
33
|
+
static vote({ change, ...rest }: VoteProps): SingleVoteState | undefined;
|
|
34
|
+
private static addVotes;
|
|
35
|
+
private static removeVotes;
|
|
36
|
+
static revertVote({ balanceAfter, initialVote, nextVoteType, voteAfter, }: UnvoteProps): bigint | undefined;
|
|
37
|
+
static getBaseVote: (v: GaugeQuotaParams) => BaseVote | undefined;
|
|
38
|
+
static getGaugeApy({ quota, voteAfter, vote }: GetGaugeApyProps): number | null;
|
|
39
|
+
}
|
|
40
|
+
export {};
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GaugeMath = void 0;
|
|
4
|
+
const sdk_gov_1 = require("@gearbox-protocol/sdk-gov");
|
|
5
|
+
const math_1 = require("../utils/math");
|
|
6
|
+
class GaugeMath {
|
|
7
|
+
static vote({ change, ...rest }) {
|
|
8
|
+
if (change?.type === "remove") {
|
|
9
|
+
return this.removeVotes({ ...rest, change });
|
|
10
|
+
}
|
|
11
|
+
if (change) {
|
|
12
|
+
return this.addVotes({
|
|
13
|
+
...rest,
|
|
14
|
+
change: { ...change, type: change.type },
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
return { ...rest.state, voteCalls: [] };
|
|
18
|
+
}
|
|
19
|
+
static addVotes({ state, change }) {
|
|
20
|
+
const { available, vote } = state;
|
|
21
|
+
if (!vote) {
|
|
22
|
+
return {
|
|
23
|
+
available: available - change.amount,
|
|
24
|
+
vote: change,
|
|
25
|
+
voteCalls: [change],
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
if (vote.type === change.type) {
|
|
29
|
+
return {
|
|
30
|
+
available: available - change.amount,
|
|
31
|
+
vote: { ...change, amount: vote.amount + change.amount },
|
|
32
|
+
voteCalls: [change],
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
const remove = { type: "remove", amount: vote.amount };
|
|
36
|
+
return {
|
|
37
|
+
available: available + vote.amount - change.amount,
|
|
38
|
+
vote: { ...change, amount: change.amount },
|
|
39
|
+
voteCalls: [remove, change],
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
static removeVotes({ state, change }) {
|
|
43
|
+
const { available, vote } = state;
|
|
44
|
+
if (!vote)
|
|
45
|
+
return { ...state, voteCalls: [] };
|
|
46
|
+
const safeChange = math_1.BigIntMath.min(vote.amount, change.amount);
|
|
47
|
+
const afterVote = vote.amount - safeChange;
|
|
48
|
+
return {
|
|
49
|
+
available: available + safeChange,
|
|
50
|
+
vote: { ...vote, amount: afterVote },
|
|
51
|
+
voteCalls: [{ ...change, amount: safeChange }],
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
static revertVote({ balanceAfter, initialVote, nextVoteType, voteAfter, }) {
|
|
55
|
+
// on vote type change unvote previous vote
|
|
56
|
+
const prevUnvoted = !initialVote || initialVote.type === nextVoteType
|
|
57
|
+
? balanceAfter
|
|
58
|
+
: balanceAfter + initialVote.amount;
|
|
59
|
+
if (!voteAfter)
|
|
60
|
+
return prevUnvoted;
|
|
61
|
+
// change call is always last, remove is always first
|
|
62
|
+
const [first, last = first] = voteAfter.voteCalls;
|
|
63
|
+
const removePart = first?.type === "remove" ? first?.amount || 0n : 0n;
|
|
64
|
+
const addPart = last?.type !== "remove" ? last?.amount || 0n : 0n;
|
|
65
|
+
// revert current changes
|
|
66
|
+
return prevUnvoted + addPart - removePart;
|
|
67
|
+
}
|
|
68
|
+
static getBaseVote = (v) => {
|
|
69
|
+
const voteDown = v.stakerVotesCaSide;
|
|
70
|
+
const voteUp = v.stakerVotesLpSide;
|
|
71
|
+
if (!voteDown && !voteUp)
|
|
72
|
+
return undefined;
|
|
73
|
+
if (voteDown > 0) {
|
|
74
|
+
return { type: "lower", amount: voteDown };
|
|
75
|
+
}
|
|
76
|
+
if (voteUp > 0) {
|
|
77
|
+
return { type: "raise", amount: voteUp };
|
|
78
|
+
}
|
|
79
|
+
return undefined;
|
|
80
|
+
};
|
|
81
|
+
// rate = (minRate *(votesFormin + yourvotesformin) +maxRate*(votesFormax +yourvotesformax)/( votesForMin + votesForMax+yourvotes)
|
|
82
|
+
static getGaugeApy({ quota, voteAfter, vote }) {
|
|
83
|
+
if (!quota)
|
|
84
|
+
return null;
|
|
85
|
+
const first = voteAfter?.voteCalls?.[0];
|
|
86
|
+
const last = voteAfter?.voteCalls?.[1] || first;
|
|
87
|
+
const isRemove = first?.type === "remove";
|
|
88
|
+
const removeCaPart = isRemove && vote?.type === "lower" ? first?.amount || 0n : 0n;
|
|
89
|
+
const removeLpPart = isRemove && vote?.type === "raise" ? first?.amount || 0n : 0n;
|
|
90
|
+
const caPart = last?.type === "lower" ? last?.amount || 0n : 0n;
|
|
91
|
+
const lpPart = last?.type === "raise" ? last?.amount || 0n : 0n;
|
|
92
|
+
const caImpact = (0, sdk_gov_1.toBigInt)(quota.minRate) *
|
|
93
|
+
(quota.totalVotesCaSide + caPart - removeCaPart);
|
|
94
|
+
const lpImpact = (0, sdk_gov_1.toBigInt)(quota.maxRate) *
|
|
95
|
+
(quota.totalVotesLpSide + lpPart - removeLpPart);
|
|
96
|
+
const total = quota.totalVotesCaSide +
|
|
97
|
+
quota.totalVotesLpSide +
|
|
98
|
+
caPart +
|
|
99
|
+
lpPart -
|
|
100
|
+
removeCaPart -
|
|
101
|
+
removeLpPart;
|
|
102
|
+
if (total === 0n)
|
|
103
|
+
return quota.minRate;
|
|
104
|
+
const r = (caImpact + lpImpact) / total;
|
|
105
|
+
return Number(r);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
exports.GaugeMath = GaugeMath;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|