@gearbox-protocol/sdk 11.12.0 → 12.0.0-next.2
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 +15 -27
- 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/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/PriceUpdatesCache.js +17 -0
- package/dist/cjs/sdk/market/pricefeeds/updates/PythUpdater.js +7 -9
- package/dist/cjs/sdk/market/pricefeeds/updates/RedstoneUpdater.js +10 -12
- 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 +16 -26
- 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/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/PriceUpdatesCache.js +17 -0
- package/dist/esm/sdk/market/pricefeeds/updates/PythUpdater.js +8 -10
- package/dist/esm/sdk/market/pricefeeds/updates/RedstoneUpdater.js +11 -13
- 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/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/market/pricefeeds/updates/PriceUpdatesCache.d.ts +8 -1
- 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
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { NOT_DEPLOYED } from "../constants/addresses.js";
|
|
2
|
+
import { AddressMap } from "../utils/AddressMap.js";
|
|
3
|
+
import { TokensMeta } from "./TokensMeta.js";
|
|
4
|
+
class ChainContractsRegister {
|
|
5
|
+
static #chains = /* @__PURE__ */ new Map();
|
|
6
|
+
static for(client, logger) {
|
|
7
|
+
const chainId = client.chain.id;
|
|
8
|
+
let result = ChainContractsRegister.#chains.get(chainId);
|
|
9
|
+
if (!result) {
|
|
10
|
+
result = new ChainContractsRegister(client, logger);
|
|
11
|
+
ChainContractsRegister.#chains.set(chainId, result);
|
|
12
|
+
}
|
|
13
|
+
return result;
|
|
14
|
+
}
|
|
15
|
+
contracts = new AddressMap(
|
|
16
|
+
[],
|
|
17
|
+
"contracts"
|
|
18
|
+
);
|
|
19
|
+
labels = new AddressMap([], "labels");
|
|
20
|
+
client;
|
|
21
|
+
/**
|
|
22
|
+
* Token metadata such as symbol and decimals
|
|
23
|
+
*/
|
|
24
|
+
tokensMeta;
|
|
25
|
+
logger;
|
|
26
|
+
constructor(client, logger) {
|
|
27
|
+
this.client = client;
|
|
28
|
+
this.tokensMeta = new TokensMeta(client);
|
|
29
|
+
this.logger = logger;
|
|
30
|
+
}
|
|
31
|
+
getContract(address) {
|
|
32
|
+
return this.contracts.get(address);
|
|
33
|
+
}
|
|
34
|
+
mustGetContract(address) {
|
|
35
|
+
const contract = this.contracts.mustGet(address);
|
|
36
|
+
if (!contract) {
|
|
37
|
+
throw new Error(`contract ${address} not found on chain ${this.chainId}`);
|
|
38
|
+
}
|
|
39
|
+
return contract;
|
|
40
|
+
}
|
|
41
|
+
setContract(address, contract) {
|
|
42
|
+
this.contracts.upsert(address, contract);
|
|
43
|
+
}
|
|
44
|
+
setAddressLabel(address, label) {
|
|
45
|
+
if (address === NOT_DEPLOYED) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
if (typeof label === "string") {
|
|
49
|
+
this.labels.upsert(address, label);
|
|
50
|
+
} else {
|
|
51
|
+
this.labels.upsert(address, label(this.labels.get(address)));
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
labelAddress(address) {
|
|
55
|
+
const label = this.labels.get(address);
|
|
56
|
+
return label ? `${address} [${label}]` : address;
|
|
57
|
+
}
|
|
58
|
+
get chain() {
|
|
59
|
+
return this.client.chain;
|
|
60
|
+
}
|
|
61
|
+
get chainId() {
|
|
62
|
+
return this.client.chain.id;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Converts contract call into some human-friendly string
|
|
66
|
+
* This method is safe and should not throw
|
|
67
|
+
* @param address
|
|
68
|
+
* @param calldata
|
|
69
|
+
* @returns
|
|
70
|
+
*/
|
|
71
|
+
stringifyFunctionData(address, calldata) {
|
|
72
|
+
const contract = this.contracts.get(address);
|
|
73
|
+
return contract ? contract.stringifyFunctionData(calldata) : `unknown: ${address}.${calldata.slice(0, 10)}`;
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Converts multicalls into some human-friendly strings
|
|
77
|
+
* This method is safe and should not throw
|
|
78
|
+
* @param address
|
|
79
|
+
* @param calldata
|
|
80
|
+
* @returns
|
|
81
|
+
*/
|
|
82
|
+
stringifyMultiCall(calls) {
|
|
83
|
+
return calls.map(
|
|
84
|
+
(call) => this.stringifyFunctionData(call.target, call.callData)
|
|
85
|
+
);
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Return args, function, type and address name from contract call
|
|
89
|
+
* @param address
|
|
90
|
+
* @param calldata
|
|
91
|
+
* @returns
|
|
92
|
+
*/
|
|
93
|
+
parseFunctionData(address, calldata) {
|
|
94
|
+
const contract = this.mustGetContract(address);
|
|
95
|
+
return contract.parseFunctionData(calldata);
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Converts multicalls into call info
|
|
99
|
+
* @param address
|
|
100
|
+
* @param calldata
|
|
101
|
+
* @returns
|
|
102
|
+
*/
|
|
103
|
+
parseMultiCall(calls) {
|
|
104
|
+
return calls.map(
|
|
105
|
+
(call) => this.parseFunctionData(call.target, call.callData)
|
|
106
|
+
);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
export {
|
|
110
|
+
ChainContractsRegister
|
|
111
|
+
};
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { childLogger } from "../utils/index.js";
|
|
2
|
+
import { ChainContractsRegister } from "./ChainContractsRegister.js";
|
|
3
|
+
class Construct {
|
|
4
|
+
logger;
|
|
5
|
+
client;
|
|
6
|
+
register;
|
|
7
|
+
/**
|
|
8
|
+
* Indicates that contract state needs to be updated
|
|
9
|
+
*/
|
|
10
|
+
#dirty = false;
|
|
11
|
+
constructor({ client, logger }) {
|
|
12
|
+
this.client = client;
|
|
13
|
+
this.register = ChainContractsRegister.for(client, logger);
|
|
14
|
+
this.logger = childLogger(
|
|
15
|
+
this.constructor.name,
|
|
16
|
+
this.register.logger ?? logger
|
|
17
|
+
);
|
|
18
|
+
}
|
|
19
|
+
get chain() {
|
|
20
|
+
return this.client.chain;
|
|
21
|
+
}
|
|
22
|
+
get chainId() {
|
|
23
|
+
return this.client.chain.id;
|
|
24
|
+
}
|
|
25
|
+
get networkType() {
|
|
26
|
+
if ("network" in this.chain) {
|
|
27
|
+
return this.chain.network;
|
|
28
|
+
}
|
|
29
|
+
throw new Error(`chain ${this.chain.id} is not a Gearbox SDK chain`);
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Indicates that contract state diverged from onchain state and needs to be updated
|
|
33
|
+
*/
|
|
34
|
+
get dirty() {
|
|
35
|
+
return this.#dirty;
|
|
36
|
+
}
|
|
37
|
+
set dirty(value) {
|
|
38
|
+
this.#dirty = value;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Syntax sugar for rgister.tokensMeta
|
|
42
|
+
*/
|
|
43
|
+
get tokensMeta() {
|
|
44
|
+
return this.register.tokensMeta;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Syntax suggar for getting contract labels
|
|
48
|
+
* @param address
|
|
49
|
+
* @returns
|
|
50
|
+
*/
|
|
51
|
+
labelAddress(address) {
|
|
52
|
+
return this.register.labelAddress(address);
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Returns list of addresses that should be watched for events to sync state
|
|
56
|
+
*/
|
|
57
|
+
get watchAddresses() {
|
|
58
|
+
return /* @__PURE__ */ new Set();
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
export {
|
|
62
|
+
Construct
|
|
63
|
+
};
|
|
@@ -1,36 +1,10 @@
|
|
|
1
|
-
|
|
1
|
+
import { Construct } from "./Construct.js";
|
|
2
|
+
class SDKConstruct extends Construct {
|
|
2
3
|
sdk;
|
|
3
|
-
/**
|
|
4
|
-
* Indicates that contract state needs to be updated
|
|
5
|
-
*/
|
|
6
|
-
#dirty = false;
|
|
7
4
|
constructor(sdk) {
|
|
5
|
+
super(sdk);
|
|
8
6
|
this.sdk = sdk;
|
|
9
7
|
}
|
|
10
|
-
get networkType() {
|
|
11
|
-
return this.sdk.networkType;
|
|
12
|
-
}
|
|
13
|
-
get client() {
|
|
14
|
-
return this.sdk.client;
|
|
15
|
-
}
|
|
16
|
-
/**
|
|
17
|
-
* Indicates that contract state needs to be updated
|
|
18
|
-
*/
|
|
19
|
-
get dirty() {
|
|
20
|
-
return this.#dirty;
|
|
21
|
-
}
|
|
22
|
-
set dirty(value) {
|
|
23
|
-
this.#dirty = value;
|
|
24
|
-
}
|
|
25
|
-
labelAddress(address) {
|
|
26
|
-
return this.sdk.labelAddress(address);
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Returns list of addresses that should be watched for events to sync state
|
|
30
|
-
*/
|
|
31
|
-
get watchAddresses() {
|
|
32
|
-
return /* @__PURE__ */ new Set();
|
|
33
|
-
}
|
|
34
8
|
}
|
|
35
9
|
export {
|
|
36
10
|
SDKConstruct
|
|
@@ -2,11 +2,11 @@ import { iVersionAbi } from "../../abi/iVersion.js";
|
|
|
2
2
|
import { bytes32ToString } from "../index.js";
|
|
3
3
|
import { AddressMap, AddressSet, formatBN } from "../utils/index.js";
|
|
4
4
|
class TokensMeta extends AddressMap {
|
|
5
|
-
#
|
|
5
|
+
#client;
|
|
6
6
|
#phantomTokensLoaded;
|
|
7
|
-
constructor(
|
|
7
|
+
constructor(client) {
|
|
8
8
|
super(void 0, "tokensMeta");
|
|
9
|
-
this.#
|
|
9
|
+
this.#client = client;
|
|
10
10
|
}
|
|
11
11
|
symbol(token) {
|
|
12
12
|
return this.mustGet(token).symbol;
|
|
@@ -61,7 +61,7 @@ class TokensMeta extends AddressMap {
|
|
|
61
61
|
async loadPhantomTokens() {
|
|
62
62
|
this.#phantomTokensLoaded = new AddressSet();
|
|
63
63
|
const tokens = this.keys();
|
|
64
|
-
const resp = await this.#
|
|
64
|
+
const resp = await this.#client.multicall({
|
|
65
65
|
contracts: tokens.map(
|
|
66
66
|
(t) => ({
|
|
67
67
|
address: t,
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
export * from "./AddressLabeller.js";
|
|
2
1
|
export * from "./BaseContract.js";
|
|
2
|
+
export * from "./ChainContractsRegister.js";
|
|
3
|
+
export * from "./Construct.js";
|
|
3
4
|
export * from "./PlaceholderContract.js";
|
|
4
5
|
export * from "./SDKConstruct.js";
|
|
5
6
|
export * from "./TokensMeta.js";
|
|
@@ -9,7 +9,7 @@ class BotListContract extends BaseContract {
|
|
|
9
9
|
super(sdk, { addr: address, name: "BotListV3", abi });
|
|
10
10
|
this.#currentBlock = sdk.chain.firstBlock ?? 0n;
|
|
11
11
|
}
|
|
12
|
-
|
|
12
|
+
stringifyFunctionParams(params) {
|
|
13
13
|
switch (params.functionName) {
|
|
14
14
|
case "setCreditManagerApprovedStatus": {
|
|
15
15
|
const [creditManager, status] = params.args;
|
|
@@ -24,7 +24,7 @@ class BotListContract extends BaseContract {
|
|
|
24
24
|
];
|
|
25
25
|
}
|
|
26
26
|
default:
|
|
27
|
-
return
|
|
27
|
+
return super.stringifyFunctionParams(params);
|
|
28
28
|
}
|
|
29
29
|
}
|
|
30
30
|
async syncState(toBlock) {
|
|
@@ -6,14 +6,14 @@ class GearStakingContract extends BaseContract {
|
|
|
6
6
|
constructor(sdk, address) {
|
|
7
7
|
super(sdk, { addr: address, name: "GearStakingV3", abi });
|
|
8
8
|
}
|
|
9
|
-
|
|
9
|
+
stringifyFunctionParams(params) {
|
|
10
10
|
switch (params.functionName) {
|
|
11
11
|
case "setVotingContractStatus": {
|
|
12
12
|
const [address, status] = params.args;
|
|
13
13
|
return [this.labelAddress(address), VotingContractStatus[status]];
|
|
14
14
|
}
|
|
15
15
|
default:
|
|
16
|
-
return
|
|
16
|
+
return super.stringifyFunctionParams(params);
|
|
17
17
|
}
|
|
18
18
|
}
|
|
19
19
|
stateHuman(raw = true) {
|
|
@@ -4,8 +4,8 @@ import { NO_VERSION } from "../../constants/index.js";
|
|
|
4
4
|
import { TypedObjectUtils } from "../../utils/mappers.js";
|
|
5
5
|
class AbstractAddressProviderContract extends BaseContract {
|
|
6
6
|
#addresses = {};
|
|
7
|
-
constructor(
|
|
8
|
-
super(
|
|
7
|
+
constructor(options, args, addresses = {}) {
|
|
8
|
+
super(options, args);
|
|
9
9
|
this.#addresses = addresses;
|
|
10
10
|
}
|
|
11
11
|
setInternalAddress(key, address, version) {
|
|
@@ -4,9 +4,9 @@ import { getLogsSafe } from "../../utils/viem/index.js";
|
|
|
4
4
|
import AbstractAddressProviderContract from "./AbstractAddressProviderContract.js";
|
|
5
5
|
const abi = iAddressProviderV300Abi;
|
|
6
6
|
class AddressProviderV300Contract extends AbstractAddressProviderContract {
|
|
7
|
-
constructor(
|
|
7
|
+
constructor(options, address, version, addresses = {}) {
|
|
8
8
|
super(
|
|
9
|
-
|
|
9
|
+
options,
|
|
10
10
|
{
|
|
11
11
|
addr: address,
|
|
12
12
|
name: "AddressProviderV300",
|
|
@@ -16,7 +16,7 @@ class AddressProviderV300Contract extends AbstractAddressProviderContract {
|
|
|
16
16
|
addresses
|
|
17
17
|
);
|
|
18
18
|
}
|
|
19
|
-
|
|
19
|
+
stringifyFunctionParams(params) {
|
|
20
20
|
switch (params.functionName) {
|
|
21
21
|
case "setAddress": {
|
|
22
22
|
if (params.args.length !== 3) {
|
|
@@ -27,7 +27,7 @@ class AddressProviderV300Contract extends AbstractAddressProviderContract {
|
|
|
27
27
|
return [bytesToString(toBytes(key)), value, `${saveVersion}`];
|
|
28
28
|
}
|
|
29
29
|
default:
|
|
30
|
-
return
|
|
30
|
+
return super.stringifyFunctionParams(params);
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
33
|
processLog(log) {
|
|
@@ -52,11 +52,16 @@ class AddressProviderV300Contract extends AbstractAddressProviderContract {
|
|
|
52
52
|
}
|
|
53
53
|
}
|
|
54
54
|
async syncState(blockNumber) {
|
|
55
|
-
|
|
55
|
+
if (!("firstBlock" in this.chain)) {
|
|
56
|
+
throw new Error(
|
|
57
|
+
`address provider v300 requires gearbox chain for ${this.chain.id} `
|
|
58
|
+
);
|
|
59
|
+
}
|
|
60
|
+
const fromBlock = this.chain.firstBlock;
|
|
56
61
|
this.logger?.debug(
|
|
57
62
|
`loading events from block ${fromBlock} to ${blockNumber}`
|
|
58
63
|
);
|
|
59
|
-
const events = await getLogsSafe(this.
|
|
64
|
+
const events = await getLogsSafe(this.client, {
|
|
60
65
|
address: this.address,
|
|
61
66
|
event: getAbiItem({ abi: this.abi, name: "SetAddress" }),
|
|
62
67
|
fromBlock,
|
|
@@ -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
|
}
|