@gearbox-protocol/sdk 3.0.0-next.13 → 3.0.0-next.131

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 (648) hide show
  1. package/contracts/index.sol +32 -3
  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 +111 -59
  10. package/lib/apy/defiLamaAPY.d.ts +3 -0
  11. package/lib/apy/defiLamaAPY.js +68 -0
  12. package/lib/apy/index.d.ts +5 -4
  13. package/lib/apy/index.js +6 -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 +9 -4
  19. package/lib/contracts/contractsRegister.js +18 -0
  20. package/lib/core/assets.d.ts +2 -2
  21. package/lib/core/assets.js +4 -4
  22. package/lib/core/creditAccount.d.ts +76 -16
  23. package/lib/core/creditAccount.js +201 -64
  24. package/lib/core/creditAccount.spec.js +1090 -17
  25. package/lib/core/creditManager.d.ts +18 -6
  26. package/lib/core/creditManager.js +70 -14
  27. package/lib/core/creditSession.d.ts +11 -1
  28. package/lib/core/creditSession.js +20 -2
  29. package/lib/core/endpoint.d.ts +14 -0
  30. package/lib/core/endpoint.js +33 -0
  31. package/lib/core/eventOrTx.d.ts +2 -3
  32. package/lib/core/events.js +16 -16
  33. package/lib/core/gauge.d.ts +26 -0
  34. package/lib/core/gauge.js +63 -0
  35. package/lib/core/gaugeMath.d.ts +40 -0
  36. package/lib/core/gaugeMath.js +108 -0
  37. package/lib/core/gaugeMath.spec.js +388 -0
  38. package/lib/core/{pool/data.d.ts → pool.d.ts} +14 -8
  39. package/lib/core/{pool/data.js → pool.js} +38 -20
  40. package/lib/core/rewardClaimer.d.ts +4 -2
  41. package/lib/core/rewardConvex.d.ts +26 -9
  42. package/lib/core/rewardConvex.js +183 -56
  43. package/lib/core/rewardConvex.spec.js +32 -68
  44. package/lib/core/strategy.d.ts +18 -21
  45. package/lib/core/strategy.js +16 -36
  46. package/lib/core/trade.d.ts +11 -12
  47. package/lib/core/trade.js +36 -29
  48. package/lib/core/transactions.d.ts +110 -14
  49. package/lib/core/transactions.js +191 -108
  50. package/lib/index.d.ts +6 -2
  51. package/lib/index.js +6 -2
  52. package/lib/parsers/ERC20Parser.js +1 -1
  53. package/lib/parsers/aaveV2LendingPoolAdapterParser.d.ts +7 -0
  54. package/lib/parsers/aaveV2LendingPoolAdapterParser.js +21 -0
  55. package/lib/parsers/aaveV2WrappedATokenAdapterParser.d.ts +7 -0
  56. package/lib/parsers/aaveV2WrappedATokenAdapterParser.js +21 -0
  57. package/lib/parsers/abstractParser.d.ts +7 -5
  58. package/lib/parsers/abstractParser.js +4 -2
  59. package/lib/parsers/addressProviderParser.js +1 -1
  60. package/lib/parsers/balancerV2VaultParser.d.ts +7 -0
  61. package/lib/parsers/balancerV2VaultParser.js +34 -0
  62. package/lib/parsers/compoundV2CTokenAdapterParser.d.ts +7 -0
  63. package/lib/parsers/compoundV2CTokenAdapterParser.js +21 -0
  64. package/lib/parsers/convexBaseRewardPoolAdapterParser.js +13 -9
  65. package/lib/parsers/convexBaseRewardPoolAdapterParser.spec.js +9 -6
  66. package/lib/parsers/convexBoosterAdapterParser.js +7 -7
  67. package/lib/parsers/convexBoosterAdapterParser.spec.js +4 -4
  68. package/lib/parsers/convextRewardPoolParser.js +1 -1
  69. package/lib/parsers/creditFacadeParser.js +33 -6
  70. package/lib/parsers/creditFacadeParser.spec.js +2 -3
  71. package/lib/parsers/creditManagerParser.js +1 -1
  72. package/lib/parsers/curveAdapterParser.js +11 -12
  73. package/lib/parsers/curveAdapterParser.spec.js +6 -2
  74. package/lib/parsers/erc626AdapterParser.d.ts +7 -0
  75. package/lib/parsers/erc626AdapterParser.js +21 -0
  76. package/lib/parsers/lidoAdapterParser.js +4 -3
  77. package/lib/parsers/lidoAdapterParser.spec.js +2 -2
  78. package/lib/parsers/lidoSTETHParser.js +1 -1
  79. package/lib/parsers/poolParser.js +1 -1
  80. package/lib/parsers/priceOracleParser.js +1 -1
  81. package/lib/parsers/txParser.d.ts +17 -11
  82. package/lib/parsers/txParser.js +41 -4
  83. package/lib/parsers/uniV2AdapterParser.js +6 -5
  84. package/lib/parsers/uniV2AdapterParser.spec.js +3 -2
  85. package/lib/parsers/uniV3AdapterParser.js +10 -8
  86. package/lib/parsers/uniV3AdapterParser.spec.js +3 -2
  87. package/lib/parsers/wstETHAdapterParser.js +7 -5
  88. package/lib/parsers/wstETHAdapterParser.spec.js +4 -4
  89. package/lib/parsers/yearnAdapterParser.spec.js +4 -4
  90. package/lib/parsers/yearnV2AdapterParser.js +14 -4
  91. package/lib/pathfinder/balancerVault.d.ts +33 -0
  92. package/lib/pathfinder/balancerVault.js +59 -0
  93. package/lib/pathfinder/core.d.ts +8 -9
  94. package/lib/pathfinder/index.d.ts +4 -0
  95. package/lib/{core/pool → pathfinder}/index.js +4 -1
  96. package/lib/pathfinder/pathOptions.d.ts +2 -1
  97. package/lib/pathfinder/pathOptions.js +33 -11
  98. package/lib/pathfinder/pathOptions.spec.js +2 -2
  99. package/lib/pathfinder/pathfinder.d.ts +46 -19
  100. package/lib/pathfinder/pathfinder.js +61 -55
  101. package/lib/pathfinder/pathfinder.spec.js +22 -9
  102. package/lib/pathfinder/utils.d.ts +36 -0
  103. package/lib/pathfinder/utils.js +181 -0
  104. package/lib/pathfinder/v1/core.d.ts +16 -0
  105. package/lib/pathfinder/v1/pathfinderv1.d.ts +46 -0
  106. package/lib/pathfinder/v1/pathfinderv1.js +155 -0
  107. package/lib/pathfinder/v1/pathfinderv1.spec.d.ts +1 -0
  108. package/lib/pathfinder/v1/pathfinderv1.spec.js +39 -0
  109. package/lib/payload/creditAccount.d.ts +3 -4
  110. package/lib/payload/creditManager.d.ts +3 -0
  111. package/lib/payload/creditSession.d.ts +11 -0
  112. package/lib/payload/gauge.d.ts +12 -0
  113. package/lib/payload/pool.d.ts +4 -0
  114. package/lib/types/CalldataExtractor.d.ts +44 -0
  115. package/lib/types/ERC20.d.ts +198 -0
  116. package/lib/types/FarmAccounting.d.ts +27 -0
  117. package/lib/types/IAaveV2_LendingPoolAdapter.d.ts +171 -0
  118. package/lib/types/IAaveV2_WrappedATokenAdapter.d.ts +290 -0
  119. package/lib/types/IBalancerV2Vault.sol/IBalancerV2Vault.d.ts +308 -0
  120. package/lib/types/IBalancerV2Vault.sol/IBalancerV2VaultGetters.d.ts +112 -0
  121. package/lib/types/IBalancerV2Vault.sol/index.d.ts +2 -0
  122. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter.d.ts +466 -0
  123. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter.js +2 -0
  124. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents.d.ts +43 -0
  125. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents.js +2 -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 +11 -40
  174. package/lib/types/IDataCompressorV3_00.d.ts +108 -41
  175. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2.d.ts +339 -0
  176. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2.js +2 -0
  177. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Events.d.ts +61 -0
  178. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Events.js +2 -0
  179. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Exceptions.d.ts +27 -0
  180. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Exceptions.js +2 -0
  181. package/lib/types/IDegenNFTV2.sol/index.d.ts +3 -0
  182. package/lib/types/IDegenNFTV2.sol/index.js +2 -0
  183. package/lib/types/IERC165.d.ts +42 -0
  184. package/lib/types/IERC165.js +2 -0
  185. package/lib/types/IERC20ZapperDeposits.d.ts +117 -0
  186. package/lib/types/IERC20ZapperDeposits.js +2 -0
  187. package/lib/types/IERC4626Adapter.d.ts +238 -0
  188. package/lib/types/IERC4626Adapter.js +2 -0
  189. package/lib/types/IERC721.d.ts +220 -0
  190. package/lib/types/IERC721.js +2 -0
  191. package/lib/types/IERC721Metadata.d.ts +244 -0
  192. package/lib/types/IERC721Metadata.js +2 -0
  193. package/lib/types/IETHZapperDeposits.d.ts +66 -0
  194. package/lib/types/IETHZapperDeposits.js +2 -0
  195. package/lib/types/IFarmingPool.d.ts +318 -0
  196. package/lib/types/IFarmingPool.js +2 -0
  197. package/lib/types/IGaugeV3.sol/IGaugeV3.d.ts +366 -0
  198. package/lib/types/IGaugeV3.sol/IGaugeV3.js +2 -0
  199. package/lib/types/IGaugeV3.sol/IGaugeV3Events.d.ts +114 -0
  200. package/lib/types/IGaugeV3.sol/IGaugeV3Events.js +2 -0
  201. package/lib/types/IGaugeV3.sol/index.d.ts +2 -0
  202. package/lib/types/IGaugeV3.sol/index.js +2 -0
  203. package/lib/types/IGearStakingV3.sol/IGearStakingV3.d.ts +408 -0
  204. package/lib/types/IGearStakingV3.sol/IGearStakingV3.js +2 -0
  205. package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.d.ts +117 -0
  206. package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.js +2 -0
  207. package/lib/types/IGearStakingV3.sol/index.d.ts +2 -0
  208. package/lib/types/IGearStakingV3.sol/index.js +2 -0
  209. package/lib/types/ILPPriceFeed.sol/ILPPriceFeed.d.ts +285 -0
  210. package/lib/types/ILPPriceFeed.sol/ILPPriceFeed.js +2 -0
  211. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedEvents.d.ts +54 -0
  212. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedEvents.js +2 -0
  213. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedExceptions.d.ts +27 -0
  214. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedExceptions.js +2 -0
  215. package/lib/types/ILPPriceFeed.sol/index.d.ts +3 -0
  216. package/lib/types/ILPPriceFeed.sol/index.js +2 -0
  217. package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.d.ts → ILidoV1Adapter.d.ts} +13 -48
  218. package/lib/types/ILidoV1Adapter.js +2 -0
  219. package/lib/types/ILinearInterestRateModelV3.d.ts +120 -0
  220. package/lib/types/ILinearInterestRateModelV3.js +2 -0
  221. package/lib/types/IPermit2.d.ts +130 -0
  222. package/lib/types/IPermit2.js +2 -0
  223. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3.d.ts +473 -0
  224. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3.js +2 -0
  225. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events.d.ts +113 -0
  226. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events.js +2 -0
  227. package/lib/types/IPoolQuotaKeeperV3.sol/index.d.ts +2 -0
  228. package/lib/types/IPoolQuotaKeeperV3.sol/index.js +2 -0
  229. package/lib/types/IPoolV3.sol/IPoolV3.d.ts +2 -2
  230. package/lib/types/IPriceFeed.sol/IPriceFeed.d.ts +109 -0
  231. package/lib/types/IPriceFeed.sol/IPriceFeed.js +2 -0
  232. package/lib/types/IPriceFeed.sol/IUpdatablePriceFeed.d.ts +133 -0
  233. package/lib/types/IPriceFeed.sol/IUpdatablePriceFeed.js +2 -0
  234. package/lib/types/IPriceFeed.sol/index.d.ts +2 -0
  235. package/lib/types/IPriceFeed.sol/index.js +2 -0
  236. package/lib/types/IPriceOracle.sol/IPriceOracleV2.d.ts +166 -0
  237. package/lib/types/IPriceOracle.sol/IPriceOracleV2.js +2 -0
  238. package/lib/types/IPriceOracle.sol/IPriceOracleV2Events.d.ts +43 -0
  239. package/lib/types/IPriceOracle.sol/IPriceOracleV2Events.js +2 -0
  240. package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.d.ts → IPriceOracle.sol/IPriceOracleV2Exceptions.d.ts} +3 -3
  241. package/lib/types/IPriceOracle.sol/IPriceOracleV2Exceptions.js +2 -0
  242. package/lib/types/IPriceOracle.sol/IPriceOracleV2Ext.d.ts +182 -0
  243. package/lib/types/IPriceOracle.sol/IPriceOracleV2Ext.js +2 -0
  244. package/lib/types/IPriceOracle.sol/index.d.ts +4 -0
  245. package/lib/types/IPriceOracle.sol/index.js +2 -0
  246. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3.d.ts +272 -0
  247. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3.js +2 -0
  248. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3Events.d.ts +79 -0
  249. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3Events.js +2 -0
  250. package/lib/types/IPriceOracleV3.sol/index.d.ts +2 -0
  251. package/lib/types/IPriceOracleV3.sol/index.js +2 -0
  252. package/lib/types/IRouter.d.ts +11 -1
  253. package/lib/types/IRouterV3.d.ts +283 -0
  254. package/lib/types/IRouterV3.js +2 -0
  255. package/lib/types/IUniswapV2Adapter.sol/IUniswapV2Adapter.d.ts +10 -9
  256. package/lib/types/IUniswapV3Adapter.sol/IUniswapV3Adapter.d.ts +27 -21
  257. package/lib/types/IVotingContractV3.d.ts +74 -0
  258. package/lib/types/IVotingContractV3.js +2 -0
  259. package/lib/types/IWETH.d.ts +197 -0
  260. package/lib/types/IWETH.js +2 -0
  261. package/lib/types/IYearnV2Adapter.d.ts +22 -22
  262. package/lib/types/IZapper.d.ts +42 -47
  263. package/lib/types/IZapperRegister.d.ts +62 -0
  264. package/lib/types/IZapperRegister.js +2 -0
  265. package/lib/types/IwstETHV1Adapter.d.ts +17 -17
  266. package/lib/types/NumericArrayLib.d.ts +27 -0
  267. package/lib/types/NumericArrayLib.js +2 -0
  268. package/lib/types/RedstoneConstants.d.ts +27 -0
  269. package/lib/types/RedstoneConstants.js +2 -0
  270. package/lib/types/RedstoneConsumerBase.d.ts +84 -0
  271. package/lib/types/RedstoneConsumerBase.js +2 -0
  272. package/lib/types/RedstoneConsumerNumericBase.d.ts +84 -0
  273. package/lib/types/RedstoneConsumerNumericBase.js +2 -0
  274. package/lib/types/RedstoneDefaultsLib.d.ts +27 -0
  275. package/lib/types/RedstoneDefaultsLib.js +2 -0
  276. package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.d.ts → RedstonePriceFeed.sol/IRedstonePriceFeedEvents.d.ts} +11 -11
  277. package/lib/types/RedstonePriceFeed.sol/IRedstonePriceFeedEvents.js +2 -0
  278. package/lib/types/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions.d.ts +27 -0
  279. package/lib/types/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions.js +2 -0
  280. package/lib/types/RedstonePriceFeed.sol/RedstonePriceFeed.d.ts +279 -0
  281. package/lib/types/RedstonePriceFeed.sol/RedstonePriceFeed.js +2 -0
  282. package/lib/types/RedstonePriceFeed.sol/index.d.ts +3 -0
  283. package/lib/types/RedstonePriceFeed.sol/index.js +2 -0
  284. package/lib/types/SafeERC20.d.ts +27 -0
  285. package/lib/types/SafeERC20.js +2 -0
  286. package/lib/types/contracts/index.d.ts +2 -0
  287. package/lib/types/contracts/index.js +2 -0
  288. package/lib/types/contracts/interfaces/IGasPricer.d.ts +44 -0
  289. package/lib/types/contracts/interfaces/IGasPricer.js +2 -0
  290. package/lib/types/contracts/interfaces/index.d.ts +1 -0
  291. package/lib/types/contracts/interfaces/index.js +2 -0
  292. package/lib/types/factories/AddressProvider__factory.d.ts +112 -112
  293. package/lib/types/factories/AddressProvider__factory.js +120 -120
  294. package/lib/types/factories/Balances.sol/BalanceOps__factory.d.ts +4 -4
  295. package/lib/types/factories/Balances.sol/BalanceOps__factory.js +4 -4
  296. package/lib/types/factories/CalldataExtractor__factory.d.ts +87 -0
  297. package/lib/types/factories/CalldataExtractor__factory.js +127 -0
  298. package/lib/types/factories/Claimable__factory.d.ts +29 -29
  299. package/lib/types/factories/Claimable__factory.js +33 -33
  300. package/lib/types/factories/ERC20__factory.d.ts +239 -0
  301. package/lib/types/factories/ERC20__factory.js +328 -0
  302. package/lib/types/factories/Errors__factory.d.ts +100 -100
  303. package/lib/types/factories/Errors__factory.js +100 -100
  304. package/lib/types/factories/FarmAccounting__factory.d.ts +33 -0
  305. package/lib/types/factories/FarmAccounting__factory.js +57 -0
  306. package/lib/types/factories/{IWERC20Zapper__factory.d.ts → IAaveV2_LendingPoolAdapter__factory.d.ts} +96 -114
  307. package/lib/types/factories/{IWETHZapper__factory.js → IAaveV2_LendingPoolAdapter__factory.js} +105 -120
  308. package/lib/types/factories/IAaveV2_WrappedATokenAdapter__factory.d.ts +252 -0
  309. package/lib/types/factories/IAaveV2_WrappedATokenAdapter__factory.js +341 -0
  310. package/lib/types/factories/IAdapter__factory.d.ts +15 -15
  311. package/lib/types/factories/IAdapter__factory.js +15 -15
  312. package/lib/types/factories/IAddressProvider.sol/IAddressProviderEvents__factory.d.ts +7 -7
  313. package/lib/types/factories/IAddressProvider.sol/IAddressProviderEvents__factory.js +7 -7
  314. package/lib/types/factories/IAddressProvider.sol/IAddressProvider__factory.d.ts +48 -48
  315. package/lib/types/factories/IAddressProvider.sol/IAddressProvider__factory.js +52 -52
  316. package/lib/types/factories/IAddressProviderV3.sol/IAddressProviderV3Events__factory.d.ts +9 -9
  317. package/lib/types/factories/IAddressProviderV3.sol/IAddressProviderV3Events__factory.js +9 -9
  318. package/lib/types/factories/IAddressProviderV3.sol/IAddressProviderV3__factory.d.ts +37 -37
  319. package/lib/types/factories/IAddressProviderV3.sol/IAddressProviderV3__factory.js +42 -42
  320. package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributorEvents__factory.d.ts +25 -25
  321. package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributorEvents__factory.js +25 -25
  322. package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributor__factory.d.ts +71 -71
  323. package/lib/types/factories/IAirdropDistributor.sol/IAirdropDistributor__factory.js +85 -85
  324. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2VaultGetters__factory.d.ts +78 -0
  325. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2VaultGetters__factory.js +111 -0
  326. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2Vault__factory.d.ts +360 -0
  327. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2Vault__factory.js +475 -0
  328. package/lib/types/factories/IBalancerV2Vault.sol/index.d.ts +2 -0
  329. package/lib/types/factories/IBalancerV2Vault.sol/index.js +10 -0
  330. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents__factory.d.ts +23 -0
  331. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents__factory.js +38 -0
  332. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions__factory.d.ts +12 -0
  333. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions__factory.js} +5 -5
  334. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter__factory.d.ts +514 -0
  335. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter__factory.js +675 -0
  336. package/lib/types/factories/IBalancerV2VaultAdapter.sol/index.d.ts +3 -0
  337. package/lib/types/factories/IBalancerV2VaultAdapter.sol/index.js +12 -0
  338. package/lib/types/factories/IBaseRewardPool__factory.d.ts +114 -114
  339. package/lib/types/factories/IBaseRewardPool__factory.js +114 -114
  340. package/lib/types/factories/IBotListV3.sol/IBotListV3Events__factory.d.ts +103 -0
  341. package/lib/types/factories/IBotListV3.sol/IBotListV3Events__factory.js +138 -0
  342. package/lib/types/factories/IBotListV3.sol/IBotListV3__factory.d.ts +315 -0
  343. package/lib/types/factories/IBotListV3.sol/IBotListV3__factory.js +416 -0
  344. package/lib/types/factories/IBotListV3.sol/index.d.ts +2 -0
  345. package/lib/types/factories/IBotListV3.sol/index.js +10 -0
  346. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter__factory.d.ts +196 -0
  347. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter__factory.js +267 -0
  348. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions__factory.d.ts +16 -0
  349. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions__factory.js +30 -0
  350. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/index.d.ts +2 -0
  351. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/index.js +10 -0
  352. package/lib/types/factories/IContractsRegister.sol/IContractsRegisterEvents__factory.d.ts +28 -0
  353. package/lib/types/factories/IContractsRegister.sol/IContractsRegisterEvents__factory.js +45 -0
  354. package/lib/types/factories/IContractsRegister.sol/IContractsRegister__factory.d.ts +134 -0
  355. package/lib/types/factories/IContractsRegister.sol/IContractsRegister__factory.js +186 -0
  356. package/lib/types/factories/IContractsRegister.sol/index.d.ts +2 -0
  357. package/lib/types/factories/IContractsRegister.sol/index.js +10 -0
  358. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3Events__factory.d.ts +73 -0
  359. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3Events__factory.js +101 -0
  360. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3__factory.d.ts +427 -0
  361. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3__factory.js +556 -0
  362. package/lib/types/factories/IControllerTimelockV3.sol/index.d.ts +2 -0
  363. package/lib/types/factories/IControllerTimelockV3.sol/index.js +10 -0
  364. package/lib/types/factories/IConvexToken__factory.d.ts +89 -79
  365. package/lib/types/factories/IConvexToken__factory.js +99 -86
  366. package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.d.ts +103 -71
  367. package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.js +113 -71
  368. package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.d.ts +23 -0
  369. package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.js +38 -0
  370. package/lib/types/factories/{IConvexV1BoosterAdapter__factory.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.d.ts} +67 -44
  371. package/lib/types/factories/{IConvexV1BoosterAdapter__factory.js → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.js} +72 -43
  372. package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
  373. package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.js +10 -0
  374. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2Events__factory.d.ts +121 -121
  375. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2Events__factory.js +127 -127
  376. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2Exceptions__factory.d.ts +18 -18
  377. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2Exceptions__factory.js +18 -18
  378. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2__factory.d.ts +376 -376
  379. package/lib/types/factories/ICreditConfiguratorV2.sol/ICreditConfiguratorV2__factory.js +417 -417
  380. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.d.ts +118 -118
  381. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.js +127 -127
  382. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.d.ts +395 -395
  383. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.js +420 -420
  384. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Events__factory.d.ts +107 -107
  385. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Events__factory.js +118 -118
  386. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Exceptions__factory.d.ts +65 -65
  387. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Exceptions__factory.js +65 -65
  388. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.d.ts +23 -27
  389. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.js +23 -28
  390. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2V2__factory.d.ts +5 -5
  391. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2V2__factory.js +5 -5
  392. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2__factory.d.ts +601 -601
  393. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2__factory.js +749 -749
  394. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.d.ts +78 -83
  395. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.js +85 -91
  396. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.d.ts +281 -348
  397. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.js +372 -457
  398. package/lib/types/factories/ICreditFacadeV3Multicall__factory.d.ts +85 -81
  399. package/lib/types/factories/ICreditFacadeV3Multicall__factory.js +93 -89
  400. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2Events__factory.d.ts +11 -11
  401. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2Events__factory.js +12 -12
  402. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2Exceptions__factory.d.ts +26 -26
  403. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2Exceptions__factory.js +26 -26
  404. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2__factory.d.ts +252 -252
  405. package/lib/types/factories/ICreditManagerV2.sol/ICreditManagerV2__factory.js +272 -272
  406. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3Events__factory.d.ts +5 -5
  407. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3Events__factory.js +5 -5
  408. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.d.ts +398 -390
  409. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.js +436 -426
  410. package/lib/types/factories/ICurvePool_2.sol/ICurvePool2Assets__factory.d.ts +191 -191
  411. package/lib/types/factories/ICurvePool_2.sol/ICurvePool2Assets__factory.js +191 -191
  412. package/lib/types/factories/ICurvePool_3.sol/ICurvePool3Assets__factory.d.ts +191 -191
  413. package/lib/types/factories/ICurvePool_3.sol/ICurvePool3Assets__factory.js +191 -191
  414. package/lib/types/factories/ICurvePool_4.sol/ICurvePool4Assets__factory.d.ts +191 -191
  415. package/lib/types/factories/ICurvePool_4.sol/ICurvePool4Assets__factory.js +191 -191
  416. package/lib/types/factories/ICurvePool__factory.d.ts +159 -159
  417. package/lib/types/factories/ICurvePool__factory.js +159 -159
  418. package/lib/types/factories/ICurveV1Adapter__factory.d.ts +171 -229
  419. package/lib/types/factories/ICurveV1Adapter__factory.js +171 -248
  420. package/lib/types/factories/ICurveV1_2AssetsAdapter__factory.d.ts +189 -247
  421. package/lib/types/factories/ICurveV1_2AssetsAdapter__factory.js +189 -266
  422. package/lib/types/factories/ICurveV1_3AssetsAdapter__factory.d.ts +189 -247
  423. package/lib/types/factories/ICurveV1_3AssetsAdapter__factory.js +189 -266
  424. package/lib/types/factories/ICurveV1_4AssetsAdapter__factory.d.ts +189 -247
  425. package/lib/types/factories/ICurveV1_4AssetsAdapter__factory.js +189 -266
  426. package/lib/types/factories/IDaiLikePermit__factory.d.ts +46 -0
  427. package/lib/types/factories/IDaiLikePermit__factory.js +67 -0
  428. package/lib/types/factories/IDataCompressorV2_10__factory.d.ts +344 -394
  429. package/lib/types/factories/IDataCompressorV2_10__factory.js +346 -410
  430. package/lib/types/factories/IDataCompressorV3_00__factory.d.ts +650 -468
  431. package/lib/types/factories/IDataCompressorV3_00__factory.js +724 -492
  432. package/lib/types/factories/IDegenDistributor.sol/IDegenDistributorEvents__factory.d.ts +14 -14
  433. package/lib/types/factories/IDegenDistributor.sol/IDegenDistributorEvents__factory.js +14 -14
  434. package/lib/types/factories/IDegenDistributor.sol/IDegenDistributor__factory.d.ts +43 -43
  435. package/lib/types/factories/IDegenDistributor.sol/IDegenDistributor__factory.js +51 -51
  436. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Events__factory.d.ts +38 -0
  437. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Events__factory.js +58 -0
  438. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Exceptions__factory.d.ts +24 -0
  439. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Exceptions__factory.js +39 -0
  440. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3__factory.d.ts → IDegenNFTV2.sol/IDegenNFTV2__factory.d.ts} +248 -238
  441. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3__factory.js → IDegenNFTV2.sol/IDegenNFTV2__factory.js} +270 -253
  442. package/lib/types/factories/IDegenNFTV2.sol/index.d.ts +3 -0
  443. package/lib/types/factories/IDegenNFTV2.sol/index.js +12 -0
  444. package/lib/types/factories/IERC165__factory.d.ts +22 -0
  445. package/lib/types/factories/IERC165__factory.js +38 -0
  446. package/lib/types/factories/IERC20Metadata__factory.d.ts +76 -76
  447. package/lib/types/factories/IERC20Metadata__factory.js +86 -86
  448. package/lib/types/factories/IERC20Permit__factory.d.ts +16 -16
  449. package/lib/types/factories/IERC20Permit__factory.js +16 -16
  450. package/lib/types/factories/IERC20ZapperDeposits__factory.d.ts +120 -0
  451. package/lib/types/factories/IERC20ZapperDeposits__factory.js +165 -0
  452. package/lib/types/factories/IERC20__factory.d.ts +67 -67
  453. package/lib/types/factories/IERC20__factory.js +77 -77
  454. package/lib/types/factories/IERC4626Adapter__factory.d.ts +220 -0
  455. package/lib/types/factories/IERC4626Adapter__factory.js +297 -0
  456. package/lib/types/factories/IERC4626__factory.d.ts +198 -198
  457. package/lib/types/factories/IERC4626__factory.js +221 -221
  458. package/lib/types/factories/IERC721Metadata__factory.d.ts +262 -0
  459. package/lib/types/factories/IERC721Metadata__factory.js +349 -0
  460. package/lib/types/factories/IERC721__factory.d.ts +228 -0
  461. package/lib/types/factories/IERC721__factory.js +304 -0
  462. package/lib/types/factories/IETHZapperDeposits__factory.d.ts +40 -0
  463. package/lib/types/factories/IETHZapperDeposits__factory.js +62 -0
  464. package/lib/types/factories/IFarmingPool__factory.d.ts +299 -0
  465. package/lib/types/factories/IFarmingPool__factory.js +396 -0
  466. package/lib/types/factories/IGaugeV3.sol/IGaugeV3Events__factory.d.ts +118 -0
  467. package/lib/types/factories/IGaugeV3.sol/IGaugeV3Events__factory.js +157 -0
  468. package/lib/types/factories/IGaugeV3.sol/IGaugeV3__factory.d.ts +342 -0
  469. package/lib/types/factories/IGaugeV3.sol/IGaugeV3__factory.js +448 -0
  470. package/lib/types/factories/IGaugeV3.sol/index.d.ts +2 -0
  471. package/lib/types/factories/IGaugeV3.sol/index.js +10 -0
  472. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events__factory.d.ts → IGearStakingV3.sol/IGearStakingV3Events__factory.d.ts} +55 -85
  473. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events__factory.js → IGearStakingV3.sol/IGearStakingV3Events__factory.js} +58 -94
  474. package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.d.ts +504 -0
  475. package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.js +660 -0
  476. package/lib/types/factories/IGearStakingV3.sol/index.d.ts +2 -0
  477. package/lib/types/factories/IGearStakingV3.sol/index.js +10 -0
  478. package/lib/types/factories/IInterestRateModel__factory.d.ts +8 -8
  479. package/lib/types/factories/IInterestRateModel__factory.js +8 -8
  480. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedEvents__factory.d.ts +33 -0
  481. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedEvents__factory.js +51 -0
  482. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedExceptions__factory.d.ts +28 -0
  483. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedExceptions__factory.js +44 -0
  484. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeed__factory.d.ts +261 -0
  485. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeed__factory.js +344 -0
  486. package/lib/types/factories/ILPPriceFeed.sol/index.d.ts +3 -0
  487. package/lib/types/factories/ILPPriceFeed.sol/index.js +12 -0
  488. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.d.ts → ILidoV1Adapter__factory.d.ts} +44 -74
  489. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.js → ILidoV1Adapter__factory.js} +45 -83
  490. package/lib/types/factories/ILinearInterestRateModelV3__factory.d.ts +98 -0
  491. package/lib/types/factories/ILinearInterestRateModelV3__factory.js +136 -0
  492. package/lib/types/factories/IOffchainOracle__factory.d.ts +11 -11
  493. package/lib/types/factories/IOffchainOracle__factory.js +11 -11
  494. package/lib/types/factories/IPermit2__factory.d.ts +113 -0
  495. package/lib/types/factories/IPermit2__factory.js +155 -0
  496. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events__factory.d.ts +103 -0
  497. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events__factory.js +140 -0
  498. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3__factory.d.ts +441 -0
  499. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3__factory.js +580 -0
  500. package/lib/types/factories/IPoolQuotaKeeperV3.sol/index.d.ts +2 -0
  501. package/lib/types/factories/IPoolQuotaKeeperV3.sol/index.js +10 -0
  502. package/lib/types/factories/IPoolService.sol/IPoolServiceEvents__factory.d.ts +66 -66
  503. package/lib/types/factories/IPoolService.sol/IPoolServiceEvents__factory.js +72 -72
  504. package/lib/types/factories/IPoolService.sol/IPoolService__factory.d.ts +235 -235
  505. package/lib/types/factories/IPoolService.sol/IPoolService__factory.js +286 -286
  506. package/lib/types/factories/IPoolV3.sol/IPoolV3Events__factory.d.ts +65 -65
  507. package/lib/types/factories/IPoolV3.sol/IPoolV3Events__factory.js +68 -68
  508. package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.d.ts +574 -574
  509. package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.js +698 -698
  510. package/lib/types/factories/IPriceFeed.sol/IPriceFeed__factory.d.ts +84 -0
  511. package/lib/types/factories/IPriceFeed.sol/IPriceFeed__factory.js +117 -0
  512. package/lib/types/factories/IPriceFeed.sol/IUpdatablePriceFeed__factory.d.ts +104 -0
  513. package/lib/types/factories/IPriceFeed.sol/IUpdatablePriceFeed__factory.js +143 -0
  514. package/lib/types/factories/IPriceFeed.sol/index.d.ts +2 -0
  515. package/lib/types/factories/IPriceFeed.sol/index.js +10 -0
  516. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Events__factory.d.ts +23 -0
  517. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Events__factory.js +38 -0
  518. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Exceptions__factory.d.ts +20 -0
  519. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Exceptions__factory.js +34 -0
  520. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Ext__factory.d.ts +197 -0
  521. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Ext__factory.js +267 -0
  522. package/lib/types/factories/{IWETHZapper__factory.d.ts → IPriceOracle.sol/IPriceOracleV2__factory.d.ts} +114 -99
  523. package/lib/types/factories/{IWERC20Zapper__factory.js → IPriceOracle.sol/IPriceOracleV2__factory.js} +119 -110
  524. package/lib/types/factories/IPriceOracle.sol/index.d.ts +4 -0
  525. package/lib/types/factories/IPriceOracle.sol/index.js +14 -0
  526. package/lib/types/factories/IPriceOracleBase__factory.d.ts +27 -27
  527. package/lib/types/factories/IPriceOracleBase__factory.js +27 -27
  528. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3Events__factory.d.ts +78 -0
  529. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3Events__factory.js +106 -0
  530. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3__factory.d.ts +326 -0
  531. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3__factory.js +433 -0
  532. package/lib/types/factories/IPriceOracleV3.sol/index.d.ts +2 -0
  533. package/lib/types/factories/IPriceOracleV3.sol/index.js +10 -0
  534. package/lib/types/factories/IRouterV3__factory.d.ts +442 -0
  535. package/lib/types/factories/IRouterV3__factory.js +585 -0
  536. package/lib/types/factories/IRouter__factory.d.ts +168 -154
  537. package/lib/types/factories/IRouter__factory.js +186 -167
  538. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2AdapterEvents__factory.d.ts +8 -8
  539. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2AdapterEvents__factory.js +9 -9
  540. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2AdapterExceptions__factory.d.ts +2 -2
  541. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2AdapterExceptions__factory.js +2 -2
  542. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2Adapter__factory.d.ts +80 -76
  543. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2Adapter__factory.js +87 -82
  544. package/lib/types/factories/IUniswapV3.sol/ISwapRouter__factory.d.ts +50 -50
  545. package/lib/types/factories/IUniswapV3.sol/ISwapRouter__factory.js +50 -50
  546. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3AdapterEvents__factory.d.ts +10 -10
  547. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3AdapterEvents__factory.js +11 -11
  548. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3AdapterExceptions__factory.d.ts +2 -2
  549. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3AdapterExceptions__factory.js +2 -2
  550. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3Adapter__factory.d.ts +142 -134
  551. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3Adapter__factory.js +151 -141
  552. package/lib/types/factories/IVersion__factory.d.ts +3 -3
  553. package/lib/types/factories/IVersion__factory.js +3 -3
  554. package/lib/types/factories/IVotingContractV3__factory.d.ts +44 -0
  555. package/lib/types/factories/IVotingContractV3__factory.js +65 -0
  556. package/lib/types/factories/IWETHGateway__factory.d.ts +14 -14
  557. package/lib/types/factories/IWETHGateway__factory.js +14 -14
  558. package/lib/types/factories/IWETH__factory.d.ts +194 -0
  559. package/lib/types/factories/IWETH__factory.js +260 -0
  560. package/lib/types/factories/IYVault__factory.d.ts +112 -112
  561. package/lib/types/factories/IYVault__factory.js +122 -122
  562. package/lib/types/factories/IYearnV2Adapter__factory.d.ts +76 -68
  563. package/lib/types/factories/IYearnV2Adapter__factory.js +82 -70
  564. package/lib/types/factories/IZapperRegister__factory.d.ts +42 -0
  565. package/lib/types/factories/IZapperRegister__factory.js +64 -0
  566. package/lib/types/factories/IZapper__factory.d.ts +40 -48
  567. package/lib/types/factories/IZapper__factory.js +40 -50
  568. package/lib/types/factories/IstETH.sol/IstETHGetters__factory.d.ts +97 -97
  569. package/lib/types/factories/IstETH.sol/IstETHGetters__factory.js +107 -107
  570. package/lib/types/factories/IstETH.sol/IstETH__factory.d.ts +101 -101
  571. package/lib/types/factories/IstETH.sol/IstETH__factory.js +111 -111
  572. package/lib/types/factories/IwstETH.sol/IwstETHGetters__factory.d.ts +93 -93
  573. package/lib/types/factories/IwstETH.sol/IwstETHGetters__factory.js +103 -103
  574. package/lib/types/factories/IwstETH.sol/IwstETH__factory.d.ts +101 -101
  575. package/lib/types/factories/IwstETH.sol/IwstETH__factory.js +111 -111
  576. package/lib/types/factories/IwstETHGateway.sol/IwstETHGateWay__factory.d.ts +14 -14
  577. package/lib/types/factories/IwstETHGateway.sol/IwstETHGateWay__factory.js +15 -15
  578. package/lib/types/factories/IwstETHV1Adapter__factory.d.ts +52 -44
  579. package/lib/types/factories/IwstETHV1Adapter__factory.js +56 -44
  580. package/lib/types/factories/NumericArrayLib__factory.d.ts +25 -0
  581. package/lib/types/factories/NumericArrayLib__factory.js +47 -0
  582. package/lib/types/factories/Ownable__factory.d.ts +23 -23
  583. package/lib/types/factories/Ownable__factory.js +27 -27
  584. package/lib/types/factories/RedstoneConstants__factory.d.ts +65 -0
  585. package/lib/types/factories/RedstoneConstants__factory.js +99 -0
  586. package/lib/types/factories/RedstoneConsumerBase__factory.d.ts +164 -0
  587. package/lib/types/factories/RedstoneConsumerBase__factory.js +223 -0
  588. package/lib/types/factories/RedstoneConsumerNumericBase__factory.d.ts +164 -0
  589. package/lib/types/factories/RedstoneConsumerNumericBase__factory.js +223 -0
  590. package/lib/types/factories/RedstoneDefaultsLib__factory.d.ts +45 -0
  591. package/lib/types/factories/RedstoneDefaultsLib__factory.js +74 -0
  592. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.d.ts → RedstonePriceFeed.sol/IRedstonePriceFeedEvents__factory.d.ts} +9 -9
  593. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.js → RedstonePriceFeed.sol/IRedstonePriceFeedEvents__factory.js} +8 -8
  594. package/lib/types/factories/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions__factory.d.ts +28 -0
  595. package/lib/types/factories/RedstonePriceFeed.sol/IRedstonePriceFeedExceptions__factory.js +44 -0
  596. package/lib/types/factories/RedstonePriceFeed.sol/RedstonePriceFeed__factory.d.ts +443 -0
  597. package/lib/types/factories/RedstonePriceFeed.sol/RedstonePriceFeed__factory.js +589 -0
  598. package/lib/types/factories/RedstonePriceFeed.sol/index.d.ts +3 -0
  599. package/lib/types/factories/RedstonePriceFeed.sol/index.js +12 -0
  600. package/lib/types/factories/SafeERC20__factory.d.ts +49 -0
  601. package/lib/types/factories/SafeERC20__factory.js +77 -0
  602. package/lib/types/factories/contracts/index.d.ts +1 -0
  603. package/lib/types/factories/contracts/index.js +30 -0
  604. package/lib/types/factories/contracts/interfaces/IGasPricer__factory.d.ts +22 -0
  605. package/lib/types/factories/contracts/interfaces/IGasPricer__factory.js +38 -0
  606. package/lib/types/factories/contracts/interfaces/index.d.ts +1 -0
  607. package/lib/types/factories/contracts/interfaces/index.js +8 -0
  608. package/lib/types/factories/index.d.ts +43 -5
  609. package/lib/types/factories/index.js +71 -10
  610. package/lib/types/index.d.ts +164 -20
  611. package/lib/types/index.js +131 -16
  612. package/lib/utils/formatter.d.ts +1 -4
  613. package/lib/utils/formatter.js +3 -69
  614. package/lib/utils/math.d.ts +2 -0
  615. package/lib/utils/math.js +2 -0
  616. package/lib/utils/types.d.ts +1 -0
  617. package/lib/watchers/creditAccountWatcher.d.ts +3 -2
  618. package/lib/watchers/creditAccountWatcher.js +19 -13
  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/ILidoV1Adapter.sol/ILidoV1Adapter.js → payload/gauge.js} +0 -0
  641. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.js → CalldataExtractor.js} +0 -0
  642. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.js → ERC20.js} +0 -0
  643. /package/lib/types/{ILidoV1Adapter.sol/index.js → FarmAccounting.js} +0 -0
  644. /package/lib/types/{IWERC20Zapper.js → IAaveV2_LendingPoolAdapter.js} +0 -0
  645. /package/lib/types/{IWETHZapper.js → IAaveV2_WrappedATokenAdapter.js} +0 -0
  646. /package/lib/types/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3.js → IBalancerV2Vault.sol/IBalancerV2Vault.js} +0 -0
  647. /package/lib/types/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events.js → IBalancerV2Vault.sol/IBalancerV2VaultGetters.js} +0 -0
  648. /package/lib/types/{IWithdrawalManagerV3.sol → IBalancerV2Vault.sol}/index.js +0 -0
@@ -27,6 +27,18 @@ const caWithoutLP = {
27
27
  debt: (0, formatter_1.toBN)("54780", sdk_gov_1.decimals.DAI),
28
28
  borrowRate: 7712,
29
29
  underlyingToken: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI.toLowerCase(),
30
+ quotas: {
31
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
32
+ balance: (0, formatter_1.toBN)("173811.830000", sdk_gov_1.decimals.WETH),
33
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI.toLowerCase(),
34
+ },
35
+ },
36
+ rates: {
37
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
38
+ rate: 38434,
39
+ isActive: true,
40
+ },
41
+ },
30
42
  };
31
43
  const caWithLP = {
32
44
  assets: [
@@ -43,6 +55,18 @@ const caWithLP = {
43
55
  debt: (0, formatter_1.toBN)("90.000000000000000000", sdk_gov_1.decimals.WETH),
44
56
  borrowRate: 5736,
45
57
  underlyingToken: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase(),
58
+ quotas: {
59
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH.toLowerCase()]: {
60
+ balance: (0, formatter_1.toBN)(String((1703.87588096 * 119.9999999999999) / 1738.1183), sdk_gov_1.decimals.WETH),
61
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH.toLowerCase(),
62
+ },
63
+ },
64
+ rates: {
65
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH.toLowerCase()]: {
66
+ rate: 38434,
67
+ isActive: true,
68
+ },
69
+ },
46
70
  };
47
71
  describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
48
72
  it("overall APY calculation for caWithoutLP is correct", () => {
@@ -50,32 +74,41 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
50
74
  caAssets: caWithoutLP.assets,
51
75
  totalValue: caWithoutLP.totalValue,
52
76
  debt: caWithoutLP.debt,
53
- borrowRate: caWithoutLP.borrowRate,
77
+ baseRateWithFee: caWithoutLP.borrowRate,
54
78
  underlyingToken: caWithoutLP.underlyingToken,
79
+ quotaRates: {},
80
+ quotas: {},
81
+ feeInterest: 0,
55
82
  lpAPY,
56
83
  prices,
57
84
  });
58
- (0, chai_1.expect)(result).to.be.eq(-6.94841);
85
+ (0, chai_1.expect)(result).to.be.eq(-69484n);
59
86
  });
60
87
  it("overall APY calculation for caWithLP is correct", () => {
61
88
  const result = creditAccount_1.CreditAccountData.calcOverallAPY({
62
89
  caAssets: caWithLP.assets,
63
90
  totalValue: caWithLP.totalValue,
64
91
  debt: caWithLP.debt,
65
- borrowRate: caWithLP.borrowRate,
92
+ baseRateWithFee: caWithLP.borrowRate,
66
93
  underlyingToken: caWithLP.underlyingToken,
94
+ quotaRates: {},
95
+ quotas: {},
96
+ feeInterest: 0,
67
97
  lpAPY,
68
98
  prices,
69
99
  });
70
- (0, chai_1.expect)(result).to.be.eq(14.4919);
100
+ (0, chai_1.expect)(result).to.be.eq(144919n);
71
101
  });
72
102
  it("overall APY is undefined when !lpAPY", () => {
73
103
  const result = creditAccount_1.CreditAccountData.calcOverallAPY({
74
104
  caAssets: caWithLP.assets,
75
105
  totalValue: caWithLP.totalValue,
76
106
  debt: caWithLP.debt,
77
- borrowRate: caWithLP.borrowRate,
107
+ baseRateWithFee: caWithLP.borrowRate,
78
108
  underlyingToken: caWithLP.underlyingToken,
109
+ quotaRates: {},
110
+ quotas: {},
111
+ feeInterest: 0,
79
112
  lpAPY: undefined,
80
113
  prices,
81
114
  });
@@ -86,8 +119,11 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
86
119
  caAssets: caWithLP.assets,
87
120
  totalValue: undefined,
88
121
  debt: caWithLP.debt,
89
- borrowRate: caWithLP.borrowRate,
122
+ baseRateWithFee: caWithLP.borrowRate,
90
123
  underlyingToken: caWithLP.underlyingToken,
124
+ quotaRates: {},
125
+ quotas: {},
126
+ feeInterest: 0,
91
127
  lpAPY,
92
128
  prices,
93
129
  });
@@ -98,8 +134,11 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
98
134
  caAssets: caWithLP.assets,
99
135
  totalValue: caWithLP.totalValue,
100
136
  debt: undefined,
101
- borrowRate: caWithLP.borrowRate,
137
+ baseRateWithFee: caWithLP.borrowRate,
102
138
  underlyingToken: caWithLP.underlyingToken,
139
+ quotaRates: {},
140
+ quotas: {},
141
+ feeInterest: 0,
103
142
  lpAPY,
104
143
  prices,
105
144
  });
@@ -110,13 +149,51 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
110
149
  caAssets: caWithLP.assets,
111
150
  totalValue: 0n,
112
151
  debt: undefined,
113
- borrowRate: caWithLP.borrowRate,
152
+ baseRateWithFee: caWithLP.borrowRate,
114
153
  underlyingToken: caWithLP.underlyingToken,
154
+ quotaRates: {},
155
+ quotas: {},
156
+ feeInterest: 0,
115
157
  lpAPY,
116
158
  prices,
117
159
  });
118
160
  (0, chai_1.expect)(result).to.be.eq(undefined);
119
161
  });
162
+ it("overall APY calculation for caWithLP with sufficient quota is correct", () => {
163
+ const result = creditAccount_1.CreditAccountData.calcOverallAPY({
164
+ caAssets: caWithLP.assets,
165
+ totalValue: caWithLP.totalValue,
166
+ debt: caWithLP.debt,
167
+ baseRateWithFee: caWithLP.borrowRate,
168
+ underlyingToken: caWithLP.underlyingToken,
169
+ quotaRates: caWithLP.rates,
170
+ quotas: caWithLP.quotas,
171
+ feeInterest: 0,
172
+ lpAPY,
173
+ prices,
174
+ });
175
+ (0, chai_1.expect)(result).to.be.eq(-18680n);
176
+ });
177
+ it("overall APY calculation for caWithLP with insufficient quota is correct", () => {
178
+ const result = creditAccount_1.CreditAccountData.calcOverallAPY({
179
+ caAssets: caWithLP.assets,
180
+ totalValue: caWithLP.totalValue,
181
+ debt: caWithLP.debt,
182
+ baseRateWithFee: caWithLP.borrowRate,
183
+ underlyingToken: caWithLP.underlyingToken,
184
+ quotaRates: caWithLP.rates,
185
+ quotas: {
186
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH.toLowerCase()]: {
187
+ balance: 0n,
188
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH.toLowerCase(),
189
+ },
190
+ },
191
+ feeInterest: 0,
192
+ lpAPY,
193
+ prices,
194
+ });
195
+ (0, chai_1.expect)(result).to.be.eq(144919n);
196
+ });
120
197
  });
121
198
  describe("CreditAccount calcMaxIncreaseBorrow test", () => {
122
199
  it("health max increase borrow is zero if hf < 1", () => {
@@ -152,27 +229,42 @@ const defaultCA = {
152
229
  healthFactor: 10244,
153
230
  underlyingToken: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI.toLowerCase(),
154
231
  underlyingDecimals: sdk_gov_1.decimals.DAI,
232
+ quotas: {
233
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
234
+ balance: (0, formatter_1.toBN)(String(1750 * 10), sdk_gov_1.decimals.DAI),
235
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase(),
236
+ },
237
+ },
238
+ quotasInfo: {
239
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
240
+ isActive: true,
241
+ },
242
+ },
155
243
  };
156
- describe("CreditManager calcHealthFactor test", () => {
157
- it("health factor calculation is calculated correctly", () => {
244
+ describe("CreditAccount calcHealthFactor test", () => {
245
+ it("health factor is calculated correctly", () => {
158
246
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
247
+ quotas: {},
248
+ quotasInfo: {},
159
249
  assets: defaultCA.assets,
160
250
  prices,
161
251
  liquidationThresholds,
162
252
  underlyingToken: defaultCA.underlyingToken,
163
- borrowed: defaultCA.debt,
253
+ debt: defaultCA.debt,
164
254
  });
165
255
  (0, chai_1.expect)(result).to.be.eq(defaultCA.healthFactor);
166
256
  });
167
257
  it("health factor calculation has no division by zero error", () => {
168
258
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
259
+ quotas: {},
260
+ quotasInfo: {},
169
261
  assets: [],
170
262
  prices: {},
171
263
  liquidationThresholds: {},
172
264
  underlyingToken: "",
173
- borrowed: 0n,
265
+ debt: 0n,
174
266
  });
175
- (0, chai_1.expect)(result).to.be.eq(0);
267
+ (0, chai_1.expect)(result).to.be.eq(65535);
176
268
  });
177
269
  it("health factor after add collateral is calculated correctly", () => {
178
270
  const collateral = {
@@ -181,11 +273,13 @@ describe("CreditManager calcHealthFactor test", () => {
181
273
  };
182
274
  const afterAdd = assets_1.AssetUtils.sumAssets(defaultCA.assets, [collateral]);
183
275
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
276
+ quotas: {},
277
+ quotasInfo: {},
184
278
  assets: afterAdd,
185
279
  prices,
186
280
  liquidationThresholds,
187
281
  underlyingToken: defaultCA.underlyingToken,
188
- borrowed: defaultCA.debt,
282
+ debt: defaultCA.debt,
189
283
  });
190
284
  (0, chai_1.expect)(result).to.be.eq(11188);
191
285
  });
@@ -199,11 +293,13 @@ describe("CreditManager calcHealthFactor test", () => {
199
293
  debtDecrease,
200
294
  ]);
201
295
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
296
+ quotas: {},
297
+ quotasInfo: {},
202
298
  assets: afterDecrease,
203
299
  prices,
204
300
  liquidationThresholds,
205
301
  underlyingToken: defaultCA.underlyingToken,
206
- borrowed: defaultCA.debt - amountDecrease,
302
+ debt: defaultCA.debt - amountDecrease,
207
303
  });
208
304
  (0, chai_1.expect)(result).to.be.eq(10308);
209
305
  });
@@ -217,11 +313,13 @@ describe("CreditManager calcHealthFactor test", () => {
217
313
  debtIncrease,
218
314
  ]);
219
315
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
316
+ quotas: {},
317
+ quotasInfo: {},
220
318
  assets: afterIncrease,
221
319
  prices,
222
320
  liquidationThresholds,
223
321
  underlyingToken: defaultCA.underlyingToken,
224
- borrowed: defaultCA.debt + amountIncrease,
322
+ debt: defaultCA.debt + amountIncrease,
225
323
  });
226
324
  (0, chai_1.expect)(result).to.be.eq(10137);
227
325
  });
@@ -240,12 +338,987 @@ describe("CreditManager calcHealthFactor test", () => {
240
338
  const afterSub = assets_1.AssetUtils.subAssets(defaultCA.assets, [swapAsset]);
241
339
  const afterSwap = assets_1.AssetUtils.sumAssets(afterSub, [getAsset]);
242
340
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
341
+ quotas: {},
342
+ quotasInfo: {},
243
343
  assets: afterSwap,
244
344
  prices,
245
345
  liquidationThresholds,
246
346
  underlyingToken: defaultCA.underlyingToken,
247
- borrowed: defaultCA.debt,
347
+ debt: defaultCA.debt,
248
348
  });
249
349
  (0, chai_1.expect)(result).to.be.eq(9444);
250
350
  });
351
+ it("health factor with sufficient quotas is calculated correctly", () => {
352
+ const result = creditAccount_1.CreditAccountData.calcHealthFactor({
353
+ quotas: defaultCA.quotas,
354
+ quotasInfo: defaultCA.quotasInfo,
355
+ assets: defaultCA.assets,
356
+ prices,
357
+ liquidationThresholds,
358
+ underlyingToken: defaultCA.underlyingToken,
359
+ debt: defaultCA.debt,
360
+ });
361
+ (0, chai_1.expect)(result).to.be.eq(defaultCA.healthFactor);
362
+ });
363
+ it("health factor with insufficient quotas is calculated correctly", () => {
364
+ const result = creditAccount_1.CreditAccountData.calcHealthFactor({
365
+ quotas: {
366
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
367
+ balance: 0n,
368
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase(),
369
+ },
370
+ },
371
+ quotasInfo: defaultCA.quotasInfo,
372
+ assets: defaultCA.assets,
373
+ prices,
374
+ liquidationThresholds,
375
+ underlyingToken: defaultCA.underlyingToken,
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,
393
+ });
394
+ (0, chai_1.expect)(result).to.be.eq(9300);
395
+ });
396
+ });
397
+ const cmQuotas = {
398
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
399
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
400
+ isActive: true,
401
+ },
402
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
403
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
404
+ isActive: true,
405
+ },
406
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
407
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
408
+ isActive: true,
409
+ },
410
+ };
411
+ const caQuota = {
412
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
413
+ quota: 5n,
414
+ },
415
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
416
+ quota: 10n,
417
+ },
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;
426
+ describe("CreditAccount calcQuotaUpdate test", () => {
427
+ it("open account should buy quota", () => {
428
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
429
+ maxDebt: HUGE_MAX_DEBT,
430
+ quotaReserve: QUOTA_RESERVE,
431
+ quotas: cmQuotas,
432
+ initialQuotas: {},
433
+ assetsAfterUpdate: {
434
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
435
+ amountInTarget: 10n,
436
+ balance: 0n,
437
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
438
+ },
439
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
440
+ amountInTarget: 20n,
441
+ balance: 0n,
442
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
443
+ },
444
+ },
445
+ allowedToObtain: {
446
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
447
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
448
+ },
449
+ allowedToSpend: {},
450
+ liquidationThresholds: DEFAULT_LT,
451
+ });
452
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
453
+ {
454
+ balance: 10n,
455
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
456
+ },
457
+ {
458
+ balance: 20n,
459
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
460
+ },
461
+ ]);
462
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
463
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
464
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
465
+ balance: 10n,
466
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
467
+ },
468
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
469
+ balance: 20n,
470
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
471
+ },
472
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
473
+ balance: 0n,
474
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
475
+ },
476
+ });
477
+ });
478
+ it("add collateral should buy quota", () => {
479
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
480
+ maxDebt: HUGE_MAX_DEBT,
481
+ quotaReserve: QUOTA_RESERVE,
482
+ quotas: cmQuotas,
483
+ initialQuotas: caQuota,
484
+ assetsAfterUpdate: {
485
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
486
+ amountInTarget: 10n,
487
+ balance: 0n,
488
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
489
+ },
490
+ },
491
+ allowedToObtain: {
492
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {},
493
+ },
494
+ allowedToSpend: {},
495
+ liquidationThresholds: DEFAULT_LT,
496
+ });
497
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
498
+ {
499
+ balance: 10n,
500
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
501
+ },
502
+ ]);
503
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
504
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
505
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
506
+ balance: 5n,
507
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
508
+ },
509
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
510
+ balance: 10n,
511
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
512
+ },
513
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
514
+ balance: 10n,
515
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
516
+ },
517
+ });
518
+ });
519
+ it("add collateral should add additional quota", () => {
520
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
521
+ maxDebt: HUGE_MAX_DEBT,
522
+ quotaReserve: QUOTA_RESERVE,
523
+ quotas: cmQuotas,
524
+ initialQuotas: caQuota,
525
+ assetsAfterUpdate: {
526
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
527
+ amountInTarget: 10n,
528
+ balance: 0n,
529
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
530
+ },
531
+ },
532
+ allowedToObtain: {
533
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
534
+ },
535
+ allowedToSpend: {},
536
+ liquidationThresholds: DEFAULT_LT,
537
+ });
538
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
539
+ {
540
+ balance: 5n,
541
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
542
+ },
543
+ ]);
544
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
545
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
546
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
547
+ balance: 10n,
548
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
549
+ },
550
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
551
+ balance: 10n,
552
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
553
+ },
554
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
555
+ balance: 0n,
556
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
557
+ },
558
+ });
559
+ });
560
+ it("add collateral shouldn't add additional quota", () => {
561
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
562
+ maxDebt: HUGE_MAX_DEBT,
563
+ quotaReserve: QUOTA_RESERVE,
564
+ quotas: cmQuotas,
565
+ initialQuotas: caQuota,
566
+ assetsAfterUpdate: {
567
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
568
+ amountInTarget: 10n,
569
+ balance: 0n,
570
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
571
+ },
572
+ },
573
+ allowedToObtain: {
574
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
575
+ },
576
+ allowedToSpend: {},
577
+ liquidationThresholds: DEFAULT_LT,
578
+ });
579
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
580
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
581
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
582
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
583
+ balance: 5n,
584
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
585
+ },
586
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
587
+ balance: 10n,
588
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
589
+ },
590
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
591
+ balance: 0n,
592
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
593
+ },
594
+ });
595
+ });
596
+ it("swap should buy quota", () => {
597
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
598
+ maxDebt: HUGE_MAX_DEBT,
599
+ quotaReserve: QUOTA_RESERVE,
600
+ quotas: cmQuotas,
601
+ initialQuotas: caQuota,
602
+ assetsAfterUpdate: {
603
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
604
+ amountInTarget: 10n,
605
+ balance: 0n,
606
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
607
+ },
608
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
609
+ amountInTarget: 0n,
610
+ balance: 0n,
611
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
612
+ },
613
+ },
614
+ allowedToObtain: {
615
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {},
616
+ },
617
+ allowedToSpend: { [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {} },
618
+ liquidationThresholds: DEFAULT_LT,
619
+ });
620
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
621
+ {
622
+ balance: 10n,
623
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
624
+ },
625
+ ]);
626
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
627
+ { balance: -10n, token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH },
628
+ ]);
629
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
630
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
631
+ balance: 5n,
632
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
633
+ },
634
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
635
+ balance: 0n,
636
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
637
+ },
638
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
639
+ balance: 10n,
640
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
641
+ },
642
+ });
643
+ });
644
+ it("swap should buy additional quota", () => {
645
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
646
+ maxDebt: HUGE_MAX_DEBT,
647
+ quotaReserve: QUOTA_RESERVE,
648
+ quotas: cmQuotas,
649
+ initialQuotas: caQuota,
650
+ assetsAfterUpdate: {
651
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
652
+ amountInTarget: 10n,
653
+ balance: 0n,
654
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
655
+ },
656
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
657
+ amountInTarget: 0n,
658
+ balance: 0n,
659
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
660
+ },
661
+ },
662
+ allowedToObtain: {
663
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
664
+ },
665
+ allowedToSpend: {
666
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
667
+ },
668
+ liquidationThresholds: DEFAULT_LT,
669
+ });
670
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
671
+ {
672
+ balance: 5n,
673
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
674
+ },
675
+ ]);
676
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
677
+ {
678
+ balance: -10n,
679
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
680
+ },
681
+ ]);
682
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
683
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
684
+ balance: 10n,
685
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
686
+ },
687
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
688
+ balance: 0n,
689
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
690
+ },
691
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
692
+ balance: 0n,
693
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
694
+ },
695
+ });
696
+ });
697
+ it("swap shouldn't buy additional quota", () => {
698
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
699
+ maxDebt: HUGE_MAX_DEBT,
700
+ quotaReserve: QUOTA_RESERVE,
701
+ quotas: cmQuotas,
702
+ initialQuotas: caQuota,
703
+ assetsAfterUpdate: {
704
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
705
+ amountInTarget: 10n,
706
+ balance: 0n,
707
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
708
+ },
709
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
710
+ amountInTarget: 0n,
711
+ balance: 0n,
712
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
713
+ },
714
+ },
715
+ allowedToObtain: {
716
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
717
+ },
718
+ allowedToSpend: { [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {} },
719
+ liquidationThresholds: DEFAULT_LT,
720
+ });
721
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
722
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
723
+ {
724
+ balance: -5n,
725
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
726
+ },
727
+ ]);
728
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
729
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
730
+ balance: 0n,
731
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
732
+ },
733
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
734
+ balance: 10n,
735
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
736
+ },
737
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
738
+ balance: 0n,
739
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
740
+ },
741
+ });
742
+ });
743
+ it("shouldn't change quota if disallowed", () => {
744
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
745
+ maxDebt: HUGE_MAX_DEBT,
746
+ quotaReserve: QUOTA_RESERVE,
747
+ quotas: cmQuotas,
748
+ initialQuotas: caQuota,
749
+ assetsAfterUpdate: {
750
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
751
+ amountInTarget: 10n,
752
+ balance: 0n,
753
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
754
+ },
755
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
756
+ amountInTarget: 0n,
757
+ balance: 0n,
758
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
759
+ },
760
+ },
761
+ allowedToObtain: {},
762
+ allowedToSpend: {},
763
+ liquidationThresholds: DEFAULT_LT,
764
+ });
765
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
766
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
767
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
768
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
769
+ balance: 5n,
770
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
771
+ },
772
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
773
+ balance: 10n,
774
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
775
+ },
776
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
777
+ balance: 0n,
778
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
779
+ },
780
+ });
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
+ });
251
1324
  });