@gearbox-protocol/sdk 13.0.0-next.9 → 13.0.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/abi/310/iLinearInterestRateModelV310.js +92 -0
- package/dist/cjs/abi/errors.js +0 -145
- package/dist/cjs/abi/iPriceFeed.js +84 -0
- package/dist/cjs/{sdk/sdk-gov-legacy/oracles → common-utils}/index.js +4 -4
- package/dist/cjs/common-utils/package.json +1 -0
- package/dist/cjs/common-utils/utils/assetsMath.js +216 -0
- package/dist/cjs/common-utils/utils/bigintMath.js +65 -0
- package/dist/cjs/common-utils/utils/creditAccount/calcHealthFactor.js +76 -0
- package/dist/cjs/common-utils/utils/creditAccount/calcOverallAPY.js +81 -0
- package/dist/cjs/{sdk/accountMigration/MigrateCreditAccountsServiceV310.js → common-utils/utils/creditAccount/calcQuotaBorrowRate.js} +19 -7
- package/dist/cjs/{sdk/sdk-legacy/utils/math.js → common-utils/utils/creditAccount/calcRelativeBaseBorrowRate.js} +11 -10
- package/dist/cjs/common-utils/utils/creditAccount/debt.js +64 -0
- package/dist/cjs/common-utils/utils/creditAccount/getTimeToLiquidation.js +38 -0
- package/dist/cjs/common-utils/utils/creditAccount/index.js +40 -0
- package/dist/cjs/common-utils/utils/creditAccount/liquidationPrice.js +47 -0
- package/dist/cjs/common-utils/utils/creditAccount/quotaUtils.js +149 -0
- package/dist/cjs/common-utils/utils/creditAccount/sort.js +95 -0
- package/dist/cjs/common-utils/utils/endpoints.js +65 -0
- package/dist/cjs/{sdk/sdk-legacy → common-utils}/utils/index.js +10 -6
- package/dist/cjs/common-utils/utils/priceMath.js +66 -0
- package/dist/cjs/dev/AccountOpener.js +3 -3
- package/dist/cjs/dev/ltUtils.js +4 -91
- package/dist/cjs/dev/migrateFaucet.js +25 -53
- package/dist/cjs/dev/providers.js +12 -0
- package/dist/cjs/history/assembleOperations.js +103 -0
- package/dist/cjs/history/classifyMulticallOperations.js +157 -0
- package/dist/cjs/history/errors.js +91 -0
- package/dist/cjs/history/extractProtocolCalls.js +53 -0
- package/dist/cjs/history/extractTransfers.js +168 -0
- package/dist/cjs/history/findFacadeCalls.js +84 -0
- package/dist/cjs/history/index.js +39 -0
- package/dist/cjs/history/inner-operations.js +16 -0
- package/dist/cjs/history/internal-types.js +16 -0
- package/dist/cjs/history/mapOperations.js +79 -0
- package/dist/cjs/history/package.json +1 -0
- package/dist/cjs/history/parseCreditAccountTransaction.js +86 -0
- package/dist/cjs/history/populateContractsRegister.js +68 -0
- package/dist/cjs/history/toLegacyOperation.js +182 -0
- package/dist/cjs/{plugins/adapters/contracts/YearnV2AdapterContract.js → history/trace-utils.js} +36 -21
- package/dist/cjs/permissionless/bindings/cross-chain-multisig.js +3 -3
- package/dist/cjs/permissionless/bindings/instance-manager.js +3 -3
- package/dist/cjs/permissionless/utils/price-update/get-prices.js +2 -6
- package/dist/cjs/plugins/adapters/AdaptersPlugin.js +13 -106
- package/dist/cjs/plugins/adapters/abi/index.js +2 -0
- package/dist/cjs/plugins/adapters/abi/targetContractAbi.js +5168 -0
- package/dist/cjs/plugins/adapters/contracts/AbstractAdapter.js +123 -3
- package/dist/cjs/plugins/adapters/contracts/AccountMigratorAdapterContract.js +8 -1
- package/dist/cjs/plugins/adapters/contracts/BalancerV3RouterAdapterContract.js +65 -30
- package/dist/cjs/plugins/adapters/contracts/BalancerV3WrapperAdapterContract.js +27 -11
- package/dist/cjs/plugins/adapters/contracts/CamelotV3AdapterContract.js +40 -21
- package/dist/cjs/plugins/adapters/contracts/ConvexV1BaseRewardPoolAdapterContract.js +100 -25
- package/dist/cjs/plugins/adapters/contracts/ConvexV1BoosterAdapterContract.js +74 -25
- package/dist/cjs/plugins/adapters/contracts/Curve2AssetsAdapterContract.js +79 -31
- package/dist/cjs/plugins/adapters/contracts/Curve3AssetsAdapterContract.js +79 -31
- package/dist/cjs/plugins/adapters/contracts/Curve4AssetsAdapterContract.js +84 -31
- package/dist/cjs/plugins/adapters/contracts/CurveV1AdapterDeposit.js +80 -33
- package/dist/cjs/plugins/adapters/contracts/CurveV1AdapterStETHContract.js +62 -26
- package/dist/cjs/plugins/adapters/contracts/CurveV1StableNGAdapterContract.js +92 -34
- package/dist/cjs/plugins/adapters/contracts/DaiUsdsAdapterContract.js +46 -14
- package/dist/cjs/plugins/adapters/contracts/ERC4626AdapterContract.js +62 -27
- package/dist/cjs/plugins/adapters/contracts/ERC4626ReferralAdapterContract.js +46 -14
- package/dist/cjs/plugins/adapters/contracts/FluidDexAdapterContract.js +34 -14
- package/dist/cjs/plugins/adapters/contracts/InfinifiGatewayAdapterContract.js +56 -23
- package/dist/cjs/plugins/adapters/contracts/InfinifiUnwindingGatewayAdapterContract.js +31 -14
- package/dist/cjs/plugins/adapters/contracts/KelpLRTDepositPoolAdapterContract.js +28 -12
- package/dist/cjs/plugins/adapters/contracts/KelpLRTWithdrawalManagerAdapterContract.js +35 -16
- package/dist/cjs/plugins/adapters/contracts/LidoV1AdapterContract.js +47 -17
- package/dist/cjs/plugins/adapters/contracts/MellowClaimerAdapterContract.js +29 -11
- package/dist/cjs/plugins/adapters/contracts/MellowDVVAdapterContract.js +45 -14
- package/dist/cjs/plugins/adapters/contracts/MellowDepositQueueAdapterContract.js +42 -17
- package/dist/cjs/plugins/adapters/contracts/MellowERC4626VaultAdapterContract.js +79 -42
- package/dist/cjs/plugins/adapters/contracts/MellowRedeemQueueAdapterContract.js +34 -14
- package/dist/cjs/plugins/adapters/contracts/MellowWrapperAdapterContract.js +27 -11
- package/dist/cjs/plugins/adapters/contracts/MidasIssuanceVaultAdapterContract.js +44 -17
- package/dist/cjs/plugins/adapters/contracts/MidasRedemptionVaultAdapterContract.js +49 -21
- package/dist/cjs/plugins/adapters/contracts/PendleRouterAdapterContract.js +92 -55
- package/dist/cjs/plugins/adapters/contracts/StakingRewardsAdapterContract.js +71 -37
- package/dist/cjs/plugins/adapters/contracts/TraderJoeRouterAdapterContract.js +55 -25
- package/dist/cjs/plugins/adapters/contracts/UniswapV2AdapterContract.js +44 -21
- package/dist/cjs/plugins/adapters/contracts/UniswapV3AdapterContract.js +42 -23
- package/dist/cjs/plugins/adapters/contracts/UniswapV4AdapterContract.js +53 -27
- package/dist/cjs/plugins/adapters/contracts/UpshiftVaultAdapterContract.js +42 -17
- package/dist/cjs/plugins/adapters/contracts/VelodromeV2AdapterContract.js +46 -25
- package/dist/cjs/plugins/adapters/contracts/WstETHV1AdapterContract.js +37 -11
- package/dist/cjs/plugins/adapters/contracts/index.js +7 -15
- package/dist/cjs/plugins/adapters/createAdapter.js +125 -0
- package/dist/cjs/plugins/adapters/index.js +6 -0
- package/dist/cjs/plugins/adapters/legacyAdapterOperations.js +16 -0
- package/dist/cjs/plugins/adapters/transferHelpers.js +127 -0
- package/dist/cjs/plugins/bots/PartialLiquidationBotV310Contract.js +4 -4
- package/dist/cjs/plugins/bots/abi/index.js +0 -2
- package/dist/cjs/plugins/degen-distributors/DegenDistributorsPlugin.js +2 -1
- package/dist/cjs/plugins/pools-history/Pools7DAgoPlugin.js +1 -1
- package/dist/cjs/plugins/zappers/ZappersPlugin.js +144 -0
- package/dist/cjs/{sdk/market/ZapperRegister.js → plugins/zappers/extraZappers.js} +6 -110
- package/dist/cjs/{sdk/sdk-gov-legacy/contracts → plugins/zappers}/index.js +8 -6
- package/dist/cjs/plugins/zappers/package.json +1 -0
- package/dist/cjs/sdk/GearboxSDK.js +6 -14
- package/dist/cjs/sdk/accounts/AbstractCreditAccountsService.js +19 -86
- package/dist/cjs/sdk/accounts/CreditAccountsServiceV310.js +11 -12
- package/dist/cjs/sdk/accounts/createCreditAccountService.js +0 -4
- package/dist/cjs/sdk/accounts/index.js +0 -2
- package/dist/cjs/sdk/base/BaseContract.js +60 -6
- package/dist/cjs/sdk/base/ChainContractsRegister.js +33 -10
- package/dist/cjs/sdk/base/Construct.js +29 -15
- package/dist/cjs/sdk/base/PlaceholderContract.js +2 -2
- package/dist/cjs/sdk/base/SDKConstruct.js +1 -1
- package/dist/cjs/sdk/base/TokensMeta.js +32 -112
- package/dist/cjs/{abi/iStateSerializer.js → sdk/base/errors.js} +12 -13
- package/dist/cjs/sdk/base/index.js +2 -2
- package/dist/cjs/sdk/chain/chains.js +13 -31
- package/dist/cjs/sdk/constants/addresses.js +2 -88
- package/dist/cjs/sdk/constants/index.js +2 -0
- package/dist/cjs/sdk/constants/networks.js +0 -32
- package/dist/cjs/sdk/{base/token-types.js → constants/phantom-tokens.js} +3 -9
- package/dist/cjs/sdk/constants/versions.js +0 -8
- package/dist/cjs/sdk/core/{address-provider/AbstractAddressProviderContract.js → AbstractAddressProviderContract.js} +3 -3
- package/dist/cjs/sdk/core/{address-provider/AddressProviderV310Contract.js → AddressProviderV310Contract.js} +1 -1
- package/dist/cjs/sdk/core/{address-provider/createAddressProvider.js → createAddressProvider.js} +4 -7
- package/dist/cjs/sdk/core/index.js +6 -6
- package/dist/cjs/sdk/{gauges/utils.js → core/types.js} +2 -2
- package/dist/cjs/sdk/index.js +0 -10
- package/dist/cjs/sdk/market/MarketConfiguratorContract.js +3 -2
- package/dist/cjs/sdk/market/MarketRegister.js +2 -3
- package/dist/cjs/sdk/market/MarketSuite.js +1 -4
- package/dist/cjs/sdk/market/adapters/PlaceholderAdapterContracts.js +25 -4
- package/dist/cjs/sdk/market/adapters/{factory.js → createAdapter.js} +3 -3
- package/dist/cjs/sdk/market/adapters/index.js +2 -2
- package/dist/cjs/sdk/market/credit/CreditFacadeV310BaseContract.js +108 -0
- package/dist/cjs/sdk/market/credit/CreditFacadeV310Contract.js +3 -40
- package/dist/cjs/sdk/market/credit/CreditManagerV310Contract.js +1 -4
- package/dist/cjs/sdk/market/credit/createCreditConfigurator.js +1 -4
- package/dist/cjs/sdk/market/credit/createCreditFacade.js +1 -4
- package/dist/cjs/sdk/market/credit/createCreditManager.js +1 -4
- package/dist/cjs/sdk/market/credit/index.js +2 -6
- package/dist/cjs/sdk/market/index.js +1 -3
- package/dist/cjs/sdk/market/oracle/PriceOracleBaseContract.js +9 -57
- package/dist/cjs/sdk/market/oracle/createPriceOracle.js +7 -38
- package/dist/cjs/sdk/market/oracle/index.js +0 -2
- package/dist/cjs/sdk/market/pool/GaugeContract.js +3 -3
- package/dist/cjs/sdk/market/pool/LinearInterestRateModelContract.js +2 -2
- package/dist/cjs/sdk/market/pool/PoolV310Contract.js +1 -1
- package/dist/cjs/sdk/market/pool/createPool.js +0 -4
- package/dist/cjs/sdk/market/pool/createPoolQuotaKeeper.js +0 -4
- package/dist/cjs/sdk/market/pool/index.js +0 -4
- package/dist/cjs/sdk/market/pricefeeds/AbstractLPPriceFeed.js +14 -53
- package/dist/cjs/sdk/market/pricefeeds/PriceFeedsRegister.js +5 -3
- package/dist/cjs/sdk/market/pricefeeds/PythPriceFeed.js +20 -0
- package/dist/cjs/sdk/market/pricefeeds/RedstonePriceFeed.js +19 -46
- package/dist/cjs/sdk/market/pricefeeds/updates/PriceUpdatesCache.js +0 -17
- package/dist/cjs/sdk/market/pricefeeds/updates/PythUpdater.js +7 -7
- package/dist/cjs/sdk/market/pricefeeds/updates/RedstoneUpdater.js +6 -6
- package/dist/cjs/sdk/market/pricefeeds/updates/fetchPythPayloads.js +7 -7
- package/dist/cjs/sdk/market/pricefeeds/updates/fetchRedstonePayloads.js +10 -10
- package/dist/cjs/sdk/plugins/index.js +1 -3
- package/dist/cjs/sdk/pools/AbstractPoolService.js +137 -0
- package/dist/cjs/sdk/{sdk-legacy/gearboxRewards/merklAPI.js → pools/PoolServiceV310.js} +7 -7
- package/dist/cjs/sdk/{accountMigration/MigrateCreditAccountsServiceV300.js → pools/createPoolService.js} +12 -7
- package/dist/cjs/sdk/pools/index.js +4 -2
- package/dist/cjs/sdk/router/AbstractRouterContract.js +0 -4
- package/dist/cjs/sdk/router/RouterV310Contract.js +3 -32
- package/dist/cjs/sdk/router/createRouter.js +0 -4
- package/dist/cjs/sdk/router/helpers.js +0 -5
- package/dist/cjs/sdk/router/index.js +0 -2
- package/dist/cjs/sdk/utils/abi-decode.js +43 -2
- package/dist/cjs/sdk/utils/formatter.js +55 -2
- package/dist/esm/abi/310/iLinearInterestRateModelV310.js +68 -0
- package/dist/esm/abi/errors.js +0 -143
- package/dist/esm/abi/iPriceFeed.js +60 -0
- package/dist/esm/common-utils/index.js +1 -0
- package/dist/esm/common-utils/package.json +1 -0
- package/dist/esm/{sdk/sdk-legacy/core/assets.js → common-utils/utils/assetsMath.js} +80 -14
- package/dist/esm/common-utils/utils/bigintMath.js +41 -0
- package/dist/esm/common-utils/utils/creditAccount/calcHealthFactor.js +55 -0
- package/dist/esm/common-utils/utils/creditAccount/calcOverallAPY.js +60 -0
- package/dist/esm/common-utils/utils/creditAccount/calcQuotaBorrowRate.js +18 -0
- package/dist/esm/common-utils/utils/creditAccount/calcRelativeBaseBorrowRate.js +10 -0
- package/dist/esm/common-utils/utils/creditAccount/debt.js +43 -0
- package/dist/esm/common-utils/utils/creditAccount/getTimeToLiquidation.js +18 -0
- package/dist/esm/common-utils/utils/creditAccount/index.js +10 -0
- package/dist/esm/common-utils/utils/creditAccount/liquidationPrice.js +23 -0
- package/dist/esm/common-utils/utils/creditAccount/quotaUtils.js +125 -0
- package/dist/esm/common-utils/utils/creditAccount/sort.js +67 -0
- package/dist/esm/common-utils/utils/endpoints.js +41 -0
- package/dist/esm/common-utils/utils/index.js +5 -0
- package/dist/esm/common-utils/utils/priceMath.js +42 -0
- package/dist/esm/dev/AccountOpener.js +3 -3
- package/dist/esm/dev/ltUtils.js +7 -100
- package/dist/esm/dev/migrateFaucet.js +24 -51
- package/dist/esm/dev/providers.js +12 -0
- package/dist/esm/history/assembleOperations.js +79 -0
- package/dist/esm/history/classifyMulticallOperations.js +137 -0
- package/dist/esm/history/errors.js +62 -0
- package/dist/esm/history/extractProtocolCalls.js +32 -0
- package/dist/esm/history/extractTransfers.js +148 -0
- package/dist/esm/history/findFacadeCalls.js +63 -0
- package/dist/esm/history/index.js +9 -0
- package/dist/esm/history/mapOperations.js +55 -0
- package/dist/esm/history/package.json +1 -0
- package/dist/esm/history/parseCreditAccountTransaction.js +62 -0
- package/dist/esm/history/populateContractsRegister.js +52 -0
- package/dist/esm/history/toLegacyOperation.js +157 -0
- package/dist/esm/history/trace-utils.js +36 -0
- package/dist/esm/permissionless/bindings/cross-chain-multisig.js +3 -3
- package/dist/esm/permissionless/bindings/instance-manager.js +3 -3
- package/dist/esm/permissionless/utils/price-update/get-prices.js +2 -6
- package/dist/esm/plugins/adapters/AdaptersPlugin.js +14 -148
- package/dist/esm/plugins/adapters/abi/index.js +1 -0
- package/dist/esm/plugins/adapters/abi/targetContractAbi.js +5113 -0
- package/dist/esm/plugins/adapters/contracts/AbstractAdapter.js +133 -4
- package/dist/esm/plugins/adapters/contracts/AccountMigratorAdapterContract.js +8 -1
- package/dist/esm/plugins/adapters/contracts/BalancerV3RouterAdapterContract.js +64 -30
- package/dist/esm/plugins/adapters/contracts/BalancerV3WrapperAdapterContract.js +27 -11
- package/dist/esm/plugins/adapters/contracts/CamelotV3AdapterContract.js +40 -21
- package/dist/esm/plugins/adapters/contracts/ConvexV1BaseRewardPoolAdapterContract.js +109 -26
- package/dist/esm/plugins/adapters/contracts/ConvexV1BoosterAdapterContract.js +76 -25
- package/dist/esm/plugins/adapters/contracts/Curve2AssetsAdapterContract.js +81 -31
- package/dist/esm/plugins/adapters/contracts/Curve3AssetsAdapterContract.js +81 -31
- package/dist/esm/plugins/adapters/contracts/Curve4AssetsAdapterContract.js +86 -31
- package/dist/esm/plugins/adapters/contracts/CurveV1AdapterDeposit.js +82 -33
- package/dist/esm/plugins/adapters/contracts/CurveV1AdapterStETHContract.js +64 -26
- package/dist/esm/plugins/adapters/contracts/CurveV1StableNGAdapterContract.js +97 -34
- package/dist/esm/plugins/adapters/contracts/DaiUsdsAdapterContract.js +48 -14
- package/dist/esm/plugins/adapters/contracts/ERC4626AdapterContract.js +64 -27
- package/dist/esm/plugins/adapters/contracts/ERC4626ReferralAdapterContract.js +48 -14
- package/dist/esm/plugins/adapters/contracts/FluidDexAdapterContract.js +36 -14
- package/dist/esm/plugins/adapters/contracts/InfinifiGatewayAdapterContract.js +58 -23
- package/dist/esm/plugins/adapters/contracts/InfinifiUnwindingGatewayAdapterContract.js +37 -15
- package/dist/esm/plugins/adapters/contracts/KelpLRTDepositPoolAdapterContract.js +33 -12
- package/dist/esm/plugins/adapters/contracts/KelpLRTWithdrawalManagerAdapterContract.js +40 -16
- package/dist/esm/plugins/adapters/contracts/LidoV1AdapterContract.js +49 -17
- package/dist/esm/plugins/adapters/contracts/MellowClaimerAdapterContract.js +31 -11
- package/dist/esm/plugins/adapters/contracts/MellowDVVAdapterContract.js +47 -14
- package/dist/esm/plugins/adapters/contracts/MellowDepositQueueAdapterContract.js +44 -17
- package/dist/esm/plugins/adapters/contracts/MellowERC4626VaultAdapterContract.js +82 -43
- package/dist/esm/plugins/adapters/contracts/MellowRedeemQueueAdapterContract.js +36 -14
- package/dist/esm/plugins/adapters/contracts/MellowWrapperAdapterContract.js +29 -11
- package/dist/esm/plugins/adapters/contracts/MidasIssuanceVaultAdapterContract.js +46 -17
- package/dist/esm/plugins/adapters/contracts/MidasRedemptionVaultAdapterContract.js +55 -22
- package/dist/esm/plugins/adapters/contracts/PendleRouterAdapterContract.js +91 -54
- package/dist/esm/plugins/adapters/contracts/StakingRewardsAdapterContract.js +73 -37
- package/dist/esm/plugins/adapters/contracts/TraderJoeRouterAdapterContract.js +54 -25
- package/dist/esm/plugins/adapters/contracts/UniswapV2AdapterContract.js +45 -22
- package/dist/esm/plugins/adapters/contracts/UniswapV3AdapterContract.js +43 -24
- package/dist/esm/plugins/adapters/contracts/UniswapV4AdapterContract.js +57 -28
- package/dist/esm/plugins/adapters/contracts/UpshiftVaultAdapterContract.js +48 -18
- package/dist/esm/plugins/adapters/contracts/VelodromeV2AdapterContract.js +46 -25
- package/dist/esm/plugins/adapters/contracts/WstETHV1AdapterContract.js +39 -11
- package/dist/esm/plugins/adapters/contracts/index.js +3 -7
- package/dist/esm/plugins/adapters/createAdapter.js +140 -0
- package/dist/esm/plugins/adapters/index.js +3 -0
- package/dist/esm/plugins/adapters/transferHelpers.js +95 -0
- package/dist/esm/plugins/bots/PartialLiquidationBotV310Contract.js +5 -8
- package/dist/esm/plugins/bots/abi/index.js +0 -1
- package/dist/esm/plugins/degen-distributors/DegenDistributorsPlugin.js +2 -1
- package/dist/esm/plugins/pools-history/Pools7DAgoPlugin.js +1 -2
- package/dist/esm/plugins/zappers/ZappersPlugin.js +126 -0
- package/dist/esm/{sdk/market/ZapperRegister.js → plugins/zappers/extraZappers.js} +2 -109
- package/dist/esm/plugins/zappers/index.js +3 -0
- package/dist/esm/plugins/zappers/package.json +1 -0
- package/dist/esm/sdk/GearboxSDK.js +7 -23
- package/dist/esm/sdk/accounts/AbstractCreditAccountsService.js +23 -91
- package/dist/esm/sdk/accounts/CreditAccountsServiceV310.js +11 -12
- package/dist/esm/sdk/accounts/createCreditAccountService.js +1 -5
- package/dist/esm/sdk/accounts/index.js +0 -1
- package/dist/esm/sdk/base/BaseContract.js +62 -6
- package/dist/esm/sdk/base/ChainContractsRegister.js +33 -10
- package/dist/esm/sdk/base/Construct.js +29 -15
- package/dist/esm/sdk/base/PlaceholderContract.js +2 -2
- package/dist/esm/sdk/base/SDKConstruct.js +1 -1
- package/dist/esm/sdk/base/TokensMeta.js +36 -117
- package/dist/esm/sdk/base/errors.js +11 -0
- package/dist/esm/sdk/base/index.js +1 -1
- package/dist/esm/sdk/chain/chains.js +14 -31
- package/dist/esm/sdk/constants/addresses.js +1 -83
- package/dist/esm/sdk/constants/index.js +1 -0
- package/dist/esm/sdk/constants/networks.js +0 -31
- package/dist/esm/sdk/{base/token-types.js → constants/phantom-tokens.js} +0 -4
- package/dist/esm/sdk/constants/versions.js +0 -6
- package/dist/esm/sdk/core/{address-provider/AbstractAddressProviderContract.js → AbstractAddressProviderContract.js} +3 -3
- package/dist/esm/sdk/core/{address-provider/AddressProviderV310Contract.js → AddressProviderV310Contract.js} +1 -1
- package/dist/esm/sdk/core/{address-provider/createAddressProvider.js → createAddressProvider.js} +4 -8
- package/dist/esm/sdk/core/index.js +3 -3
- package/dist/esm/sdk/index.js +0 -5
- package/dist/esm/sdk/market/MarketConfiguratorContract.js +3 -2
- package/dist/esm/sdk/market/MarketRegister.js +2 -3
- package/dist/esm/sdk/market/MarketSuite.js +2 -5
- package/dist/esm/sdk/market/adapters/PlaceholderAdapterContracts.js +29 -5
- package/dist/esm/sdk/market/adapters/index.js +1 -1
- package/dist/esm/sdk/market/credit/CreditFacadeV310BaseContract.js +86 -0
- package/dist/esm/sdk/market/credit/CreditFacadeV310Contract.js +3 -43
- package/dist/esm/sdk/market/credit/CreditManagerV310Contract.js +1 -4
- package/dist/esm/sdk/market/credit/createCreditConfigurator.js +2 -5
- package/dist/esm/sdk/market/credit/createCreditFacade.js +2 -5
- package/dist/esm/sdk/market/credit/createCreditManager.js +2 -5
- package/dist/esm/sdk/market/credit/index.js +1 -3
- package/dist/esm/sdk/market/index.js +0 -1
- package/dist/esm/sdk/market/oracle/PriceOracleBaseContract.js +10 -59
- package/dist/esm/sdk/market/oracle/createPriceOracle.js +7 -38
- package/dist/esm/sdk/market/oracle/index.js +0 -1
- package/dist/esm/sdk/market/pool/GaugeContract.js +3 -3
- package/dist/esm/sdk/market/pool/LinearInterestRateModelContract.js +2 -2
- package/dist/esm/sdk/market/pool/PoolV310Contract.js +1 -1
- package/dist/esm/sdk/market/pool/createPool.js +1 -5
- package/dist/esm/sdk/market/pool/createPoolQuotaKeeper.js +1 -5
- package/dist/esm/sdk/market/pool/index.js +0 -2
- package/dist/esm/sdk/market/pricefeeds/AbstractLPPriceFeed.js +14 -53
- package/dist/esm/sdk/market/pricefeeds/PriceFeedsRegister.js +5 -3
- package/dist/esm/sdk/market/pricefeeds/PythPriceFeed.js +21 -1
- package/dist/esm/sdk/market/pricefeeds/RedstonePriceFeed.js +20 -47
- package/dist/esm/sdk/market/pricefeeds/updates/PriceUpdatesCache.js +0 -17
- package/dist/esm/sdk/market/pricefeeds/updates/PythUpdater.js +7 -7
- package/dist/esm/sdk/market/pricefeeds/updates/RedstoneUpdater.js +6 -6
- package/dist/esm/sdk/market/pricefeeds/updates/fetchPythPayloads.js +7 -7
- package/dist/esm/sdk/market/pricefeeds/updates/fetchRedstonePayloads.js +10 -10
- package/dist/esm/sdk/plugins/index.js +0 -1
- package/dist/esm/sdk/pools/AbstractPoolService.js +113 -0
- package/dist/esm/sdk/pools/PoolServiceV310.js +6 -0
- package/dist/esm/sdk/pools/createPoolService.js +11 -0
- package/dist/esm/sdk/pools/index.js +2 -1
- package/dist/esm/sdk/router/AbstractRouterContract.js +0 -4
- package/dist/esm/sdk/router/RouterV310Contract.js +3 -32
- package/dist/esm/sdk/router/createRouter.js +1 -5
- package/dist/esm/sdk/router/helpers.js +0 -4
- package/dist/esm/sdk/router/index.js +0 -1
- package/dist/esm/sdk/utils/abi-decode.js +43 -2
- package/dist/esm/sdk/utils/formatter.js +37 -1
- package/dist/types/abi/310/iLinearInterestRateModelV310.d.ts +111 -0
- package/dist/types/abi/errors.d.ts +186 -996
- package/dist/types/abi/iPriceFeed.d.ts +87 -0
- package/dist/types/common-utils/index.d.ts +1 -0
- package/dist/types/common-utils/utils/assetsMath.d.ts +114 -0
- package/dist/types/common-utils/utils/bigintMath.d.ts +43 -0
- package/dist/types/common-utils/utils/creditAccount/calcHealthFactor.d.ts +25 -0
- package/dist/types/common-utils/utils/creditAccount/calcOverallAPY.d.ts +37 -0
- package/dist/types/common-utils/utils/creditAccount/calcQuotaBorrowRate.d.ts +18 -0
- package/dist/types/common-utils/utils/creditAccount/calcRelativeBaseBorrowRate.d.ts +15 -0
- package/dist/types/common-utils/utils/creditAccount/debt.d.ts +35 -0
- package/dist/types/common-utils/utils/creditAccount/getTimeToLiquidation.d.ts +16 -0
- package/dist/types/common-utils/utils/creditAccount/index.d.ts +10 -0
- package/dist/types/common-utils/utils/creditAccount/liquidationPrice.d.ts +25 -0
- package/dist/types/common-utils/utils/creditAccount/quotaUtils.d.ts +81 -0
- package/dist/types/common-utils/utils/creditAccount/sort.d.ts +55 -0
- package/dist/types/common-utils/utils/creditAccount/types.d.ts +18 -0
- package/dist/types/common-utils/utils/endpoints.d.ts +27 -0
- package/dist/types/common-utils/utils/index.d.ts +5 -0
- package/dist/types/common-utils/utils/priceMath.d.ts +47 -0
- package/dist/types/dev/migrateFaucet.d.ts +4 -5
- package/dist/types/dev/providers.d.ts +5 -5
- package/dist/types/history/assembleOperations.d.ts +22 -0
- package/dist/types/history/classifyMulticallOperations.d.ts +35 -0
- package/dist/types/history/errors.d.ts +30 -0
- package/dist/types/history/extractProtocolCalls.d.ts +8 -0
- package/dist/types/history/extractTransfers.d.ts +22 -0
- package/dist/types/history/findFacadeCalls.d.ts +9 -0
- package/dist/types/history/index.d.ts +6 -0
- package/dist/types/history/inner-operations.d.ts +57 -0
- package/dist/types/history/internal-types.d.ts +47 -0
- package/dist/types/history/mapOperations.d.ts +27 -0
- package/dist/types/history/parseCreditAccountTransaction.d.ts +27 -0
- package/dist/types/history/populateContractsRegister.d.ts +19 -0
- package/dist/types/history/toLegacyOperation.d.ts +18 -0
- package/dist/types/history/trace-utils.d.ts +12 -0
- package/dist/types/history/types.d.ts +71 -0
- package/dist/types/permissionless/bindings/cross-chain-multisig.d.ts +3 -3
- package/dist/types/permissionless/bindings/instance-manager.d.ts +3 -3
- package/dist/types/plugins/adapters/abi/index.d.ts +1 -0
- package/dist/types/plugins/adapters/abi/targetContractAbi.d.ts +8262 -0
- package/dist/types/plugins/adapters/contracts/AbstractAdapter.d.ts +50 -8
- package/dist/types/plugins/adapters/contracts/AccountMigratorAdapterContract.d.ts +238 -4
- package/dist/types/plugins/adapters/contracts/BalancerV3RouterAdapterContract.d.ts +135 -8
- package/dist/types/plugins/adapters/contracts/BalancerV3WrapperAdapterContract.d.ts +45 -4
- package/dist/types/plugins/adapters/contracts/CamelotV3AdapterContract.d.ts +225 -7
- package/dist/types/plugins/adapters/contracts/ConvexV1BaseRewardPoolAdapterContract.d.ts +418 -8
- package/dist/types/plugins/adapters/contracts/ConvexV1BoosterAdapterContract.d.ts +227 -10
- package/dist/types/plugins/adapters/contracts/Curve2AssetsAdapterContract.d.ts +1257 -10
- package/dist/types/plugins/adapters/contracts/Curve3AssetsAdapterContract.d.ts +1257 -10
- package/dist/types/plugins/adapters/contracts/Curve4AssetsAdapterContract.d.ts +1257 -10
- package/dist/types/plugins/adapters/contracts/CurveV1AdapterDeposit.d.ts +575 -11
- package/dist/types/plugins/adapters/contracts/CurveV1AdapterStETHContract.d.ts +1244 -10
- package/dist/types/plugins/adapters/contracts/CurveV1StableNGAdapterContract.d.ts +1227 -11
- package/dist/types/plugins/adapters/contracts/DaiUsdsAdapterContract.d.ts +69 -6
- package/dist/types/plugins/adapters/contracts/ERC4626AdapterContract.d.ts +492 -6
- package/dist/types/plugins/adapters/contracts/ERC4626ReferralAdapterContract.d.ts +67 -6
- package/dist/types/plugins/adapters/contracts/FluidDexAdapterContract.d.ts +132 -6
- package/dist/types/plugins/adapters/contracts/InfinifiGatewayAdapterContract.d.ts +144 -8
- package/dist/types/plugins/adapters/contracts/InfinifiUnwindingGatewayAdapterContract.d.ts +163 -5
- package/dist/types/plugins/adapters/contracts/KelpLRTDepositPoolAdapterContract.d.ts +248 -6
- package/dist/types/plugins/adapters/contracts/KelpLRTWithdrawalManagerAdapterContract.d.ts +367 -6
- package/dist/types/plugins/adapters/contracts/LidoV1AdapterContract.d.ts +104 -7
- package/dist/types/plugins/adapters/contracts/MellowClaimerAdapterContract.d.ts +46 -5
- package/dist/types/plugins/adapters/contracts/MellowDVVAdapterContract.d.ts +488 -6
- package/dist/types/plugins/adapters/contracts/MellowDepositQueueAdapterContract.d.ts +20 -7
- package/dist/types/plugins/adapters/contracts/MellowERC4626VaultAdapterContract.d.ts +493 -7
- package/dist/types/plugins/adapters/contracts/MellowRedeemQueueAdapterContract.d.ts +18 -6
- package/dist/types/plugins/adapters/contracts/MellowWrapperAdapterContract.d.ts +56 -5
- package/dist/types/plugins/adapters/contracts/MidasIssuanceVaultAdapterContract.d.ts +52 -7
- package/dist/types/plugins/adapters/contracts/MidasRedemptionVaultAdapterContract.d.ts +199 -7
- package/dist/types/plugins/adapters/contracts/PendleRouterAdapterContract.d.ts +1040 -17
- package/dist/types/plugins/adapters/contracts/StakingRewardsAdapterContract.d.ts +82 -8
- package/dist/types/plugins/adapters/contracts/TraderJoeRouterAdapterContract.d.ts +148 -10
- package/dist/types/plugins/adapters/contracts/UniswapV2AdapterContract.d.ts +758 -5
- package/dist/types/plugins/adapters/contracts/UniswapV3AdapterContract.d.ts +183 -4
- package/dist/types/plugins/adapters/contracts/UniswapV4AdapterContract.d.ts +110 -5
- package/dist/types/plugins/adapters/contracts/UpshiftVaultAdapterContract.d.ts +84 -7
- package/dist/types/plugins/adapters/contracts/VelodromeV2AdapterContract.d.ts +122 -4
- package/dist/types/plugins/adapters/contracts/WstETHV1AdapterContract.d.ts +275 -5
- package/dist/types/plugins/adapters/contracts/index.d.ts +3 -7
- package/dist/types/plugins/adapters/createAdapter.d.ts +5 -0
- package/dist/types/plugins/adapters/index.d.ts +3 -0
- package/dist/types/plugins/adapters/legacyAdapterOperations.d.ts +200 -0
- package/dist/types/plugins/adapters/transferHelpers.d.ts +60 -0
- package/dist/types/plugins/adapters/types.d.ts +64 -2
- package/dist/types/plugins/bots/abi/index.d.ts +0 -1
- package/dist/types/plugins/zappers/ZappersPlugin.d.ts +18 -0
- package/dist/types/plugins/zappers/extraZappers.d.ts +6 -0
- package/dist/types/plugins/zappers/index.d.ts +3 -0
- package/dist/types/plugins/zappers/types.d.ts +12 -0
- package/dist/types/sdk/GearboxSDK.d.ts +0 -3
- package/dist/types/sdk/accounts/AbstractCreditAccountsService.d.ts +3 -13
- package/dist/types/sdk/accounts/CreditAccountsServiceV310.d.ts +1 -1
- package/dist/types/sdk/accounts/createCreditAccountService.d.ts +1 -1
- package/dist/types/sdk/accounts/index.d.ts +0 -1
- package/dist/types/sdk/accounts/types.d.ts +9 -37
- package/dist/types/sdk/base/BaseContract.d.ts +17 -4
- package/dist/types/sdk/base/ChainContractsRegister.d.ts +11 -3
- package/dist/types/sdk/base/Construct.d.ts +13 -13
- package/dist/types/sdk/base/PlaceholderContract.d.ts +2 -2
- package/dist/types/sdk/base/TokensMeta.d.ts +18 -11
- package/dist/types/sdk/base/errors.d.ts +3 -0
- package/dist/types/sdk/base/index.d.ts +1 -1
- package/dist/types/sdk/base/types.d.ts +37 -0
- package/dist/types/sdk/chain/chains.d.ts +1 -1
- package/dist/types/sdk/constants/addresses.d.ts +0 -19
- package/dist/types/sdk/constants/index.d.ts +1 -0
- package/dist/types/sdk/constants/networks.d.ts +0 -5
- package/dist/types/sdk/constants/phantom-tokens.d.ts +2 -0
- package/dist/types/sdk/constants/versions.d.ts +0 -2
- package/dist/types/sdk/core/{address-provider/AbstractAddressProviderContract.d.ts → AbstractAddressProviderContract.d.ts} +4 -4
- package/dist/types/sdk/core/{address-provider/AddressProviderV310Contract.d.ts → AddressProviderV310Contract.d.ts} +1 -1
- package/dist/types/sdk/core/{address-provider/createAddressProvider.d.ts → createAddressProvider.d.ts} +1 -1
- package/dist/types/sdk/core/index.d.ts +3 -3
- package/dist/types/sdk/core/{address-provider/types.d.ts → types.d.ts} +3 -3
- package/dist/types/sdk/index.d.ts +0 -5
- package/dist/types/sdk/market/MarketConfiguratorContract.d.ts +1 -1
- package/dist/types/sdk/market/MarketRegister.d.ts +2 -3
- package/dist/types/sdk/market/MarketSuite.d.ts +0 -1
- package/dist/types/sdk/market/adapters/PlaceholderAdapterContracts.d.ts +10 -5
- package/dist/types/sdk/market/adapters/index.d.ts +1 -1
- package/dist/types/sdk/market/credit/CreditConfiguratorV310Contract.d.ts +6 -2
- package/dist/types/sdk/market/credit/{CreditFacadeV300Contract.d.ts → CreditFacadeV310BaseContract.d.ts} +335 -267
- package/dist/types/sdk/market/credit/CreditFacadeV310Contract.d.ts +6 -848
- package/dist/types/sdk/market/credit/index.d.ts +1 -3
- package/dist/types/sdk/market/credit/types.d.ts +2 -3
- package/dist/types/sdk/market/index.d.ts +0 -1
- package/dist/types/sdk/market/loss-policy/createLossPolicy.d.ts +0 -12
- package/dist/types/sdk/market/oracle/PriceOracleBaseContract.d.ts +2 -21
- package/dist/types/sdk/market/oracle/PriceOracleV310Contract.d.ts +2 -2
- package/dist/types/sdk/market/oracle/createPriceOracle.d.ts +1 -15
- package/dist/types/sdk/market/oracle/index.d.ts +0 -1
- package/dist/types/sdk/market/oracle/types.d.ts +6 -18
- package/dist/types/sdk/market/pool/GaugeContract.d.ts +116 -76
- package/dist/types/sdk/market/pool/LinearInterestRateModelContract.d.ts +20 -0
- package/dist/types/sdk/market/pool/index.d.ts +0 -2
- package/dist/types/sdk/market/pool/types.d.ts +2 -4
- package/dist/types/sdk/market/pricefeeds/AbstractLPPriceFeed.d.ts +0 -3
- package/dist/types/sdk/market/pricefeeds/PythPriceFeed.d.ts +21 -1
- package/dist/types/sdk/market/pricefeeds/types.d.ts +0 -9
- package/dist/types/sdk/market/pricefeeds/updates/PriceUpdatesCache.d.ts +1 -8
- package/dist/types/sdk/market/pricefeeds/updates/PythUpdater.d.ts +1 -1
- package/dist/types/sdk/market/pricefeeds/updates/RedstoneUpdater.d.ts +1 -1
- package/dist/types/sdk/market/pricefeeds/updates/fetchPythPayloads.d.ts +2 -2
- package/dist/types/sdk/market/pricefeeds/updates/fetchRedstonePayloads.d.ts +2 -2
- package/dist/types/sdk/options.d.ts +2 -2
- package/dist/types/sdk/plugins/index.d.ts +0 -1
- package/dist/types/sdk/pools/AbstractPoolService.d.ts +9 -0
- package/dist/types/sdk/pools/PoolServiceV310.d.ts +4 -0
- package/dist/types/sdk/pools/createPoolService.d.ts +3 -0
- package/dist/types/sdk/pools/index.d.ts +2 -1
- package/dist/types/sdk/pools/types.d.ts +62 -64
- package/dist/types/sdk/router/AbstractRouterContract.d.ts +2 -7
- package/dist/types/sdk/router/RouterV310Contract.d.ts +1 -16
- package/dist/types/sdk/router/helpers.d.ts +2 -2
- package/dist/types/sdk/router/index.d.ts +0 -1
- package/dist/types/sdk/router/types.d.ts +2 -55
- package/dist/types/sdk/types/state-human.d.ts +1 -4
- package/dist/types/sdk/utils/abi-decode.d.ts +14 -1
- package/dist/types/sdk/utils/formatter.d.ts +9 -0
- package/package.json +26 -12
- package/dist/cjs/abi/iDegenDistributorV300.js +0 -100
- package/dist/cjs/abi/routerV300.js +0 -406
- package/dist/cjs/abi/v300.js +0 -4189
- package/dist/cjs/plugins/adapters/contracts/BalancerV2VaultAdapterContract.js +0 -51
- package/dist/cjs/plugins/adapters/contracts/EqualizerRouterAdapterContract.js +0 -58
- package/dist/cjs/plugins/adapters/contracts/InfraredVaultAdapterContract.js +0 -49
- package/dist/cjs/plugins/adapters/contracts/KodiakIslandGatewayAdapterContract.js +0 -56
- package/dist/cjs/plugins/adapters/contracts/MellowVaultAdapterContract.js +0 -46
- package/dist/cjs/plugins/adapters/contracts/types.js +0 -77
- package/dist/cjs/plugins/bots/abi/iPartialLiquidationBotV300.js +0 -164
- package/dist/cjs/sdk/accountMigration/AbstractMigrateCreditAccountsService.js +0 -192
- package/dist/cjs/sdk/accountMigration/createMigrateCreditAccountsService.js +0 -41
- package/dist/cjs/sdk/accountMigration/index.js +0 -26
- package/dist/cjs/sdk/accounts/CreditAccountsServiceV300.js +0 -454
- package/dist/cjs/sdk/core/BotListV3Contract.js +0 -101
- package/dist/cjs/sdk/core/GearStakingV3Contract.js +0 -83
- package/dist/cjs/sdk/core/address-provider/AddressProviderV300Contract.js +0 -116
- package/dist/cjs/sdk/core/address-provider/index.js +0 -28
- package/dist/cjs/sdk/gauges/GaugeStakingService.js +0 -118
- package/dist/cjs/sdk/gauges/index.js +0 -24
- package/dist/cjs/sdk/market/credit/CreditConfiguratorV300Contract.js +0 -139
- package/dist/cjs/sdk/market/credit/CreditFacadeV300Contract.js +0 -160
- package/dist/cjs/sdk/market/credit/CreditManagerV300Contract.js +0 -114
- package/dist/cjs/sdk/market/oracle/PriceOracleV300Contract.js +0 -129
- package/dist/cjs/sdk/market/pool/PoolQuotaKeeperV300Contract.js +0 -85
- package/dist/cjs/sdk/market/pool/PoolV300Contract.js +0 -135
- package/dist/cjs/sdk/plugins/V300StalenessPeriodPlugin.js +0 -131
- package/dist/cjs/sdk/poolMigration/index.js +0 -84
- package/dist/cjs/sdk/pools/PoolService.js +0 -260
- package/dist/cjs/sdk/router/PathOptionFactory.js +0 -105
- package/dist/cjs/sdk/router/RouterV300Contract.js +0 -390
- package/dist/cjs/sdk/sdk-gov-legacy/contracts/adapters.js +0 -67
- package/dist/cjs/sdk/sdk-gov-legacy/contracts/contracts.js +0 -2576
- package/dist/cjs/sdk/sdk-gov-legacy/contracts/protocols.js +0 -58
- package/dist/cjs/sdk/sdk-gov-legacy/index.js +0 -26
- package/dist/cjs/sdk/sdk-gov-legacy/oracles/PriceFeedType.js +0 -52
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/aave.js +0 -16
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/aura.js +0 -239
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/balancer.js +0 -339
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/compound.js +0 -16
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/convex.js +0 -450
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/curveLP.js +0 -394
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/erc4626.js +0 -16
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/gear.js +0 -16
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/index.js +0 -52
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/normal.js +0 -562
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/stakingRewards.js +0 -45
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/token.js +0 -1002
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/tokenData.js +0 -80
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/tokenType.js +0 -50
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/wrapped.js +0 -16
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/yearn.js +0 -95
- package/dist/cjs/sdk/sdk-gov-legacy/tokens/zircuit.js +0 -16
- package/dist/cjs/sdk/sdk-legacy/core/assets.js +0 -150
- package/dist/cjs/sdk/sdk-legacy/core/creditAccount.js +0 -510
- package/dist/cjs/sdk/sdk-legacy/core/creditAccount.spec.js +0 -1802
- package/dist/cjs/sdk/sdk-legacy/core/creditManager.js +0 -263
- package/dist/cjs/sdk/sdk-legacy/core/creditSession.js +0 -256
- package/dist/cjs/sdk/sdk-legacy/core/endpoint.js +0 -137
- package/dist/cjs/sdk/sdk-legacy/core/eventOrTx.js +0 -87
- package/dist/cjs/sdk/sdk-legacy/core/pool.js +0 -334
- package/dist/cjs/sdk/sdk-legacy/core/transactions.js +0 -783
- package/dist/cjs/sdk/sdk-legacy/gearboxRewards/api.js +0 -366
- package/dist/cjs/sdk/sdk-legacy/gearboxRewards/apy.js +0 -176
- package/dist/cjs/sdk/sdk-legacy/gearboxRewards/extraAPY.js +0 -137
- package/dist/cjs/sdk/sdk-legacy/gearboxRewards/index.js +0 -26
- package/dist/cjs/sdk/sdk-legacy/index.js +0 -52
- package/dist/cjs/sdk/sdk-legacy/payload/creditAccount.js +0 -16
- package/dist/cjs/sdk/sdk-legacy/payload/creditManager.js +0 -16
- package/dist/cjs/sdk/sdk-legacy/payload/creditSession.js +0 -16
- package/dist/cjs/sdk/sdk-legacy/payload/graphPayload.js +0 -16
- package/dist/cjs/sdk/sdk-legacy/payload/pool.js +0 -16
- package/dist/cjs/sdk/sdk-legacy/tokens/tokenData.js +0 -92
- package/dist/cjs/sdk/sdk-legacy/utils/formatter.js +0 -79
- package/dist/cjs/sdk/sdk-legacy/utils/price.js +0 -35
- package/dist/esm/abi/iDegenDistributorV300.js +0 -76
- package/dist/esm/abi/iStateSerializer.js +0 -12
- package/dist/esm/abi/routerV300.js +0 -381
- package/dist/esm/abi/v300.js +0 -4154
- package/dist/esm/plugins/adapters/contracts/BalancerV2VaultAdapterContract.js +0 -27
- package/dist/esm/plugins/adapters/contracts/EqualizerRouterAdapterContract.js +0 -34
- package/dist/esm/plugins/adapters/contracts/InfraredVaultAdapterContract.js +0 -25
- package/dist/esm/plugins/adapters/contracts/KodiakIslandGatewayAdapterContract.js +0 -32
- package/dist/esm/plugins/adapters/contracts/MellowVaultAdapterContract.js +0 -22
- package/dist/esm/plugins/adapters/contracts/YearnV2AdapterContract.js +0 -22
- package/dist/esm/plugins/adapters/contracts/types.js +0 -48
- package/dist/esm/plugins/bots/abi/iPartialLiquidationBotV300.js +0 -140
- package/dist/esm/sdk/accountMigration/AbstractMigrateCreditAccountsService.js +0 -171
- package/dist/esm/sdk/accountMigration/MigrateCreditAccountsServiceV300.js +0 -6
- package/dist/esm/sdk/accountMigration/MigrateCreditAccountsServiceV310.js +0 -6
- package/dist/esm/sdk/accountMigration/createMigrateCreditAccountsService.js +0 -17
- package/dist/esm/sdk/accountMigration/index.js +0 -3
- package/dist/esm/sdk/accounts/CreditAccountsServiceV300.js +0 -442
- package/dist/esm/sdk/core/BotListV3Contract.js +0 -77
- package/dist/esm/sdk/core/GearStakingV3Contract.js +0 -59
- package/dist/esm/sdk/core/address-provider/AddressProviderV300Contract.js +0 -82
- package/dist/esm/sdk/core/address-provider/index.js +0 -4
- package/dist/esm/sdk/gauges/GaugeStakingService.js +0 -94
- package/dist/esm/sdk/gauges/index.js +0 -2
- package/dist/esm/sdk/market/credit/CreditConfiguratorV300Contract.js +0 -115
- package/dist/esm/sdk/market/credit/CreditFacadeV300Contract.js +0 -143
- package/dist/esm/sdk/market/credit/CreditManagerV300Contract.js +0 -90
- package/dist/esm/sdk/market/oracle/PriceOracleV300Contract.js +0 -111
- package/dist/esm/sdk/market/pool/PoolQuotaKeeperV300Contract.js +0 -61
- package/dist/esm/sdk/market/pool/PoolV300Contract.js +0 -116
- package/dist/esm/sdk/plugins/V300StalenessPeriodPlugin.js +0 -107
- package/dist/esm/sdk/poolMigration/index.js +0 -60
- package/dist/esm/sdk/pools/PoolService.js +0 -240
- package/dist/esm/sdk/router/PathOptionFactory.js +0 -92
- package/dist/esm/sdk/router/RouterV300Contract.js +0 -374
- package/dist/esm/sdk/sdk-gov-legacy/contracts/adapters.js +0 -43
- package/dist/esm/sdk/sdk-gov-legacy/contracts/contracts.js +0 -2538
- package/dist/esm/sdk/sdk-gov-legacy/contracts/index.js +0 -2
- package/dist/esm/sdk/sdk-gov-legacy/contracts/protocols.js +0 -34
- package/dist/esm/sdk/sdk-gov-legacy/index.js +0 -3
- package/dist/esm/sdk/sdk-gov-legacy/oracles/PriceFeedType.js +0 -28
- package/dist/esm/sdk/sdk-gov-legacy/oracles/index.js +0 -1
- package/dist/esm/sdk/sdk-gov-legacy/tokens/aura.js +0 -213
- package/dist/esm/sdk/sdk-gov-legacy/tokens/balancer.js +0 -314
- package/dist/esm/sdk/sdk-gov-legacy/tokens/convex.js +0 -424
- package/dist/esm/sdk/sdk-gov-legacy/tokens/curveLP.js +0 -369
- package/dist/esm/sdk/sdk-gov-legacy/tokens/gear.js +0 -0
- package/dist/esm/sdk/sdk-gov-legacy/tokens/index.js +0 -16
- package/dist/esm/sdk/sdk-gov-legacy/tokens/normal.js +0 -538
- package/dist/esm/sdk/sdk-gov-legacy/tokens/stakingRewards.js +0 -20
- package/dist/esm/sdk/sdk-gov-legacy/tokens/token.js +0 -975
- package/dist/esm/sdk/sdk-gov-legacy/tokens/tokenData.js +0 -55
- package/dist/esm/sdk/sdk-gov-legacy/tokens/tokenType.js +0 -26
- package/dist/esm/sdk/sdk-gov-legacy/tokens/wrapped.js +0 -0
- package/dist/esm/sdk/sdk-gov-legacy/tokens/yearn.js +0 -71
- package/dist/esm/sdk/sdk-gov-legacy/tokens/zircuit.js +0 -0
- package/dist/esm/sdk/sdk-legacy/core/creditAccount.js +0 -495
- package/dist/esm/sdk/sdk-legacy/core/creditAccount.spec.js +0 -1805
- package/dist/esm/sdk/sdk-legacy/core/creditManager.js +0 -242
- package/dist/esm/sdk/sdk-legacy/core/creditSession.js +0 -228
- package/dist/esm/sdk/sdk-legacy/core/endpoint.js +0 -107
- package/dist/esm/sdk/sdk-legacy/core/eventOrTx.js +0 -63
- package/dist/esm/sdk/sdk-legacy/core/pool.js +0 -311
- package/dist/esm/sdk/sdk-legacy/core/transactions.js +0 -732
- package/dist/esm/sdk/sdk-legacy/gearboxRewards/api.js +0 -332
- package/dist/esm/sdk/sdk-legacy/gearboxRewards/apy.js +0 -158
- package/dist/esm/sdk/sdk-legacy/gearboxRewards/extraAPY.js +0 -102
- package/dist/esm/sdk/sdk-legacy/gearboxRewards/index.js +0 -3
- package/dist/esm/sdk/sdk-legacy/gearboxRewards/merklAPI.js +0 -6
- package/dist/esm/sdk/sdk-legacy/index.js +0 -16
- package/dist/esm/sdk/sdk-legacy/payload/creditAccount.js +0 -0
- package/dist/esm/sdk/sdk-legacy/payload/creditManager.js +0 -0
- package/dist/esm/sdk/sdk-legacy/payload/creditSession.js +0 -0
- package/dist/esm/sdk/sdk-legacy/payload/graphPayload.js +0 -0
- package/dist/esm/sdk/sdk-legacy/payload/pool.js +0 -0
- package/dist/esm/sdk/sdk-legacy/tokens/tokenData.js +0 -68
- package/dist/esm/sdk/sdk-legacy/utils/formatter.js +0 -39
- package/dist/esm/sdk/sdk-legacy/utils/index.js +0 -3
- package/dist/esm/sdk/sdk-legacy/utils/math.js +0 -9
- package/dist/esm/sdk/sdk-legacy/utils/price.js +0 -11
- package/dist/types/abi/iDegenDistributorV300.d.ts +0 -87
- package/dist/types/abi/iStateSerializer.d.ts +0 -11
- package/dist/types/abi/routerV300.d.ts +0 -585
- package/dist/types/abi/v300.d.ts +0 -5484
- package/dist/types/plugins/adapters/contracts/BalancerV2VaultAdapterContract.d.ts +0 -482
- package/dist/types/plugins/adapters/contracts/EqualizerRouterAdapterContract.d.ts +0 -225
- package/dist/types/plugins/adapters/contracts/InfraredVaultAdapterContract.d.ts +0 -198
- package/dist/types/plugins/adapters/contracts/KodiakIslandGatewayAdapterContract.d.ts +0 -396
- package/dist/types/plugins/adapters/contracts/MellowVaultAdapterContract.d.ts +0 -203
- package/dist/types/plugins/adapters/contracts/YearnV2AdapterContract.d.ts +0 -185
- package/dist/types/plugins/adapters/contracts/types.d.ts +0 -34
- package/dist/types/plugins/bots/abi/iPartialLiquidationBotV300.d.ts +0 -210
- package/dist/types/sdk/accountMigration/AbstractMigrateCreditAccountsService.d.ts +0 -32
- package/dist/types/sdk/accountMigration/MigrateCreditAccountsServiceV300.d.ts +0 -4
- package/dist/types/sdk/accountMigration/MigrateCreditAccountsServiceV310.d.ts +0 -4
- package/dist/types/sdk/accountMigration/createMigrateCreditAccountsService.d.ts +0 -8
- package/dist/types/sdk/accountMigration/index.d.ts +0 -3
- package/dist/types/sdk/accountMigration/types.d.ts +0 -62
- package/dist/types/sdk/accounts/CreditAccountsServiceV300.d.ts +0 -32
- package/dist/types/sdk/base/token-types.d.ts +0 -25
- package/dist/types/sdk/core/BotListV3Contract.d.ts +0 -323
- package/dist/types/sdk/core/GearStakingV3Contract.d.ts +0 -520
- package/dist/types/sdk/core/address-provider/AddressProviderV300Contract.d.ts +0 -97
- package/dist/types/sdk/core/address-provider/index.d.ts +0 -4
- package/dist/types/sdk/gauges/GaugeStakingService.d.ts +0 -14
- package/dist/types/sdk/gauges/index.d.ts +0 -2
- package/dist/types/sdk/gauges/utils.d.ts +0 -22
- package/dist/types/sdk/market/ZapperRegister.d.ts +0 -17
- package/dist/types/sdk/market/credit/CreditConfiguratorV300Contract.d.ts +0 -648
- package/dist/types/sdk/market/credit/CreditManagerV300Contract.d.ts +0 -1043
- package/dist/types/sdk/market/oracle/PriceOracleV300Contract.d.ts +0 -369
- package/dist/types/sdk/market/pool/PoolQuotaKeeperV300Contract.d.ts +0 -448
- package/dist/types/sdk/market/pool/PoolV300Contract.d.ts +0 -1107
- package/dist/types/sdk/market/types.d.ts +0 -10
- package/dist/types/sdk/plugins/V300StalenessPeriodPlugin.d.ts +0 -29
- package/dist/types/sdk/poolMigration/index.d.ts +0 -11
- package/dist/types/sdk/pools/PoolService.d.ts +0 -11
- package/dist/types/sdk/router/PathOptionFactory.d.ts +0 -9
- package/dist/types/sdk/router/RouterV300Contract.d.ts +0 -39
- package/dist/types/sdk/sdk-gov-legacy/contracts/adapters.d.ts +0 -39
- package/dist/types/sdk/sdk-gov-legacy/contracts/contracts.d.ts +0 -194
- package/dist/types/sdk/sdk-gov-legacy/contracts/index.d.ts +0 -2
- package/dist/types/sdk/sdk-gov-legacy/contracts/protocols.d.ts +0 -30
- package/dist/types/sdk/sdk-gov-legacy/index.d.ts +0 -3
- package/dist/types/sdk/sdk-gov-legacy/oracles/PriceFeedType.d.ts +0 -24
- package/dist/types/sdk/sdk-gov-legacy/oracles/index.d.ts +0 -1
- package/dist/types/sdk/sdk-gov-legacy/tokens/aave.d.ts +0 -2
- package/dist/types/sdk/sdk-gov-legacy/tokens/aura.d.ts +0 -26
- package/dist/types/sdk/sdk-gov-legacy/tokens/balancer.d.ts +0 -15
- package/dist/types/sdk/sdk-gov-legacy/tokens/compound.d.ts +0 -1
- package/dist/types/sdk/sdk-gov-legacy/tokens/convex.d.ts +0 -31
- package/dist/types/sdk/sdk-gov-legacy/tokens/curveLP.d.ts +0 -25
- package/dist/types/sdk/sdk-gov-legacy/tokens/erc4626.d.ts +0 -1
- package/dist/types/sdk/sdk-gov-legacy/tokens/gear.d.ts +0 -5
- package/dist/types/sdk/sdk-gov-legacy/tokens/index.d.ts +0 -16
- package/dist/types/sdk/sdk-gov-legacy/tokens/normal.d.ts +0 -9
- package/dist/types/sdk/sdk-gov-legacy/tokens/stakingRewards.d.ts +0 -13
- package/dist/types/sdk/sdk-gov-legacy/tokens/token.d.ts +0 -34
- package/dist/types/sdk/sdk-gov-legacy/tokens/tokenData.d.ts +0 -5
- package/dist/types/sdk/sdk-gov-legacy/tokens/tokenType.d.ts +0 -24
- package/dist/types/sdk/sdk-gov-legacy/tokens/wrapped.d.ts +0 -7
- package/dist/types/sdk/sdk-gov-legacy/tokens/yearn.d.ts +0 -26
- package/dist/types/sdk/sdk-gov-legacy/tokens/zircuit.d.ts +0 -1
- package/dist/types/sdk/sdk-legacy/core/assets.d.ts +0 -39
- package/dist/types/sdk/sdk-legacy/core/creditAccount.d.ts +0 -152
- package/dist/types/sdk/sdk-legacy/core/creditAccount.spec.d.ts +0 -1
- package/dist/types/sdk/sdk-legacy/core/creditManager.d.ts +0 -92
- package/dist/types/sdk/sdk-legacy/core/creditSession.d.ts +0 -110
- package/dist/types/sdk/sdk-legacy/core/endpoint.d.ts +0 -24
- package/dist/types/sdk/sdk-legacy/core/eventOrTx.d.ts +0 -35
- package/dist/types/sdk/sdk-legacy/core/pool.d.ts +0 -144
- package/dist/types/sdk/sdk-legacy/core/transactions.d.ts +0 -348
- package/dist/types/sdk/sdk-legacy/gearboxRewards/api.d.ts +0 -87
- package/dist/types/sdk/sdk-legacy/gearboxRewards/apy.d.ts +0 -46
- package/dist/types/sdk/sdk-legacy/gearboxRewards/extraAPY.d.ts +0 -41
- package/dist/types/sdk/sdk-legacy/gearboxRewards/index.d.ts +0 -3
- package/dist/types/sdk/sdk-legacy/gearboxRewards/merklAPI.d.ts +0 -42
- package/dist/types/sdk/sdk-legacy/index.d.ts +0 -16
- package/dist/types/sdk/sdk-legacy/payload/creditAccount.d.ts +0 -47
- package/dist/types/sdk/sdk-legacy/payload/creditManager.d.ts +0 -109
- package/dist/types/sdk/sdk-legacy/payload/creditSession.d.ts +0 -111
- package/dist/types/sdk/sdk-legacy/payload/graphPayload.d.ts +0 -10
- package/dist/types/sdk/sdk-legacy/payload/pool.d.ts +0 -181
- package/dist/types/sdk/sdk-legacy/tokens/tokenData.d.ts +0 -21
- package/dist/types/sdk/sdk-legacy/utils/formatter.d.ts +0 -8
- package/dist/types/sdk/sdk-legacy/utils/index.d.ts +0 -3
- package/dist/types/sdk/sdk-legacy/utils/math.d.ts +0 -6
- package/dist/types/sdk/sdk-legacy/utils/price.d.ts +0 -9
- /package/dist/cjs/{sdk/accountMigration → common-utils/utils/creditAccount}/types.js +0 -0
- /package/dist/cjs/{sdk/core/address-provider → history}/types.js +0 -0
- /package/dist/cjs/{sdk/market → plugins/zappers}/types.js +0 -0
- /package/dist/esm/{sdk/accountMigration → common-utils/utils/creditAccount}/types.js +0 -0
- /package/dist/esm/{sdk/core/address-provider/types.js → history/inner-operations.js} +0 -0
- /package/dist/esm/{sdk/gauges/utils.js → history/internal-types.js} +0 -0
- /package/dist/esm/{sdk/market → history}/types.js +0 -0
- /package/dist/esm/{sdk/sdk-gov-legacy/tokens/aave.js → plugins/adapters/legacyAdapterOperations.js} +0 -0
- /package/dist/esm/{sdk/sdk-gov-legacy/tokens/compound.js → plugins/zappers/types.js} +0 -0
- /package/dist/esm/sdk/{sdk-gov-legacy/tokens/erc4626.js → core/types.js} +0 -0
- /package/dist/esm/sdk/market/adapters/{factory.js → createAdapter.js} +0 -0
- /package/dist/types/sdk/market/adapters/{factory.d.ts → createAdapter.d.ts} +0 -0
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getAddress,
|
|
3
|
+
isAddressEqual,
|
|
4
|
+
parseEventLogs
|
|
5
|
+
} from "viem";
|
|
6
|
+
import { iCreditFacadeV310Abi } from "../abi/310/generated.js";
|
|
7
|
+
import { ierc20Abi } from "../abi/iERC20.js";
|
|
8
|
+
import { AddressMap } from "../sdk/index.js";
|
|
9
|
+
import { UnexpectedFacadeEventOrderError } from "./errors.js";
|
|
10
|
+
function extractTransfers(logs, creditAccount, pool, creditFacade) {
|
|
11
|
+
const ranges = buildOperationRanges(logs, creditFacade, creditAccount);
|
|
12
|
+
let currentEntries = [];
|
|
13
|
+
const executeResults = [];
|
|
14
|
+
const directTransfers = [];
|
|
15
|
+
const phantomTokens = new AddressMap();
|
|
16
|
+
let liquidationRemainingFunds;
|
|
17
|
+
for (const log of logs) {
|
|
18
|
+
const facadeEvent = tryDecodeFacadeEvent(log, creditFacade);
|
|
19
|
+
if (facadeEvent) {
|
|
20
|
+
if (isExecute(facadeEvent, creditAccount)) {
|
|
21
|
+
executeResults.push({
|
|
22
|
+
transfers: currentEntries,
|
|
23
|
+
targetContract: facadeEvent.args.targetContract
|
|
24
|
+
});
|
|
25
|
+
} else if (isLiquidation(facadeEvent, creditAccount)) {
|
|
26
|
+
liquidationRemainingFunds = facadeEvent.args.remainingFunds;
|
|
27
|
+
} else if (isWithdrawPhantomToken(facadeEvent, creditAccount)) {
|
|
28
|
+
const phantomExec = executeResults.pop();
|
|
29
|
+
if (!phantomExec) {
|
|
30
|
+
throw new Error(
|
|
31
|
+
`WithdrawPhantomToken without preceding Execute at logIndex ${facadeEvent.logIndex}`
|
|
32
|
+
);
|
|
33
|
+
}
|
|
34
|
+
const rawDeposit = phantomExec.transfers.find(
|
|
35
|
+
(t) => isAddressEqual(t.to, creditAccount)
|
|
36
|
+
);
|
|
37
|
+
if (!rawDeposit) {
|
|
38
|
+
throw new Error(
|
|
39
|
+
`phantom Execute has no transfer to credit account at logIndex ${facadeEvent.logIndex}`
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
phantomTokens.upsert(
|
|
43
|
+
facadeEvent.args.token,
|
|
44
|
+
getAddress(rawDeposit.token)
|
|
45
|
+
);
|
|
46
|
+
}
|
|
47
|
+
currentEntries = [];
|
|
48
|
+
continue;
|
|
49
|
+
}
|
|
50
|
+
const transfer = tryDecodeTransfer(log);
|
|
51
|
+
if (!transfer) {
|
|
52
|
+
continue;
|
|
53
|
+
}
|
|
54
|
+
const { from, to, value } = transfer.args;
|
|
55
|
+
const token = transfer.address;
|
|
56
|
+
if (isAddressEqual(from, pool) && isAddressEqual(to, creditAccount) || isAddressEqual(from, creditAccount) && isAddressEqual(to, pool)) {
|
|
57
|
+
continue;
|
|
58
|
+
}
|
|
59
|
+
if (isAddressEqual(from, creditAccount) || isAddressEqual(to, creditAccount)) {
|
|
60
|
+
currentEntries.push({ token, amount: value, from, to });
|
|
61
|
+
}
|
|
62
|
+
if (isAddressEqual(to, creditAccount) && !isInRange(log.logIndex, ranges)) {
|
|
63
|
+
directTransfers.push({ token, from, amount: value });
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
return {
|
|
67
|
+
executeResults,
|
|
68
|
+
directTransfers,
|
|
69
|
+
liquidationRemainingFunds,
|
|
70
|
+
phantomTokens
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
function buildOperationRanges(logs, facadeAddress, creditAccount) {
|
|
74
|
+
const breakpoints = [];
|
|
75
|
+
let inMulticall = false;
|
|
76
|
+
for (const l of logs) {
|
|
77
|
+
const e = tryDecodeFacadeEvent(l, facadeAddress);
|
|
78
|
+
switch (e?.eventName) {
|
|
79
|
+
case "StartMultiCall":
|
|
80
|
+
if (isAddressEqual(e.args.creditAccount, creditAccount)) {
|
|
81
|
+
breakpoints.push(e);
|
|
82
|
+
inMulticall = true;
|
|
83
|
+
}
|
|
84
|
+
break;
|
|
85
|
+
case "FinishMultiCall":
|
|
86
|
+
if (inMulticall) {
|
|
87
|
+
breakpoints.push(e);
|
|
88
|
+
inMulticall = false;
|
|
89
|
+
}
|
|
90
|
+
break;
|
|
91
|
+
case "PartiallyLiquidateCreditAccount":
|
|
92
|
+
if (isAddressEqual(e.args.creditAccount, creditAccount)) {
|
|
93
|
+
breakpoints.push(e);
|
|
94
|
+
}
|
|
95
|
+
break;
|
|
96
|
+
case "AddCollateral":
|
|
97
|
+
if (!inMulticall && isAddressEqual(e.args.creditAccount, creditAccount)) {
|
|
98
|
+
breakpoints.push(e);
|
|
99
|
+
}
|
|
100
|
+
break;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
const ranges = [];
|
|
104
|
+
let i = 0;
|
|
105
|
+
while (i < breakpoints.length - 1) {
|
|
106
|
+
const a = breakpoints[i];
|
|
107
|
+
const b = breakpoints[i + 1];
|
|
108
|
+
if (a.eventName === "StartMultiCall" && b.eventName === "FinishMultiCall") {
|
|
109
|
+
ranges.push({ start: a.logIndex, end: b.logIndex });
|
|
110
|
+
i += 2;
|
|
111
|
+
} else if (a.eventName === "AddCollateral" && b.eventName === "PartiallyLiquidateCreditAccount") {
|
|
112
|
+
ranges.push({ start: a.logIndex - 1, end: b.logIndex });
|
|
113
|
+
i += 2;
|
|
114
|
+
} else {
|
|
115
|
+
throw new UnexpectedFacadeEventOrderError(a);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
return ranges;
|
|
119
|
+
}
|
|
120
|
+
function tryDecodeFacadeEvent(log, facadeAddress) {
|
|
121
|
+
if (!isAddressEqual(log.address, facadeAddress)) return void 0;
|
|
122
|
+
return parseEventLogs({
|
|
123
|
+
abi: iCreditFacadeV310Abi,
|
|
124
|
+
logs: [log]
|
|
125
|
+
})[0];
|
|
126
|
+
}
|
|
127
|
+
function tryDecodeTransfer(log) {
|
|
128
|
+
return parseEventLogs({
|
|
129
|
+
abi: ierc20Abi,
|
|
130
|
+
logs: [log],
|
|
131
|
+
eventName: "Transfer"
|
|
132
|
+
})[0];
|
|
133
|
+
}
|
|
134
|
+
function isInRange(logIndex, ranges) {
|
|
135
|
+
return ranges.some((r) => logIndex >= r.start && logIndex <= r.end);
|
|
136
|
+
}
|
|
137
|
+
function isExecute(e, creditAccount) {
|
|
138
|
+
return e.eventName === "Execute" && isAddressEqual(e.args.creditAccount, creditAccount);
|
|
139
|
+
}
|
|
140
|
+
function isLiquidation(e, creditAccount) {
|
|
141
|
+
return e.eventName === "LiquidateCreditAccount" && isAddressEqual(e.args.creditAccount, creditAccount);
|
|
142
|
+
}
|
|
143
|
+
function isWithdrawPhantomToken(e, creditAccount) {
|
|
144
|
+
return e.eventName === "WithdrawPhantomToken" && isAddressEqual(e.args.creditAccount, creditAccount);
|
|
145
|
+
}
|
|
146
|
+
export {
|
|
147
|
+
extractTransfers
|
|
148
|
+
};
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import {
|
|
2
|
+
decodeFunctionResult,
|
|
3
|
+
isAddressEqual
|
|
4
|
+
} from "viem";
|
|
5
|
+
import { iCreditFacadeV310Abi } from "../abi/310/generated.js";
|
|
6
|
+
import { UnknownFacadeCallError } from "./errors.js";
|
|
7
|
+
import { collectTraces } from "./trace-utils.js";
|
|
8
|
+
const FACADE_CALL_TYPES = {
|
|
9
|
+
multicall: "MultiCall",
|
|
10
|
+
botMulticall: "BotMulticall",
|
|
11
|
+
openCreditAccount: "OpenCreditAccount",
|
|
12
|
+
closeCreditAccount: "CloseCreditAccount",
|
|
13
|
+
liquidateCreditAccount: "LiquidateCreditAccount",
|
|
14
|
+
partiallyLiquidateCreditAccount: "PartiallyLiquidateCreditAccount"
|
|
15
|
+
};
|
|
16
|
+
function extractCreditAccount(operation, rawArgs, traceOutput) {
|
|
17
|
+
if (operation === "OpenCreditAccount") {
|
|
18
|
+
return decodeFunctionResult({
|
|
19
|
+
abi: iCreditFacadeV310Abi,
|
|
20
|
+
functionName: "openCreditAccount",
|
|
21
|
+
data: traceOutput
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
const ca = rawArgs.creditAccount;
|
|
25
|
+
if (!ca) {
|
|
26
|
+
throw new Error(`missing creditAccount arg in ${operation} call`);
|
|
27
|
+
}
|
|
28
|
+
return ca;
|
|
29
|
+
}
|
|
30
|
+
function findFacadeCalls(trace, creditFacade, creditAccount, register, strict) {
|
|
31
|
+
const facadeTraces = collectTraces(trace, creditFacade);
|
|
32
|
+
const results = [];
|
|
33
|
+
for (const trace2 of facadeTraces) {
|
|
34
|
+
const parsed = register.parseFunctionDataV2(
|
|
35
|
+
creditFacade,
|
|
36
|
+
trace2.input,
|
|
37
|
+
strict
|
|
38
|
+
);
|
|
39
|
+
const name = parsed.functionName.split("(")[0];
|
|
40
|
+
const operation = FACADE_CALL_TYPES[name];
|
|
41
|
+
if (!operation) {
|
|
42
|
+
if (strict) {
|
|
43
|
+
throw new UnknownFacadeCallError(creditFacade, parsed.functionName);
|
|
44
|
+
}
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
const ca = extractCreditAccount(operation, parsed.rawArgs, trace2.output);
|
|
48
|
+
if (!isAddressEqual(ca, creditAccount)) {
|
|
49
|
+
continue;
|
|
50
|
+
}
|
|
51
|
+
results.push({
|
|
52
|
+
operation,
|
|
53
|
+
creditAccount: ca,
|
|
54
|
+
parsed,
|
|
55
|
+
innerCalls: parsed.rawArgs.calls ?? [],
|
|
56
|
+
trace: trace2
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
return results;
|
|
60
|
+
}
|
|
61
|
+
export {
|
|
62
|
+
findFacadeCalls
|
|
63
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export * from "./inner-operations.js";
|
|
2
|
+
export * from "./mapOperations.js";
|
|
3
|
+
import { parseCreditAccountTransaction } from "./parseCreditAccountTransaction.js";
|
|
4
|
+
export * from "./populateContractsRegister.js";
|
|
5
|
+
export * from "./toLegacyOperation.js";
|
|
6
|
+
export * from "./types.js";
|
|
7
|
+
export {
|
|
8
|
+
parseCreditAccountTransaction
|
|
9
|
+
};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
function mapInnerOperation(op, visitor, ctx) {
|
|
2
|
+
switch (op.operation) {
|
|
3
|
+
case "Execute":
|
|
4
|
+
return visitor.Execute(op, ctx);
|
|
5
|
+
case "IncreaseBorrowedAmount":
|
|
6
|
+
return visitor.IncreaseBorrowedAmount(op, ctx);
|
|
7
|
+
case "DecreaseBorrowedAmount":
|
|
8
|
+
return visitor.DecreaseBorrowedAmount(op, ctx);
|
|
9
|
+
case "AddCollateral":
|
|
10
|
+
return visitor.AddCollateral(op, ctx);
|
|
11
|
+
case "WithdrawCollateral":
|
|
12
|
+
return visitor.WithdrawCollateral(op, ctx);
|
|
13
|
+
case "UpdateQuota":
|
|
14
|
+
return visitor.UpdateQuota(op, ctx);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
function mapOuterOperation(op, visitor) {
|
|
18
|
+
switch (op.operation) {
|
|
19
|
+
case "DirectTokenTransfer":
|
|
20
|
+
return visitor.DirectTokenTransfer(op);
|
|
21
|
+
case "PartiallyLiquidateCreditAccount":
|
|
22
|
+
return visitor.PartiallyLiquidateCreditAccount(op);
|
|
23
|
+
case "MultiCall":
|
|
24
|
+
case "BotMulticall": {
|
|
25
|
+
const multicall = op.multicall.map(
|
|
26
|
+
(inner) => mapInnerOperation(inner, visitor, op)
|
|
27
|
+
);
|
|
28
|
+
return visitor.MultiCall(op, multicall);
|
|
29
|
+
}
|
|
30
|
+
case "OpenCreditAccount": {
|
|
31
|
+
const multicall = op.multicall.map(
|
|
32
|
+
(inner) => mapInnerOperation(inner, visitor, op)
|
|
33
|
+
);
|
|
34
|
+
return visitor.OpenCreditAccount(op, multicall);
|
|
35
|
+
}
|
|
36
|
+
case "CloseCreditAccount": {
|
|
37
|
+
const multicall = op.multicall.map(
|
|
38
|
+
(inner) => mapInnerOperation(inner, visitor, op)
|
|
39
|
+
);
|
|
40
|
+
return visitor.CloseCreditAccount(op, multicall);
|
|
41
|
+
}
|
|
42
|
+
case "LiquidateCreditAccount": {
|
|
43
|
+
const multicall = op.multicall.map(
|
|
44
|
+
(inner) => mapInnerOperation(inner, visitor, op)
|
|
45
|
+
);
|
|
46
|
+
return visitor.LiquidateCreditAccount(op, multicall);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
function mapOperations(ops, visitor) {
|
|
51
|
+
return ops.map((op) => mapOuterOperation(op, visitor));
|
|
52
|
+
}
|
|
53
|
+
export {
|
|
54
|
+
mapOperations
|
|
55
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"type": "module","sideEffects":false}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { assembleOperations } from "./assembleOperations.js";
|
|
2
|
+
import { extractTransfers } from "./extractTransfers.js";
|
|
3
|
+
import { findFacadeCalls } from "./findFacadeCalls.js";
|
|
4
|
+
function parseCreditAccountTransaction(input) {
|
|
5
|
+
const {
|
|
6
|
+
trace,
|
|
7
|
+
receipt,
|
|
8
|
+
pool,
|
|
9
|
+
creditFacade,
|
|
10
|
+
creditManager,
|
|
11
|
+
creditAccount,
|
|
12
|
+
underlying,
|
|
13
|
+
register,
|
|
14
|
+
strict
|
|
15
|
+
} = input;
|
|
16
|
+
const logs = receipt.logs;
|
|
17
|
+
const txHash = receipt.transactionHash;
|
|
18
|
+
const blockNumber = Number(receipt.blockNumber);
|
|
19
|
+
const timestamp = Number(receipt.blockTimestamp ?? 0);
|
|
20
|
+
const facadeCalls = findFacadeCalls(
|
|
21
|
+
trace,
|
|
22
|
+
creditFacade,
|
|
23
|
+
creditAccount,
|
|
24
|
+
register,
|
|
25
|
+
strict
|
|
26
|
+
);
|
|
27
|
+
const {
|
|
28
|
+
executeResults,
|
|
29
|
+
directTransfers,
|
|
30
|
+
liquidationRemainingFunds,
|
|
31
|
+
phantomTokens
|
|
32
|
+
} = extractTransfers(logs, creditAccount, pool, creditFacade);
|
|
33
|
+
const meta = {
|
|
34
|
+
creditManager,
|
|
35
|
+
creditFacade,
|
|
36
|
+
timestamp,
|
|
37
|
+
blockNumber,
|
|
38
|
+
txHash
|
|
39
|
+
};
|
|
40
|
+
const facadeOps = assembleOperations({
|
|
41
|
+
facadeCalls,
|
|
42
|
+
executeResults,
|
|
43
|
+
register,
|
|
44
|
+
underlying,
|
|
45
|
+
liquidationRemainingFunds,
|
|
46
|
+
phantomTokens,
|
|
47
|
+
strict
|
|
48
|
+
}).map((o) => ({ ...o, ...meta }));
|
|
49
|
+
const directOps = directTransfers.map((dt) => ({
|
|
50
|
+
operation: "DirectTokenTransfer",
|
|
51
|
+
txHash,
|
|
52
|
+
blockNumber,
|
|
53
|
+
timestamp,
|
|
54
|
+
protocol: dt.token,
|
|
55
|
+
creditAccount,
|
|
56
|
+
...dt
|
|
57
|
+
}));
|
|
58
|
+
return [...facadeOps, ...directOps];
|
|
59
|
+
}
|
|
60
|
+
export {
|
|
61
|
+
parseCreditAccountTransaction
|
|
62
|
+
};
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import {
|
|
2
|
+
isHex
|
|
3
|
+
} from "viem";
|
|
4
|
+
import { createAdapter } from "../plugins/adapters/createAdapter.js";
|
|
5
|
+
import {
|
|
6
|
+
bytes32ToString,
|
|
7
|
+
ChainContractsRegister,
|
|
8
|
+
CreditFacadeV310BaseContract,
|
|
9
|
+
isV310,
|
|
10
|
+
TokensMeta
|
|
11
|
+
} from "../sdk/index.js";
|
|
12
|
+
function populateContractsRegister(options) {
|
|
13
|
+
const { client, deployments, tokens, logger, strict } = options;
|
|
14
|
+
const register = new ChainContractsRegister(client, logger);
|
|
15
|
+
for (const d of deployments) {
|
|
16
|
+
let contractType;
|
|
17
|
+
if ("contractType" in d) {
|
|
18
|
+
contractType = isHex(d.contractType) ? bytes32ToString(d.contractType) : d.contractType;
|
|
19
|
+
} else {
|
|
20
|
+
contractType = [d.contractTypePrefix, d.contractTypeSuffix].filter(Boolean).join("::");
|
|
21
|
+
}
|
|
22
|
+
if (contractType === "CREDIT_FACADE" && isV310(d.version)) {
|
|
23
|
+
new CreditFacadeV310BaseContract(
|
|
24
|
+
{ register, logger },
|
|
25
|
+
{ addr: d.address, version: d.version, contractType }
|
|
26
|
+
);
|
|
27
|
+
} else if (contractType.startsWith("ADAPTER::")) {
|
|
28
|
+
createAdapter(
|
|
29
|
+
{
|
|
30
|
+
register,
|
|
31
|
+
logger
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
baseParams: {
|
|
35
|
+
addr: d.address,
|
|
36
|
+
version: d.version,
|
|
37
|
+
contractType
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
strict
|
|
41
|
+
);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
const tMetas = tokens instanceof TokensMeta ? tokens.values() : tokens;
|
|
45
|
+
for (const t of tMetas) {
|
|
46
|
+
register.tokensMeta.upsert(t.addr, t);
|
|
47
|
+
}
|
|
48
|
+
return register;
|
|
49
|
+
}
|
|
50
|
+
export {
|
|
51
|
+
populateContractsRegister
|
|
52
|
+
};
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
import { mapOperations } from "./mapOperations.js";
|
|
2
|
+
function commonFields(op, params) {
|
|
3
|
+
return {
|
|
4
|
+
timestamp: op.timestamp,
|
|
5
|
+
sessionId: params.sessionId,
|
|
6
|
+
protocol: op.creditFacade
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
function innerCommonFields(ctx, params) {
|
|
10
|
+
return {
|
|
11
|
+
txHash: ctx.txHash,
|
|
12
|
+
blockNum: ctx.blockNumber,
|
|
13
|
+
timestamp: ctx.timestamp,
|
|
14
|
+
sessionId: params.sessionId,
|
|
15
|
+
protocol: ctx.creditFacade
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
function createLegacyVisitor(params) {
|
|
19
|
+
return {
|
|
20
|
+
Execute(op, ctx) {
|
|
21
|
+
return {
|
|
22
|
+
...op.legacy,
|
|
23
|
+
txHash: ctx.txHash,
|
|
24
|
+
blockNum: ctx.blockNumber,
|
|
25
|
+
timestamp: ctx.timestamp,
|
|
26
|
+
sessionId: params.sessionId,
|
|
27
|
+
protocol: op.protocol
|
|
28
|
+
};
|
|
29
|
+
},
|
|
30
|
+
IncreaseBorrowedAmount(op, ctx) {
|
|
31
|
+
return {
|
|
32
|
+
operation: op.operation,
|
|
33
|
+
amount: op.amount.toString(),
|
|
34
|
+
...innerCommonFields(ctx, params),
|
|
35
|
+
protocol: ctx.creditManager
|
|
36
|
+
};
|
|
37
|
+
},
|
|
38
|
+
DecreaseBorrowedAmount(op, ctx) {
|
|
39
|
+
return {
|
|
40
|
+
operation: op.operation,
|
|
41
|
+
amount: op.amount.toString(),
|
|
42
|
+
...innerCommonFields(ctx, params),
|
|
43
|
+
protocol: ctx.creditManager
|
|
44
|
+
};
|
|
45
|
+
},
|
|
46
|
+
AddCollateral(op, ctx) {
|
|
47
|
+
return {
|
|
48
|
+
operation: op.operation,
|
|
49
|
+
token: op.token,
|
|
50
|
+
amount: op.amount.toString(),
|
|
51
|
+
...innerCommonFields(ctx, params)
|
|
52
|
+
};
|
|
53
|
+
},
|
|
54
|
+
WithdrawCollateral(op, ctx) {
|
|
55
|
+
return {
|
|
56
|
+
operation: op.operation,
|
|
57
|
+
token: op.token,
|
|
58
|
+
amount: op.amount.toString(),
|
|
59
|
+
to: op.to,
|
|
60
|
+
...op.phantomToken ? { phantomToken: op.phantomToken } : {},
|
|
61
|
+
...innerCommonFields(ctx, params)
|
|
62
|
+
};
|
|
63
|
+
},
|
|
64
|
+
UpdateQuota(op, ctx) {
|
|
65
|
+
return {
|
|
66
|
+
operation: op.operation,
|
|
67
|
+
token: op.token,
|
|
68
|
+
change: op.change.toString(),
|
|
69
|
+
...innerCommonFields(ctx, params)
|
|
70
|
+
};
|
|
71
|
+
},
|
|
72
|
+
DirectTokenTransfer(op) {
|
|
73
|
+
return {
|
|
74
|
+
operation: op.operation,
|
|
75
|
+
txHash: op.txHash,
|
|
76
|
+
blockNum: op.blockNumber,
|
|
77
|
+
timestamp: op.timestamp,
|
|
78
|
+
sessionId: params.sessionId,
|
|
79
|
+
protocol: op.protocol,
|
|
80
|
+
token: op.token,
|
|
81
|
+
amount: op.amount.toString(),
|
|
82
|
+
from: op.from,
|
|
83
|
+
to: op.creditAccount
|
|
84
|
+
};
|
|
85
|
+
},
|
|
86
|
+
MultiCall(op, multicall) {
|
|
87
|
+
return {
|
|
88
|
+
operation: op.operation,
|
|
89
|
+
txHash: op.txHash,
|
|
90
|
+
blockNum: op.blockNumber,
|
|
91
|
+
...commonFields(op, params),
|
|
92
|
+
multicall
|
|
93
|
+
};
|
|
94
|
+
},
|
|
95
|
+
OpenCreditAccount(op, multicall) {
|
|
96
|
+
return {
|
|
97
|
+
operation: op.operation,
|
|
98
|
+
txHash: op.txHash,
|
|
99
|
+
blockNum: op.blockNumber,
|
|
100
|
+
...commonFields(op, params),
|
|
101
|
+
multicall,
|
|
102
|
+
// TODO: missing legacy fields:
|
|
103
|
+
// userFunds: require prices to compute as
|
|
104
|
+
// sum of AddCollateral/WithdrawCollateral amounts denominated in underlying token.
|
|
105
|
+
// initialFunds: === userFunds
|
|
106
|
+
//
|
|
107
|
+
// leverage: (userFunds + borrowAmount) / userFunds
|
|
108
|
+
// where borrowAmount = sum of IncreaseDebt amounts in multicall (computable from data)
|
|
109
|
+
userFunds: "0",
|
|
110
|
+
initialFunds: "0",
|
|
111
|
+
leverage: "0"
|
|
112
|
+
};
|
|
113
|
+
},
|
|
114
|
+
CloseCreditAccount(op, multicall) {
|
|
115
|
+
return {
|
|
116
|
+
operation: op.operation,
|
|
117
|
+
txHash: op.txHash,
|
|
118
|
+
blockNum: op.blockNumber,
|
|
119
|
+
...commonFields(op, params),
|
|
120
|
+
multicall,
|
|
121
|
+
// TODO: missing legacy fields:
|
|
122
|
+
// remainingFunds:
|
|
123
|
+
remainingFunds: "0"
|
|
124
|
+
};
|
|
125
|
+
},
|
|
126
|
+
LiquidateCreditAccount(op, multicall) {
|
|
127
|
+
return {
|
|
128
|
+
operation: op.operation,
|
|
129
|
+
txHash: op.txHash,
|
|
130
|
+
blockNum: op.blockNumber,
|
|
131
|
+
...commonFields(op, params),
|
|
132
|
+
to: op.to,
|
|
133
|
+
remainingFunds: op.remainingFunds.toString(),
|
|
134
|
+
multicall
|
|
135
|
+
};
|
|
136
|
+
},
|
|
137
|
+
PartiallyLiquidateCreditAccount(op) {
|
|
138
|
+
return {
|
|
139
|
+
operation: op.operation,
|
|
140
|
+
txHash: op.txHash,
|
|
141
|
+
blockNum: op.blockNumber,
|
|
142
|
+
...commonFields(op, params),
|
|
143
|
+
token: op.token,
|
|
144
|
+
repaidAmount: op.repaidAmount.toString(),
|
|
145
|
+
minSeizedAmount: op.minSeizedAmount.toString(),
|
|
146
|
+
to: op.to
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
function toLegacyOperations(ops, params) {
|
|
152
|
+
return mapOperations(ops, createLegacyVisitor(params));
|
|
153
|
+
}
|
|
154
|
+
export {
|
|
155
|
+
createLegacyVisitor,
|
|
156
|
+
toLegacyOperations
|
|
157
|
+
};
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { isAddressEqual } from "viem";
|
|
2
|
+
function findCallTo(node, target) {
|
|
3
|
+
if (node.error) {
|
|
4
|
+
return void 0;
|
|
5
|
+
}
|
|
6
|
+
if (node.type === "CALL" && isAddressEqual(node.to, target)) {
|
|
7
|
+
return node;
|
|
8
|
+
}
|
|
9
|
+
if (node.calls) {
|
|
10
|
+
for (const child of node.calls) {
|
|
11
|
+
const found = findCallTo(child, target);
|
|
12
|
+
if (found) {
|
|
13
|
+
return found;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
return void 0;
|
|
18
|
+
}
|
|
19
|
+
function collectTraces(node, target) {
|
|
20
|
+
const results = [];
|
|
21
|
+
if (node.error) {
|
|
22
|
+
return results;
|
|
23
|
+
}
|
|
24
|
+
if (node.type === "CALL" && isAddressEqual(node.to, target)) {
|
|
25
|
+
results.push(node);
|
|
26
|
+
} else if (node.calls) {
|
|
27
|
+
for (const child of node.calls) {
|
|
28
|
+
results.push(...collectTraces(child, target));
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
return results;
|
|
32
|
+
}
|
|
33
|
+
export {
|
|
34
|
+
collectTraces,
|
|
35
|
+
findCallTo
|
|
36
|
+
};
|
|
@@ -16,8 +16,8 @@ import { InstanceManagerContract } from "./instance-manager.js";
|
|
|
16
16
|
import { MarketConfiguratorFactoryContract } from "./market-configurator-factory.js";
|
|
17
17
|
const abi = crossChainMultisigAbi;
|
|
18
18
|
class CrossChainMultisigContract extends BaseContract {
|
|
19
|
-
constructor(addr,
|
|
20
|
-
super({
|
|
19
|
+
constructor(addr, register) {
|
|
20
|
+
super({ register }, { abi, addr, name: "CrossChainMultisig" });
|
|
21
21
|
}
|
|
22
22
|
async getExecutedBatches(fromBlock, toBlock) {
|
|
23
23
|
const events = await this.getEvents("ExecuteBatch", fromBlock, toBlock);
|
|
@@ -170,7 +170,7 @@ class CrossChainMultisigContract extends BaseContract {
|
|
|
170
170
|
case Addresses.INSTANCE_MANAGER.toLowerCase(): {
|
|
171
171
|
const instanceManager = new InstanceManagerContract(
|
|
172
172
|
target,
|
|
173
|
-
this.
|
|
173
|
+
this.register
|
|
174
174
|
);
|
|
175
175
|
return instanceManager.parseFunctionData(calldata);
|
|
176
176
|
}
|
|
@@ -22,8 +22,8 @@ import { RoutingManagerContract } from "./router/index.js";
|
|
|
22
22
|
import { TreasurySplitterContract } from "./treasury-splitter.js";
|
|
23
23
|
const abi = instanceManagerAbi;
|
|
24
24
|
class InstanceManagerContract extends BaseContract {
|
|
25
|
-
constructor(addr,
|
|
26
|
-
super({
|
|
25
|
+
constructor(addr, register) {
|
|
26
|
+
super({ register }, { abi, addr, name: "InstanceManager" });
|
|
27
27
|
}
|
|
28
28
|
// TODO:
|
|
29
29
|
#decodeFunctionData(target, calldata) {
|
|
@@ -138,7 +138,7 @@ class InstanceManagerContract extends BaseContract {
|
|
|
138
138
|
);
|
|
139
139
|
return {
|
|
140
140
|
...result,
|
|
141
|
-
label: `${this.
|
|
141
|
+
label: `${this.labelAddress(target, true)} via ${result.label}`
|
|
142
142
|
};
|
|
143
143
|
}
|
|
144
144
|
return super.mustParseFunctionData(calldata);
|
|
@@ -84,12 +84,8 @@ async function getPrices({
|
|
|
84
84
|
client,
|
|
85
85
|
gasLimit,
|
|
86
86
|
marketConfigurators: [],
|
|
87
|
-
redstone: {
|
|
88
|
-
|
|
89
|
-
},
|
|
90
|
-
pyth: {
|
|
91
|
-
ignoreMissingFeeds: true
|
|
92
|
-
}
|
|
87
|
+
redstone: {},
|
|
88
|
+
pyth: {}
|
|
93
89
|
});
|
|
94
90
|
const chunks = [];
|
|
95
91
|
for (let i = 0; i < priceFeeds.length; i += chunkSize) {
|