@0xkoaj/sdk 0.0.1-beta.1 → 0.0.1-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +272 -5
- package/dist/chains.d.ts +1183 -0
- package/dist/chains.js +679 -0
- package/dist/chains.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.js +21 -0
- package/dist/index.js.map +1 -0
- package/dist/sdk/builders/allowance-builder.d.ts +22 -0
- package/dist/sdk/builders/allowance-builder.js +28 -0
- package/dist/sdk/builders/allowance-builder.js.map +1 -0
- package/dist/sdk/builders/balance-builder.d.ts +30 -0
- package/dist/sdk/builders/balance-builder.js +33 -0
- package/dist/sdk/builders/balance-builder.js.map +1 -0
- package/dist/sdk/builders/blocks-builder.d.ts +22 -0
- package/dist/sdk/builders/blocks-builder.js +30 -0
- package/dist/sdk/builders/blocks-builder.js.map +1 -0
- package/dist/sdk/builders/fetch-builder.d.ts +6 -0
- package/dist/sdk/builders/fetch-builder.js +9 -0
- package/dist/sdk/builders/fetch-builder.js.map +1 -0
- package/dist/sdk/builders/gas-builder.d.ts +106 -0
- package/dist/sdk/builders/gas-builder.js +69 -0
- package/dist/sdk/builders/gas-builder.js.map +1 -0
- package/dist/sdk/builders/index.d.ts +10 -0
- package/dist/sdk/builders/index.js +3 -0
- package/dist/sdk/builders/index.js.map +1 -0
- package/dist/sdk/builders/logs-builder.d.ts +6 -0
- package/dist/sdk/builders/logs-builder.js +9 -0
- package/dist/sdk/builders/logs-builder.js.map +1 -0
- package/dist/sdk/builders/metadata-builder.d.ts +49 -0
- package/dist/sdk/builders/metadata-builder.js +37 -0
- package/dist/sdk/builders/metadata-builder.js.map +1 -0
- package/dist/sdk/builders/price-builder.d.ts +49 -0
- package/dist/sdk/builders/price-builder.js +59 -0
- package/dist/sdk/builders/price-builder.js.map +1 -0
- package/dist/sdk/builders/provider-builder.d.ts +121 -0
- package/dist/sdk/builders/provider-builder.js +88 -0
- package/dist/sdk/builders/provider-builder.js.map +1 -0
- package/dist/sdk/builders/quote-builder.d.ts +44 -0
- package/dist/sdk/builders/quote-builder.js +55 -0
- package/dist/sdk/builders/quote-builder.js.map +1 -0
- package/dist/sdk/index.d.ts +3 -0
- package/dist/sdk/index.js +21 -0
- package/dist/sdk/index.js.map +1 -0
- package/dist/sdk/sdk-builder.d.ts +24 -0
- package/dist/sdk/sdk-builder.js +39 -0
- package/dist/sdk/sdk-builder.js.map +1 -0
- package/dist/sdk/types.d.ts +24 -0
- package/dist/sdk/types.js +3 -0
- package/dist/sdk/types.js.map +1 -0
- package/dist/services/allowances/allowance-service.d.ts +29 -0
- package/dist/services/allowances/allowance-service.js +35 -0
- package/dist/services/allowances/allowance-service.js.map +1 -0
- package/dist/services/allowances/allowance-sources/cached-allowance-source.d.ts +16 -0
- package/dist/services/allowances/allowance-sources/cached-allowance-source.js +69 -0
- package/dist/services/allowances/allowance-sources/cached-allowance-source.js.map +1 -0
- package/dist/services/allowances/allowance-sources/rpc-allowance-source.d.ts +15 -0
- package/dist/services/allowances/allowance-sources/rpc-allowance-source.js +54 -0
- package/dist/services/allowances/allowance-sources/rpc-allowance-source.js.map +1 -0
- package/dist/services/allowances/index.d.ts +1 -0
- package/dist/services/allowances/index.js +3 -0
- package/dist/services/allowances/index.js.map +1 -0
- package/dist/services/allowances/types.d.ts +43 -0
- package/dist/services/allowances/types.js +3 -0
- package/dist/services/allowances/types.js.map +1 -0
- package/dist/services/balances/balance-service.d.ts +35 -0
- package/dist/services/balances/balance-service.js +36 -0
- package/dist/services/balances/balance-service.js.map +1 -0
- package/dist/services/balances/balance-sources/cached-balance-source.d.ts +16 -0
- package/dist/services/balances/balance-sources/cached-balance-source.js +56 -0
- package/dist/services/balances/balance-sources/cached-balance-source.js.map +1 -0
- package/dist/services/balances/balance-sources/fastest-balance-source.d.ts +15 -0
- package/dist/services/balances/balance-sources/fastest-balance-source.js +45 -0
- package/dist/services/balances/balance-sources/fastest-balance-source.js.map +1 -0
- package/dist/services/balances/balance-sources/rpc-balance-source.d.ts +23 -0
- package/dist/services/balances/balance-sources/rpc-balance-source.js +70 -0
- package/dist/services/balances/balance-sources/rpc-balance-source.js.map +1 -0
- package/dist/services/balances/balance-sources/utils.d.ts +15 -0
- package/dist/services/balances/balance-sources/utils.js +43 -0
- package/dist/services/balances/balance-sources/utils.js.map +1 -0
- package/dist/services/balances/index.d.ts +1 -0
- package/dist/services/balances/index.js +3 -0
- package/dist/services/balances/index.js.map +1 -0
- package/dist/services/balances/types.d.ts +48 -0
- package/dist/services/balances/types.js +3 -0
- package/dist/services/balances/types.js.map +1 -0
- package/dist/services/blocks/block-service.d.ts +28 -0
- package/dist/services/blocks/block-service.js +27 -0
- package/dist/services/blocks/block-service.js.map +1 -0
- package/dist/services/blocks/block-sources/defi-llama-block-source.d.ts +13 -0
- package/dist/services/blocks/block-sources/defi-llama-block-source.js +41 -0
- package/dist/services/blocks/block-sources/defi-llama-block-source.js.map +1 -0
- package/dist/services/blocks/block-sources/fallback-block-source.d.ts +13 -0
- package/dist/services/blocks/block-sources/fallback-block-source.js +28 -0
- package/dist/services/blocks/block-sources/fallback-block-source.js.map +1 -0
- package/dist/services/blocks/block-sources/rpc-block-source.d.ts +12 -0
- package/dist/services/blocks/block-sources/rpc-block-source.js +139 -0
- package/dist/services/blocks/block-sources/rpc-block-source.js.map +1 -0
- package/dist/services/blocks/block-sources/utils.d.ts +3 -0
- package/dist/services/blocks/block-sources/utils.js +10 -0
- package/dist/services/blocks/block-sources/utils.js.map +1 -0
- package/dist/services/blocks/index.d.ts +1 -0
- package/dist/services/blocks/index.js +3 -0
- package/dist/services/blocks/index.js.map +1 -0
- package/dist/services/blocks/types.d.ts +42 -0
- package/dist/services/blocks/types.js +3 -0
- package/dist/services/blocks/types.js.map +1 -0
- package/dist/services/fetch/fetch-service.d.ts +6 -0
- package/dist/services/fetch/fetch-service.js +58 -0
- package/dist/services/fetch/fetch-service.js.map +1 -0
- package/dist/services/fetch/index.d.ts +1 -0
- package/dist/services/fetch/index.js +3 -0
- package/dist/services/fetch/index.js.map +1 -0
- package/dist/services/fetch/types.d.ts +11 -0
- package/dist/services/fetch/types.js +3 -0
- package/dist/services/fetch/types.js.map +1 -0
- package/dist/services/gas/gas-price-sources/aggregator-gas-price-source.d.ts +19 -0
- package/dist/services/gas/gas-price-sources/aggregator-gas-price-source.js +108 -0
- package/dist/services/gas/gas-price-sources/aggregator-gas-price-source.js.map +1 -0
- package/dist/services/gas/gas-price-sources/cached-gas-price-source.d.ts +28 -0
- package/dist/services/gas/gas-price-sources/cached-gas-price-source.js +56 -0
- package/dist/services/gas/gas-price-sources/cached-gas-price-source.js.map +1 -0
- package/dist/services/gas/gas-price-sources/etherscan-gas-price-source.d.ts +19 -0
- package/dist/services/gas/gas-price-sources/etherscan-gas-price-source.js +48 -0
- package/dist/services/gas/gas-price-sources/etherscan-gas-price-source.js.map +1 -0
- package/dist/services/gas/gas-price-sources/fastest-gas-price-source-combinator.d.ts +14 -0
- package/dist/services/gas/gas-price-sources/fastest-gas-price-source-combinator.js +33 -0
- package/dist/services/gas/gas-price-sources/fastest-gas-price-source-combinator.js.map +1 -0
- package/dist/services/gas/gas-price-sources/open-ocean-gas-price-source.d.ts +18 -0
- package/dist/services/gas/gas-price-sources/open-ocean-gas-price-source.js +60 -0
- package/dist/services/gas/gas-price-sources/open-ocean-gas-price-source.js.map +1 -0
- package/dist/services/gas/gas-price-sources/owlracle-gas-price-source.d.ts +29 -0
- package/dist/services/gas/gas-price-sources/owlracle-gas-price-source.js +65 -0
- package/dist/services/gas/gas-price-sources/owlracle-gas-price-source.js.map +1 -0
- package/dist/services/gas/gas-price-sources/paraswap-gas-price-source.d.ts +18 -0
- package/dist/services/gas/gas-price-sources/paraswap-gas-price-source.js +28 -0
- package/dist/services/gas/gas-price-sources/paraswap-gas-price-source.js.map +1 -0
- package/dist/services/gas/gas-price-sources/polygon-gas-station-gas-price-source.d.ts +18 -0
- package/dist/services/gas/gas-price-sources/polygon-gas-station-gas-price-source.js +31 -0
- package/dist/services/gas/gas-price-sources/polygon-gas-station-gas-price-source.js.map +1 -0
- package/dist/services/gas/gas-price-sources/prioritized-gas-price-source-combinator.d.ts +14 -0
- package/dist/services/gas/gas-price-sources/prioritized-gas-price-source-combinator.js +33 -0
- package/dist/services/gas/gas-price-sources/prioritized-gas-price-source-combinator.js.map +1 -0
- package/dist/services/gas/gas-price-sources/rpc-gas-price-source.d.ts +18 -0
- package/dist/services/gas/gas-price-sources/rpc-gas-price-source.js +32 -0
- package/dist/services/gas/gas-price-sources/rpc-gas-price-source.js.map +1 -0
- package/dist/services/gas/gas-service.d.ts +48 -0
- package/dist/services/gas/gas-service.js +67 -0
- package/dist/services/gas/gas-service.js.map +1 -0
- package/dist/services/gas/index.d.ts +2 -0
- package/dist/services/gas/index.js +6 -0
- package/dist/services/gas/index.js.map +1 -0
- package/dist/services/gas/types.d.ts +80 -0
- package/dist/services/gas/types.js +5 -0
- package/dist/services/gas/types.js.map +1 -0
- package/dist/services/gas/utils.d.ts +11 -0
- package/dist/services/gas/utils.js +25 -0
- package/dist/services/gas/utils.js.map +1 -0
- package/dist/services/index.d.ts +10 -0
- package/dist/services/index.js +27 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/logs/index.d.ts +1 -0
- package/dist/services/logs/index.js +3 -0
- package/dist/services/logs/index.js.map +1 -0
- package/dist/services/logs/loggers/console-logger.d.ts +12 -0
- package/dist/services/logs/loggers/console-logger.js +37 -0
- package/dist/services/logs/loggers/console-logger.js.map +1 -0
- package/dist/services/logs/logs-service.d.ts +8 -0
- package/dist/services/logs/logs-service.js +14 -0
- package/dist/services/logs/logs-service.js.map +1 -0
- package/dist/services/logs/types.d.ts +13 -0
- package/dist/services/logs/types.js +3 -0
- package/dist/services/logs/types.js.map +1 -0
- package/dist/services/logs/utils.d.ts +2 -0
- package/dist/services/logs/utils.js +25 -0
- package/dist/services/logs/utils.js.map +1 -0
- package/dist/services/metadata/index.d.ts +1 -0
- package/dist/services/metadata/index.js +3 -0
- package/dist/services/metadata/index.js.map +1 -0
- package/dist/services/metadata/metadata-service.d.ts +23 -0
- package/dist/services/metadata/metadata-service.js +38 -0
- package/dist/services/metadata/metadata-service.js.map +1 -0
- package/dist/services/metadata/metadata-sources/cached-metadata-source.d.ts +17 -0
- package/dist/services/metadata/metadata-sources/cached-metadata-source.js +87 -0
- package/dist/services/metadata/metadata-sources/cached-metadata-source.js.map +1 -0
- package/dist/services/metadata/metadata-sources/defi-llama-metadata-source.d.ts +16 -0
- package/dist/services/metadata/metadata-sources/defi-llama-metadata-source.js +27 -0
- package/dist/services/metadata/metadata-sources/defi-llama-metadata-source.js.map +1 -0
- package/dist/services/metadata/metadata-sources/fallback-metadata-source.d.ts +14 -0
- package/dist/services/metadata/metadata-sources/fallback-metadata-source.js +131 -0
- package/dist/services/metadata/metadata-sources/fallback-metadata-source.js.map +1 -0
- package/dist/services/metadata/metadata-sources/rpc-metadata-source.d.ts +23 -0
- package/dist/services/metadata/metadata-sources/rpc-metadata-source.js +77 -0
- package/dist/services/metadata/metadata-sources/rpc-metadata-source.js.map +1 -0
- package/dist/services/metadata/types.d.ts +44 -0
- package/dist/services/metadata/types.js +3 -0
- package/dist/services/metadata/types.js.map +1 -0
- package/dist/services/prices/index.d.ts +1 -0
- package/dist/services/prices/index.js +3 -0
- package/dist/services/prices/index.js.map +1 -0
- package/dist/services/prices/price-service.d.ts +69 -0
- package/dist/services/prices/price-service.js +58 -0
- package/dist/services/prices/price-service.js.map +1 -0
- package/dist/services/prices/price-sources/aggregator-price-source.d.ts +41 -0
- package/dist/services/prices/price-sources/aggregator-price-source.js +128 -0
- package/dist/services/prices/price-sources/aggregator-price-source.js.map +1 -0
- package/dist/services/prices/price-sources/alchemy-price-source.d.ts +47 -0
- package/dist/services/prices/price-sources/alchemy-price-source.js +110 -0
- package/dist/services/prices/price-sources/alchemy-price-source.js.map +1 -0
- package/dist/services/prices/price-sources/batch-price-source.d.ts +44 -0
- package/dist/services/prices/price-sources/batch-price-source.js +89 -0
- package/dist/services/prices/price-sources/batch-price-source.js.map +1 -0
- package/dist/services/prices/price-sources/cached-price-source.d.ts +41 -0
- package/dist/services/prices/price-sources/cached-price-source.js +68 -0
- package/dist/services/prices/price-sources/cached-price-source.js.map +1 -0
- package/dist/services/prices/price-sources/codex-price-source.d.ts +41 -0
- package/dist/services/prices/price-sources/codex-price-source.js +124 -0
- package/dist/services/prices/price-sources/codex-price-source.js.map +1 -0
- package/dist/services/prices/price-sources/coingecko-price-source.d.ts +42 -0
- package/dist/services/prices/price-sources/coingecko-price-source.js +109 -0
- package/dist/services/prices/price-sources/coingecko-price-source.js.map +1 -0
- package/dist/services/prices/price-sources/defi-llama-price-source.d.ts +39 -0
- package/dist/services/prices/price-sources/defi-llama-price-source.js +34 -0
- package/dist/services/prices/price-sources/defi-llama-price-source.js.map +1 -0
- package/dist/services/prices/price-sources/fastest-price-source.d.ts +38 -0
- package/dist/services/prices/price-sources/fastest-price-source.js +82 -0
- package/dist/services/prices/price-sources/fastest-price-source.js.map +1 -0
- package/dist/services/prices/price-sources/odos-price-source.d.ts +40 -0
- package/dist/services/prices/price-sources/odos-price-source.js +54 -0
- package/dist/services/prices/price-sources/odos-price-source.js.map +1 -0
- package/dist/services/prices/price-sources/prioritized-price-source.d.ts +38 -0
- package/dist/services/prices/price-sources/prioritized-price-source.js +81 -0
- package/dist/services/prices/price-sources/prioritized-price-source.js.map +1 -0
- package/dist/services/prices/price-sources/utils.d.ts +10 -0
- package/dist/services/prices/price-sources/utils.js +70 -0
- package/dist/services/prices/price-sources/utils.js.map +1 -0
- package/dist/services/prices/types.d.ts +105 -0
- package/dist/services/prices/types.js +3 -0
- package/dist/services/prices/types.js.map +1 -0
- package/dist/services/providers/index.d.ts +2 -0
- package/dist/services/providers/index.js +18 -0
- package/dist/services/providers/index.js.map +1 -0
- package/dist/services/providers/provider-service.d.ts +20 -0
- package/dist/services/providers/provider-service.js +33 -0
- package/dist/services/providers/provider-service.js.map +1 -0
- package/dist/services/providers/provider-sources/alchemy-provider.d.ts +20 -0
- package/dist/services/providers/provider-sources/alchemy-provider.js +37 -0
- package/dist/services/providers/provider-sources/alchemy-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/ankr-provider.d.ts +18 -0
- package/dist/services/providers/provider-sources/ankr-provider.js +52 -0
- package/dist/services/providers/provider-sources/ankr-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/base/base-http-provider.d.ts +14 -0
- package/dist/services/providers/provider-sources/base/base-http-provider.js +20 -0
- package/dist/services/providers/provider-sources/base/base-http-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/base/base-web-socket-provider.d.ts +10 -0
- package/dist/services/providers/provider-sources/base/base-web-socket-provider.js +17 -0
- package/dist/services/providers/provider-sources/base/base-web-socket-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/blast-provider.d.ts +18 -0
- package/dist/services/providers/provider-sources/blast-provider.js +52 -0
- package/dist/services/providers/provider-sources/blast-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/by-method-provider.d.ts +12 -0
- package/dist/services/providers/provider-sources/by-method-provider.js +40 -0
- package/dist/services/providers/provider-sources/by-method-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/drpc-provider.d.ts +18 -0
- package/dist/services/providers/provider-sources/drpc-provider.js +60 -0
- package/dist/services/providers/provider-sources/drpc-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/envio-provider.d.ts +18 -0
- package/dist/services/providers/provider-sources/envio-provider.js +72 -0
- package/dist/services/providers/provider-sources/envio-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/fallback-provider.d.ts +13 -0
- package/dist/services/providers/provider-sources/fallback-provider.js +26 -0
- package/dist/services/providers/provider-sources/fallback-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/get-block-provider.d.ts +15 -0
- package/dist/services/providers/provider-sources/get-block-provider.js +23 -0
- package/dist/services/providers/provider-sources/get-block-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/http-provider.d.ts +13 -0
- package/dist/services/providers/provider-sources/http-provider.js +21 -0
- package/dist/services/providers/provider-sources/http-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/index.d.ts +17 -0
- package/dist/services/providers/provider-sources/index.js +45 -0
- package/dist/services/providers/provider-sources/index.js.map +1 -0
- package/dist/services/providers/provider-sources/infura-provider.d.ts +18 -0
- package/dist/services/providers/provider-sources/infura-provider.js +40 -0
- package/dist/services/providers/provider-sources/infura-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/llama-nodes-provider.d.ts +18 -0
- package/dist/services/providers/provider-sources/llama-nodes-provider.js +40 -0
- package/dist/services/providers/provider-sources/llama-nodes-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/load-balance-provider.d.ts +23 -0
- package/dist/services/providers/provider-sources/load-balance-provider.js +163 -0
- package/dist/services/providers/provider-sources/load-balance-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/moralis-provider.d.ts +25 -0
- package/dist/services/providers/provider-sources/moralis-provider.js +56 -0
- package/dist/services/providers/provider-sources/moralis-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/node-real-provider.d.ts +18 -0
- package/dist/services/providers/provider-sources/node-real-provider.js +35 -0
- package/dist/services/providers/provider-sources/node-real-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/on-finality-provider.d.ts +18 -0
- package/dist/services/providers/provider-sources/on-finality-provider.js +50 -0
- package/dist/services/providers/provider-sources/on-finality-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/one-rpc-provider.d.ts +18 -0
- package/dist/services/providers/provider-sources/one-rpc-provider.js +56 -0
- package/dist/services/providers/provider-sources/one-rpc-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/prioritized-provider-source-combinator.d.ts +10 -0
- package/dist/services/providers/provider-sources/prioritized-provider-source-combinator.js +24 -0
- package/dist/services/providers/provider-sources/prioritized-provider-source-combinator.js.map +1 -0
- package/dist/services/providers/provider-sources/public-rpcs-provider.d.ts +21 -0
- package/dist/services/providers/provider-sources/public-rpcs-provider.js +35 -0
- package/dist/services/providers/provider-sources/public-rpcs-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/tenderly-provider.d.ts +18 -0
- package/dist/services/providers/provider-sources/tenderly-provider.js +48 -0
- package/dist/services/providers/provider-sources/tenderly-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/third-web-provider.d.ts +15 -0
- package/dist/services/providers/provider-sources/third-web-provider.js +58 -0
- package/dist/services/providers/provider-sources/third-web-provider.js.map +1 -0
- package/dist/services/providers/provider-sources/web-sockets-provider.d.ts +9 -0
- package/dist/services/providers/provider-sources/web-sockets-provider.js +21 -0
- package/dist/services/providers/provider-sources/web-sockets-provider.js.map +1 -0
- package/dist/services/providers/types.d.ts +17 -0
- package/dist/services/providers/types.js +3 -0
- package/dist/services/providers/types.js.map +1 -0
- package/dist/services/providers/utils.d.ts +4 -0
- package/dist/services/providers/utils.js +34 -0
- package/dist/services/providers/utils.js.map +1 -0
- package/dist/services/quotes/errors.d.ts +17 -0
- package/dist/services/quotes/errors.js +38 -0
- package/dist/services/quotes/errors.js.map +1 -0
- package/dist/services/quotes/index.d.ts +5 -0
- package/dist/services/quotes/index.js +28 -0
- package/dist/services/quotes/index.js.map +1 -0
- package/dist/services/quotes/quote-compare.d.ts +9 -0
- package/dist/services/quotes/quote-compare.js +144 -0
- package/dist/services/quotes/quote-compare.js.map +1 -0
- package/dist/services/quotes/quote-service.d.ts +117 -0
- package/dist/services/quotes/quote-service.js +304 -0
- package/dist/services/quotes/quote-service.js.map +1 -0
- package/dist/services/quotes/quote-sources/0x-quote-source.d.ts +19 -0
- package/dist/services/quotes/quote-sources/0x-quote-source.js +89 -0
- package/dist/services/quotes/quote-sources/0x-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/1inch-quote-source.d.ts +28 -0
- package/dist/services/quotes/quote-sources/1inch-quote-source.js +102 -0
- package/dist/services/quotes/quote-sources/1inch-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/barter-quote-source.d.ts +28 -0
- package/dist/services/quotes/quote-sources/barter-quote-source.js +126 -0
- package/dist/services/quotes/quote-sources/barter-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/base/always-valid-source.d.ts +8 -0
- package/dist/services/quotes/quote-sources/base/always-valid-source.js +13 -0
- package/dist/services/quotes/quote-sources/base/always-valid-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/bebop-quote-source.d.ts +21 -0
- package/dist/services/quotes/quote-sources/bebop-quote-source.js +97 -0
- package/dist/services/quotes/quote-sources/bebop-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/braindex-quote-source.d.ts +20 -0
- package/dist/services/quotes/quote-sources/braindex-quote-source.js +150 -0
- package/dist/services/quotes/quote-sources/braindex-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/changelly-quote-source.d.ts +20 -0
- package/dist/services/quotes/quote-sources/changelly-quote-source.js +71 -0
- package/dist/services/quotes/quote-sources/changelly-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/conveyor-quote-source.d.ts +19 -0
- package/dist/services/quotes/quote-sources/conveyor-quote-source.js +93 -0
- package/dist/services/quotes/quote-sources/conveyor-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/dodo-quote-source.d.ts +19 -0
- package/dist/services/quotes/quote-sources/dodo-quote-source.js +97 -0
- package/dist/services/quotes/quote-sources/dodo-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/enso-quote-source.d.ts +20 -0
- package/dist/services/quotes/quote-sources/enso-quote-source.js +85 -0
- package/dist/services/quotes/quote-sources/enso-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/fly-trade-quote-source.d.ts +20 -0
- package/dist/services/quotes/quote-sources/fly-trade-quote-source.js +99 -0
- package/dist/services/quotes/quote-sources/fly-trade-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/jupiter-quote-source.d.ts +50 -0
- package/dist/services/quotes/quote-sources/jupiter-quote-source.js +111 -0
- package/dist/services/quotes/quote-sources/jupiter-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/kyberswap-quote-source.d.ts +26 -0
- package/dist/services/quotes/quote-sources/kyberswap-quote-source.js +100 -0
- package/dist/services/quotes/quote-sources/kyberswap-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/li-fi-quote-source.d.ts +18 -0
- package/dist/services/quotes/quote-sources/li-fi-quote-source.js +104 -0
- package/dist/services/quotes/quote-sources/li-fi-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/odos-quote-source.d.ts +29 -0
- package/dist/services/quotes/quote-sources/odos-quote-source.js +130 -0
- package/dist/services/quotes/quote-sources/odos-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/okx-dex-quote-source.d.ts +21 -0
- package/dist/services/quotes/quote-sources/okx-dex-quote-source.js +143 -0
- package/dist/services/quotes/quote-sources/okx-dex-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/open-ocean-quote-source.d.ts +19 -0
- package/dist/services/quotes/quote-sources/open-ocean-quote-source.js +113 -0
- package/dist/services/quotes/quote-sources/open-ocean-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/paraswap-quote-source.d.ts +19 -0
- package/dist/services/quotes/quote-sources/paraswap-quote-source.js +84 -0
- package/dist/services/quotes/quote-sources/paraswap-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/portals-fi-quote-source.d.ts +20 -0
- package/dist/services/quotes/quote-sources/portals-fi-quote-source.js +94 -0
- package/dist/services/quotes/quote-sources/portals-fi-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/rango-quote-source.d.ts +21 -0
- package/dist/services/quotes/quote-sources/rango-quote-source.js +115 -0
- package/dist/services/quotes/quote-sources/rango-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/squid-quote-source.d.ts +20 -0
- package/dist/services/quotes/quote-sources/squid-quote-source.js +92 -0
- package/dist/services/quotes/quote-sources/squid-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/sushiswap-quote-source.d.ts +18 -0
- package/dist/services/quotes/quote-sources/sushiswap-quote-source.js +90 -0
- package/dist/services/quotes/quote-sources/sushiswap-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/swing-quote-source.d.ts +28 -0
- package/dist/services/quotes/quote-sources/swing-quote-source.js +148 -0
- package/dist/services/quotes/quote-sources/swing-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/types.d.ts +120 -0
- package/dist/services/quotes/quote-sources/types.js +13 -0
- package/dist/services/quotes/quote-sources/types.js.map +1 -0
- package/dist/services/quotes/quote-sources/uniswap-quote-source.d.ts +16 -0
- package/dist/services/quotes/quote-sources/uniswap-quote-source.js +119 -0
- package/dist/services/quotes/quote-sources/uniswap-quote-source.js.map +1 -0
- package/dist/services/quotes/quote-sources/utils.d.ts +9 -0
- package/dist/services/quotes/quote-sources/utils.js +37 -0
- package/dist/services/quotes/quote-sources/utils.js.map +1 -0
- package/dist/services/quotes/quote-sources/wrappers/buy-to-sell-order-wrapper.d.ts +6 -0
- package/dist/services/quotes/quote-sources/wrappers/buy-to-sell-order-wrapper.js +73 -0
- package/dist/services/quotes/quote-sources/wrappers/buy-to-sell-order-wrapper.js.map +1 -0
- package/dist/services/quotes/quote-sources/wrappers/forced-timeout-wrapper.d.ts +2 -0
- package/dist/services/quotes/quote-sources/wrappers/forced-timeout-wrapper.js +27 -0
- package/dist/services/quotes/quote-sources/wrappers/forced-timeout-wrapper.js.map +1 -0
- package/dist/services/quotes/quote-sources/xy-finance-quote-source.d.ts +16 -0
- package/dist/services/quotes/quote-sources/xy-finance-quote-source.js +87 -0
- package/dist/services/quotes/quote-sources/xy-finance-quote-source.js.map +1 -0
- package/dist/services/quotes/source-lists/batch-api-source-list.d.ts +30 -0
- package/dist/services/quotes/source-lists/batch-api-source-list.js +62 -0
- package/dist/services/quotes/source-lists/batch-api-source-list.js.map +1 -0
- package/dist/services/quotes/source-lists/index.d.ts +1 -0
- package/dist/services/quotes/source-lists/index.js +3 -0
- package/dist/services/quotes/source-lists/index.js.map +1 -0
- package/dist/services/quotes/source-lists/local-source-list.d.ts +21 -0
- package/dist/services/quotes/source-lists/local-source-list.js +157 -0
- package/dist/services/quotes/source-lists/local-source-list.js.map +1 -0
- package/dist/services/quotes/source-lists/overridable-source-list.d.ts +25 -0
- package/dist/services/quotes/source-lists/overridable-source-list.js +70 -0
- package/dist/services/quotes/source-lists/overridable-source-list.js.map +1 -0
- package/dist/services/quotes/source-lists/types.d.ts +44 -0
- package/dist/services/quotes/source-lists/types.js +3 -0
- package/dist/services/quotes/source-lists/types.js.map +1 -0
- package/dist/services/quotes/source-lists/utils.d.ts +5 -0
- package/dist/services/quotes/source-lists/utils.js +29 -0
- package/dist/services/quotes/source-lists/utils.js.map +1 -0
- package/dist/services/quotes/source-registry.d.ts +70 -0
- package/dist/services/quotes/source-registry.js +57 -0
- package/dist/services/quotes/source-registry.js.map +1 -0
- package/dist/services/quotes/types.d.ts +204 -0
- package/dist/services/quotes/types.js +3 -0
- package/dist/services/quotes/types.js.map +1 -0
- package/dist/shared/abis/erc20.d.ts +86 -0
- package/dist/shared/abis/erc20.js +116 -0
- package/dist/shared/abis/erc20.js.map +1 -0
- package/dist/shared/alchemy.d.ts +7 -0
- package/dist/shared/alchemy.js +35 -0
- package/dist/shared/alchemy.js.map +1 -0
- package/dist/shared/auto-update-cache.d.ts +23 -0
- package/dist/shared/auto-update-cache.js +38 -0
- package/dist/shared/auto-update-cache.js.map +1 -0
- package/dist/shared/concurrent-lru-cache.d.ts +66 -0
- package/dist/shared/concurrent-lru-cache.js +156 -0
- package/dist/shared/concurrent-lru-cache.js.map +1 -0
- package/dist/shared/constants.d.ts +12 -0
- package/dist/shared/constants.js +20 -0
- package/dist/shared/constants.js.map +1 -0
- package/dist/shared/contracts.d.ts +27 -0
- package/dist/shared/contracts.js +41 -0
- package/dist/shared/contracts.js.map +1 -0
- package/dist/shared/deferred.d.ts +12 -0
- package/dist/shared/deferred.js +32 -0
- package/dist/shared/deferred.js.map +1 -0
- package/dist/shared/defi-llama.d.ts +72 -0
- package/dist/shared/defi-llama.js +247 -0
- package/dist/shared/defi-llama.js.map +1 -0
- package/dist/shared/index.d.ts +10 -0
- package/dist/shared/index.js +51 -0
- package/dist/shared/index.js.map +1 -0
- package/dist/shared/requirements-and-support.d.ts +14 -0
- package/dist/shared/requirements-and-support.js +110 -0
- package/dist/shared/requirements-and-support.js.map +1 -0
- package/dist/shared/timeouts.d.ts +10 -0
- package/dist/shared/timeouts.js +41 -0
- package/dist/shared/timeouts.js.map +1 -0
- package/dist/shared/triggerable-promise.d.ts +9 -0
- package/dist/shared/triggerable-promise.js +16 -0
- package/dist/shared/triggerable-promise.js.map +1 -0
- package/dist/shared/utils.d.ts +39 -0
- package/dist/shared/utils.js +119 -0
- package/dist/shared/utils.js.map +1 -0
- package/dist/shared/viem.d.ts +5 -0
- package/dist/shared/viem.js +18 -0
- package/dist/shared/viem.js.map +1 -0
- package/dist/shared/wait.d.ts +7 -0
- package/dist/shared/wait.js +34 -0
- package/dist/shared/wait.js.map +1 -0
- package/dist/types.d.ts +99 -0
- package/dist/types.js +13 -0
- package/dist/types.js.map +1 -0
- package/dist/utility-types.d.ts +46 -0
- package/dist/utility-types.js +3 -0
- package/dist/utility-types.js.map +1 -0
- package/package.json +2 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/balances/index.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { Address, ChainId, TimeString, TokenAddress } from '../../types';
|
|
2
|
+
type Account = Address;
|
|
3
|
+
export type IBalanceService = {
|
|
4
|
+
supportedChains(): ChainId[];
|
|
5
|
+
getBalancesForAccountInChain(_: {
|
|
6
|
+
chainId: ChainId;
|
|
7
|
+
account: Address;
|
|
8
|
+
tokens: TokenAddress[];
|
|
9
|
+
config?: {
|
|
10
|
+
timeout?: TimeString;
|
|
11
|
+
};
|
|
12
|
+
}): Promise<Record<TokenAddress, bigint>>;
|
|
13
|
+
getBalancesForAccount(_: {
|
|
14
|
+
account: Address;
|
|
15
|
+
tokens: Omit<BalanceInput, 'account'>[];
|
|
16
|
+
config?: {
|
|
17
|
+
timeout?: TimeString;
|
|
18
|
+
};
|
|
19
|
+
}): Promise<Record<ChainId, Record<TokenAddress, bigint>>>;
|
|
20
|
+
getBalancesInChain(_: {
|
|
21
|
+
chainId: ChainId;
|
|
22
|
+
tokens: Omit<BalanceInput, 'chainId'>[];
|
|
23
|
+
config?: {
|
|
24
|
+
timeout?: TimeString;
|
|
25
|
+
};
|
|
26
|
+
}): Promise<Record<Account, Record<TokenAddress, bigint>>>;
|
|
27
|
+
getBalances(_: {
|
|
28
|
+
tokens: BalanceInput[];
|
|
29
|
+
config?: {
|
|
30
|
+
timeout?: TimeString;
|
|
31
|
+
};
|
|
32
|
+
}): Promise<Record<ChainId, Record<Account, Record<TokenAddress, bigint>>>>;
|
|
33
|
+
};
|
|
34
|
+
export type IBalanceSource = {
|
|
35
|
+
supportedChains(): ChainId[];
|
|
36
|
+
getBalances(_: {
|
|
37
|
+
tokens: BalanceInput[];
|
|
38
|
+
config?: {
|
|
39
|
+
timeout?: TimeString;
|
|
40
|
+
};
|
|
41
|
+
}): Promise<Record<ChainId, Record<Account, Record<TokenAddress, bigint>>>>;
|
|
42
|
+
};
|
|
43
|
+
export type BalanceInput = {
|
|
44
|
+
chainId: ChainId;
|
|
45
|
+
account: Account;
|
|
46
|
+
token: TokenAddress;
|
|
47
|
+
};
|
|
48
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/services/balances/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { StringValue } from 'ms';
|
|
2
|
+
import { ChainId, TimeString, Timestamp } from '../../types';
|
|
3
|
+
import { BlockInput, IBlocksService, IBlocksSource } from './types';
|
|
4
|
+
export declare class BlocksService implements IBlocksService {
|
|
5
|
+
private readonly source;
|
|
6
|
+
constructor(source: IBlocksSource);
|
|
7
|
+
supportedChains(): ChainId[];
|
|
8
|
+
getBlockClosestToTimestampInChain({ chainId, timestamp, config, }: {
|
|
9
|
+
chainId: ChainId;
|
|
10
|
+
timestamp: Timestamp;
|
|
11
|
+
config?: {
|
|
12
|
+
timeout?: TimeString;
|
|
13
|
+
};
|
|
14
|
+
}): Promise<import("./types").BlockResult>;
|
|
15
|
+
getBlocksClosestToTimestampsInChain({ chainId, timestamps, config, }: {
|
|
16
|
+
chainId: ChainId;
|
|
17
|
+
timestamps: Timestamp[];
|
|
18
|
+
config?: {
|
|
19
|
+
timeout?: StringValue;
|
|
20
|
+
};
|
|
21
|
+
}): Promise<Record<number, import("./types").BlockResult>>;
|
|
22
|
+
getBlocksClosestToTimestamps({ timestamps, config }: {
|
|
23
|
+
timestamps: BlockInput[];
|
|
24
|
+
config?: {
|
|
25
|
+
timeout?: TimeString;
|
|
26
|
+
};
|
|
27
|
+
}): Promise<Record<ChainId, Record<number, import("./types").BlockResult>>>;
|
|
28
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BlocksService = void 0;
|
|
4
|
+
const timeouts_1 = require("../../shared/timeouts");
|
|
5
|
+
class BlocksService {
|
|
6
|
+
constructor(source) {
|
|
7
|
+
this.source = source;
|
|
8
|
+
}
|
|
9
|
+
supportedChains() {
|
|
10
|
+
return this.source.supportedChains();
|
|
11
|
+
}
|
|
12
|
+
async getBlockClosestToTimestampInChain({ chainId, timestamp, config, }) {
|
|
13
|
+
const result = await this.getBlocksClosestToTimestampsInChain({ chainId, timestamps: [timestamp], config });
|
|
14
|
+
return result[timestamp];
|
|
15
|
+
}
|
|
16
|
+
async getBlocksClosestToTimestampsInChain({ chainId, timestamps, config, }) {
|
|
17
|
+
const result = await this.getBlocksClosestToTimestamps({ timestamps: timestamps.map((timestamp) => ({ chainId, timestamp })), config });
|
|
18
|
+
return result[chainId];
|
|
19
|
+
}
|
|
20
|
+
async getBlocksClosestToTimestamps({ timestamps, config }) {
|
|
21
|
+
if (timestamps.length === 0)
|
|
22
|
+
return {};
|
|
23
|
+
return (0, timeouts_1.timeoutPromise)(this.source.getBlocksClosestToTimestamps({ timestamps, config }), config?.timeout);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
exports.BlocksService = BlocksService;
|
|
27
|
+
//# sourceMappingURL=block-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"block-service.js","sourceRoot":"","sources":["../../../src/services/blocks/block-service.ts"],"names":[],"mappings":";;;AAEA,+CAAkD;AAGlD,MAAa,aAAa;IACxB,YAA6B,MAAqB;QAArB,WAAM,GAAN,MAAM,CAAe;IAAG,CAAC;IAEtD,eAAe;QACb,OAAO,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC;IACvC,CAAC;IAED,KAAK,CAAC,iCAAiC,CAAC,EACtC,OAAO,EACP,SAAS,EACT,MAAM,GAKP;QACC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,mCAAmC,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QAC5G,OAAO,MAAM,CAAC,SAAS,CAAC,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,mCAAmC,CAAC,EACxC,OAAO,EACP,UAAU,EACV,MAAM,GAKP;QACC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,4BAA4B,CAAC,EAAE,UAAU,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QACxI,OAAO,MAAM,CAAC,OAAO,CAAC,CAAC;IACzB,CAAC;IAED,KAAK,CAAC,4BAA4B,CAAC,EAAE,UAAU,EAAE,MAAM,EAAmE;QACxH,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QACvC,OAAO,IAAA,yBAAc,EAAC,IAAI,CAAC,MAAM,CAAC,4BAA4B,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3G,CAAC;CACF;AArCD,sCAqCC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ChainId, Timestamp } from '../../../types';
|
|
2
|
+
import { IFetchService } from '../../fetch';
|
|
3
|
+
import { BlockInput, BlockResult, IBlocksSource } from '../types';
|
|
4
|
+
import { IProviderService } from '../../providers';
|
|
5
|
+
export declare class DefiLlamaBlockSource implements IBlocksSource {
|
|
6
|
+
private readonly defiLlama;
|
|
7
|
+
private readonly providerService;
|
|
8
|
+
constructor(fetch: IFetchService, providerService: IProviderService);
|
|
9
|
+
supportedChains(): ChainId[];
|
|
10
|
+
getBlocksClosestToTimestamps({ timestamps }: {
|
|
11
|
+
timestamps: BlockInput[];
|
|
12
|
+
}): Promise<Record<ChainId, Record<Timestamp, BlockResult>>>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DefiLlamaBlockSource = void 0;
|
|
4
|
+
const defi_llama_1 = require("../../../shared/defi-llama");
|
|
5
|
+
class DefiLlamaBlockSource {
|
|
6
|
+
constructor(fetch, providerService) {
|
|
7
|
+
this.defiLlama = new defi_llama_1.DefiLlamaClient(fetch);
|
|
8
|
+
this.providerService = providerService;
|
|
9
|
+
}
|
|
10
|
+
supportedChains() {
|
|
11
|
+
return this.defiLlama.supportedChains();
|
|
12
|
+
}
|
|
13
|
+
async getBlocksClosestToTimestamps({ timestamps }) {
|
|
14
|
+
const result = {};
|
|
15
|
+
const promises = [];
|
|
16
|
+
for (const { chainId, timestamp } of timestamps) {
|
|
17
|
+
if (!(chainId in result))
|
|
18
|
+
result[chainId] = {};
|
|
19
|
+
const promise = this.defiLlama
|
|
20
|
+
.getClosestBlock(chainId, timestamp)
|
|
21
|
+
.then((block) => (result[chainId][timestamp] = block))
|
|
22
|
+
.catch(async (e) => {
|
|
23
|
+
const provider = this.providerService.getViemPublicClient({ chainId });
|
|
24
|
+
// We're getting a timestamp value of 0n for genesis block, so we will use block 1n for now
|
|
25
|
+
const blockOne = await provider.getBlock({ blockNumber: 1n });
|
|
26
|
+
const blockTimestamp = Number(blockOne.timestamp);
|
|
27
|
+
if (timestamp < blockTimestamp) {
|
|
28
|
+
result[chainId][timestamp] = { block: 1n, timestamp: blockTimestamp };
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
throw e;
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
promises.push(promise);
|
|
35
|
+
}
|
|
36
|
+
await Promise.all(promises);
|
|
37
|
+
return result;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
exports.DefiLlamaBlockSource = DefiLlamaBlockSource;
|
|
41
|
+
//# sourceMappingURL=defi-llama-block-source.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defi-llama-block-source.js","sourceRoot":"","sources":["../../../../src/services/blocks/block-sources/defi-llama-block-source.ts"],"names":[],"mappings":";;;AAEA,mDAAqD;AAIrD,MAAa,oBAAoB;IAI/B,YAAY,KAAoB,EAAE,eAAiC;QACjE,IAAI,CAAC,SAAS,GAAG,IAAI,4BAAe,CAAC,KAAK,CAAC,CAAC;QAC5C,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;IACzC,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,SAAS,CAAC,eAAe,EAAE,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,4BAA4B,CAAC,EAAE,UAAU,EAAgC;QAC7E,MAAM,MAAM,GAAoD,EAAE,CAAC;QACnE,MAAM,QAAQ,GAAmB,EAAE,CAAC;QACpC,KAAK,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,UAAU,EAAE,CAAC;YAChD,IAAI,CAAC,CAAC,OAAO,IAAI,MAAM,CAAC;gBAAE,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC;YAC/C,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS;iBAC3B,eAAe,CAAC,OAAO,EAAE,SAAS,CAAC;iBACnC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC,CAAC;iBACrD,KAAK,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;gBACjB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;gBAEvE,2FAA2F;gBAC3F,MAAM,QAAQ,GAAG,MAAM,QAAQ,CAAC,QAAQ,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,CAAC;gBAC9D,MAAM,cAAc,GAAG,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;gBAClD,IAAI,SAAS,GAAG,cAAc,EAAE,CAAC;oBAC/B,MAAM,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,cAAc,EAAE,CAAC;gBACxE,CAAC;qBAAM,CAAC;oBACN,MAAM,CAAC,CAAC;gBACV,CAAC;YACH,CAAC,CAAC,CAAC;YACL,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACzB,CAAC;QACD,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC5B,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAtCD,oDAsCC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ChainId, Timestamp, TimeString } from '../../../types';
|
|
2
|
+
import { BlockInput, BlockResult, IBlocksSource } from '../types';
|
|
3
|
+
export declare class FallbackBlockSource implements IBlocksSource {
|
|
4
|
+
private readonly sources;
|
|
5
|
+
constructor(sources: IBlocksSource[]);
|
|
6
|
+
supportedChains(): ChainId[];
|
|
7
|
+
getBlocksClosestToTimestamps({ timestamps, config, }: {
|
|
8
|
+
timestamps: BlockInput[];
|
|
9
|
+
config?: {
|
|
10
|
+
timeout?: TimeString;
|
|
11
|
+
};
|
|
12
|
+
}): Promise<Record<ChainId, Record<Timestamp, BlockResult>>>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FallbackBlockSource = void 0;
|
|
4
|
+
const _chains_1 = require("../../../chains");
|
|
5
|
+
const timeouts_1 = require("../../../shared/timeouts");
|
|
6
|
+
class FallbackBlockSource {
|
|
7
|
+
constructor(sources) {
|
|
8
|
+
this.sources = sources;
|
|
9
|
+
}
|
|
10
|
+
supportedChains() {
|
|
11
|
+
return (0, _chains_1.chainsUnion)(this.sources.map((source) => source.supportedChains()));
|
|
12
|
+
}
|
|
13
|
+
async getBlocksClosestToTimestamps({ timestamps, config, }) {
|
|
14
|
+
// TODO: we need to split the input by supported chains. Not all sources might support all chains
|
|
15
|
+
const errors = [];
|
|
16
|
+
for (const source of this.sources) {
|
|
17
|
+
try {
|
|
18
|
+
return await (0, timeouts_1.timeoutPromise)(source.getBlocksClosestToTimestamps({ timestamps, config }), config?.timeout, { reduceBy: '100' });
|
|
19
|
+
}
|
|
20
|
+
catch (e) {
|
|
21
|
+
errors.push(e);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
throw new AggregateError(errors);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
exports.FallbackBlockSource = FallbackBlockSource;
|
|
28
|
+
//# sourceMappingURL=fallback-block-source.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fallback-block-source.js","sourceRoot":"","sources":["../../../../src/services/blocks/block-sources/fallback-block-source.ts"],"names":[],"mappings":";;;AAEA,qCAAsC;AACtC,+CAAkD;AAElD,MAAa,mBAAmB;IAC9B,YAA6B,OAAwB;QAAxB,YAAO,GAAP,OAAO,CAAiB;IAAG,CAAC;IAEzD,eAAe;QACb,OAAO,IAAA,qBAAW,EAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED,KAAK,CAAC,4BAA4B,CAAC,EACjC,UAAU,EACV,MAAM,GAIP;QACC,iGAAiG;QACjG,MAAM,MAAM,GAAY,EAAE,CAAC;QAC3B,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YAClC,IAAI,CAAC;gBACH,OAAO,MAAM,IAAA,yBAAc,EAAC,MAAM,CAAC,4BAA4B,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;YACjI,CAAC;YAAC,OAAO,CAAM,EAAE,CAAC;gBAChB,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACjB,CAAC;QACH,CAAC;QACD,MAAM,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;CACF;AAzBD,kDAyBC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { ChainId, Timestamp } from '../../../types';
|
|
2
|
+
import { IProviderService } from '../../providers';
|
|
3
|
+
import { BlockInput, BlockResult, IBlocksSource } from '../types';
|
|
4
|
+
export declare class RPCBlockSource implements IBlocksSource {
|
|
5
|
+
private readonly providerService;
|
|
6
|
+
constructor(providerService: IProviderService);
|
|
7
|
+
supportedChains(): ChainId[];
|
|
8
|
+
getBlocksClosestToTimestamps({ timestamps }: {
|
|
9
|
+
timestamps: BlockInput[];
|
|
10
|
+
}): Promise<Record<ChainId, Record<Timestamp, BlockResult>>>;
|
|
11
|
+
private getBlocksClosestToTimestampsInChain;
|
|
12
|
+
}
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RPCBlockSource = void 0;
|
|
4
|
+
const utils_1 = require("../../../shared/utils");
|
|
5
|
+
const utils_2 = require("./utils");
|
|
6
|
+
class RPCBlockSource {
|
|
7
|
+
constructor(providerService) {
|
|
8
|
+
this.providerService = providerService;
|
|
9
|
+
}
|
|
10
|
+
supportedChains() {
|
|
11
|
+
return this.providerService.supportedChains();
|
|
12
|
+
}
|
|
13
|
+
async getBlocksClosestToTimestamps({ timestamps }) {
|
|
14
|
+
const timestampsByChain = (0, utils_1.groupByChain)(timestamps, ({ timestamp }) => timestamp);
|
|
15
|
+
const promises = Object.entries(timestampsByChain).map(async ([chainId, timestamps]) => {
|
|
16
|
+
const filteredAndSorted = [...new Set(timestamps)].sort();
|
|
17
|
+
return [chainId, await this.getBlocksClosestToTimestampsInChain(Number(chainId), filteredAndSorted)];
|
|
18
|
+
});
|
|
19
|
+
return Object.fromEntries(await Promise.all(promises));
|
|
20
|
+
}
|
|
21
|
+
// First of all, we know that timestamps are sorted. We will attempt to do a sort of binary search, but we'll attempt to optimize it. Instead of doing
|
|
22
|
+
// a binary search for each timestamp, we will first try to find blocks between the given timestamps. Once we have that, we can attempt a more "regular"
|
|
23
|
+
// binary search for each timestamp. By doing this, we can optimize the number of RPC calls we make
|
|
24
|
+
async getBlocksClosestToTimestampsInChain(chainId, timestamps) {
|
|
25
|
+
const client = this.providerService.getViemPublicClient({ chainId });
|
|
26
|
+
// We build a small cache for block => timestamp, to avoid unnecessary RPC calls
|
|
27
|
+
const cache = new Map();
|
|
28
|
+
const fetchBlock = async (block) => {
|
|
29
|
+
let result = cache.get(block ?? -1n);
|
|
30
|
+
if (!result) {
|
|
31
|
+
result = await client.getBlock({ blockNumber: block }).then((block) => ({ block: block.number, timestamp: Number(block.timestamp) }));
|
|
32
|
+
cache.set(result.block, result);
|
|
33
|
+
}
|
|
34
|
+
return result;
|
|
35
|
+
};
|
|
36
|
+
// Note: we ask for the block "1" instead of "0" because many RPCs return timestamp "0" for the genesis block
|
|
37
|
+
const firstBlock = await fetchBlock(1n);
|
|
38
|
+
const timestampsBeforeFirstBlock = timestamps.filter((timestamp) => timestamp <= firstBlock.timestamp);
|
|
39
|
+
if (timestamps.length === timestampsBeforeFirstBlock.length) {
|
|
40
|
+
// Note: this is a small check to avoid an extra RPC call
|
|
41
|
+
return buildResultForOneBlockOnly(timestamps, firstBlock);
|
|
42
|
+
}
|
|
43
|
+
const currentBlock = await fetchBlock();
|
|
44
|
+
const timestampsAfterCurrentBlock = timestamps.filter((timestamp) => timestamp >= currentBlock.timestamp);
|
|
45
|
+
const timestampsToCalculate = timestamps.filter((timestamp) => firstBlock.timestamp < timestamp && timestamp < currentBlock.timestamp);
|
|
46
|
+
const calculated = await findBlocks({
|
|
47
|
+
fromBlock: firstBlock,
|
|
48
|
+
toBlock: currentBlock,
|
|
49
|
+
timestamps: timestampsToCalculate,
|
|
50
|
+
fetchBlock,
|
|
51
|
+
});
|
|
52
|
+
return {
|
|
53
|
+
...calculated,
|
|
54
|
+
...buildResultForOneBlockOnly(timestampsBeforeFirstBlock, firstBlock),
|
|
55
|
+
...buildResultForOneBlockOnly(timestampsAfterCurrentBlock, currentBlock),
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
exports.RPCBlockSource = RPCBlockSource;
|
|
60
|
+
async function findBlocks({ fromBlock, toBlock, timestamps, fetchBlock, }) {
|
|
61
|
+
if (timestamps.length === 0) {
|
|
62
|
+
return {};
|
|
63
|
+
}
|
|
64
|
+
else if (timestamps.length === 1) {
|
|
65
|
+
// If we only have one timestamp, then we'll find it directly
|
|
66
|
+
const block = await findClosestBlockToTimestamp({ fromBlock, toBlock, timestamp: timestamps[0], fetchBlock });
|
|
67
|
+
return { [timestamps[0]]: block };
|
|
68
|
+
}
|
|
69
|
+
else if (fromBlock.block + 1n === toBlock.block) {
|
|
70
|
+
// If we got to this place, then we have found two consecutive blocks that surround more than one timestamp. We will simply return the closest
|
|
71
|
+
// block for each timestamp then
|
|
72
|
+
return Object.fromEntries(timestamps.map((timestamp) => [timestamp, (0, utils_2.closestBlock)(fromBlock, toBlock, timestamp)]));
|
|
73
|
+
}
|
|
74
|
+
// We know that we have more than one timestamp, then we'll try to find a block in between them
|
|
75
|
+
const [firstTimestamp, lastTimestamp] = [timestamps[0], timestamps[timestamps.length - 1]]; // Remember we assume the array is sorted
|
|
76
|
+
const midTimestamp = Math.floor((firstTimestamp + lastTimestamp) / 2);
|
|
77
|
+
const midBlockNumber = nextMidBlock(fromBlock, toBlock, midTimestamp);
|
|
78
|
+
const midBlock = await fetchBlock(midBlockNumber);
|
|
79
|
+
const timestampsBefore = timestamps.filter((timestamp) => timestamp < midBlock.timestamp);
|
|
80
|
+
const timestampsAt = timestamps.filter((timestamp) => timestamp === midBlock.timestamp);
|
|
81
|
+
const timestampsAfter = timestamps.filter((timestamp) => timestamp > midBlock.timestamp);
|
|
82
|
+
const [resultsBefore, resultsAfter] = await Promise.all([
|
|
83
|
+
findBlocks({
|
|
84
|
+
fromBlock,
|
|
85
|
+
toBlock: midBlock,
|
|
86
|
+
timestamps: timestampsBefore,
|
|
87
|
+
fetchBlock,
|
|
88
|
+
}),
|
|
89
|
+
findBlocks({
|
|
90
|
+
fromBlock: midBlock,
|
|
91
|
+
toBlock,
|
|
92
|
+
timestamps: timestampsAfter,
|
|
93
|
+
fetchBlock,
|
|
94
|
+
}),
|
|
95
|
+
]);
|
|
96
|
+
return {
|
|
97
|
+
...resultsBefore,
|
|
98
|
+
...buildResultForOneBlockOnly(timestampsAt, midBlock),
|
|
99
|
+
...resultsAfter,
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
async function findClosestBlockToTimestamp({ fromBlock, toBlock, timestamp, fetchBlock, }) {
|
|
103
|
+
while (toBlock.block > fromBlock.block + 1n) {
|
|
104
|
+
const next = nextMidBlock(fromBlock, toBlock, timestamp);
|
|
105
|
+
const block = await fetchBlock(next);
|
|
106
|
+
if (block.timestamp === timestamp) {
|
|
107
|
+
return block;
|
|
108
|
+
}
|
|
109
|
+
else if (block.timestamp > timestamp) {
|
|
110
|
+
toBlock = block;
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
fromBlock = block;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
return (0, utils_2.closestBlock)(fromBlock, toBlock, timestamp);
|
|
117
|
+
}
|
|
118
|
+
// Instead of doing an ordinary binary search, we will try to do something smarter. Blockchains tend to produce blocks at a certain frequency so, if we have two
|
|
119
|
+
// blocks and their timestamps, we will assume a constant frequency and attempt to find the closest block based on it. Now, the thing is that this is not always true,
|
|
120
|
+
// the block frequency might fluctuate. So we will calculate the following block by calculating the avg between the estimated block (based on the frequency), and
|
|
121
|
+
// the "mid" block (per the regular binary search algorithm).
|
|
122
|
+
function nextMidBlock(fromBlock, toBlock, timestamp) {
|
|
123
|
+
// The "mid" block (per the regular binary search algorithm)
|
|
124
|
+
const mid = (fromBlock.block + toBlock.block) / 2n;
|
|
125
|
+
// The estimated block, based on assumed constant frequency
|
|
126
|
+
const estimatedFrequency = Number(toBlock.block - fromBlock.block) / (toBlock.timestamp - fromBlock.timestamp);
|
|
127
|
+
const estimatedBlock = fromBlock.block + BigInt(Math.floor((timestamp - fromBlock.timestamp) * estimatedFrequency));
|
|
128
|
+
// The average between the two ("mid" block and estimated block). After a few tests we realized that this method often produced the least amount of RPC calls
|
|
129
|
+
const next = (mid + estimatedBlock) / 2n;
|
|
130
|
+
// Since we always round down, it could happen that we end up setting the "from block" as next. We'll check if that is the case to avoid doing so
|
|
131
|
+
return maxBigInt(fromBlock.block + 1n, next);
|
|
132
|
+
}
|
|
133
|
+
function buildResultForOneBlockOnly(timestamps, block) {
|
|
134
|
+
return Object.fromEntries(timestamps.map((timestamp) => [timestamp, block]));
|
|
135
|
+
}
|
|
136
|
+
function maxBigInt(a, b) {
|
|
137
|
+
return a > b ? a : b;
|
|
138
|
+
}
|
|
139
|
+
//# sourceMappingURL=rpc-block-source.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rpc-block-source.js","sourceRoot":"","sources":["../../../../src/services/blocks/block-sources/rpc-block-source.ts"],"names":[],"mappings":";;;AAGA,yCAA6C;AAE7C,mCAAuC;AAEvC,MAAa,cAAc;IACzB,YAA6B,eAAiC;QAAjC,oBAAe,GAAf,eAAe,CAAkB;IAAG,CAAC;IAElE,eAAe;QACb,OAAO,IAAI,CAAC,eAAe,CAAC,eAAe,EAAE,CAAC;IAChD,CAAC;IAED,KAAK,CAAC,4BAA4B,CAAC,EAAE,UAAU,EAAgC;QAC7E,MAAM,iBAAiB,GAAG,IAAA,oBAAY,EAAC,UAAU,EAAE,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,SAAS,CAAC,CAAC;QACjF,MAAM,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,EAAE,EAAE;YACrF,MAAM,iBAAiB,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YAC1D,OAAO,CAAC,OAAuB,EAAE,MAAM,IAAI,CAAC,mCAAmC,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,iBAAiB,CAAC,CAAC,CAAC;QACvH,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC,WAAW,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC;IACzD,CAAC;IAED,sJAAsJ;IACtJ,wJAAwJ;IACxJ,mGAAmG;IAC3F,KAAK,CAAC,mCAAmC,CAAC,OAAgB,EAAE,UAAuB;QACzF,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;QAErE,gFAAgF;QAChF,MAAM,KAAK,GAAkC,IAAI,GAAG,EAAE,CAAC;QACvD,MAAM,UAAU,GAAG,KAAK,EAAE,KAAmB,EAAE,EAAE;YAC/C,IAAI,MAAM,GAA4B,KAAK,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;YAC9D,IAAI,CAAC,MAAM,EAAE,CAAC;gBACZ,MAAM,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,MAAM,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;gBACtI,KAAK,CAAC,GAAG,CAAC,MAAO,CAAC,KAAK,EAAE,MAAO,CAAC,CAAC;YACpC,CAAC;YACD,OAAO,MAAO,CAAC;QACjB,CAAC,CAAC;QAEF,6GAA6G;QAC7G,MAAM,UAAU,GAAG,MAAM,UAAU,CAAC,EAAE,CAAC,CAAC;QACxC,MAAM,0BAA0B,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;QACvG,IAAI,UAAU,CAAC,MAAM,KAAK,0BAA0B,CAAC,MAAM,EAAE,CAAC;YAC5D,yDAAyD;YACzD,OAAO,0BAA0B,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAC5D,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,UAAU,EAAE,CAAC;QACxC,MAAM,2BAA2B,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,IAAI,YAAY,CAAC,SAAS,CAAC,CAAC;QAE1G,MAAM,qBAAqB,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,UAAU,CAAC,SAAS,GAAG,SAAS,IAAI,SAAS,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;QACvI,MAAM,UAAU,GAAG,MAAM,UAAU,CAAC;YAClC,SAAS,EAAE,UAAU;YACrB,OAAO,EAAE,YAAY;YACrB,UAAU,EAAE,qBAAqB;YACjC,UAAU;SACX,CAAC,CAAC;QAEH,OAAO;YACL,GAAG,UAAU;YACb,GAAG,0BAA0B,CAAC,0BAA0B,EAAE,UAAU,CAAC;YACrE,GAAG,0BAA0B,CAAC,2BAA2B,EAAE,YAAY,CAAC;SACzE,CAAC;IACJ,CAAC;CACF;AA1DD,wCA0DC;AAED,KAAK,UAAU,UAAU,CAAC,EACxB,SAAS,EACT,OAAO,EACP,UAAU,EACV,UAAU,GAMX;IACC,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,OAAO,EAAE,CAAC;IACZ,CAAC;SAAM,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACnC,6DAA6D;QAC7D,MAAM,KAAK,GAAG,MAAM,2BAA2B,CAAC,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC;QAC9G,OAAO,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC;IACpC,CAAC;SAAM,IAAI,SAAS,CAAC,KAAK,GAAG,EAAE,KAAK,OAAO,CAAC,KAAK,EAAE,CAAC;QAClD,8IAA8I;QAC9I,gCAAgC;QAChC,OAAO,MAAM,CAAC,WAAW,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,SAAS,EAAE,IAAA,oBAAY,EAAC,SAAS,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IACrH,CAAC;IAED,+FAA+F;IAC/F,MAAM,CAAC,cAAc,EAAE,aAAa,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,yCAAyC;IACrI,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,cAAc,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;IACtE,MAAM,cAAc,GAAG,YAAY,CAAC,SAAS,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;IACtE,MAAM,QAAQ,GAAG,MAAM,UAAU,CAAC,cAAc,CAAC,CAAC;IAElD,MAAM,gBAAgB,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;IAC1F,MAAM,YAAY,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,KAAK,QAAQ,CAAC,SAAS,CAAC,CAAC;IACxF,MAAM,eAAe,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;IAEzF,MAAM,CAAC,aAAa,EAAE,YAAY,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACtD,UAAU,CAAC;YACT,SAAS;YACT,OAAO,EAAE,QAAQ;YACjB,UAAU,EAAE,gBAAgB;YAC5B,UAAU;SACX,CAAC;QACF,UAAU,CAAC;YACT,SAAS,EAAE,QAAQ;YACnB,OAAO;YACP,UAAU,EAAE,eAAe;YAC3B,UAAU;SACX,CAAC;KACH,CAAC,CAAC;IAEH,OAAO;QACL,GAAG,aAAa;QAChB,GAAG,0BAA0B,CAAC,YAAY,EAAE,QAAQ,CAAC;QACrD,GAAG,YAAY;KAChB,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,2BAA2B,CAAC,EACzC,SAAS,EACT,OAAO,EACP,SAAS,EACT,UAAU,GAMX;IACC,OAAO,OAAO,CAAC,KAAK,GAAG,SAAS,CAAC,KAAK,GAAG,EAAE,EAAE,CAAC;QAC5C,MAAM,IAAI,GAAG,YAAY,CAAC,SAAS,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC;QACzD,MAAM,KAAK,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,CAAC;QAErC,IAAI,KAAK,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YAClC,OAAO,KAAK,CAAC;QACf,CAAC;aAAM,IAAI,KAAK,CAAC,SAAS,GAAG,SAAS,EAAE,CAAC;YACvC,OAAO,GAAG,KAAK,CAAC;QAClB,CAAC;aAAM,CAAC;YACN,SAAS,GAAG,KAAK,CAAC;QACpB,CAAC;IACH,CAAC;IAED,OAAO,IAAA,oBAAY,EAAC,SAAS,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC;AACrD,CAAC;AAED,gKAAgK;AAChK,sKAAsK;AACtK,iKAAiK;AACjK,6DAA6D;AAC7D,SAAS,YAAY,CAAC,SAAsB,EAAE,OAAoB,EAAE,SAAiB;IACnF,4DAA4D;IAC5D,MAAM,GAAG,GAAG,CAAC,SAAS,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;IAEnD,2DAA2D;IAC3D,MAAM,kBAAkB,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;IAC/G,MAAM,cAAc,GAAG,SAAS,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC,GAAG,kBAAkB,CAAC,CAAC,CAAC;IAEpH,6JAA6J;IAC7J,MAAM,IAAI,GAAG,CAAC,GAAG,GAAG,cAAc,CAAC,GAAG,EAAE,CAAC;IAEzC,iJAAiJ;IACjJ,OAAO,SAAS,CAAC,SAAS,CAAC,KAAK,GAAG,EAAE,EAAE,IAAI,CAAC,CAAC;AAC/C,CAAC;AAED,SAAS,0BAA0B,CAAC,UAAuB,EAAE,KAAkB;IAC7E,OAAO,MAAM,CAAC,WAAW,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;AAC/E,CAAC;AAED,SAAS,SAAS,CAAC,CAAS,EAAE,CAAS;IACrC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACvB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.closestBlock = void 0;
|
|
4
|
+
function closestBlock(blockA, blockB, timestamp) {
|
|
5
|
+
const diffA = Math.abs(blockA.timestamp - timestamp);
|
|
6
|
+
const diffB = Math.abs(blockB.timestamp - timestamp);
|
|
7
|
+
return diffA <= diffB ? blockA : blockB;
|
|
8
|
+
}
|
|
9
|
+
exports.closestBlock = closestBlock;
|
|
10
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/services/blocks/block-sources/utils.ts"],"names":[],"mappings":";;;AAGA,SAAgB,YAAY,CAAC,MAAmB,EAAE,MAAmB,EAAE,SAAoB;IACzF,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,SAAS,GAAG,SAAS,CAAC,CAAC;IACrD,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,SAAS,GAAG,SAAS,CAAC,CAAC;IACrD,OAAO,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;AAC1C,CAAC;AAJD,oCAIC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { IBlocksService, IBlocksSource, BlockResult, BlockInput } from './types';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/blocks/index.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { BlockNumber } from 'viem';
|
|
2
|
+
import { ChainId, TimeString, Timestamp } from '../../types';
|
|
3
|
+
export type BlockResult = {
|
|
4
|
+
block: BlockNumber;
|
|
5
|
+
timestamp: Timestamp;
|
|
6
|
+
};
|
|
7
|
+
export type IBlocksService = {
|
|
8
|
+
supportedChains(): ChainId[];
|
|
9
|
+
getBlockClosestToTimestampInChain(_: {
|
|
10
|
+
chainId: ChainId;
|
|
11
|
+
timestamp: Timestamp;
|
|
12
|
+
config?: {
|
|
13
|
+
timeout?: TimeString;
|
|
14
|
+
};
|
|
15
|
+
}): Promise<BlockResult>;
|
|
16
|
+
getBlocksClosestToTimestampsInChain(_: {
|
|
17
|
+
chainId: ChainId;
|
|
18
|
+
timestamps: Timestamp[];
|
|
19
|
+
config?: {
|
|
20
|
+
timeout?: TimeString;
|
|
21
|
+
};
|
|
22
|
+
}): Promise<Record<Timestamp, BlockResult>>;
|
|
23
|
+
getBlocksClosestToTimestamps(_: {
|
|
24
|
+
timestamps: BlockInput[];
|
|
25
|
+
config?: {
|
|
26
|
+
timeout?: TimeString;
|
|
27
|
+
};
|
|
28
|
+
}): Promise<Record<ChainId, Record<Timestamp, BlockResult>>>;
|
|
29
|
+
};
|
|
30
|
+
export type IBlocksSource = {
|
|
31
|
+
supportedChains(): ChainId[];
|
|
32
|
+
getBlocksClosestToTimestamps(_: {
|
|
33
|
+
timestamps: BlockInput[];
|
|
34
|
+
config?: {
|
|
35
|
+
timeout?: TimeString;
|
|
36
|
+
};
|
|
37
|
+
}): Promise<Record<ChainId, Record<Timestamp, BlockResult>>>;
|
|
38
|
+
};
|
|
39
|
+
export type BlockInput = {
|
|
40
|
+
chainId: ChainId;
|
|
41
|
+
timestamp: Timestamp;
|
|
42
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/services/blocks/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { IFetchService, RequestInit } from './types';
|
|
2
|
+
export declare class FetchService implements IFetchService {
|
|
3
|
+
private readonly realFetch?;
|
|
4
|
+
constructor(realFetch?: typeof fetch | undefined);
|
|
5
|
+
fetch(url: RequestInfo | URL, init?: RequestInit): Promise<Response>;
|
|
6
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.FetchService = void 0;
|
|
7
|
+
const ms_1 = __importDefault(require("ms"));
|
|
8
|
+
const cross_fetch_1 = __importDefault(require("cross-fetch"));
|
|
9
|
+
const timeouts_1 = require("../../shared/timeouts");
|
|
10
|
+
const wait_1 = require("../../shared/wait");
|
|
11
|
+
class FetchService {
|
|
12
|
+
constructor(realFetch) {
|
|
13
|
+
this.realFetch = realFetch;
|
|
14
|
+
}
|
|
15
|
+
async fetch(url, init) {
|
|
16
|
+
const { retries = 0, retryDelay = 1000, retryWhenTimeouted = true, timeout: timeoutText = '5m', ...restInit } = init ?? {};
|
|
17
|
+
const errors = [];
|
|
18
|
+
for (let attempt = 0; attempt <= retries; attempt++) {
|
|
19
|
+
const controller = new AbortController();
|
|
20
|
+
let timeouted = false;
|
|
21
|
+
const timeoutId = setTimeout(() => {
|
|
22
|
+
timeouted = true;
|
|
23
|
+
controller.abort();
|
|
24
|
+
}, (0, ms_1.default)(timeoutText));
|
|
25
|
+
try {
|
|
26
|
+
const response = await (this.realFetch ?? cross_fetch_1.default)(url, {
|
|
27
|
+
...restInit,
|
|
28
|
+
signal: controller.signal,
|
|
29
|
+
});
|
|
30
|
+
return response;
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
if (timeouted) {
|
|
34
|
+
const timeoutError = new timeouts_1.TimeoutError(`Request to ${url}`, timeoutText);
|
|
35
|
+
errors.push(timeoutError);
|
|
36
|
+
if (!retryWhenTimeouted || attempt === retries) {
|
|
37
|
+
throw new AggregateError(errors);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
errors.push(error);
|
|
42
|
+
if (attempt === retries) {
|
|
43
|
+
throw new AggregateError(errors);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
// Calculate delay with exponential backoff: delay * 2^attempt
|
|
47
|
+
const backoffDelay = retryDelay * Math.pow(2, attempt + 1);
|
|
48
|
+
await (0, wait_1.wait)(backoffDelay);
|
|
49
|
+
}
|
|
50
|
+
finally {
|
|
51
|
+
clearTimeout(timeoutId);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
throw new AggregateError(errors, 'Multiple fetch attempts failed');
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
exports.FetchService = FetchService;
|
|
58
|
+
//# sourceMappingURL=fetch-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetch-service.js","sourceRoot":"","sources":["../../../src/services/fetch/fetch-service.ts"],"names":[],"mappings":";;;;;;AAAA,4CAAoB;AACpB,8DAAqC;AAErC,+CAAgD;AAChD,uCAAoC;AAEpC,MAAa,YAAY;IACvB,YAA6B,SAAiB;QAAjB,cAAS,GAAT,SAAS,CAAQ;IAAG,CAAC;IAElD,KAAK,CAAC,KAAK,CAAC,GAAsB,EAAE,IAAkB;QACpD,MAAM,EAAE,OAAO,GAAG,CAAC,EAAE,UAAU,GAAG,IAAI,EAAE,kBAAkB,GAAG,IAAI,EAAE,OAAO,EAAE,WAAW,GAAG,IAAI,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,IAAI,EAAE,CAAC;QAE3H,MAAM,MAAM,GAAY,EAAE,CAAC;QAE3B,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,OAAO,EAAE,OAAO,EAAE,EAAE,CAAC;YACpD,MAAM,UAAU,GAAG,IAAI,eAAe,EAAE,CAAC;YACzC,IAAI,SAAS,GAAG,KAAK,CAAC;YACtB,MAAM,SAAS,GAAG,UAAU,CAAC,GAAG,EAAE;gBAChC,SAAS,GAAG,IAAI,CAAC;gBACjB,UAAU,CAAC,KAAK,EAAE,CAAC;YACrB,CAAC,EAAE,IAAA,YAAE,EAAC,WAAW,CAAC,CAAC,CAAC;YAEpB,IAAI,CAAC;gBACH,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,IAAI,qBAAU,CAAC,CAAC,GAAG,EAAE;oBACzD,GAAG,QAAQ;oBACX,MAAM,EAAE,UAAU,CAAC,MAAqB;iBACzC,CAAC,CAAC;gBACH,OAAO,QAAQ,CAAC;YAClB,CAAC;YAAC,OAAO,KAAU,EAAE,CAAC;gBACpB,IAAI,SAAS,EAAE,CAAC;oBACd,MAAM,YAAY,GAAG,IAAI,uBAAY,CAAC,cAAc,GAAG,EAAE,EAAE,WAAW,CAAC,CAAC;oBACxE,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;oBAC1B,IAAI,CAAC,kBAAkB,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;wBAC/C,MAAM,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;oBACnC,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBACnB,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;wBACxB,MAAM,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;oBACnC,CAAC;gBACH,CAAC;gBAED,8DAA8D;gBAC9D,MAAM,YAAY,GAAG,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,GAAG,CAAC,CAAC,CAAC;gBAC3D,MAAM,IAAA,WAAI,EAAC,YAAY,CAAC,CAAC;YAC3B,CAAC;oBAAS,CAAC;gBACT,YAAY,CAAC,SAAS,CAAC,CAAC;YAC1B,CAAC;QACH,CAAC;QAED,MAAM,IAAI,cAAc,CAAC,MAAM,EAAE,gCAAgC,CAAC,CAAC;IACrE,CAAC;CACF;AA9CD,oCA8CC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { RequestInit, IFetchService } from './types';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/fetch/index.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { TimeString } from '../../types';
|
|
2
|
+
export type RequestInit = globalThis.RequestInit & {
|
|
3
|
+
timeout?: TimeString;
|
|
4
|
+
retries?: number;
|
|
5
|
+
retryDelay?: number;
|
|
6
|
+
retryWhenTimeouted?: boolean;
|
|
7
|
+
};
|
|
8
|
+
export type IFetchService = {
|
|
9
|
+
fetch(input: RequestInfo | URL, init?: RequestInit): Promise<Response>;
|
|
10
|
+
};
|
|
11
|
+
export type Fetch = typeof global.fetch;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/services/fetch/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { ChainId, FieldsRequirements, TimeString } from '../../../types';
|
|
2
|
+
import { GasPriceResult, IGasPriceSource, MergeGasValues } from '../types';
|
|
3
|
+
import { ILogsService } from '../../logs';
|
|
4
|
+
export type GasPriceAggregationMethod = 'median' | 'min' | 'max';
|
|
5
|
+
export declare class AggregatorGasPriceSource<Sources extends IGasPriceSource<object>[] | []> implements IGasPriceSource<MergeGasValues<Sources>> {
|
|
6
|
+
private readonly sources;
|
|
7
|
+
private readonly method;
|
|
8
|
+
private readonly logger;
|
|
9
|
+
constructor(logsService: ILogsService, sources: Sources, method: GasPriceAggregationMethod);
|
|
10
|
+
supportedSpeeds(): Record<ChainId, import("../../../types").SupportInChain<MergeGasValues<Sources>>>;
|
|
11
|
+
getGasPrice<Requirements extends FieldsRequirements<MergeGasValues<Sources>>>({ chainId, config, }: {
|
|
12
|
+
chainId: ChainId;
|
|
13
|
+
config?: {
|
|
14
|
+
fields?: Requirements;
|
|
15
|
+
timeout?: TimeString;
|
|
16
|
+
};
|
|
17
|
+
}): Promise<GasPriceResult<MergeGasValues<Sources>, Requirements>>;
|
|
18
|
+
private aggregate;
|
|
19
|
+
}
|