@gearbox-protocol/sdk 3.0.0-next.11 → 3.0.0-next.110

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