@gearbox-protocol/sdk 11.10.0 → 11.11.0-next.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.
- package/dist/cjs/dev/create2.js +1 -1
- package/dist/cjs/dev/mint/AbstractMinter.js +2 -4
- package/dist/cjs/dev/mint/DealMinter.js +0 -3
- package/dist/cjs/dev/mint/DirectMinter.js +0 -3
- package/dist/cjs/dev/mint/FallbackMinter.js +1 -1
- package/dist/cjs/dev/mint/TransferMinter.js +0 -3
- package/dist/cjs/permissionless/bindings/address-provider.js +4 -6
- package/dist/cjs/permissionless/bindings/bytecode-repository.js +23 -25
- package/dist/cjs/permissionless/bindings/compressors/token-compressor.js +4 -4
- package/dist/cjs/permissionless/bindings/compressors/withdrawal-compressor.js +11 -17
- package/dist/cjs/permissionless/bindings/cross-chain-multisig.js +23 -22
- package/dist/cjs/permissionless/bindings/factory/abstract-factory.js +7 -4
- package/dist/cjs/permissionless/bindings/governance/batches-chain.js +4 -4
- package/dist/cjs/permissionless/bindings/governance/governor.js +30 -49
- package/dist/cjs/permissionless/bindings/governance/timelock.js +4 -4
- package/dist/cjs/permissionless/bindings/index.js +0 -2
- package/dist/cjs/permissionless/bindings/instance-manager.js +58 -77
- package/dist/cjs/permissionless/bindings/market-configurator-factory.js +4 -4
- package/dist/cjs/permissionless/bindings/market-configurator.js +71 -143
- package/dist/cjs/permissionless/bindings/price-feed-store.js +8 -17
- package/dist/cjs/permissionless/bindings/router/routing-manager.js +9 -15
- package/dist/cjs/permissionless/bindings/treasury-splitter.js +14 -23
- package/dist/cjs/permissionless/core/raw-tx.js +2 -2
- package/dist/cjs/permissionless/utils/format.js +2 -2
- package/dist/cjs/permissionless/utils/governance/timelock-txs.js +2 -2
- package/dist/cjs/permissionless/utils/index.js +0 -2
- package/dist/cjs/permissionless/utils/price-update/get-price-feeds.js +1 -2
- package/dist/cjs/permissionless/utils/price-update/get-price-update-tx.js +1 -2
- package/dist/cjs/permissionless/utils/price-update/get-prices.js +1 -2
- package/dist/cjs/permissionless/utils/price-update/get-updatable-feeds.js +2 -3
- package/dist/cjs/plugins/adapters/contracts/AbstractAdapter.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/AccountMigratorAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/BalancerV2VaultAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/BalancerV3RouterAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/BalancerV3WrapperAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/CamelotV3AdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/ConvexV1BaseRewardPoolAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/ConvexV1BoosterAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/Curve2AssetsAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/Curve3AssetsAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/Curve4AssetsAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/CurveV1AdapterDeposit.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/CurveV1AdapterStETHContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/CurveV1StableNGAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/DaiUsdsAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/ERC4626AdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/ERC4626ReferralAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/EqualizerRouterAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/FluidDexAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/InfinifiGatewayAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/InfinifiUnwindingGatewayAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/InfraredVaultAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/KelpLRTDepositPoolAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/KelpLRTWithdrawalManagerAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/KodiakIslandGatewayAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/LidoV1AdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/MellowClaimerAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/MellowDVVAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/MellowDepositQueueAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/MellowERC4626VaultAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/MellowRedeemQueueAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/MellowVaultAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/MellowWrapperAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/MidasIssuanceVaultAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/MidasRedemptionVaultAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/PendleRouterAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/StakingRewardsAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/TraderJoeRouterAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/UniswapV2AdapterContract.js +5 -5
- package/dist/cjs/plugins/adapters/contracts/UniswapV3AdapterContract.js +22 -22
- package/dist/cjs/plugins/adapters/contracts/UniswapV4AdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/UpshiftVaultAdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/VelodromeV2AdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/WstETHV1AdapterContract.js +2 -2
- package/dist/cjs/plugins/adapters/contracts/YearnV2AdapterContract.js +2 -2
- package/dist/cjs/plugins/bots/BotsPlugin.js +21 -8
- package/dist/cjs/plugins/bots/PartialLiquidationBotBaseContract.js +17 -22
- package/dist/cjs/plugins/bots/PartialLiquidationBotV300Contract.js +4 -20
- package/dist/cjs/plugins/bots/deserializePartialLiquidationBotParams.js +49 -0
- package/dist/cjs/plugins/zappers/ZappersPlugin.js +1 -1
- package/dist/cjs/sdk/GearboxSDK.js +8 -110
- package/dist/cjs/sdk/accountMigration/AbstractMigrateCreditAccountsService.js +1 -4
- package/dist/cjs/sdk/accounts/AbstractCreditAccountsService.js +6 -8
- package/dist/cjs/sdk/base/BaseContract.js +195 -80
- package/dist/cjs/sdk/base/ChainContractsRegister.js +135 -0
- package/dist/cjs/sdk/base/Construct.js +87 -0
- package/dist/cjs/sdk/base/SDKConstruct.js +3 -29
- package/dist/cjs/sdk/base/TokensMeta.js +4 -4
- package/dist/cjs/sdk/base/index.js +4 -2
- package/dist/cjs/sdk/core/BotListV3Contract.js +2 -2
- package/dist/cjs/sdk/core/GearStakingV3Contract.js +2 -2
- package/dist/cjs/sdk/core/address-provider/AbstractAddressProviderContract.js +2 -2
- package/dist/cjs/sdk/core/address-provider/AddressProviderV300Contract.js +11 -6
- package/dist/cjs/sdk/core/address-provider/AddressProviderV310Contract.js +4 -4
- package/dist/cjs/sdk/market/MarketConfiguratorContract.js +5 -5
- package/dist/cjs/sdk/market/MarketRegister.js +7 -9
- package/dist/cjs/sdk/market/MarketSuite.js +2 -2
- package/dist/cjs/sdk/market/credit/CreditConfiguratorV300Contract.js +4 -3
- package/dist/cjs/sdk/market/credit/CreditConfiguratorV310Contract.js +4 -3
- package/dist/cjs/sdk/market/credit/CreditFacadeV300Contract.js +9 -9
- package/dist/cjs/sdk/market/credit/CreditFacadeV310Contract.js +8 -8
- package/dist/cjs/sdk/market/credit/CreditManagerV300Contract.js +5 -2
- package/dist/cjs/sdk/market/credit/CreditManagerV310Contract.js +5 -2
- package/dist/cjs/sdk/market/credit/CreditSuite.js +2 -3
- package/dist/cjs/sdk/market/loss-policy/AliasLossPolicyV310Contract.js +3 -1
- package/dist/cjs/sdk/market/loss-policy/LossPolicyContract.js +2 -2
- package/dist/cjs/sdk/market/loss-policy/createLossPolicy.js +1 -1
- package/dist/cjs/sdk/market/oracle/PriceOracleBaseContract.js +8 -26
- package/dist/cjs/sdk/market/oracle/createPriceOracle.js +1 -1
- package/dist/cjs/sdk/market/pool/GaugeContract.js +2 -2
- package/dist/cjs/sdk/market/pool/LinearInterestRateModelContract.js +2 -2
- package/dist/cjs/sdk/market/pool/PoolQuotaKeeperV300Contract.js +2 -2
- package/dist/cjs/sdk/market/pool/PoolQuotaKeeperV310Contract.js +2 -2
- package/dist/cjs/sdk/market/pool/PoolSuite.js +1 -1
- package/dist/cjs/sdk/market/pool/PoolV300Contract.js +5 -5
- package/dist/cjs/sdk/market/pool/PoolV310Contract.js +5 -5
- package/dist/cjs/sdk/market/pool/TumblerContract.js +2 -2
- package/dist/cjs/sdk/market/pool/createInterestRateModel.js +11 -15
- package/dist/cjs/sdk/market/pricefeeds/AbstractLPPriceFeed.js +2 -22
- package/dist/cjs/sdk/market/pricefeeds/AbstractPriceFeed.js +3 -3
- package/dist/cjs/sdk/market/pricefeeds/BalancerStablePriceFeed.js +2 -9
- package/dist/cjs/sdk/market/pricefeeds/BalancerWeightedPriceFeed.js +2 -9
- package/dist/cjs/sdk/market/pricefeeds/BoundedPriceFeed.js +6 -2
- package/dist/cjs/sdk/market/pricefeeds/CompositePriceFeed.js +2 -2
- package/dist/cjs/sdk/market/pricefeeds/ConstantPriceFeed.js +2 -2
- package/dist/cjs/sdk/market/pricefeeds/CurveCryptoPriceFeed.js +2 -9
- package/dist/cjs/sdk/market/pricefeeds/CurveStablePriceFeed.js +2 -9
- package/dist/cjs/sdk/market/pricefeeds/CurveUSDPriceFeed.js +2 -9
- package/dist/cjs/sdk/market/pricefeeds/Erc4626PriceFeed.js +2 -18
- package/dist/cjs/sdk/market/pricefeeds/ExternalPriceFeed.js +2 -2
- package/dist/cjs/sdk/market/pricefeeds/MellowLRTPriceFeed.js +2 -10
- package/dist/cjs/sdk/market/pricefeeds/PendleTWAPPTPriceFeed.js +2 -2
- package/dist/cjs/sdk/market/pricefeeds/PriceFeedRef.js +6 -4
- package/dist/cjs/sdk/market/pricefeeds/PriceFeedsRegister.js +2 -3
- package/dist/cjs/sdk/market/pricefeeds/PythPriceFeed.js +2 -2
- package/dist/cjs/sdk/market/pricefeeds/RedstonePriceFeed.js +3 -3
- package/dist/cjs/sdk/market/pricefeeds/WstETHPriceFeed.js +2 -9
- package/dist/cjs/sdk/market/pricefeeds/YearnPriceFeed.js +2 -9
- package/dist/cjs/sdk/market/pricefeeds/ZeroPriceFeed.js +2 -2
- package/dist/cjs/sdk/market/pricefeeds/updates/PythUpdater.js +6 -8
- package/dist/cjs/sdk/market/pricefeeds/updates/RedstoneUpdater.js +9 -11
- package/dist/cjs/sdk/router/AbstractRouterContract.js +5 -0
- package/dist/cjs/sdk/router/RouterV310Contract.js +3 -3
- package/dist/cjs/sdk/router/createRouter.js +4 -0
- package/dist/cjs/sdk/utils/abi-decode.js +58 -0
- package/dist/cjs/sdk/utils/index.js +2 -0
- package/dist/esm/dev/create2.js +2 -2
- package/dist/esm/dev/mint/AbstractMinter.js +3 -7
- package/dist/esm/dev/mint/DealMinter.js +0 -3
- package/dist/esm/dev/mint/DirectMinter.js +0 -3
- package/dist/esm/dev/mint/FallbackMinter.js +1 -1
- package/dist/esm/dev/mint/TransferMinter.js +0 -3
- package/dist/esm/permissionless/bindings/address-provider.js +7 -7
- package/dist/esm/permissionless/bindings/bytecode-repository.js +22 -24
- package/dist/esm/permissionless/bindings/compressors/token-compressor.js +3 -3
- package/dist/esm/permissionless/bindings/compressors/withdrawal-compressor.js +10 -16
- package/dist/esm/permissionless/bindings/cross-chain-multisig.js +20 -16
- package/dist/esm/permissionless/bindings/factory/abstract-factory.js +9 -4
- package/dist/esm/permissionless/bindings/governance/batches-chain.js +3 -3
- package/dist/esm/permissionless/bindings/governance/governor.js +28 -47
- package/dist/esm/permissionless/bindings/governance/timelock.js +3 -3
- package/dist/esm/permissionless/bindings/index.js +0 -1
- package/dist/esm/permissionless/bindings/instance-manager.js +53 -69
- package/dist/esm/permissionless/bindings/market-configurator-factory.js +3 -3
- package/dist/esm/permissionless/bindings/market-configurator.js +65 -137
- package/dist/esm/permissionless/bindings/price-feed-store.js +8 -14
- package/dist/esm/permissionless/bindings/router/routing-manager.js +8 -14
- package/dist/esm/permissionless/bindings/treasury-splitter.js +15 -22
- package/dist/esm/permissionless/core/raw-tx.js +1 -1
- package/dist/esm/permissionless/utils/format.js +1 -1
- package/dist/esm/permissionless/utils/governance/timelock-txs.js +1 -1
- package/dist/esm/permissionless/utils/index.js +0 -1
- package/dist/esm/permissionless/utils/price-update/get-price-feeds.js +4 -2
- package/dist/esm/permissionless/utils/price-update/get-price-update-tx.js +1 -1
- package/dist/esm/permissionless/utils/price-update/get-prices.js +1 -2
- package/dist/esm/permissionless/utils/price-update/get-updatable-feeds.js +1 -1
- package/dist/esm/plugins/adapters/contracts/AbstractAdapter.js +2 -2
- package/dist/esm/plugins/adapters/contracts/AccountMigratorAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/BalancerV2VaultAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/BalancerV3RouterAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/BalancerV3WrapperAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/CamelotV3AdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/ConvexV1BaseRewardPoolAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/ConvexV1BoosterAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/Curve2AssetsAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/Curve3AssetsAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/Curve4AssetsAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/CurveV1AdapterDeposit.js +2 -2
- package/dist/esm/plugins/adapters/contracts/CurveV1AdapterStETHContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/CurveV1StableNGAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/DaiUsdsAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/ERC4626AdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/ERC4626ReferralAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/EqualizerRouterAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/FluidDexAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/InfinifiGatewayAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/InfinifiUnwindingGatewayAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/InfraredVaultAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/KelpLRTDepositPoolAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/KelpLRTWithdrawalManagerAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/KodiakIslandGatewayAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/LidoV1AdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/MellowClaimerAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/MellowDVVAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/MellowDepositQueueAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/MellowERC4626VaultAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/MellowRedeemQueueAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/MellowVaultAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/MellowWrapperAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/MidasIssuanceVaultAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/MidasRedemptionVaultAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/PendleRouterAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/StakingRewardsAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/TraderJoeRouterAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/UniswapV2AdapterContract.js +5 -5
- package/dist/esm/plugins/adapters/contracts/UniswapV3AdapterContract.js +22 -22
- package/dist/esm/plugins/adapters/contracts/UniswapV4AdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/UpshiftVaultAdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/VelodromeV2AdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/WstETHV1AdapterContract.js +2 -2
- package/dist/esm/plugins/adapters/contracts/YearnV2AdapterContract.js +2 -2
- package/dist/esm/plugins/bots/BotsPlugin.js +11 -8
- package/dist/esm/plugins/bots/PartialLiquidationBotBaseContract.js +7 -22
- package/dist/esm/plugins/bots/PartialLiquidationBotV300Contract.js +4 -20
- package/dist/esm/plugins/bots/deserializePartialLiquidationBotParams.js +29 -0
- package/dist/esm/plugins/zappers/ZappersPlugin.js +1 -1
- package/dist/esm/sdk/GearboxSDK.js +10 -112
- package/dist/esm/sdk/accountMigration/AbstractMigrateCreditAccountsService.js +1 -4
- package/dist/esm/sdk/accounts/AbstractCreditAccountsService.js +7 -9
- package/dist/esm/sdk/base/BaseContract.js +202 -81
- package/dist/esm/sdk/base/ChainContractsRegister.js +111 -0
- package/dist/esm/sdk/base/Construct.js +63 -0
- package/dist/esm/sdk/base/SDKConstruct.js +3 -29
- package/dist/esm/sdk/base/TokensMeta.js +4 -4
- package/dist/esm/sdk/base/index.js +2 -1
- package/dist/esm/sdk/core/BotListV3Contract.js +2 -2
- package/dist/esm/sdk/core/GearStakingV3Contract.js +2 -2
- package/dist/esm/sdk/core/address-provider/AbstractAddressProviderContract.js +2 -2
- package/dist/esm/sdk/core/address-provider/AddressProviderV300Contract.js +11 -6
- package/dist/esm/sdk/core/address-provider/AddressProviderV310Contract.js +4 -4
- package/dist/esm/sdk/market/MarketConfiguratorContract.js +5 -5
- package/dist/esm/sdk/market/MarketRegister.js +8 -10
- package/dist/esm/sdk/market/MarketSuite.js +2 -2
- package/dist/esm/sdk/market/credit/CreditConfiguratorV300Contract.js +4 -3
- package/dist/esm/sdk/market/credit/CreditConfiguratorV310Contract.js +4 -3
- package/dist/esm/sdk/market/credit/CreditFacadeV300Contract.js +9 -9
- package/dist/esm/sdk/market/credit/CreditFacadeV310Contract.js +8 -8
- package/dist/esm/sdk/market/credit/CreditManagerV300Contract.js +5 -2
- package/dist/esm/sdk/market/credit/CreditManagerV310Contract.js +5 -2
- package/dist/esm/sdk/market/credit/CreditSuite.js +2 -3
- package/dist/esm/sdk/market/loss-policy/AliasLossPolicyV310Contract.js +3 -1
- package/dist/esm/sdk/market/loss-policy/LossPolicyContract.js +5 -3
- package/dist/esm/sdk/market/loss-policy/createLossPolicy.js +1 -1
- package/dist/esm/sdk/market/oracle/PriceOracleBaseContract.js +8 -26
- package/dist/esm/sdk/market/oracle/createPriceOracle.js +1 -1
- package/dist/esm/sdk/market/pool/GaugeContract.js +2 -2
- package/dist/esm/sdk/market/pool/LinearInterestRateModelContract.js +2 -2
- package/dist/esm/sdk/market/pool/PoolQuotaKeeperV300Contract.js +2 -2
- package/dist/esm/sdk/market/pool/PoolQuotaKeeperV310Contract.js +2 -2
- package/dist/esm/sdk/market/pool/PoolSuite.js +1 -1
- package/dist/esm/sdk/market/pool/PoolV300Contract.js +5 -5
- package/dist/esm/sdk/market/pool/PoolV310Contract.js +5 -5
- package/dist/esm/sdk/market/pool/TumblerContract.js +2 -2
- package/dist/esm/sdk/market/pool/createInterestRateModel.js +11 -15
- package/dist/esm/sdk/market/pricefeeds/AbstractLPPriceFeed.js +2 -22
- package/dist/esm/sdk/market/pricefeeds/AbstractPriceFeed.js +3 -3
- package/dist/esm/sdk/market/pricefeeds/BalancerStablePriceFeed.js +3 -13
- package/dist/esm/sdk/market/pricefeeds/BalancerWeightedPriceFeed.js +3 -13
- package/dist/esm/sdk/market/pricefeeds/BoundedPriceFeed.js +6 -2
- package/dist/esm/sdk/market/pricefeeds/CompositePriceFeed.js +2 -2
- package/dist/esm/sdk/market/pricefeeds/ConstantPriceFeed.js +2 -2
- package/dist/esm/sdk/market/pricefeeds/CurveCryptoPriceFeed.js +3 -10
- package/dist/esm/sdk/market/pricefeeds/CurveStablePriceFeed.js +3 -10
- package/dist/esm/sdk/market/pricefeeds/CurveUSDPriceFeed.js +3 -10
- package/dist/esm/sdk/market/pricefeeds/Erc4626PriceFeed.js +2 -18
- package/dist/esm/sdk/market/pricefeeds/ExternalPriceFeed.js +2 -2
- package/dist/esm/sdk/market/pricefeeds/MellowLRTPriceFeed.js +3 -11
- package/dist/esm/sdk/market/pricefeeds/PendleTWAPPTPriceFeed.js +2 -2
- package/dist/esm/sdk/market/pricefeeds/PriceFeedRef.js +7 -5
- package/dist/esm/sdk/market/pricefeeds/PriceFeedsRegister.js +3 -9
- package/dist/esm/sdk/market/pricefeeds/PythPriceFeed.js +2 -2
- package/dist/esm/sdk/market/pricefeeds/RedstonePriceFeed.js +3 -3
- package/dist/esm/sdk/market/pricefeeds/WstETHPriceFeed.js +3 -10
- package/dist/esm/sdk/market/pricefeeds/YearnPriceFeed.js +3 -10
- package/dist/esm/sdk/market/pricefeeds/ZeroPriceFeed.js +2 -2
- package/dist/esm/sdk/market/pricefeeds/updates/PythUpdater.js +7 -9
- package/dist/esm/sdk/market/pricefeeds/updates/RedstoneUpdater.js +10 -12
- package/dist/esm/sdk/router/AbstractRouterContract.js +5 -0
- package/dist/esm/sdk/router/RouterV310Contract.js +3 -3
- package/dist/esm/sdk/router/createRouter.js +4 -0
- package/dist/esm/sdk/utils/abi-decode.js +37 -0
- package/dist/esm/sdk/utils/index.js +1 -0
- package/dist/types/dev/create2.d.ts +2 -2
- package/dist/types/dev/mint/AbstractMinter.d.ts +3 -4
- package/dist/types/dev/mint/DealMinter.d.ts +0 -3
- package/dist/types/dev/mint/DirectMinter.d.ts +0 -3
- package/dist/types/dev/mint/TransferMinter.d.ts +0 -3
- package/dist/types/permissionless/bindings/address-provider.d.ts +4 -255
- package/dist/types/permissionless/bindings/bytecode-repository.d.ts +5 -6
- package/dist/types/permissionless/bindings/compressors/token-compressor.d.ts +3 -3
- package/dist/types/permissionless/bindings/compressors/withdrawal-compressor.d.ts +4 -5
- package/dist/types/permissionless/bindings/cross-chain-multisig.d.ts +7 -7
- package/dist/types/permissionless/bindings/factory/abstract-factory.d.ts +1 -1
- package/dist/types/permissionless/bindings/governance/batches-chain.d.ts +3 -4
- package/dist/types/permissionless/bindings/governance/governor.d.ts +6 -7
- package/dist/types/permissionless/bindings/governance/timelock.d.ts +3 -3
- package/dist/types/permissionless/bindings/governance/types.d.ts +1 -1
- package/dist/types/permissionless/bindings/index.d.ts +0 -1
- package/dist/types/permissionless/bindings/instance-manager.d.ts +6 -7
- package/dist/types/permissionless/bindings/market-configurator-factory.d.ts +4 -4
- package/dist/types/permissionless/bindings/market-configurator.d.ts +6 -6
- package/dist/types/permissionless/bindings/price-feed-store.d.ts +6 -7
- package/dist/types/permissionless/bindings/router/routing-manager.d.ts +4 -5
- package/dist/types/permissionless/bindings/treasury-splitter.d.ts +5 -6
- package/dist/types/permissionless/core/proposal.d.ts +1 -7
- package/dist/types/permissionless/utils/create2.d.ts +1 -1
- package/dist/types/permissionless/utils/governance/batch.d.ts +1 -1
- package/dist/types/permissionless/utils/index.d.ts +0 -1
- package/dist/types/permissionless/utils/price-update/get-price-feeds.d.ts +3 -3
- package/dist/types/permissionless/utils/price-update/get-price-update-tx.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/AbstractAdapter.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/AccountMigratorAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/BalancerV2VaultAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/BalancerV3RouterAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/BalancerV3WrapperAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/CamelotV3AdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/ConvexV1BaseRewardPoolAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/ConvexV1BoosterAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/Curve2AssetsAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/Curve3AssetsAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/Curve4AssetsAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/CurveV1AdapterDeposit.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/CurveV1AdapterStETHContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/CurveV1StableNGAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/DaiUsdsAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/ERC4626AdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/ERC4626ReferralAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/EqualizerRouterAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/FluidDexAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/InfinifiGatewayAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/InfinifiUnwindingGatewayAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/InfraredVaultAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/KelpLRTDepositPoolAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/KelpLRTWithdrawalManagerAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/KodiakIslandGatewayAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/LidoV1AdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/MellowClaimerAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/MellowDVVAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/MellowDepositQueueAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/MellowERC4626VaultAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/MellowRedeemQueueAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/MellowVaultAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/MellowWrapperAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/MidasIssuanceVaultAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/MidasRedemptionVaultAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/PendleRouterAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/StakingRewardsAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/TraderJoeRouterAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/UniswapV2AdapterContract.d.ts +3 -3
- package/dist/types/plugins/adapters/contracts/UniswapV3AdapterContract.d.ts +3 -3
- package/dist/types/plugins/adapters/contracts/UniswapV4AdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/UpshiftVaultAdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/VelodromeV2AdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/WstETHV1AdapterContract.d.ts +2 -2
- package/dist/types/plugins/adapters/contracts/YearnV2AdapterContract.d.ts +2 -2
- package/dist/types/plugins/bots/PartialLiquidationBotV300Contract.d.ts +2 -8
- package/dist/types/plugins/bots/deserializePartialLiquidationBotParams.d.ts +3 -0
- package/dist/types/sdk/GearboxSDK.d.ts +5 -76
- package/dist/types/sdk/accountMigration/types.d.ts +1 -2
- package/dist/types/sdk/accounts/types.d.ts +4 -3
- package/dist/types/sdk/base/BaseContract.d.ts +72 -28
- package/dist/types/sdk/base/ChainContractsRegister.d.ts +57 -0
- package/dist/types/sdk/base/Construct.d.ts +38 -0
- package/dist/types/sdk/base/PlaceholderContract.d.ts +2 -2
- package/dist/types/sdk/base/SDKConstruct.d.ts +2 -16
- package/dist/types/sdk/base/TokensMeta.d.ts +2 -3
- package/dist/types/sdk/base/index.d.ts +2 -1
- package/dist/types/sdk/base/types.d.ts +50 -0
- package/dist/types/sdk/core/BotListV3Contract.d.ts +1 -1
- package/dist/types/sdk/core/GearStakingV3Contract.d.ts +1 -1
- package/dist/types/sdk/core/address-provider/AbstractAddressProviderContract.d.ts +3 -4
- package/dist/types/sdk/core/address-provider/AddressProviderV300Contract.d.ts +3 -3
- package/dist/types/sdk/core/address-provider/AddressProviderV310Contract.d.ts +3 -3
- package/dist/types/sdk/market/MarketConfiguratorContract.d.ts +2 -2
- package/dist/types/sdk/market/credit/CreditConfiguratorV300Contract.d.ts +3 -3
- package/dist/types/sdk/market/credit/CreditConfiguratorV310Contract.d.ts +3 -3
- package/dist/types/sdk/market/credit/CreditFacadeV300Contract.d.ts +3 -4
- package/dist/types/sdk/market/credit/CreditFacadeV310Contract.d.ts +3 -4
- package/dist/types/sdk/market/credit/CreditManagerV300Contract.d.ts +1 -1
- package/dist/types/sdk/market/credit/CreditManagerV310Contract.d.ts +1 -1
- package/dist/types/sdk/market/credit/CreditSuite.d.ts +1 -1
- package/dist/types/sdk/market/credit/types.d.ts +1 -2
- package/dist/types/sdk/market/loss-policy/AliasLossPolicyV310Contract.d.ts +1 -0
- package/dist/types/sdk/market/loss-policy/LossPolicyContract.d.ts +2 -3
- package/dist/types/sdk/market/oracle/PriceOracleBaseContract.d.ts +3 -12
- package/dist/types/sdk/market/oracle/types.d.ts +0 -10
- package/dist/types/sdk/market/pool/GaugeContract.d.ts +2 -3
- package/dist/types/sdk/market/pool/LinearInterestRateModelContract.d.ts +2 -3
- package/dist/types/sdk/market/pool/PoolQuotaKeeperV300Contract.d.ts +2 -3
- package/dist/types/sdk/market/pool/PoolQuotaKeeperV310Contract.d.ts +2 -3
- package/dist/types/sdk/market/pool/PoolV300Contract.d.ts +4 -5
- package/dist/types/sdk/market/pool/PoolV310Contract.d.ts +4 -5
- package/dist/types/sdk/market/pool/TumblerContract.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/AbstractLPPriceFeed.d.ts +3 -8
- package/dist/types/sdk/market/pricefeeds/AbstractPriceFeed.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/BalancerStablePriceFeed.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/BalancerWeightedPriceFeed.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/BoundedPriceFeed.d.ts +2 -2
- package/dist/types/sdk/market/pricefeeds/CompositePriceFeed.d.ts +2 -2
- package/dist/types/sdk/market/pricefeeds/ConstantPriceFeed.d.ts +2 -2
- package/dist/types/sdk/market/pricefeeds/CurveCryptoPriceFeed.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/CurveStablePriceFeed.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/CurveUSDPriceFeed.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/Erc4626PriceFeed.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/ExternalPriceFeed.d.ts +2 -2
- package/dist/types/sdk/market/pricefeeds/MellowLRTPriceFeed.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/PendleTWAPPTPriceFeed.d.ts +2 -2
- package/dist/types/sdk/market/pricefeeds/PriceFeedRef.d.ts +3 -4
- package/dist/types/sdk/market/pricefeeds/PriceFeedsRegister.d.ts +1 -2
- package/dist/types/sdk/market/pricefeeds/PythPriceFeed.d.ts +2 -2
- package/dist/types/sdk/market/pricefeeds/RedstonePriceFeed.d.ts +2 -2
- package/dist/types/sdk/market/pricefeeds/WstETHPriceFeed.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/YearnPriceFeed.d.ts +2 -3
- package/dist/types/sdk/market/pricefeeds/ZeroPriceFeed.d.ts +2 -2
- package/dist/types/sdk/market/pricefeeds/types.d.ts +0 -5
- package/dist/types/sdk/router/AbstractRouterContract.d.ts +4 -1
- package/dist/types/sdk/router/types.d.ts +1 -2
- package/dist/types/sdk/sdk-legacy/core/creditAccount.d.ts +2 -2
- package/dist/types/sdk/utils/abi-decode.d.ts +10 -0
- package/dist/types/sdk/utils/index.d.ts +1 -0
- package/package.json +1 -1
- package/dist/cjs/permissionless/bindings/base-contract.js +0 -173
- package/dist/cjs/permissionless/utils/abi-decoder.js +0 -72
- package/dist/cjs/sdk/base/AddressLabeller.js +0 -49
- package/dist/cjs/sdk/base/IAddressLabeller.js +0 -16
- package/dist/esm/permissionless/bindings/base-contract.js +0 -151
- package/dist/esm/permissionless/utils/abi-decoder.js +0 -50
- package/dist/esm/sdk/base/AddressLabeller.js +0 -25
- package/dist/esm/sdk/base/IAddressLabeller.js +0 -0
- package/dist/types/permissionless/bindings/base-contract.d.ts +0 -23
- package/dist/types/permissionless/utils/abi-decoder.d.ts +0 -13
- package/dist/types/sdk/base/AddressLabeller.d.ts +0 -11
- package/dist/types/sdk/base/IAddressLabeller.d.ts +0 -9
|
@@ -3,9 +3,9 @@ import { iAddressProviderV310Abi } from "../../../abi/310/generated.js";
|
|
|
3
3
|
import AbstractAddressProviderContract from "./AbstractAddressProviderContract.js";
|
|
4
4
|
const abi = iAddressProviderV310Abi;
|
|
5
5
|
class AddressProviderV310Contract extends AbstractAddressProviderContract {
|
|
6
|
-
constructor(
|
|
6
|
+
constructor(options, address, version = 310, addresses = {}) {
|
|
7
7
|
super(
|
|
8
|
-
|
|
8
|
+
options,
|
|
9
9
|
{
|
|
10
10
|
addr: address,
|
|
11
11
|
name: "AddressProviderV310",
|
|
@@ -15,7 +15,7 @@ class AddressProviderV310Contract extends AbstractAddressProviderContract {
|
|
|
15
15
|
addresses
|
|
16
16
|
);
|
|
17
17
|
}
|
|
18
|
-
|
|
18
|
+
stringifyFunctionParams(params) {
|
|
19
19
|
switch (params.functionName) {
|
|
20
20
|
case "setAddress": {
|
|
21
21
|
if (params.args.length !== 3) {
|
|
@@ -26,7 +26,7 @@ class AddressProviderV310Contract extends AbstractAddressProviderContract {
|
|
|
26
26
|
return [bytesToString(toBytes(key)), value, `${saveVersion}`];
|
|
27
27
|
}
|
|
28
28
|
default:
|
|
29
|
-
return
|
|
29
|
+
return super.stringifyFunctionParams(params);
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
32
|
processLog(log) {
|
|
@@ -7,8 +7,8 @@ import { AP_MARKET_CONFIGURATOR } from "../constants/index.js";
|
|
|
7
7
|
const abi = iMarketConfiguratorV310Abi;
|
|
8
8
|
class MarketConfiguratorContract extends BaseContract {
|
|
9
9
|
#curatorName;
|
|
10
|
-
constructor(
|
|
11
|
-
super(
|
|
10
|
+
constructor(options, address) {
|
|
11
|
+
super(options, {
|
|
12
12
|
abi,
|
|
13
13
|
addr: address,
|
|
14
14
|
contractType: AP_MARKET_CONFIGURATOR,
|
|
@@ -16,18 +16,18 @@ class MarketConfiguratorContract extends BaseContract {
|
|
|
16
16
|
});
|
|
17
17
|
}
|
|
18
18
|
async loadCuratorName() {
|
|
19
|
-
this.#curatorName = await this.
|
|
19
|
+
this.#curatorName = await this.client.readContract({
|
|
20
20
|
address: this.address,
|
|
21
21
|
abi: this.abi,
|
|
22
22
|
functionName: "curatorName"
|
|
23
23
|
});
|
|
24
|
-
this.
|
|
24
|
+
this.register.setAddressLabel(
|
|
25
25
|
this.address,
|
|
26
26
|
`Market configurator ${this.#curatorName}`
|
|
27
27
|
);
|
|
28
28
|
}
|
|
29
29
|
async getPeripheryContract(contract) {
|
|
30
|
-
const resp = await this.
|
|
30
|
+
const resp = await this.client.readContract({
|
|
31
31
|
address: this.address,
|
|
32
32
|
abi: this.abi,
|
|
33
33
|
functionName: "getPeripheryContracts",
|
|
@@ -5,12 +5,11 @@ import {
|
|
|
5
5
|
AP_MARKET_COMPRESSOR,
|
|
6
6
|
VERSION_RANGE_310
|
|
7
7
|
} from "../constants/index.js";
|
|
8
|
-
import { AddressMap
|
|
8
|
+
import { AddressMap } from "../utils/index.js";
|
|
9
9
|
import { simulateWithPriceUpdates } from "../utils/viem/index.js";
|
|
10
10
|
import { MarketConfiguratorContract } from "./MarketConfiguratorContract.js";
|
|
11
11
|
import { MarketSuite } from "./MarketSuite.js";
|
|
12
12
|
class MarketRegister extends SDKConstruct {
|
|
13
|
-
#logger;
|
|
14
13
|
/**
|
|
15
14
|
* Mapping pool.address -> MarketSuite
|
|
16
15
|
*/
|
|
@@ -23,7 +22,6 @@ class MarketRegister extends SDKConstruct {
|
|
|
23
22
|
#ignoreMarkets;
|
|
24
23
|
constructor(sdk, ignoreMarkets = []) {
|
|
25
24
|
super(sdk);
|
|
26
|
-
this.#logger = childLogger("MarketRegister", sdk.logger);
|
|
27
25
|
this.#ignoreMarkets = new Set(
|
|
28
26
|
ignoreMarkets.map((m) => m.toLowerCase())
|
|
29
27
|
);
|
|
@@ -35,7 +33,7 @@ class MarketRegister extends SDKConstruct {
|
|
|
35
33
|
for (const data of state) {
|
|
36
34
|
const pool = data.pool.baseParams.addr;
|
|
37
35
|
if (this.#ignoreMarkets.has(pool.toLowerCase())) {
|
|
38
|
-
this
|
|
36
|
+
this.logger?.debug(
|
|
39
37
|
`ignoring market of pool ${pool} (${data.pool.name})`
|
|
40
38
|
);
|
|
41
39
|
continue;
|
|
@@ -48,7 +46,7 @@ class MarketRegister extends SDKConstruct {
|
|
|
48
46
|
}
|
|
49
47
|
async loadMarkets(marketConfigurators, ignoreUpdateablePrices) {
|
|
50
48
|
if (!marketConfigurators.length) {
|
|
51
|
-
this
|
|
49
|
+
this.logger?.warn(
|
|
52
50
|
"no market configurators provided, skipping loadMarkets"
|
|
53
51
|
);
|
|
54
52
|
return;
|
|
@@ -79,7 +77,7 @@ class MarketRegister extends SDKConstruct {
|
|
|
79
77
|
async syncState(ignoreUpdateablePrices) {
|
|
80
78
|
const dirty = this.markets.some((m) => m.dirty) || this.marketConfigurators.some((c) => c.dirty);
|
|
81
79
|
if (dirty) {
|
|
82
|
-
this
|
|
80
|
+
this.logger?.debug(
|
|
83
81
|
"some markets or market configurators are dirty, reloading everything"
|
|
84
82
|
);
|
|
85
83
|
await this.#loadMarkets(
|
|
@@ -106,7 +104,7 @@ class MarketRegister extends SDKConstruct {
|
|
|
106
104
|
const updates = await this.sdk.priceFeeds.generatePriceFeedsUpdateTxs(updatables);
|
|
107
105
|
txs = updates.txs;
|
|
108
106
|
}
|
|
109
|
-
this
|
|
107
|
+
this.logger?.debug(
|
|
110
108
|
{ configurators, pools },
|
|
111
109
|
`calling getMarkets with ${txs.length} price updates in block ${this.sdk.currentBlock}`
|
|
112
110
|
);
|
|
@@ -140,14 +138,14 @@ class MarketRegister extends SDKConstruct {
|
|
|
140
138
|
for (const data of markets) {
|
|
141
139
|
const pool = data.pool.baseParams.addr;
|
|
142
140
|
if (this.#ignoreMarkets.has(pool.toLowerCase())) {
|
|
143
|
-
this
|
|
141
|
+
this.logger?.debug(
|
|
144
142
|
`ignoring market of pool ${pool} (${data.pool.name})`
|
|
145
143
|
);
|
|
146
144
|
continue;
|
|
147
145
|
}
|
|
148
146
|
this.#markets.upsert(pool, new MarketSuite(this.sdk, data));
|
|
149
147
|
}
|
|
150
|
-
this
|
|
148
|
+
this.logger?.info(
|
|
151
149
|
`loaded ${this.#markets.size} markets in block ${this.sdk.currentBlock}`
|
|
152
150
|
);
|
|
153
151
|
}
|
|
@@ -166,7 +164,7 @@ class MarketRegister extends SDKConstruct {
|
|
|
166
164
|
if (!multicalls.length) {
|
|
167
165
|
return;
|
|
168
166
|
}
|
|
169
|
-
this
|
|
167
|
+
this.logger?.debug(`syncing prices on ${multicalls.length} oracles`);
|
|
170
168
|
const { txs } = await this.sdk.priceFeeds.generatePriceFeedsUpdateTxs();
|
|
171
169
|
const oraclesStates = await simulateWithPriceUpdates(this.client, {
|
|
172
170
|
priceUpdates: txs,
|
|
@@ -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.
|
|
24
|
+
const mc = sdk.mustGetContract(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.
|
|
35
|
+
sdk.setAddressLabel(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
|
-
|
|
8
|
+
sdk;
|
|
9
9
|
isPaused = false;
|
|
10
10
|
constructor(sdk, { creditConfigurator, creditManager }) {
|
|
11
11
|
super(sdk, {
|
|
@@ -13,6 +13,7 @@ class CreditConfiguratorV300Contract extends BaseContract {
|
|
|
13
13
|
name: `CreditConfigurator(${creditManager.name})`,
|
|
14
14
|
abi
|
|
15
15
|
});
|
|
16
|
+
this.sdk = sdk;
|
|
16
17
|
}
|
|
17
18
|
processLog(log) {
|
|
18
19
|
switch (log.eventName) {
|
|
@@ -59,7 +60,7 @@ class CreditConfiguratorV300Contract extends BaseContract {
|
|
|
59
60
|
});
|
|
60
61
|
return logs.map(({ args }) => args);
|
|
61
62
|
}
|
|
62
|
-
|
|
63
|
+
stringifyFunctionParams(params) {
|
|
63
64
|
switch (params.functionName) {
|
|
64
65
|
case "addCollateralToken":
|
|
65
66
|
case "setLiquidationThreshold": {
|
|
@@ -105,7 +106,7 @@ class CreditConfiguratorV300Contract extends BaseContract {
|
|
|
105
106
|
];
|
|
106
107
|
}
|
|
107
108
|
default:
|
|
108
|
-
return
|
|
109
|
+
return super.stringifyFunctionParams(params);
|
|
109
110
|
}
|
|
110
111
|
}
|
|
111
112
|
}
|
|
@@ -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
|
-
|
|
7
|
+
sdk;
|
|
8
8
|
isPaused = false;
|
|
9
9
|
constructor(sdk, { creditConfigurator, creditManager }) {
|
|
10
10
|
super(sdk, {
|
|
@@ -12,6 +12,7 @@ class CreditConfiguratorV310Contract extends BaseContract {
|
|
|
12
12
|
name: `CreditConfigurator(${creditManager.name})`,
|
|
13
13
|
abi
|
|
14
14
|
});
|
|
15
|
+
this.sdk = sdk;
|
|
15
16
|
}
|
|
16
17
|
processLog(log) {
|
|
17
18
|
switch (log.eventName) {
|
|
@@ -46,7 +47,7 @@ class CreditConfiguratorV310Contract extends BaseContract {
|
|
|
46
47
|
});
|
|
47
48
|
return logs.map(({ args }) => args);
|
|
48
49
|
}
|
|
49
|
-
|
|
50
|
+
stringifyFunctionParams(params) {
|
|
50
51
|
switch (params.functionName) {
|
|
51
52
|
case "addCollateralToken":
|
|
52
53
|
case "setLiquidationThreshold": {
|
|
@@ -90,7 +91,7 @@ class CreditConfiguratorV310Contract extends BaseContract {
|
|
|
90
91
|
];
|
|
91
92
|
}
|
|
92
93
|
default:
|
|
93
|
-
return
|
|
94
|
+
return super.stringifyFunctionParams(params);
|
|
94
95
|
}
|
|
95
96
|
}
|
|
96
97
|
}
|
|
@@ -13,9 +13,9 @@ const abi = [
|
|
|
13
13
|
];
|
|
14
14
|
class CreditFacadeV300Contract extends BaseContract {
|
|
15
15
|
underlying;
|
|
16
|
-
constructor(
|
|
16
|
+
constructor(options, { creditFacade, creditManager }) {
|
|
17
17
|
const { baseParams, ...rest } = creditFacade;
|
|
18
|
-
super(
|
|
18
|
+
super(options, {
|
|
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.
|
|
27
|
+
const decimals = this.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
|
-
|
|
91
|
+
stringifyFunctionParams(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.
|
|
97
|
+
this.register.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.
|
|
105
|
+
this.register.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.
|
|
113
|
+
this.register.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.
|
|
128
|
+
return this.labelAddress(token) + ": " + this.tokensMeta.formatBN(token, amount);
|
|
129
129
|
}).join(",")
|
|
130
130
|
];
|
|
131
131
|
}
|
|
132
132
|
default:
|
|
133
|
-
return
|
|
133
|
+
return super.stringifyFunctionParams(params);
|
|
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(
|
|
16
|
+
constructor(options, { creditFacade, creditManager }) {
|
|
17
17
|
const { baseParams, ...rest } = creditFacade;
|
|
18
|
-
super(
|
|
18
|
+
super(options, {
|
|
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.
|
|
27
|
+
const decimals = this.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
|
-
|
|
88
|
+
stringifyFunctionParams(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.
|
|
94
|
+
this.register.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.
|
|
102
|
+
this.register.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.
|
|
110
|
+
this.register.parseMultiCall([...calls]).join(",")
|
|
111
111
|
];
|
|
112
112
|
}
|
|
113
113
|
default:
|
|
114
|
-
return
|
|
114
|
+
return super.stringifyFunctionParams(params);
|
|
115
115
|
}
|
|
116
116
|
}
|
|
117
117
|
}
|
|
@@ -27,9 +27,12 @@ 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(
|
|
31
|
-
adapter.name = `${adapter.name}(${this.name})`;
|
|
30
|
+
const adapter = createAdapter(sdk, adapterData);
|
|
32
31
|
this.adapters.upsert(adapter.targetContract, adapter);
|
|
32
|
+
this.register.setAddressLabel(
|
|
33
|
+
adapter.address,
|
|
34
|
+
`${adapter.name}(${this.name})`
|
|
35
|
+
);
|
|
33
36
|
} catch (e) {
|
|
34
37
|
throw new Error(`cannot attach adapter: ${e}`, { cause: e });
|
|
35
38
|
}
|
|
@@ -27,9 +27,12 @@ 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(
|
|
31
|
-
adapter.name = `${adapter.name}(${this.name})`;
|
|
30
|
+
const adapter = createAdapter(sdk, adapterData);
|
|
32
31
|
this.adapters.upsert(adapter.targetContract, adapter);
|
|
32
|
+
this.register.setAddressLabel(
|
|
33
|
+
adapter.address,
|
|
34
|
+
`${adapter.name}(${this.name})`
|
|
35
|
+
);
|
|
33
36
|
} catch (e) {
|
|
34
37
|
throw new Error(`cannot attach adapter: ${e}`, { cause: e });
|
|
35
38
|
}
|
|
@@ -3,7 +3,6 @@ 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;
|
|
7
6
|
pool;
|
|
8
7
|
underlying;
|
|
9
8
|
creditManager;
|
|
@@ -11,12 +10,12 @@ class CreditSuite extends SDKConstruct {
|
|
|
11
10
|
creditConfigurator;
|
|
12
11
|
marketConfigurator;
|
|
13
12
|
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;
|
|
17
18
|
this.state = creditManagers[index];
|
|
18
|
-
const { name } = this.state.creditManager;
|
|
19
|
-
this.name = name;
|
|
20
19
|
this.pool = pool.baseParams.addr;
|
|
21
20
|
this.underlying = pool.underlying;
|
|
22
21
|
this.creditManager = createCreditManager(sdk, this.state);
|
|
@@ -12,6 +12,7 @@ class AliasLossPolicyV310Contract extends BaseContract {
|
|
|
12
12
|
checksEnabled;
|
|
13
13
|
tokens;
|
|
14
14
|
priceFeedParams;
|
|
15
|
+
sdk;
|
|
15
16
|
constructor(sdk, params) {
|
|
16
17
|
super(sdk, {
|
|
17
18
|
abi,
|
|
@@ -19,6 +20,7 @@ class AliasLossPolicyV310Contract extends BaseContract {
|
|
|
19
20
|
contractType: params.contractType,
|
|
20
21
|
version: params.version
|
|
21
22
|
});
|
|
23
|
+
this.sdk = sdk;
|
|
22
24
|
[this.accessMode, this.checksEnabled, this.tokens, this.priceFeedParams] = decodeAbiParameters(
|
|
23
25
|
[
|
|
24
26
|
{ name: "accessMode", type: "uint8" },
|
|
@@ -39,7 +41,7 @@ class AliasLossPolicyV310Contract extends BaseContract {
|
|
|
39
41
|
);
|
|
40
42
|
}
|
|
41
43
|
async getLiquidationData(creditAccount, blockNumber) {
|
|
42
|
-
const pfs = await this.
|
|
44
|
+
const pfs = await this.client.readContract({
|
|
43
45
|
address: this.address,
|
|
44
46
|
abi: this.abi,
|
|
45
47
|
functionName: "getRequiredAliasPriceFeeds",
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
import { iLossPolicyV310Abi } from "../../../abi/310/generated.js";
|
|
2
|
-
import {
|
|
2
|
+
import {
|
|
3
|
+
BaseContract
|
|
4
|
+
} from "../../base/index.js";
|
|
3
5
|
const abi = iLossPolicyV310Abi;
|
|
4
6
|
class LossPolicyContract extends BaseContract {
|
|
5
|
-
constructor(
|
|
6
|
-
super(
|
|
7
|
+
constructor(options, params) {
|
|
8
|
+
super(options, {
|
|
7
9
|
abi,
|
|
8
10
|
addr: params.addr,
|
|
9
11
|
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.
|
|
6
|
+
const existing = sdk.getContract(baseParams.addr);
|
|
7
7
|
if (existing) {
|
|
8
8
|
return existing;
|
|
9
9
|
}
|
|
@@ -12,6 +12,7 @@ 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;
|
|
15
16
|
/**
|
|
16
17
|
* Mapping Token => [PriceFeed Address, stalenessPeriod]
|
|
17
18
|
*/
|
|
@@ -43,6 +44,7 @@ class PriceOracleBaseContract extends BaseContract {
|
|
|
43
44
|
);
|
|
44
45
|
constructor(sdk, args, data) {
|
|
45
46
|
super(sdk, args);
|
|
47
|
+
this.sdk = sdk;
|
|
46
48
|
const { priceFeedMap, priceFeedTree } = data;
|
|
47
49
|
this.#loadState(priceFeedMap, priceFeedTree, true);
|
|
48
50
|
}
|
|
@@ -60,19 +62,6 @@ class PriceOracleBaseContract extends BaseContract {
|
|
|
60
62
|
reserve ? this.reservePriceFeeds.get(t)?.priceFeed : void 0
|
|
61
63
|
]).filter((f) => !!f);
|
|
62
64
|
}
|
|
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
|
-
}
|
|
76
65
|
/**
|
|
77
66
|
* Gets main price for given token
|
|
78
67
|
* Throws if token price feed is not found or answer is not successful
|
|
@@ -112,9 +101,9 @@ class PriceOracleBaseContract extends BaseContract {
|
|
|
112
101
|
return amount;
|
|
113
102
|
}
|
|
114
103
|
const fromPrice = reserve ? this.reservePrice(from) : this.mainPrice(from);
|
|
115
|
-
const fromScale = 10n ** BigInt(this.
|
|
104
|
+
const fromScale = 10n ** BigInt(this.tokensMeta.decimals(from));
|
|
116
105
|
const toPrice = reserve ? this.reservePrice(to) : this.mainPrice(to);
|
|
117
|
-
const toScale = 10n ** BigInt(this.
|
|
106
|
+
const toScale = 10n ** BigInt(this.tokensMeta.decimals(to));
|
|
118
107
|
return amount * fromPrice * toScale / (toPrice * fromScale);
|
|
119
108
|
}
|
|
120
109
|
/**
|
|
@@ -125,7 +114,7 @@ class PriceOracleBaseContract extends BaseContract {
|
|
|
125
114
|
*/
|
|
126
115
|
convertToUSD(from, amount, reserve = false) {
|
|
127
116
|
const price = reserve ? this.reservePrice(from) : this.mainPrice(from);
|
|
128
|
-
const scale = 10n ** BigInt(this.
|
|
117
|
+
const scale = 10n ** BigInt(this.tokensMeta.decimals(from));
|
|
129
118
|
return amount * price / scale;
|
|
130
119
|
}
|
|
131
120
|
/**
|
|
@@ -136,16 +125,9 @@ class PriceOracleBaseContract extends BaseContract {
|
|
|
136
125
|
*/
|
|
137
126
|
convertFromUSD(to, amount, reserve = false) {
|
|
138
127
|
const price = reserve ? this.reservePrice(to) : this.mainPrice(to);
|
|
139
|
-
const scale = 10n ** BigInt(this.
|
|
128
|
+
const scale = 10n ** BigInt(this.tokensMeta.decimals(to));
|
|
140
129
|
return amount * scale / price;
|
|
141
130
|
}
|
|
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
|
-
}
|
|
149
131
|
/**
|
|
150
132
|
* All price feed tree nodes known to this oracle
|
|
151
133
|
*/
|
|
@@ -234,8 +216,8 @@ class PriceOracleBaseContract extends BaseContract {
|
|
|
234
216
|
this.dirty = false;
|
|
235
217
|
}
|
|
236
218
|
#labelPriceFeed(address, usage, token) {
|
|
237
|
-
this.sdk.
|
|
238
|
-
const symbol = this.
|
|
219
|
+
this.sdk.setAddressLabel(address, (oldLabel) => {
|
|
220
|
+
const symbol = this.tokensMeta.symbol(token);
|
|
239
221
|
let pricefeedTag = `${symbol}.${usage}`;
|
|
240
222
|
if (oldLabel) {
|
|
241
223
|
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.
|
|
7
|
+
const existing = sdk.getContract(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(
|
|
13
|
-
super(
|
|
12
|
+
constructor(options, pool, gauge) {
|
|
13
|
+
super(options, {
|
|
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(
|
|
15
|
-
super(
|
|
14
|
+
constructor(options, params) {
|
|
15
|
+
super(options, {
|
|
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(
|
|
9
|
-
super(
|
|
8
|
+
constructor(options, pool, pqk) {
|
|
9
|
+
super(options, {
|
|
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(
|
|
9
|
-
super(
|
|
8
|
+
constructor(options, pool, pqk) {
|
|
9
|
+
super(options, {
|
|
10
10
|
...pqk.baseParams,
|
|
11
11
|
name: `PoolQuotaKeeper(${pool.name})`,
|
|
12
12
|
abi
|
|
@@ -10,9 +10,9 @@ import {
|
|
|
10
10
|
const abi = [...iPoolV300Abi, ...iPausableAbi];
|
|
11
11
|
class PoolV300Contract extends BaseContract {
|
|
12
12
|
creditManagerDebtParams;
|
|
13
|
-
constructor(
|
|
13
|
+
constructor(options, data) {
|
|
14
14
|
const { baseParams, creditManagerDebtParams, ...rest } = data;
|
|
15
|
-
super(
|
|
15
|
+
super(options, {
|
|
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
|
-
|
|
24
|
+
this.register.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
|
-
|
|
103
|
+
stringifyFunctionParams(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
|
|
110
|
+
return super.stringifyFunctionParams(params);
|
|
111
111
|
}
|
|
112
112
|
}
|
|
113
113
|
}
|