@gearbox-protocol/sdk 11.11.0-next.2 → 11.11.1

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 (458) hide show
  1. package/dist/cjs/dev/create2.js +1 -1
  2. package/dist/cjs/dev/mint/AbstractMinter.js +4 -2
  3. package/dist/cjs/dev/mint/DealMinter.js +3 -0
  4. package/dist/cjs/dev/mint/DirectMinter.js +3 -0
  5. package/dist/cjs/dev/mint/FallbackMinter.js +1 -1
  6. package/dist/cjs/dev/mint/TransferMinter.js +3 -0
  7. package/dist/cjs/permissionless/bindings/address-provider.js +6 -4
  8. package/dist/cjs/permissionless/bindings/base-contract.js +173 -0
  9. package/dist/cjs/permissionless/bindings/bytecode-repository.js +25 -23
  10. package/dist/cjs/permissionless/bindings/compressors/token-compressor.js +4 -4
  11. package/dist/cjs/permissionless/bindings/compressors/withdrawal-compressor.js +17 -11
  12. package/dist/cjs/permissionless/bindings/cross-chain-multisig.js +22 -23
  13. package/dist/cjs/permissionless/bindings/factory/abstract-factory.js +4 -7
  14. package/dist/cjs/permissionless/bindings/governance/batches-chain.js +4 -4
  15. package/dist/cjs/permissionless/bindings/governance/governor.js +49 -30
  16. package/dist/cjs/permissionless/bindings/governance/timelock.js +4 -4
  17. package/dist/cjs/permissionless/bindings/index.js +2 -0
  18. package/dist/cjs/permissionless/bindings/instance-manager.js +77 -58
  19. package/dist/cjs/permissionless/bindings/market-configurator-factory.js +4 -4
  20. package/dist/cjs/permissionless/bindings/market-configurator.js +143 -71
  21. package/dist/cjs/permissionless/bindings/price-feed-store.js +17 -8
  22. package/dist/cjs/permissionless/bindings/router/routing-manager.js +15 -9
  23. package/dist/cjs/permissionless/bindings/treasury-splitter.js +23 -14
  24. package/dist/cjs/permissionless/core/raw-tx.js +2 -2
  25. package/dist/cjs/permissionless/utils/abi-decoder.js +72 -0
  26. package/dist/cjs/permissionless/utils/format.js +2 -2
  27. package/dist/cjs/permissionless/utils/governance/timelock-txs.js +2 -2
  28. package/dist/cjs/permissionless/utils/index.js +2 -0
  29. package/dist/cjs/permissionless/utils/price-update/get-price-feeds.js +2 -1
  30. package/dist/cjs/permissionless/utils/price-update/get-price-update-tx.js +2 -1
  31. package/dist/cjs/permissionless/utils/price-update/get-prices.js +2 -1
  32. package/dist/cjs/permissionless/utils/price-update/get-updatable-feeds.js +3 -2
  33. package/dist/cjs/plugins/adapters/contracts/AbstractAdapter.js +2 -2
  34. package/dist/cjs/plugins/adapters/contracts/AccountMigratorAdapterContract.js +2 -2
  35. package/dist/cjs/plugins/adapters/contracts/BalancerV2VaultAdapterContract.js +2 -2
  36. package/dist/cjs/plugins/adapters/contracts/BalancerV3RouterAdapterContract.js +2 -2
  37. package/dist/cjs/plugins/adapters/contracts/BalancerV3WrapperAdapterContract.js +2 -2
  38. package/dist/cjs/plugins/adapters/contracts/CamelotV3AdapterContract.js +2 -2
  39. package/dist/cjs/plugins/adapters/contracts/ConvexV1BaseRewardPoolAdapterContract.js +2 -2
  40. package/dist/cjs/plugins/adapters/contracts/ConvexV1BoosterAdapterContract.js +2 -2
  41. package/dist/cjs/plugins/adapters/contracts/Curve2AssetsAdapterContract.js +2 -2
  42. package/dist/cjs/plugins/adapters/contracts/Curve3AssetsAdapterContract.js +2 -2
  43. package/dist/cjs/plugins/adapters/contracts/Curve4AssetsAdapterContract.js +2 -2
  44. package/dist/cjs/plugins/adapters/contracts/CurveV1AdapterDeposit.js +2 -2
  45. package/dist/cjs/plugins/adapters/contracts/CurveV1AdapterStETHContract.js +2 -2
  46. package/dist/cjs/plugins/adapters/contracts/CurveV1StableNGAdapterContract.js +2 -2
  47. package/dist/cjs/plugins/adapters/contracts/DaiUsdsAdapterContract.js +2 -2
  48. package/dist/cjs/plugins/adapters/contracts/ERC4626AdapterContract.js +2 -2
  49. package/dist/cjs/plugins/adapters/contracts/ERC4626ReferralAdapterContract.js +2 -2
  50. package/dist/cjs/plugins/adapters/contracts/EqualizerRouterAdapterContract.js +2 -2
  51. package/dist/cjs/plugins/adapters/contracts/FluidDexAdapterContract.js +2 -2
  52. package/dist/cjs/plugins/adapters/contracts/InfinifiGatewayAdapterContract.js +2 -2
  53. package/dist/cjs/plugins/adapters/contracts/InfinifiUnwindingGatewayAdapterContract.js +2 -2
  54. package/dist/cjs/plugins/adapters/contracts/InfraredVaultAdapterContract.js +2 -2
  55. package/dist/cjs/plugins/adapters/contracts/KelpLRTDepositPoolAdapterContract.js +2 -2
  56. package/dist/cjs/plugins/adapters/contracts/KelpLRTWithdrawalManagerAdapterContract.js +2 -2
  57. package/dist/cjs/plugins/adapters/contracts/KodiakIslandGatewayAdapterContract.js +2 -2
  58. package/dist/cjs/plugins/adapters/contracts/LidoV1AdapterContract.js +2 -2
  59. package/dist/cjs/plugins/adapters/contracts/MellowClaimerAdapterContract.js +2 -2
  60. package/dist/cjs/plugins/adapters/contracts/MellowDVVAdapterContract.js +2 -2
  61. package/dist/cjs/plugins/adapters/contracts/MellowDepositQueueAdapterContract.js +2 -2
  62. package/dist/cjs/plugins/adapters/contracts/MellowERC4626VaultAdapterContract.js +2 -2
  63. package/dist/cjs/plugins/adapters/contracts/MellowRedeemQueueAdapterContract.js +2 -2
  64. package/dist/cjs/plugins/adapters/contracts/MellowVaultAdapterContract.js +2 -2
  65. package/dist/cjs/plugins/adapters/contracts/MellowWrapperAdapterContract.js +2 -2
  66. package/dist/cjs/plugins/adapters/contracts/MidasIssuanceVaultAdapterContract.js +2 -2
  67. package/dist/cjs/plugins/adapters/contracts/MidasRedemptionVaultAdapterContract.js +2 -2
  68. package/dist/cjs/plugins/adapters/contracts/PendleRouterAdapterContract.js +2 -2
  69. package/dist/cjs/plugins/adapters/contracts/StakingRewardsAdapterContract.js +2 -2
  70. package/dist/cjs/plugins/adapters/contracts/TraderJoeRouterAdapterContract.js +2 -2
  71. package/dist/cjs/plugins/adapters/contracts/UniswapV2AdapterContract.js +5 -5
  72. package/dist/cjs/plugins/adapters/contracts/UniswapV3AdapterContract.js +22 -22
  73. package/dist/cjs/plugins/adapters/contracts/UniswapV4AdapterContract.js +2 -2
  74. package/dist/cjs/plugins/adapters/contracts/UpshiftVaultAdapterContract.js +2 -2
  75. package/dist/cjs/plugins/adapters/contracts/VelodromeV2AdapterContract.js +2 -2
  76. package/dist/cjs/plugins/adapters/contracts/WstETHV1AdapterContract.js +2 -2
  77. package/dist/cjs/plugins/adapters/contracts/YearnV2AdapterContract.js +2 -2
  78. package/dist/cjs/plugins/bots/BotsPlugin.js +96 -21
  79. package/dist/cjs/plugins/bots/PartialLiquidationBotBaseContract.js +14 -17
  80. package/dist/cjs/plugins/bots/PartialLiquidationBotV300Contract.js +20 -4
  81. package/dist/cjs/plugins/bots/config.js +59 -0
  82. package/dist/cjs/plugins/bots/index.js +4 -0
  83. package/dist/cjs/plugins/bots/types.js +9 -0
  84. package/dist/cjs/plugins/zappers/ZappersPlugin.js +1 -1
  85. package/dist/cjs/sdk/GearboxSDK.js +110 -8
  86. package/dist/cjs/sdk/accountMigration/AbstractMigrateCreditAccountsService.js +4 -1
  87. package/dist/cjs/sdk/accounts/AbstractCreditAccountsService.js +8 -6
  88. package/dist/cjs/sdk/base/AddressLabeller.js +49 -0
  89. package/dist/cjs/sdk/base/BaseContract.js +80 -195
  90. package/dist/cjs/sdk/base/IAddressLabeller.js +16 -0
  91. package/dist/cjs/sdk/base/SDKConstruct.js +29 -3
  92. package/dist/cjs/sdk/base/TokensMeta.js +4 -4
  93. package/dist/cjs/sdk/base/index.js +2 -4
  94. package/dist/cjs/sdk/core/BotListV3Contract.js +2 -2
  95. package/dist/cjs/sdk/core/GearStakingV3Contract.js +2 -2
  96. package/dist/cjs/sdk/core/address-provider/AbstractAddressProviderContract.js +2 -2
  97. package/dist/cjs/sdk/core/address-provider/AddressProviderV300Contract.js +6 -11
  98. package/dist/cjs/sdk/core/address-provider/AddressProviderV310Contract.js +4 -4
  99. package/dist/cjs/sdk/market/MarketConfiguratorContract.js +5 -5
  100. package/dist/cjs/sdk/market/MarketRegister.js +9 -7
  101. package/dist/cjs/sdk/market/MarketSuite.js +2 -2
  102. package/dist/cjs/sdk/market/credit/CreditConfiguratorV300Contract.js +3 -4
  103. package/dist/cjs/sdk/market/credit/CreditConfiguratorV310Contract.js +3 -4
  104. package/dist/cjs/sdk/market/credit/CreditFacadeV300Contract.js +9 -9
  105. package/dist/cjs/sdk/market/credit/CreditFacadeV310Contract.js +8 -8
  106. package/dist/cjs/sdk/market/credit/CreditManagerV300Contract.js +2 -5
  107. package/dist/cjs/sdk/market/credit/CreditManagerV310Contract.js +2 -5
  108. package/dist/cjs/sdk/market/credit/CreditSuite.js +3 -2
  109. package/dist/cjs/sdk/market/loss-policy/AliasLossPolicyV310Contract.js +1 -3
  110. package/dist/cjs/sdk/market/loss-policy/LossPolicyContract.js +2 -2
  111. package/dist/cjs/sdk/market/loss-policy/createLossPolicy.js +1 -1
  112. package/dist/cjs/sdk/market/oracle/PriceOracleBaseContract.js +26 -8
  113. package/dist/cjs/sdk/market/oracle/createPriceOracle.js +1 -1
  114. package/dist/cjs/sdk/market/pool/GaugeContract.js +2 -2
  115. package/dist/cjs/sdk/market/pool/LinearInterestRateModelContract.js +2 -2
  116. package/dist/cjs/sdk/market/pool/PoolQuotaKeeperV300Contract.js +2 -2
  117. package/dist/cjs/sdk/market/pool/PoolQuotaKeeperV310Contract.js +2 -2
  118. package/dist/cjs/sdk/market/pool/PoolSuite.js +1 -1
  119. package/dist/cjs/sdk/market/pool/PoolV300Contract.js +5 -5
  120. package/dist/cjs/sdk/market/pool/PoolV310Contract.js +5 -5
  121. package/dist/cjs/sdk/market/pool/TumblerContract.js +2 -2
  122. package/dist/cjs/sdk/market/pool/createInterestRateModel.js +15 -11
  123. package/dist/cjs/sdk/market/pricefeeds/AbstractLPPriceFeed.js +22 -2
  124. package/dist/cjs/sdk/market/pricefeeds/AbstractPriceFeed.js +3 -3
  125. package/dist/cjs/sdk/market/pricefeeds/BalancerStablePriceFeed.js +9 -2
  126. package/dist/cjs/sdk/market/pricefeeds/BalancerWeightedPriceFeed.js +9 -2
  127. package/dist/cjs/sdk/market/pricefeeds/BoundedPriceFeed.js +2 -6
  128. package/dist/cjs/sdk/market/pricefeeds/CompositePriceFeed.js +2 -2
  129. package/dist/cjs/sdk/market/pricefeeds/ConstantPriceFeed.js +2 -2
  130. package/dist/cjs/sdk/market/pricefeeds/CurveCryptoPriceFeed.js +9 -2
  131. package/dist/cjs/sdk/market/pricefeeds/CurveStablePriceFeed.js +9 -2
  132. package/dist/cjs/sdk/market/pricefeeds/CurveUSDPriceFeed.js +9 -2
  133. package/dist/cjs/sdk/market/pricefeeds/Erc4626PriceFeed.js +18 -2
  134. package/dist/cjs/sdk/market/pricefeeds/ExternalPriceFeed.js +2 -2
  135. package/dist/cjs/sdk/market/pricefeeds/MellowLRTPriceFeed.js +10 -2
  136. package/dist/cjs/sdk/market/pricefeeds/PendleTWAPPTPriceFeed.js +2 -2
  137. package/dist/cjs/sdk/market/pricefeeds/PriceFeedRef.js +4 -6
  138. package/dist/cjs/sdk/market/pricefeeds/PriceFeedsRegister.js +3 -2
  139. package/dist/cjs/sdk/market/pricefeeds/PythPriceFeed.js +2 -2
  140. package/dist/cjs/sdk/market/pricefeeds/RedstonePriceFeed.js +3 -3
  141. package/dist/cjs/sdk/market/pricefeeds/WstETHPriceFeed.js +9 -2
  142. package/dist/cjs/sdk/market/pricefeeds/YearnPriceFeed.js +9 -2
  143. package/dist/cjs/sdk/market/pricefeeds/ZeroPriceFeed.js +2 -2
  144. package/dist/cjs/sdk/market/pricefeeds/updates/PriceUpdatesCache.js +0 -17
  145. package/dist/cjs/sdk/market/pricefeeds/updates/PythUpdater.js +9 -7
  146. package/dist/cjs/sdk/market/pricefeeds/updates/RedstoneUpdater.js +12 -10
  147. package/dist/cjs/sdk/router/AbstractRouterContract.js +0 -5
  148. package/dist/cjs/sdk/router/RouterV310Contract.js +3 -3
  149. package/dist/cjs/sdk/router/createRouter.js +0 -4
  150. package/dist/cjs/sdk/utils/index.js +0 -2
  151. package/dist/esm/dev/create2.js +2 -2
  152. package/dist/esm/dev/mint/AbstractMinter.js +7 -3
  153. package/dist/esm/dev/mint/DealMinter.js +3 -0
  154. package/dist/esm/dev/mint/DirectMinter.js +3 -0
  155. package/dist/esm/dev/mint/FallbackMinter.js +1 -1
  156. package/dist/esm/dev/mint/TransferMinter.js +3 -0
  157. package/dist/esm/permissionless/bindings/address-provider.js +7 -7
  158. package/dist/esm/permissionless/bindings/base-contract.js +151 -0
  159. package/dist/esm/permissionless/bindings/bytecode-repository.js +24 -22
  160. package/dist/esm/permissionless/bindings/compressors/token-compressor.js +3 -3
  161. package/dist/esm/permissionless/bindings/compressors/withdrawal-compressor.js +16 -10
  162. package/dist/esm/permissionless/bindings/cross-chain-multisig.js +16 -20
  163. package/dist/esm/permissionless/bindings/factory/abstract-factory.js +4 -9
  164. package/dist/esm/permissionless/bindings/governance/batches-chain.js +3 -3
  165. package/dist/esm/permissionless/bindings/governance/governor.js +47 -28
  166. package/dist/esm/permissionless/bindings/governance/timelock.js +3 -3
  167. package/dist/esm/permissionless/bindings/index.js +1 -0
  168. package/dist/esm/permissionless/bindings/instance-manager.js +69 -53
  169. package/dist/esm/permissionless/bindings/market-configurator-factory.js +3 -3
  170. package/dist/esm/permissionless/bindings/market-configurator.js +137 -65
  171. package/dist/esm/permissionless/bindings/price-feed-store.js +14 -8
  172. package/dist/esm/permissionless/bindings/router/routing-manager.js +14 -8
  173. package/dist/esm/permissionless/bindings/treasury-splitter.js +22 -15
  174. package/dist/esm/permissionless/core/raw-tx.js +1 -1
  175. package/dist/esm/permissionless/utils/abi-decoder.js +50 -0
  176. package/dist/esm/permissionless/utils/format.js +1 -1
  177. package/dist/esm/permissionless/utils/governance/timelock-txs.js +1 -1
  178. package/dist/esm/permissionless/utils/index.js +1 -0
  179. package/dist/esm/permissionless/utils/price-update/get-price-feeds.js +2 -4
  180. package/dist/esm/permissionless/utils/price-update/get-price-update-tx.js +1 -1
  181. package/dist/esm/permissionless/utils/price-update/get-prices.js +2 -1
  182. package/dist/esm/permissionless/utils/price-update/get-updatable-feeds.js +1 -1
  183. package/dist/esm/plugins/adapters/contracts/AbstractAdapter.js +2 -2
  184. package/dist/esm/plugins/adapters/contracts/AccountMigratorAdapterContract.js +2 -2
  185. package/dist/esm/plugins/adapters/contracts/BalancerV2VaultAdapterContract.js +2 -2
  186. package/dist/esm/plugins/adapters/contracts/BalancerV3RouterAdapterContract.js +2 -2
  187. package/dist/esm/plugins/adapters/contracts/BalancerV3WrapperAdapterContract.js +2 -2
  188. package/dist/esm/plugins/adapters/contracts/CamelotV3AdapterContract.js +2 -2
  189. package/dist/esm/plugins/adapters/contracts/ConvexV1BaseRewardPoolAdapterContract.js +2 -2
  190. package/dist/esm/plugins/adapters/contracts/ConvexV1BoosterAdapterContract.js +2 -2
  191. package/dist/esm/plugins/adapters/contracts/Curve2AssetsAdapterContract.js +2 -2
  192. package/dist/esm/plugins/adapters/contracts/Curve3AssetsAdapterContract.js +2 -2
  193. package/dist/esm/plugins/adapters/contracts/Curve4AssetsAdapterContract.js +2 -2
  194. package/dist/esm/plugins/adapters/contracts/CurveV1AdapterDeposit.js +2 -2
  195. package/dist/esm/plugins/adapters/contracts/CurveV1AdapterStETHContract.js +2 -2
  196. package/dist/esm/plugins/adapters/contracts/CurveV1StableNGAdapterContract.js +2 -2
  197. package/dist/esm/plugins/adapters/contracts/DaiUsdsAdapterContract.js +2 -2
  198. package/dist/esm/plugins/adapters/contracts/ERC4626AdapterContract.js +2 -2
  199. package/dist/esm/plugins/adapters/contracts/ERC4626ReferralAdapterContract.js +2 -2
  200. package/dist/esm/plugins/adapters/contracts/EqualizerRouterAdapterContract.js +2 -2
  201. package/dist/esm/plugins/adapters/contracts/FluidDexAdapterContract.js +2 -2
  202. package/dist/esm/plugins/adapters/contracts/InfinifiGatewayAdapterContract.js +2 -2
  203. package/dist/esm/plugins/adapters/contracts/InfinifiUnwindingGatewayAdapterContract.js +2 -2
  204. package/dist/esm/plugins/adapters/contracts/InfraredVaultAdapterContract.js +2 -2
  205. package/dist/esm/plugins/adapters/contracts/KelpLRTDepositPoolAdapterContract.js +2 -2
  206. package/dist/esm/plugins/adapters/contracts/KelpLRTWithdrawalManagerAdapterContract.js +2 -2
  207. package/dist/esm/plugins/adapters/contracts/KodiakIslandGatewayAdapterContract.js +2 -2
  208. package/dist/esm/plugins/adapters/contracts/LidoV1AdapterContract.js +2 -2
  209. package/dist/esm/plugins/adapters/contracts/MellowClaimerAdapterContract.js +2 -2
  210. package/dist/esm/plugins/adapters/contracts/MellowDVVAdapterContract.js +2 -2
  211. package/dist/esm/plugins/adapters/contracts/MellowDepositQueueAdapterContract.js +2 -2
  212. package/dist/esm/plugins/adapters/contracts/MellowERC4626VaultAdapterContract.js +2 -2
  213. package/dist/esm/plugins/adapters/contracts/MellowRedeemQueueAdapterContract.js +2 -2
  214. package/dist/esm/plugins/adapters/contracts/MellowVaultAdapterContract.js +2 -2
  215. package/dist/esm/plugins/adapters/contracts/MellowWrapperAdapterContract.js +2 -2
  216. package/dist/esm/plugins/adapters/contracts/MidasIssuanceVaultAdapterContract.js +2 -2
  217. package/dist/esm/plugins/adapters/contracts/MidasRedemptionVaultAdapterContract.js +2 -2
  218. package/dist/esm/plugins/adapters/contracts/PendleRouterAdapterContract.js +2 -2
  219. package/dist/esm/plugins/adapters/contracts/StakingRewardsAdapterContract.js +2 -2
  220. package/dist/esm/plugins/adapters/contracts/TraderJoeRouterAdapterContract.js +2 -2
  221. package/dist/esm/plugins/adapters/contracts/UniswapV2AdapterContract.js +5 -5
  222. package/dist/esm/plugins/adapters/contracts/UniswapV3AdapterContract.js +22 -22
  223. package/dist/esm/plugins/adapters/contracts/UniswapV4AdapterContract.js +2 -2
  224. package/dist/esm/plugins/adapters/contracts/UpshiftVaultAdapterContract.js +2 -2
  225. package/dist/esm/plugins/adapters/contracts/VelodromeV2AdapterContract.js +2 -2
  226. package/dist/esm/plugins/adapters/contracts/WstETHV1AdapterContract.js +2 -2
  227. package/dist/esm/plugins/adapters/contracts/YearnV2AdapterContract.js +2 -2
  228. package/dist/esm/plugins/bots/BotsPlugin.js +108 -11
  229. package/dist/esm/plugins/bots/PartialLiquidationBotBaseContract.js +16 -7
  230. package/dist/esm/plugins/bots/PartialLiquidationBotV300Contract.js +20 -4
  231. package/dist/esm/plugins/bots/config.js +33 -0
  232. package/dist/esm/plugins/bots/index.js +2 -0
  233. package/dist/esm/plugins/bots/types.js +8 -0
  234. package/dist/esm/plugins/zappers/ZappersPlugin.js +1 -1
  235. package/dist/esm/sdk/GearboxSDK.js +112 -10
  236. package/dist/esm/sdk/accountMigration/AbstractMigrateCreditAccountsService.js +4 -1
  237. package/dist/esm/sdk/accounts/AbstractCreditAccountsService.js +9 -7
  238. package/dist/esm/sdk/base/AddressLabeller.js +25 -0
  239. package/dist/esm/sdk/base/BaseContract.js +81 -202
  240. package/dist/esm/sdk/base/IAddressLabeller.js +0 -0
  241. package/dist/esm/sdk/base/SDKConstruct.js +29 -3
  242. package/dist/esm/sdk/base/TokensMeta.js +4 -4
  243. package/dist/esm/sdk/base/index.js +1 -2
  244. package/dist/esm/sdk/core/BotListV3Contract.js +2 -2
  245. package/dist/esm/sdk/core/GearStakingV3Contract.js +2 -2
  246. package/dist/esm/sdk/core/address-provider/AbstractAddressProviderContract.js +2 -2
  247. package/dist/esm/sdk/core/address-provider/AddressProviderV300Contract.js +6 -11
  248. package/dist/esm/sdk/core/address-provider/AddressProviderV310Contract.js +4 -4
  249. package/dist/esm/sdk/market/MarketConfiguratorContract.js +5 -5
  250. package/dist/esm/sdk/market/MarketRegister.js +10 -8
  251. package/dist/esm/sdk/market/MarketSuite.js +2 -2
  252. package/dist/esm/sdk/market/credit/CreditConfiguratorV300Contract.js +3 -4
  253. package/dist/esm/sdk/market/credit/CreditConfiguratorV310Contract.js +3 -4
  254. package/dist/esm/sdk/market/credit/CreditFacadeV300Contract.js +9 -9
  255. package/dist/esm/sdk/market/credit/CreditFacadeV310Contract.js +8 -8
  256. package/dist/esm/sdk/market/credit/CreditManagerV300Contract.js +2 -5
  257. package/dist/esm/sdk/market/credit/CreditManagerV310Contract.js +2 -5
  258. package/dist/esm/sdk/market/credit/CreditSuite.js +3 -2
  259. package/dist/esm/sdk/market/loss-policy/AliasLossPolicyV310Contract.js +1 -3
  260. package/dist/esm/sdk/market/loss-policy/LossPolicyContract.js +3 -5
  261. package/dist/esm/sdk/market/loss-policy/createLossPolicy.js +1 -1
  262. package/dist/esm/sdk/market/oracle/PriceOracleBaseContract.js +26 -8
  263. package/dist/esm/sdk/market/oracle/createPriceOracle.js +1 -1
  264. package/dist/esm/sdk/market/pool/GaugeContract.js +2 -2
  265. package/dist/esm/sdk/market/pool/LinearInterestRateModelContract.js +2 -2
  266. package/dist/esm/sdk/market/pool/PoolQuotaKeeperV300Contract.js +2 -2
  267. package/dist/esm/sdk/market/pool/PoolQuotaKeeperV310Contract.js +2 -2
  268. package/dist/esm/sdk/market/pool/PoolSuite.js +1 -1
  269. package/dist/esm/sdk/market/pool/PoolV300Contract.js +5 -5
  270. package/dist/esm/sdk/market/pool/PoolV310Contract.js +5 -5
  271. package/dist/esm/sdk/market/pool/TumblerContract.js +2 -2
  272. package/dist/esm/sdk/market/pool/createInterestRateModel.js +15 -11
  273. package/dist/esm/sdk/market/pricefeeds/AbstractLPPriceFeed.js +22 -2
  274. package/dist/esm/sdk/market/pricefeeds/AbstractPriceFeed.js +3 -3
  275. package/dist/esm/sdk/market/pricefeeds/BalancerStablePriceFeed.js +13 -3
  276. package/dist/esm/sdk/market/pricefeeds/BalancerWeightedPriceFeed.js +13 -3
  277. package/dist/esm/sdk/market/pricefeeds/BoundedPriceFeed.js +2 -6
  278. package/dist/esm/sdk/market/pricefeeds/CompositePriceFeed.js +2 -2
  279. package/dist/esm/sdk/market/pricefeeds/ConstantPriceFeed.js +2 -2
  280. package/dist/esm/sdk/market/pricefeeds/CurveCryptoPriceFeed.js +10 -3
  281. package/dist/esm/sdk/market/pricefeeds/CurveStablePriceFeed.js +10 -3
  282. package/dist/esm/sdk/market/pricefeeds/CurveUSDPriceFeed.js +10 -3
  283. package/dist/esm/sdk/market/pricefeeds/Erc4626PriceFeed.js +18 -2
  284. package/dist/esm/sdk/market/pricefeeds/ExternalPriceFeed.js +2 -2
  285. package/dist/esm/sdk/market/pricefeeds/MellowLRTPriceFeed.js +11 -3
  286. package/dist/esm/sdk/market/pricefeeds/PendleTWAPPTPriceFeed.js +2 -2
  287. package/dist/esm/sdk/market/pricefeeds/PriceFeedRef.js +5 -7
  288. package/dist/esm/sdk/market/pricefeeds/PriceFeedsRegister.js +9 -3
  289. package/dist/esm/sdk/market/pricefeeds/PythPriceFeed.js +2 -2
  290. package/dist/esm/sdk/market/pricefeeds/RedstonePriceFeed.js +3 -3
  291. package/dist/esm/sdk/market/pricefeeds/WstETHPriceFeed.js +10 -3
  292. package/dist/esm/sdk/market/pricefeeds/YearnPriceFeed.js +10 -3
  293. package/dist/esm/sdk/market/pricefeeds/ZeroPriceFeed.js +2 -2
  294. package/dist/esm/sdk/market/pricefeeds/updates/PriceUpdatesCache.js +0 -17
  295. package/dist/esm/sdk/market/pricefeeds/updates/PythUpdater.js +10 -8
  296. package/dist/esm/sdk/market/pricefeeds/updates/RedstoneUpdater.js +13 -11
  297. package/dist/esm/sdk/router/AbstractRouterContract.js +0 -5
  298. package/dist/esm/sdk/router/RouterV310Contract.js +3 -3
  299. package/dist/esm/sdk/router/createRouter.js +0 -4
  300. package/dist/esm/sdk/utils/index.js +0 -1
  301. package/dist/types/dev/create2.d.ts +2 -2
  302. package/dist/types/dev/mint/AbstractMinter.d.ts +4 -3
  303. package/dist/types/dev/mint/DealMinter.d.ts +3 -0
  304. package/dist/types/dev/mint/DirectMinter.d.ts +3 -0
  305. package/dist/types/dev/mint/TransferMinter.d.ts +3 -0
  306. package/dist/types/permissionless/bindings/address-provider.d.ts +255 -4
  307. package/dist/types/permissionless/bindings/base-contract.d.ts +23 -0
  308. package/dist/types/permissionless/bindings/bytecode-repository.d.ts +6 -5
  309. package/dist/types/permissionless/bindings/compressors/token-compressor.d.ts +3 -3
  310. package/dist/types/permissionless/bindings/compressors/withdrawal-compressor.d.ts +5 -4
  311. package/dist/types/permissionless/bindings/cross-chain-multisig.d.ts +7 -7
  312. package/dist/types/permissionless/bindings/factory/abstract-factory.d.ts +1 -1
  313. package/dist/types/permissionless/bindings/governance/batches-chain.d.ts +4 -3
  314. package/dist/types/permissionless/bindings/governance/governor.d.ts +7 -6
  315. package/dist/types/permissionless/bindings/governance/timelock.d.ts +3 -3
  316. package/dist/types/permissionless/bindings/governance/types.d.ts +1 -1
  317. package/dist/types/permissionless/bindings/index.d.ts +1 -0
  318. package/dist/types/permissionless/bindings/instance-manager.d.ts +7 -6
  319. package/dist/types/permissionless/bindings/market-configurator-factory.d.ts +4 -4
  320. package/dist/types/permissionless/bindings/market-configurator.d.ts +6 -6
  321. package/dist/types/permissionless/bindings/price-feed-store.d.ts +7 -6
  322. package/dist/types/permissionless/bindings/router/routing-manager.d.ts +5 -4
  323. package/dist/types/permissionless/bindings/treasury-splitter.d.ts +6 -5
  324. package/dist/types/permissionless/core/proposal.d.ts +7 -1
  325. package/dist/types/permissionless/utils/abi-decoder.d.ts +13 -0
  326. package/dist/types/permissionless/utils/create2.d.ts +1 -1
  327. package/dist/types/permissionless/utils/governance/batch.d.ts +1 -1
  328. package/dist/types/permissionless/utils/index.d.ts +1 -0
  329. package/dist/types/permissionless/utils/price-update/get-price-feeds.d.ts +3 -3
  330. package/dist/types/permissionless/utils/price-update/get-price-update-tx.d.ts +2 -2
  331. package/dist/types/plugins/adapters/contracts/AbstractAdapter.d.ts +2 -2
  332. package/dist/types/plugins/adapters/contracts/AccountMigratorAdapterContract.d.ts +2 -2
  333. package/dist/types/plugins/adapters/contracts/BalancerV2VaultAdapterContract.d.ts +2 -2
  334. package/dist/types/plugins/adapters/contracts/BalancerV3RouterAdapterContract.d.ts +2 -2
  335. package/dist/types/plugins/adapters/contracts/BalancerV3WrapperAdapterContract.d.ts +2 -2
  336. package/dist/types/plugins/adapters/contracts/CamelotV3AdapterContract.d.ts +2 -2
  337. package/dist/types/plugins/adapters/contracts/ConvexV1BaseRewardPoolAdapterContract.d.ts +2 -2
  338. package/dist/types/plugins/adapters/contracts/ConvexV1BoosterAdapterContract.d.ts +2 -2
  339. package/dist/types/plugins/adapters/contracts/Curve2AssetsAdapterContract.d.ts +2 -2
  340. package/dist/types/plugins/adapters/contracts/Curve3AssetsAdapterContract.d.ts +2 -2
  341. package/dist/types/plugins/adapters/contracts/Curve4AssetsAdapterContract.d.ts +2 -2
  342. package/dist/types/plugins/adapters/contracts/CurveV1AdapterDeposit.d.ts +2 -2
  343. package/dist/types/plugins/adapters/contracts/CurveV1AdapterStETHContract.d.ts +2 -2
  344. package/dist/types/plugins/adapters/contracts/CurveV1StableNGAdapterContract.d.ts +2 -2
  345. package/dist/types/plugins/adapters/contracts/DaiUsdsAdapterContract.d.ts +2 -2
  346. package/dist/types/plugins/adapters/contracts/ERC4626AdapterContract.d.ts +2 -2
  347. package/dist/types/plugins/adapters/contracts/ERC4626ReferralAdapterContract.d.ts +2 -2
  348. package/dist/types/plugins/adapters/contracts/EqualizerRouterAdapterContract.d.ts +2 -2
  349. package/dist/types/plugins/adapters/contracts/FluidDexAdapterContract.d.ts +2 -2
  350. package/dist/types/plugins/adapters/contracts/InfinifiGatewayAdapterContract.d.ts +2 -2
  351. package/dist/types/plugins/adapters/contracts/InfinifiUnwindingGatewayAdapterContract.d.ts +2 -2
  352. package/dist/types/plugins/adapters/contracts/InfraredVaultAdapterContract.d.ts +2 -2
  353. package/dist/types/plugins/adapters/contracts/KelpLRTDepositPoolAdapterContract.d.ts +2 -2
  354. package/dist/types/plugins/adapters/contracts/KelpLRTWithdrawalManagerAdapterContract.d.ts +2 -2
  355. package/dist/types/plugins/adapters/contracts/KodiakIslandGatewayAdapterContract.d.ts +2 -2
  356. package/dist/types/plugins/adapters/contracts/LidoV1AdapterContract.d.ts +2 -2
  357. package/dist/types/plugins/adapters/contracts/MellowClaimerAdapterContract.d.ts +2 -2
  358. package/dist/types/plugins/adapters/contracts/MellowDVVAdapterContract.d.ts +2 -2
  359. package/dist/types/plugins/adapters/contracts/MellowDepositQueueAdapterContract.d.ts +2 -2
  360. package/dist/types/plugins/adapters/contracts/MellowERC4626VaultAdapterContract.d.ts +2 -2
  361. package/dist/types/plugins/adapters/contracts/MellowRedeemQueueAdapterContract.d.ts +2 -2
  362. package/dist/types/plugins/adapters/contracts/MellowVaultAdapterContract.d.ts +2 -2
  363. package/dist/types/plugins/adapters/contracts/MellowWrapperAdapterContract.d.ts +2 -2
  364. package/dist/types/plugins/adapters/contracts/MidasIssuanceVaultAdapterContract.d.ts +2 -2
  365. package/dist/types/plugins/adapters/contracts/MidasRedemptionVaultAdapterContract.d.ts +2 -2
  366. package/dist/types/plugins/adapters/contracts/PendleRouterAdapterContract.d.ts +2 -2
  367. package/dist/types/plugins/adapters/contracts/StakingRewardsAdapterContract.d.ts +2 -2
  368. package/dist/types/plugins/adapters/contracts/TraderJoeRouterAdapterContract.d.ts +2 -2
  369. package/dist/types/plugins/adapters/contracts/UniswapV2AdapterContract.d.ts +3 -3
  370. package/dist/types/plugins/adapters/contracts/UniswapV3AdapterContract.d.ts +3 -3
  371. package/dist/types/plugins/adapters/contracts/UniswapV4AdapterContract.d.ts +2 -2
  372. package/dist/types/plugins/adapters/contracts/UpshiftVaultAdapterContract.d.ts +16 -2
  373. package/dist/types/plugins/adapters/contracts/VelodromeV2AdapterContract.d.ts +2 -2
  374. package/dist/types/plugins/adapters/contracts/WstETHV1AdapterContract.d.ts +2 -2
  375. package/dist/types/plugins/adapters/contracts/YearnV2AdapterContract.d.ts +2 -2
  376. package/dist/types/plugins/bots/BotsPlugin.d.ts +3 -2
  377. package/dist/types/plugins/bots/PartialLiquidationBotBaseContract.d.ts +1 -1
  378. package/dist/types/plugins/bots/PartialLiquidationBotV300Contract.d.ts +8 -2
  379. package/dist/types/plugins/bots/config.d.ts +6 -0
  380. package/dist/types/plugins/bots/index.d.ts +2 -0
  381. package/dist/types/plugins/bots/types.d.ts +16 -0
  382. package/dist/types/sdk/GearboxSDK.d.ts +76 -5
  383. package/dist/types/sdk/accountMigration/AbstractMigrateCreditAccountsService.d.ts +2 -2
  384. package/dist/types/sdk/accountMigration/types.d.ts +2 -1
  385. package/dist/types/sdk/accounts/types.d.ts +3 -4
  386. package/dist/types/sdk/base/AddressLabeller.d.ts +11 -0
  387. package/dist/types/sdk/base/BaseContract.d.ts +28 -72
  388. package/dist/types/sdk/base/IAddressLabeller.d.ts +9 -0
  389. package/dist/types/sdk/base/PlaceholderContract.d.ts +2 -2
  390. package/dist/types/sdk/base/SDKConstruct.d.ts +16 -2
  391. package/dist/types/sdk/base/TokensMeta.d.ts +3 -2
  392. package/dist/types/sdk/base/index.d.ts +1 -2
  393. package/dist/types/sdk/base/types.d.ts +0 -50
  394. package/dist/types/sdk/core/BotListV3Contract.d.ts +1 -1
  395. package/dist/types/sdk/core/GearStakingV3Contract.d.ts +1 -1
  396. package/dist/types/sdk/core/address-provider/AbstractAddressProviderContract.d.ts +4 -3
  397. package/dist/types/sdk/core/address-provider/AddressProviderV300Contract.d.ts +3 -3
  398. package/dist/types/sdk/core/address-provider/AddressProviderV310Contract.d.ts +3 -3
  399. package/dist/types/sdk/market/MarketConfiguratorContract.d.ts +2 -2
  400. package/dist/types/sdk/market/credit/CreditConfiguratorV300Contract.d.ts +3 -3
  401. package/dist/types/sdk/market/credit/CreditConfiguratorV310Contract.d.ts +3 -3
  402. package/dist/types/sdk/market/credit/CreditFacadeV300Contract.d.ts +4 -3
  403. package/dist/types/sdk/market/credit/CreditFacadeV310Contract.d.ts +4 -3
  404. package/dist/types/sdk/market/credit/CreditManagerV300Contract.d.ts +1 -1
  405. package/dist/types/sdk/market/credit/CreditManagerV310Contract.d.ts +1 -1
  406. package/dist/types/sdk/market/credit/CreditSuite.d.ts +1 -1
  407. package/dist/types/sdk/market/credit/types.d.ts +2 -1
  408. package/dist/types/sdk/market/loss-policy/AliasLossPolicyV310Contract.d.ts +0 -1
  409. package/dist/types/sdk/market/loss-policy/LossPolicyContract.d.ts +3 -2
  410. package/dist/types/sdk/market/oracle/PriceOracleBaseContract.d.ts +12 -3
  411. package/dist/types/sdk/market/oracle/types.d.ts +10 -0
  412. package/dist/types/sdk/market/pool/GaugeContract.d.ts +3 -2
  413. package/dist/types/sdk/market/pool/LinearInterestRateModelContract.d.ts +3 -2
  414. package/dist/types/sdk/market/pool/PoolQuotaKeeperV300Contract.d.ts +3 -2
  415. package/dist/types/sdk/market/pool/PoolQuotaKeeperV310Contract.d.ts +3 -2
  416. package/dist/types/sdk/market/pool/PoolV300Contract.d.ts +5 -4
  417. package/dist/types/sdk/market/pool/PoolV310Contract.d.ts +5 -4
  418. package/dist/types/sdk/market/pool/TumblerContract.d.ts +3 -2
  419. package/dist/types/sdk/market/pricefeeds/AbstractLPPriceFeed.d.ts +8 -3
  420. package/dist/types/sdk/market/pricefeeds/AbstractPriceFeed.d.ts +3 -2
  421. package/dist/types/sdk/market/pricefeeds/BalancerStablePriceFeed.d.ts +3 -2
  422. package/dist/types/sdk/market/pricefeeds/BalancerWeightedPriceFeed.d.ts +3 -2
  423. package/dist/types/sdk/market/pricefeeds/BoundedPriceFeed.d.ts +2 -2
  424. package/dist/types/sdk/market/pricefeeds/CompositePriceFeed.d.ts +2 -2
  425. package/dist/types/sdk/market/pricefeeds/ConstantPriceFeed.d.ts +2 -2
  426. package/dist/types/sdk/market/pricefeeds/CurveCryptoPriceFeed.d.ts +3 -2
  427. package/dist/types/sdk/market/pricefeeds/CurveStablePriceFeed.d.ts +3 -2
  428. package/dist/types/sdk/market/pricefeeds/CurveUSDPriceFeed.d.ts +3 -2
  429. package/dist/types/sdk/market/pricefeeds/Erc4626PriceFeed.d.ts +3 -2
  430. package/dist/types/sdk/market/pricefeeds/ExternalPriceFeed.d.ts +2 -2
  431. package/dist/types/sdk/market/pricefeeds/MellowLRTPriceFeed.d.ts +3 -2
  432. package/dist/types/sdk/market/pricefeeds/PendleTWAPPTPriceFeed.d.ts +2 -2
  433. package/dist/types/sdk/market/pricefeeds/PriceFeedRef.d.ts +4 -3
  434. package/dist/types/sdk/market/pricefeeds/PriceFeedsRegister.d.ts +2 -1
  435. package/dist/types/sdk/market/pricefeeds/PythPriceFeed.d.ts +2 -2
  436. package/dist/types/sdk/market/pricefeeds/RedstonePriceFeed.d.ts +2 -2
  437. package/dist/types/sdk/market/pricefeeds/WstETHPriceFeed.d.ts +3 -2
  438. package/dist/types/sdk/market/pricefeeds/YearnPriceFeed.d.ts +3 -2
  439. package/dist/types/sdk/market/pricefeeds/ZeroPriceFeed.d.ts +2 -2
  440. package/dist/types/sdk/market/pricefeeds/types.d.ts +5 -0
  441. package/dist/types/sdk/market/pricefeeds/updates/PriceUpdatesCache.d.ts +1 -8
  442. package/dist/types/sdk/router/AbstractRouterContract.d.ts +1 -4
  443. package/dist/types/sdk/router/types.d.ts +2 -1
  444. package/dist/types/sdk/sdk-legacy/core/creditAccount.d.ts +2 -2
  445. package/dist/types/sdk/utils/index.d.ts +0 -1
  446. package/package.json +10 -10
  447. package/dist/cjs/plugins/bots/deserializePartialLiquidationBotParams.js +0 -49
  448. package/dist/cjs/sdk/base/ChainContractsRegister.js +0 -135
  449. package/dist/cjs/sdk/base/Construct.js +0 -87
  450. package/dist/cjs/sdk/utils/abi-decode.js +0 -58
  451. package/dist/esm/plugins/bots/deserializePartialLiquidationBotParams.js +0 -29
  452. package/dist/esm/sdk/base/ChainContractsRegister.js +0 -111
  453. package/dist/esm/sdk/base/Construct.js +0 -63
  454. package/dist/esm/sdk/utils/abi-decode.js +0 -37
  455. package/dist/types/plugins/bots/deserializePartialLiquidationBotParams.d.ts +0 -3
  456. package/dist/types/sdk/base/ChainContractsRegister.d.ts +0 -57
  457. package/dist/types/sdk/base/Construct.d.ts +0 -38
  458. package/dist/types/sdk/utils/abi-decode.d.ts +0 -10
@@ -21,7 +21,7 @@ class MarketSuite extends SDKConstruct {
21
21
  constructor(sdk, marketData) {
22
22
  super(sdk);
23
23
  this.state = marketData;
24
- const mc = sdk.mustGetContract(marketData.configurator);
24
+ const mc = sdk.contracts.mustGet(marketData.configurator);
25
25
  if (!(mc instanceof MarketConfiguratorContract)) {
26
26
  throw new Error(
27
27
  `Market configurator ${marketData.configurator} is not a market configurator`
@@ -32,7 +32,7 @@ class MarketSuite extends SDKConstruct {
32
32
  this.treasury = marketData.treasury;
33
33
  for (const t of marketData.tokens) {
34
34
  sdk.tokensMeta.upsert(t.addr, t);
35
- sdk.setAddressLabel(t.addr, t.symbol);
35
+ sdk.addressLabels.set(t.addr, t.symbol);
36
36
  }
37
37
  this.pool = new PoolSuite(sdk, marketData);
38
38
  for (let i = 0; i < marketData.creditManagers.length; i++) {
@@ -5,7 +5,7 @@ import { RAMP_DURATION_BY_NETWORK } from "../../constants/index.js";
5
5
  import { formatDuration, percentFmt } from "../../utils/index.js";
6
6
  const abi = [...iCreditConfiguratorV300Abi, ...iPausableAbi];
7
7
  class CreditConfiguratorV300Contract extends BaseContract {
8
- sdk;
8
+ adapters = [];
9
9
  isPaused = false;
10
10
  constructor(sdk, { creditConfigurator, creditManager }) {
11
11
  super(sdk, {
@@ -13,7 +13,6 @@ class CreditConfiguratorV300Contract extends BaseContract {
13
13
  name: `CreditConfigurator(${creditManager.name})`,
14
14
  abi
15
15
  });
16
- this.sdk = sdk;
17
16
  }
18
17
  processLog(log) {
19
18
  switch (log.eventName) {
@@ -60,7 +59,7 @@ class CreditConfiguratorV300Contract extends BaseContract {
60
59
  });
61
60
  return logs.map(({ args }) => args);
62
61
  }
63
- stringifyFunctionParams(params) {
62
+ parseFunctionParams(params) {
64
63
  switch (params.functionName) {
65
64
  case "addCollateralToken":
66
65
  case "setLiquidationThreshold": {
@@ -106,7 +105,7 @@ class CreditConfiguratorV300Contract extends BaseContract {
106
105
  ];
107
106
  }
108
107
  default:
109
- return super.stringifyFunctionParams(params);
108
+ return void 0;
110
109
  }
111
110
  }
112
111
  }
@@ -4,7 +4,7 @@ import { RAMP_DURATION_BY_NETWORK } from "../../constants/index.js";
4
4
  import { formatDuration, percentFmt } from "../../utils/index.js";
5
5
  const abi = iCreditConfiguratorV310Abi;
6
6
  class CreditConfiguratorV310Contract extends BaseContract {
7
- sdk;
7
+ adapters = [];
8
8
  isPaused = false;
9
9
  constructor(sdk, { creditConfigurator, creditManager }) {
10
10
  super(sdk, {
@@ -12,7 +12,6 @@ class CreditConfiguratorV310Contract extends BaseContract {
12
12
  name: `CreditConfigurator(${creditManager.name})`,
13
13
  abi
14
14
  });
15
- this.sdk = sdk;
16
15
  }
17
16
  processLog(log) {
18
17
  switch (log.eventName) {
@@ -47,7 +46,7 @@ class CreditConfiguratorV310Contract extends BaseContract {
47
46
  });
48
47
  return logs.map(({ args }) => args);
49
48
  }
50
- stringifyFunctionParams(params) {
49
+ parseFunctionParams(params) {
51
50
  switch (params.functionName) {
52
51
  case "addCollateralToken":
53
52
  case "setLiquidationThreshold": {
@@ -91,7 +90,7 @@ class CreditConfiguratorV310Contract extends BaseContract {
91
90
  ];
92
91
  }
93
92
  default:
94
- return super.stringifyFunctionParams(params);
93
+ return void 0;
95
94
  }
96
95
  }
97
96
  }
@@ -13,9 +13,9 @@ const abi = [
13
13
  ];
14
14
  class CreditFacadeV300Contract extends BaseContract {
15
15
  underlying;
16
- constructor(options, { creditFacade, creditManager }) {
16
+ constructor(sdk, { creditFacade, creditManager }) {
17
17
  const { baseParams, ...rest } = creditFacade;
18
- super(options, {
18
+ super(sdk, {
19
19
  ...baseParams,
20
20
  name: `CreditFacadeV3(${creditManager.name})`,
21
21
  abi
@@ -24,7 +24,7 @@ class CreditFacadeV300Contract extends BaseContract {
24
24
  this.underlying = creditManager.underlying;
25
25
  }
26
26
  stateHuman(raw) {
27
- const decimals = this.tokensMeta.decimals(this.underlying);
27
+ const decimals = this.sdk.tokensMeta.decimals(this.underlying);
28
28
  return {
29
29
  ...super.stateHuman(raw),
30
30
  expirable: this.expirable,
@@ -88,13 +88,13 @@ class CreditFacadeV300Contract extends BaseContract {
88
88
  args: [to, calls, referralCode]
89
89
  });
90
90
  }
91
- stringifyFunctionParams(params) {
91
+ parseFunctionParams(params) {
92
92
  switch (params.functionName) {
93
93
  case "openCreditAccount": {
94
94
  const [onBehalfOf, calls, referralCode] = params.args;
95
95
  return [
96
96
  this.labelAddress(onBehalfOf),
97
- this.register.parseMultiCall([...calls]).join(","),
97
+ this.sdk.parseMultiCall([...calls]).join(","),
98
98
  `${referralCode}`
99
99
  ];
100
100
  }
@@ -102,7 +102,7 @@ class CreditFacadeV300Contract extends BaseContract {
102
102
  const [creditAccount, calls] = params.args;
103
103
  return [
104
104
  this.labelAddress(creditAccount),
105
- this.register.parseMultiCall([...calls]).join(",")
105
+ this.sdk.parseMultiCall([...calls]).join(",")
106
106
  ];
107
107
  }
108
108
  case "liquidateCreditAccount": {
@@ -110,7 +110,7 @@ class CreditFacadeV300Contract extends BaseContract {
110
110
  return [
111
111
  this.labelAddress(creditAccount),
112
112
  this.labelAddress(to),
113
- this.register.parseMultiCall([...calls]).join(",")
113
+ this.sdk.parseMultiCall([...calls]).join(",")
114
114
  ];
115
115
  }
116
116
  case "setBotPermissions": {
@@ -125,12 +125,12 @@ class CreditFacadeV300Contract extends BaseContract {
125
125
  const [deltas] = params.args;
126
126
  return [
127
127
  deltas.map(({ token, amount }) => {
128
- return this.labelAddress(token) + ": " + this.tokensMeta.formatBN(token, amount);
128
+ return this.labelAddress(token) + ": " + this.sdk.tokensMeta.formatBN(token, amount);
129
129
  }).join(",")
130
130
  ];
131
131
  }
132
132
  default:
133
- return super.stringifyFunctionParams(params);
133
+ return void 0;
134
134
  }
135
135
  }
136
136
  }
@@ -13,9 +13,9 @@ const abi = [
13
13
  ];
14
14
  class CreditFacadeV310Contract extends BaseContract {
15
15
  underlying;
16
- constructor(options, { creditFacade, creditManager }) {
16
+ constructor(sdk, { creditFacade, creditManager }) {
17
17
  const { baseParams, ...rest } = creditFacade;
18
- super(options, {
18
+ super(sdk, {
19
19
  ...baseParams,
20
20
  name: `CreditFacadeV310(${creditManager.name})`,
21
21
  abi
@@ -24,7 +24,7 @@ class CreditFacadeV310Contract extends BaseContract {
24
24
  this.underlying = creditManager.underlying;
25
25
  }
26
26
  stateHuman(raw) {
27
- const decimals = this.tokensMeta.decimals(this.underlying);
27
+ const decimals = this.sdk.tokensMeta.decimals(this.underlying);
28
28
  return {
29
29
  ...super.stateHuman(raw),
30
30
  expirable: this.expirable,
@@ -85,13 +85,13 @@ class CreditFacadeV310Contract extends BaseContract {
85
85
  args: [to, calls, referralCode]
86
86
  });
87
87
  }
88
- stringifyFunctionParams(params) {
88
+ parseFunctionParams(params) {
89
89
  switch (params.functionName) {
90
90
  case "openCreditAccount": {
91
91
  const [onBehalfOf, calls, referralCode] = params.args;
92
92
  return [
93
93
  this.labelAddress(onBehalfOf),
94
- this.register.parseMultiCall([...calls]).join(","),
94
+ this.sdk.parseMultiCall([...calls]).join(","),
95
95
  `${referralCode}`
96
96
  ];
97
97
  }
@@ -99,7 +99,7 @@ class CreditFacadeV310Contract extends BaseContract {
99
99
  const [creditAccount, calls] = params.args;
100
100
  return [
101
101
  this.labelAddress(creditAccount),
102
- this.register.parseMultiCall([...calls]).join(",")
102
+ this.sdk.parseMultiCall([...calls]).join(",")
103
103
  ];
104
104
  }
105
105
  case "liquidateCreditAccount": {
@@ -107,11 +107,11 @@ class CreditFacadeV310Contract extends BaseContract {
107
107
  return [
108
108
  this.labelAddress(creditAccount),
109
109
  this.labelAddress(to),
110
- this.register.parseMultiCall([...calls]).join(",")
110
+ this.sdk.parseMultiCall([...calls]).join(",")
111
111
  ];
112
112
  }
113
113
  default:
114
- return super.stringifyFunctionParams(params);
114
+ return void 0;
115
115
  }
116
116
  }
117
117
  }
@@ -27,12 +27,9 @@ class CreditManagerV300Contract extends BaseContract {
27
27
  this.adapters = new AddressMap(void 0, "adapters");
28
28
  for (const adapterData of adapters) {
29
29
  try {
30
- const adapter = createAdapter(sdk, adapterData);
30
+ const adapter = createAdapter(this.sdk, adapterData);
31
+ adapter.name = `${adapter.name}(${this.name})`;
31
32
  this.adapters.upsert(adapter.targetContract, adapter);
32
- this.register.setAddressLabel(
33
- adapter.address,
34
- `${adapter.name}(${this.name})`
35
- );
36
33
  } catch (e) {
37
34
  throw new Error(`cannot attach adapter: ${e}`, { cause: e });
38
35
  }
@@ -27,12 +27,9 @@ class CreditManagerV310Contract extends BaseContract {
27
27
  this.adapters = new AddressMap(void 0, "adapters");
28
28
  for (const adapterData of adapters) {
29
29
  try {
30
- const adapter = createAdapter(sdk, adapterData);
30
+ const adapter = createAdapter(this.sdk, adapterData);
31
+ adapter.name = `${adapter.name}(${this.name})`;
31
32
  this.adapters.upsert(adapter.targetContract, adapter);
32
- this.register.setAddressLabel(
33
- adapter.address,
34
- `${adapter.name}(${this.name})`
35
- );
36
33
  } catch (e) {
37
34
  throw new Error(`cannot attach adapter: ${e}`, { cause: e });
38
35
  }
@@ -3,6 +3,7 @@ import createCreditConfigurator from "./createCreditConfigurator.js";
3
3
  import createCreditFacade from "./createCreditFacade.js";
4
4
  import createCreditManager from "./createCreditManager.js";
5
5
  class CreditSuite extends SDKConstruct {
6
+ name;
6
7
  pool;
7
8
  underlying;
8
9
  creditManager;
@@ -10,12 +11,12 @@ class CreditSuite extends SDKConstruct {
10
11
  creditConfigurator;
11
12
  marketConfigurator;
12
13
  state;
13
- name;
14
14
  constructor(sdk, marketData, index) {
15
15
  super(sdk);
16
16
  const { creditManagers, pool } = marketData;
17
- this.name = creditManagers[index].creditManager.name;
18
17
  this.state = creditManagers[index];
18
+ const { name } = this.state.creditManager;
19
+ this.name = name;
19
20
  this.pool = pool.baseParams.addr;
20
21
  this.underlying = pool.underlying;
21
22
  this.creditManager = createCreditManager(sdk, this.state);
@@ -12,7 +12,6 @@ class AliasLossPolicyV310Contract extends BaseContract {
12
12
  checksEnabled;
13
13
  tokens;
14
14
  priceFeedParams;
15
- sdk;
16
15
  constructor(sdk, params) {
17
16
  super(sdk, {
18
17
  abi,
@@ -20,7 +19,6 @@ class AliasLossPolicyV310Contract extends BaseContract {
20
19
  contractType: params.contractType,
21
20
  version: params.version
22
21
  });
23
- this.sdk = sdk;
24
22
  [this.accessMode, this.checksEnabled, this.tokens, this.priceFeedParams] = decodeAbiParameters(
25
23
  [
26
24
  { name: "accessMode", type: "uint8" },
@@ -41,7 +39,7 @@ class AliasLossPolicyV310Contract extends BaseContract {
41
39
  );
42
40
  }
43
41
  async getLiquidationData(creditAccount, blockNumber) {
44
- const pfs = await this.client.readContract({
42
+ const pfs = await this.sdk.client.readContract({
45
43
  address: this.address,
46
44
  abi: this.abi,
47
45
  functionName: "getRequiredAliasPriceFeeds",
@@ -1,11 +1,9 @@
1
1
  import { iLossPolicyV310Abi } from "../../../abi/310/generated.js";
2
- import {
3
- BaseContract
4
- } from "../../base/index.js";
2
+ import { BaseContract } from "../../base/index.js";
5
3
  const abi = iLossPolicyV310Abi;
6
4
  class LossPolicyContract extends BaseContract {
7
- constructor(options, params) {
8
- super(options, {
5
+ constructor(sdk, params) {
6
+ super(sdk, {
9
7
  abi,
10
8
  addr: params.addr,
11
9
  contractType: params.contractType,
@@ -3,7 +3,7 @@ import { AliasLossPolicyV310Contract } from "./AliasLossPolicyV310Contract.js";
3
3
  import { LOSS_POLICY_ALIASED, LOSS_POLICY_DEFAULT } from "./constants.js";
4
4
  import { LossPolicyContract } from "./LossPolicyContract.js";
5
5
  function createLossPolicy(sdk, { baseParams }) {
6
- const existing = sdk.getContract(baseParams.addr);
6
+ const existing = sdk.contracts.get(baseParams.addr);
7
7
  if (existing) {
8
8
  return existing;
9
9
  }
@@ -12,7 +12,6 @@ import { PriceFeedRef } from "../pricefeeds/index.js";
12
12
  import PriceFeedAnswerMap from "./PriceFeedAnswerMap.js";
13
13
  const ZERO_PRICE_FEED = stringToHex("PRICE_FEED::ZERO", { size: 32 });
14
14
  class PriceOracleBaseContract extends BaseContract {
15
- sdk;
16
15
  /**
17
16
  * Mapping Token => [PriceFeed Address, stalenessPeriod]
18
17
  */
@@ -44,7 +43,6 @@ class PriceOracleBaseContract extends BaseContract {
44
43
  );
45
44
  constructor(sdk, args, data) {
46
45
  super(sdk, args);
47
- this.sdk = sdk;
48
46
  const { priceFeedMap, priceFeedTree } = data;
49
47
  this.#loadState(priceFeedMap, priceFeedTree, true);
50
48
  }
@@ -62,6 +60,19 @@ class PriceOracleBaseContract extends BaseContract {
62
60
  reserve ? this.reservePriceFeeds.get(t)?.priceFeed : void 0
63
61
  ]).filter((f) => !!f);
64
62
  }
63
+ /**
64
+ * Generates updates for all updateable price feeds in this oracle (including dependencies)
65
+ * @returns
66
+ */
67
+ async updatePriceFeeds() {
68
+ const updatables = [];
69
+ for (const node of this.#priceFeedTree.values()) {
70
+ if (node.updatable) {
71
+ updatables.push(this.sdk.priceFeeds.mustGet(node.baseParams.addr));
72
+ }
73
+ }
74
+ return this.sdk.priceFeeds.generatePriceFeedsUpdateTxs(updatables);
75
+ }
65
76
  /**
66
77
  * Gets main price for given token
67
78
  * Throws if token price feed is not found or answer is not successful
@@ -101,9 +112,9 @@ class PriceOracleBaseContract extends BaseContract {
101
112
  return amount;
102
113
  }
103
114
  const fromPrice = reserve ? this.reservePrice(from) : this.mainPrice(from);
104
- const fromScale = 10n ** BigInt(this.tokensMeta.decimals(from));
115
+ const fromScale = 10n ** BigInt(this.sdk.tokensMeta.decimals(from));
105
116
  const toPrice = reserve ? this.reservePrice(to) : this.mainPrice(to);
106
- const toScale = 10n ** BigInt(this.tokensMeta.decimals(to));
117
+ const toScale = 10n ** BigInt(this.sdk.tokensMeta.decimals(to));
107
118
  return amount * fromPrice * toScale / (toPrice * fromScale);
108
119
  }
109
120
  /**
@@ -114,7 +125,7 @@ class PriceOracleBaseContract extends BaseContract {
114
125
  */
115
126
  convertToUSD(from, amount, reserve = false) {
116
127
  const price = reserve ? this.reservePrice(from) : this.mainPrice(from);
117
- const scale = 10n ** BigInt(this.tokensMeta.decimals(from));
128
+ const scale = 10n ** BigInt(this.sdk.tokensMeta.decimals(from));
118
129
  return amount * price / scale;
119
130
  }
120
131
  /**
@@ -125,9 +136,16 @@ class PriceOracleBaseContract extends BaseContract {
125
136
  */
126
137
  convertFromUSD(to, amount, reserve = false) {
127
138
  const price = reserve ? this.reservePrice(to) : this.mainPrice(to);
128
- const scale = 10n ** BigInt(this.tokensMeta.decimals(to));
139
+ const scale = 10n ** BigInt(this.sdk.tokensMeta.decimals(to));
129
140
  return amount * scale / price;
130
141
  }
142
+ /**
143
+ * Loads new prices for this oracle from PriceFeedCompressor
144
+ * Will (re)create price feeds if needed
145
+ */
146
+ async updatePrices() {
147
+ await this.sdk.marketRegister.updatePrices([this.address]);
148
+ }
131
149
  /**
132
150
  * All price feed tree nodes known to this oracle
133
151
  */
@@ -216,8 +234,8 @@ class PriceOracleBaseContract extends BaseContract {
216
234
  this.dirty = false;
217
235
  }
218
236
  #labelPriceFeed(address, usage, token) {
219
- this.sdk.setAddressLabel(address, (oldLabel) => {
220
- const symbol = this.tokensMeta.symbol(token);
237
+ this.sdk.addressLabels.set(address, (oldLabel) => {
238
+ const symbol = this.sdk.tokensMeta.symbol(token);
221
239
  let pricefeedTag = `${symbol}.${usage}`;
222
240
  if (oldLabel) {
223
241
  const oldLabelParts = new Set(oldLabel.split(", "));
@@ -4,7 +4,7 @@ import { PriceOracleV300Contract } from "./PriceOracleV300Contract.js";
4
4
  import { PriceOracleV310Contract } from "./PriceOracleV310Contract.js";
5
5
  function getOrCreatePriceOracle(sdk, data) {
6
6
  const { version, addr } = data.baseParams;
7
- const existing = sdk.getContract(addr);
7
+ const existing = sdk.contracts.get(addr);
8
8
  let result;
9
9
  if (existing) {
10
10
  result = tryExtendExistingOracle(existing, data);
@@ -9,8 +9,8 @@ class GaugeContract extends BaseContract {
9
9
  epochFrozen;
10
10
  epochLastUpdate;
11
11
  rates;
12
- constructor(options, pool, gauge) {
13
- super(options, {
12
+ constructor(sdk, pool, gauge) {
13
+ super(sdk, {
14
14
  ...gauge.baseParams,
15
15
  name: `Gauge(${pool.name})`,
16
16
  abi: iGaugeV300Abi
@@ -11,8 +11,8 @@ class LinearInterestRateModelContract extends BaseContract {
11
11
  Rslope2;
12
12
  Rslope3;
13
13
  isBorrowingMoreU2Forbidden;
14
- constructor(options, params) {
15
- super(options, {
14
+ constructor(sdk, params) {
15
+ super(sdk, {
16
16
  ...params.baseParams,
17
17
  name: "LinearInterestRateModel",
18
18
  abi
@@ -5,8 +5,8 @@ const abi = iPoolQuotaKeeperV300Abi;
5
5
  class PoolQuotaKeeperV300Contract extends BaseContract {
6
6
  decimals;
7
7
  quotas;
8
- constructor(options, pool, pqk) {
9
- super(options, {
8
+ constructor(sdk, pool, pqk) {
9
+ super(sdk, {
10
10
  ...pqk.baseParams,
11
11
  name: `PoolQuotaKeeper(${pool.name})`,
12
12
  abi
@@ -5,8 +5,8 @@ const abi = iPoolQuotaKeeperV310Abi;
5
5
  class PoolQuotaKeeperV310Contract extends BaseContract {
6
6
  decimals;
7
7
  quotas;
8
- constructor(options, pool, pqk) {
9
- super(options, {
8
+ constructor(sdk, pool, pqk) {
9
+ super(sdk, {
10
10
  ...pqk.baseParams,
11
11
  name: `PoolQuotaKeeper(${pool.name})`,
12
12
  abi
@@ -48,7 +48,7 @@ class PoolSuite extends SDKConstruct {
48
48
  );
49
49
  }
50
50
  get marketConfigurator() {
51
- return this.register.mustGetContract(
51
+ return this.sdk.contracts.mustGet(
52
52
  this.#marketConfigurator
53
53
  );
54
54
  }
@@ -10,9 +10,9 @@ import {
10
10
  const abi = [...iPoolV300Abi, ...iPausableAbi];
11
11
  class PoolV300Contract extends BaseContract {
12
12
  creditManagerDebtParams;
13
- constructor(options, data) {
13
+ constructor(sdk, data) {
14
14
  const { baseParams, creditManagerDebtParams, ...rest } = data;
15
- super(options, {
15
+ super(sdk, {
16
16
  ...data.baseParams,
17
17
  name: `PoolV3(${data.name})`,
18
18
  abi
@@ -21,7 +21,7 @@ class PoolV300Contract extends BaseContract {
21
21
  this.creditManagerDebtParams = new AddressMap(
22
22
  creditManagerDebtParams.map((p) => [p.creditManager, p])
23
23
  );
24
- this.register.tokensMeta.upsert(data.baseParams.addr, {
24
+ sdk.tokensMeta.upsert(data.baseParams.addr, {
25
25
  addr: data.baseParams.addr,
26
26
  decimals: data.decimals,
27
27
  name: data.name,
@@ -100,14 +100,14 @@ class PoolV300Contract extends BaseContract {
100
100
  break;
101
101
  }
102
102
  }
103
- stringifyFunctionParams(params) {
103
+ parseFunctionParams(params) {
104
104
  switch (params.functionName) {
105
105
  case "deposit": {
106
106
  const [amount, onBehalfOf] = params.args;
107
107
  return [formatBN(amount, this.decimals), this.labelAddress(onBehalfOf)];
108
108
  }
109
109
  default:
110
- return super.stringifyFunctionParams(params);
110
+ return void 0;
111
111
  }
112
112
  }
113
113
  }
@@ -10,9 +10,9 @@ import {
10
10
  const abi = [...iPoolV310Abi, ...iPausableAbi];
11
11
  class PoolV310Contract extends BaseContract {
12
12
  creditManagerDebtParams;
13
- constructor(options, data) {
13
+ constructor(sdk, data) {
14
14
  const { baseParams, creditManagerDebtParams, ...rest } = data;
15
- super(options, {
15
+ super(sdk, {
16
16
  ...data.baseParams,
17
17
  name: `PoolV3(${data.name})`,
18
18
  abi
@@ -21,7 +21,7 @@ class PoolV310Contract extends BaseContract {
21
21
  this.creditManagerDebtParams = new AddressMap(
22
22
  creditManagerDebtParams.map((p) => [p.creditManager, p])
23
23
  );
24
- this.register.tokensMeta.upsert(data.baseParams.addr, {
24
+ sdk.tokensMeta.upsert(data.baseParams.addr, {
25
25
  addr: data.baseParams.addr,
26
26
  decimals: data.decimals,
27
27
  name: data.name,
@@ -100,14 +100,14 @@ class PoolV310Contract extends BaseContract {
100
100
  break;
101
101
  }
102
102
  }
103
- stringifyFunctionParams(params) {
103
+ parseFunctionParams(params) {
104
104
  switch (params.functionName) {
105
105
  case "deposit": {
106
106
  const [amount, onBehalfOf] = params.args;
107
107
  return [formatBN(amount, this.decimals), this.labelAddress(onBehalfOf)];
108
108
  }
109
109
  default:
110
- return super.stringifyFunctionParams(params);
110
+ return void 0;
111
111
  }
112
112
  }
113
113
  }
@@ -6,8 +6,8 @@ const abi = iTumblerV310Abi;
6
6
  class TumblerContract extends BaseContract {
7
7
  epochLength;
8
8
  rates;
9
- constructor(options, pool, tumbler) {
10
- super(options, {
9
+ constructor(sdk, pool, tumbler) {
10
+ super(sdk, {
11
11
  ...tumbler.baseParams,
12
12
  name: `Tumbler(${pool.name})`,
13
13
  abi
@@ -2,17 +2,21 @@ import { bytes32ToString } from "../../utils/index.js";
2
2
  import { LinearInterestRateModelContract } from "./LinearInterestRateModelContract.js";
3
3
  function createInterestRateModel(sdk, data) {
4
4
  const { addr, contractType } = data.baseParams;
5
- const existing = sdk.getContract(addr);
6
- if (existing) {
7
- return existing;
8
- }
9
- const modelType = bytes32ToString(contractType);
10
- switch (modelType) {
11
- case "IRM::LINEAR": {
12
- return new LinearInterestRateModelContract(sdk, data);
13
- }
14
- default: {
15
- throw new Error(`Unknown interest rate model type: ${modelType}`);
5
+ if (sdk.interestRateModels.has(addr)) {
6
+ return sdk.interestRateModels.mustGet(
7
+ addr
8
+ );
9
+ } else {
10
+ const modelType = bytes32ToString(contractType);
11
+ switch (modelType) {
12
+ case "IRM::LINEAR": {
13
+ const linearModel = new LinearInterestRateModelContract(sdk, data);
14
+ sdk.interestRateModels.insert(addr, linearModel);
15
+ return linearModel;
16
+ }
17
+ default: {
18
+ throw new Error(`Unknown interest rate model type: ${modelType}`);
19
+ }
16
20
  }
17
21
  }
18
22
  }
@@ -1,8 +1,10 @@
1
1
  import { decodeAbiParameters, hexToBytes } from "viem";
2
+ import { ilpPriceFeedAbi } from "../../abi/index.js";
2
3
  import { isV310 } from "../../constants/versions.js";
3
4
  import {
4
5
  AbstractPriceFeedContract
5
6
  } from "./AbstractPriceFeed.js";
7
+ const LOWER_BOUND_FACTOR = 99n;
6
8
  class AbstractLPPriceFeedContract extends AbstractPriceFeedContract {
7
9
  lpContract;
8
10
  lpToken;
@@ -12,8 +14,8 @@ class AbstractLPPriceFeedContract extends AbstractPriceFeedContract {
12
14
  exchangeRate;
13
15
  aggregatePrice;
14
16
  scale;
15
- constructor(options, args) {
16
- super(options, { ...args, decimals: 8 });
17
+ constructor(sdk, args) {
18
+ super(sdk, { ...args, decimals: 8 });
17
19
  this.hasLowerBoundCap = true;
18
20
  if (isV310(args.baseParams.version)) {
19
21
  const decoder = decodeAbiParameters(
@@ -59,6 +61,24 @@ class AbstractLPPriceFeedContract extends AbstractPriceFeedContract {
59
61
  this.scale = decoder[4].scale;
60
62
  }
61
63
  }
64
+ async getLowerBound() {
65
+ const value = await this.getValue();
66
+ const lowerBound = AbstractLPPriceFeedContract.toLowerBound(value);
67
+ this.logger?.debug(
68
+ `Lowerbound for ${this.labelAddress(this.address)}: ${lowerBound}`
69
+ );
70
+ return lowerBound;
71
+ }
72
+ async currentLowerBound() {
73
+ return await this.sdk.client.readContract({
74
+ abi: ilpPriceFeedAbi,
75
+ address: this.address,
76
+ functionName: "lowerBound"
77
+ });
78
+ }
79
+ static toLowerBound(value) {
80
+ return value * LOWER_BOUND_FACTOR / 100n;
81
+ }
62
82
  stateHuman(raw) {
63
83
  return {
64
84
  ...super.stateHuman(raw),
@@ -23,8 +23,8 @@ class AbstractPriceFeedContract extends BaseContract {
23
23
  #args;
24
24
  hasLowerBoundCap = false;
25
25
  description;
26
- constructor(options, args) {
27
- super(options, {
26
+ constructor(sdk, args) {
27
+ super(sdk, {
28
28
  abi: args.abi,
29
29
  addr: args.baseParams.addr,
30
30
  name: args.name + (args.description ? ` ${args.description}` : ""),
@@ -40,7 +40,7 @@ class AbstractPriceFeedContract extends BaseContract {
40
40
  if (args.underlyingFeeds && args.underlyingStalenessPeriods) {
41
41
  const underlyingStalenessPeriods = args.underlyingStalenessPeriods;
42
42
  this.#underlyingPriceFeeds = args.underlyingFeeds.map(
43
- (address, i) => new PriceFeedRef(options, address, underlyingStalenessPeriods[i])
43
+ (address, i) => new PriceFeedRef(this.sdk, address, underlyingStalenessPeriods[i])
44
44
  );
45
45
  }
46
46
  }