@gearbox-protocol/sdk 3.0.0-next.10 → 3.0.0-next.100

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