@gearbox-protocol/sdk 3.0.0-next.15 → 3.0.0-next.151

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 (650) hide show
  1. package/contracts/index.sol +34 -5
  2. package/lib/apy/auraAPY.d.ts +1 -0
  3. package/lib/apy/auraAPY.js +23 -0
  4. package/lib/apy/auraAbi.d.ts +17 -0
  5. package/lib/apy/auraAbi.js +26 -0
  6. package/lib/apy/convexAPY.d.ts +8 -7
  7. package/lib/apy/convexAPY.js +19 -8
  8. package/lib/apy/curveAPY.d.ts +57 -5
  9. package/lib/apy/curveAPY.js +112 -59
  10. package/lib/apy/defiLamaAPY.d.ts +3 -0
  11. package/lib/apy/defiLamaAPY.js +74 -0
  12. package/lib/apy/index.d.ts +3 -2
  13. package/lib/apy/index.js +9 -0
  14. package/lib/apy/lidoAPY.d.ts +4 -1
  15. package/lib/apy/lidoAPY.js +6 -3
  16. package/lib/apy/yearnAPY.d.ts +3 -3
  17. package/lib/apy/yearnAPY.js +15 -12
  18. package/lib/contracts/contractsRegister.d.ts +13 -6
  19. package/lib/contracts/contractsRegister.js +39 -2
  20. package/lib/core/assets.js +2 -2
  21. package/lib/core/creditAccount.d.ts +59 -16
  22. package/lib/core/creditAccount.js +176 -77
  23. package/lib/core/creditAccount.spec.js +639 -27
  24. package/lib/core/creditManager.d.ts +18 -5
  25. package/lib/core/creditManager.js +70 -12
  26. package/lib/core/creditSession.d.ts +24 -3
  27. package/lib/core/creditSession.js +32 -7
  28. package/lib/core/endpoint.d.ts +14 -0
  29. package/lib/core/endpoint.js +34 -0
  30. package/lib/core/eventOrTx.d.ts +2 -3
  31. package/lib/core/events.js +16 -16
  32. package/lib/core/gauge.d.ts +26 -0
  33. package/lib/core/gauge.js +63 -0
  34. package/lib/core/gaugeMath.d.ts +40 -0
  35. package/lib/core/gaugeMath.js +108 -0
  36. package/lib/core/gaugeMath.spec.js +388 -0
  37. package/lib/core/{pool/data.d.ts → pool.d.ts} +14 -8
  38. package/lib/core/{pool/data.js → pool.js} +38 -20
  39. package/lib/core/rewardClaimer.d.ts +4 -2
  40. package/lib/core/rewardConvex.d.ts +26 -9
  41. package/lib/core/rewardConvex.js +183 -56
  42. package/lib/core/rewardConvex.spec.js +32 -68
  43. package/lib/core/strategy.d.ts +18 -21
  44. package/lib/core/strategy.js +16 -36
  45. package/lib/core/trade.d.ts +11 -12
  46. package/lib/core/trade.js +36 -29
  47. package/lib/core/transactions.d.ts +97 -15
  48. package/lib/core/transactions.js +164 -117
  49. package/lib/index.d.ts +6 -2
  50. package/lib/index.js +6 -2
  51. package/lib/parsers/ERC20Parser.js +1 -1
  52. package/lib/parsers/aaveV2LendingPoolAdapterParser.d.ts +7 -0
  53. package/lib/parsers/aaveV2LendingPoolAdapterParser.js +21 -0
  54. package/lib/parsers/aaveV2WrappedATokenAdapterParser.d.ts +7 -0
  55. package/lib/parsers/aaveV2WrappedATokenAdapterParser.js +21 -0
  56. package/lib/parsers/abstractParser.d.ts +7 -5
  57. package/lib/parsers/abstractParser.js +4 -2
  58. package/lib/parsers/addressProviderParser.js +1 -1
  59. package/lib/parsers/balancerV2VaultParser.d.ts +7 -0
  60. package/lib/parsers/balancerV2VaultParser.js +34 -0
  61. package/lib/parsers/compoundV2CTokenAdapterParser.d.ts +7 -0
  62. package/lib/parsers/compoundV2CTokenAdapterParser.js +21 -0
  63. package/lib/parsers/convexBaseRewardPoolAdapterParser.js +13 -9
  64. package/lib/parsers/convexBaseRewardPoolAdapterParser.spec.js +9 -6
  65. package/lib/parsers/convexBoosterAdapterParser.js +7 -7
  66. package/lib/parsers/convexBoosterAdapterParser.spec.js +4 -4
  67. package/lib/parsers/convextRewardPoolParser.js +1 -1
  68. package/lib/parsers/creditFacadeParser.js +34 -7
  69. package/lib/parsers/creditFacadeParser.spec.js +2 -3
  70. package/lib/parsers/creditManagerParser.js +1 -1
  71. package/lib/parsers/curveAdapterParser.js +11 -12
  72. package/lib/parsers/curveAdapterParser.spec.js +6 -2
  73. package/lib/parsers/erc626AdapterParser.d.ts +7 -0
  74. package/lib/parsers/erc626AdapterParser.js +21 -0
  75. package/lib/parsers/lidoAdapterParser.js +4 -3
  76. package/lib/parsers/lidoAdapterParser.spec.js +2 -2
  77. package/lib/parsers/lidoSTETHParser.js +1 -1
  78. package/lib/parsers/poolParser.js +1 -1
  79. package/lib/parsers/priceOracleParser.js +1 -1
  80. package/lib/parsers/txParser.d.ts +17 -11
  81. package/lib/parsers/txParser.js +41 -4
  82. package/lib/parsers/uniV2AdapterParser.js +6 -5
  83. package/lib/parsers/uniV2AdapterParser.spec.js +3 -2
  84. package/lib/parsers/uniV3AdapterParser.js +10 -8
  85. package/lib/parsers/uniV3AdapterParser.spec.js +3 -2
  86. package/lib/parsers/wstETHAdapterParser.js +7 -5
  87. package/lib/parsers/wstETHAdapterParser.spec.js +4 -4
  88. package/lib/parsers/yearnAdapterParser.spec.js +4 -4
  89. package/lib/parsers/yearnV2AdapterParser.js +14 -4
  90. package/lib/pathfinder/balancerVault.d.ts +33 -0
  91. package/lib/pathfinder/balancerVault.js +59 -0
  92. package/lib/pathfinder/core.d.ts +8 -9
  93. package/lib/pathfinder/index.d.ts +4 -0
  94. package/lib/{core/pool → pathfinder}/index.js +4 -1
  95. package/lib/pathfinder/pathOptions.d.ts +2 -1
  96. package/lib/pathfinder/pathOptions.js +33 -11
  97. package/lib/pathfinder/pathOptions.spec.js +2 -2
  98. package/lib/pathfinder/pathfinder.d.ts +46 -19
  99. package/lib/pathfinder/pathfinder.js +67 -55
  100. package/lib/pathfinder/pathfinder.spec.js +22 -9
  101. package/lib/pathfinder/utils.d.ts +36 -0
  102. package/lib/pathfinder/utils.js +181 -0
  103. package/lib/pathfinder/v1/core.d.ts +16 -0
  104. package/lib/pathfinder/v1/pathfinderv1.d.ts +46 -0
  105. package/lib/pathfinder/v1/pathfinderv1.js +155 -0
  106. package/lib/pathfinder/v1/pathfinderv1.spec.d.ts +1 -0
  107. package/lib/pathfinder/v1/pathfinderv1.spec.js +39 -0
  108. package/lib/payload/creditAccount.d.ts +3 -4
  109. package/lib/payload/creditManager.d.ts +5 -1
  110. package/lib/payload/creditSession.d.ts +15 -1
  111. package/lib/payload/gauge.d.ts +12 -0
  112. package/lib/payload/pool.d.ts +6 -2
  113. package/lib/payload/token.d.ts +3 -1
  114. package/lib/tokens/tokenData.d.ts +5 -4
  115. package/lib/tokens/tokenData.js +21 -5
  116. package/lib/types/CalldataExtractor.d.ts +44 -0
  117. package/lib/types/ERC20.d.ts +198 -0
  118. package/lib/types/FarmAccounting.d.ts +27 -0
  119. package/lib/types/IAaveV2_LendingPoolAdapter.d.ts +171 -0
  120. package/lib/types/IAaveV2_WrappedATokenAdapter.d.ts +290 -0
  121. package/lib/types/IBalancerV2Vault.sol/IBalancerV2Vault.d.ts +308 -0
  122. package/lib/types/IBalancerV2Vault.sol/IBalancerV2VaultGetters.d.ts +112 -0
  123. package/lib/types/IBalancerV2Vault.sol/index.d.ts +2 -0
  124. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter.d.ts +466 -0
  125. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents.d.ts +43 -0
  126. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions.d.ts +27 -0
  127. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions.js +2 -0
  128. package/lib/types/IBalancerV2VaultAdapter.sol/index.d.ts +3 -0
  129. package/lib/types/IBalancerV2VaultAdapter.sol/index.js +2 -0
  130. package/lib/types/IBotListV3.sol/IBotListV3.d.ts +286 -0
  131. package/lib/types/IBotListV3.sol/IBotListV3.js +2 -0
  132. package/lib/types/IBotListV3.sol/IBotListV3Events.d.ts +103 -0
  133. package/lib/types/IBotListV3.sol/IBotListV3Events.js +2 -0
  134. package/lib/types/IBotListV3.sol/index.d.ts +2 -0
  135. package/lib/types/IBotListV3.sol/index.js +2 -0
  136. package/lib/types/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter.d.ts +216 -0
  137. package/lib/types/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter.js +2 -0
  138. package/lib/types/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions.d.ts +27 -0
  139. package/lib/types/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions.js +2 -0
  140. package/lib/types/ICompoundV2_CTokenAdapter.sol/index.d.ts +2 -0
  141. package/lib/types/ICompoundV2_CTokenAdapter.sol/index.js +2 -0
  142. package/lib/types/IContractsRegister.sol/IContractsRegister.d.ts +128 -0
  143. package/lib/types/IContractsRegister.sol/IContractsRegister.js +2 -0
  144. package/lib/types/IContractsRegister.sol/IContractsRegisterEvents.d.ts +50 -0
  145. package/lib/types/IContractsRegister.sol/IContractsRegisterEvents.js +2 -0
  146. package/lib/types/IContractsRegister.sol/index.d.ts +2 -0
  147. package/lib/types/IContractsRegister.sol/index.js +2 -0
  148. package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3.d.ts +504 -0
  149. package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3.js +2 -0
  150. package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3Events.d.ts +82 -0
  151. package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3Events.js +2 -0
  152. package/lib/types/IControllerTimelockV3.sol/index.d.ts +2 -0
  153. package/lib/types/IControllerTimelockV3.sol/index.js +2 -0
  154. package/lib/types/IConvexToken.d.ts +9 -1
  155. package/lib/types/IConvexV1BaseRewardPoolAdapter.d.ts +46 -30
  156. package/lib/types/{IConvexV1BoosterAdapter.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter.d.ts} +40 -21
  157. package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter.js +2 -0
  158. package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents.d.ts +43 -0
  159. package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents.js +2 -0
  160. package/lib/types/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
  161. package/lib/types/IConvexV1BoosterAdapter.sol/index.js +2 -0
  162. package/lib/types/ICreditFacadeV2.sol/ICreditFacadeV2Extended.d.ts +7 -11
  163. package/lib/types/ICreditFacadeV3.sol/ICreditFacadeV3.d.ts +52 -100
  164. package/lib/types/ICreditFacadeV3.sol/ICreditFacadeV3Events.d.ts +30 -32
  165. package/lib/types/ICreditFacadeV3Multicall.d.ts +68 -60
  166. package/lib/types/ICreditManagerV3.sol/ICreditManagerV3.d.ts +99 -79
  167. package/lib/types/ICurveV1Adapter.d.ts +41 -105
  168. package/lib/types/ICurveV1_2AssetsAdapter.d.ts +41 -105
  169. package/lib/types/ICurveV1_3AssetsAdapter.d.ts +41 -105
  170. package/lib/types/ICurveV1_4AssetsAdapter.d.ts +41 -105
  171. package/lib/types/IDaiLikePermit.d.ts +59 -0
  172. package/lib/types/IDaiLikePermit.js +2 -0
  173. package/lib/types/{IDataCompressorV2_10.d.ts → IDataCompressorV2_1.d.ts} +14 -43
  174. package/lib/types/IDataCompressorV2_1.js +2 -0
  175. package/lib/types/{IDataCompressorV3_00.d.ts → IDataCompressorV3.d.ts} +111 -44
  176. package/lib/types/IDataCompressorV3.js +2 -0
  177. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2.d.ts +339 -0
  178. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2.js +2 -0
  179. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Events.d.ts +61 -0
  180. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Events.js +2 -0
  181. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Exceptions.d.ts +27 -0
  182. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Exceptions.js +2 -0
  183. package/lib/types/IDegenNFTV2.sol/index.d.ts +3 -0
  184. package/lib/types/IDegenNFTV2.sol/index.js +2 -0
  185. package/lib/types/IERC165.d.ts +42 -0
  186. package/lib/types/IERC165.js +2 -0
  187. package/lib/types/IERC20ZapperDeposits.d.ts +117 -0
  188. package/lib/types/IERC20ZapperDeposits.js +2 -0
  189. package/lib/types/IERC4626Adapter.d.ts +238 -0
  190. package/lib/types/IERC4626Adapter.js +2 -0
  191. package/lib/types/IERC721.d.ts +220 -0
  192. package/lib/types/IERC721.js +2 -0
  193. package/lib/types/IERC721Metadata.d.ts +244 -0
  194. package/lib/types/IERC721Metadata.js +2 -0
  195. package/lib/types/IETHZapperDeposits.d.ts +66 -0
  196. package/lib/types/IETHZapperDeposits.js +2 -0
  197. package/lib/types/IFarmingPool.d.ts +318 -0
  198. package/lib/types/IFarmingPool.js +2 -0
  199. package/lib/types/IGaugeV3.sol/IGaugeV3.d.ts +366 -0
  200. package/lib/types/IGaugeV3.sol/IGaugeV3.js +2 -0
  201. package/lib/types/IGaugeV3.sol/IGaugeV3Events.d.ts +114 -0
  202. package/lib/types/IGaugeV3.sol/IGaugeV3Events.js +2 -0
  203. package/lib/types/IGaugeV3.sol/index.d.ts +2 -0
  204. package/lib/types/IGaugeV3.sol/index.js +2 -0
  205. package/lib/types/IGearStakingV3.sol/IGearStakingV3.d.ts +408 -0
  206. package/lib/types/IGearStakingV3.sol/IGearStakingV3.js +2 -0
  207. package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.d.ts +117 -0
  208. package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.js +2 -0
  209. package/lib/types/IGearStakingV3.sol/index.d.ts +2 -0
  210. package/lib/types/IGearStakingV3.sol/index.js +2 -0
  211. package/lib/types/ILPPriceFeed.sol/ILPPriceFeed.d.ts +285 -0
  212. package/lib/types/ILPPriceFeed.sol/ILPPriceFeed.js +2 -0
  213. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedEvents.d.ts +54 -0
  214. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedEvents.js +2 -0
  215. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedExceptions.d.ts +27 -0
  216. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedExceptions.js +2 -0
  217. package/lib/types/ILPPriceFeed.sol/index.d.ts +3 -0
  218. package/lib/types/ILPPriceFeed.sol/index.js +2 -0
  219. package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.d.ts → ILidoV1Adapter.d.ts} +13 -48
  220. package/lib/types/ILidoV1Adapter.js +2 -0
  221. package/lib/types/ILinearInterestRateModelV3.d.ts +120 -0
  222. package/lib/types/ILinearInterestRateModelV3.js +2 -0
  223. package/lib/types/IPermit2.d.ts +130 -0
  224. package/lib/types/IPermit2.js +2 -0
  225. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3.d.ts +473 -0
  226. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3.js +2 -0
  227. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events.d.ts +113 -0
  228. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events.js +2 -0
  229. package/lib/types/IPoolQuotaKeeperV3.sol/index.d.ts +2 -0
  230. package/lib/types/IPoolQuotaKeeperV3.sol/index.js +2 -0
  231. package/lib/types/IPoolV3.sol/IPoolV3.d.ts +2 -2
  232. package/lib/types/IPriceFeed.sol/IPriceFeed.d.ts +109 -0
  233. package/lib/types/IPriceFeed.sol/IPriceFeed.js +2 -0
  234. package/lib/types/IPriceFeed.sol/IUpdatablePriceFeed.d.ts +133 -0
  235. package/lib/types/IPriceFeed.sol/IUpdatablePriceFeed.js +2 -0
  236. package/lib/types/IPriceFeed.sol/index.d.ts +2 -0
  237. package/lib/types/IPriceFeed.sol/index.js +2 -0
  238. package/lib/types/IPriceOracle.sol/IPriceOracleV2.d.ts +166 -0
  239. package/lib/types/IPriceOracle.sol/IPriceOracleV2.js +2 -0
  240. package/lib/types/IPriceOracle.sol/IPriceOracleV2Events.d.ts +43 -0
  241. package/lib/types/IPriceOracle.sol/IPriceOracleV2Events.js +2 -0
  242. package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.d.ts → IPriceOracle.sol/IPriceOracleV2Exceptions.d.ts} +3 -3
  243. package/lib/types/IPriceOracle.sol/IPriceOracleV2Exceptions.js +2 -0
  244. package/lib/types/IPriceOracle.sol/IPriceOracleV2Ext.d.ts +182 -0
  245. package/lib/types/IPriceOracle.sol/IPriceOracleV2Ext.js +2 -0
  246. package/lib/types/IPriceOracle.sol/index.d.ts +4 -0
  247. package/lib/types/IPriceOracle.sol/index.js +2 -0
  248. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3.d.ts +272 -0
  249. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3.js +2 -0
  250. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3Events.d.ts +79 -0
  251. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3Events.js +2 -0
  252. package/lib/types/IPriceOracleV3.sol/index.d.ts +2 -0
  253. package/lib/types/IPriceOracleV3.sol/index.js +2 -0
  254. package/lib/types/IRouter.d.ts +11 -1
  255. package/lib/types/IRouterV3.d.ts +315 -0
  256. package/lib/types/IRouterV3.js +2 -0
  257. package/lib/types/IUniswapV2Adapter.sol/IUniswapV2Adapter.d.ts +10 -9
  258. package/lib/types/IUniswapV3Adapter.sol/IUniswapV3Adapter.d.ts +27 -21
  259. package/lib/types/IVotingContractV3.d.ts +74 -0
  260. package/lib/types/IVotingContractV3.js +2 -0
  261. package/lib/types/IWETH.d.ts +197 -0
  262. package/lib/types/IWETH.js +2 -0
  263. package/lib/types/IYearnV2Adapter.d.ts +22 -22
  264. package/lib/types/IZapper.d.ts +42 -47
  265. package/lib/types/IZapperRegister.d.ts +62 -0
  266. package/lib/types/IZapperRegister.js +2 -0
  267. package/lib/types/IwstETHV1Adapter.d.ts +17 -17
  268. package/lib/types/NumericArrayLib.d.ts +27 -0
  269. package/lib/types/NumericArrayLib.js +2 -0
  270. package/lib/types/RedstoneConstants.d.ts +27 -0
  271. package/lib/types/RedstoneConstants.js +2 -0
  272. package/lib/types/RedstoneConsumerBase.d.ts +84 -0
  273. package/lib/types/RedstoneConsumerBase.js +2 -0
  274. package/lib/types/RedstoneConsumerNumericBase.d.ts +84 -0
  275. package/lib/types/RedstoneConsumerNumericBase.js +2 -0
  276. package/lib/types/RedstoneDefaultsLib.d.ts +27 -0
  277. package/lib/types/RedstoneDefaultsLib.js +2 -0
  278. package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.d.ts → RedstonePriceFeed.sol/IRedstonePriceFeedEvents.d.ts} +11 -11
  279. package/lib/types/RedstonePriceFeed.sol/IRedstonePriceFeedEvents.js +2 -0
  280. package/lib/types/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions.d.ts +27 -0
  281. package/lib/types/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions.js +2 -0
  282. package/lib/types/RedstonePriceFeed.sol/RedstonePriceFeed.d.ts +279 -0
  283. package/lib/types/RedstonePriceFeed.sol/RedstonePriceFeed.js +2 -0
  284. package/lib/types/RedstonePriceFeed.sol/index.d.ts +3 -0
  285. package/lib/types/RedstonePriceFeed.sol/index.js +2 -0
  286. package/lib/types/SafeERC20.d.ts +27 -0
  287. package/lib/types/SafeERC20.js +2 -0
  288. package/lib/types/contracts/index.d.ts +2 -0
  289. package/lib/types/contracts/index.js +2 -0
  290. package/lib/types/contracts/interfaces/IGasPricer.d.ts +44 -0
  291. package/lib/types/contracts/interfaces/IGasPricer.js +2 -0
  292. package/lib/types/contracts/interfaces/index.d.ts +1 -0
  293. package/lib/types/contracts/interfaces/index.js +2 -0
  294. package/lib/types/factories/AddressProvider__factory.d.ts +112 -112
  295. package/lib/types/factories/AddressProvider__factory.js +120 -120
  296. package/lib/types/factories/Balances.sol/BalanceOps__factory.d.ts +4 -4
  297. package/lib/types/factories/Balances.sol/BalanceOps__factory.js +4 -4
  298. package/lib/types/factories/CalldataExtractor__factory.d.ts +87 -0
  299. package/lib/types/factories/CalldataExtractor__factory.js +127 -0
  300. package/lib/types/factories/Claimable__factory.d.ts +29 -29
  301. package/lib/types/factories/Claimable__factory.js +33 -33
  302. package/lib/types/factories/ERC20__factory.d.ts +239 -0
  303. package/lib/types/factories/ERC20__factory.js +328 -0
  304. package/lib/types/factories/Errors__factory.d.ts +100 -100
  305. package/lib/types/factories/Errors__factory.js +100 -100
  306. package/lib/types/factories/FarmAccounting__factory.d.ts +33 -0
  307. package/lib/types/factories/FarmAccounting__factory.js +57 -0
  308. package/lib/types/factories/{IWERC20Zapper__factory.d.ts → IAaveV2_LendingPoolAdapter__factory.d.ts} +96 -114
  309. package/lib/types/factories/{IWETHZapper__factory.js → IAaveV2_LendingPoolAdapter__factory.js} +105 -120
  310. package/lib/types/factories/IAaveV2_WrappedATokenAdapter__factory.d.ts +252 -0
  311. package/lib/types/factories/IAaveV2_WrappedATokenAdapter__factory.js +341 -0
  312. package/lib/types/factories/IAdapter__factory.d.ts +15 -15
  313. package/lib/types/factories/IAdapter__factory.js +15 -15
  314. package/lib/types/factories/IAddressProvider.sol/IAddressProviderEvents__factory.d.ts +7 -7
  315. package/lib/types/factories/IAddressProvider.sol/IAddressProviderEvents__factory.js +7 -7
  316. package/lib/types/factories/IAddressProvider.sol/IAddressProvider__factory.d.ts +48 -48
  317. package/lib/types/factories/IAddressProvider.sol/IAddressProvider__factory.js +52 -52
  318. package/lib/types/factories/IAddressProviderV3.sol/IAddressProviderV3Events__factory.d.ts +9 -9
  319. package/lib/types/factories/IAddressProviderV3.sol/IAddressProviderV3Events__factory.js +9 -9
  320. package/lib/types/factories/IAddressProviderV3.sol/IAddressProviderV3__factory.d.ts +37 -37
  321. package/lib/types/factories/IAddressProviderV3.sol/IAddressProviderV3__factory.js +42 -42
  322. package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributorEvents__factory.d.ts +25 -25
  323. package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributorEvents__factory.js +25 -25
  324. package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributor__factory.d.ts +71 -71
  325. package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributor__factory.js +85 -85
  326. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2VaultGetters__factory.d.ts +78 -0
  327. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2VaultGetters__factory.js +111 -0
  328. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2Vault__factory.d.ts +360 -0
  329. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2Vault__factory.js +475 -0
  330. package/lib/types/factories/IBalancerV2Vault.sol/index.d.ts +2 -0
  331. package/lib/types/factories/IBalancerV2Vault.sol/index.js +10 -0
  332. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents__factory.d.ts +23 -0
  333. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents__factory.js +38 -0
  334. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions__factory.d.ts +12 -0
  335. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions__factory.js} +5 -5
  336. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter__factory.d.ts +514 -0
  337. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter__factory.js +675 -0
  338. package/lib/types/factories/IBalancerV2VaultAdapter.sol/index.d.ts +3 -0
  339. package/lib/types/factories/IBalancerV2VaultAdapter.sol/index.js +12 -0
  340. package/lib/types/factories/IBaseRewardPool__factory.d.ts +114 -114
  341. package/lib/types/factories/IBaseRewardPool__factory.js +114 -114
  342. package/lib/types/factories/IBotListV3.sol/IBotListV3Events__factory.d.ts +103 -0
  343. package/lib/types/factories/IBotListV3.sol/IBotListV3Events__factory.js +138 -0
  344. package/lib/types/factories/IBotListV3.sol/IBotListV3__factory.d.ts +315 -0
  345. package/lib/types/factories/IBotListV3.sol/IBotListV3__factory.js +416 -0
  346. package/lib/types/factories/IBotListV3.sol/index.d.ts +2 -0
  347. package/lib/types/factories/IBotListV3.sol/index.js +10 -0
  348. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter__factory.d.ts +196 -0
  349. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter__factory.js +267 -0
  350. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions__factory.d.ts +16 -0
  351. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions__factory.js +30 -0
  352. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/index.d.ts +2 -0
  353. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/index.js +10 -0
  354. package/lib/types/factories/IContractsRegister.sol/IContractsRegisterEvents__factory.d.ts +28 -0
  355. package/lib/types/factories/IContractsRegister.sol/IContractsRegisterEvents__factory.js +45 -0
  356. package/lib/types/factories/IContractsRegister.sol/IContractsRegister__factory.d.ts +134 -0
  357. package/lib/types/factories/IContractsRegister.sol/IContractsRegister__factory.js +186 -0
  358. package/lib/types/factories/IContractsRegister.sol/index.d.ts +2 -0
  359. package/lib/types/factories/IContractsRegister.sol/index.js +10 -0
  360. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3Events__factory.d.ts +73 -0
  361. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3Events__factory.js +101 -0
  362. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3__factory.d.ts +427 -0
  363. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3__factory.js +556 -0
  364. package/lib/types/factories/IControllerTimelockV3.sol/index.d.ts +2 -0
  365. package/lib/types/factories/IControllerTimelockV3.sol/index.js +10 -0
  366. package/lib/types/factories/IConvexToken__factory.d.ts +89 -79
  367. package/lib/types/factories/IConvexToken__factory.js +99 -86
  368. package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.d.ts +103 -71
  369. package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.js +113 -71
  370. package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.d.ts +23 -0
  371. package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.js +38 -0
  372. package/lib/types/factories/{IConvexV1BoosterAdapter__factory.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.d.ts} +67 -44
  373. package/lib/types/factories/{IConvexV1BoosterAdapter__factory.js → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.js} +72 -43
  374. package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
  375. package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.js +10 -0
  376. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2Events__factory.d.ts +121 -121
  377. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2Events__factory.js +127 -127
  378. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2Exceptions__factory.d.ts +18 -18
  379. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2Exceptions__factory.js +18 -18
  380. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2__factory.d.ts +376 -376
  381. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2__factory.js +417 -417
  382. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.d.ts +118 -118
  383. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.js +127 -127
  384. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.d.ts +395 -395
  385. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.js +420 -420
  386. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Events__factory.d.ts +107 -107
  387. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Events__factory.js +118 -118
  388. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Exceptions__factory.d.ts +65 -65
  389. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Exceptions__factory.js +65 -65
  390. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.d.ts +23 -27
  391. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.js +23 -28
  392. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2V2__factory.d.ts +5 -5
  393. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2V2__factory.js +5 -5
  394. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2__factory.d.ts +601 -601
  395. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2__factory.js +749 -749
  396. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.d.ts +78 -83
  397. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.js +85 -91
  398. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.d.ts +281 -348
  399. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.js +372 -457
  400. package/lib/types/factories/ICreditFacadeV3Multicall__factory.d.ts +85 -81
  401. package/lib/types/factories/ICreditFacadeV3Multicall__factory.js +93 -89
  402. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2Events__factory.d.ts +11 -11
  403. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2Events__factory.js +12 -12
  404. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2Exceptions__factory.d.ts +26 -26
  405. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2Exceptions__factory.js +26 -26
  406. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2__factory.d.ts +252 -252
  407. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2__factory.js +272 -272
  408. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3Events__factory.d.ts +5 -5
  409. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3Events__factory.js +5 -5
  410. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.d.ts +398 -390
  411. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.js +436 -426
  412. package/lib/types/factories/ICurvePool_2.sol/ICurvePool2Assets__factory.d.ts +191 -191
  413. package/lib/types/factories/ICurvePool_2.sol/ICurvePool2Assets__factory.js +191 -191
  414. package/lib/types/factories/ICurvePool_3.sol/ICurvePool3Assets__factory.d.ts +191 -191
  415. package/lib/types/factories/ICurvePool_3.sol/ICurvePool3Assets__factory.js +191 -191
  416. package/lib/types/factories/ICurvePool_4.sol/ICurvePool4Assets__factory.d.ts +191 -191
  417. package/lib/types/factories/ICurvePool_4.sol/ICurvePool4Assets__factory.js +191 -191
  418. package/lib/types/factories/ICurvePool__factory.d.ts +159 -159
  419. package/lib/types/factories/ICurvePool__factory.js +159 -159
  420. package/lib/types/factories/ICurveV1Adapter__factory.d.ts +171 -229
  421. package/lib/types/factories/ICurveV1Adapter__factory.js +171 -248
  422. package/lib/types/factories/ICurveV1_2AssetsAdapter__factory.d.ts +189 -247
  423. package/lib/types/factories/ICurveV1_2AssetsAdapter__factory.js +189 -266
  424. package/lib/types/factories/ICurveV1_3AssetsAdapter__factory.d.ts +189 -247
  425. package/lib/types/factories/ICurveV1_3AssetsAdapter__factory.js +189 -266
  426. package/lib/types/factories/ICurveV1_4AssetsAdapter__factory.d.ts +189 -247
  427. package/lib/types/factories/ICurveV1_4AssetsAdapter__factory.js +189 -266
  428. package/lib/types/factories/IDaiLikePermit__factory.d.ts +46 -0
  429. package/lib/types/factories/IDaiLikePermit__factory.js +67 -0
  430. package/lib/types/factories/{IDataCompressorV2_10__factory.d.ts → IDataCompressorV2_1__factory.d.ts} +348 -398
  431. package/lib/types/factories/{IDataCompressorV2_10__factory.js → IDataCompressorV2_1__factory.js} +349 -413
  432. package/lib/types/factories/{IDataCompressorV3_00__factory.d.ts → IDataCompressorV3__factory.d.ts} +654 -472
  433. package/lib/types/factories/{IDataCompressorV3_00__factory.js → IDataCompressorV3__factory.js} +727 -495
  434. package/lib/types/factories/IDegenDistributor.sol/IDegenDistributorEvents__factory.d.ts +14 -14
  435. package/lib/types/factories/IDegenDistributor.sol/IDegenDistributorEvents__factory.js +14 -14
  436. package/lib/types/factories/IDegenDistributor.sol/IDegenDistributor__factory.d.ts +43 -43
  437. package/lib/types/factories/IDegenDistributor.sol/IDegenDistributor__factory.js +51 -51
  438. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Events__factory.d.ts +38 -0
  439. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Events__factory.js +58 -0
  440. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Exceptions__factory.d.ts +24 -0
  441. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Exceptions__factory.js +39 -0
  442. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3__factory.d.ts → IDegenNFTV2.sol/IDegenNFTV2__factory.d.ts} +248 -238
  443. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3__factory.js → IDegenNFTV2.sol/IDegenNFTV2__factory.js} +270 -253
  444. package/lib/types/factories/IDegenNFTV2.sol/index.d.ts +3 -0
  445. package/lib/types/factories/IDegenNFTV2.sol/index.js +12 -0
  446. package/lib/types/factories/IERC165__factory.d.ts +22 -0
  447. package/lib/types/factories/IERC165__factory.js +38 -0
  448. package/lib/types/factories/IERC20Metadata__factory.d.ts +76 -76
  449. package/lib/types/factories/IERC20Metadata__factory.js +86 -86
  450. package/lib/types/factories/IERC20Permit__factory.d.ts +16 -16
  451. package/lib/types/factories/IERC20Permit__factory.js +16 -16
  452. package/lib/types/factories/IERC20ZapperDeposits__factory.d.ts +120 -0
  453. package/lib/types/factories/IERC20ZapperDeposits__factory.js +165 -0
  454. package/lib/types/factories/IERC20__factory.d.ts +67 -67
  455. package/lib/types/factories/IERC20__factory.js +77 -77
  456. package/lib/types/factories/IERC4626Adapter__factory.d.ts +220 -0
  457. package/lib/types/factories/IERC4626Adapter__factory.js +297 -0
  458. package/lib/types/factories/IERC4626__factory.d.ts +198 -198
  459. package/lib/types/factories/IERC4626__factory.js +221 -221
  460. package/lib/types/factories/IERC721Metadata__factory.d.ts +262 -0
  461. package/lib/types/factories/IERC721Metadata__factory.js +349 -0
  462. package/lib/types/factories/IERC721__factory.d.ts +228 -0
  463. package/lib/types/factories/IERC721__factory.js +304 -0
  464. package/lib/types/factories/IETHZapperDeposits__factory.d.ts +40 -0
  465. package/lib/types/factories/IETHZapperDeposits__factory.js +62 -0
  466. package/lib/types/factories/IFarmingPool__factory.d.ts +299 -0
  467. package/lib/types/factories/IFarmingPool__factory.js +396 -0
  468. package/lib/types/factories/IGaugeV3.sol/IGaugeV3Events__factory.d.ts +118 -0
  469. package/lib/types/factories/IGaugeV3.sol/IGaugeV3Events__factory.js +157 -0
  470. package/lib/types/factories/IGaugeV3.sol/IGaugeV3__factory.d.ts +342 -0
  471. package/lib/types/factories/IGaugeV3.sol/IGaugeV3__factory.js +448 -0
  472. package/lib/types/factories/IGaugeV3.sol/index.d.ts +2 -0
  473. package/lib/types/factories/IGaugeV3.sol/index.js +10 -0
  474. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events__factory.d.ts → IGearStakingV3.sol/IGearStakingV3Events__factory.d.ts} +55 -85
  475. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events__factory.js → IGearStakingV3.sol/IGearStakingV3Events__factory.js} +58 -94
  476. package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.d.ts +504 -0
  477. package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.js +660 -0
  478. package/lib/types/factories/IGearStakingV3.sol/index.d.ts +2 -0
  479. package/lib/types/factories/IGearStakingV3.sol/index.js +10 -0
  480. package/lib/types/factories/IInterestRateModel__factory.d.ts +8 -8
  481. package/lib/types/factories/IInterestRateModel__factory.js +8 -8
  482. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedEvents__factory.d.ts +33 -0
  483. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedEvents__factory.js +51 -0
  484. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedExceptions__factory.d.ts +28 -0
  485. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedExceptions__factory.js +44 -0
  486. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeed__factory.d.ts +261 -0
  487. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeed__factory.js +344 -0
  488. package/lib/types/factories/ILPPriceFeed.sol/index.d.ts +3 -0
  489. package/lib/types/factories/ILPPriceFeed.sol/index.js +12 -0
  490. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.d.ts → ILidoV1Adapter__factory.d.ts} +44 -74
  491. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.js → ILidoV1Adapter__factory.js} +45 -83
  492. package/lib/types/factories/ILinearInterestRateModelV3__factory.d.ts +98 -0
  493. package/lib/types/factories/ILinearInterestRateModelV3__factory.js +136 -0
  494. package/lib/types/factories/IOffchainOracle__factory.d.ts +11 -11
  495. package/lib/types/factories/IOffchainOracle__factory.js +11 -11
  496. package/lib/types/factories/IPermit2__factory.d.ts +113 -0
  497. package/lib/types/factories/IPermit2__factory.js +155 -0
  498. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events__factory.d.ts +103 -0
  499. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events__factory.js +140 -0
  500. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3__factory.d.ts +441 -0
  501. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3__factory.js +580 -0
  502. package/lib/types/factories/IPoolQuotaKeeperV3.sol/index.d.ts +2 -0
  503. package/lib/types/factories/IPoolQuotaKeeperV3.sol/index.js +10 -0
  504. package/lib/types/factories/IPoolService.sol/IPoolServiceEvents__factory.d.ts +66 -66
  505. package/lib/types/factories/IPoolService.sol/IPoolServiceEvents__factory.js +72 -72
  506. package/lib/types/factories/IPoolService.sol/IPoolService__factory.d.ts +235 -235
  507. package/lib/types/factories/IPoolService.sol/IPoolService__factory.js +286 -286
  508. package/lib/types/factories/IPoolV3.sol/IPoolV3Events__factory.d.ts +65 -65
  509. package/lib/types/factories/IPoolV3.sol/IPoolV3Events__factory.js +68 -68
  510. package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.d.ts +574 -574
  511. package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.js +698 -698
  512. package/lib/types/factories/IPriceFeed.sol/IPriceFeed__factory.d.ts +84 -0
  513. package/lib/types/factories/IPriceFeed.sol/IPriceFeed__factory.js +117 -0
  514. package/lib/types/factories/IPriceFeed.sol/IUpdatablePriceFeed__factory.d.ts +104 -0
  515. package/lib/types/factories/IPriceFeed.sol/IUpdatablePriceFeed__factory.js +143 -0
  516. package/lib/types/factories/IPriceFeed.sol/index.d.ts +2 -0
  517. package/lib/types/factories/IPriceFeed.sol/index.js +10 -0
  518. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Events__factory.d.ts +23 -0
  519. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Events__factory.js +38 -0
  520. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Exceptions__factory.d.ts +20 -0
  521. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Exceptions__factory.js +34 -0
  522. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Ext__factory.d.ts +197 -0
  523. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Ext__factory.js +267 -0
  524. package/lib/types/factories/{IWETHZapper__factory.d.ts → IPriceOracle.sol/IPriceOracleV2__factory.d.ts} +114 -99
  525. package/lib/types/factories/{IWERC20Zapper__factory.js → IPriceOracle.sol/IPriceOracleV2__factory.js} +119 -110
  526. package/lib/types/factories/IPriceOracle.sol/index.d.ts +4 -0
  527. package/lib/types/factories/IPriceOracle.sol/index.js +14 -0
  528. package/lib/types/factories/IPriceOracleBase__factory.d.ts +27 -27
  529. package/lib/types/factories/IPriceOracleBase__factory.js +27 -27
  530. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3Events__factory.d.ts +78 -0
  531. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3Events__factory.js +106 -0
  532. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3__factory.d.ts +326 -0
  533. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3__factory.js +433 -0
  534. package/lib/types/factories/IPriceOracleV3.sol/index.d.ts +2 -0
  535. package/lib/types/factories/IPriceOracleV3.sol/index.js +10 -0
  536. package/lib/types/factories/IRouterV3__factory.d.ts +512 -0
  537. package/lib/types/factories/IRouterV3__factory.js +676 -0
  538. package/lib/types/factories/IRouter__factory.d.ts +168 -154
  539. package/lib/types/factories/IRouter__factory.js +186 -167
  540. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2AdapterEvents__factory.d.ts +8 -8
  541. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2AdapterEvents__factory.js +9 -9
  542. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2AdapterExceptions__factory.d.ts +2 -2
  543. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2AdapterExceptions__factory.js +2 -2
  544. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2Adapter__factory.d.ts +80 -76
  545. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2Adapter__factory.js +87 -82
  546. package/lib/types/factories/IUniswapV3.sol/ISwapRouter__factory.d.ts +50 -50
  547. package/lib/types/factories/IUniswapV3.sol/ISwapRouter__factory.js +50 -50
  548. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3AdapterEvents__factory.d.ts +10 -10
  549. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3AdapterEvents__factory.js +11 -11
  550. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3AdapterExceptions__factory.d.ts +2 -2
  551. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3AdapterExceptions__factory.js +2 -2
  552. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3Adapter__factory.d.ts +142 -134
  553. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3Adapter__factory.js +151 -141
  554. package/lib/types/factories/IVersion__factory.d.ts +3 -3
  555. package/lib/types/factories/IVersion__factory.js +3 -3
  556. package/lib/types/factories/IVotingContractV3__factory.d.ts +44 -0
  557. package/lib/types/factories/IVotingContractV3__factory.js +65 -0
  558. package/lib/types/factories/IWETHGateway__factory.d.ts +14 -14
  559. package/lib/types/factories/IWETHGateway__factory.js +14 -14
  560. package/lib/types/factories/IWETH__factory.d.ts +194 -0
  561. package/lib/types/factories/IWETH__factory.js +260 -0
  562. package/lib/types/factories/IYVault__factory.d.ts +112 -112
  563. package/lib/types/factories/IYVault__factory.js +122 -122
  564. package/lib/types/factories/IYearnV2Adapter__factory.d.ts +76 -68
  565. package/lib/types/factories/IYearnV2Adapter__factory.js +82 -70
  566. package/lib/types/factories/IZapperRegister__factory.d.ts +42 -0
  567. package/lib/types/factories/IZapperRegister__factory.js +64 -0
  568. package/lib/types/factories/IZapper__factory.d.ts +40 -48
  569. package/lib/types/factories/IZapper__factory.js +40 -50
  570. package/lib/types/factories/IstETH.sol/IstETHGetters__factory.d.ts +97 -97
  571. package/lib/types/factories/IstETH.sol/IstETHGetters__factory.js +107 -107
  572. package/lib/types/factories/IstETH.sol/IstETH__factory.d.ts +101 -101
  573. package/lib/types/factories/IstETH.sol/IstETH__factory.js +111 -111
  574. package/lib/types/factories/IwstETH.sol/IwstETHGetters__factory.d.ts +93 -93
  575. package/lib/types/factories/IwstETH.sol/IwstETHGetters__factory.js +103 -103
  576. package/lib/types/factories/IwstETH.sol/IwstETH__factory.d.ts +101 -101
  577. package/lib/types/factories/IwstETH.sol/IwstETH__factory.js +111 -111
  578. package/lib/types/factories/IwstETHGateway.sol/IwstETHGateWay__factory.d.ts +14 -14
  579. package/lib/types/factories/IwstETHGateway.sol/IwstETHGateWay__factory.js +15 -15
  580. package/lib/types/factories/IwstETHV1Adapter__factory.d.ts +52 -44
  581. package/lib/types/factories/IwstETHV1Adapter__factory.js +56 -44
  582. package/lib/types/factories/NumericArrayLib__factory.d.ts +25 -0
  583. package/lib/types/factories/NumericArrayLib__factory.js +47 -0
  584. package/lib/types/factories/Ownable__factory.d.ts +23 -23
  585. package/lib/types/factories/Ownable__factory.js +27 -27
  586. package/lib/types/factories/RedstoneConstants__factory.d.ts +65 -0
  587. package/lib/types/factories/RedstoneConstants__factory.js +99 -0
  588. package/lib/types/factories/RedstoneConsumerBase__factory.d.ts +164 -0
  589. package/lib/types/factories/RedstoneConsumerBase__factory.js +223 -0
  590. package/lib/types/factories/RedstoneConsumerNumericBase__factory.d.ts +164 -0
  591. package/lib/types/factories/RedstoneConsumerNumericBase__factory.js +223 -0
  592. package/lib/types/factories/RedstoneDefaultsLib__factory.d.ts +45 -0
  593. package/lib/types/factories/RedstoneDefaultsLib__factory.js +74 -0
  594. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.d.ts → RedstonePriceFeed.sol/IRedstonePriceFeedEvents__factory.d.ts} +9 -9
  595. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.js → RedstonePriceFeed.sol/IRedstonePriceFeedEvents__factory.js} +8 -8
  596. package/lib/types/factories/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions__factory.d.ts +28 -0
  597. package/lib/types/factories/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions__factory.js +44 -0
  598. package/lib/types/factories/RedstonePriceFeed.sol/RedstonePriceFeed__factory.d.ts +443 -0
  599. package/lib/types/factories/RedstonePriceFeed.sol/RedstonePriceFeed__factory.js +589 -0
  600. package/lib/types/factories/RedstonePriceFeed.sol/index.d.ts +3 -0
  601. package/lib/types/factories/RedstonePriceFeed.sol/index.js +12 -0
  602. package/lib/types/factories/SafeERC20__factory.d.ts +49 -0
  603. package/lib/types/factories/SafeERC20__factory.js +77 -0
  604. package/lib/types/factories/contracts/index.d.ts +1 -0
  605. package/lib/types/factories/contracts/index.js +30 -0
  606. package/lib/types/factories/contracts/interfaces/IGasPricer__factory.d.ts +22 -0
  607. package/lib/types/factories/contracts/interfaces/IGasPricer__factory.js +38 -0
  608. package/lib/types/factories/contracts/interfaces/index.d.ts +1 -0
  609. package/lib/types/factories/contracts/interfaces/index.js +8 -0
  610. package/lib/types/factories/index.d.ts +45 -7
  611. package/lib/types/factories/index.js +75 -14
  612. package/lib/types/index.d.ts +168 -24
  613. package/lib/types/index.js +135 -20
  614. package/lib/utils/formatter.d.ts +1 -4
  615. package/lib/utils/formatter.js +3 -69
  616. package/lib/utils/types.d.ts +1 -0
  617. package/lib/watchers/creditAccountWatcher.d.ts +3 -2
  618. package/lib/watchers/creditAccountWatcher.js +20 -14
  619. package/lib/watchers/creditAccountWatcher.spec.js +18 -18
  620. package/lib/watchers/creditManagerWatcher.d.ts +5 -3
  621. package/lib/watchers/creditManagerWatcher.js +32 -10
  622. package/lib/watchers/creditManagerWatcher.spec.js +12 -4
  623. package/package.json +12 -8
  624. package/contracts/IRouter.sol +0 -100
  625. package/lib/core/pool/index.d.ts +0 -1
  626. package/lib/core/strategy.spec.js +0 -62
  627. package/lib/types/ILidoV1Adapter.sol/index.d.ts +0 -3
  628. package/lib/types/IWERC20Zapper.d.ts +0 -166
  629. package/lib/types/IWETHZapper.d.ts +0 -162
  630. package/lib/types/IWithdrawalManagerV3.sol/IWithdrawalManagerV3.d.ts +0 -370
  631. package/lib/types/IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events.d.ts +0 -133
  632. package/lib/types/IWithdrawalManagerV3.sol/index.d.ts +0 -2
  633. package/lib/types/factories/ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.d.ts +0 -12
  634. package/lib/types/factories/ILidoV1Adapter.sol/index.d.ts +0 -3
  635. package/lib/types/factories/ILidoV1Adapter.sol/index.js +0 -12
  636. package/lib/types/factories/IWithdrawalManagerV3.sol/index.d.ts +0 -2
  637. package/lib/types/factories/IWithdrawalManagerV3.sol/index.js +0 -10
  638. /package/lib/core/{strategy.spec.d.ts → gaugeMath.spec.d.ts} +0 -0
  639. /package/lib/{types/IConvexV1BoosterAdapter.js → pathfinder/v1/core.js} +0 -0
  640. /package/lib/{types/IDataCompressorV2_10.js → payload/gauge.js} +0 -0
  641. /package/lib/types/{IDataCompressorV3_00.js → CalldataExtractor.js} +0 -0
  642. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.js → ERC20.js} +0 -0
  643. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.js → FarmAccounting.js} +0 -0
  644. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.js → IAaveV2_LendingPoolAdapter.js} +0 -0
  645. /package/lib/types/{ILidoV1Adapter.sol/index.js → IAaveV2_WrappedATokenAdapter.js} +0 -0
  646. /package/lib/types/{IWERC20Zapper.js → IBalancerV2Vault.sol/IBalancerV2Vault.js} +0 -0
  647. /package/lib/types/{IWETHZapper.js → IBalancerV2Vault.sol/IBalancerV2VaultGetters.js} +0 -0
  648. /package/lib/types/{IWithdrawalManagerV3.sol → IBalancerV2Vault.sol}/index.js +0 -0
  649. /package/lib/types/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter.js} +0 -0
  650. /package/lib/types/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents.js} +0 -0
@@ -36,6 +36,7 @@ const caWithoutLP = {
36
36
  rates: {
37
37
  [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
38
38
  rate: 38434,
39
+ isActive: true,
39
40
  },
40
41
  },
41
42
  };
@@ -63,6 +64,7 @@ const caWithLP = {
63
64
  rates: {
64
65
  [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH.toLowerCase()]: {
65
66
  rate: 38434,
67
+ isActive: true,
66
68
  },
67
69
  },
68
70
  };
@@ -72,38 +74,41 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
72
74
  caAssets: caWithoutLP.assets,
73
75
  totalValue: caWithoutLP.totalValue,
74
76
  debt: caWithoutLP.debt,
75
- baseBorrowRate: caWithoutLP.borrowRate,
77
+ baseRateWithFee: caWithoutLP.borrowRate,
76
78
  underlyingToken: caWithoutLP.underlyingToken,
77
79
  quotaRates: {},
78
80
  quotas: {},
81
+ feeInterest: 0,
79
82
  lpAPY,
80
83
  prices,
81
84
  });
82
- (0, chai_1.expect)(result).to.be.eq(-6.94841);
85
+ (0, chai_1.expect)(result).to.be.eq(-69484n);
83
86
  });
84
87
  it("overall APY calculation for caWithLP is correct", () => {
85
88
  const result = creditAccount_1.CreditAccountData.calcOverallAPY({
86
89
  caAssets: caWithLP.assets,
87
90
  totalValue: caWithLP.totalValue,
88
91
  debt: caWithLP.debt,
89
- baseBorrowRate: caWithLP.borrowRate,
92
+ baseRateWithFee: caWithLP.borrowRate,
90
93
  underlyingToken: caWithLP.underlyingToken,
91
94
  quotaRates: {},
92
95
  quotas: {},
96
+ feeInterest: 0,
93
97
  lpAPY,
94
98
  prices,
95
99
  });
96
- (0, chai_1.expect)(result).to.be.eq(14.4919);
100
+ (0, chai_1.expect)(result).to.be.eq(144919n);
97
101
  });
98
102
  it("overall APY is undefined when !lpAPY", () => {
99
103
  const result = creditAccount_1.CreditAccountData.calcOverallAPY({
100
104
  caAssets: caWithLP.assets,
101
105
  totalValue: caWithLP.totalValue,
102
106
  debt: caWithLP.debt,
103
- baseBorrowRate: caWithLP.borrowRate,
107
+ baseRateWithFee: caWithLP.borrowRate,
104
108
  underlyingToken: caWithLP.underlyingToken,
105
109
  quotaRates: {},
106
110
  quotas: {},
111
+ feeInterest: 0,
107
112
  lpAPY: undefined,
108
113
  prices,
109
114
  });
@@ -114,10 +119,11 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
114
119
  caAssets: caWithLP.assets,
115
120
  totalValue: undefined,
116
121
  debt: caWithLP.debt,
117
- baseBorrowRate: caWithLP.borrowRate,
122
+ baseRateWithFee: caWithLP.borrowRate,
118
123
  underlyingToken: caWithLP.underlyingToken,
119
124
  quotaRates: {},
120
125
  quotas: {},
126
+ feeInterest: 0,
121
127
  lpAPY,
122
128
  prices,
123
129
  });
@@ -128,10 +134,11 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
128
134
  caAssets: caWithLP.assets,
129
135
  totalValue: caWithLP.totalValue,
130
136
  debt: undefined,
131
- baseBorrowRate: caWithLP.borrowRate,
137
+ baseRateWithFee: caWithLP.borrowRate,
132
138
  underlyingToken: caWithLP.underlyingToken,
133
139
  quotaRates: {},
134
140
  quotas: {},
141
+ feeInterest: 0,
135
142
  lpAPY,
136
143
  prices,
137
144
  });
@@ -142,10 +149,11 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
142
149
  caAssets: caWithLP.assets,
143
150
  totalValue: 0n,
144
151
  debt: undefined,
145
- baseBorrowRate: caWithLP.borrowRate,
152
+ baseRateWithFee: caWithLP.borrowRate,
146
153
  underlyingToken: caWithLP.underlyingToken,
147
154
  quotaRates: {},
148
155
  quotas: {},
156
+ feeInterest: 0,
149
157
  lpAPY,
150
158
  prices,
151
159
  });
@@ -156,21 +164,22 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
156
164
  caAssets: caWithLP.assets,
157
165
  totalValue: caWithLP.totalValue,
158
166
  debt: caWithLP.debt,
159
- baseBorrowRate: caWithLP.borrowRate,
167
+ baseRateWithFee: caWithLP.borrowRate,
160
168
  underlyingToken: caWithLP.underlyingToken,
161
169
  quotaRates: caWithLP.rates,
162
170
  quotas: caWithLP.quotas,
171
+ feeInterest: 0,
163
172
  lpAPY,
164
173
  prices,
165
174
  });
166
- (0, chai_1.expect)(result).to.be.eq(-1.86801);
175
+ (0, chai_1.expect)(result).to.be.eq(-18680n);
167
176
  });
168
177
  it("overall APY calculation for caWithLP with insufficient quota is correct", () => {
169
178
  const result = creditAccount_1.CreditAccountData.calcOverallAPY({
170
179
  caAssets: caWithLP.assets,
171
180
  totalValue: caWithLP.totalValue,
172
181
  debt: caWithLP.debt,
173
- baseBorrowRate: caWithLP.borrowRate,
182
+ baseRateWithFee: caWithLP.borrowRate,
174
183
  underlyingToken: caWithLP.underlyingToken,
175
184
  quotaRates: caWithLP.rates,
176
185
  quotas: {
@@ -179,10 +188,11 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
179
188
  token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH.toLowerCase(),
180
189
  },
181
190
  },
191
+ feeInterest: 0,
182
192
  lpAPY,
183
193
  prices,
184
194
  });
185
- (0, chai_1.expect)(result).to.be.eq(14.4919);
195
+ (0, chai_1.expect)(result).to.be.eq(144919n);
186
196
  });
187
197
  });
188
198
  describe("CreditAccount calcMaxIncreaseBorrow test", () => {
@@ -225,29 +235,36 @@ const defaultCA = {
225
235
  token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase(),
226
236
  },
227
237
  },
238
+ quotasInfo: {
239
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
240
+ isActive: true,
241
+ },
242
+ },
228
243
  };
229
244
  describe("CreditAccount calcHealthFactor test", () => {
230
245
  it("health factor is calculated correctly", () => {
231
246
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
232
247
  quotas: {},
248
+ quotasInfo: {},
233
249
  assets: defaultCA.assets,
234
250
  prices,
235
251
  liquidationThresholds,
236
252
  underlyingToken: defaultCA.underlyingToken,
237
- borrowed: defaultCA.debt,
253
+ debt: defaultCA.debt,
238
254
  });
239
255
  (0, chai_1.expect)(result).to.be.eq(defaultCA.healthFactor);
240
256
  });
241
257
  it("health factor calculation has no division by zero error", () => {
242
258
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
243
259
  quotas: {},
260
+ quotasInfo: {},
244
261
  assets: [],
245
262
  prices: {},
246
263
  liquidationThresholds: {},
247
264
  underlyingToken: "",
248
- borrowed: 0n,
265
+ debt: 0n,
249
266
  });
250
- (0, chai_1.expect)(result).to.be.eq(0);
267
+ (0, chai_1.expect)(result).to.be.eq(65535);
251
268
  });
252
269
  it("health factor after add collateral is calculated correctly", () => {
253
270
  const collateral = {
@@ -257,11 +274,12 @@ describe("CreditAccount calcHealthFactor test", () => {
257
274
  const afterAdd = assets_1.AssetUtils.sumAssets(defaultCA.assets, [collateral]);
258
275
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
259
276
  quotas: {},
277
+ quotasInfo: {},
260
278
  assets: afterAdd,
261
279
  prices,
262
280
  liquidationThresholds,
263
281
  underlyingToken: defaultCA.underlyingToken,
264
- borrowed: defaultCA.debt,
282
+ debt: defaultCA.debt,
265
283
  });
266
284
  (0, chai_1.expect)(result).to.be.eq(11188);
267
285
  });
@@ -276,11 +294,12 @@ describe("CreditAccount calcHealthFactor test", () => {
276
294
  ]);
277
295
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
278
296
  quotas: {},
297
+ quotasInfo: {},
279
298
  assets: afterDecrease,
280
299
  prices,
281
300
  liquidationThresholds,
282
301
  underlyingToken: defaultCA.underlyingToken,
283
- borrowed: defaultCA.debt - amountDecrease,
302
+ debt: defaultCA.debt - amountDecrease,
284
303
  });
285
304
  (0, chai_1.expect)(result).to.be.eq(10308);
286
305
  });
@@ -295,11 +314,12 @@ describe("CreditAccount calcHealthFactor test", () => {
295
314
  ]);
296
315
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
297
316
  quotas: {},
317
+ quotasInfo: {},
298
318
  assets: afterIncrease,
299
319
  prices,
300
320
  liquidationThresholds,
301
321
  underlyingToken: defaultCA.underlyingToken,
302
- borrowed: defaultCA.debt + amountIncrease,
322
+ debt: defaultCA.debt + amountIncrease,
303
323
  });
304
324
  (0, chai_1.expect)(result).to.be.eq(10137);
305
325
  });
@@ -319,22 +339,24 @@ describe("CreditAccount calcHealthFactor test", () => {
319
339
  const afterSwap = assets_1.AssetUtils.sumAssets(afterSub, [getAsset]);
320
340
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
321
341
  quotas: {},
342
+ quotasInfo: {},
322
343
  assets: afterSwap,
323
344
  prices,
324
345
  liquidationThresholds,
325
346
  underlyingToken: defaultCA.underlyingToken,
326
- borrowed: defaultCA.debt,
347
+ debt: defaultCA.debt,
327
348
  });
328
349
  (0, chai_1.expect)(result).to.be.eq(9444);
329
350
  });
330
351
  it("health factor with sufficient quotas is calculated correctly", () => {
331
352
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
332
353
  quotas: defaultCA.quotas,
354
+ quotasInfo: defaultCA.quotasInfo,
333
355
  assets: defaultCA.assets,
334
356
  prices,
335
357
  liquidationThresholds,
336
358
  underlyingToken: defaultCA.underlyingToken,
337
- borrowed: defaultCA.debt,
359
+ debt: defaultCA.debt,
338
360
  });
339
361
  (0, chai_1.expect)(result).to.be.eq(defaultCA.healthFactor);
340
362
  });
@@ -346,11 +368,28 @@ describe("CreditAccount calcHealthFactor test", () => {
346
368
  token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase(),
347
369
  },
348
370
  },
371
+ quotasInfo: defaultCA.quotasInfo,
349
372
  assets: defaultCA.assets,
350
373
  prices,
351
374
  liquidationThresholds,
352
375
  underlyingToken: defaultCA.underlyingToken,
353
- borrowed: defaultCA.debt,
376
+ debt: defaultCA.debt,
377
+ });
378
+ (0, chai_1.expect)(result).to.be.eq(9300);
379
+ });
380
+ it("health factor with disabled quota is calculated correctly", () => {
381
+ const result = creditAccount_1.CreditAccountData.calcHealthFactor({
382
+ quotas: defaultCA.quotas,
383
+ quotasInfo: {
384
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
385
+ isActive: false,
386
+ },
387
+ },
388
+ assets: defaultCA.assets,
389
+ prices,
390
+ liquidationThresholds,
391
+ underlyingToken: defaultCA.underlyingToken,
392
+ debt: defaultCA.debt,
354
393
  });
355
394
  (0, chai_1.expect)(result).to.be.eq(9300);
356
395
  });
@@ -377,9 +416,18 @@ const caQuota = {
377
416
  quota: 10n,
378
417
  },
379
418
  };
419
+ const QUOTA_RESERVE = 100n;
420
+ const DEFAULT_LT = {
421
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: sdk_gov_1.PERCENTAGE_FACTOR,
422
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: sdk_gov_1.PERCENTAGE_FACTOR,
423
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: sdk_gov_1.PERCENTAGE_FACTOR,
424
+ };
425
+ const HUGE_MAX_DEBT = 20n;
380
426
  describe("CreditAccount calcQuotaUpdate test", () => {
381
427
  it("open account should buy quota", () => {
382
428
  const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
429
+ maxDebt: HUGE_MAX_DEBT,
430
+ quotaReserve: QUOTA_RESERVE,
383
431
  quotas: cmQuotas,
384
432
  initialQuotas: {},
385
433
  assetsAfterUpdate: {
@@ -399,6 +447,7 @@ describe("CreditAccount calcQuotaUpdate test", () => {
399
447
  [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
400
448
  },
401
449
  allowedToSpend: {},
450
+ liquidationThresholds: DEFAULT_LT,
402
451
  });
403
452
  (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
404
453
  {
@@ -428,6 +477,8 @@ describe("CreditAccount calcQuotaUpdate test", () => {
428
477
  });
429
478
  it("add collateral should buy quota", () => {
430
479
  const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
480
+ maxDebt: HUGE_MAX_DEBT,
481
+ quotaReserve: QUOTA_RESERVE,
431
482
  quotas: cmQuotas,
432
483
  initialQuotas: caQuota,
433
484
  assetsAfterUpdate: {
@@ -441,6 +492,7 @@ describe("CreditAccount calcQuotaUpdate test", () => {
441
492
  [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {},
442
493
  },
443
494
  allowedToSpend: {},
495
+ liquidationThresholds: DEFAULT_LT,
444
496
  });
445
497
  (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
446
498
  {
@@ -466,6 +518,8 @@ describe("CreditAccount calcQuotaUpdate test", () => {
466
518
  });
467
519
  it("add collateral should add additional quota", () => {
468
520
  const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
521
+ maxDebt: HUGE_MAX_DEBT,
522
+ quotaReserve: QUOTA_RESERVE,
469
523
  quotas: cmQuotas,
470
524
  initialQuotas: caQuota,
471
525
  assetsAfterUpdate: {
@@ -479,6 +533,7 @@ describe("CreditAccount calcQuotaUpdate test", () => {
479
533
  [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
480
534
  },
481
535
  allowedToSpend: {},
536
+ liquidationThresholds: DEFAULT_LT,
482
537
  });
483
538
  (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
484
539
  {
@@ -504,6 +559,8 @@ describe("CreditAccount calcQuotaUpdate test", () => {
504
559
  });
505
560
  it("add collateral shouldn't add additional quota", () => {
506
561
  const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
562
+ maxDebt: HUGE_MAX_DEBT,
563
+ quotaReserve: QUOTA_RESERVE,
507
564
  quotas: cmQuotas,
508
565
  initialQuotas: caQuota,
509
566
  assetsAfterUpdate: {
@@ -517,6 +574,7 @@ describe("CreditAccount calcQuotaUpdate test", () => {
517
574
  [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
518
575
  },
519
576
  allowedToSpend: {},
577
+ liquidationThresholds: DEFAULT_LT,
520
578
  });
521
579
  (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
522
580
  (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
@@ -537,6 +595,8 @@ describe("CreditAccount calcQuotaUpdate test", () => {
537
595
  });
538
596
  it("swap should buy quota", () => {
539
597
  const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
598
+ maxDebt: HUGE_MAX_DEBT,
599
+ quotaReserve: QUOTA_RESERVE,
540
600
  quotas: cmQuotas,
541
601
  initialQuotas: caQuota,
542
602
  assetsAfterUpdate: {
@@ -555,6 +615,7 @@ describe("CreditAccount calcQuotaUpdate test", () => {
555
615
  [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {},
556
616
  },
557
617
  allowedToSpend: { [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {} },
618
+ liquidationThresholds: DEFAULT_LT,
558
619
  });
559
620
  (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
560
621
  {
@@ -580,8 +641,10 @@ describe("CreditAccount calcQuotaUpdate test", () => {
580
641
  },
581
642
  });
582
643
  });
583
- it("swap should add additional quota", () => {
644
+ it("swap should buy additional quota", () => {
584
645
  const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
646
+ maxDebt: HUGE_MAX_DEBT,
647
+ quotaReserve: QUOTA_RESERVE,
585
648
  quotas: cmQuotas,
586
649
  initialQuotas: caQuota,
587
650
  assetsAfterUpdate: {
@@ -602,6 +665,7 @@ describe("CreditAccount calcQuotaUpdate test", () => {
602
665
  allowedToSpend: {
603
666
  [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
604
667
  },
668
+ liquidationThresholds: DEFAULT_LT,
605
669
  });
606
670
  (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
607
671
  {
@@ -630,8 +694,10 @@ describe("CreditAccount calcQuotaUpdate test", () => {
630
694
  },
631
695
  });
632
696
  });
633
- it("swap shouldn't add additional quota", () => {
697
+ it("swap shouldn't buy additional quota", () => {
634
698
  const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
699
+ maxDebt: HUGE_MAX_DEBT,
700
+ quotaReserve: QUOTA_RESERVE,
635
701
  quotas: cmQuotas,
636
702
  initialQuotas: caQuota,
637
703
  assetsAfterUpdate: {
@@ -650,6 +716,7 @@ describe("CreditAccount calcQuotaUpdate test", () => {
650
716
  [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
651
717
  },
652
718
  allowedToSpend: { [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {} },
719
+ liquidationThresholds: DEFAULT_LT,
653
720
  });
654
721
  (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
655
722
  (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
@@ -675,22 +742,25 @@ describe("CreditAccount calcQuotaUpdate test", () => {
675
742
  });
676
743
  it("shouldn't change quota if disallowed", () => {
677
744
  const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
745
+ maxDebt: HUGE_MAX_DEBT,
746
+ quotaReserve: QUOTA_RESERVE,
678
747
  quotas: cmQuotas,
679
748
  initialQuotas: caQuota,
680
749
  assetsAfterUpdate: {
681
- [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
750
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
682
751
  amountInTarget: 10n,
683
752
  balance: 0n,
684
- token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
753
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
685
754
  },
686
- [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
755
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
687
756
  amountInTarget: 0n,
688
757
  balance: 0n,
689
- token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
758
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
690
759
  },
691
760
  },
692
761
  allowedToObtain: {},
693
762
  allowedToSpend: {},
763
+ liquidationThresholds: DEFAULT_LT,
694
764
  });
695
765
  (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
696
766
  (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
@@ -709,4 +779,546 @@ describe("CreditAccount calcQuotaUpdate test", () => {
709
779
  },
710
780
  });
711
781
  });
782
+ it("shouldn't change quota if it is disabled", () => {
783
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
784
+ maxDebt: HUGE_MAX_DEBT,
785
+ quotaReserve: QUOTA_RESERVE,
786
+ quotas: {
787
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
788
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
789
+ isActive: false,
790
+ },
791
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
792
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
793
+ isActive: false,
794
+ },
795
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
796
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
797
+ isActive: false,
798
+ },
799
+ },
800
+ initialQuotas: caQuota,
801
+ assetsAfterUpdate: {
802
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
803
+ amountInTarget: 10n,
804
+ balance: 0n,
805
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
806
+ },
807
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
808
+ amountInTarget: 0n,
809
+ balance: 0n,
810
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
811
+ },
812
+ },
813
+ allowedToObtain: {
814
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
815
+ },
816
+ allowedToSpend: {
817
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
818
+ },
819
+ liquidationThresholds: DEFAULT_LT,
820
+ });
821
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
822
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
823
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
824
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
825
+ balance: 5n,
826
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
827
+ },
828
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
829
+ balance: 10n,
830
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
831
+ },
832
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
833
+ balance: 0n,
834
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
835
+ },
836
+ });
837
+ });
838
+ it("swap shouldn't buy quota if no lt", () => {
839
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
840
+ maxDebt: HUGE_MAX_DEBT,
841
+ quotaReserve: QUOTA_RESERVE,
842
+ quotas: cmQuotas,
843
+ initialQuotas: {
844
+ ...caQuota,
845
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
846
+ quota: 5n,
847
+ },
848
+ },
849
+ assetsAfterUpdate: {
850
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
851
+ amountInTarget: 10n,
852
+ balance: 0n,
853
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
854
+ },
855
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
856
+ amountInTarget: 5n,
857
+ balance: 0n,
858
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
859
+ },
860
+ },
861
+ allowedToObtain: {
862
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {},
863
+ },
864
+ allowedToSpend: { [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {} },
865
+ liquidationThresholds: {},
866
+ });
867
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
868
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
869
+ { balance: -10n, token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH },
870
+ ]);
871
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
872
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
873
+ balance: 5n,
874
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
875
+ },
876
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
877
+ balance: 0n,
878
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
879
+ },
880
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
881
+ balance: 5n,
882
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
883
+ },
884
+ });
885
+ });
886
+ it("swap should buy quota with respect to lt", () => {
887
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
888
+ maxDebt: HUGE_MAX_DEBT,
889
+ quotaReserve: QUOTA_RESERVE,
890
+ quotas: cmQuotas,
891
+ initialQuotas: {
892
+ ...caQuota,
893
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: { quota: 5n },
894
+ },
895
+ assetsAfterUpdate: {
896
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
897
+ amountInTarget: 20n,
898
+ balance: 0n,
899
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
900
+ },
901
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
902
+ amountInTarget: 5n,
903
+ balance: 0n,
904
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
905
+ },
906
+ },
907
+ allowedToObtain: {
908
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {},
909
+ },
910
+ allowedToSpend: { [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {} },
911
+ liquidationThresholds: {
912
+ ...DEFAULT_LT,
913
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: 5000n,
914
+ },
915
+ });
916
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
917
+ {
918
+ balance: 5n,
919
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
920
+ },
921
+ ]);
922
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
923
+ { balance: -5n, token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH },
924
+ ]);
925
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
926
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
927
+ balance: 5n,
928
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
929
+ },
930
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
931
+ balance: 5n,
932
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
933
+ },
934
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
935
+ balance: 10n,
936
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
937
+ },
938
+ });
939
+ });
940
+ it("swap shouldn't buy quota with respect to lt", () => {
941
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
942
+ maxDebt: HUGE_MAX_DEBT,
943
+ quotaReserve: QUOTA_RESERVE,
944
+ quotas: cmQuotas,
945
+ initialQuotas: {
946
+ ...caQuota,
947
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: { quota: 5n },
948
+ },
949
+ assetsAfterUpdate: {
950
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
951
+ amountInTarget: 10n,
952
+ balance: 0n,
953
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
954
+ },
955
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
956
+ amountInTarget: 5n,
957
+ balance: 0n,
958
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
959
+ },
960
+ },
961
+ allowedToObtain: {
962
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {},
963
+ },
964
+ allowedToSpend: { [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {} },
965
+ liquidationThresholds: {
966
+ ...DEFAULT_LT,
967
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: 5000n,
968
+ },
969
+ });
970
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
971
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
972
+ { balance: -5n, token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH },
973
+ ]);
974
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
975
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
976
+ balance: 5n,
977
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
978
+ },
979
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
980
+ balance: 5n,
981
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
982
+ },
983
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
984
+ balance: 5n,
985
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
986
+ },
987
+ });
988
+ });
989
+ it("swap should buy additional quota after limit was increased", () => {
990
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
991
+ maxDebt: 10n,
992
+ quotaReserve: QUOTA_RESERVE,
993
+ quotas: cmQuotas,
994
+ initialQuotas: {
995
+ ...caQuota,
996
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
997
+ quota: 10n,
998
+ },
999
+ },
1000
+ assetsAfterUpdate: {
1001
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1002
+ amountInTarget: 20n,
1003
+ balance: 0n,
1004
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1005
+ },
1006
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1007
+ amountInTarget: 0n,
1008
+ balance: 0n,
1009
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1010
+ },
1011
+ },
1012
+ allowedToObtain: {
1013
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
1014
+ },
1015
+ allowedToSpend: {
1016
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
1017
+ },
1018
+ liquidationThresholds: DEFAULT_LT,
1019
+ });
1020
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
1021
+ {
1022
+ balance: 10n,
1023
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1024
+ },
1025
+ ]);
1026
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
1027
+ {
1028
+ balance: -10n,
1029
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1030
+ },
1031
+ ]);
1032
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
1033
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1034
+ balance: 20n,
1035
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1036
+ },
1037
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1038
+ balance: 0n,
1039
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1040
+ },
1041
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
1042
+ balance: 0n,
1043
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
1044
+ },
1045
+ });
1046
+ });
1047
+ it("swap should buy additional quota with respect to debt limit", () => {
1048
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
1049
+ maxDebt: 9n,
1050
+ quotaReserve: QUOTA_RESERVE,
1051
+ quotas: cmQuotas,
1052
+ initialQuotas: {
1053
+ ...caQuota,
1054
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1055
+ quota: 10n,
1056
+ },
1057
+ },
1058
+ assetsAfterUpdate: {
1059
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1060
+ amountInTarget: 20n,
1061
+ balance: 0n,
1062
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1063
+ },
1064
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1065
+ amountInTarget: 0n,
1066
+ balance: 0n,
1067
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1068
+ },
1069
+ },
1070
+ allowedToObtain: {
1071
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
1072
+ },
1073
+ allowedToSpend: {
1074
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
1075
+ },
1076
+ liquidationThresholds: DEFAULT_LT,
1077
+ });
1078
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
1079
+ {
1080
+ balance: 8n,
1081
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1082
+ },
1083
+ ]);
1084
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
1085
+ {
1086
+ balance: -10n,
1087
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1088
+ },
1089
+ ]);
1090
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
1091
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1092
+ balance: 18n,
1093
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1094
+ },
1095
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1096
+ balance: 0n,
1097
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1098
+ },
1099
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
1100
+ balance: 0n,
1101
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
1102
+ },
1103
+ });
1104
+ });
1105
+ it("swap shouldn't buy additional quota if debt limit more then current quota", () => {
1106
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
1107
+ maxDebt: 5n,
1108
+ quotaReserve: QUOTA_RESERVE,
1109
+ quotas: cmQuotas,
1110
+ initialQuotas: {
1111
+ ...caQuota,
1112
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1113
+ quota: 10n,
1114
+ },
1115
+ },
1116
+ assetsAfterUpdate: {
1117
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1118
+ amountInTarget: 20n,
1119
+ balance: 0n,
1120
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1121
+ },
1122
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1123
+ amountInTarget: 0n,
1124
+ balance: 0n,
1125
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1126
+ },
1127
+ },
1128
+ allowedToObtain: {
1129
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
1130
+ },
1131
+ allowedToSpend: {
1132
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
1133
+ },
1134
+ liquidationThresholds: DEFAULT_LT,
1135
+ });
1136
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
1137
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
1138
+ {
1139
+ balance: -10n,
1140
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1141
+ },
1142
+ ]);
1143
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
1144
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1145
+ balance: 10n,
1146
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1147
+ },
1148
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1149
+ balance: 0n,
1150
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1151
+ },
1152
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
1153
+ balance: 0n,
1154
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
1155
+ },
1156
+ });
1157
+ });
1158
+ });
1159
+ describe("CreditAccount calcAvgQuotaBorrowRate test", () => {
1160
+ it("should calculate quota rate (same amounts, different rates)", () => {
1161
+ const result = creditAccount_1.CreditAccountData.calcQuotaBorrowRate({
1162
+ quotas: {
1163
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1164
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1165
+ balance: 10n,
1166
+ },
1167
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1168
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1169
+ balance: 10n,
1170
+ },
1171
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
1172
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
1173
+ balance: 10n,
1174
+ },
1175
+ },
1176
+ quotaRates: {
1177
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1178
+ rate: 5,
1179
+ isActive: true,
1180
+ },
1181
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1182
+ rate: 10,
1183
+ isActive: true,
1184
+ },
1185
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
1186
+ rate: 15,
1187
+ isActive: true,
1188
+ },
1189
+ },
1190
+ });
1191
+ (0, chai_1.expect)(result).to.be.eq(300n);
1192
+ });
1193
+ it("should calculate quota rate (same rates, different amounts)", () => {
1194
+ const result = creditAccount_1.CreditAccountData.calcQuotaBorrowRate({
1195
+ quotas: {
1196
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1197
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1198
+ balance: 5n,
1199
+ },
1200
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1201
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1202
+ balance: 10n,
1203
+ },
1204
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
1205
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
1206
+ balance: 15n,
1207
+ },
1208
+ },
1209
+ quotaRates: {
1210
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1211
+ rate: 10,
1212
+ isActive: true,
1213
+ },
1214
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1215
+ rate: 10,
1216
+ isActive: true,
1217
+ },
1218
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
1219
+ rate: 10,
1220
+ isActive: true,
1221
+ },
1222
+ },
1223
+ });
1224
+ (0, chai_1.expect)(result).to.be.eq(300n);
1225
+ });
1226
+ it("should calculate quota rate (disabled quota)", () => {
1227
+ const result = creditAccount_1.CreditAccountData.calcQuotaBorrowRate({
1228
+ quotas: {
1229
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1230
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1231
+ balance: 5n,
1232
+ },
1233
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1234
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
1235
+ balance: 10n,
1236
+ },
1237
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
1238
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
1239
+ balance: 15n,
1240
+ },
1241
+ },
1242
+ quotaRates: {
1243
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1244
+ rate: 10,
1245
+ isActive: true,
1246
+ },
1247
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
1248
+ rate: 10,
1249
+ isActive: false,
1250
+ },
1251
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
1252
+ rate: 10,
1253
+ isActive: true,
1254
+ },
1255
+ },
1256
+ });
1257
+ (0, chai_1.expect)(result).to.be.eq(200n);
1258
+ });
1259
+ });
1260
+ describe("CreditAccount calcQuotaBorrowRate test", () => {
1261
+ it("should calculate quota borrow rate", () => {
1262
+ const result = creditAccount_1.CreditAccountData.calcQuotaBorrowRate({
1263
+ quotas: {
1264
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1265
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1266
+ balance: 10n,
1267
+ },
1268
+ },
1269
+ quotaRates: {
1270
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1271
+ rate: 5,
1272
+ isActive: true,
1273
+ },
1274
+ },
1275
+ });
1276
+ (0, chai_1.expect)(result).to.be.eq(50n);
1277
+ });
1278
+ it("should calculate quota borrow rate when no balance", () => {
1279
+ const result = creditAccount_1.CreditAccountData.calcQuotaBorrowRate({
1280
+ quotas: {
1281
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1282
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
1283
+ balance: 1n,
1284
+ },
1285
+ },
1286
+ quotaRates: {
1287
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
1288
+ rate: 5,
1289
+ isActive: true,
1290
+ },
1291
+ },
1292
+ });
1293
+ (0, chai_1.expect)(result).to.be.eq(5n);
1294
+ });
1295
+ });
1296
+ describe("CreditAccount calcRelativeBaseBorrowRate test", () => {
1297
+ it("should calculate relative borrow rate", () => {
1298
+ const result = creditAccount_1.CreditAccountData.calcRelativeBaseBorrowRate({
1299
+ debt: 200n,
1300
+ baseRateWithFee: 250,
1301
+ assetAmountInUnderlying: 200n,
1302
+ totalValue: 400n,
1303
+ });
1304
+ (0, chai_1.expect)(result).to.be.eq(25000n);
1305
+ });
1306
+ it("should calculate relative borrow rate if position asset === 0", () => {
1307
+ const result = creditAccount_1.CreditAccountData.calcRelativeBaseBorrowRate({
1308
+ debt: 200n,
1309
+ baseRateWithFee: 250,
1310
+ assetAmountInUnderlying: 1n,
1311
+ totalValue: 400n,
1312
+ });
1313
+ (0, chai_1.expect)(result).to.be.eq(125n);
1314
+ });
1315
+ it("should calculate relative borrow rate if position === 0", () => {
1316
+ const result = creditAccount_1.CreditAccountData.calcRelativeBaseBorrowRate({
1317
+ debt: 1n,
1318
+ baseRateWithFee: 250,
1319
+ assetAmountInUnderlying: 1n,
1320
+ totalValue: 1n,
1321
+ });
1322
+ (0, chai_1.expect)(result).to.be.eq(250n);
1323
+ });
712
1324
  });