@gearbox-protocol/sdk 3.0.0-next.7 → 3.0.0-next.70

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.
Files changed (465) hide show
  1. package/contracts/index.sol +29 -4
  2. package/lib/apy/curveAPY.js +2 -1
  3. package/lib/apy/index.d.ts +2 -2
  4. package/lib/apy/yearnAPY.js +1 -1
  5. package/lib/core/assets.d.ts +4 -4
  6. package/lib/core/assets.js +28 -17
  7. package/lib/core/creditAccount.d.ts +32 -8
  8. package/lib/core/creditAccount.js +101 -44
  9. package/lib/core/creditAccount.spec.js +693 -10
  10. package/lib/core/creditManager.d.ts +12 -3
  11. package/lib/core/creditManager.js +43 -10
  12. package/lib/core/events.js +14 -14
  13. package/lib/core/gauge.d.ts +26 -0
  14. package/lib/core/gauge.js +63 -0
  15. package/lib/core/gaugeMath.d.ts +40 -0
  16. package/lib/core/gaugeMath.js +108 -0
  17. package/lib/core/gaugeMath.spec.d.ts +1 -0
  18. package/lib/core/gaugeMath.spec.js +388 -0
  19. package/lib/core/{pool/data.d.ts → pool.d.ts} +17 -10
  20. package/lib/core/{pool/data.js → pool.js} +66 -24
  21. package/lib/core/strategy.d.ts +4 -3
  22. package/lib/core/strategy.js +15 -14
  23. package/lib/core/strategy.spec.js +68 -3
  24. package/lib/core/trade.d.ts +12 -29
  25. package/lib/core/trade.js +33 -82
  26. package/lib/core/transactions.d.ts +65 -3
  27. package/lib/core/transactions.js +162 -105
  28. package/lib/index.d.ts +3 -0
  29. package/lib/index.js +3 -0
  30. package/lib/parsers/abstractParser.js +1 -2
  31. package/lib/parsers/convexBaseRewardPoolAdapterParser.js +10 -8
  32. package/lib/parsers/convexBaseRewardPoolAdapterParser.spec.js +9 -6
  33. package/lib/parsers/convexBoosterAdapterParser.js +6 -6
  34. package/lib/parsers/convexBoosterAdapterParser.spec.js +4 -4
  35. package/lib/parsers/creditFacadeParser.d.ts +2 -1
  36. package/lib/parsers/creditFacadeParser.js +40 -5
  37. package/lib/parsers/creditFacadeParser.spec.js +3 -4
  38. package/lib/parsers/curveAdapterParser.js +10 -11
  39. package/lib/parsers/curveAdapterParser.spec.js +6 -2
  40. package/lib/parsers/lidoAdapterParser.js +3 -2
  41. package/lib/parsers/lidoAdapterParser.spec.js +2 -2
  42. package/lib/parsers/txParser.d.ts +1 -1
  43. package/lib/parsers/txParser.js +9 -3
  44. package/lib/parsers/uniV2AdapterParser.js +5 -4
  45. package/lib/parsers/uniV2AdapterParser.spec.js +3 -2
  46. package/lib/parsers/uniV3AdapterParser.js +9 -7
  47. package/lib/parsers/uniV3AdapterParser.spec.js +3 -2
  48. package/lib/parsers/wstETHAdapterParser.js +6 -4
  49. package/lib/parsers/wstETHAdapterParser.spec.js +4 -4
  50. package/lib/parsers/yearnAdapterParser.spec.js +4 -4
  51. package/lib/parsers/yearnV2AdapterParser.js +13 -3
  52. package/lib/pathfinder/core.d.ts +8 -9
  53. package/lib/pathfinder/pathOptions.d.ts +2 -1
  54. package/lib/pathfinder/pathOptions.js +20 -1
  55. package/lib/pathfinder/pathOptions.spec.js +2 -2
  56. package/lib/pathfinder/pathfinder.d.ts +38 -10
  57. package/lib/pathfinder/pathfinder.js +53 -34
  58. package/lib/pathfinder/pathfinder.spec.js +7 -3
  59. package/lib/payload/creditAccount.d.ts +3 -4
  60. package/lib/payload/gauge.d.ts +12 -0
  61. package/lib/payload/pool.d.ts +6 -1
  62. package/lib/types/IAaveV2_LendingPoolAdapter.d.ts +171 -0
  63. package/lib/types/IAaveV2_WrappedATokenAdapter.d.ts +290 -0
  64. package/lib/types/IBalancerV2Vault.sol/IBalancerV2Vault.d.ts +308 -0
  65. package/lib/types/IBalancerV2Vault.sol/IBalancerV2VaultGetters.d.ts +112 -0
  66. package/lib/types/IBalancerV2Vault.sol/index.d.ts +2 -0
  67. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter.d.ts +466 -0
  68. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents.d.ts +43 -0
  69. package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.d.ts → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions.d.ts} +6 -18
  70. package/lib/types/IBalancerV2VaultAdapter.sol/index.d.ts +3 -0
  71. package/lib/types/IBotListV3.sol/IBotListV3.d.ts +286 -0
  72. package/lib/types/IBotListV3.sol/IBotListV3Events.d.ts +103 -0
  73. package/lib/types/IBotListV3.sol/index.d.ts +2 -0
  74. package/lib/types/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter.d.ts +216 -0
  75. package/lib/types/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions.d.ts +27 -0
  76. package/lib/types/ICompoundV2_CTokenAdapter.sol/index.d.ts +2 -0
  77. package/lib/types/IContractsRegister.sol/IContractsRegister.d.ts +128 -0
  78. package/lib/types/IContractsRegister.sol/IContractsRegisterEvents.d.ts +50 -0
  79. package/lib/types/IContractsRegister.sol/index.d.ts +2 -0
  80. package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3.d.ts +504 -0
  81. package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3Events.d.ts +82 -0
  82. package/lib/types/IControllerTimelockV3.sol/index.d.ts +2 -0
  83. package/lib/types/IConvexToken.d.ts +9 -1
  84. package/lib/types/IConvexV1BaseRewardPoolAdapter.d.ts +46 -30
  85. package/lib/types/{IConvexV1BoosterAdapter.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter.d.ts} +40 -21
  86. package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents.d.ts +43 -0
  87. package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents.js +2 -0
  88. package/lib/types/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
  89. package/lib/types/IConvexV1BoosterAdapter.sol/index.js +2 -0
  90. package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3.d.ts +716 -0
  91. package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3.js +2 -0
  92. package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events.d.ts +275 -0
  93. package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events.js +2 -0
  94. package/lib/types/ICreditConfiguratorV3.sol/index.d.ts +2 -0
  95. package/lib/types/ICreditConfiguratorV3.sol/index.js +2 -0
  96. package/lib/types/ICreditFacadeV2.sol/ICreditFacadeV2Extended.d.ts +7 -11
  97. package/lib/types/ICreditFacadeV3.sol/ICreditFacadeV3.d.ts +201 -94
  98. package/lib/types/ICreditFacadeV3.sol/ICreditFacadeV3Events.d.ts +31 -33
  99. package/lib/types/ICreditFacadeV3Multicall.d.ts +91 -60
  100. package/lib/types/ICreditManagerV3.sol/ICreditManagerV3.d.ts +360 -98
  101. package/lib/types/ICurveV1Adapter.d.ts +41 -105
  102. package/lib/types/ICurveV1_2AssetsAdapter.d.ts +41 -105
  103. package/lib/types/ICurveV1_3AssetsAdapter.d.ts +41 -105
  104. package/lib/types/ICurveV1_4AssetsAdapter.d.ts +41 -105
  105. package/lib/types/IDataCompressorV2_10.d.ts +44 -36
  106. package/lib/types/IDataCompressorV3_00.d.ts +141 -37
  107. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2.d.ts +339 -0
  108. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2.js +2 -0
  109. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Events.d.ts +61 -0
  110. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Events.js +2 -0
  111. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Exceptions.d.ts +27 -0
  112. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Exceptions.js +2 -0
  113. package/lib/types/IDegenNFTV2.sol/index.d.ts +3 -0
  114. package/lib/types/IDegenNFTV2.sol/index.js +2 -0
  115. package/lib/types/IERC165.d.ts +42 -0
  116. package/lib/types/IERC165.js +2 -0
  117. package/lib/types/{draft-IERC20Permit.sol/IERC20Permit.d.ts → IERC20Permit.d.ts} +1 -1
  118. package/lib/types/IERC20Permit.js +2 -0
  119. package/lib/types/IERC20ZapperDeposits.d.ts +117 -0
  120. package/lib/types/IERC20ZapperDeposits.js +2 -0
  121. package/lib/types/IERC4626Adapter.d.ts +238 -0
  122. package/lib/types/IERC4626Adapter.js +2 -0
  123. package/lib/types/IERC721.d.ts +220 -0
  124. package/lib/types/IERC721.js +2 -0
  125. package/lib/types/IERC721Metadata.d.ts +244 -0
  126. package/lib/types/IERC721Metadata.js +2 -0
  127. package/lib/types/IETHZapperDeposits.d.ts +66 -0
  128. package/lib/types/IETHZapperDeposits.js +2 -0
  129. package/lib/types/IGasPricer.d.ts +44 -0
  130. package/lib/types/IGasPricer.js +2 -0
  131. package/lib/types/IGaugeV3.sol/IGaugeV3.d.ts +366 -0
  132. package/lib/types/IGaugeV3.sol/IGaugeV3.js +2 -0
  133. package/lib/types/IGaugeV3.sol/IGaugeV3Events.d.ts +114 -0
  134. package/lib/types/IGaugeV3.sol/IGaugeV3Events.js +2 -0
  135. package/lib/types/IGaugeV3.sol/index.d.ts +2 -0
  136. package/lib/types/IGaugeV3.sol/index.js +2 -0
  137. package/lib/types/IGearStakingV3.sol/IGearStakingV3.d.ts +408 -0
  138. package/lib/types/IGearStakingV3.sol/IGearStakingV3.js +2 -0
  139. package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.d.ts +117 -0
  140. package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.js +2 -0
  141. package/lib/types/IGearStakingV3.sol/index.d.ts +2 -0
  142. package/lib/types/IGearStakingV3.sol/index.js +2 -0
  143. package/lib/types/ILPPriceFeed.sol/ILPPriceFeed.d.ts +285 -0
  144. package/lib/types/ILPPriceFeed.sol/ILPPriceFeed.js +2 -0
  145. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedEvents.d.ts +54 -0
  146. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedEvents.js +2 -0
  147. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedExceptions.d.ts +27 -0
  148. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedExceptions.js +2 -0
  149. package/lib/types/ILPPriceFeed.sol/index.d.ts +3 -0
  150. package/lib/types/ILPPriceFeed.sol/index.js +2 -0
  151. package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.d.ts → ILidoV1Adapter.d.ts} +13 -48
  152. package/lib/types/ILidoV1Adapter.js +2 -0
  153. package/lib/types/ILinearInterestRateModelV3.d.ts +120 -0
  154. package/lib/types/ILinearInterestRateModelV3.js +2 -0
  155. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3.d.ts +473 -0
  156. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3.js +2 -0
  157. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events.d.ts +113 -0
  158. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events.js +2 -0
  159. package/lib/types/IPoolQuotaKeeperV3.sol/index.d.ts +2 -0
  160. package/lib/types/IPoolQuotaKeeperV3.sol/index.js +2 -0
  161. package/lib/types/IPoolV3.sol/IPoolV3.d.ts +43 -11
  162. package/lib/types/IPoolV3.sol/index.d.ts +0 -1
  163. package/lib/types/IPriceFeed.sol/IPriceFeed.d.ts +109 -0
  164. package/lib/types/IPriceFeed.sol/IPriceFeed.js +2 -0
  165. package/lib/types/IPriceFeed.sol/IUpdatablePriceFeed.d.ts +133 -0
  166. package/lib/types/IPriceFeed.sol/IUpdatablePriceFeed.js +2 -0
  167. package/lib/types/IPriceFeed.sol/index.d.ts +2 -0
  168. package/lib/types/IPriceFeed.sol/index.js +2 -0
  169. package/lib/types/IPriceOracle.sol/IPriceOracleV2.d.ts +166 -0
  170. package/lib/types/IPriceOracle.sol/IPriceOracleV2.js +2 -0
  171. package/lib/types/IPriceOracle.sol/IPriceOracleV2Events.d.ts +43 -0
  172. package/lib/types/IPriceOracle.sol/IPriceOracleV2Events.js +2 -0
  173. package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.d.ts → IPriceOracle.sol/IPriceOracleV2Exceptions.d.ts} +3 -3
  174. package/lib/types/IPriceOracle.sol/IPriceOracleV2Exceptions.js +2 -0
  175. package/lib/types/IPriceOracle.sol/IPriceOracleV2Ext.d.ts +182 -0
  176. package/lib/types/IPriceOracle.sol/IPriceOracleV2Ext.js +2 -0
  177. package/lib/types/IPriceOracle.sol/index.d.ts +4 -0
  178. package/lib/types/IPriceOracle.sol/index.js +2 -0
  179. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3.d.ts +272 -0
  180. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3.js +2 -0
  181. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3Events.d.ts +79 -0
  182. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3Events.js +2 -0
  183. package/lib/types/IPriceOracleV3.sol/index.d.ts +2 -0
  184. package/lib/types/IPriceOracleV3.sol/index.js +2 -0
  185. package/lib/types/IUniswapV2Adapter.sol/IUniswapV2Adapter.d.ts +10 -9
  186. package/lib/types/IUniswapV3Adapter.sol/IUniswapV3Adapter.d.ts +27 -21
  187. package/lib/types/IVotingContractV3.d.ts +74 -0
  188. package/lib/types/IVotingContractV3.js +2 -0
  189. package/lib/types/IYearnV2Adapter.d.ts +22 -22
  190. package/lib/types/IZapper.d.ts +125 -0
  191. package/lib/types/IZapper.js +2 -0
  192. package/lib/types/IZapperRegister.d.ts +62 -0
  193. package/lib/types/IZapperRegister.js +2 -0
  194. package/lib/types/IwstETHV1Adapter.d.ts +17 -17
  195. package/lib/types/factories/AddressProvider__factory.d.ts +1 -1
  196. package/lib/types/factories/AddressProvider__factory.js +1 -1
  197. package/lib/types/factories/Claimable__factory.d.ts +1 -1
  198. package/lib/types/factories/Claimable__factory.js +1 -1
  199. package/lib/types/factories/IAaveV2_LendingPoolAdapter__factory.d.ts +158 -0
  200. package/lib/types/factories/IAaveV2_LendingPoolAdapter__factory.js +215 -0
  201. package/lib/types/factories/IAaveV2_WrappedATokenAdapter__factory.d.ts +252 -0
  202. package/lib/types/factories/IAaveV2_WrappedATokenAdapter__factory.js +341 -0
  203. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2VaultGetters__factory.d.ts +78 -0
  204. package/lib/types/factories/{ZapperBase__factory.js → IBalancerV2Vault.sol/IBalancerV2VaultGetters__factory.js} +54 -31
  205. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2Vault__factory.d.ts +360 -0
  206. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2Vault__factory.js +475 -0
  207. package/lib/types/factories/IBalancerV2Vault.sol/index.d.ts +2 -0
  208. package/lib/types/factories/IBalancerV2Vault.sol/index.js +10 -0
  209. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents__factory.d.ts +23 -0
  210. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents__factory.js +38 -0
  211. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions__factory.d.ts +12 -0
  212. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions__factory.js} +4 -4
  213. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter__factory.d.ts +514 -0
  214. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter__factory.js +675 -0
  215. package/lib/types/factories/IBalancerV2VaultAdapter.sol/index.d.ts +3 -0
  216. package/lib/types/factories/IBalancerV2VaultAdapter.sol/index.js +12 -0
  217. package/lib/types/factories/IBotListV3.sol/IBotListV3Events__factory.d.ts +103 -0
  218. package/lib/types/factories/IBotListV3.sol/IBotListV3Events__factory.js +138 -0
  219. package/lib/types/factories/IBotListV3.sol/IBotListV3__factory.d.ts +315 -0
  220. package/lib/types/factories/IBotListV3.sol/IBotListV3__factory.js +416 -0
  221. package/lib/types/factories/IBotListV3.sol/index.d.ts +2 -0
  222. package/lib/types/factories/IBotListV3.sol/index.js +10 -0
  223. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter__factory.d.ts +196 -0
  224. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter__factory.js +267 -0
  225. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions__factory.d.ts +16 -0
  226. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.js → ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions__factory.js} +6 -8
  227. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/index.d.ts +2 -0
  228. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/index.js +10 -0
  229. package/lib/types/factories/IContractsRegister.sol/IContractsRegisterEvents__factory.d.ts +28 -0
  230. package/lib/types/factories/IContractsRegister.sol/IContractsRegisterEvents__factory.js +45 -0
  231. package/lib/types/factories/IContractsRegister.sol/IContractsRegister__factory.d.ts +134 -0
  232. package/lib/types/factories/IContractsRegister.sol/IContractsRegister__factory.js +186 -0
  233. package/lib/types/factories/IContractsRegister.sol/index.d.ts +2 -0
  234. package/lib/types/factories/IContractsRegister.sol/index.js +10 -0
  235. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3Events__factory.d.ts +73 -0
  236. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3Events__factory.js +101 -0
  237. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3__factory.d.ts +427 -0
  238. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3__factory.js +556 -0
  239. package/lib/types/factories/IControllerTimelockV3.sol/index.d.ts +2 -0
  240. package/lib/types/factories/IControllerTimelockV3.sol/index.js +10 -0
  241. package/lib/types/factories/IConvexToken__factory.d.ts +10 -0
  242. package/lib/types/factories/IConvexToken__factory.js +13 -0
  243. package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.d.ts +38 -6
  244. package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.js +48 -6
  245. package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.d.ts +23 -0
  246. package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.js +38 -0
  247. package/lib/types/factories/{IConvexV1BoosterAdapter__factory.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.d.ts} +26 -3
  248. package/lib/types/factories/{IConvexV1BoosterAdapter__factory.js → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.js} +31 -2
  249. package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
  250. package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.js +10 -0
  251. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.d.ts +273 -0
  252. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.js +357 -0
  253. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.d.ts +605 -0
  254. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.js +785 -0
  255. package/lib/types/factories/ICreditConfiguratorV3.sol/index.d.ts +2 -0
  256. package/lib/types/factories/ICreditConfiguratorV3.sol/index.js +10 -0
  257. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.d.ts +0 -4
  258. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.js +0 -5
  259. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.d.ts +19 -24
  260. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.js +21 -27
  261. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.d.ts +151 -72
  262. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.js +189 -85
  263. package/lib/types/factories/ICreditFacadeV3Multicall__factory.d.ts +77 -43
  264. package/lib/types/factories/ICreditFacadeV3Multicall__factory.js +96 -54
  265. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.d.ts +339 -147
  266. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.js +427 -180
  267. package/lib/types/factories/ICurveV1Adapter__factory.d.ts +13 -71
  268. package/lib/types/factories/ICurveV1Adapter__factory.js +14 -91
  269. package/lib/types/factories/ICurveV1_2AssetsAdapter__factory.d.ts +13 -71
  270. package/lib/types/factories/ICurveV1_2AssetsAdapter__factory.js +14 -91
  271. package/lib/types/factories/ICurveV1_3AssetsAdapter__factory.d.ts +13 -71
  272. package/lib/types/factories/ICurveV1_3AssetsAdapter__factory.js +14 -91
  273. package/lib/types/factories/ICurveV1_4AssetsAdapter__factory.d.ts +13 -71
  274. package/lib/types/factories/ICurveV1_4AssetsAdapter__factory.js +14 -91
  275. package/lib/types/factories/IDataCompressorV2_10__factory.d.ts +110 -54
  276. package/lib/types/factories/IDataCompressorV2_10__factory.js +138 -68
  277. package/lib/types/factories/IDataCompressorV3_00__factory.d.ts +379 -79
  278. package/lib/types/factories/IDataCompressorV3_00__factory.js +481 -100
  279. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Events__factory.d.ts +38 -0
  280. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Events__factory.js +58 -0
  281. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Exceptions__factory.d.ts +24 -0
  282. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Exceptions__factory.js +39 -0
  283. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3__factory.d.ts → IDegenNFTV2.sol/IDegenNFTV2__factory.d.ts} +190 -180
  284. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3__factory.js → IDegenNFTV2.sol/IDegenNFTV2__factory.js} +212 -195
  285. package/lib/types/factories/IDegenNFTV2.sol/index.d.ts +3 -0
  286. package/lib/types/factories/IDegenNFTV2.sol/index.js +12 -0
  287. package/lib/types/factories/IERC165__factory.d.ts +22 -0
  288. package/lib/types/factories/IERC165__factory.js +38 -0
  289. package/lib/types/factories/{draft-IERC20Permit.sol/IERC20Permit__factory.d.ts → IERC20Permit__factory.d.ts} +1 -1
  290. package/lib/types/factories/IERC20ZapperDeposits__factory.d.ts +120 -0
  291. package/lib/types/factories/IERC20ZapperDeposits__factory.js +165 -0
  292. package/lib/types/factories/IERC4626Adapter__factory.d.ts +220 -0
  293. package/lib/types/factories/IERC4626Adapter__factory.js +297 -0
  294. package/lib/types/factories/IERC721Metadata__factory.d.ts +262 -0
  295. package/lib/types/factories/IERC721Metadata__factory.js +349 -0
  296. package/lib/types/factories/IERC721__factory.d.ts +228 -0
  297. package/lib/types/factories/IERC721__factory.js +304 -0
  298. package/lib/types/factories/IETHZapperDeposits__factory.d.ts +40 -0
  299. package/lib/types/factories/{AaveV2_WrappedAToken.sol/IWrappedATokenEvents__factory.js → IETHZapperDeposits__factory.js} +18 -25
  300. package/lib/types/factories/IGasPricer__factory.d.ts +22 -0
  301. package/lib/types/factories/IGasPricer__factory.js +38 -0
  302. package/lib/types/factories/IGaugeV3.sol/IGaugeV3Events__factory.d.ts +118 -0
  303. package/lib/types/factories/IGaugeV3.sol/IGaugeV3Events__factory.js +157 -0
  304. package/lib/types/factories/IGaugeV3.sol/IGaugeV3__factory.d.ts +342 -0
  305. package/lib/types/factories/IGaugeV3.sol/IGaugeV3__factory.js +448 -0
  306. package/lib/types/factories/IGaugeV3.sol/index.d.ts +2 -0
  307. package/lib/types/factories/IGaugeV3.sol/index.js +10 -0
  308. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events__factory.d.ts → IGearStakingV3.sol/IGearStakingV3Events__factory.d.ts} +33 -63
  309. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events__factory.js → IGearStakingV3.sol/IGearStakingV3Events__factory.js} +34 -70
  310. package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.d.ts +504 -0
  311. package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.js +660 -0
  312. package/lib/types/factories/IGearStakingV3.sol/index.d.ts +2 -0
  313. package/lib/types/factories/IGearStakingV3.sol/index.js +10 -0
  314. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedEvents__factory.d.ts +33 -0
  315. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedEvents__factory.js +51 -0
  316. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedExceptions__factory.d.ts +24 -0
  317. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedExceptions__factory.js +39 -0
  318. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeed__factory.d.ts +257 -0
  319. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeed__factory.js +339 -0
  320. package/lib/types/factories/ILPPriceFeed.sol/index.d.ts +3 -0
  321. package/lib/types/factories/ILPPriceFeed.sol/index.js +12 -0
  322. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.d.ts → ILidoV1Adapter__factory.d.ts} +7 -37
  323. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.js → ILidoV1Adapter__factory.js} +8 -46
  324. package/lib/types/factories/ILinearInterestRateModelV3__factory.d.ts +98 -0
  325. package/lib/types/factories/ILinearInterestRateModelV3__factory.js +136 -0
  326. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events__factory.d.ts +103 -0
  327. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events__factory.js +140 -0
  328. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3__factory.d.ts +441 -0
  329. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3__factory.js +580 -0
  330. package/lib/types/factories/IPoolQuotaKeeperV3.sol/index.d.ts +2 -0
  331. package/lib/types/factories/IPoolQuotaKeeperV3.sol/index.js +10 -0
  332. package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.d.ts +62 -14
  333. package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.js +79 -17
  334. package/lib/types/factories/IPoolV3.sol/index.d.ts +0 -1
  335. package/lib/types/factories/IPoolV3.sol/index.js +1 -3
  336. package/lib/types/factories/{IPoolV3.sol/IPoolBase__factory.d.ts → IPriceFeed.sol/IPriceFeed__factory.d.ts} +39 -35
  337. package/lib/types/factories/{IPoolV3.sol/IPoolBase__factory.js → IPriceFeed.sol/IPriceFeed__factory.js} +40 -35
  338. package/lib/types/factories/IPriceFeed.sol/IUpdatablePriceFeed__factory.d.ts +104 -0
  339. package/lib/types/factories/IPriceFeed.sol/IUpdatablePriceFeed__factory.js +143 -0
  340. package/lib/types/factories/IPriceFeed.sol/index.d.ts +2 -0
  341. package/lib/types/factories/IPriceFeed.sol/index.js +10 -0
  342. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Events__factory.d.ts +23 -0
  343. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Events__factory.js +38 -0
  344. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Exceptions__factory.d.ts +20 -0
  345. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Exceptions__factory.js +34 -0
  346. package/lib/types/factories/{IAToken__factory.d.ts → IPriceOracle.sol/IPriceOracleV2Ext__factory.d.ts} +98 -99
  347. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Ext__factory.js +267 -0
  348. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2__factory.d.ts +183 -0
  349. package/lib/types/factories/{IAToken__factory.js → IPriceOracle.sol/IPriceOracleV2__factory.js} +94 -112
  350. package/lib/types/factories/IPriceOracle.sol/index.d.ts +4 -0
  351. package/lib/types/factories/IPriceOracle.sol/index.js +14 -0
  352. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3Events__factory.d.ts +78 -0
  353. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3Events__factory.js +106 -0
  354. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3__factory.d.ts +326 -0
  355. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3__factory.js +433 -0
  356. package/lib/types/factories/IPriceOracleV3.sol/index.d.ts +2 -0
  357. package/lib/types/factories/IPriceOracleV3.sol/index.js +10 -0
  358. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2Adapter__factory.d.ts +5 -1
  359. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2Adapter__factory.js +6 -1
  360. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3Adapter__factory.d.ts +12 -4
  361. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3Adapter__factory.js +14 -4
  362. package/lib/types/factories/IVotingContractV3__factory.d.ts +44 -0
  363. package/lib/types/factories/IVotingContractV3__factory.js +65 -0
  364. package/lib/types/factories/IYearnV2Adapter__factory.d.ts +21 -13
  365. package/lib/types/factories/IYearnV2Adapter__factory.js +27 -15
  366. package/lib/types/factories/IZapperRegister__factory.d.ts +42 -0
  367. package/lib/types/factories/IZapperRegister__factory.js +64 -0
  368. package/lib/types/factories/{WERC20ZapperBase__factory.d.ts → IZapper__factory.d.ts} +52 -64
  369. package/lib/types/factories/{WERC20ZapperBase__factory.js → IZapper__factory.js} +58 -74
  370. package/lib/types/factories/IwstETHV1Adapter__factory.d.ts +12 -4
  371. package/lib/types/factories/IwstETHV1Adapter__factory.js +16 -4
  372. package/lib/types/factories/SafeERC20__factory.d.ts +1 -1
  373. package/lib/types/factories/SafeERC20__factory.js +1 -1
  374. package/lib/types/factories/index.d.ts +32 -14
  375. package/lib/types/factories/index.js +49 -26
  376. package/lib/types/factories/{IRouter__factory.d.ts → interfaces/IRouter__factory.d.ts} +75 -6
  377. package/lib/types/factories/{IRouter__factory.js → interfaces/IRouter__factory.js} +96 -6
  378. package/lib/types/factories/interfaces/index.d.ts +1 -0
  379. package/lib/types/factories/interfaces/index.js +8 -0
  380. package/lib/types/index.d.ts +141 -46
  381. package/lib/types/index.js +109 -38
  382. package/lib/types/{IRouter.d.ts → interfaces/IRouter.d.ts} +48 -35
  383. package/lib/types/interfaces/IRouter.js +2 -0
  384. package/lib/types/interfaces/index.d.ts +1 -0
  385. package/lib/types/interfaces/index.js +2 -0
  386. package/lib/utils/formatter.d.ts +0 -3
  387. package/lib/utils/formatter.js +1 -67
  388. package/lib/utils/math.d.ts +2 -0
  389. package/lib/utils/math.js +2 -0
  390. package/lib/utils/types.d.ts +1 -0
  391. package/lib/watchers/creditAccountWatcher.d.ts +3 -2
  392. package/lib/watchers/creditAccountWatcher.js +19 -13
  393. package/lib/watchers/creditAccountWatcher.spec.js +18 -18
  394. package/lib/watchers/creditManagerWatcher.d.ts +5 -3
  395. package/lib/watchers/creditManagerWatcher.js +32 -10
  396. package/lib/watchers/creditManagerWatcher.spec.js +12 -4
  397. package/package.json +10 -9
  398. package/contracts/IRouter.sol +0 -100
  399. package/lib/core/pool/index.d.ts +0 -1
  400. package/lib/core/pool/index.js +0 -17
  401. package/lib/types/AaveV2_WrappedAToken.sol/IWrappedATokenEvents.d.ts +0 -60
  402. package/lib/types/AaveV2_WrappedAToken.sol/WrappedAToken.d.ts +0 -332
  403. package/lib/types/AaveV2_WrappedAToken.sol/index.d.ts +0 -2
  404. package/lib/types/ERC20.d.ts +0 -198
  405. package/lib/types/IAToken.d.ts +0 -182
  406. package/lib/types/ILendingPool.d.ts +0 -140
  407. package/lib/types/ILidoV1Adapter.sol/index.d.ts +0 -3
  408. package/lib/types/IPoolV3.sol/IPoolBase.d.ts +0 -102
  409. package/lib/types/IWithdrawalManagerV3.sol/IWithdrawalManagerV3.d.ts +0 -370
  410. package/lib/types/IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events.d.ts +0 -133
  411. package/lib/types/IWithdrawalManagerV3.sol/index.d.ts +0 -2
  412. package/lib/types/WATokenZapper.d.ts +0 -134
  413. package/lib/types/WERC20ZapperBase.d.ts +0 -134
  414. package/lib/types/WETHZapper.d.ts +0 -122
  415. package/lib/types/WstETHZapper.d.ts +0 -134
  416. package/lib/types/ZapperBase.d.ts +0 -70
  417. package/lib/types/draft-IERC20Permit.sol/index.d.ts +0 -1
  418. package/lib/types/factories/AaveV2_WrappedAToken.sol/IWrappedATokenEvents__factory.d.ts +0 -48
  419. package/lib/types/factories/AaveV2_WrappedAToken.sol/WrappedAToken__factory.d.ts +0 -397
  420. package/lib/types/factories/AaveV2_WrappedAToken.sol/WrappedAToken__factory.js +0 -535
  421. package/lib/types/factories/AaveV2_WrappedAToken.sol/index.d.ts +0 -2
  422. package/lib/types/factories/AaveV2_WrappedAToken.sol/index.js +0 -10
  423. package/lib/types/factories/ERC20__factory.d.ts +0 -239
  424. package/lib/types/factories/ERC20__factory.js +0 -328
  425. package/lib/types/factories/ILendingPool__factory.d.ts +0 -134
  426. package/lib/types/factories/ILendingPool__factory.js +0 -183
  427. package/lib/types/factories/ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.d.ts +0 -18
  428. package/lib/types/factories/ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.d.ts +0 -12
  429. package/lib/types/factories/ILidoV1Adapter.sol/index.d.ts +0 -3
  430. package/lib/types/factories/ILidoV1Adapter.sol/index.js +0 -12
  431. package/lib/types/factories/IWithdrawalManagerV3.sol/index.d.ts +0 -2
  432. package/lib/types/factories/IWithdrawalManagerV3.sol/index.js +0 -10
  433. package/lib/types/factories/WATokenZapper__factory.d.ts +0 -161
  434. package/lib/types/factories/WATokenZapper__factory.js +0 -227
  435. package/lib/types/factories/WETHZapper__factory.d.ts +0 -138
  436. package/lib/types/factories/WETHZapper__factory.js +0 -198
  437. package/lib/types/factories/WstETHZapper__factory.d.ts +0 -161
  438. package/lib/types/factories/WstETHZapper__factory.js +0 -227
  439. package/lib/types/factories/ZapperBase__factory.d.ts +0 -60
  440. package/lib/types/factories/draft-IERC20Permit.sol/index.d.ts +0 -1
  441. package/lib/types/factories/draft-IERC20Permit.sol/index.js +0 -8
  442. /package/lib/{types/AaveV2_WrappedAToken.sol/IWrappedATokenEvents.js → payload/gauge.js} +0 -0
  443. /package/lib/types/{AaveV2_WrappedAToken.sol/WrappedAToken.js → IAaveV2_LendingPoolAdapter.js} +0 -0
  444. /package/lib/types/{AaveV2_WrappedAToken.sol/index.js → IAaveV2_WrappedATokenAdapter.js} +0 -0
  445. /package/lib/types/{ERC20.js → IBalancerV2Vault.sol/IBalancerV2Vault.js} +0 -0
  446. /package/lib/types/{IAToken.js → IBalancerV2Vault.sol/IBalancerV2VaultGetters.js} +0 -0
  447. /package/lib/types/{ILidoV1Adapter.sol → IBalancerV2Vault.sol}/index.js +0 -0
  448. /package/lib/types/{IConvexV1BoosterAdapter.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter.js} +0 -0
  449. /package/lib/types/{ILendingPool.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents.js} +0 -0
  450. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions.js} +0 -0
  451. /package/lib/types/{IWithdrawalManagerV3.sol → IBalancerV2VaultAdapter.sol}/index.js +0 -0
  452. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.js → IBotListV3.sol/IBotListV3.js} +0 -0
  453. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.js → IBotListV3.sol/IBotListV3Events.js} +0 -0
  454. /package/lib/types/{draft-IERC20Permit.sol → IBotListV3.sol}/index.js +0 -0
  455. /package/lib/types/{IPoolV3.sol/IPoolBase.js → ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter.js} +0 -0
  456. /package/lib/types/{IRouter.js → ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions.js} +0 -0
  457. /package/lib/types/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3.js → ICompoundV2_CTokenAdapter.sol/index.js} +0 -0
  458. /package/lib/types/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events.js → IContractsRegister.sol/IContractsRegister.js} +0 -0
  459. /package/lib/types/{WATokenZapper.js → IContractsRegister.sol/IContractsRegisterEvents.js} +0 -0
  460. /package/lib/types/{WERC20ZapperBase.js → IContractsRegister.sol/index.js} +0 -0
  461. /package/lib/types/{WETHZapper.js → IControllerTimelockV3.sol/IControllerTimelockV3.js} +0 -0
  462. /package/lib/types/{WstETHZapper.js → IControllerTimelockV3.sol/IControllerTimelockV3Events.js} +0 -0
  463. /package/lib/types/{ZapperBase.js → IControllerTimelockV3.sol/index.js} +0 -0
  464. /package/lib/types/{draft-IERC20Permit.sol/IERC20Permit.js → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter.js} +0 -0
  465. /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
- constructor(token) {
7
+ version;
8
+ constructor(token, version) {
8
9
  super(token);
9
- this.ifc = types_1.ICreditFacadeV2Extended__factory.createInterface();
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 [onBehalf, token, amount] = this.decodeFunctionData(functionFragment, calldata);
17
- return `${functionName}(onBehalf: ${onBehalf}, token: ${this.tokenSymbol(token)}, amount: ${this.formatAmount(amount)})`;
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,44 @@ 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(b.balance, symbol)}`;
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
+ }
39
74
  default:
40
75
  return `${functionName}: Unknown operation ${functionFragment.name} with calldata ${calldata}`;
41
76
  }
@@ -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.WAD * 444n) / 10n,
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(onBehalf: 0xC4375B7De8af5a38a93548eb8453a498222C4fF2, token: WBTC, amount: 44.40 [44400000000000000000])", "Incorrect parse 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 "exchange_all":
49
- case "exchange_all_underlying": {
50
- const [i, j, rateMinRAY] = this.decodeFunctionData(functionFragment, calldata);
51
- const iSym = functionFragment.name === "exchange_all_underlying"
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 === "exchange_all_underlying"
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, formatter_1.formatBN)(rateMinRAY, 27)}`;
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 "add_all_liquidity_one_coin":
65
- case "remove_all_liquidity_one_coin": {
66
- const [i, rateMinRAY] = this.decodeFunctionData(functionFragment, calldata);
67
- return `${functionName}(i: ${this.getTokenByIndex(i)}, rateMinRAY: ${(0, formatter_1.formatBN)(rateMinRAY, 27)})`;
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("add_all_liquidity_one_coin", [0, sdk_gov_1.RAY * 912n]));
23
- (0, chai_1.expect)(parsed).to.be.eq("Curve2AssetsAdapter[CURVE_FRAX_POOL].add_all_liquidity_one_coin(i: FRAX, rateMinRAY: 912.00)", "Curve2AssetsAdapter: Incorrect parse add_all_liquidity_one_coin");
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 "submitAll": {
21
- return `${functionName}()`;
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("submitAll"));
15
- (0, chai_1.expect)(parsed).to.be.eq("Contract[LIDO_STETH_GATEWAY].submitAll()", "Incorrect parse submitAll()");
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;
@@ -22,7 +22,13 @@ class TxParser {
22
22
  static parsers = {};
23
23
  static parse(address, calldata) {
24
24
  const parser = TxParser.getParser(address);
25
- return parser.parse(calldata);
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 "swapAllTokensForTokens": {
43
- const [rateMinRAY, path] = this.decodeFunctionData(functionFragment, calldata);
44
- return `${functionName}(rate: ${(0, formatter_1.formatBN)(rateMinRAY, 27)}, path: [${path
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("swapAllTokensForTokens", [
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].swapAllTokensForTokens(rate: 3.24K, path: [USDC => DAI => FRAX])", "Incorrect parse swapAllTokensForTokens");
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 "exactAllInputSingle": {
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
- return `${functionName}(rate: ${(0, formatter_1.formatBN)(rateMinRAY, 27)}, path: ${tokenInSym} ==(fee: ${fee})==> ${tokenOutSym})`;
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 "exactAllInput": {
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, formatter_1.formatBN)(rateMinRAY, 27)}, path: ${pathStr}`;
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("exactAllInput", [
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].exactAllInput(rate: 1.20K, path: AAVE ==(fee: 3000)==> LINK ==(fee: 3000)==> USDC", "Incorrect parse swapExactTokensForTokens");
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 "wrapAll": {
24
- return `${functionName}()`;
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 "unwrapAll": {
31
- return `${functionName}()`;
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("wrapAll"));
12
- (0, chai_1.expect)(parsed).to.be.eq("wstETHAdapter[LIDO_WSTETH].wrapAll()", "Incorrect parse wrapAll()");
13
- parsed = parser.parse(ifc.encodeFunctionData("unwrapAll"));
14
- (0, chai_1.expect)(parsed).to.be.eq("wstETHAdapter[LIDO_WSTETH].unwrapAll()", "Incorrect parse unwrapAll()");
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("deposit()"));
12
- (0, chai_1.expect)(parsed).to.be.eq("YearnV2Adapter[YEARN_CURVE_STETH_VAULT].deposit()", "Incorrect parse deposit()");
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("withdraw()"));
21
- (0, chai_1.expect)(parsed).to.be.eq("YearnV2Adapter[YEARN_CURVE_STETH_VAULT].withdraw()", "Incorrect parse withdraw()");
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.IYVault__factory.createInterface();
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
  }
@@ -1,21 +1,20 @@
1
1
  import { ExcludeArrayProps } from "@gearbox-protocol/sdk-gov";
2
- import { MultiCallStructOutput, SwapTaskStructOutput } from "../types/IRouter";
2
+ import { MultiCallStructOutput, RouterResultStructOutput, SwapTaskStruct } from "../types/interfaces/IRouter";
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<SwapTaskStructOutput>;
10
- export interface PathFinderResult {
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
- calls: Array<MultiCall>;
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 initPO = curvePools.map(symbol => {
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.LUSD3CRV]: { balance: 200n },
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.LUSD3CRV,
79
+ target: sdk_gov_1.tokenDataByNetwork.Mainnet["50OHM_50DAI"],
80
80
  option: 0,
81
81
  totalOptions: 2,
82
82
  },
@@ -1,13 +1,40 @@
1
1
  import { NetworkType, SupportedToken } from "@gearbox-protocol/sdk-gov";
2
- import { BigNumberish, providers, Signer } from "ethers";
2
+ import { providers, Signer } from "ethers";
3
+ import { Asset } from "../core/assets";
3
4
  import { CreditAccountData } from "../core/creditAccount";
4
5
  import { CreditManagerData } from "../core/creditManager";
5
6
  import { IRouter } from "../types";
6
- import { MultiCall, PathFinderCloseResult, PathFinderOpenStrategyResult, PathFinderResult, SwapOperation } from "./core";
7
- export interface CloseResult {
7
+ import { PathFinderCloseResult, PathFinderOpenStrategyResult, PathFinderResult, SwapOperation } from "./core";
8
+ interface FindAllSwapsProps {
9
+ creditAccount: CreditAccountData;
10
+ swapOperation: SwapOperation;
11
+ tokenIn: string;
12
+ tokenOut: string;
8
13
  amount: bigint;
9
- calls: Array<MultiCall>;
10
- gasUsage: bigint;
14
+ leftoverAmount: bigint;
15
+ slippage: number;
16
+ }
17
+ interface FindOneTokenPathProps {
18
+ creditAccount: CreditAccountData;
19
+ tokenIn: string;
20
+ tokenOut: string;
21
+ amount: bigint;
22
+ slippage: number;
23
+ }
24
+ interface FindBestClosePathProps {
25
+ creditAccount: CreditAccountData;
26
+ creditManager: CreditManagerData;
27
+ expectedBalances: Record<string, Asset>;
28
+ leftoverBalances: Record<string, Asset>;
29
+ slippage: number;
30
+ noConcurrency?: boolean;
31
+ }
32
+ interface FindOpenStrategyPathProps {
33
+ creditManager: CreditManagerData;
34
+ expectedBalances: Record<string, Asset>;
35
+ leftoverBalances: Record<string, Asset>;
36
+ target: string;
37
+ slippage: number;
11
38
  }
12
39
  export declare class PathFinder {
13
40
  pathFinder: IRouter;
@@ -15,8 +42,8 @@ export declare class PathFinder {
15
42
  static connectors: Array<SupportedToken>;
16
43
  protected readonly _connectors: Array<string>;
17
44
  constructor(address: string, provider: Signer | providers.Provider, network?: NetworkType, connectors?: SupportedToken[]);
18
- findAllSwaps(creditAccount: CreditAccountData, swapOperation: SwapOperation, tokenIn: SupportedToken | string, tokenOut: SupportedToken | string, amount: BigNumberish, slippage: number): Promise<Array<PathFinderResult>>;
19
- findOneTokenPath(creditAccount: CreditAccountData, tokenIn: SupportedToken | string, tokenOut: SupportedToken | string, amount: BigNumberish, slippage: number): Promise<PathFinderResult>;
45
+ findAllSwaps({ creditAccount, swapOperation, tokenIn, tokenOut, amount, leftoverAmount, slippage, }: FindAllSwapsProps): Promise<Array<PathFinderResult>>;
46
+ findOneTokenPath({ creditAccount, tokenIn, tokenOut, amount, slippage, }: FindOneTokenPathProps): Promise<PathFinderResult>;
20
47
  /**
21
48
  * @dev Finds the best path for opening credit account and converting all NORMAL tokens and LP token in the way to TARGET
22
49
  * @param cm CreditManagerData which represents credit manager you want to use to open credit account
@@ -28,7 +55,7 @@ export declare class PathFinder {
28
55
  * @param slippage Slippage in PERCENTAGE_FORMAT (100% = 10_000) per operation
29
56
  * @returns PathFinderOpenStrategyResult which
30
57
  */
31
- findOpenStrategyPath(cm: CreditManagerData, expectedBalances: Record<SupportedToken | string, BigNumberish>, target: SupportedToken | string, slippage: number): Promise<PathFinderOpenStrategyResult>;
58
+ findOpenStrategyPath({ creditManager: cm, expectedBalances, leftoverBalances, target, slippage, }: FindOpenStrategyPathProps): Promise<PathFinderOpenStrategyResult>;
32
59
  /**
33
60
  * @dev Finds the path to swap / withdraw all assets from CreditAccount into underlying asset
34
61
  * Can bu used for closing credit account and for liquidations as well.
@@ -38,8 +65,9 @@ export declare class PathFinder {
38
65
  * - underlyingBalance - total balance of underlying token
39
66
  * - calls - list of calls which should be done to swap & unwrap everything to underlying token
40
67
  */
41
- findBestClosePath(creditAccount: CreditAccountData, slippage: number, noConcurency?: boolean): Promise<PathFinderCloseResult>;
42
- static compare(r1: CloseResult, r2: CloseResult, gasPriceRAY: bigint): CloseResult;
68
+ findBestClosePath({ creditAccount, creditManager: cm, expectedBalances, leftoverBalances, slippage, noConcurrency, }: FindBestClosePathProps): Promise<PathFinderCloseResult>;
69
+ static compare(r1: PathFinderResult, r2: PathFinderResult, gasPriceRAY: bigint): PathFinderResult;
43
70
  getAvailableConnectors(availableList: Record<string, bigint> | Record<string, true>): string[];
44
71
  static getAvailableConnectors(availableList: Record<string, bigint> | Record<string, true>, connectors: string[]): string[];
45
72
  }
73
+ export {};