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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (465) hide show
  1. package/contracts/index.sol +29 -4
  2. package/lib/apy/curveAPY.js +2 -1
  3. package/lib/apy/index.d.ts +2 -2
  4. package/lib/apy/yearnAPY.js +1 -1
  5. package/lib/core/assets.d.ts +4 -4
  6. package/lib/core/assets.js +28 -17
  7. package/lib/core/creditAccount.d.ts +32 -8
  8. package/lib/core/creditAccount.js +101 -44
  9. package/lib/core/creditAccount.spec.js +693 -10
  10. package/lib/core/creditManager.d.ts +12 -3
  11. package/lib/core/creditManager.js +43 -10
  12. package/lib/core/events.js +14 -14
  13. package/lib/core/gauge.d.ts +26 -0
  14. package/lib/core/gauge.js +63 -0
  15. package/lib/core/gaugeMath.d.ts +40 -0
  16. package/lib/core/gaugeMath.js +108 -0
  17. package/lib/core/gaugeMath.spec.d.ts +1 -0
  18. package/lib/core/gaugeMath.spec.js +388 -0
  19. package/lib/core/{pool/data.d.ts → pool.d.ts} +17 -10
  20. package/lib/core/{pool/data.js → pool.js} +66 -24
  21. package/lib/core/strategy.d.ts +4 -3
  22. package/lib/core/strategy.js +15 -14
  23. package/lib/core/strategy.spec.js +68 -3
  24. package/lib/core/trade.d.ts +12 -29
  25. package/lib/core/trade.js +33 -82
  26. package/lib/core/transactions.d.ts +65 -3
  27. package/lib/core/transactions.js +162 -105
  28. package/lib/index.d.ts +3 -0
  29. package/lib/index.js +3 -0
  30. package/lib/parsers/abstractParser.js +1 -2
  31. package/lib/parsers/convexBaseRewardPoolAdapterParser.js +10 -8
  32. package/lib/parsers/convexBaseRewardPoolAdapterParser.spec.js +9 -6
  33. package/lib/parsers/convexBoosterAdapterParser.js +6 -6
  34. package/lib/parsers/convexBoosterAdapterParser.spec.js +4 -4
  35. package/lib/parsers/creditFacadeParser.d.ts +2 -1
  36. package/lib/parsers/creditFacadeParser.js +40 -5
  37. package/lib/parsers/creditFacadeParser.spec.js +3 -4
  38. package/lib/parsers/curveAdapterParser.js +10 -11
  39. package/lib/parsers/curveAdapterParser.spec.js +6 -2
  40. package/lib/parsers/lidoAdapterParser.js +3 -2
  41. package/lib/parsers/lidoAdapterParser.spec.js +2 -2
  42. package/lib/parsers/txParser.d.ts +1 -1
  43. package/lib/parsers/txParser.js +9 -3
  44. package/lib/parsers/uniV2AdapterParser.js +5 -4
  45. package/lib/parsers/uniV2AdapterParser.spec.js +3 -2
  46. package/lib/parsers/uniV3AdapterParser.js +9 -7
  47. package/lib/parsers/uniV3AdapterParser.spec.js +3 -2
  48. package/lib/parsers/wstETHAdapterParser.js +6 -4
  49. package/lib/parsers/wstETHAdapterParser.spec.js +4 -4
  50. package/lib/parsers/yearnAdapterParser.spec.js +4 -4
  51. package/lib/parsers/yearnV2AdapterParser.js +13 -3
  52. package/lib/pathfinder/core.d.ts +8 -9
  53. package/lib/pathfinder/pathOptions.d.ts +2 -1
  54. package/lib/pathfinder/pathOptions.js +20 -1
  55. package/lib/pathfinder/pathOptions.spec.js +2 -2
  56. package/lib/pathfinder/pathfinder.d.ts +38 -10
  57. package/lib/pathfinder/pathfinder.js +53 -34
  58. package/lib/pathfinder/pathfinder.spec.js +7 -3
  59. package/lib/payload/creditAccount.d.ts +3 -4
  60. package/lib/payload/gauge.d.ts +12 -0
  61. package/lib/payload/pool.d.ts +6 -1
  62. package/lib/types/IAaveV2_LendingPoolAdapter.d.ts +171 -0
  63. package/lib/types/IAaveV2_WrappedATokenAdapter.d.ts +290 -0
  64. package/lib/types/IBalancerV2Vault.sol/IBalancerV2Vault.d.ts +308 -0
  65. package/lib/types/IBalancerV2Vault.sol/IBalancerV2VaultGetters.d.ts +112 -0
  66. package/lib/types/IBalancerV2Vault.sol/index.d.ts +2 -0
  67. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter.d.ts +466 -0
  68. package/lib/types/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents.d.ts +43 -0
  69. package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.d.ts → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions.d.ts} +6 -18
  70. package/lib/types/IBalancerV2VaultAdapter.sol/index.d.ts +3 -0
  71. package/lib/types/IBotListV3.sol/IBotListV3.d.ts +286 -0
  72. package/lib/types/IBotListV3.sol/IBotListV3Events.d.ts +103 -0
  73. package/lib/types/IBotListV3.sol/index.d.ts +2 -0
  74. package/lib/types/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter.d.ts +216 -0
  75. package/lib/types/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions.d.ts +27 -0
  76. package/lib/types/ICompoundV2_CTokenAdapter.sol/index.d.ts +2 -0
  77. package/lib/types/IContractsRegister.sol/IContractsRegister.d.ts +128 -0
  78. package/lib/types/IContractsRegister.sol/IContractsRegisterEvents.d.ts +50 -0
  79. package/lib/types/IContractsRegister.sol/index.d.ts +2 -0
  80. package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3.d.ts +504 -0
  81. package/lib/types/IControllerTimelockV3.sol/IControllerTimelockV3Events.d.ts +82 -0
  82. package/lib/types/IControllerTimelockV3.sol/index.d.ts +2 -0
  83. package/lib/types/IConvexToken.d.ts +9 -1
  84. package/lib/types/IConvexV1BaseRewardPoolAdapter.d.ts +46 -30
  85. package/lib/types/{IConvexV1BoosterAdapter.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter.d.ts} +40 -21
  86. package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents.d.ts +43 -0
  87. package/lib/types/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents.js +2 -0
  88. package/lib/types/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
  89. package/lib/types/IConvexV1BoosterAdapter.sol/index.js +2 -0
  90. package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3.d.ts +716 -0
  91. package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3.js +2 -0
  92. package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events.d.ts +275 -0
  93. package/lib/types/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events.js +2 -0
  94. package/lib/types/ICreditConfiguratorV3.sol/index.d.ts +2 -0
  95. package/lib/types/ICreditConfiguratorV3.sol/index.js +2 -0
  96. package/lib/types/ICreditFacadeV2.sol/ICreditFacadeV2Extended.d.ts +7 -11
  97. package/lib/types/ICreditFacadeV3.sol/ICreditFacadeV3.d.ts +201 -94
  98. package/lib/types/ICreditFacadeV3.sol/ICreditFacadeV3Events.d.ts +31 -33
  99. package/lib/types/ICreditFacadeV3Multicall.d.ts +91 -60
  100. package/lib/types/ICreditManagerV3.sol/ICreditManagerV3.d.ts +360 -98
  101. package/lib/types/ICurveV1Adapter.d.ts +41 -105
  102. package/lib/types/ICurveV1_2AssetsAdapter.d.ts +41 -105
  103. package/lib/types/ICurveV1_3AssetsAdapter.d.ts +41 -105
  104. package/lib/types/ICurveV1_4AssetsAdapter.d.ts +41 -105
  105. package/lib/types/IDataCompressorV2_10.d.ts +44 -36
  106. package/lib/types/IDataCompressorV3_00.d.ts +141 -37
  107. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2.d.ts +339 -0
  108. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2.js +2 -0
  109. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Events.d.ts +61 -0
  110. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Events.js +2 -0
  111. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Exceptions.d.ts +27 -0
  112. package/lib/types/IDegenNFTV2.sol/IDegenNFTV2Exceptions.js +2 -0
  113. package/lib/types/IDegenNFTV2.sol/index.d.ts +3 -0
  114. package/lib/types/IDegenNFTV2.sol/index.js +2 -0
  115. package/lib/types/IERC165.d.ts +42 -0
  116. package/lib/types/IERC165.js +2 -0
  117. package/lib/types/{draft-IERC20Permit.sol/IERC20Permit.d.ts → IERC20Permit.d.ts} +1 -1
  118. package/lib/types/IERC20Permit.js +2 -0
  119. package/lib/types/IERC20ZapperDeposits.d.ts +117 -0
  120. package/lib/types/IERC20ZapperDeposits.js +2 -0
  121. package/lib/types/IERC4626Adapter.d.ts +238 -0
  122. package/lib/types/IERC4626Adapter.js +2 -0
  123. package/lib/types/IERC721.d.ts +220 -0
  124. package/lib/types/IERC721.js +2 -0
  125. package/lib/types/IERC721Metadata.d.ts +244 -0
  126. package/lib/types/IERC721Metadata.js +2 -0
  127. package/lib/types/IETHZapperDeposits.d.ts +66 -0
  128. package/lib/types/IETHZapperDeposits.js +2 -0
  129. package/lib/types/IGasPricer.d.ts +44 -0
  130. package/lib/types/IGasPricer.js +2 -0
  131. package/lib/types/IGaugeV3.sol/IGaugeV3.d.ts +366 -0
  132. package/lib/types/IGaugeV3.sol/IGaugeV3.js +2 -0
  133. package/lib/types/IGaugeV3.sol/IGaugeV3Events.d.ts +114 -0
  134. package/lib/types/IGaugeV3.sol/IGaugeV3Events.js +2 -0
  135. package/lib/types/IGaugeV3.sol/index.d.ts +2 -0
  136. package/lib/types/IGaugeV3.sol/index.js +2 -0
  137. package/lib/types/IGearStakingV3.sol/IGearStakingV3.d.ts +408 -0
  138. package/lib/types/IGearStakingV3.sol/IGearStakingV3.js +2 -0
  139. package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.d.ts +117 -0
  140. package/lib/types/IGearStakingV3.sol/IGearStakingV3Events.js +2 -0
  141. package/lib/types/IGearStakingV3.sol/index.d.ts +2 -0
  142. package/lib/types/IGearStakingV3.sol/index.js +2 -0
  143. package/lib/types/ILPPriceFeed.sol/ILPPriceFeed.d.ts +285 -0
  144. package/lib/types/ILPPriceFeed.sol/ILPPriceFeed.js +2 -0
  145. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedEvents.d.ts +54 -0
  146. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedEvents.js +2 -0
  147. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedExceptions.d.ts +27 -0
  148. package/lib/types/ILPPriceFeed.sol/ILPPriceFeedExceptions.js +2 -0
  149. package/lib/types/ILPPriceFeed.sol/index.d.ts +3 -0
  150. package/lib/types/ILPPriceFeed.sol/index.js +2 -0
  151. package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.d.ts → ILidoV1Adapter.d.ts} +13 -48
  152. package/lib/types/ILidoV1Adapter.js +2 -0
  153. package/lib/types/ILinearInterestRateModelV3.d.ts +120 -0
  154. package/lib/types/ILinearInterestRateModelV3.js +2 -0
  155. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3.d.ts +473 -0
  156. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3.js +2 -0
  157. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events.d.ts +113 -0
  158. package/lib/types/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events.js +2 -0
  159. package/lib/types/IPoolQuotaKeeperV3.sol/index.d.ts +2 -0
  160. package/lib/types/IPoolQuotaKeeperV3.sol/index.js +2 -0
  161. package/lib/types/IPoolV3.sol/IPoolV3.d.ts +43 -11
  162. package/lib/types/IPoolV3.sol/index.d.ts +0 -1
  163. package/lib/types/IPriceFeed.sol/IPriceFeed.d.ts +109 -0
  164. package/lib/types/IPriceFeed.sol/IPriceFeed.js +2 -0
  165. package/lib/types/IPriceFeed.sol/IUpdatablePriceFeed.d.ts +133 -0
  166. package/lib/types/IPriceFeed.sol/IUpdatablePriceFeed.js +2 -0
  167. package/lib/types/IPriceFeed.sol/index.d.ts +2 -0
  168. package/lib/types/IPriceFeed.sol/index.js +2 -0
  169. package/lib/types/IPriceOracle.sol/IPriceOracleV2.d.ts +166 -0
  170. package/lib/types/IPriceOracle.sol/IPriceOracleV2.js +2 -0
  171. package/lib/types/IPriceOracle.sol/IPriceOracleV2Events.d.ts +43 -0
  172. package/lib/types/IPriceOracle.sol/IPriceOracleV2Events.js +2 -0
  173. package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.d.ts → IPriceOracle.sol/IPriceOracleV2Exceptions.d.ts} +3 -3
  174. package/lib/types/IPriceOracle.sol/IPriceOracleV2Exceptions.js +2 -0
  175. package/lib/types/IPriceOracle.sol/IPriceOracleV2Ext.d.ts +182 -0
  176. package/lib/types/IPriceOracle.sol/IPriceOracleV2Ext.js +2 -0
  177. package/lib/types/IPriceOracle.sol/index.d.ts +4 -0
  178. package/lib/types/IPriceOracle.sol/index.js +2 -0
  179. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3.d.ts +272 -0
  180. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3.js +2 -0
  181. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3Events.d.ts +79 -0
  182. package/lib/types/IPriceOracleV3.sol/IPriceOracleV3Events.js +2 -0
  183. package/lib/types/IPriceOracleV3.sol/index.d.ts +2 -0
  184. package/lib/types/IPriceOracleV3.sol/index.js +2 -0
  185. package/lib/types/IUniswapV2Adapter.sol/IUniswapV2Adapter.d.ts +10 -9
  186. package/lib/types/IUniswapV3Adapter.sol/IUniswapV3Adapter.d.ts +27 -21
  187. package/lib/types/IVotingContractV3.d.ts +74 -0
  188. package/lib/types/IVotingContractV3.js +2 -0
  189. package/lib/types/IYearnV2Adapter.d.ts +22 -22
  190. package/lib/types/IZapper.d.ts +125 -0
  191. package/lib/types/IZapper.js +2 -0
  192. package/lib/types/IZapperRegister.d.ts +62 -0
  193. package/lib/types/IZapperRegister.js +2 -0
  194. package/lib/types/IwstETHV1Adapter.d.ts +17 -17
  195. package/lib/types/factories/AddressProvider__factory.d.ts +1 -1
  196. package/lib/types/factories/AddressProvider__factory.js +1 -1
  197. package/lib/types/factories/Claimable__factory.d.ts +1 -1
  198. package/lib/types/factories/Claimable__factory.js +1 -1
  199. package/lib/types/factories/IAaveV2_LendingPoolAdapter__factory.d.ts +158 -0
  200. package/lib/types/factories/IAaveV2_LendingPoolAdapter__factory.js +215 -0
  201. package/lib/types/factories/IAaveV2_WrappedATokenAdapter__factory.d.ts +252 -0
  202. package/lib/types/factories/IAaveV2_WrappedATokenAdapter__factory.js +341 -0
  203. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2VaultGetters__factory.d.ts +78 -0
  204. package/lib/types/factories/{ZapperBase__factory.js → IBalancerV2Vault.sol/IBalancerV2VaultGetters__factory.js} +54 -31
  205. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2Vault__factory.d.ts +360 -0
  206. package/lib/types/factories/IBalancerV2Vault.sol/IBalancerV2Vault__factory.js +475 -0
  207. package/lib/types/factories/IBalancerV2Vault.sol/index.d.ts +2 -0
  208. package/lib/types/factories/IBalancerV2Vault.sol/index.js +10 -0
  209. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents__factory.d.ts +23 -0
  210. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents__factory.js +38 -0
  211. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions__factory.d.ts +12 -0
  212. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions__factory.js} +4 -4
  213. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter__factory.d.ts +514 -0
  214. package/lib/types/factories/IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter__factory.js +675 -0
  215. package/lib/types/factories/IBalancerV2VaultAdapter.sol/index.d.ts +3 -0
  216. package/lib/types/factories/IBalancerV2VaultAdapter.sol/index.js +12 -0
  217. package/lib/types/factories/IBotListV3.sol/IBotListV3Events__factory.d.ts +103 -0
  218. package/lib/types/factories/IBotListV3.sol/IBotListV3Events__factory.js +138 -0
  219. package/lib/types/factories/IBotListV3.sol/IBotListV3__factory.d.ts +315 -0
  220. package/lib/types/factories/IBotListV3.sol/IBotListV3__factory.js +416 -0
  221. package/lib/types/factories/IBotListV3.sol/index.d.ts +2 -0
  222. package/lib/types/factories/IBotListV3.sol/index.js +10 -0
  223. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter__factory.d.ts +196 -0
  224. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter__factory.js +267 -0
  225. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions__factory.d.ts +16 -0
  226. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.js → ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions__factory.js} +6 -8
  227. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/index.d.ts +2 -0
  228. package/lib/types/factories/ICompoundV2_CTokenAdapter.sol/index.js +10 -0
  229. package/lib/types/factories/IContractsRegister.sol/IContractsRegisterEvents__factory.d.ts +28 -0
  230. package/lib/types/factories/IContractsRegister.sol/IContractsRegisterEvents__factory.js +45 -0
  231. package/lib/types/factories/IContractsRegister.sol/IContractsRegister__factory.d.ts +134 -0
  232. package/lib/types/factories/IContractsRegister.sol/IContractsRegister__factory.js +186 -0
  233. package/lib/types/factories/IContractsRegister.sol/index.d.ts +2 -0
  234. package/lib/types/factories/IContractsRegister.sol/index.js +10 -0
  235. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3Events__factory.d.ts +73 -0
  236. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3Events__factory.js +101 -0
  237. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3__factory.d.ts +427 -0
  238. package/lib/types/factories/IControllerTimelockV3.sol/IControllerTimelockV3__factory.js +556 -0
  239. package/lib/types/factories/IControllerTimelockV3.sol/index.d.ts +2 -0
  240. package/lib/types/factories/IControllerTimelockV3.sol/index.js +10 -0
  241. package/lib/types/factories/IConvexToken__factory.d.ts +10 -0
  242. package/lib/types/factories/IConvexToken__factory.js +13 -0
  243. package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.d.ts +38 -6
  244. package/lib/types/factories/IConvexV1BaseRewardPoolAdapter__factory.js +48 -6
  245. package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.d.ts +23 -0
  246. package/lib/types/factories/IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapterEvents__factory.js +38 -0
  247. package/lib/types/factories/{IConvexV1BoosterAdapter__factory.d.ts → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.d.ts} +26 -3
  248. package/lib/types/factories/{IConvexV1BoosterAdapter__factory.js → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter__factory.js} +31 -2
  249. package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.d.ts +2 -0
  250. package/lib/types/factories/IConvexV1BoosterAdapter.sol/index.js +10 -0
  251. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.d.ts +273 -0
  252. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3Events__factory.js +357 -0
  253. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.d.ts +605 -0
  254. package/lib/types/factories/ICreditConfiguratorV3.sol/ICreditConfiguratorV3__factory.js +785 -0
  255. package/lib/types/factories/ICreditConfiguratorV3.sol/index.d.ts +2 -0
  256. package/lib/types/factories/ICreditConfiguratorV3.sol/index.js +10 -0
  257. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.d.ts +0 -4
  258. package/lib/types/factories/ICreditFacadeV2.sol/ICreditFacadeV2Extended__factory.js +0 -5
  259. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.d.ts +19 -24
  260. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3Events__factory.js +21 -27
  261. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.d.ts +151 -72
  262. package/lib/types/factories/ICreditFacadeV3.sol/ICreditFacadeV3__factory.js +189 -85
  263. package/lib/types/factories/ICreditFacadeV3Multicall__factory.d.ts +77 -43
  264. package/lib/types/factories/ICreditFacadeV3Multicall__factory.js +96 -54
  265. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.d.ts +339 -147
  266. package/lib/types/factories/ICreditManagerV3.sol/ICreditManagerV3__factory.js +427 -180
  267. package/lib/types/factories/ICurveV1Adapter__factory.d.ts +13 -71
  268. package/lib/types/factories/ICurveV1Adapter__factory.js +14 -91
  269. package/lib/types/factories/ICurveV1_2AssetsAdapter__factory.d.ts +13 -71
  270. package/lib/types/factories/ICurveV1_2AssetsAdapter__factory.js +14 -91
  271. package/lib/types/factories/ICurveV1_3AssetsAdapter__factory.d.ts +13 -71
  272. package/lib/types/factories/ICurveV1_3AssetsAdapter__factory.js +14 -91
  273. package/lib/types/factories/ICurveV1_4AssetsAdapter__factory.d.ts +13 -71
  274. package/lib/types/factories/ICurveV1_4AssetsAdapter__factory.js +14 -91
  275. package/lib/types/factories/IDataCompressorV2_10__factory.d.ts +110 -54
  276. package/lib/types/factories/IDataCompressorV2_10__factory.js +138 -68
  277. package/lib/types/factories/IDataCompressorV3_00__factory.d.ts +379 -79
  278. package/lib/types/factories/IDataCompressorV3_00__factory.js +481 -100
  279. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Events__factory.d.ts +38 -0
  280. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Events__factory.js +58 -0
  281. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Exceptions__factory.d.ts +24 -0
  282. package/lib/types/factories/IDegenNFTV2.sol/IDegenNFTV2Exceptions__factory.js +39 -0
  283. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3__factory.d.ts → IDegenNFTV2.sol/IDegenNFTV2__factory.d.ts} +190 -180
  284. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3__factory.js → IDegenNFTV2.sol/IDegenNFTV2__factory.js} +212 -195
  285. package/lib/types/factories/IDegenNFTV2.sol/index.d.ts +3 -0
  286. package/lib/types/factories/IDegenNFTV2.sol/index.js +12 -0
  287. package/lib/types/factories/IERC165__factory.d.ts +22 -0
  288. package/lib/types/factories/IERC165__factory.js +38 -0
  289. package/lib/types/factories/{draft-IERC20Permit.sol/IERC20Permit__factory.d.ts → IERC20Permit__factory.d.ts} +1 -1
  290. package/lib/types/factories/IERC20ZapperDeposits__factory.d.ts +120 -0
  291. package/lib/types/factories/IERC20ZapperDeposits__factory.js +165 -0
  292. package/lib/types/factories/IERC4626Adapter__factory.d.ts +220 -0
  293. package/lib/types/factories/IERC4626Adapter__factory.js +297 -0
  294. package/lib/types/factories/IERC721Metadata__factory.d.ts +262 -0
  295. package/lib/types/factories/IERC721Metadata__factory.js +349 -0
  296. package/lib/types/factories/IERC721__factory.d.ts +228 -0
  297. package/lib/types/factories/IERC721__factory.js +304 -0
  298. package/lib/types/factories/IETHZapperDeposits__factory.d.ts +40 -0
  299. package/lib/types/factories/{AaveV2_WrappedAToken.sol/IWrappedATokenEvents__factory.js → IETHZapperDeposits__factory.js} +18 -25
  300. package/lib/types/factories/IGasPricer__factory.d.ts +22 -0
  301. package/lib/types/factories/IGasPricer__factory.js +38 -0
  302. package/lib/types/factories/IGaugeV3.sol/IGaugeV3Events__factory.d.ts +118 -0
  303. package/lib/types/factories/IGaugeV3.sol/IGaugeV3Events__factory.js +157 -0
  304. package/lib/types/factories/IGaugeV3.sol/IGaugeV3__factory.d.ts +342 -0
  305. package/lib/types/factories/IGaugeV3.sol/IGaugeV3__factory.js +448 -0
  306. package/lib/types/factories/IGaugeV3.sol/index.d.ts +2 -0
  307. package/lib/types/factories/IGaugeV3.sol/index.js +10 -0
  308. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events__factory.d.ts → IGearStakingV3.sol/IGearStakingV3Events__factory.d.ts} +33 -63
  309. package/lib/types/factories/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events__factory.js → IGearStakingV3.sol/IGearStakingV3Events__factory.js} +34 -70
  310. package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.d.ts +504 -0
  311. package/lib/types/factories/IGearStakingV3.sol/IGearStakingV3__factory.js +660 -0
  312. package/lib/types/factories/IGearStakingV3.sol/index.d.ts +2 -0
  313. package/lib/types/factories/IGearStakingV3.sol/index.js +10 -0
  314. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedEvents__factory.d.ts +33 -0
  315. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedEvents__factory.js +51 -0
  316. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedExceptions__factory.d.ts +24 -0
  317. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeedExceptions__factory.js +39 -0
  318. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeed__factory.d.ts +257 -0
  319. package/lib/types/factories/ILPPriceFeed.sol/ILPPriceFeed__factory.js +339 -0
  320. package/lib/types/factories/ILPPriceFeed.sol/index.d.ts +3 -0
  321. package/lib/types/factories/ILPPriceFeed.sol/index.js +12 -0
  322. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.d.ts → ILidoV1Adapter__factory.d.ts} +7 -37
  323. package/lib/types/factories/{ILidoV1Adapter.sol/ILidoV1Adapter__factory.js → ILidoV1Adapter__factory.js} +8 -46
  324. package/lib/types/factories/ILinearInterestRateModelV3__factory.d.ts +98 -0
  325. package/lib/types/factories/ILinearInterestRateModelV3__factory.js +136 -0
  326. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events__factory.d.ts +103 -0
  327. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3Events__factory.js +140 -0
  328. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3__factory.d.ts +441 -0
  329. package/lib/types/factories/IPoolQuotaKeeperV3.sol/IPoolQuotaKeeperV3__factory.js +580 -0
  330. package/lib/types/factories/IPoolQuotaKeeperV3.sol/index.d.ts +2 -0
  331. package/lib/types/factories/IPoolQuotaKeeperV3.sol/index.js +10 -0
  332. package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.d.ts +62 -14
  333. package/lib/types/factories/IPoolV3.sol/IPoolV3__factory.js +79 -17
  334. package/lib/types/factories/IPoolV3.sol/index.d.ts +0 -1
  335. package/lib/types/factories/IPoolV3.sol/index.js +1 -3
  336. package/lib/types/factories/{IPoolV3.sol/IPoolBase__factory.d.ts → IPriceFeed.sol/IPriceFeed__factory.d.ts} +39 -35
  337. package/lib/types/factories/{IPoolV3.sol/IPoolBase__factory.js → IPriceFeed.sol/IPriceFeed__factory.js} +40 -35
  338. package/lib/types/factories/IPriceFeed.sol/IUpdatablePriceFeed__factory.d.ts +104 -0
  339. package/lib/types/factories/IPriceFeed.sol/IUpdatablePriceFeed__factory.js +143 -0
  340. package/lib/types/factories/IPriceFeed.sol/index.d.ts +2 -0
  341. package/lib/types/factories/IPriceFeed.sol/index.js +10 -0
  342. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Events__factory.d.ts +23 -0
  343. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Events__factory.js +38 -0
  344. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Exceptions__factory.d.ts +20 -0
  345. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Exceptions__factory.js +34 -0
  346. package/lib/types/factories/{IAToken__factory.d.ts → IPriceOracle.sol/IPriceOracleV2Ext__factory.d.ts} +98 -99
  347. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2Ext__factory.js +267 -0
  348. package/lib/types/factories/IPriceOracle.sol/IPriceOracleV2__factory.d.ts +183 -0
  349. package/lib/types/factories/{IAToken__factory.js → IPriceOracle.sol/IPriceOracleV2__factory.js} +94 -112
  350. package/lib/types/factories/IPriceOracle.sol/index.d.ts +4 -0
  351. package/lib/types/factories/IPriceOracle.sol/index.js +14 -0
  352. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3Events__factory.d.ts +78 -0
  353. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3Events__factory.js +106 -0
  354. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3__factory.d.ts +326 -0
  355. package/lib/types/factories/IPriceOracleV3.sol/IPriceOracleV3__factory.js +433 -0
  356. package/lib/types/factories/IPriceOracleV3.sol/index.d.ts +2 -0
  357. package/lib/types/factories/IPriceOracleV3.sol/index.js +10 -0
  358. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2Adapter__factory.d.ts +5 -1
  359. package/lib/types/factories/IUniswapV2Adapter.sol/IUniswapV2Adapter__factory.js +6 -1
  360. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3Adapter__factory.d.ts +12 -4
  361. package/lib/types/factories/IUniswapV3Adapter.sol/IUniswapV3Adapter__factory.js +14 -4
  362. package/lib/types/factories/IVotingContractV3__factory.d.ts +44 -0
  363. package/lib/types/factories/IVotingContractV3__factory.js +65 -0
  364. package/lib/types/factories/IYearnV2Adapter__factory.d.ts +21 -13
  365. package/lib/types/factories/IYearnV2Adapter__factory.js +27 -15
  366. package/lib/types/factories/IZapperRegister__factory.d.ts +42 -0
  367. package/lib/types/factories/IZapperRegister__factory.js +64 -0
  368. package/lib/types/factories/{WERC20ZapperBase__factory.d.ts → IZapper__factory.d.ts} +52 -64
  369. package/lib/types/factories/{WERC20ZapperBase__factory.js → IZapper__factory.js} +58 -74
  370. package/lib/types/factories/IwstETHV1Adapter__factory.d.ts +12 -4
  371. package/lib/types/factories/IwstETHV1Adapter__factory.js +16 -4
  372. package/lib/types/factories/SafeERC20__factory.d.ts +1 -1
  373. package/lib/types/factories/SafeERC20__factory.js +1 -1
  374. package/lib/types/factories/index.d.ts +32 -14
  375. package/lib/types/factories/index.js +49 -26
  376. package/lib/types/factories/{IRouter__factory.d.ts → interfaces/IRouter__factory.d.ts} +75 -6
  377. package/lib/types/factories/{IRouter__factory.js → interfaces/IRouter__factory.js} +96 -6
  378. package/lib/types/factories/interfaces/index.d.ts +1 -0
  379. package/lib/types/factories/interfaces/index.js +8 -0
  380. package/lib/types/index.d.ts +141 -46
  381. package/lib/types/index.js +109 -38
  382. package/lib/types/{IRouter.d.ts → interfaces/IRouter.d.ts} +48 -35
  383. package/lib/types/interfaces/IRouter.js +2 -0
  384. package/lib/types/interfaces/index.d.ts +1 -0
  385. package/lib/types/interfaces/index.js +2 -0
  386. package/lib/utils/formatter.d.ts +0 -3
  387. package/lib/utils/formatter.js +1 -67
  388. package/lib/utils/math.d.ts +2 -0
  389. package/lib/utils/math.js +2 -0
  390. package/lib/utils/types.d.ts +1 -0
  391. package/lib/watchers/creditAccountWatcher.d.ts +3 -2
  392. package/lib/watchers/creditAccountWatcher.js +19 -13
  393. package/lib/watchers/creditAccountWatcher.spec.js +18 -18
  394. package/lib/watchers/creditManagerWatcher.d.ts +5 -3
  395. package/lib/watchers/creditManagerWatcher.js +32 -10
  396. package/lib/watchers/creditManagerWatcher.spec.js +12 -4
  397. package/package.json +10 -9
  398. package/contracts/IRouter.sol +0 -100
  399. package/lib/core/pool/index.d.ts +0 -1
  400. package/lib/core/pool/index.js +0 -17
  401. package/lib/types/AaveV2_WrappedAToken.sol/IWrappedATokenEvents.d.ts +0 -60
  402. package/lib/types/AaveV2_WrappedAToken.sol/WrappedAToken.d.ts +0 -332
  403. package/lib/types/AaveV2_WrappedAToken.sol/index.d.ts +0 -2
  404. package/lib/types/ERC20.d.ts +0 -198
  405. package/lib/types/IAToken.d.ts +0 -182
  406. package/lib/types/ILendingPool.d.ts +0 -140
  407. package/lib/types/ILidoV1Adapter.sol/index.d.ts +0 -3
  408. package/lib/types/IPoolV3.sol/IPoolBase.d.ts +0 -102
  409. package/lib/types/IWithdrawalManagerV3.sol/IWithdrawalManagerV3.d.ts +0 -370
  410. package/lib/types/IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events.d.ts +0 -133
  411. package/lib/types/IWithdrawalManagerV3.sol/index.d.ts +0 -2
  412. package/lib/types/WATokenZapper.d.ts +0 -134
  413. package/lib/types/WERC20ZapperBase.d.ts +0 -134
  414. package/lib/types/WETHZapper.d.ts +0 -122
  415. package/lib/types/WstETHZapper.d.ts +0 -134
  416. package/lib/types/ZapperBase.d.ts +0 -70
  417. package/lib/types/draft-IERC20Permit.sol/index.d.ts +0 -1
  418. package/lib/types/factories/AaveV2_WrappedAToken.sol/IWrappedATokenEvents__factory.d.ts +0 -48
  419. package/lib/types/factories/AaveV2_WrappedAToken.sol/WrappedAToken__factory.d.ts +0 -397
  420. package/lib/types/factories/AaveV2_WrappedAToken.sol/WrappedAToken__factory.js +0 -535
  421. package/lib/types/factories/AaveV2_WrappedAToken.sol/index.d.ts +0 -2
  422. package/lib/types/factories/AaveV2_WrappedAToken.sol/index.js +0 -10
  423. package/lib/types/factories/ERC20__factory.d.ts +0 -239
  424. package/lib/types/factories/ERC20__factory.js +0 -328
  425. package/lib/types/factories/ILendingPool__factory.d.ts +0 -134
  426. package/lib/types/factories/ILendingPool__factory.js +0 -183
  427. package/lib/types/factories/ILidoV1Adapter.sol/ILidoV1AdapterEvents__factory.d.ts +0 -18
  428. package/lib/types/factories/ILidoV1Adapter.sol/ILidoV1AdapterExceptions__factory.d.ts +0 -12
  429. package/lib/types/factories/ILidoV1Adapter.sol/index.d.ts +0 -3
  430. package/lib/types/factories/ILidoV1Adapter.sol/index.js +0 -12
  431. package/lib/types/factories/IWithdrawalManagerV3.sol/index.d.ts +0 -2
  432. package/lib/types/factories/IWithdrawalManagerV3.sol/index.js +0 -10
  433. package/lib/types/factories/WATokenZapper__factory.d.ts +0 -161
  434. package/lib/types/factories/WATokenZapper__factory.js +0 -227
  435. package/lib/types/factories/WETHZapper__factory.d.ts +0 -138
  436. package/lib/types/factories/WETHZapper__factory.js +0 -198
  437. package/lib/types/factories/WstETHZapper__factory.d.ts +0 -161
  438. package/lib/types/factories/WstETHZapper__factory.js +0 -227
  439. package/lib/types/factories/ZapperBase__factory.d.ts +0 -60
  440. package/lib/types/factories/draft-IERC20Permit.sol/index.d.ts +0 -1
  441. package/lib/types/factories/draft-IERC20Permit.sol/index.js +0 -8
  442. /package/lib/{types/AaveV2_WrappedAToken.sol/IWrappedATokenEvents.js → payload/gauge.js} +0 -0
  443. /package/lib/types/{AaveV2_WrappedAToken.sol/WrappedAToken.js → IAaveV2_LendingPoolAdapter.js} +0 -0
  444. /package/lib/types/{AaveV2_WrappedAToken.sol/index.js → IAaveV2_WrappedATokenAdapter.js} +0 -0
  445. /package/lib/types/{ERC20.js → IBalancerV2Vault.sol/IBalancerV2Vault.js} +0 -0
  446. /package/lib/types/{IAToken.js → IBalancerV2Vault.sol/IBalancerV2VaultGetters.js} +0 -0
  447. /package/lib/types/{ILidoV1Adapter.sol → IBalancerV2Vault.sol}/index.js +0 -0
  448. /package/lib/types/{IConvexV1BoosterAdapter.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapter.js} +0 -0
  449. /package/lib/types/{ILendingPool.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterEvents.js} +0 -0
  450. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1Adapter.js → IBalancerV2VaultAdapter.sol/IBalancerV2VaultAdapterExceptions.js} +0 -0
  451. /package/lib/types/{IWithdrawalManagerV3.sol → IBalancerV2VaultAdapter.sol}/index.js +0 -0
  452. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterEvents.js → IBotListV3.sol/IBotListV3.js} +0 -0
  453. /package/lib/types/{ILidoV1Adapter.sol/ILidoV1AdapterExceptions.js → IBotListV3.sol/IBotListV3Events.js} +0 -0
  454. /package/lib/types/{draft-IERC20Permit.sol → IBotListV3.sol}/index.js +0 -0
  455. /package/lib/types/{IPoolV3.sol/IPoolBase.js → ICompoundV2_CTokenAdapter.sol/ICompoundV2_CTokenAdapter.js} +0 -0
  456. /package/lib/types/{IRouter.js → ICompoundV2_CTokenAdapter.sol/ICompoundV2_Exceptions.js} +0 -0
  457. /package/lib/types/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3.js → ICompoundV2_CTokenAdapter.sol/index.js} +0 -0
  458. /package/lib/types/{IWithdrawalManagerV3.sol/IWithdrawalManagerV3Events.js → IContractsRegister.sol/IContractsRegister.js} +0 -0
  459. /package/lib/types/{WATokenZapper.js → IContractsRegister.sol/IContractsRegisterEvents.js} +0 -0
  460. /package/lib/types/{WERC20ZapperBase.js → IContractsRegister.sol/index.js} +0 -0
  461. /package/lib/types/{WETHZapper.js → IControllerTimelockV3.sol/IControllerTimelockV3.js} +0 -0
  462. /package/lib/types/{WstETHZapper.js → IControllerTimelockV3.sol/IControllerTimelockV3Events.js} +0 -0
  463. /package/lib/types/{ZapperBase.js → IControllerTimelockV3.sol/index.js} +0 -0
  464. /package/lib/types/{draft-IERC20Permit.sol/IERC20Permit.js → IConvexV1BoosterAdapter.sol/IConvexV1BoosterAdapter.js} +0 -0
  465. /package/lib/types/factories/{draft-IERC20Permit.sol/IERC20Permit__factory.js → IERC20Permit__factory.js} +0 -0
@@ -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,38 @@ 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
+ baseBorrowRate: caWithoutLP.borrowRate,
54
78
  underlyingToken: caWithoutLP.underlyingToken,
79
+ quotaRates: {},
80
+ quotas: {},
55
81
  lpAPY,
56
82
  prices,
57
83
  });
58
- (0, chai_1.expect)(result).to.be.eq(-6.94841);
84
+ (0, chai_1.expect)(result).to.be.eq(-69484n);
59
85
  });
60
86
  it("overall APY calculation for caWithLP is correct", () => {
61
87
  const result = creditAccount_1.CreditAccountData.calcOverallAPY({
62
88
  caAssets: caWithLP.assets,
63
89
  totalValue: caWithLP.totalValue,
64
90
  debt: caWithLP.debt,
65
- borrowRate: caWithLP.borrowRate,
91
+ baseBorrowRate: caWithLP.borrowRate,
66
92
  underlyingToken: caWithLP.underlyingToken,
93
+ quotaRates: {},
94
+ quotas: {},
67
95
  lpAPY,
68
96
  prices,
69
97
  });
70
- (0, chai_1.expect)(result).to.be.eq(14.4919);
98
+ (0, chai_1.expect)(result).to.be.eq(144919n);
71
99
  });
72
100
  it("overall APY is undefined when !lpAPY", () => {
73
101
  const result = creditAccount_1.CreditAccountData.calcOverallAPY({
74
102
  caAssets: caWithLP.assets,
75
103
  totalValue: caWithLP.totalValue,
76
104
  debt: caWithLP.debt,
77
- borrowRate: caWithLP.borrowRate,
105
+ baseBorrowRate: caWithLP.borrowRate,
78
106
  underlyingToken: caWithLP.underlyingToken,
107
+ quotaRates: {},
108
+ quotas: {},
79
109
  lpAPY: undefined,
80
110
  prices,
81
111
  });
@@ -86,8 +116,10 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
86
116
  caAssets: caWithLP.assets,
87
117
  totalValue: undefined,
88
118
  debt: caWithLP.debt,
89
- borrowRate: caWithLP.borrowRate,
119
+ baseBorrowRate: caWithLP.borrowRate,
90
120
  underlyingToken: caWithLP.underlyingToken,
121
+ quotaRates: {},
122
+ quotas: {},
91
123
  lpAPY,
92
124
  prices,
93
125
  });
@@ -98,8 +130,10 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
98
130
  caAssets: caWithLP.assets,
99
131
  totalValue: caWithLP.totalValue,
100
132
  debt: undefined,
101
- borrowRate: caWithLP.borrowRate,
133
+ baseBorrowRate: caWithLP.borrowRate,
102
134
  underlyingToken: caWithLP.underlyingToken,
135
+ quotaRates: {},
136
+ quotas: {},
103
137
  lpAPY,
104
138
  prices,
105
139
  });
@@ -110,13 +144,48 @@ describe("CreditAccount CreditAccountData.calcOverallAPY test", () => {
110
144
  caAssets: caWithLP.assets,
111
145
  totalValue: 0n,
112
146
  debt: undefined,
113
- borrowRate: caWithLP.borrowRate,
147
+ baseBorrowRate: caWithLP.borrowRate,
114
148
  underlyingToken: caWithLP.underlyingToken,
149
+ quotaRates: {},
150
+ quotas: {},
115
151
  lpAPY,
116
152
  prices,
117
153
  });
118
154
  (0, chai_1.expect)(result).to.be.eq(undefined);
119
155
  });
156
+ it("overall APY calculation for caWithLP with sufficient quota is correct", () => {
157
+ const result = creditAccount_1.CreditAccountData.calcOverallAPY({
158
+ caAssets: caWithLP.assets,
159
+ totalValue: caWithLP.totalValue,
160
+ debt: caWithLP.debt,
161
+ baseBorrowRate: caWithLP.borrowRate,
162
+ underlyingToken: caWithLP.underlyingToken,
163
+ quotaRates: caWithLP.rates,
164
+ quotas: caWithLP.quotas,
165
+ lpAPY,
166
+ prices,
167
+ });
168
+ (0, chai_1.expect)(result).to.be.eq(-18680n);
169
+ });
170
+ it("overall APY calculation for caWithLP with insufficient quota is correct", () => {
171
+ const result = creditAccount_1.CreditAccountData.calcOverallAPY({
172
+ caAssets: caWithLP.assets,
173
+ totalValue: caWithLP.totalValue,
174
+ debt: caWithLP.debt,
175
+ baseBorrowRate: caWithLP.borrowRate,
176
+ underlyingToken: caWithLP.underlyingToken,
177
+ quotaRates: caWithLP.rates,
178
+ quotas: {
179
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH.toLowerCase()]: {
180
+ balance: 0n,
181
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH.toLowerCase(),
182
+ },
183
+ },
184
+ lpAPY,
185
+ prices,
186
+ });
187
+ (0, chai_1.expect)(result).to.be.eq(144919n);
188
+ });
120
189
  });
121
190
  describe("CreditAccount calcMaxIncreaseBorrow test", () => {
122
191
  it("health max increase borrow is zero if hf < 1", () => {
@@ -152,10 +221,23 @@ const defaultCA = {
152
221
  healthFactor: 10244,
153
222
  underlyingToken: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI.toLowerCase(),
154
223
  underlyingDecimals: sdk_gov_1.decimals.DAI,
224
+ quotas: {
225
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
226
+ balance: (0, formatter_1.toBN)(String(1750 * 10), sdk_gov_1.decimals.DAI),
227
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase(),
228
+ },
229
+ },
230
+ quotasInfo: {
231
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
232
+ isActive: true,
233
+ },
234
+ },
155
235
  };
156
- describe("CreditManager calcHealthFactor test", () => {
157
- it("health factor calculation is calculated correctly", () => {
236
+ describe("CreditAccount calcHealthFactor test", () => {
237
+ it("health factor is calculated correctly", () => {
158
238
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
239
+ quotas: {},
240
+ quotasInfo: {},
159
241
  assets: defaultCA.assets,
160
242
  prices,
161
243
  liquidationThresholds,
@@ -166,6 +248,8 @@ describe("CreditManager calcHealthFactor test", () => {
166
248
  });
167
249
  it("health factor calculation has no division by zero error", () => {
168
250
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
251
+ quotas: {},
252
+ quotasInfo: {},
169
253
  assets: [],
170
254
  prices: {},
171
255
  liquidationThresholds: {},
@@ -181,6 +265,8 @@ describe("CreditManager calcHealthFactor test", () => {
181
265
  };
182
266
  const afterAdd = assets_1.AssetUtils.sumAssets(defaultCA.assets, [collateral]);
183
267
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
268
+ quotas: {},
269
+ quotasInfo: {},
184
270
  assets: afterAdd,
185
271
  prices,
186
272
  liquidationThresholds,
@@ -199,6 +285,8 @@ describe("CreditManager calcHealthFactor test", () => {
199
285
  debtDecrease,
200
286
  ]);
201
287
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
288
+ quotas: {},
289
+ quotasInfo: {},
202
290
  assets: afterDecrease,
203
291
  prices,
204
292
  liquidationThresholds,
@@ -217,6 +305,8 @@ describe("CreditManager calcHealthFactor test", () => {
217
305
  debtIncrease,
218
306
  ]);
219
307
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
308
+ quotas: {},
309
+ quotasInfo: {},
220
310
  assets: afterIncrease,
221
311
  prices,
222
312
  liquidationThresholds,
@@ -240,6 +330,8 @@ describe("CreditManager calcHealthFactor test", () => {
240
330
  const afterSub = assets_1.AssetUtils.subAssets(defaultCA.assets, [swapAsset]);
241
331
  const afterSwap = assets_1.AssetUtils.sumAssets(afterSub, [getAsset]);
242
332
  const result = creditAccount_1.CreditAccountData.calcHealthFactor({
333
+ quotas: {},
334
+ quotasInfo: {},
243
335
  assets: afterSwap,
244
336
  prices,
245
337
  liquidationThresholds,
@@ -248,4 +340,595 @@ describe("CreditManager calcHealthFactor test", () => {
248
340
  });
249
341
  (0, chai_1.expect)(result).to.be.eq(9444);
250
342
  });
343
+ it("health factor with sufficient quotas is calculated correctly", () => {
344
+ const result = creditAccount_1.CreditAccountData.calcHealthFactor({
345
+ quotas: defaultCA.quotas,
346
+ quotasInfo: defaultCA.quotasInfo,
347
+ assets: defaultCA.assets,
348
+ prices,
349
+ liquidationThresholds,
350
+ underlyingToken: defaultCA.underlyingToken,
351
+ borrowed: defaultCA.debt,
352
+ });
353
+ (0, chai_1.expect)(result).to.be.eq(defaultCA.healthFactor);
354
+ });
355
+ it("health factor with insufficient quotas is calculated correctly", () => {
356
+ const result = creditAccount_1.CreditAccountData.calcHealthFactor({
357
+ quotas: {
358
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
359
+ balance: 0n,
360
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase(),
361
+ },
362
+ },
363
+ quotasInfo: defaultCA.quotasInfo,
364
+ assets: defaultCA.assets,
365
+ prices,
366
+ liquidationThresholds,
367
+ underlyingToken: defaultCA.underlyingToken,
368
+ borrowed: defaultCA.debt,
369
+ });
370
+ (0, chai_1.expect)(result).to.be.eq(9300);
371
+ });
372
+ it("health factor with disabled quota is calculated correctly", () => {
373
+ const result = creditAccount_1.CreditAccountData.calcHealthFactor({
374
+ quotas: defaultCA.quotas,
375
+ quotasInfo: {
376
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH.toLowerCase()]: {
377
+ isActive: false,
378
+ },
379
+ },
380
+ assets: defaultCA.assets,
381
+ prices,
382
+ liquidationThresholds,
383
+ underlyingToken: defaultCA.underlyingToken,
384
+ borrowed: defaultCA.debt,
385
+ });
386
+ (0, chai_1.expect)(result).to.be.eq(9300);
387
+ });
388
+ });
389
+ const cmQuotas = {
390
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
391
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
392
+ isActive: true,
393
+ },
394
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
395
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
396
+ isActive: true,
397
+ },
398
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
399
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
400
+ isActive: true,
401
+ },
402
+ };
403
+ const caQuota = {
404
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
405
+ quota: 5n,
406
+ },
407
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
408
+ quota: 10n,
409
+ },
410
+ };
411
+ describe("CreditAccount calcQuotaUpdate test", () => {
412
+ it("open account should buy quota", () => {
413
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
414
+ quotas: cmQuotas,
415
+ initialQuotas: {},
416
+ assetsAfterUpdate: {
417
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
418
+ amountInTarget: 10n,
419
+ balance: 0n,
420
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
421
+ },
422
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
423
+ amountInTarget: 20n,
424
+ balance: 0n,
425
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
426
+ },
427
+ },
428
+ allowedToObtain: {
429
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
430
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
431
+ },
432
+ allowedToSpend: {},
433
+ });
434
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
435
+ {
436
+ balance: 10n,
437
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
438
+ },
439
+ {
440
+ balance: 20n,
441
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
442
+ },
443
+ ]);
444
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
445
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
446
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
447
+ balance: 10n,
448
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
449
+ },
450
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
451
+ balance: 20n,
452
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
453
+ },
454
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
455
+ balance: 0n,
456
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
457
+ },
458
+ });
459
+ });
460
+ it("add collateral should buy quota", () => {
461
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
462
+ quotas: cmQuotas,
463
+ initialQuotas: caQuota,
464
+ assetsAfterUpdate: {
465
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
466
+ amountInTarget: 10n,
467
+ balance: 0n,
468
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
469
+ },
470
+ },
471
+ allowedToObtain: {
472
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {},
473
+ },
474
+ allowedToSpend: {},
475
+ });
476
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
477
+ {
478
+ balance: 10n,
479
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
480
+ },
481
+ ]);
482
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
483
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
484
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
485
+ balance: 5n,
486
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
487
+ },
488
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
489
+ balance: 10n,
490
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
491
+ },
492
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
493
+ balance: 10n,
494
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
495
+ },
496
+ });
497
+ });
498
+ it("add collateral should add additional quota", () => {
499
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
500
+ quotas: cmQuotas,
501
+ initialQuotas: caQuota,
502
+ assetsAfterUpdate: {
503
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
504
+ amountInTarget: 10n,
505
+ balance: 0n,
506
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
507
+ },
508
+ },
509
+ allowedToObtain: {
510
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
511
+ },
512
+ allowedToSpend: {},
513
+ });
514
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
515
+ {
516
+ balance: 5n,
517
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
518
+ },
519
+ ]);
520
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
521
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
522
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
523
+ balance: 10n,
524
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
525
+ },
526
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
527
+ balance: 10n,
528
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
529
+ },
530
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
531
+ balance: 0n,
532
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
533
+ },
534
+ });
535
+ });
536
+ it("add collateral shouldn't add additional quota", () => {
537
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
538
+ quotas: cmQuotas,
539
+ initialQuotas: caQuota,
540
+ assetsAfterUpdate: {
541
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
542
+ amountInTarget: 10n,
543
+ balance: 0n,
544
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
545
+ },
546
+ },
547
+ allowedToObtain: {
548
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
549
+ },
550
+ allowedToSpend: {},
551
+ });
552
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
553
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
554
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
555
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
556
+ balance: 5n,
557
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
558
+ },
559
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
560
+ balance: 10n,
561
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
562
+ },
563
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
564
+ balance: 0n,
565
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
566
+ },
567
+ });
568
+ });
569
+ it("swap should buy quota", () => {
570
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
571
+ quotas: cmQuotas,
572
+ initialQuotas: caQuota,
573
+ assetsAfterUpdate: {
574
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
575
+ amountInTarget: 10n,
576
+ balance: 0n,
577
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
578
+ },
579
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
580
+ amountInTarget: 0n,
581
+ balance: 0n,
582
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
583
+ },
584
+ },
585
+ allowedToObtain: {
586
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {},
587
+ },
588
+ allowedToSpend: { [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {} },
589
+ });
590
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
591
+ {
592
+ balance: 10n,
593
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
594
+ },
595
+ ]);
596
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
597
+ { balance: -10n, token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH },
598
+ ]);
599
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
600
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
601
+ balance: 5n,
602
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
603
+ },
604
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
605
+ balance: 0n,
606
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
607
+ },
608
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
609
+ balance: 10n,
610
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
611
+ },
612
+ });
613
+ });
614
+ it("swap should add additional quota", () => {
615
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
616
+ quotas: cmQuotas,
617
+ initialQuotas: caQuota,
618
+ assetsAfterUpdate: {
619
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
620
+ amountInTarget: 10n,
621
+ balance: 0n,
622
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
623
+ },
624
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
625
+ amountInTarget: 0n,
626
+ balance: 0n,
627
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
628
+ },
629
+ },
630
+ allowedToObtain: {
631
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
632
+ },
633
+ allowedToSpend: {
634
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
635
+ },
636
+ });
637
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([
638
+ {
639
+ balance: 5n,
640
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
641
+ },
642
+ ]);
643
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
644
+ {
645
+ balance: -10n,
646
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
647
+ },
648
+ ]);
649
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
650
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
651
+ balance: 10n,
652
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
653
+ },
654
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
655
+ balance: 0n,
656
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
657
+ },
658
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
659
+ balance: 0n,
660
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
661
+ },
662
+ });
663
+ });
664
+ it("swap shouldn't add additional quota", () => {
665
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
666
+ quotas: cmQuotas,
667
+ initialQuotas: caQuota,
668
+ assetsAfterUpdate: {
669
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
670
+ amountInTarget: 10n,
671
+ balance: 0n,
672
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
673
+ },
674
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
675
+ amountInTarget: 0n,
676
+ balance: 0n,
677
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
678
+ },
679
+ },
680
+ allowedToObtain: {
681
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
682
+ },
683
+ allowedToSpend: { [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {} },
684
+ });
685
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
686
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([
687
+ {
688
+ balance: -5n,
689
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
690
+ },
691
+ ]);
692
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
693
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
694
+ balance: 0n,
695
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
696
+ },
697
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
698
+ balance: 10n,
699
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
700
+ },
701
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
702
+ balance: 0n,
703
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
704
+ },
705
+ });
706
+ });
707
+ it("shouldn't change quota if disallowed", () => {
708
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
709
+ quotas: cmQuotas,
710
+ initialQuotas: caQuota,
711
+ assetsAfterUpdate: {
712
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
713
+ amountInTarget: 10n,
714
+ balance: 0n,
715
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
716
+ },
717
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
718
+ amountInTarget: 0n,
719
+ balance: 0n,
720
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
721
+ },
722
+ },
723
+ allowedToObtain: {},
724
+ allowedToSpend: {},
725
+ });
726
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
727
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
728
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
729
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
730
+ balance: 5n,
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 it is disabled", () => {
744
+ const result = creditAccount_1.CreditAccountData.calcQuotaUpdate({
745
+ quotas: {
746
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
747
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
748
+ isActive: false,
749
+ },
750
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
751
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
752
+ isActive: false,
753
+ },
754
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
755
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
756
+ isActive: false,
757
+ },
758
+ },
759
+ initialQuotas: caQuota,
760
+ assetsAfterUpdate: {
761
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
762
+ amountInTarget: 10n,
763
+ balance: 0n,
764
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
765
+ },
766
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
767
+ amountInTarget: 0n,
768
+ balance: 0n,
769
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
770
+ },
771
+ },
772
+ allowedToObtain: {
773
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {},
774
+ },
775
+ allowedToSpend: {
776
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {},
777
+ },
778
+ });
779
+ (0, chai_1.expect)(result.quotaIncrease).to.be.deep.eq([]);
780
+ (0, chai_1.expect)(result.quotaDecrease).to.be.deep.eq([]);
781
+ (0, chai_1.expect)(result.desiredQuota).to.be.deep.eq({
782
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
783
+ balance: 5n,
784
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
785
+ },
786
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
787
+ balance: 10n,
788
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
789
+ },
790
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
791
+ balance: 0n,
792
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
793
+ },
794
+ });
795
+ });
796
+ });
797
+ describe("CreditAccount calcQuotaBorrowRate test", () => {
798
+ it("should calculate quota rate (same amounts, different rates)", () => {
799
+ const result = creditAccount_1.CreditAccountData.calcQuotaBorrowRate({
800
+ quotas: {
801
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
802
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
803
+ balance: 10n,
804
+ },
805
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
806
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
807
+ balance: 10n,
808
+ },
809
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
810
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
811
+ balance: 10n,
812
+ },
813
+ },
814
+ quotaRates: {
815
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
816
+ rate: 5,
817
+ isActive: true,
818
+ },
819
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
820
+ rate: 10,
821
+ isActive: true,
822
+ },
823
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
824
+ rate: 15,
825
+ isActive: true,
826
+ },
827
+ },
828
+ borrowAmount: 30n,
829
+ });
830
+ (0, chai_1.expect)(result).to.be.eq(10);
831
+ });
832
+ it("should calculate quota rate (same rates, different amounts)", () => {
833
+ const result = creditAccount_1.CreditAccountData.calcQuotaBorrowRate({
834
+ quotas: {
835
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
836
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
837
+ balance: 5n,
838
+ },
839
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
840
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
841
+ balance: 10n,
842
+ },
843
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
844
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
845
+ balance: 15n,
846
+ },
847
+ },
848
+ quotaRates: {
849
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
850
+ rate: 10,
851
+ isActive: true,
852
+ },
853
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
854
+ rate: 10,
855
+ isActive: true,
856
+ },
857
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
858
+ rate: 10,
859
+ isActive: true,
860
+ },
861
+ },
862
+ borrowAmount: 30n,
863
+ });
864
+ (0, chai_1.expect)(result).to.be.eq(10);
865
+ });
866
+ it("should calculate quota rate (borrow amount)", () => {
867
+ const result = creditAccount_1.CreditAccountData.calcQuotaBorrowRate({
868
+ quotas: {
869
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
870
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
871
+ balance: 5n,
872
+ },
873
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
874
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
875
+ balance: 10n,
876
+ },
877
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
878
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
879
+ balance: 15n,
880
+ },
881
+ },
882
+ quotaRates: {
883
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
884
+ rate: 10,
885
+ isActive: true,
886
+ },
887
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
888
+ rate: 10,
889
+ isActive: true,
890
+ },
891
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
892
+ rate: 10,
893
+ isActive: true,
894
+ },
895
+ },
896
+ borrowAmount: 60n,
897
+ });
898
+ (0, chai_1.expect)(result).to.be.eq(5);
899
+ });
900
+ it("should calculate quota rate (disabled quota)", () => {
901
+ const result = creditAccount_1.CreditAccountData.calcQuotaBorrowRate({
902
+ quotas: {
903
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
904
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.DAI,
905
+ balance: 5n,
906
+ },
907
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
908
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.WETH,
909
+ balance: 10n,
910
+ },
911
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
912
+ token: sdk_gov_1.tokenDataByNetwork.Mainnet.STETH,
913
+ balance: 15n,
914
+ },
915
+ },
916
+ quotaRates: {
917
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.DAI]: {
918
+ rate: 10,
919
+ isActive: true,
920
+ },
921
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.WETH]: {
922
+ rate: 10,
923
+ isActive: false,
924
+ },
925
+ [sdk_gov_1.tokenDataByNetwork.Mainnet.STETH]: {
926
+ rate: 10,
927
+ isActive: true,
928
+ },
929
+ },
930
+ borrowAmount: 50n,
931
+ });
932
+ (0, chai_1.expect)(result).to.be.eq(4);
933
+ });
251
934
  });