@across-protocol/sdk 4.3.111-alpha.0 → 4.3.111-alpha.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/addressAggregator/adapters/abstract.js +50 -64
- package/dist/cjs/addressAggregator/adapters/abstract.js.map +1 -1
- package/dist/cjs/addressAggregator/adapters/bybit.js +16 -29
- package/dist/cjs/addressAggregator/adapters/bybit.js.map +1 -1
- package/dist/cjs/addressAggregator/adapters/env.js +11 -15
- package/dist/cjs/addressAggregator/adapters/env.js.map +1 -1
- package/dist/cjs/addressAggregator/adapters/file.js +32 -45
- package/dist/cjs/addressAggregator/adapters/file.js.map +1 -1
- package/dist/cjs/addressAggregator/adapters/index.js +1 -1
- package/dist/cjs/addressAggregator/adapters/risklabs.js +22 -36
- package/dist/cjs/addressAggregator/adapters/risklabs.js.map +1 -1
- package/dist/cjs/addressAggregator/index.js +57 -87
- package/dist/cjs/addressAggregator/index.js.map +1 -1
- package/dist/cjs/apiClient/abstractClient.js +9 -8
- package/dist/cjs/apiClient/abstractClient.js.map +1 -1
- package/dist/cjs/apiClient/index.js +1 -1
- package/dist/cjs/apiClient/mockedClient.js +23 -29
- package/dist/cjs/apiClient/mockedClient.js.map +1 -1
- package/dist/cjs/apiClient/productionClient.js +65 -103
- package/dist/cjs/apiClient/productionClient.js.map +1 -1
- package/dist/cjs/arch/evm/BlockUtils.js +122 -208
- package/dist/cjs/arch/evm/BlockUtils.js.map +1 -1
- package/dist/cjs/arch/evm/MessageUtils.js +1 -1
- package/dist/cjs/arch/evm/MessageUtils.js.map +1 -1
- package/dist/cjs/arch/evm/SpokeUtils.js +134 -288
- package/dist/cjs/arch/evm/SpokeUtils.js.map +1 -1
- package/dist/cjs/arch/evm/index.js +1 -1
- package/dist/cjs/arch/evm/utils/index.js +1 -1
- package/dist/cjs/arch/evm/utils/wait.js +38 -49
- package/dist/cjs/arch/evm/utils/wait.js.map +1 -1
- package/dist/cjs/arch/index.js +1 -1
- package/dist/cjs/arch/svm/BlockUtils.js +102 -158
- package/dist/cjs/arch/svm/BlockUtils.js.map +1 -1
- package/dist/cjs/arch/svm/MessageUtils.js +2 -2
- package/dist/cjs/arch/svm/MessageUtils.js.map +1 -1
- package/dist/cjs/arch/svm/SpokeUtils.js +708 -1147
- package/dist/cjs/arch/svm/SpokeUtils.js.map +1 -1
- package/dist/cjs/arch/svm/encoders.js +1 -1
- package/dist/cjs/arch/svm/encoders.js.map +1 -1
- package/dist/cjs/arch/svm/eventsClient.js +174 -236
- package/dist/cjs/arch/svm/eventsClient.js.map +1 -1
- package/dist/cjs/arch/svm/index.js +1 -1
- package/dist/cjs/arch/svm/provider.js +3 -3
- package/dist/cjs/arch/svm/provider.js.map +1 -1
- package/dist/cjs/arch/svm/utils.js +166 -355
- package/dist/cjs/arch/svm/utils.js.map +1 -1
- package/dist/cjs/caching/Arweave/ArweaveClient.js +168 -246
- package/dist/cjs/caching/Arweave/ArweaveClient.js.map +1 -1
- package/dist/cjs/caching/Arweave/index.js +1 -1
- package/dist/cjs/caching/IPFS/PinataIPFSClient.js +40 -49
- package/dist/cjs/caching/IPFS/PinataIPFSClient.js.map +1 -1
- package/dist/cjs/caching/IPFS/index.js +1 -1
- package/dist/cjs/caching/Memory/MemoryCacheClient.js +13 -18
- package/dist/cjs/caching/Memory/MemoryCacheClient.js.map +1 -1
- package/dist/cjs/caching/Memory/index.js +1 -1
- package/dist/cjs/caching/index.js +1 -1
- package/dist/cjs/clients/AcrossConfigStoreClient/AcrossConfigStoreClient.js +302 -381
- package/dist/cjs/clients/AcrossConfigStoreClient/AcrossConfigStoreClient.js.map +1 -1
- package/dist/cjs/clients/AcrossConfigStoreClient/index.js +1 -1
- package/dist/cjs/clients/BaseAbstractClient.js +58 -83
- package/dist/cjs/clients/BaseAbstractClient.js.map +1 -1
- package/dist/cjs/clients/BundleDataClient/BundleDataClient.js +709 -900
- package/dist/cjs/clients/BundleDataClient/BundleDataClient.js.map +1 -1
- package/dist/cjs/clients/BundleDataClient/index.js +1 -1
- package/dist/cjs/clients/BundleDataClient/utils/DataworkerUtils.js +95 -128
- package/dist/cjs/clients/BundleDataClient/utils/DataworkerUtils.js.map +1 -1
- package/dist/cjs/clients/BundleDataClient/utils/FillUtils.js +48 -53
- package/dist/cjs/clients/BundleDataClient/utils/FillUtils.js.map +1 -1
- package/dist/cjs/clients/BundleDataClient/utils/MerkleTreeUtils.js +10 -8
- package/dist/cjs/clients/BundleDataClient/utils/MerkleTreeUtils.js.map +1 -1
- package/dist/cjs/clients/BundleDataClient/utils/PoolRebalanceUtils.js +67 -90
- package/dist/cjs/clients/BundleDataClient/utils/PoolRebalanceUtils.js.map +1 -1
- package/dist/cjs/clients/BundleDataClient/utils/SuperstructUtils.js +46 -24
- package/dist/cjs/clients/BundleDataClient/utils/SuperstructUtils.js.map +1 -1
- package/dist/cjs/clients/BundleDataClient/utils/index.js +1 -1
- package/dist/cjs/clients/HubPoolClient.js +526 -708
- package/dist/cjs/clients/HubPoolClient.js.map +1 -1
- package/dist/cjs/clients/SpokePoolClient/EVMSpokePoolClient.js +133 -179
- package/dist/cjs/clients/SpokePoolClient/EVMSpokePoolClient.js.map +1 -1
- package/dist/cjs/clients/SpokePoolClient/SVMSpokePoolClient.js +124 -183
- package/dist/cjs/clients/SpokePoolClient/SVMSpokePoolClient.js.map +1 -1
- package/dist/cjs/clients/SpokePoolClient/SpokePoolClient.js +357 -389
- package/dist/cjs/clients/SpokePoolClient/SpokePoolClient.js.map +1 -1
- package/dist/cjs/clients/SpokePoolClient/SpokePoolClientManager.js +9 -8
- package/dist/cjs/clients/SpokePoolClient/SpokePoolClientManager.js.map +1 -1
- package/dist/cjs/clients/SpokePoolClient/index.js +3 -3
- package/dist/cjs/clients/SpokePoolClient/index.js.map +1 -1
- package/dist/cjs/clients/index.js +1 -1
- package/dist/cjs/clients/mocks/MockConfigStoreClient.js +58 -67
- package/dist/cjs/clients/mocks/MockConfigStoreClient.js.map +1 -1
- package/dist/cjs/clients/mocks/MockEvents.js +47 -52
- package/dist/cjs/clients/mocks/MockEvents.js.map +1 -1
- package/dist/cjs/clients/mocks/MockHubPoolClient.js +142 -185
- package/dist/cjs/clients/mocks/MockHubPoolClient.js.map +1 -1
- package/dist/cjs/clients/mocks/MockSpokePoolClient.js +208 -192
- package/dist/cjs/clients/mocks/MockSpokePoolClient.js.map +1 -1
- package/dist/cjs/clients/mocks/MockSvmCpiEventsClient.js +140 -143
- package/dist/cjs/clients/mocks/MockSvmCpiEventsClient.js.map +1 -1
- package/dist/cjs/clients/mocks/MockSvmSpokePoolClient.js +57 -73
- package/dist/cjs/clients/mocks/MockSvmSpokePoolClient.js.map +1 -1
- package/dist/cjs/clients/mocks/index.js +1 -1
- package/dist/cjs/coingecko/Coingecko.js +285 -437
- package/dist/cjs/coingecko/Coingecko.js.map +1 -1
- package/dist/cjs/coingecko/index.js +1 -1
- package/dist/cjs/constants.js +23 -30
- package/dist/cjs/constants.js.map +1 -1
- package/dist/cjs/contracts/acrossConfigStore.js +27 -48
- package/dist/cjs/contracts/acrossConfigStore.js.map +1 -1
- package/dist/cjs/contracts/hubPool.js +36 -20
- package/dist/cjs/contracts/hubPool.js.map +1 -1
- package/dist/cjs/contracts/index.js +1 -1
- package/dist/cjs/contracts/utils.js +6 -8
- package/dist/cjs/contracts/utils.js.map +1 -1
- package/dist/cjs/gasPriceOracle/adapters/arbitrum.js +7 -16
- package/dist/cjs/gasPriceOracle/adapters/arbitrum.js.map +1 -1
- package/dist/cjs/gasPriceOracle/adapters/ethereum.js +26 -45
- package/dist/cjs/gasPriceOracle/adapters/ethereum.js.map +1 -1
- package/dist/cjs/gasPriceOracle/adapters/linea-viem.js +16 -28
- package/dist/cjs/gasPriceOracle/adapters/linea-viem.js.map +1 -1
- package/dist/cjs/gasPriceOracle/adapters/polygon.js +73 -112
- package/dist/cjs/gasPriceOracle/adapters/polygon.js.map +1 -1
- package/dist/cjs/gasPriceOracle/adapters/solana.js +20 -33
- package/dist/cjs/gasPriceOracle/adapters/solana.js.map +1 -1
- package/dist/cjs/gasPriceOracle/oracle.js +77 -104
- package/dist/cjs/gasPriceOracle/oracle.js.map +1 -1
- package/dist/cjs/gasPriceOracle/types.js +3 -3
- package/dist/cjs/gasPriceOracle/types.js.map +1 -1
- package/dist/cjs/gasPriceOracle/util.js +8 -8
- package/dist/cjs/gasPriceOracle/util.js.map +1 -1
- package/dist/cjs/index.js +1 -1
- package/dist/cjs/interfaces/index.js +1 -1
- package/dist/cjs/lpFeeCalculator/index.js +1 -1
- package/dist/cjs/lpFeeCalculator/lpFeeCalculator.js +33 -35
- package/dist/cjs/lpFeeCalculator/lpFeeCalculator.js.map +1 -1
- package/dist/cjs/lpFeeCalculator/rateModel.js +7 -9
- package/dist/cjs/lpFeeCalculator/rateModel.js.map +1 -1
- package/dist/cjs/merkleDistributor/MerkleDistributor.js +20 -18
- package/dist/cjs/merkleDistributor/MerkleDistributor.js.map +1 -1
- package/dist/cjs/merkleDistributor/index.js +1 -1
- package/dist/cjs/merkleDistributor/model/index.js +1 -1
- package/dist/cjs/pool/TransactionManager.js +45 -100
- package/dist/cjs/pool/TransactionManager.js.map +1 -1
- package/dist/cjs/pool/index.js +1 -1
- package/dist/cjs/pool/poolClient.js +464 -731
- package/dist/cjs/pool/poolClient.js.map +1 -1
- package/dist/cjs/pool/uma/across/index.js +1 -1
- package/dist/cjs/pool/uma/across/transactionManager.js +45 -100
- package/dist/cjs/pool/uma/across/transactionManager.js.map +1 -1
- package/dist/cjs/pool/uma/clients/erc20/client.js +18 -16
- package/dist/cjs/pool/uma/clients/erc20/client.js.map +1 -1
- package/dist/cjs/pool/uma/clients/erc20/index.js +1 -1
- package/dist/cjs/pool/uma/clients/index.js +1 -1
- package/dist/cjs/pool/uma/index.js +1 -1
- package/dist/cjs/pool/uma/oracle/index.js +1 -1
- package/dist/cjs/pool/uma/oracle/utils.js +4 -5
- package/dist/cjs/pool/uma/oracle/utils.js.map +1 -1
- package/dist/cjs/pool/uma/utils.js +11 -30
- package/dist/cjs/pool/uma/utils.js.map +1 -1
- package/dist/cjs/priceClient/adapters/acrossApi.js +22 -39
- package/dist/cjs/priceClient/adapters/acrossApi.js.map +1 -1
- package/dist/cjs/priceClient/adapters/baseAdapter.js +49 -73
- package/dist/cjs/priceClient/adapters/baseAdapter.js.map +1 -1
- package/dist/cjs/priceClient/adapters/coingecko.js +34 -61
- package/dist/cjs/priceClient/adapters/coingecko.js.map +1 -1
- package/dist/cjs/priceClient/adapters/default.js +16 -31
- package/dist/cjs/priceClient/adapters/default.js.map +1 -1
- package/dist/cjs/priceClient/adapters/defiLlama.js +40 -74
- package/dist/cjs/priceClient/adapters/defiLlama.js.map +1 -1
- package/dist/cjs/priceClient/adapters/index.js +1 -1
- package/dist/cjs/priceClient/index.js +1 -1
- package/dist/cjs/priceClient/priceClient.js +110 -159
- package/dist/cjs/priceClient/priceClient.js.map +1 -1
- package/dist/cjs/providers/alchemy.js +17 -19
- package/dist/cjs/providers/alchemy.js.map +1 -1
- package/dist/cjs/providers/cachedProvider.js +88 -129
- package/dist/cjs/providers/cachedProvider.js.map +1 -1
- package/dist/cjs/providers/drpc.js +9 -11
- package/dist/cjs/providers/drpc.js.map +1 -1
- package/dist/cjs/providers/index.js +1 -1
- package/dist/cjs/providers/infura.js +10 -12
- package/dist/cjs/providers/infura.js.map +1 -1
- package/dist/cjs/providers/mocks/MockCachedSolanaRpcFactory.js +7 -15
- package/dist/cjs/providers/mocks/MockCachedSolanaRpcFactory.js.map +1 -1
- package/dist/cjs/providers/mocks/MockRateLimitedSolanaRpcFactory.js +6 -14
- package/dist/cjs/providers/mocks/MockRateLimitedSolanaRpcFactory.js.map +1 -1
- package/dist/cjs/providers/mocks/MockRetrySolanaRpcFactory.js +7 -15
- package/dist/cjs/providers/mocks/MockRetrySolanaRpcFactory.js.map +1 -1
- package/dist/cjs/providers/mocks/MockSolanaRpcFactory.js +42 -66
- package/dist/cjs/providers/mocks/MockSolanaRpcFactory.js.map +1 -1
- package/dist/cjs/providers/mocks/index.js +1 -1
- package/dist/cjs/providers/mocks/mockEthersProvider.js +29 -31
- package/dist/cjs/providers/mocks/mockEthersProvider.js.map +1 -1
- package/dist/cjs/providers/quicknode.js +19 -21
- package/dist/cjs/providers/quicknode.js.map +1 -1
- package/dist/cjs/providers/rateLimitedProvider.js +64 -79
- package/dist/cjs/providers/rateLimitedProvider.js.map +1 -1
- package/dist/cjs/providers/retryProvider.js +163 -246
- package/dist/cjs/providers/retryProvider.js.map +1 -1
- package/dist/cjs/providers/solana/baseRpcFactories.js +14 -18
- package/dist/cjs/providers/solana/baseRpcFactories.js.map +1 -1
- package/dist/cjs/providers/solana/cachedRpcFactory.js +70 -112
- package/dist/cjs/providers/solana/cachedRpcFactory.js.map +1 -1
- package/dist/cjs/providers/solana/defaultRpcFactory.js +8 -15
- package/dist/cjs/providers/solana/defaultRpcFactory.js.map +1 -1
- package/dist/cjs/providers/solana/index.js +1 -1
- package/dist/cjs/providers/solana/quorumFallbackRpcFactory.js +135 -191
- package/dist/cjs/providers/solana/quorumFallbackRpcFactory.js.map +1 -1
- package/dist/cjs/providers/solana/rateLimitedRpcFactory.js +67 -90
- package/dist/cjs/providers/solana/rateLimitedRpcFactory.js.map +1 -1
- package/dist/cjs/providers/solana/retryRpcFactory.js +52 -79
- package/dist/cjs/providers/solana/retryRpcFactory.js.map +1 -1
- package/dist/cjs/providers/solana/utils.js +2 -2
- package/dist/cjs/providers/solana/utils.js.map +1 -1
- package/dist/cjs/providers/speedProvider.js +31 -53
- package/dist/cjs/providers/speedProvider.js.map +1 -1
- package/dist/cjs/providers/types.js +1 -1
- package/dist/cjs/providers/types.js.map +1 -1
- package/dist/cjs/providers/utils.js +26 -28
- package/dist/cjs/providers/utils.js.map +1 -1
- package/dist/cjs/relayFeeCalculator/chain-queries/baseQuery.js +108 -162
- package/dist/cjs/relayFeeCalculator/chain-queries/baseQuery.js.map +1 -1
- package/dist/cjs/relayFeeCalculator/chain-queries/customGasToken.js +14 -26
- package/dist/cjs/relayFeeCalculator/chain-queries/customGasToken.js.map +1 -1
- package/dist/cjs/relayFeeCalculator/chain-queries/factory.js +20 -29
- package/dist/cjs/relayFeeCalculator/chain-queries/factory.js.map +1 -1
- package/dist/cjs/relayFeeCalculator/chain-queries/index.js +1 -1
- package/dist/cjs/relayFeeCalculator/chain-queries/svmQuery.js +88 -137
- package/dist/cjs/relayFeeCalculator/chain-queries/svmQuery.js.map +1 -1
- package/dist/cjs/relayFeeCalculator/index.js +1 -1
- package/dist/cjs/relayFeeCalculator/relayFeeCalculator.js +199 -297
- package/dist/cjs/relayFeeCalculator/relayFeeCalculator.js.map +1 -1
- package/dist/cjs/typeguards/error.js +5 -7
- package/dist/cjs/typeguards/error.js.map +1 -1
- package/dist/cjs/typeguards/index.js +1 -1
- package/dist/cjs/utils/AddressUtils.js +117 -144
- package/dist/cjs/utils/AddressUtils.js.map +1 -1
- package/dist/cjs/utils/ArrayUtils.js +21 -78
- package/dist/cjs/utils/ArrayUtils.js.map +1 -1
- package/dist/cjs/utils/BigNumberUtils.js +9 -10
- package/dist/cjs/utils/BigNumberUtils.js.map +1 -1
- package/dist/cjs/utils/BlockExplorerUtils.js +26 -30
- package/dist/cjs/utils/BlockExplorerUtils.js.map +1 -1
- package/dist/cjs/utils/BlockFinder.js +2 -5
- package/dist/cjs/utils/BlockFinder.js.map +1 -1
- package/dist/cjs/utils/BlockUtils.js +24 -41
- package/dist/cjs/utils/BlockUtils.js.map +1 -1
- package/dist/cjs/utils/BundleUtils.js +21 -24
- package/dist/cjs/utils/BundleUtils.js.map +1 -1
- package/dist/cjs/utils/CCTPUtils.js +62 -126
- package/dist/cjs/utils/CCTPUtils.js.map +1 -1
- package/dist/cjs/utils/CachingUtils.js +20 -42
- package/dist/cjs/utils/CachingUtils.js.map +1 -1
- package/dist/cjs/utils/ContractUtils.js +5 -5
- package/dist/cjs/utils/ContractUtils.js.map +1 -1
- package/dist/cjs/utils/DepositUtils.js +122 -99
- package/dist/cjs/utils/DepositUtils.js.map +1 -1
- package/dist/cjs/utils/EventUtils.js +49 -70
- package/dist/cjs/utils/EventUtils.js.map +1 -1
- package/dist/cjs/utils/FormattingUtils.js +26 -32
- package/dist/cjs/utils/FormattingUtils.js.map +1 -1
- package/dist/cjs/utils/HyperLiquidUtils.js +10 -23
- package/dist/cjs/utils/HyperLiquidUtils.js.map +1 -1
- package/dist/cjs/utils/IPFSUtils.js +16 -34
- package/dist/cjs/utils/IPFSUtils.js.map +1 -1
- package/dist/cjs/utils/JSONUtils.js +6 -6
- package/dist/cjs/utils/JSONUtils.js.map +1 -1
- package/dist/cjs/utils/LogUtils.js +10 -12
- package/dist/cjs/utils/LogUtils.js.map +1 -1
- package/dist/cjs/utils/Multicall.js +56 -115
- package/dist/cjs/utils/Multicall.js.map +1 -1
- package/dist/cjs/utils/NetworkUtils.js +12 -28
- package/dist/cjs/utils/NetworkUtils.js.map +1 -1
- package/dist/cjs/utils/NumberUtils.js +1 -3
- package/dist/cjs/utils/NumberUtils.js.map +1 -1
- package/dist/cjs/utils/ObjectUtils.js +27 -41
- package/dist/cjs/utils/ObjectUtils.js.map +1 -1
- package/dist/cjs/utils/Profiler.js +80 -83
- package/dist/cjs/utils/Profiler.js.map +1 -1
- package/dist/cjs/utils/ReviverUtils.js +5 -9
- package/dist/cjs/utils/ReviverUtils.js.map +1 -1
- package/dist/cjs/utils/SpokeUtils.js +84 -84
- package/dist/cjs/utils/SpokeUtils.js.map +1 -1
- package/dist/cjs/utils/TokenUtils.js +41 -64
- package/dist/cjs/utils/TokenUtils.js.map +1 -1
- package/dist/cjs/utils/TypeGuards.js +1 -1
- package/dist/cjs/utils/TypeGuards.js.map +1 -1
- package/dist/cjs/utils/ValidatorUtils.js +7 -7
- package/dist/cjs/utils/ValidatorUtils.js.map +1 -1
- package/dist/cjs/utils/abi/contracts/index.js +1 -1
- package/dist/cjs/utils/abi/index.js +12 -22
- package/dist/cjs/utils/abi/index.js.map +1 -1
- package/dist/cjs/utils/abi/typechain/factories/Multicall3__factory.js +9 -12
- package/dist/cjs/utils/abi/typechain/factories/Multicall3__factory.js.map +1 -1
- package/dist/cjs/utils/abi/typechain/index.js +1 -1
- package/dist/cjs/utils/common.js +40 -53
- package/dist/cjs/utils/common.js.map +1 -1
- package/dist/cjs/utils/index.js +1 -1
- package/dist/esm/addressAggregator/adapters/abstract.js +48 -64
- package/dist/esm/addressAggregator/adapters/abstract.js.map +1 -1
- package/dist/esm/addressAggregator/adapters/bybit.js +15 -29
- package/dist/esm/addressAggregator/adapters/bybit.js.map +1 -1
- package/dist/esm/addressAggregator/adapters/env.js +9 -14
- package/dist/esm/addressAggregator/adapters/env.js.map +1 -1
- package/dist/esm/addressAggregator/adapters/file.js +29 -43
- package/dist/esm/addressAggregator/adapters/file.js.map +1 -1
- package/dist/esm/addressAggregator/adapters/risklabs.js +20 -35
- package/dist/esm/addressAggregator/adapters/risklabs.js.map +1 -1
- package/dist/esm/addressAggregator/index.js +52 -83
- package/dist/esm/addressAggregator/index.js.map +1 -1
- package/dist/esm/addressAggregator/types.js +1 -1
- package/dist/esm/addressAggregator/types.js.map +1 -1
- package/dist/esm/apiClient/abstractClient.js +15 -9
- package/dist/esm/apiClient/abstractClient.js.map +1 -1
- package/dist/esm/apiClient/mockedClient.js +21 -26
- package/dist/esm/apiClient/mockedClient.js.map +1 -1
- package/dist/esm/apiClient/productionClient.js +61 -101
- package/dist/esm/apiClient/productionClient.js.map +1 -1
- package/dist/esm/arch/evm/BlockUtils.js +139 -217
- package/dist/esm/arch/evm/BlockUtils.js.map +1 -1
- package/dist/esm/arch/evm/SpokeUtils.js +146 -289
- package/dist/esm/arch/evm/SpokeUtils.js.map +1 -1
- package/dist/esm/arch/evm/utils/wait.js +34 -46
- package/dist/esm/arch/evm/utils/wait.js.map +1 -1
- package/dist/esm/arch/svm/BlockUtils.js +118 -166
- package/dist/esm/arch/svm/BlockUtils.js.map +1 -1
- package/dist/esm/arch/svm/SpokeUtils.js +738 -1150
- package/dist/esm/arch/svm/SpokeUtils.js.map +1 -1
- package/dist/esm/arch/svm/constants.js +1 -1
- package/dist/esm/arch/svm/constants.js.map +1 -1
- package/dist/esm/arch/svm/eventsClient.js +172 -232
- package/dist/esm/arch/svm/eventsClient.js.map +1 -1
- package/dist/esm/arch/svm/provider.js +1 -1
- package/dist/esm/arch/svm/provider.js.map +1 -1
- package/dist/esm/arch/svm/utils.js +155 -345
- package/dist/esm/arch/svm/utils.js.map +1 -1
- package/dist/esm/caching/Arweave/ArweaveClient.js +182 -256
- package/dist/esm/caching/Arweave/ArweaveClient.js.map +1 -1
- package/dist/esm/caching/IPFS/PinataIPFSClient.js +47 -48
- package/dist/esm/caching/IPFS/PinataIPFSClient.js.map +1 -1
- package/dist/esm/caching/Memory/MemoryCacheClient.js +13 -19
- package/dist/esm/caching/Memory/MemoryCacheClient.js.map +1 -1
- package/dist/esm/clients/AcrossConfigStoreClient/AcrossConfigStoreClient.js +333 -408
- package/dist/esm/clients/AcrossConfigStoreClient/AcrossConfigStoreClient.js.map +1 -1
- package/dist/esm/clients/BaseAbstractClient.js +66 -92
- package/dist/esm/clients/BaseAbstractClient.js.map +1 -1
- package/dist/esm/clients/BundleDataClient/BundleDataClient.js +927 -1054
- package/dist/esm/clients/BundleDataClient/BundleDataClient.js.map +1 -1
- package/dist/esm/clients/BundleDataClient/utils/DataworkerUtils.js +102 -131
- package/dist/esm/clients/BundleDataClient/utils/DataworkerUtils.js.map +1 -1
- package/dist/esm/clients/BundleDataClient/utils/FillUtils.js +57 -59
- package/dist/esm/clients/BundleDataClient/utils/FillUtils.js.map +1 -1
- package/dist/esm/clients/BundleDataClient/utils/MerkleTreeUtils.js +7 -5
- package/dist/esm/clients/BundleDataClient/utils/MerkleTreeUtils.js.map +1 -1
- package/dist/esm/clients/BundleDataClient/utils/PoolRebalanceUtils.js +75 -94
- package/dist/esm/clients/BundleDataClient/utils/PoolRebalanceUtils.js.map +1 -1
- package/dist/esm/clients/BundleDataClient/utils/SuperstructUtils.js +45 -23
- package/dist/esm/clients/BundleDataClient/utils/SuperstructUtils.js.map +1 -1
- package/dist/esm/clients/HubPoolClient.js +581 -740
- package/dist/esm/clients/HubPoolClient.js.map +1 -1
- package/dist/esm/clients/SpokePoolClient/EVMSpokePoolClient.js +133 -178
- package/dist/esm/clients/SpokePoolClient/EVMSpokePoolClient.js.map +1 -1
- package/dist/esm/clients/SpokePoolClient/SVMSpokePoolClient.js +126 -183
- package/dist/esm/clients/SpokePoolClient/SVMSpokePoolClient.js.map +1 -1
- package/dist/esm/clients/SpokePoolClient/SpokePoolClient.js +372 -399
- package/dist/esm/clients/SpokePoolClient/SpokePoolClient.js.map +1 -1
- package/dist/esm/clients/SpokePoolClient/SpokePoolClientManager.js +9 -9
- package/dist/esm/clients/SpokePoolClient/SpokePoolClientManager.js.map +1 -1
- package/dist/esm/clients/SpokePoolClient/index.js +2 -2
- package/dist/esm/clients/SpokePoolClient/index.js.map +1 -1
- package/dist/esm/clients/SpokePoolClient/types.js +2 -2
- package/dist/esm/clients/SpokePoolClient/types.js.map +1 -1
- package/dist/esm/clients/mocks/MockConfigStoreClient.js +53 -64
- package/dist/esm/clients/mocks/MockConfigStoreClient.js.map +1 -1
- package/dist/esm/clients/mocks/MockEvents.js +42 -49
- package/dist/esm/clients/mocks/MockEvents.js.map +1 -1
- package/dist/esm/clients/mocks/MockHubPoolClient.js +138 -182
- package/dist/esm/clients/mocks/MockHubPoolClient.js.map +1 -1
- package/dist/esm/clients/mocks/MockSpokePoolClient.js +202 -188
- package/dist/esm/clients/mocks/MockSpokePoolClient.js.map +1 -1
- package/dist/esm/clients/mocks/MockSvmCpiEventsClient.js +127 -132
- package/dist/esm/clients/mocks/MockSvmCpiEventsClient.js.map +1 -1
- package/dist/esm/clients/mocks/MockSvmSpokePoolClient.js +53 -69
- package/dist/esm/clients/mocks/MockSvmSpokePoolClient.js.map +1 -1
- package/dist/esm/coingecko/Coingecko.js +298 -443
- package/dist/esm/coingecko/Coingecko.js.map +1 -1
- package/dist/esm/constants.js +40 -47
- package/dist/esm/constants.js.map +1 -1
- package/dist/esm/contracts/acrossConfigStore.js +24 -46
- package/dist/esm/contracts/acrossConfigStore.js.map +1 -1
- package/dist/esm/contracts/hubPool.js +34 -18
- package/dist/esm/contracts/hubPool.js.map +1 -1
- package/dist/esm/contracts/utils.js +3 -5
- package/dist/esm/contracts/utils.js.map +1 -1
- package/dist/esm/gasPriceOracle/adapters/arbitrum.js +6 -14
- package/dist/esm/gasPriceOracle/adapters/arbitrum.js.map +1 -1
- package/dist/esm/gasPriceOracle/adapters/ethereum.js +22 -42
- package/dist/esm/gasPriceOracle/adapters/ethereum.js.map +1 -1
- package/dist/esm/gasPriceOracle/adapters/linea-viem.js +13 -25
- package/dist/esm/gasPriceOracle/adapters/linea-viem.js.map +1 -1
- package/dist/esm/gasPriceOracle/adapters/polygon.js +72 -108
- package/dist/esm/gasPriceOracle/adapters/polygon.js.map +1 -1
- package/dist/esm/gasPriceOracle/adapters/solana.js +22 -31
- package/dist/esm/gasPriceOracle/adapters/solana.js.map +1 -1
- package/dist/esm/gasPriceOracle/oracle.js +70 -96
- package/dist/esm/gasPriceOracle/oracle.js.map +1 -1
- package/dist/esm/gasPriceOracle/types.js +2 -2
- package/dist/esm/gasPriceOracle/types.js.map +1 -1
- package/dist/esm/gasPriceOracle/util.js +4 -4
- package/dist/esm/gasPriceOracle/util.js.map +1 -1
- package/dist/esm/lpFeeCalculator/lpFeeCalculator.js +30 -33
- package/dist/esm/lpFeeCalculator/lpFeeCalculator.js.map +1 -1
- package/dist/esm/lpFeeCalculator/rateModel.js +7 -9
- package/dist/esm/lpFeeCalculator/rateModel.js.map +1 -1
- package/dist/esm/merkleDistributor/MerkleDistributor.js +18 -17
- package/dist/esm/merkleDistributor/MerkleDistributor.js.map +1 -1
- package/dist/esm/pool/TransactionManager.js +45 -100
- package/dist/esm/pool/TransactionManager.js.map +1 -1
- package/dist/esm/pool/poolClient.js +479 -740
- package/dist/esm/pool/poolClient.js.map +1 -1
- package/dist/esm/pool/uma/across/constants.js +2 -2
- package/dist/esm/pool/uma/across/constants.js.map +1 -1
- package/dist/esm/pool/uma/across/transactionManager.js +45 -100
- package/dist/esm/pool/uma/across/transactionManager.js.map +1 -1
- package/dist/esm/pool/uma/clients/erc20/client.js +15 -13
- package/dist/esm/pool/uma/clients/erc20/client.js.map +1 -1
- package/dist/esm/pool/uma/oracle/utils.js +2 -3
- package/dist/esm/pool/uma/oracle/utils.js.map +1 -1
- package/dist/esm/pool/uma/utils.js +9 -28
- package/dist/esm/pool/uma/utils.js.map +1 -1
- package/dist/esm/priceClient/adapters/acrossApi.js +21 -40
- package/dist/esm/priceClient/adapters/acrossApi.js.map +1 -1
- package/dist/esm/priceClient/adapters/baseAdapter.js +46 -72
- package/dist/esm/priceClient/adapters/baseAdapter.js.map +1 -1
- package/dist/esm/priceClient/adapters/coingecko.js +33 -61
- package/dist/esm/priceClient/adapters/coingecko.js.map +1 -1
- package/dist/esm/priceClient/adapters/default.js +15 -31
- package/dist/esm/priceClient/adapters/default.js.map +1 -1
- package/dist/esm/priceClient/adapters/defiLlama.js +38 -73
- package/dist/esm/priceClient/adapters/defiLlama.js.map +1 -1
- package/dist/esm/priceClient/priceClient.js +109 -158
- package/dist/esm/priceClient/priceClient.js.map +1 -1
- package/dist/esm/providers/alchemy.js +16 -18
- package/dist/esm/providers/alchemy.js.map +1 -1
- package/dist/esm/providers/cachedProvider.js +99 -134
- package/dist/esm/providers/cachedProvider.js.map +1 -1
- package/dist/esm/providers/constants.js +3 -3
- package/dist/esm/providers/constants.js.map +1 -1
- package/dist/esm/providers/drpc.js +8 -10
- package/dist/esm/providers/drpc.js.map +1 -1
- package/dist/esm/providers/infura.js +9 -11
- package/dist/esm/providers/infura.js.map +1 -1
- package/dist/esm/providers/mocks/MockCachedSolanaRpcFactory.js +6 -15
- package/dist/esm/providers/mocks/MockCachedSolanaRpcFactory.js.map +1 -1
- package/dist/esm/providers/mocks/MockRateLimitedSolanaRpcFactory.js +5 -14
- package/dist/esm/providers/mocks/MockRateLimitedSolanaRpcFactory.js.map +1 -1
- package/dist/esm/providers/mocks/MockRetrySolanaRpcFactory.js +6 -15
- package/dist/esm/providers/mocks/MockRetrySolanaRpcFactory.js.map +1 -1
- package/dist/esm/providers/mocks/MockSolanaRpcFactory.js +41 -66
- package/dist/esm/providers/mocks/MockSolanaRpcFactory.js.map +1 -1
- package/dist/esm/providers/mocks/mockEthersProvider.js +27 -30
- package/dist/esm/providers/mocks/mockEthersProvider.js.map +1 -1
- package/dist/esm/providers/quicknode.js +18 -20
- package/dist/esm/providers/quicknode.js.map +1 -1
- package/dist/esm/providers/rateLimitedProvider.js +68 -80
- package/dist/esm/providers/rateLimitedProvider.js.map +1 -1
- package/dist/esm/providers/retryProvider.js +186 -259
- package/dist/esm/providers/retryProvider.js.map +1 -1
- package/dist/esm/providers/solana/baseRpcFactories.js +13 -19
- package/dist/esm/providers/solana/baseRpcFactories.js.map +1 -1
- package/dist/esm/providers/solana/cachedRpcFactory.js +75 -112
- package/dist/esm/providers/solana/cachedRpcFactory.js.map +1 -1
- package/dist/esm/providers/solana/defaultRpcFactory.js +6 -14
- package/dist/esm/providers/solana/defaultRpcFactory.js.map +1 -1
- package/dist/esm/providers/solana/quorumFallbackRpcFactory.js +149 -202
- package/dist/esm/providers/solana/quorumFallbackRpcFactory.js.map +1 -1
- package/dist/esm/providers/solana/rateLimitedRpcFactory.js +70 -90
- package/dist/esm/providers/solana/rateLimitedRpcFactory.js.map +1 -1
- package/dist/esm/providers/solana/retryRpcFactory.js +50 -74
- package/dist/esm/providers/solana/retryRpcFactory.js.map +1 -1
- package/dist/esm/providers/solana/utils.js +1 -1
- package/dist/esm/providers/solana/utils.js.map +1 -1
- package/dist/esm/providers/speedProvider.js +28 -51
- package/dist/esm/providers/speedProvider.js.map +1 -1
- package/dist/esm/providers/types.js +2 -2
- package/dist/esm/providers/types.js.map +1 -1
- package/dist/esm/providers/utils.js +17 -20
- package/dist/esm/providers/utils.js.map +1 -1
- package/dist/esm/relayFeeCalculator/chain-queries/baseQuery.js +98 -152
- package/dist/esm/relayFeeCalculator/chain-queries/baseQuery.js.map +1 -1
- package/dist/esm/relayFeeCalculator/chain-queries/customGasToken.js +13 -26
- package/dist/esm/relayFeeCalculator/chain-queries/customGasToken.js.map +1 -1
- package/dist/esm/relayFeeCalculator/chain-queries/factory.js +9 -19
- package/dist/esm/relayFeeCalculator/chain-queries/factory.js.map +1 -1
- package/dist/esm/relayFeeCalculator/chain-queries/svmQuery.js +83 -128
- package/dist/esm/relayFeeCalculator/chain-queries/svmQuery.js.map +1 -1
- package/dist/esm/relayFeeCalculator/relayFeeCalculator.js +211 -299
- package/dist/esm/relayFeeCalculator/relayFeeCalculator.js.map +1 -1
- package/dist/esm/typeguards/error.js +3 -5
- package/dist/esm/typeguards/error.js.map +1 -1
- package/dist/esm/utils/AddressUtils.js +115 -147
- package/dist/esm/utils/AddressUtils.js.map +1 -1
- package/dist/esm/utils/ArrayUtils.js +21 -78
- package/dist/esm/utils/ArrayUtils.js.map +1 -1
- package/dist/esm/utils/BigNumberUtils.js +11 -12
- package/dist/esm/utils/BigNumberUtils.js.map +1 -1
- package/dist/esm/utils/BlockExplorerUtils.js +19 -23
- package/dist/esm/utils/BlockExplorerUtils.js.map +1 -1
- package/dist/esm/utils/BlockFinder.js +2 -6
- package/dist/esm/utils/BlockFinder.js.map +1 -1
- package/dist/esm/utils/BlockUtils.js +31 -40
- package/dist/esm/utils/BlockUtils.js.map +1 -1
- package/dist/esm/utils/BundleUtils.js +21 -24
- package/dist/esm/utils/BundleUtils.js.map +1 -1
- package/dist/esm/utils/CCTPUtils.js +62 -123
- package/dist/esm/utils/CCTPUtils.js.map +1 -1
- package/dist/esm/utils/CachingUtils.js +17 -38
- package/dist/esm/utils/CachingUtils.js.map +1 -1
- package/dist/esm/utils/ContractUtils.js +3 -3
- package/dist/esm/utils/ContractUtils.js.map +1 -1
- package/dist/esm/utils/DepositUtils.js +121 -98
- package/dist/esm/utils/DepositUtils.js.map +1 -1
- package/dist/esm/utils/EventUtils.js +52 -69
- package/dist/esm/utils/EventUtils.js.map +1 -1
- package/dist/esm/utils/FormattingUtils.js +20 -26
- package/dist/esm/utils/FormattingUtils.js.map +1 -1
- package/dist/esm/utils/HyperLiquidUtils.js +8 -22
- package/dist/esm/utils/HyperLiquidUtils.js.map +1 -1
- package/dist/esm/utils/IPFSUtils.js +16 -35
- package/dist/esm/utils/IPFSUtils.js.map +1 -1
- package/dist/esm/utils/JSONUtils.js +4 -4
- package/dist/esm/utils/JSONUtils.js.map +1 -1
- package/dist/esm/utils/LogUtils.js +8 -12
- package/dist/esm/utils/LogUtils.js.map +1 -1
- package/dist/esm/utils/Multicall.js +50 -110
- package/dist/esm/utils/Multicall.js.map +1 -1
- package/dist/esm/utils/NetworkUtils.js +12 -28
- package/dist/esm/utils/NetworkUtils.js.map +1 -1
- package/dist/esm/utils/NumberUtils.js +1 -3
- package/dist/esm/utils/NumberUtils.js.map +1 -1
- package/dist/esm/utils/ObjectUtils.js +27 -41
- package/dist/esm/utils/ObjectUtils.js.map +1 -1
- package/dist/esm/utils/Profiler.js +77 -82
- package/dist/esm/utils/Profiler.js.map +1 -1
- package/dist/esm/utils/ReviverUtils.js +3 -7
- package/dist/esm/utils/ReviverUtils.js.map +1 -1
- package/dist/esm/utils/SpokeUtils.js +83 -78
- package/dist/esm/utils/SpokeUtils.js.map +1 -1
- package/dist/esm/utils/TokenUtils.js +33 -57
- package/dist/esm/utils/TokenUtils.js.map +1 -1
- package/dist/esm/utils/ValidatorUtils.js +4 -4
- package/dist/esm/utils/ValidatorUtils.js.map +1 -1
- package/dist/esm/utils/abi/index.js +10 -20
- package/dist/esm/utils/abi/index.js.map +1 -1
- package/dist/esm/utils/abi/typechain/factories/Multicall3__factory.js +8 -12
- package/dist/esm/utils/abi/typechain/factories/Multicall3__factory.js.map +1 -1
- package/dist/esm/utils/common.js +38 -52
- package/dist/esm/utils/common.js.map +1 -1
- package/dist/types/constants.d.ts.map +1 -1
- package/dist/types/gasPriceOracle/oracle.d.ts.map +1 -1
- package/dist/types/utils/Multicall.d.ts.map +1 -1
- package/dist/types/utils/NetworkUtils.d.ts.map +1 -1
- package/package.json +2 -2
- package/src/constants.ts +0 -1
- package/src/gasPriceOracle/oracle.ts +0 -1
- package/src/utils/Multicall.ts +0 -1
- package/src/utils/NetworkUtils.ts +1 -8
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { __awaiter, __extends, __generator, __spreadArray } from "tslib";
|
|
2
1
|
import { isPromiseFulfilled, isPromiseRejected } from "../../utils/TypeGuards";
|
|
3
2
|
import { compareSvmRpcResults, createSendErrorWithMessage } from "../utils";
|
|
4
3
|
import { CachedSolanaRpcFactory } from "./cachedRpcFactory";
|
|
@@ -7,212 +6,162 @@ import { shouldFailImmediate } from "./utils";
|
|
|
7
6
|
// This factory stores multiple Cached RPC factories so that users of this factory can specify multiple RPC providers
|
|
8
7
|
// and the factory will fallback through them if any RPC calls fail. This factory also implements quorum logic amongst
|
|
9
8
|
// the RPC providers.
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
9
|
+
export class QuorumFallbackSolanaRpcFactory extends SolanaBaseRpcFactory {
|
|
10
|
+
nodeQuorumThreshold;
|
|
11
|
+
logger;
|
|
12
|
+
rpcFactories = [];
|
|
13
|
+
constructor(factoryConstructorParams, nodeQuorumThreshold, logger) {
|
|
14
|
+
super();
|
|
15
|
+
this.nodeQuorumThreshold = nodeQuorumThreshold;
|
|
16
|
+
this.logger = logger;
|
|
17
|
+
factoryConstructorParams.forEach((params) => {
|
|
18
|
+
const rpcFactory = new CachedSolanaRpcFactory(...params);
|
|
19
|
+
this.rpcFactories.push({
|
|
20
20
|
transport: rpcFactory.createTransport(),
|
|
21
21
|
rpcClient: rpcFactory.createRpcClient(),
|
|
22
|
-
rpcFactory
|
|
22
|
+
rpcFactory,
|
|
23
23
|
});
|
|
24
24
|
});
|
|
25
|
-
if (
|
|
26
|
-
throw new Error(
|
|
25
|
+
if (this.nodeQuorumThreshold < 1 || !Number.isInteger(this.nodeQuorumThreshold)) {
|
|
26
|
+
throw new Error(`nodeQuorum,Threshold cannot be < 1 and must be an integer. Currently set to ${this.nodeQuorumThreshold}`);
|
|
27
27
|
}
|
|
28
|
-
return _this;
|
|
29
28
|
}
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
29
|
+
createTransport() {
|
|
30
|
+
return async (...args) => {
|
|
31
|
+
const { method, params } = args[0].payload;
|
|
32
|
+
const quorumThreshold = this._getQuorum(method, params ?? []);
|
|
33
|
+
const requiredFactories = this.rpcFactories.slice(0, quorumThreshold);
|
|
34
|
+
const fallbackFactories = [...this.rpcFactories.slice(quorumThreshold)];
|
|
35
|
+
const errors = [];
|
|
36
|
+
const tryWithFallback = (factory, ...args) => {
|
|
37
|
+
return factory
|
|
38
|
+
.transport(...args)
|
|
39
|
+
.then((result) => [factory.rpcFactory, result])
|
|
40
|
+
.catch((error) => {
|
|
41
|
+
// Append the provider and error to the error array.
|
|
42
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
43
|
+
errors.push([factory.rpcFactory, error?.stack || error?.toString()]);
|
|
44
|
+
// If all fallback providers fail, then return the last received error.
|
|
45
|
+
if (fallbackFactories.length === 0) {
|
|
46
|
+
throw error;
|
|
47
|
+
}
|
|
48
|
+
// If one RPC provider reverted, others likely will too. Skip them.
|
|
49
|
+
if (quorumThreshold === 1 && shouldFailImmediate(method, error)) {
|
|
50
|
+
throw new Error(`RPC provider reverted for method ${method}`);
|
|
51
|
+
}
|
|
52
|
+
const currentFactory = factory.rpcFactory.clusterUrl;
|
|
53
|
+
const nextFactory = fallbackFactories.shift();
|
|
54
|
+
this.logger.debug({
|
|
55
|
+
at: "FallbackSolanaRpcFactory#createTransport::tryWithFallback",
|
|
56
|
+
message: `[${method}] ${currentFactory} failed, falling back to ${nextFactory.rpcFactory.clusterUrl}, new fallback providers length: ${fallbackFactories.length}`,
|
|
57
|
+
method,
|
|
58
|
+
jsonError: error,
|
|
59
|
+
});
|
|
60
|
+
return tryWithFallback(nextFactory, ...args);
|
|
61
|
+
});
|
|
62
|
+
};
|
|
63
|
+
const results = await Promise.allSettled(requiredFactories.map((factory) => {
|
|
64
|
+
return tryWithFallback(factory, ...args);
|
|
65
|
+
}));
|
|
66
|
+
const getErrorStrings = () => {
|
|
67
|
+
return errors.map(([factory, errorText]) => `Provider ${factory.clusterUrl} failed to call ${method} with error ${errorText}`);
|
|
68
|
+
};
|
|
69
|
+
if (!results.every(isPromiseFulfilled)) {
|
|
70
|
+
// Format the error so that it's very clear which providers failed and succeeded.
|
|
71
|
+
const errorTexts = getErrorStrings();
|
|
72
|
+
const successfulProviderUrls = results.filter(isPromiseFulfilled).map((result) => result.value[0].clusterUrl);
|
|
73
|
+
throw createSendErrorWithMessage(`Not enough providers succeeded on ${method} call. Errors:\n${errorTexts.join("\n")}\n` +
|
|
74
|
+
`Successful Providers:\n${successfulProviderUrls.join("\n")}`, results.find(isPromiseRejected)?.reason);
|
|
36
75
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
return
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
.transport.apply(factory, args).then(function (result) { return [factory.rpcFactory, result]; })
|
|
56
|
-
.catch(function (error) {
|
|
57
|
-
// Append the provider and error to the error array.
|
|
58
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
59
|
-
errors.push([factory.rpcFactory, (error === null || error === void 0 ? void 0 : error.stack) || (error === null || error === void 0 ? void 0 : error.toString())]);
|
|
60
|
-
// If all fallback providers fail, then return the last received error.
|
|
61
|
-
if (fallbackFactories.length === 0) {
|
|
62
|
-
throw error;
|
|
63
|
-
}
|
|
64
|
-
// If one RPC provider reverted, others likely will too. Skip them.
|
|
65
|
-
if (quorumThreshold === 1 && shouldFailImmediate(method, error)) {
|
|
66
|
-
throw new Error("RPC provider reverted for method ".concat(method));
|
|
67
|
-
}
|
|
68
|
-
var currentFactory = factory.rpcFactory.clusterUrl;
|
|
69
|
-
var nextFactory = fallbackFactories.shift();
|
|
70
|
-
_this.logger.debug({
|
|
71
|
-
at: "FallbackSolanaRpcFactory#createTransport::tryWithFallback",
|
|
72
|
-
message: "[".concat(method, "] ").concat(currentFactory, " failed, falling back to ").concat(nextFactory.rpcFactory.clusterUrl, ", new fallback providers length: ").concat(fallbackFactories.length),
|
|
73
|
-
method: method,
|
|
74
|
-
jsonError: error,
|
|
75
|
-
});
|
|
76
|
-
return tryWithFallback.apply(void 0, __spreadArray([nextFactory], args, false));
|
|
77
|
-
});
|
|
78
|
-
};
|
|
79
|
-
return [4 /*yield*/, Promise.allSettled(requiredFactories.map(function (factory) {
|
|
80
|
-
return tryWithFallback.apply(void 0, __spreadArray([factory], args, false));
|
|
81
|
-
}))];
|
|
82
|
-
case 1:
|
|
83
|
-
results = _d.sent();
|
|
84
|
-
getErrorStrings = function () {
|
|
85
|
-
return errors.map(function (_a) {
|
|
86
|
-
var factory = _a[0], errorText = _a[1];
|
|
87
|
-
return "Provider ".concat(factory.clusterUrl, " failed to call ").concat(method, " with error ").concat(errorText);
|
|
88
|
-
});
|
|
89
|
-
};
|
|
90
|
-
if (!results.every(isPromiseFulfilled)) {
|
|
91
|
-
errorTexts = getErrorStrings();
|
|
92
|
-
successfulProviderUrls_1 = results.filter(isPromiseFulfilled).map(function (result) { return result.value[0].clusterUrl; });
|
|
93
|
-
throw createSendErrorWithMessage("Not enough providers succeeded on ".concat(method, " call. Errors:\n").concat(errorTexts.join("\n"), "\n") +
|
|
94
|
-
"Successful Providers:\n".concat(successfulProviderUrls_1.join("\n")), (_c = results.find(isPromiseRejected)) === null || _c === void 0 ? void 0 : _c.reason);
|
|
95
|
-
}
|
|
96
|
-
values = results.map(function (result) { return result.value; });
|
|
97
|
-
// Start at element 1 and begin comparing.
|
|
98
|
-
// If _all_ values are equal, we have hit quorum, so return.
|
|
99
|
-
if (values.slice(1).every(function (_a) {
|
|
100
|
-
var output = _a[1];
|
|
101
|
-
return compareSvmRpcResults(method, values[0][1], output);
|
|
102
|
-
})) {
|
|
103
|
-
return [2 /*return*/, values[0][1]];
|
|
104
|
-
}
|
|
105
|
-
getHighestCountResult = function (values) {
|
|
106
|
-
// Group the results by the count of that result.
|
|
107
|
-
var counts = __spreadArray([], values, true).reduce(function (acc, curr) {
|
|
108
|
-
var result = curr[1];
|
|
109
|
-
// Find the first result that matches the return value.
|
|
110
|
-
var existingMatch = acc.find(function (_a) {
|
|
111
|
-
var existingResult = _a[0];
|
|
112
|
-
return compareSvmRpcResults(method, existingResult, result);
|
|
113
|
-
});
|
|
114
|
-
// Increment the count if a match is found, else add a new element to the match array with a count of 1.
|
|
115
|
-
if (existingMatch) {
|
|
116
|
-
existingMatch[1]++;
|
|
117
|
-
}
|
|
118
|
-
else {
|
|
119
|
-
acc.push([result, 1]);
|
|
120
|
-
}
|
|
121
|
-
// Return the same acc object because it was modified in place.
|
|
122
|
-
return acc;
|
|
123
|
-
}, [[undefined, 0]] // Initialize with [undefined, 0] as the first element so something is always returned.
|
|
124
|
-
);
|
|
125
|
-
// Sort so the result with the highest count is first.
|
|
126
|
-
counts.sort(function (_a, _b) {
|
|
127
|
-
var a = _a[1];
|
|
128
|
-
var b = _b[1];
|
|
129
|
-
return b - a;
|
|
130
|
-
});
|
|
131
|
-
// Extract the result by grabbing the first element.
|
|
132
|
-
var _a = counts[0], mostFrequentResult = _a[0], count = _a[1];
|
|
133
|
-
return [mostFrequentResult, count];
|
|
134
|
-
};
|
|
135
|
-
logQuorumMismatchOrFailureDetails = function (method, params, mismatchedProviders, successfulProviders, errors, quorumResult) {
|
|
136
|
-
_this.logger.warn({
|
|
137
|
-
at: "FallbackSolanaRpcFactory#createTransport",
|
|
138
|
-
message: "[".concat(method, "] Some providers mismatched with the quorum result or failed \uD83D\uDEB8"),
|
|
139
|
-
notificationPath: "across-warn",
|
|
140
|
-
method: method,
|
|
141
|
-
params: JSON.stringify(params),
|
|
142
|
-
quorumResult: METHODS_RETURNING_BIGINT.includes(method) ? Number(quorumResult) : undefined,
|
|
143
|
-
mismatchedProviders: mismatchedProviders,
|
|
144
|
-
successfulProviders: successfulProviders,
|
|
145
|
-
erroringProviders: errors.map(function (_a) {
|
|
146
|
-
var factory = _a[0], errorText = _a[1];
|
|
147
|
-
return "Provider ".concat(factory.clusterUrl, " failed with error ").concat(errorText);
|
|
148
|
-
}),
|
|
149
|
-
});
|
|
150
|
-
};
|
|
151
|
-
throwQuorumError = function (mostFrequentResult, allValues) {
|
|
152
|
-
var errorTexts = getErrorStrings();
|
|
153
|
-
var successfulProviderUrls = values.map(function (_a) {
|
|
154
|
-
var provider = _a[0];
|
|
155
|
-
return provider.clusterUrl;
|
|
156
|
-
});
|
|
157
|
-
var mismatchedProviders = allValues
|
|
158
|
-
.filter(function (_a) {
|
|
159
|
-
var result = _a[1];
|
|
160
|
-
return !compareSvmRpcResults(method, result, mostFrequentResult);
|
|
161
|
-
})
|
|
162
|
-
.map(function (_a) {
|
|
163
|
-
var factory = _a[0];
|
|
164
|
-
return factory.clusterUrl;
|
|
165
|
-
});
|
|
166
|
-
logQuorumMismatchOrFailureDetails(method, params !== null && params !== void 0 ? params : [], mismatchedProviders, successfulProviderUrls, errors, mostFrequentResult);
|
|
167
|
-
throw new Error("Not enough providers agreed to meet quorum.\n" +
|
|
168
|
-
"Providers that errored:\n" +
|
|
169
|
-
"".concat(errorTexts.join("\n"), "\n") +
|
|
170
|
-
"Providers that succeeded, but some failed to match:\n" +
|
|
171
|
-
successfulProviderUrls.join("\n"));
|
|
172
|
-
};
|
|
173
|
-
// Exit early if there are no fallback providers left.
|
|
174
|
-
if (fallbackFactories.length === 0) {
|
|
175
|
-
mostFrequentResult = getHighestCountResult(values)[0];
|
|
176
|
-
throwQuorumError(mostFrequentResult, values);
|
|
177
|
-
}
|
|
178
|
-
return [4 /*yield*/, Promise.allSettled(fallbackFactories.map(function (factory) {
|
|
179
|
-
return factory
|
|
180
|
-
.transport.apply(factory, args).then(function (result) { return [factory.rpcFactory, result]; })
|
|
181
|
-
.catch(function (err) {
|
|
182
|
-
errors.push([factory.rpcFactory, (err === null || err === void 0 ? void 0 : err.stack) || (err === null || err === void 0 ? void 0 : err.toString())]);
|
|
183
|
-
throw new Error("Fallback RPC call failed while trying to reach quorum");
|
|
184
|
-
});
|
|
185
|
-
}))];
|
|
186
|
-
case 2:
|
|
187
|
-
fallbackResults = _d.sent();
|
|
188
|
-
fallbackValues = fallbackResults.filter(isPromiseFulfilled).map(function (promise) { return promise.value; });
|
|
189
|
-
_b = getHighestCountResult(__spreadArray(__spreadArray([], values, true), fallbackValues, true)), quorumResult = _b[0], count = _b[1];
|
|
190
|
-
// If this count is less than we need for quorum, throw the quorum error.
|
|
191
|
-
if (count < quorumThreshold) {
|
|
192
|
-
throwQuorumError(quorumResult, __spreadArray(__spreadArray([], values, true), fallbackValues, true));
|
|
193
|
-
}
|
|
194
|
-
mismatchedProviders = __spreadArray(__spreadArray([], values, true), fallbackValues, true).filter(function (_a) {
|
|
195
|
-
var result = _a[1];
|
|
196
|
-
return !compareSvmRpcResults(method, result, quorumResult);
|
|
197
|
-
})
|
|
198
|
-
.map(function (_a) {
|
|
199
|
-
var factory = _a[0];
|
|
200
|
-
return factory.clusterUrl;
|
|
201
|
-
});
|
|
202
|
-
successfulProviderUrls = __spreadArray(__spreadArray([], values, true), fallbackValues, true).map(function (_a) {
|
|
203
|
-
var provider = _a[0];
|
|
204
|
-
return provider.clusterUrl;
|
|
205
|
-
});
|
|
206
|
-
if (mismatchedProviders.length > 0 || errors.length > 0) {
|
|
207
|
-
logQuorumMismatchOrFailureDetails(method, params !== null && params !== void 0 ? params : [], mismatchedProviders, successfulProviderUrls, errors, quorumResult);
|
|
208
|
-
}
|
|
209
|
-
return [2 /*return*/, quorumResult];
|
|
76
|
+
const values = results.map((result) => result.value);
|
|
77
|
+
// Start at element 1 and begin comparing.
|
|
78
|
+
// If _all_ values are equal, we have hit quorum, so return.
|
|
79
|
+
if (values.slice(1).every(([, output]) => compareSvmRpcResults(method, values[0][1], output))) {
|
|
80
|
+
return values[0][1];
|
|
81
|
+
}
|
|
82
|
+
const getHighestCountResult = (values) => {
|
|
83
|
+
// Group the results by the count of that result.
|
|
84
|
+
const counts = [...values].reduce((acc, curr) => {
|
|
85
|
+
const [, result] = curr;
|
|
86
|
+
// Find the first result that matches the return value.
|
|
87
|
+
const existingMatch = acc.find(([existingResult]) => compareSvmRpcResults(method, existingResult, result));
|
|
88
|
+
// Increment the count if a match is found, else add a new element to the match array with a count of 1.
|
|
89
|
+
if (existingMatch) {
|
|
90
|
+
existingMatch[1]++;
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
acc.push([result, 1]);
|
|
210
94
|
}
|
|
95
|
+
// Return the same acc object because it was modified in place.
|
|
96
|
+
return acc;
|
|
97
|
+
}, [[undefined, 0]] // Initialize with [undefined, 0] as the first element so something is always returned.
|
|
98
|
+
);
|
|
99
|
+
// Sort so the result with the highest count is first.
|
|
100
|
+
counts.sort(([, a], [, b]) => b - a);
|
|
101
|
+
// Extract the result by grabbing the first element.
|
|
102
|
+
const [mostFrequentResult, count] = counts[0];
|
|
103
|
+
return [mostFrequentResult, count];
|
|
104
|
+
};
|
|
105
|
+
const logQuorumMismatchOrFailureDetails = (method, params, mismatchedProviders, successfulProviders, errors, quorumResult) => {
|
|
106
|
+
this.logger.warn({
|
|
107
|
+
at: "FallbackSolanaRpcFactory#createTransport",
|
|
108
|
+
message: `[${method}] Some providers mismatched with the quorum result or failed 🚸`,
|
|
109
|
+
notificationPath: "across-warn",
|
|
110
|
+
method,
|
|
111
|
+
params: JSON.stringify(params),
|
|
112
|
+
quorumResult: METHODS_RETURNING_BIGINT.includes(method) ? Number(quorumResult) : undefined,
|
|
113
|
+
mismatchedProviders,
|
|
114
|
+
successfulProviders,
|
|
115
|
+
erroringProviders: errors.map(([factory, errorText]) => `Provider ${factory.clusterUrl} failed with error ${errorText}`),
|
|
211
116
|
});
|
|
212
|
-
}
|
|
117
|
+
};
|
|
118
|
+
const throwQuorumError = (mostFrequentResult, allValues) => {
|
|
119
|
+
const errorTexts = getErrorStrings();
|
|
120
|
+
const successfulProviderUrls = values.map(([provider]) => provider.clusterUrl);
|
|
121
|
+
const mismatchedProviders = allValues
|
|
122
|
+
.filter(([, result]) => !compareSvmRpcResults(method, result, mostFrequentResult))
|
|
123
|
+
.map(([factory]) => factory.clusterUrl);
|
|
124
|
+
logQuorumMismatchOrFailureDetails(method, params ?? [], mismatchedProviders, successfulProviderUrls, errors, mostFrequentResult);
|
|
125
|
+
throw new Error("Not enough providers agreed to meet quorum.\n" +
|
|
126
|
+
"Providers that errored:\n" +
|
|
127
|
+
`${errorTexts.join("\n")}\n` +
|
|
128
|
+
"Providers that succeeded, but some failed to match:\n" +
|
|
129
|
+
successfulProviderUrls.join("\n"));
|
|
130
|
+
};
|
|
131
|
+
// Exit early if there are no fallback providers left.
|
|
132
|
+
if (fallbackFactories.length === 0) {
|
|
133
|
+
const [mostFrequentResult] = getHighestCountResult(values);
|
|
134
|
+
throwQuorumError(mostFrequentResult, values);
|
|
135
|
+
}
|
|
136
|
+
// Try each fallback provider in parallel.
|
|
137
|
+
const fallbackResults = await Promise.allSettled(fallbackFactories.map((factory) => {
|
|
138
|
+
return factory
|
|
139
|
+
.transport(...args)
|
|
140
|
+
.then((result) => [factory.rpcFactory, result])
|
|
141
|
+
.catch((err) => {
|
|
142
|
+
errors.push([factory.rpcFactory, err?.stack || err?.toString()]);
|
|
143
|
+
throw new Error("Fallback RPC call failed while trying to reach quorum");
|
|
144
|
+
});
|
|
145
|
+
}));
|
|
146
|
+
// This filters only the fallbacks that succeeded.
|
|
147
|
+
const fallbackValues = fallbackResults.filter(isPromiseFulfilled).map((promise) => promise.value);
|
|
148
|
+
const [quorumResult, count] = getHighestCountResult([...values, ...fallbackValues]);
|
|
149
|
+
// If this count is less than we need for quorum, throw the quorum error.
|
|
150
|
+
if (count < quorumThreshold) {
|
|
151
|
+
throwQuorumError(quorumResult, [...values, ...fallbackValues]);
|
|
152
|
+
}
|
|
153
|
+
// If we've achieved quorum, then we should still log the providers that mismatched with the quorum result.
|
|
154
|
+
const mismatchedProviders = [...values, ...fallbackValues]
|
|
155
|
+
.filter(([, result]) => !compareSvmRpcResults(method, result, quorumResult))
|
|
156
|
+
.map(([factory]) => factory.clusterUrl);
|
|
157
|
+
const successfulProviderUrls = [...values, ...fallbackValues].map(([provider]) => provider.clusterUrl);
|
|
158
|
+
if (mismatchedProviders.length > 0 || errors.length > 0) {
|
|
159
|
+
logQuorumMismatchOrFailureDetails(method, params ?? [], mismatchedProviders, successfulProviderUrls, errors, quorumResult);
|
|
160
|
+
}
|
|
161
|
+
return quorumResult;
|
|
213
162
|
};
|
|
214
|
-
}
|
|
215
|
-
|
|
163
|
+
}
|
|
164
|
+
_getQuorum(method, _params) {
|
|
216
165
|
// Only use quorum if this is a historical query that doesn't depend on the current block number.
|
|
217
166
|
switch (method) {
|
|
218
167
|
case "getBlock":
|
|
@@ -221,11 +170,9 @@ var QuorumFallbackSolanaRpcFactory = /** @class */ (function (_super) {
|
|
|
221
170
|
}
|
|
222
171
|
// All other calls should use quorum 1 to avoid errors due to sync differences.
|
|
223
172
|
return 1;
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
}(SolanaBaseRpcFactory));
|
|
227
|
-
export { QuorumFallbackSolanaRpcFactory };
|
|
173
|
+
}
|
|
174
|
+
}
|
|
228
175
|
// These methods return a bigint and their results are loggable because they are succinct and can further assist
|
|
229
176
|
// quorum debugging.
|
|
230
|
-
|
|
177
|
+
const METHODS_RETURNING_BIGINT = ["getBlockTime", "getSlot"];
|
|
231
178
|
//# sourceMappingURL=quorumFallbackRpcFactory.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"quorumFallbackRpcFactory.js","sourceRoot":"","sources":["../../../../src/providers/solana/quorumFallbackRpcFactory.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"quorumFallbackRpcFactory.js","sourceRoot":"","sources":["../../../../src/providers/solana/quorumFallbackRpcFactory.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { __assign, __awaiter, __extends, __generator, __spreadArray } from "tslib";
|
|
2
1
|
import { queue } from "async";
|
|
3
2
|
import winston from "winston";
|
|
4
3
|
import { SolanaClusterRpcFactory } from "./baseRpcFactories";
|
|
@@ -6,109 +5,90 @@ import { SolanaDefaultRpcFactory } from "./defaultRpcFactory";
|
|
|
6
5
|
import { getOriginFromURL } from "../../utils";
|
|
7
6
|
// This factory is a very small addition to the SolanaDefaultRpcFactory that ensures that no more than maxConcurrency
|
|
8
7
|
// requests are ever in flight. It uses the async/queue library to manage this.
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
export class RateLimitedSolanaRpcFactory extends SolanaClusterRpcFactory {
|
|
9
|
+
pctRpcCallsLogged;
|
|
10
|
+
logger;
|
|
11
|
+
// The queue object that manages the tasks.
|
|
12
|
+
queue;
|
|
13
|
+
// Holds the underlying transport that the rate limiter wraps.
|
|
14
|
+
defaultTransport;
|
|
11
15
|
// Takes the same arguments as the SolanaDefaultRpcFactory, but it has an additional parameters to control
|
|
12
16
|
// concurrency and logging at the beginning of the list.
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
}
|
|
21
|
-
var _this = _super.apply(this, defaultConstructorParams) || this;
|
|
22
|
-
_this.pctRpcCallsLogged = pctRpcCallsLogged;
|
|
23
|
-
_this.logger = logger;
|
|
24
|
-
_this.defaultTransport = new (SolanaDefaultRpcFactory.bind.apply(SolanaDefaultRpcFactory, __spreadArray([void 0], defaultConstructorParams, false)))().createTransport();
|
|
17
|
+
constructor(maxConcurrency, pctRpcCallsLogged, logger = winston.createLogger({
|
|
18
|
+
transports: [new winston.transports.Console()],
|
|
19
|
+
}), ...defaultConstructorParams) {
|
|
20
|
+
super(...defaultConstructorParams);
|
|
21
|
+
this.pctRpcCallsLogged = pctRpcCallsLogged;
|
|
22
|
+
this.logger = logger;
|
|
23
|
+
this.defaultTransport = new SolanaDefaultRpcFactory(...defaultConstructorParams).createTransport();
|
|
25
24
|
// This sets up the queue. Each task is executed by forwarding the RPC request to the underlying base transport.
|
|
26
25
|
// This queue sends out requests concurrently, but stops once the concurrency limit is reached. The maxConcurrency
|
|
27
26
|
// is configured here.
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
// we need this for the queue to know that the task is done
|
|
37
|
-
// @see: https://caolan.github.io/async/v3/global.html
|
|
38
|
-
callback();
|
|
39
|
-
return [2 /*return*/];
|
|
40
|
-
}
|
|
41
|
-
});
|
|
42
|
-
}); }, maxConcurrency);
|
|
43
|
-
return _this;
|
|
27
|
+
this.queue = queue(async ({ rpcArgs, resolve, reject }, callback) => {
|
|
28
|
+
await this.wrapSendWithLog(...rpcArgs)
|
|
29
|
+
.then(resolve)
|
|
30
|
+
.catch(reject);
|
|
31
|
+
// we need this for the queue to know that the task is done
|
|
32
|
+
// @see: https://caolan.github.io/async/v3/global.html
|
|
33
|
+
callback();
|
|
34
|
+
}, maxConcurrency);
|
|
44
35
|
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
36
|
+
async wrapSendWithLog(...rpcArgs) {
|
|
37
|
+
if (this.pctRpcCallsLogged <= 0 || Math.random() > this.pctRpcCallsLogged / 100) {
|
|
38
|
+
// Non sample path: no logging or timing, just issue the request.
|
|
39
|
+
return await this.defaultTransport(...rpcArgs);
|
|
49
40
|
}
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
this.logger.debug(__assign(__assign({}, loggerArgs), { success: false, timeElapsed: elapsedTimeS }));
|
|
85
|
-
throw error_1;
|
|
86
|
-
case 6: return [2 /*return*/];
|
|
87
|
-
}
|
|
88
|
-
});
|
|
89
|
-
});
|
|
90
|
-
};
|
|
91
|
-
RateLimitedSolanaRpcFactory.prototype.createTransport = function () {
|
|
92
|
-
var _this = this;
|
|
93
|
-
return function () {
|
|
94
|
-
var args = [];
|
|
95
|
-
for (var _i = 0; _i < arguments.length; _i++) {
|
|
96
|
-
args[_i] = arguments[_i];
|
|
41
|
+
else {
|
|
42
|
+
const payload = rpcArgs[0].payload;
|
|
43
|
+
const loggerArgs = {
|
|
44
|
+
at: "SolanaProviderUtils",
|
|
45
|
+
message: "Solana provider response sample",
|
|
46
|
+
provider: getOriginFromURL(this.clusterUrl),
|
|
47
|
+
method: payload.method,
|
|
48
|
+
params: payload.params,
|
|
49
|
+
chainId: this.chainId,
|
|
50
|
+
datadog: true,
|
|
51
|
+
};
|
|
52
|
+
// In this path we log an rpc response sample.
|
|
53
|
+
// Note: use performance.now() to ensure a purely monotonic clock.
|
|
54
|
+
const startTime = performance.now();
|
|
55
|
+
try {
|
|
56
|
+
const result = await this.defaultTransport(...rpcArgs);
|
|
57
|
+
const elapsedTimeS = (performance.now() - startTime) / 1000;
|
|
58
|
+
this.logger.debug({
|
|
59
|
+
...loggerArgs,
|
|
60
|
+
success: true,
|
|
61
|
+
timeElapsed: elapsedTimeS,
|
|
62
|
+
});
|
|
63
|
+
return result;
|
|
64
|
+
}
|
|
65
|
+
catch (error) {
|
|
66
|
+
// Log errors as well.
|
|
67
|
+
// For now, to keep logs light, don't log the error itself, just propagate and let it be handled higher up.
|
|
68
|
+
const elapsedTimeS = (performance.now() - startTime) / 1000;
|
|
69
|
+
this.logger.debug({
|
|
70
|
+
...loggerArgs,
|
|
71
|
+
success: false,
|
|
72
|
+
timeElapsed: elapsedTimeS,
|
|
73
|
+
});
|
|
74
|
+
throw error;
|
|
97
75
|
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
createTransport() {
|
|
79
|
+
return (...args) => {
|
|
98
80
|
// This simply creates a promise and adds the arguments and resolve and reject handlers to the task.
|
|
99
|
-
return new Promise(
|
|
100
|
-
|
|
81
|
+
return new Promise((resolve, reject) => {
|
|
82
|
+
const task = {
|
|
101
83
|
rpcArgs: args,
|
|
102
84
|
resolve: resolve,
|
|
103
|
-
reject
|
|
85
|
+
reject,
|
|
104
86
|
};
|
|
105
87
|
// We didn't previously wait for this push so we can emulate
|
|
106
88
|
// the same behavior with the `void` keyword.
|
|
107
|
-
void
|
|
89
|
+
void this.queue.push(task);
|
|
108
90
|
});
|
|
109
91
|
};
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
}(SolanaClusterRpcFactory));
|
|
113
|
-
export { RateLimitedSolanaRpcFactory };
|
|
92
|
+
}
|
|
93
|
+
}
|
|
114
94
|
//# sourceMappingURL=rateLimitedRpcFactory.js.map
|