@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
|
@@ -4,17 +4,24 @@ exports.CreditFacadeParser = void 0;
|
|
|
4
4
|
const types_1 = require("../types");
|
|
5
5
|
const abstractParser_1 = require("./abstractParser");
|
|
6
6
|
class CreditFacadeParser extends abstractParser_1.AbstractParser {
|
|
7
|
-
|
|
7
|
+
version;
|
|
8
|
+
constructor(token, version) {
|
|
8
9
|
super(token);
|
|
9
|
-
this.
|
|
10
|
+
this.version = version;
|
|
11
|
+
this.ifc =
|
|
12
|
+
version === 300
|
|
13
|
+
? types_1.ICreditFacadeV3Multicall__factory.createInterface()
|
|
14
|
+
: types_1.ICreditFacadeV2Extended__factory.createInterface();
|
|
10
15
|
this.adapterName = "CreditFacade";
|
|
11
16
|
}
|
|
12
17
|
parse(calldata) {
|
|
13
18
|
const { functionFragment, functionName } = this.parseSelector(calldata);
|
|
14
19
|
switch (functionFragment.name) {
|
|
15
20
|
case "addCollateral": {
|
|
16
|
-
const
|
|
17
|
-
|
|
21
|
+
const r = this.decodeFunctionData(functionFragment, calldata);
|
|
22
|
+
const token = r[0];
|
|
23
|
+
const amount = r[1];
|
|
24
|
+
return `${functionName}(token: ${this.tokenSymbol(token)}, amount: ${this.formatBN(amount, this.tokenSymbol(token))})`;
|
|
18
25
|
}
|
|
19
26
|
case "increaseDebt":
|
|
20
27
|
case "decreaseDebt": {
|
|
@@ -26,16 +33,48 @@ class CreditFacadeParser extends abstractParser_1.AbstractParser {
|
|
|
26
33
|
const [address] = this.decodeFunctionData(functionFragment, calldata);
|
|
27
34
|
return `${functionName}(token: ${this.tokenSymbol(address)})`;
|
|
28
35
|
}
|
|
36
|
+
case "updateQuota": {
|
|
37
|
+
const [address, quotaUpdate, minQuota] = this.decodeFunctionData(functionFragment, calldata);
|
|
38
|
+
return `${functionName}(token: ${this.tokenSymbol(address)}, quotaUpdate: ${this.formatAmount(quotaUpdate)}, minQuota: ${this.formatAmount(minQuota)})`;
|
|
39
|
+
}
|
|
29
40
|
case "revertIfReceivedLessThan": {
|
|
30
41
|
const [balances] = this.decodeFunctionData(functionFragment, calldata);
|
|
31
42
|
const balancesStr = balances
|
|
32
43
|
.map(b => {
|
|
44
|
+
const balance = "balance" in b ? b.balance : b.amount;
|
|
33
45
|
const symbol = this.tokenSymbol(b.token);
|
|
34
|
-
return `${symbol}: ${this.formatBN(
|
|
46
|
+
return `${symbol}: ${this.formatBN(balance, symbol)}`;
|
|
35
47
|
})
|
|
36
48
|
.join(", ");
|
|
37
49
|
return `${functionName}(${balancesStr})`;
|
|
38
50
|
}
|
|
51
|
+
case "withdrawCollateral": {
|
|
52
|
+
const [token, amount, to] = this.decodeFunctionData(functionFragment, calldata);
|
|
53
|
+
return `${functionName}(token: ${this.tokenSymbol(token)}, withdraw: ${this.formatBN(amount, this.tokenSymbol(token))}, to: ${to})`;
|
|
54
|
+
}
|
|
55
|
+
case "addCollateralWithPermit": {
|
|
56
|
+
const [tokenAddress, amount, deadline, v, r, s] = this.decodeFunctionData(functionFragment, calldata);
|
|
57
|
+
return `${functionName}(token: ${this.tokenSymbol(tokenAddress)}, amount: ${this.formatBN(amount, this.tokenSymbol(tokenAddress))}, ${[deadline, v, r, s].join(", ")})`;
|
|
58
|
+
}
|
|
59
|
+
case "compareBalances": {
|
|
60
|
+
return `${functionName}()`;
|
|
61
|
+
}
|
|
62
|
+
case "setFullCheckParams": {
|
|
63
|
+
const [collateralHints, minHealthFactor] = this.decodeFunctionData(functionFragment, calldata);
|
|
64
|
+
return `${functionName}(token: ${collateralHints
|
|
65
|
+
.map((a) => this.formatAmount(a))
|
|
66
|
+
.join(", ")}, minHealthFactor: ${minHealthFactor})`;
|
|
67
|
+
}
|
|
68
|
+
case "storeExpectedBalances": {
|
|
69
|
+
const [balanceDeltas] = this.decodeFunctionData(functionFragment, calldata);
|
|
70
|
+
return `${functionName}(balanceDeltas: ${balanceDeltas
|
|
71
|
+
.map((b) => `${this.tokenSymbol(b.token)}: ${this.formatBN(b.amount, this.tokenSymbol(b.token))}`)
|
|
72
|
+
.join(", ")})`;
|
|
73
|
+
}
|
|
74
|
+
case "onDemandPriceUpdate": {
|
|
75
|
+
const [token, reserve, data] = this.decodeFunctionData(functionFragment, calldata);
|
|
76
|
+
return `${functionName}(token: ${this.tokenSymbol(token)}, reserve: ${reserve}, data: ${data})`;
|
|
77
|
+
}
|
|
39
78
|
default:
|
|
40
79
|
return `${functionName}: Unknown operation ${functionFragment.name} with calldata ${calldata}`;
|
|
41
80
|
}
|
|
@@ -6,14 +6,13 @@ const types_1 = require("../types");
|
|
|
6
6
|
const creditFacadeParser_1 = require("./creditFacadeParser");
|
|
7
7
|
describe("CreditFacadeParser test", () => {
|
|
8
8
|
it("all functions works well", () => {
|
|
9
|
-
let parser = new creditFacadeParser_1.CreditFacadeParser("DAI");
|
|
9
|
+
let parser = new creditFacadeParser_1.CreditFacadeParser("DAI", 1);
|
|
10
10
|
const ifc = types_1.ICreditFacadeV2Extended__factory.createInterface();
|
|
11
11
|
let parsed = parser.parse(ifc.encodeFunctionData("addCollateral", [
|
|
12
|
-
sdk_gov_1.DUMB_ADDRESS,
|
|
13
12
|
sdk_gov_1.tokenDataByNetwork.Mainnet.WBTC,
|
|
14
|
-
(sdk_gov_1.
|
|
13
|
+
(10n ** (0, sdk_gov_1.toBigInt)(sdk_gov_1.decimals.WBTC) * 444n) / 10n,
|
|
15
14
|
]));
|
|
16
|
-
(0, chai_1.expect)(parsed).to.be.eq("CreditFacade[DAI].addCollateral(
|
|
15
|
+
(0, chai_1.expect)(parsed).to.be.eq("CreditFacade[DAI].addCollateral(token: WBTC, amount: 44.40 [4440000000])", "Incorrect parse addCollateral");
|
|
17
16
|
parsed = parser.parse(ifc.encodeFunctionData("increaseDebt", [(sdk_gov_1.WAD * 414n) / 10n]));
|
|
18
17
|
(0, chai_1.expect)(parsed).to.be.eq("CreditFacade[DAI].increaseDebt(amount: 41.40 [41400000000000000000])", "Incorrect parse increaseDebt");
|
|
19
18
|
parsed = parser.parse(ifc.encodeFunctionData("decreaseDebt", [(sdk_gov_1.WAD * 334n) / 10n]));
|
|
@@ -3,7 +3,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.CurveAdapterParser = void 0;
|
|
4
4
|
const sdk_gov_1 = require("@gearbox-protocol/sdk-gov");
|
|
5
5
|
const types_1 = require("../types");
|
|
6
|
-
const formatter_1 = require("../utils/formatter");
|
|
7
6
|
const abstractParser_1 = require("./abstractParser");
|
|
8
7
|
class CurveAdapterParser extends abstractParser_1.AbstractParser {
|
|
9
8
|
lpToken;
|
|
@@ -45,26 +44,26 @@ class CurveAdapterParser extends abstractParser_1.AbstractParser {
|
|
|
45
44
|
: this.getTokenByIndex(j);
|
|
46
45
|
return `${functionName}(i ,j: ${iSym} => ${jSym}, dx: ${this.formatBN(dx, iSym)}, min_dy: ${this.formatBN(min_dy, jSym)})`;
|
|
47
46
|
}
|
|
48
|
-
case "
|
|
49
|
-
case "
|
|
50
|
-
const [i, j, rateMinRAY] = this.decodeFunctionData(functionFragment, calldata);
|
|
51
|
-
const iSym = functionFragment.name === "
|
|
47
|
+
case "exchange_diff":
|
|
48
|
+
case "exchange_diff_underlying": {
|
|
49
|
+
const [i, j, leftoverAmount, rateMinRAY] = this.decodeFunctionData(functionFragment, calldata);
|
|
50
|
+
const iSym = functionFragment.name === "exchange_diff_underlying"
|
|
52
51
|
? this.getUnderlyingTokenByIndex(i)
|
|
53
52
|
: this.getTokenByIndex(i);
|
|
54
|
-
const jSym = functionFragment.name === "
|
|
53
|
+
const jSym = functionFragment.name === "exchange_diff_underlying"
|
|
55
54
|
? this.getUnderlyingTokenByIndex(j)
|
|
56
55
|
: this.getTokenByIndex(j);
|
|
57
|
-
return `${functionName}(i: ${iSym}, j: ${jSym}, rateMinRAY: ${(0,
|
|
56
|
+
return `${functionName}(i: ${iSym}, j: ${jSym}, leftoverAmount: ${this.formatBN(leftoverAmount, iSym)}, rateMinRAY: ${(0, sdk_gov_1.formatBN)(rateMinRAY, 27)}`;
|
|
58
57
|
}
|
|
59
58
|
case "add_liquidity_one_coin": {
|
|
60
59
|
const [amount, i, minAmount] = this.decodeFunctionData(functionFragment, calldata);
|
|
61
60
|
const iSym = this.getTokenByIndex(i);
|
|
62
61
|
return `${functionName}(amount: ${this.formatBN(amount, iSym)}, i: ${iSym}, minAmount: ${this.formatBN(minAmount, this.lpToken)})`;
|
|
63
62
|
}
|
|
64
|
-
case "
|
|
65
|
-
case "
|
|
66
|
-
const [i, rateMinRAY] = this.decodeFunctionData(functionFragment, calldata);
|
|
67
|
-
return `${functionName}(i: ${this.getTokenByIndex(i)}, rateMinRAY: ${(0,
|
|
63
|
+
case "add_diff_liquidity_one_coin":
|
|
64
|
+
case "remove_diff_liquidity_one_coin": {
|
|
65
|
+
const [leftoverAmount, i, rateMinRAY] = this.decodeFunctionData(functionFragment, calldata);
|
|
66
|
+
return `${functionName}(leftoverAmount: ${this.formatBN(leftoverAmount, i)}, i: ${this.getTokenByIndex(i)}, rateMinRAY: ${(0, sdk_gov_1.formatBN)(rateMinRAY, 27)})`;
|
|
68
67
|
}
|
|
69
68
|
case "add_liquidity": {
|
|
70
69
|
const [amounts, minAmount] = this.decodeFunctionData(functionFragment, calldata);
|
|
@@ -19,8 +19,12 @@ describe("CurveAdapterParser test", () => {
|
|
|
19
19
|
(0, chai_1.expect)(parsed).to.be.eq("Curve2AssetsAdapter[CURVE_FRAX_POOL].exchange_underlying(i ,j: FRAX => DAI, dx: 3.00 [3000000000000000000], min_dy: 32.00 [32000000000000000000])", "Curve2AssetsAdapter: Incorrect parse exchange_underlying");
|
|
20
20
|
parsed = parser.parse(ifc.encodeFunctionData("add_liquidity_one_coin", [sdk_gov_1.WAD * 3n, 0, sdk_gov_1.WAD * 2n]));
|
|
21
21
|
(0, chai_1.expect)(parsed).to.be.eq("Curve2AssetsAdapter[CURVE_FRAX_POOL].add_liquidity_one_coin(amount: 3.00 [3000000000000000000], i: FRAX, minAmount: 2.00 [2000000000000000000])", "Curve2AssetsAdapter: Incorrect parse add_liquidity_one_coin");
|
|
22
|
-
parsed = parser.parse(ifc.encodeFunctionData("
|
|
23
|
-
|
|
22
|
+
parsed = parser.parse(ifc.encodeFunctionData("add_diff_liquidity_one_coin", [
|
|
23
|
+
sdk_gov_1.WAD * 3n,
|
|
24
|
+
0,
|
|
25
|
+
sdk_gov_1.RAY * 912n,
|
|
26
|
+
]));
|
|
27
|
+
(0, chai_1.expect)(parsed).to.be.eq("Curve2AssetsAdapter[CURVE_FRAX_POOL].add_diff_liquidity_one_coin(leftoverAmount: 3.00 [3000000000000000000], i: FRAX, rateMinRAY: 912.00)", "Curve2AssetsAdapter: Incorrect parse add_diff_liquidity_one_coin");
|
|
24
28
|
parsed = parser.parse(ifc.encodeFunctionData("remove_liquidity_one_coin(uint256,uint256,uint256)", [sdk_gov_1.WAD * 100n, 0, sdk_gov_1.WAD * 10n]));
|
|
25
29
|
(0, chai_1.expect)(parsed).to.be.eq("Curve2AssetsAdapter[CURVE_FRAX_POOL].remove_liquidity_one_coin(amount: 100.00 [100000000000000000000],i: FRAX, min_amount: 10.00 [10000000000000000000])", "Curve2AssetsAdapter: Incorrect parse remove_liquidity_one_coin");
|
|
26
30
|
parsed = parser.parse(ifc.encodeFunctionData("add_liquidity", [
|
|
@@ -17,8 +17,9 @@ class LidoAdapterParser extends abstractParser_1.AbstractParser {
|
|
|
17
17
|
const [amount] = this.decodeFunctionData(functionFragment, calldata);
|
|
18
18
|
return `${functionName}(amount: ${this.formatBN(amount, "STETH")})`;
|
|
19
19
|
}
|
|
20
|
-
case "
|
|
21
|
-
|
|
20
|
+
case "submitDiff": {
|
|
21
|
+
const [leftoverAmount] = this.decodeFunctionData(functionFragment, calldata);
|
|
22
|
+
return `${functionName}(leftoverAmount: ${this.formatBN(leftoverAmount, "STETH")})`;
|
|
22
23
|
}
|
|
23
24
|
default:
|
|
24
25
|
return `${functionName}: Unknown operation ${functionFragment.name} with calldata ${calldata}`;
|
|
@@ -11,7 +11,7 @@ describe("LidoAdapterParser test", () => {
|
|
|
11
11
|
let parsed = parser.parse(ifc.encodeFunctionData("submit", [sdk_gov_1.WAD * 1020n]));
|
|
12
12
|
(0, chai_1.expect)(parsed).to.be.eq("LidoV1Adapter[LIDO_STETH_GATEWAY].submit(amount: 1.02K [1020000000000000000000])", "Incorrect parse submit(amount)");
|
|
13
13
|
parser = new lidoAdapterParser_1.LidoAdapterParser("LIDO_STETH_GATEWAY", true);
|
|
14
|
-
parsed = parser.parse(ifc.encodeFunctionData("
|
|
15
|
-
(0, chai_1.expect)(parsed).to.be.eq("Contract[LIDO_STETH_GATEWAY].
|
|
14
|
+
parsed = parser.parse(ifc.encodeFunctionData("submitDiff", [sdk_gov_1.WAD * 1020n]));
|
|
15
|
+
(0, chai_1.expect)(parsed).to.be.eq("Contract[LIDO_STETH_GATEWAY].submitDiff(leftoverAmount: 1.02K [1020000000000000000000])", "Incorrect parse submitDiff(leftoverAmount)");
|
|
16
16
|
});
|
|
17
17
|
});
|
|
@@ -27,7 +27,7 @@ export declare class TxParser {
|
|
|
27
27
|
}[];
|
|
28
28
|
static addAdapters(adapters: Array<AdapterForParser>): void;
|
|
29
29
|
static addContracts(network: NetworkType): void;
|
|
30
|
-
static addCreditFacade(creditFacade: string, underlying: SupportedToken): void;
|
|
30
|
+
static addCreditFacade(creditFacade: string, underlying: SupportedToken, version: number): void;
|
|
31
31
|
static addTokens(network: NetworkType): void;
|
|
32
32
|
static addPriceOracle(address: string): void;
|
|
33
33
|
static addAddressProvider(address: string): void;
|
package/lib/parsers/txParser.js
CHANGED
|
@@ -22,7 +22,13 @@ class TxParser {
|
|
|
22
22
|
static parsers = {};
|
|
23
23
|
static parse(address, calldata) {
|
|
24
24
|
const parser = TxParser.getParser(address);
|
|
25
|
-
|
|
25
|
+
try {
|
|
26
|
+
return parser.parse(calldata);
|
|
27
|
+
}
|
|
28
|
+
catch (e) {
|
|
29
|
+
console.error(`Error while parsing ${address}`, parser, e);
|
|
30
|
+
return "Parsing error";
|
|
31
|
+
}
|
|
26
32
|
}
|
|
27
33
|
static parseToObject(address, calldata) {
|
|
28
34
|
const parser = TxParser.getParser(address);
|
|
@@ -61,8 +67,8 @@ class TxParser {
|
|
|
61
67
|
}
|
|
62
68
|
});
|
|
63
69
|
}
|
|
64
|
-
static addCreditFacade(creditFacade, underlying) {
|
|
65
|
-
TxParser._addParser(creditFacade, new creditFacadeParser_1.CreditFacadeParser(underlying));
|
|
70
|
+
static addCreditFacade(creditFacade, underlying, version) {
|
|
71
|
+
TxParser._addParser(creditFacade, new creditFacadeParser_1.CreditFacadeParser(underlying, version));
|
|
66
72
|
}
|
|
67
73
|
static addTokens(network) {
|
|
68
74
|
sdk_gov_1.TypedObjectUtils.entries(sdk_gov_1.tokenDataByNetwork[network]).forEach(([s, t]) => {
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.UniswapV2AdapterParser = void 0;
|
|
4
|
+
const sdk_gov_1 = require("@gearbox-protocol/sdk-gov");
|
|
4
5
|
const types_1 = require("../types");
|
|
5
|
-
const formatter_1 = require("../utils/formatter");
|
|
6
6
|
const abstractParser_1 = require("./abstractParser");
|
|
7
7
|
class UniswapV2AdapterParser extends abstractParser_1.AbstractParser {
|
|
8
8
|
constructor(contract, isContract) {
|
|
@@ -39,9 +39,10 @@ class UniswapV2AdapterParser extends abstractParser_1.AbstractParser {
|
|
|
39
39
|
const amountInMaxStr = this.formatBN(amountInMax, tokenOut);
|
|
40
40
|
return `${functionName}(amountOut: ${amountOutStr}, amountInMax: ${amountInMaxStr}, path: [${pathStr}])`;
|
|
41
41
|
}
|
|
42
|
-
case "
|
|
43
|
-
const [rateMinRAY, path] = this.decodeFunctionData(functionFragment, calldata);
|
|
44
|
-
|
|
42
|
+
case "swapDiffTokensForTokens": {
|
|
43
|
+
const [leftoverAmount, rateMinRAY, path] = this.decodeFunctionData(functionFragment, calldata);
|
|
44
|
+
const tokenIn = this.tokenSymbol(path[0]);
|
|
45
|
+
return `${functionName}(leftoverAmount: ${this.formatBN(leftoverAmount, tokenIn)}, rate: ${(0, sdk_gov_1.formatBN)(rateMinRAY, 27)}, path: [${path
|
|
45
46
|
.map(r => this.tokenSymbol(r))
|
|
46
47
|
.join(" => ")}])`;
|
|
47
48
|
}
|
|
@@ -32,7 +32,8 @@ describe("UniswapV2AdapterParser test", () => {
|
|
|
32
32
|
45033,
|
|
33
33
|
]));
|
|
34
34
|
(0, chai_1.expect)(parsed).to.be.eq("UniswapV2Adapter[UNISWAP_V2_ROUTER].swapTokensForExactTokens(amountOut: 234.50K [234500000000], amountInMax: 17.70K [17700000000000000000000], path: [USDC => DAI => FRAX])", "Incorrect parse swapTokensForExactTokens");
|
|
35
|
-
parsed = parser.parse(ifc.encodeFunctionData("
|
|
35
|
+
parsed = parser.parse(ifc.encodeFunctionData("swapDiffTokensForTokens", [
|
|
36
|
+
BigInt(1e6) * 234500n,
|
|
36
37
|
sdk_gov_1.RAY * 3240n,
|
|
37
38
|
[
|
|
38
39
|
sdk_gov_1.tokenDataByNetwork.Mainnet.USDC,
|
|
@@ -41,6 +42,6 @@ describe("UniswapV2AdapterParser test", () => {
|
|
|
41
42
|
],
|
|
42
43
|
45033,
|
|
43
44
|
]));
|
|
44
|
-
(0, chai_1.expect)(parsed).to.be.eq("UniswapV2Adapter[UNISWAP_V2_ROUTER].
|
|
45
|
+
(0, chai_1.expect)(parsed).to.be.eq("UniswapV2Adapter[UNISWAP_V2_ROUTER].swapDiffTokensForTokens(leftoverAmount: 234.50K [234500000000], rate: 3.24K, path: [USDC => DAI => FRAX])", "Incorrect parse swapDiffTokensForTokens");
|
|
45
46
|
});
|
|
46
47
|
});
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.UniswapV3AdapterParser = void 0;
|
|
4
|
+
const sdk_gov_1 = require("@gearbox-protocol/sdk-gov");
|
|
4
5
|
const types_1 = require("../types");
|
|
5
|
-
const formatter_1 = require("../utils/formatter");
|
|
6
6
|
const abstractParser_1 = require("./abstractParser");
|
|
7
7
|
class UniswapV3AdapterParser extends abstractParser_1.AbstractParser {
|
|
8
8
|
constructor(contract, isContract) {
|
|
@@ -22,11 +22,12 @@ class UniswapV3AdapterParser extends abstractParser_1.AbstractParser {
|
|
|
22
22
|
const amountOutMinimumStr = this.formatBN(amountOutMinimum, tokenOut);
|
|
23
23
|
return `${functionName}(amountIn: ${amountInStr}, amountOutMinimum: ${amountOutMinimumStr}, path: ${tokenInSym} ==(fee: ${fee})==> ${tokenOutSym})`;
|
|
24
24
|
}
|
|
25
|
-
case "
|
|
26
|
-
const { params: { tokenIn, tokenOut, fee, rateMinRAY }, } = this.decodeFunctionData(functionFragment, calldata);
|
|
25
|
+
case "exactDiffInputSingle": {
|
|
26
|
+
const { params: { tokenIn, tokenOut, fee, leftoverAmount, rateMinRAY }, } = this.decodeFunctionData(functionFragment, calldata);
|
|
27
27
|
const tokenInSym = this.tokenSymbol(tokenIn);
|
|
28
28
|
const tokenOutSym = this.tokenSymbol(tokenOut);
|
|
29
|
-
|
|
29
|
+
const leftoverAmountStr = this.formatBN(leftoverAmount, tokenIn);
|
|
30
|
+
return `${functionName}(leftoverAmount: ${leftoverAmountStr}, rate: ${(0, sdk_gov_1.formatBN)(rateMinRAY, 27)}, path: ${tokenInSym} ==(fee: ${fee})==> ${tokenOutSym})`;
|
|
30
31
|
}
|
|
31
32
|
case "exactInput": {
|
|
32
33
|
const { params: { amountIn, amountOutMinimum, path }, } = this.decodeFunctionData(functionFragment, calldata);
|
|
@@ -35,10 +36,11 @@ class UniswapV3AdapterParser extends abstractParser_1.AbstractParser {
|
|
|
35
36
|
const amountOutMinimumStr = this.formatBN(amountOutMinimum, this.tokenSymbol(`0x${path.slice(-40, path.length)}`));
|
|
36
37
|
return `${functionName}(amountIn: ${amountInStr}, amountOutMinimum: ${amountOutMinimumStr}, path: ${pathStr}`;
|
|
37
38
|
}
|
|
38
|
-
case "
|
|
39
|
-
const { params: { rateMinRAY, path }, } = this.decodeFunctionData(functionFragment, calldata);
|
|
39
|
+
case "exactDiffInput": {
|
|
40
|
+
const { params: { leftoverAmount, rateMinRAY, path }, } = this.decodeFunctionData(functionFragment, calldata);
|
|
41
|
+
const leftoverAmountStr = this.formatBN(leftoverAmount, this.tokenSymbol(`0x${path.replace("0x", "").slice(0, 40)}`));
|
|
40
42
|
const pathStr = this.trackInputPath(path);
|
|
41
|
-
return `${functionName}(rate: ${(0,
|
|
43
|
+
return `${functionName}(leftoverAmount: ${leftoverAmountStr}, rate: ${(0, sdk_gov_1.formatBN)(rateMinRAY, 27)}, path: ${pathStr}`;
|
|
42
44
|
}
|
|
43
45
|
case "exactOutput": {
|
|
44
46
|
const { params: { amountInMaximum, amountOut, path }, } = this.decodeFunctionData(functionFragment, calldata);
|
|
@@ -71,18 +71,19 @@ describe("UniswapV3AdapterParser test", () => {
|
|
|
71
71
|
},
|
|
72
72
|
]));
|
|
73
73
|
(0, chai_1.expect)(parsed).to.be.eq("UniswapV3Adapter[UNISWAP_V3_ROUTER].exactInput(amountIn: 12.39K [12399000000000000000000], amountOutMinimum: 122.00 [122000000], path: AAVE ==(fee: 3000)==> LINK ==(fee: 3000)==> USDC", "Incorrect parse swapExactTokensForTokens");
|
|
74
|
-
parsed = parser.parse(ifc.encodeFunctionData("
|
|
74
|
+
parsed = parser.parse(ifc.encodeFunctionData("exactDiffInput", [
|
|
75
75
|
{
|
|
76
76
|
path: pathToUniV3Path([
|
|
77
77
|
sdk_gov_1.tokenDataByNetwork.Mainnet.AAVE,
|
|
78
78
|
sdk_gov_1.tokenDataByNetwork.Mainnet.LINK,
|
|
79
79
|
sdk_gov_1.tokenDataByNetwork.Mainnet.USDC,
|
|
80
80
|
]),
|
|
81
|
+
leftoverAmount: sdk_gov_1.WAD * 12399n,
|
|
81
82
|
rateMinRAY: sdk_gov_1.RAY * 1200n,
|
|
82
83
|
deadline: 1232131,
|
|
83
84
|
},
|
|
84
85
|
]));
|
|
85
|
-
(0, chai_1.expect)(parsed).to.be.eq("UniswapV3Adapter[UNISWAP_V3_ROUTER].
|
|
86
|
+
(0, chai_1.expect)(parsed).to.be.eq("UniswapV3Adapter[UNISWAP_V3_ROUTER].exactDiffInput(leftoverAmount: 12.39K [12399000000000000000000], rate: 1.20K, path: AAVE ==(fee: 3000)==> LINK ==(fee: 3000)==> USDC", "Incorrect parse swapExactTokensForTokens");
|
|
86
87
|
// parsed = parser.parse(
|
|
87
88
|
// ifc.encodeFunctionData("exactOutputSingle", [
|
|
88
89
|
// {
|
|
@@ -20,15 +20,17 @@ class WstETHAdapterParser extends abstractParser_1.AbstractParser {
|
|
|
20
20
|
const [amount] = this.decodeFunctionData(functionFragment, calldata);
|
|
21
21
|
return `${functionName}(amount: ${this.formatBN(amount, "STETH")})`;
|
|
22
22
|
}
|
|
23
|
-
case "
|
|
24
|
-
|
|
23
|
+
case "wrapDiff": {
|
|
24
|
+
const [leftoverAmount] = this.decodeFunctionData(functionFragment, calldata);
|
|
25
|
+
return `${functionName}(leftoverAmount: ${this.formatBN(leftoverAmount, "STETH")})`;
|
|
25
26
|
}
|
|
26
27
|
case "unwrap": {
|
|
27
28
|
const [amount] = this.decodeFunctionData(functionFragment, calldata);
|
|
28
29
|
return `${functionName}(amount: ${this.formatBN(amount, "wstETH")})`;
|
|
29
30
|
}
|
|
30
|
-
case "
|
|
31
|
-
|
|
31
|
+
case "unwrapDiff": {
|
|
32
|
+
const [leftoverAmount] = this.decodeFunctionData(functionFragment, calldata);
|
|
33
|
+
return `${functionName}(leftoverAmount: ${this.formatBN(leftoverAmount, "STETH")})`;
|
|
32
34
|
}
|
|
33
35
|
case "balanceOf": {
|
|
34
36
|
const [address] = this.decodeFunctionData(functionFragment, calldata);
|
|
@@ -8,10 +8,10 @@ describe("WstETHAdapterParser test", () => {
|
|
|
8
8
|
it("wrap / unwrap function works well", () => {
|
|
9
9
|
let parser = new wstETHAdapterParser_1.WstETHAdapterParser("LIDO_WSTETH", false);
|
|
10
10
|
const ifc = types_1.IwstETHV1Adapter__factory.createInterface();
|
|
11
|
-
let parsed = parser.parse(ifc.encodeFunctionData("
|
|
12
|
-
(0, chai_1.expect)(parsed).to.be.eq("wstETHAdapter[LIDO_WSTETH].
|
|
13
|
-
parsed = parser.parse(ifc.encodeFunctionData("
|
|
14
|
-
(0, chai_1.expect)(parsed).to.be.eq("wstETHAdapter[LIDO_WSTETH].
|
|
11
|
+
let parsed = parser.parse(ifc.encodeFunctionData("wrapDiff", [sdk_gov_1.WAD * 1020n]));
|
|
12
|
+
(0, chai_1.expect)(parsed).to.be.eq("wstETHAdapter[LIDO_WSTETH].wrapDiff(leftoverAmount: 1.02K [1020000000000000000000])", "Incorrect parse wrapDiff()");
|
|
13
|
+
parsed = parser.parse(ifc.encodeFunctionData("unwrapDiff", [sdk_gov_1.WAD * 1020n]));
|
|
14
|
+
(0, chai_1.expect)(parsed).to.be.eq("wstETHAdapter[LIDO_WSTETH].unwrapDiff(leftoverAmount: 1.02K [1020000000000000000000])", "Incorrect parse unwrapDiff()");
|
|
15
15
|
parser = new wstETHAdapterParser_1.WstETHAdapterParser("LIDO_WSTETH", true);
|
|
16
16
|
parsed = parser.parse(ifc.encodeFunctionData("wrap", [sdk_gov_1.WAD * 1020n]));
|
|
17
17
|
(0, chai_1.expect)(parsed).to.be.eq("Contract[LIDO_WSTETH].wrap(amount: 1.02K [1020000000000000000000])", "Incorrect parse wrap(amount)");
|
|
@@ -8,8 +8,8 @@ describe("YearnV2AdapterParser test", () => {
|
|
|
8
8
|
it("deposit / withdraw functions works well", () => {
|
|
9
9
|
let parser = new yearnV2AdapterParser_1.YearnV2AdapterParser("YEARN_CURVE_STETH_VAULT", false);
|
|
10
10
|
const ifc = types_1.IYearnV2Adapter__factory.createInterface();
|
|
11
|
-
let parsed = parser.parse(ifc.encodeFunctionData("
|
|
12
|
-
(0, chai_1.expect)(parsed).to.be.eq("YearnV2Adapter[YEARN_CURVE_STETH_VAULT].
|
|
11
|
+
let parsed = parser.parse(ifc.encodeFunctionData("depositDiff", [sdk_gov_1.WAD * 19000n]));
|
|
12
|
+
(0, chai_1.expect)(parsed).to.be.eq("YearnV2Adapter[YEARN_CURVE_STETH_VAULT].depositDiff(leftoverAmount: 19.00K [19000000000000000000000])", "Incorrect parse depositDiff");
|
|
13
13
|
parsed = parser.parse(ifc.encodeFunctionData("deposit(uint256)", [sdk_gov_1.WAD * 19000n]));
|
|
14
14
|
(0, chai_1.expect)(parsed).to.be.eq("YearnV2Adapter[YEARN_CURVE_STETH_VAULT].deposit(amount: 19.00K [19000000000000000000000])", "Incorrect parse deposit(amount)");
|
|
15
15
|
parsed = parser.parse(ifc.encodeFunctionData("deposit(uint256,address)", [
|
|
@@ -17,8 +17,8 @@ describe("YearnV2AdapterParser test", () => {
|
|
|
17
17
|
sdk_gov_1.DUMB_ADDRESS,
|
|
18
18
|
]));
|
|
19
19
|
(0, chai_1.expect)(parsed).to.be.eq(`YearnV2Adapter[YEARN_CURVE_STETH_VAULT].deposit(amount: 19.00K [19000000000000000000000], address: ${sdk_gov_1.DUMB_ADDRESS})`, "Incorrect parse deposit(amount,address)");
|
|
20
|
-
parsed = parser.parse(ifc.encodeFunctionData("
|
|
21
|
-
(0, chai_1.expect)(parsed).to.be.eq("YearnV2Adapter[YEARN_CURVE_STETH_VAULT].
|
|
20
|
+
parsed = parser.parse(ifc.encodeFunctionData("withdrawDiff", [sdk_gov_1.WAD * 19000n]));
|
|
21
|
+
(0, chai_1.expect)(parsed).to.be.eq("YearnV2Adapter[YEARN_CURVE_STETH_VAULT].withdrawDiff(leftoverAmount: 19.00K [19000000000000000000000])", "Incorrect parse withdrawDiff");
|
|
22
22
|
parsed = parser.parse(ifc.encodeFunctionData("withdraw(uint256)", [sdk_gov_1.WAD * 19000n]));
|
|
23
23
|
(0, chai_1.expect)(parsed).to.be.eq("YearnV2Adapter[YEARN_CURVE_STETH_VAULT].withdraw(amount: 19.00K [19000000000000000000000])", "Incorrect parse withdraw(amount)");
|
|
24
24
|
parsed = parser.parse(ifc.encodeFunctionData("withdraw(uint256,address)", [
|
|
@@ -7,7 +7,7 @@ const abstractParser_1 = require("./abstractParser");
|
|
|
7
7
|
class YearnV2AdapterParser extends abstractParser_1.AbstractParser {
|
|
8
8
|
constructor(contract, isContract) {
|
|
9
9
|
super(contract);
|
|
10
|
-
this.ifc = types_1.
|
|
10
|
+
this.ifc = types_1.IYearnV2Adapter__factory.createInterface();
|
|
11
11
|
if (!isContract)
|
|
12
12
|
this.adapterName = "YearnV2Adapter";
|
|
13
13
|
}
|
|
@@ -16,8 +16,6 @@ class YearnV2AdapterParser extends abstractParser_1.AbstractParser {
|
|
|
16
16
|
switch (functionFragment.name) {
|
|
17
17
|
case "deposit":
|
|
18
18
|
case "withdraw":
|
|
19
|
-
case "deposit(uint256)":
|
|
20
|
-
case "withdraw(uint256)":
|
|
21
19
|
case "withdraw(uint256,address,uint256)": {
|
|
22
20
|
const [amount, address, maxLoss] = this.decodeFunctionData(functionFragment, calldata);
|
|
23
21
|
const yvSym = this.tokenSymbol(sdk_gov_1.contractsByNetwork.Mainnet[this.contract]);
|
|
@@ -28,6 +26,18 @@ class YearnV2AdapterParser extends abstractParser_1.AbstractParser {
|
|
|
28
26
|
const maxLossStr = maxLoss ? `, maxLoss: ${maxLoss}` : "";
|
|
29
27
|
return `${functionName}(${amountStr}${addressStr}${maxLossStr})`;
|
|
30
28
|
}
|
|
29
|
+
case "depositDiff": {
|
|
30
|
+
const [leftoverAmount] = this.decodeFunctionData(functionFragment, calldata);
|
|
31
|
+
const yvSym = this.tokenSymbol(sdk_gov_1.contractsByNetwork.Mainnet[this.contract]);
|
|
32
|
+
const leftoverAmountStr = this.formatBN(leftoverAmount, yvSym);
|
|
33
|
+
return `${functionName}(leftoverAmount: ${leftoverAmountStr})`;
|
|
34
|
+
}
|
|
35
|
+
case "withdrawDiff": {
|
|
36
|
+
const [leftoverAmount] = this.decodeFunctionData(functionFragment, calldata);
|
|
37
|
+
const yvSym = this.tokenSymbol(sdk_gov_1.contractsByNetwork.Mainnet[this.contract]);
|
|
38
|
+
const leftoverAmountStr = this.formatBN(leftoverAmount, yvSym);
|
|
39
|
+
return `${functionName}(leftoverAmount: ${leftoverAmountStr})`;
|
|
40
|
+
}
|
|
31
41
|
case "pricePerShare": {
|
|
32
42
|
return `${functionName}()`;
|
|
33
43
|
}
|
package/lib/pathfinder/core.d.ts
CHANGED
|
@@ -1,21 +1,20 @@
|
|
|
1
1
|
import { ExcludeArrayProps } from "@gearbox-protocol/sdk-gov";
|
|
2
|
-
import { MultiCallStructOutput,
|
|
2
|
+
import { MultiCallStructOutput, RouterResultStructOutput, SwapTaskStruct } from "../types/IRouterV3";
|
|
3
|
+
import { BigintifyProps } from "../utils/types";
|
|
3
4
|
export declare enum SwapOperation {
|
|
4
5
|
EXACT_INPUT = 0,
|
|
5
6
|
EXACT_INPUT_ALL = 1,
|
|
6
7
|
EXACT_OUTPUT = 2
|
|
7
8
|
}
|
|
8
9
|
export type MultiCall = ExcludeArrayProps<MultiCallStructOutput>;
|
|
9
|
-
export type SwapTask = ExcludeArrayProps<
|
|
10
|
-
export
|
|
11
|
-
amount: bigint;
|
|
10
|
+
export type SwapTask = ExcludeArrayProps<SwapTaskStruct>;
|
|
11
|
+
export type PathFinderResult = Omit<BigintifyProps<ExcludeArrayProps<RouterResultStructOutput>>, "calls"> & {
|
|
12
12
|
calls: Array<MultiCall>;
|
|
13
|
-
}
|
|
14
|
-
export interface PathFinderOpenStrategyResult {
|
|
13
|
+
};
|
|
14
|
+
export interface PathFinderOpenStrategyResult extends PathFinderResult {
|
|
15
15
|
balances: Record<string, bigint>;
|
|
16
|
-
|
|
16
|
+
minBalances: Record<string, bigint>;
|
|
17
17
|
}
|
|
18
|
-
export interface PathFinderCloseResult {
|
|
18
|
+
export interface PathFinderCloseResult extends PathFinderResult {
|
|
19
19
|
underlyingBalance: bigint;
|
|
20
|
-
calls: Array<MultiCall>;
|
|
21
20
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CurveLPToken, NetworkType } from "@gearbox-protocol/sdk-gov";
|
|
1
|
+
import { BalancerLPToken, CurveLPToken, NetworkType } from "@gearbox-protocol/sdk-gov";
|
|
2
2
|
import { CaTokenBalance } from "../payload/creditAccount";
|
|
3
3
|
export interface PathOption {
|
|
4
4
|
target: string;
|
|
@@ -10,6 +10,7 @@ export type BalanceInterface = Pick<CaTokenBalance, "balance">;
|
|
|
10
10
|
export declare class PathOptionFactory {
|
|
11
11
|
static generatePathOptions(balances: Record<string, BalanceInterface>, loopsInTx: number): Array<PathOptionSerie>;
|
|
12
12
|
static getCurvePools(balances: Record<string, BalanceInterface>): Array<CurveLPToken>;
|
|
13
|
+
static getBalancerPools(balances: Record<string, BalanceInterface>): Array<BalancerLPToken>;
|
|
13
14
|
static next(path: PathOptionSerie): PathOptionSerie;
|
|
14
15
|
static detectNetwork(underlying: string): NetworkType;
|
|
15
16
|
}
|
|
@@ -5,8 +5,9 @@ const sdk_gov_1 = require("@gearbox-protocol/sdk-gov");
|
|
|
5
5
|
class PathOptionFactory {
|
|
6
6
|
static generatePathOptions(balances, loopsInTx) {
|
|
7
7
|
const curvePools = PathOptionFactory.getCurvePools(balances);
|
|
8
|
+
const balancerPools = PathOptionFactory.getBalancerPools(balances);
|
|
8
9
|
const network = PathOptionFactory.detectNetwork(Object.keys(balances)[0]);
|
|
9
|
-
const
|
|
10
|
+
const curveInitPO = curvePools.map(symbol => {
|
|
10
11
|
return {
|
|
11
12
|
target: sdk_gov_1.tokenDataByNetwork[network][symbol],
|
|
12
13
|
option: 0,
|
|
@@ -14,6 +15,14 @@ class PathOptionFactory {
|
|
|
14
15
|
.tokens.length,
|
|
15
16
|
};
|
|
16
17
|
});
|
|
18
|
+
const balancerInitPO = balancerPools.map(symbol => {
|
|
19
|
+
return {
|
|
20
|
+
target: sdk_gov_1.tokenDataByNetwork[network][symbol],
|
|
21
|
+
option: 0,
|
|
22
|
+
totalOptions: sdk_gov_1.balancerLpTokens[symbol].underlying.length,
|
|
23
|
+
};
|
|
24
|
+
});
|
|
25
|
+
const initPO = [...curveInitPO, ...balancerInitPO];
|
|
17
26
|
const totalLoops = initPO.reduce((acc, item) => acc * item.totalOptions, 1);
|
|
18
27
|
const result = [];
|
|
19
28
|
let currentPo = [...initPO];
|
|
@@ -56,6 +65,16 @@ class PathOptionFactory {
|
|
|
56
65
|
]);
|
|
57
66
|
return Array.from(curveSet.values());
|
|
58
67
|
}
|
|
68
|
+
static getBalancerPools(balances) {
|
|
69
|
+
const result = [];
|
|
70
|
+
for (const [token, { balance }] of Object.entries(balances)) {
|
|
71
|
+
const symbol = sdk_gov_1.tokenSymbolByAddress[token.toLowerCase()];
|
|
72
|
+
if ((0, sdk_gov_1.isBalancerLPToken)(symbol) && (0, sdk_gov_1.toBigInt)(balance) > 1) {
|
|
73
|
+
result.push(symbol);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return result;
|
|
77
|
+
}
|
|
59
78
|
static next(path) {
|
|
60
79
|
let newPath = [...path];
|
|
61
80
|
for (let i = path.length - 1; i >= 0; i--) {
|
|
@@ -61,7 +61,7 @@ describe("PathOptionFactory test", () => {
|
|
|
61
61
|
[sdk_gov_1.tokenDataByNetwork.Mainnet["3Crv"]]: { balance: 200n },
|
|
62
62
|
[sdk_gov_1.tokenDataByNetwork.Mainnet.USDC]: { balance: 200n },
|
|
63
63
|
[sdk_gov_1.tokenDataByNetwork.Mainnet.FRAX3CRV]: { balance: 200n },
|
|
64
|
-
[sdk_gov_1.tokenDataByNetwork.Mainnet
|
|
64
|
+
[sdk_gov_1.tokenDataByNetwork.Mainnet["50OHM_50DAI"]]: { balance: 200n },
|
|
65
65
|
};
|
|
66
66
|
const result = pathOptions_1.PathOptionFactory.generatePathOptions(balances, 4);
|
|
67
67
|
const expected = [
|
|
@@ -76,7 +76,7 @@ describe("PathOptionFactory test", () => {
|
|
|
76
76
|
totalOptions: 2,
|
|
77
77
|
},
|
|
78
78
|
{
|
|
79
|
-
target: sdk_gov_1.tokenDataByNetwork.Mainnet
|
|
79
|
+
target: sdk_gov_1.tokenDataByNetwork.Mainnet["50OHM_50DAI"],
|
|
80
80
|
option: 0,
|
|
81
81
|
totalOptions: 2,
|
|
82
82
|
},
|