@0xkoaj/sdk 0.0.1-beta.1 → 0.0.1-beta.3
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 +302 -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,40 @@
|
|
|
1
|
+
import { ChainId, TimeString, Timestamp, TokenAddress } from '../../../types';
|
|
2
|
+
import { IFetchService } from '../../fetch/types';
|
|
3
|
+
import { PriceResult, IPriceSource, PriceInput } from '../types';
|
|
4
|
+
export declare class OdosPriceSource implements IPriceSource {
|
|
5
|
+
private readonly fetch;
|
|
6
|
+
constructor(fetch: IFetchService);
|
|
7
|
+
supportedQueries(): any;
|
|
8
|
+
getCurrentPrices({ tokens, config, }: {
|
|
9
|
+
tokens: PriceInput[];
|
|
10
|
+
config: {
|
|
11
|
+
timeout?: TimeString;
|
|
12
|
+
} | undefined;
|
|
13
|
+
}): Promise<Record<ChainId, Record<TokenAddress, PriceResult>>>;
|
|
14
|
+
getHistoricalPrices(_: {
|
|
15
|
+
tokens: {
|
|
16
|
+
chainId: ChainId;
|
|
17
|
+
token: TokenAddress;
|
|
18
|
+
timestamp: Timestamp;
|
|
19
|
+
}[];
|
|
20
|
+
searchWidth: TimeString | undefined;
|
|
21
|
+
config: {
|
|
22
|
+
timeout?: TimeString;
|
|
23
|
+
} | undefined;
|
|
24
|
+
}): Promise<Record<ChainId, Record<TokenAddress, Record<Timestamp, PriceResult>>>>;
|
|
25
|
+
getChart(_: {
|
|
26
|
+
tokens: PriceInput[];
|
|
27
|
+
span: number;
|
|
28
|
+
period: TimeString;
|
|
29
|
+
bound: {
|
|
30
|
+
from: Timestamp;
|
|
31
|
+
} | {
|
|
32
|
+
upTo: Timestamp | 'now';
|
|
33
|
+
};
|
|
34
|
+
searchWidth?: TimeString;
|
|
35
|
+
config: {
|
|
36
|
+
timeout?: TimeString;
|
|
37
|
+
} | undefined;
|
|
38
|
+
}): Promise<Record<ChainId, Record<TokenAddress, PriceResult[]>>>;
|
|
39
|
+
private getCurrentPricesInChain;
|
|
40
|
+
}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.OdosPriceSource = void 0;
|
|
4
|
+
const _chains_1 = require("../../../chains");
|
|
5
|
+
const timeouts_1 = require("../../../shared/timeouts");
|
|
6
|
+
const utils_1 = require("../../../shared/utils");
|
|
7
|
+
const constants_1 = require("../../../shared/constants");
|
|
8
|
+
const utils_2 = require("./utils");
|
|
9
|
+
const SUPPORTED_CHAINS = [_chains_1.Chains.ETHEREUM, _chains_1.Chains.POLYGON, _chains_1.Chains.OPTIMISM, _chains_1.Chains.AVALANCHE, _chains_1.Chains.ARBITRUM, _chains_1.Chains.BNB_CHAIN, _chains_1.Chains.BASE];
|
|
10
|
+
class OdosPriceSource {
|
|
11
|
+
constructor(fetch) {
|
|
12
|
+
this.fetch = fetch;
|
|
13
|
+
}
|
|
14
|
+
supportedQueries() {
|
|
15
|
+
const support = {
|
|
16
|
+
getCurrentPrices: true,
|
|
17
|
+
getHistoricalPrices: false,
|
|
18
|
+
getChart: false,
|
|
19
|
+
};
|
|
20
|
+
const entries = SUPPORTED_CHAINS.map(({ chainId }) => chainId).map((chainId) => [chainId, support]);
|
|
21
|
+
return Object.fromEntries(entries);
|
|
22
|
+
}
|
|
23
|
+
async getCurrentPrices({ tokens, config, }) {
|
|
24
|
+
const groupedByChain = (0, utils_1.groupByChain)(tokens, ({ token }) => token);
|
|
25
|
+
const reducedTimeout = (0, timeouts_1.reduceTimeout)(config?.timeout, '100');
|
|
26
|
+
const promises = Object.entries(groupedByChain).map(async ([chainId, tokens]) => [
|
|
27
|
+
Number(chainId),
|
|
28
|
+
await (0, timeouts_1.timeoutPromise)(this.getCurrentPricesInChain(chainId, tokens, reducedTimeout), reducedTimeout),
|
|
29
|
+
]);
|
|
30
|
+
return Object.fromEntries(await (0, utils_1.filterRejectedResults)(promises));
|
|
31
|
+
}
|
|
32
|
+
getHistoricalPrices(_) {
|
|
33
|
+
return Promise.reject(new Error('Operation not supported'));
|
|
34
|
+
}
|
|
35
|
+
async getChart(_) {
|
|
36
|
+
return Promise.reject(new Error('Operation not supported'));
|
|
37
|
+
}
|
|
38
|
+
async getCurrentPricesInChain(chainId, addresses, timeout) {
|
|
39
|
+
const params = addresses.map((address) => `token_addresses=${mapToken(address)}`).join('&');
|
|
40
|
+
const url = `https://api.odos.xyz/pricing/token/${chainId}?${params}`;
|
|
41
|
+
const response = await this.fetch.fetch(url, { timeout });
|
|
42
|
+
const body = await response.json();
|
|
43
|
+
const lowercased = toLowerCase(body.tokenPrices);
|
|
44
|
+
return Object.fromEntries(addresses.map((address) => [address, { price: lowercased[mapToken(address.toLowerCase())], closestTimestamp: (0, utils_2.nowInSeconds)() }]));
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
exports.OdosPriceSource = OdosPriceSource;
|
|
48
|
+
function mapToken(address) {
|
|
49
|
+
return (0, utils_1.isSameAddress)(address, constants_1.Addresses.NATIVE_TOKEN) ? constants_1.Addresses.ZERO_ADDRESS : address;
|
|
50
|
+
}
|
|
51
|
+
function toLowerCase(prices) {
|
|
52
|
+
return Object.fromEntries(Object.entries(prices).map(([token, price]) => [token.toLowerCase(), price]));
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=odos-price-source.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"odos-price-source.js","sourceRoot":"","sources":["../../../../src/services/prices/price-sources/odos-price-source.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { ChainId, TimeString, Timestamp, TokenAddress } from '../../../types';
|
|
2
|
+
import { PriceResult, IPriceSource, PricesQueriesSupport, PriceInput } from '../types';
|
|
3
|
+
export declare class PrioritizedPriceSource implements IPriceSource {
|
|
4
|
+
private readonly sources;
|
|
5
|
+
constructor(sources: IPriceSource[]);
|
|
6
|
+
supportedQueries(): Record<ChainId, PricesQueriesSupport>;
|
|
7
|
+
getCurrentPrices({ tokens, config }: {
|
|
8
|
+
tokens: PriceInput[];
|
|
9
|
+
config?: {
|
|
10
|
+
timeout?: TimeString;
|
|
11
|
+
};
|
|
12
|
+
}): Promise<Record<ChainId, Record<string, PriceResult>>>;
|
|
13
|
+
getHistoricalPrices({ tokens, searchWidth, config, }: {
|
|
14
|
+
tokens: {
|
|
15
|
+
chainId: ChainId;
|
|
16
|
+
token: TokenAddress;
|
|
17
|
+
timestamp: Timestamp;
|
|
18
|
+
}[];
|
|
19
|
+
searchWidth: TimeString | undefined;
|
|
20
|
+
config: {
|
|
21
|
+
timeout?: TimeString;
|
|
22
|
+
} | undefined;
|
|
23
|
+
}): Promise<Record<ChainId, Record<TokenAddress, Record<Timestamp, PriceResult>>>>;
|
|
24
|
+
getChart({ tokens, span, period, bound, searchWidth, config, }: {
|
|
25
|
+
tokens: PriceInput[];
|
|
26
|
+
span: number;
|
|
27
|
+
period: TimeString;
|
|
28
|
+
bound: {
|
|
29
|
+
from: Timestamp;
|
|
30
|
+
} | {
|
|
31
|
+
upTo: Timestamp | 'now';
|
|
32
|
+
};
|
|
33
|
+
searchWidth?: TimeString;
|
|
34
|
+
config: {
|
|
35
|
+
timeout?: TimeString;
|
|
36
|
+
} | undefined;
|
|
37
|
+
}): Promise<Record<ChainId, Record<TokenAddress, PriceResult[]>>>;
|
|
38
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PrioritizedPriceSource = void 0;
|
|
4
|
+
const timeouts_1 = require("../../../shared/timeouts");
|
|
5
|
+
const utils_1 = require("./utils");
|
|
6
|
+
const utils_2 = require("../../../shared/utils");
|
|
7
|
+
// This source will take a list of sources, sorted by priority, and combine the results of each
|
|
8
|
+
// one to try to fulfill the request. The response will prioritize the sources results based on the prioritized
|
|
9
|
+
class PrioritizedPriceSource {
|
|
10
|
+
constructor(sources) {
|
|
11
|
+
this.sources = sources;
|
|
12
|
+
if (sources.length === 0)
|
|
13
|
+
throw new Error('No sources were specified');
|
|
14
|
+
}
|
|
15
|
+
supportedQueries() {
|
|
16
|
+
return (0, utils_1.combineSupport)(this.sources);
|
|
17
|
+
}
|
|
18
|
+
async getCurrentPrices({ tokens, config }) {
|
|
19
|
+
return executePrioritized({
|
|
20
|
+
allSources: this.sources,
|
|
21
|
+
fullRequest: tokens,
|
|
22
|
+
query: 'getCurrentPrices',
|
|
23
|
+
getResult: (source, filteredRequest, sourceTimeout) => source.getCurrentPrices({
|
|
24
|
+
tokens: filteredRequest,
|
|
25
|
+
config: { timeout: sourceTimeout },
|
|
26
|
+
}),
|
|
27
|
+
timeout: config?.timeout,
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
getHistoricalPrices({ tokens, searchWidth, config, }) {
|
|
31
|
+
return executePrioritized({
|
|
32
|
+
allSources: this.sources,
|
|
33
|
+
fullRequest: tokens,
|
|
34
|
+
query: 'getHistoricalPrices',
|
|
35
|
+
getResult: (source, filteredRequest, sourceTimeout) => source.getHistoricalPrices({
|
|
36
|
+
tokens: filteredRequest,
|
|
37
|
+
searchWidth,
|
|
38
|
+
config: { timeout: sourceTimeout },
|
|
39
|
+
}),
|
|
40
|
+
timeout: config?.timeout,
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
async getChart({ tokens, span, period, bound, searchWidth, config, }) {
|
|
44
|
+
return executePrioritized({
|
|
45
|
+
allSources: this.sources,
|
|
46
|
+
fullRequest: tokens,
|
|
47
|
+
query: 'getChart',
|
|
48
|
+
getResult: (source, filteredRequest, sourceTimeout) => source.getChart({
|
|
49
|
+
tokens: filteredRequest,
|
|
50
|
+
span,
|
|
51
|
+
period,
|
|
52
|
+
bound,
|
|
53
|
+
searchWidth,
|
|
54
|
+
config: { timeout: sourceTimeout },
|
|
55
|
+
}),
|
|
56
|
+
timeout: config?.timeout,
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
exports.PrioritizedPriceSource = PrioritizedPriceSource;
|
|
61
|
+
async function executePrioritized({ allSources, fullRequest, query, getResult, timeout, }) {
|
|
62
|
+
const sourcesInChains = (0, utils_1.getSourcesThatSupportRequestOrFail)(fullRequest, allSources, query);
|
|
63
|
+
const addressesPerChain = (0, utils_2.groupByChain)(fullRequest, ({ token }) => token);
|
|
64
|
+
const reducedTimeout = (0, timeouts_1.reduceTimeout)(timeout, '100');
|
|
65
|
+
return new Promise(async (resolve) => {
|
|
66
|
+
const result = {};
|
|
67
|
+
const fetchPromises = sourcesInChains.map((source) => (0, timeouts_1.timeoutPromise)(getResult(source, (0, utils_1.filterRequestForSource)(fullRequest, query, source), reducedTimeout), reducedTimeout, {
|
|
68
|
+
description: 'Timeouted while executing a prioritized price query',
|
|
69
|
+
}).catch(() => ({})) // Handle rejection and return empty result
|
|
70
|
+
);
|
|
71
|
+
let i = 0;
|
|
72
|
+
while (!(0, utils_1.doesResponseFulfillRequest)(result, addressesPerChain) && i < fetchPromises.length) {
|
|
73
|
+
const response = await fetchPromises[i];
|
|
74
|
+
(0, utils_1.fillResponseWithNewResult)(result, response);
|
|
75
|
+
i++;
|
|
76
|
+
}
|
|
77
|
+
// Return whatever we could fetch
|
|
78
|
+
resolve(result);
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=prioritized-price-source.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prioritized-price-source.js","sourceRoot":"","sources":["../../../../src/services/prices/price-sources/prioritized-price-source.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ChainId, TokenAddress } from '../../../types';
|
|
2
|
+
import { IPriceSource, PriceInput, PricesQueriesSupport } from '../types';
|
|
3
|
+
export declare function fillResponseWithNewResult<T>(result: Record<ChainId, Record<TokenAddress, T>>, newResult: Record<ChainId, Record<TokenAddress, T>>): void;
|
|
4
|
+
export declare function doesResponseFulfillRequest<T>(result: Record<ChainId, Record<TokenAddress, T>>, request: Record<ChainId, TokenAddress[]>): boolean;
|
|
5
|
+
export declare function filterRequestForSource<T extends {
|
|
6
|
+
chainId: ChainId;
|
|
7
|
+
}>(request: T[], query: keyof PricesQueriesSupport, source: IPriceSource): T[];
|
|
8
|
+
export declare function combineSupport(sources: IPriceSource[]): Record<ChainId, PricesQueriesSupport>;
|
|
9
|
+
export declare function getSourcesThatSupportRequestOrFail<T extends PriceInput>(request: T[], sources: IPriceSource[], query: keyof PricesQueriesSupport): IPriceSource[];
|
|
10
|
+
export declare function nowInSeconds(): number;
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.nowInSeconds = exports.getSourcesThatSupportRequestOrFail = exports.combineSupport = exports.filterRequestForSource = exports.doesResponseFulfillRequest = exports.fillResponseWithNewResult = void 0;
|
|
4
|
+
function fillResponseWithNewResult(result, newResult) {
|
|
5
|
+
for (const chainId in newResult) {
|
|
6
|
+
for (const address in newResult[chainId]) {
|
|
7
|
+
if (!result[chainId]?.[address]) {
|
|
8
|
+
if (!(chainId in result)) {
|
|
9
|
+
result[chainId] = {};
|
|
10
|
+
}
|
|
11
|
+
result[chainId][address] = newResult[chainId][address];
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
exports.fillResponseWithNewResult = fillResponseWithNewResult;
|
|
17
|
+
function doesResponseFulfillRequest(result, request) {
|
|
18
|
+
for (const chainId in request) {
|
|
19
|
+
for (const address of request[chainId]) {
|
|
20
|
+
if (typeof result[chainId]?.[address] === 'undefined') {
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
27
|
+
exports.doesResponseFulfillRequest = doesResponseFulfillRequest;
|
|
28
|
+
function doesSourceSupportQueryInAnyOfTheChains(source, query, chains) {
|
|
29
|
+
const support = source.supportedQueries();
|
|
30
|
+
return chains.some((chainId) => support[chainId]?.[query]);
|
|
31
|
+
}
|
|
32
|
+
function filterRequestForSource(request, query, source) {
|
|
33
|
+
const support = source.supportedQueries();
|
|
34
|
+
return request.filter(({ chainId }) => support[chainId]?.[query]);
|
|
35
|
+
}
|
|
36
|
+
exports.filterRequestForSource = filterRequestForSource;
|
|
37
|
+
function combineSupport(sources) {
|
|
38
|
+
const result = {};
|
|
39
|
+
for (const source of sources) {
|
|
40
|
+
for (const [chainIdString, support] of Object.entries(source.supportedQueries())) {
|
|
41
|
+
const chainId = Number(chainIdString);
|
|
42
|
+
const current = result[chainId] ?? {
|
|
43
|
+
getCurrentPrices: false,
|
|
44
|
+
getHistoricalPrices: false,
|
|
45
|
+
getBulkHistoricalPrices: false,
|
|
46
|
+
getChart: false,
|
|
47
|
+
};
|
|
48
|
+
result[chainId] = {
|
|
49
|
+
getCurrentPrices: current.getCurrentPrices || support.getCurrentPrices,
|
|
50
|
+
getHistoricalPrices: current.getHistoricalPrices || support.getHistoricalPrices,
|
|
51
|
+
getChart: current.getChart || support.getChart,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
return result;
|
|
56
|
+
}
|
|
57
|
+
exports.combineSupport = combineSupport;
|
|
58
|
+
function getSourcesThatSupportRequestOrFail(request, sources, query) {
|
|
59
|
+
const chainsInRequest = [...new Set(request.map(({ chainId }) => chainId))];
|
|
60
|
+
const sourcesInChain = sources.filter((source) => doesSourceSupportQueryInAnyOfTheChains(source, query, chainsInRequest));
|
|
61
|
+
if (sourcesInChain.length === 0)
|
|
62
|
+
throw new Error(`Current price sources can't support all the given chains`);
|
|
63
|
+
return sourcesInChain;
|
|
64
|
+
}
|
|
65
|
+
exports.getSourcesThatSupportRequestOrFail = getSourcesThatSupportRequestOrFail;
|
|
66
|
+
function nowInSeconds() {
|
|
67
|
+
return Math.floor(Date.now() / 1000);
|
|
68
|
+
}
|
|
69
|
+
exports.nowInSeconds = nowInSeconds;
|
|
70
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/services/prices/price-sources/utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { ChainId, TimeString, Timestamp, TokenAddress } from '../../types';
|
|
2
|
+
export type TokenPrice = number;
|
|
3
|
+
export type IPriceService = {
|
|
4
|
+
supportedChains(): ChainId[];
|
|
5
|
+
supportedQueries(): Record<ChainId, PricesQueriesSupport>;
|
|
6
|
+
getCurrentPricesInChain(_: {
|
|
7
|
+
chainId: ChainId;
|
|
8
|
+
tokens: TokenAddress[];
|
|
9
|
+
config?: {
|
|
10
|
+
timeout?: TimeString;
|
|
11
|
+
};
|
|
12
|
+
}): Promise<Record<TokenAddress, PriceResult>>;
|
|
13
|
+
getCurrentPrices(_: {
|
|
14
|
+
tokens: PriceInput[];
|
|
15
|
+
config?: {
|
|
16
|
+
timeout?: TimeString;
|
|
17
|
+
};
|
|
18
|
+
}): Promise<Record<ChainId, Record<TokenAddress, PriceResult>>>;
|
|
19
|
+
getHistoricalPricesInChain(_: {
|
|
20
|
+
chainId: ChainId;
|
|
21
|
+
tokens: TokenAddress[];
|
|
22
|
+
timestamp: Timestamp;
|
|
23
|
+
searchWidth?: TimeString;
|
|
24
|
+
config?: {
|
|
25
|
+
timeout?: TimeString;
|
|
26
|
+
};
|
|
27
|
+
}): Promise<Record<TokenAddress, PriceResult>>;
|
|
28
|
+
getHistoricalPrices(_: {
|
|
29
|
+
tokens: PriceInput[];
|
|
30
|
+
timestamp: Timestamp;
|
|
31
|
+
searchWidth?: TimeString;
|
|
32
|
+
config?: {
|
|
33
|
+
timeout?: TimeString;
|
|
34
|
+
};
|
|
35
|
+
}): Promise<Record<ChainId, Record<TokenAddress, PriceResult>>>;
|
|
36
|
+
getBulkHistoricalPrices(_: {
|
|
37
|
+
tokens: {
|
|
38
|
+
chainId: ChainId;
|
|
39
|
+
token: TokenAddress;
|
|
40
|
+
timestamp: Timestamp;
|
|
41
|
+
}[];
|
|
42
|
+
searchWidth?: TimeString;
|
|
43
|
+
config?: {
|
|
44
|
+
timeout?: TimeString;
|
|
45
|
+
};
|
|
46
|
+
}): Promise<Record<ChainId, Record<TokenAddress, Record<Timestamp, PriceResult>>>>;
|
|
47
|
+
getChart(_: {
|
|
48
|
+
tokens: PriceInput[];
|
|
49
|
+
span: number;
|
|
50
|
+
period: TimeString;
|
|
51
|
+
bound: {
|
|
52
|
+
from: Timestamp;
|
|
53
|
+
} | {
|
|
54
|
+
upTo: Timestamp | 'now';
|
|
55
|
+
};
|
|
56
|
+
searchWidth?: TimeString;
|
|
57
|
+
}): Promise<Record<ChainId, Record<TokenAddress, PriceResult[]>>>;
|
|
58
|
+
};
|
|
59
|
+
export type PricesQueriesSupport = {
|
|
60
|
+
getHistoricalPrices: boolean;
|
|
61
|
+
getCurrentPrices: true;
|
|
62
|
+
getChart: boolean;
|
|
63
|
+
};
|
|
64
|
+
export type PriceResult = {
|
|
65
|
+
price: TokenPrice;
|
|
66
|
+
closestTimestamp: Timestamp;
|
|
67
|
+
};
|
|
68
|
+
export type IPriceSource = {
|
|
69
|
+
supportedQueries(): Record<ChainId, PricesQueriesSupport>;
|
|
70
|
+
getCurrentPrices(_: {
|
|
71
|
+
tokens: PriceInput[];
|
|
72
|
+
config: {
|
|
73
|
+
timeout?: TimeString;
|
|
74
|
+
} | undefined;
|
|
75
|
+
}): Promise<Record<ChainId, Record<TokenAddress, PriceResult>>>;
|
|
76
|
+
getHistoricalPrices(_: {
|
|
77
|
+
tokens: {
|
|
78
|
+
chainId: ChainId;
|
|
79
|
+
token: TokenAddress;
|
|
80
|
+
timestamp: Timestamp;
|
|
81
|
+
}[];
|
|
82
|
+
searchWidth: TimeString | undefined;
|
|
83
|
+
config: {
|
|
84
|
+
timeout?: TimeString;
|
|
85
|
+
} | undefined;
|
|
86
|
+
}): Promise<Record<ChainId, Record<TokenAddress, Record<Timestamp, PriceResult>>>>;
|
|
87
|
+
getChart(_: {
|
|
88
|
+
tokens: PriceInput[];
|
|
89
|
+
span: number;
|
|
90
|
+
period: TimeString;
|
|
91
|
+
bound: {
|
|
92
|
+
from: Timestamp;
|
|
93
|
+
} | {
|
|
94
|
+
upTo: Timestamp | 'now';
|
|
95
|
+
};
|
|
96
|
+
searchWidth?: TimeString;
|
|
97
|
+
config: {
|
|
98
|
+
timeout?: TimeString;
|
|
99
|
+
} | undefined;
|
|
100
|
+
}): Promise<Record<ChainId, Record<TokenAddress, PriceResult[]>>>;
|
|
101
|
+
};
|
|
102
|
+
export type PriceInput = {
|
|
103
|
+
chainId: ChainId;
|
|
104
|
+
token: TokenAddress;
|
|
105
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/services/prices/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./provider-sources"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/providers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,qDAAmC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { PublicClient, PublicClientConfig, Transport } from 'viem';
|
|
2
|
+
import { ChainId } from '../../types';
|
|
3
|
+
import { IProviderService, IProviderSource } from './types';
|
|
4
|
+
export type ProviderConfig = Pick<PublicClientConfig, 'batch'>;
|
|
5
|
+
export declare class ProviderService implements IProviderService {
|
|
6
|
+
private readonly viemPublicClients;
|
|
7
|
+
private readonly source;
|
|
8
|
+
private readonly config;
|
|
9
|
+
constructor({ source, config }: {
|
|
10
|
+
source: IProviderSource;
|
|
11
|
+
config?: ProviderConfig;
|
|
12
|
+
});
|
|
13
|
+
supportedChains(): ChainId[];
|
|
14
|
+
getViemPublicClient({ chainId }: {
|
|
15
|
+
chainId: ChainId;
|
|
16
|
+
}): PublicClient;
|
|
17
|
+
getViemTransport({ chainId }: {
|
|
18
|
+
chainId: number;
|
|
19
|
+
}): Transport;
|
|
20
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProviderService = void 0;
|
|
4
|
+
const viem_1 = require("viem");
|
|
5
|
+
const utils_1 = require("./utils");
|
|
6
|
+
class ProviderService {
|
|
7
|
+
constructor({ source, config }) {
|
|
8
|
+
// Viem clients have a lot of state and they even do some polling at regular intervals
|
|
9
|
+
// That's why we'll only create one client per chain, and then re-use it
|
|
10
|
+
this.viemPublicClients = new Map();
|
|
11
|
+
this.source = source;
|
|
12
|
+
this.config = config;
|
|
13
|
+
}
|
|
14
|
+
supportedChains() {
|
|
15
|
+
return this.source.supportedChains();
|
|
16
|
+
}
|
|
17
|
+
getViemPublicClient({ chainId }) {
|
|
18
|
+
if (!this.viemPublicClients.has(chainId)) {
|
|
19
|
+
// Viem only works with EVM chains (numeric chainIds)
|
|
20
|
+
const evmChainId = chainId;
|
|
21
|
+
const transport = this.getViemTransport({ chainId: evmChainId });
|
|
22
|
+
const chain = (0, utils_1.getViemChain)(evmChainId);
|
|
23
|
+
const client = (0, viem_1.createPublicClient)({ ...this.config, chain, transport });
|
|
24
|
+
this.viemPublicClients.set(chainId, client);
|
|
25
|
+
}
|
|
26
|
+
return this.viemPublicClients.get(chainId);
|
|
27
|
+
}
|
|
28
|
+
getViemTransport({ chainId }) {
|
|
29
|
+
return this.source.getViemTransport({ chainId });
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
exports.ProviderService = ProviderService;
|
|
33
|
+
//# sourceMappingURL=provider-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider-service.js","sourceRoot":"","sources":["../../../src/services/providers/provider-service.ts"],"names":[],"mappings":";;;AAAA,+BAAuF;AAGvF,mCAAuC;AAIvC,MAAa,eAAe;IAO1B,YAAY,EAAE,MAAM,EAAE,MAAM,EAAwD;QANpF,sFAAsF;QACtF,wEAAwE;QACvD,sBAAiB,GAA+B,IAAI,GAAG,EAAE,CAAC;QAKzE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC;IACvC,CAAC;IAED,mBAAmB,CAAC,EAAE,OAAO,EAAwB;QACnD,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC;YACzC,qDAAqD;YACrD,MAAM,UAAU,GAAG,OAAiB,CAAC;YACrC,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC,CAAC;YACjE,MAAM,KAAK,GAAG,IAAA,oBAAY,EAAC,UAAU,CAAC,CAAC;YACvC,MAAM,MAAM,GAAG,IAAA,yBAAkB,EAAC,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;YACxE,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,OAAO,EAAE,MAAsB,CAAC,CAAC;QAC9D,CAAC;QACD,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,OAAO,CAAE,CAAC;IAC9C,CAAC;IAED,gBAAgB,CAAC,EAAE,OAAO,EAAuB;QAC/C,OAAO,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;IACnD,CAAC;CACF;AA/BD,0CA+BC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ChainId } from '../../../types';
|
|
2
|
+
import { BaseHttpProvider, HttpProviderConfig } from './base/base-http-provider';
|
|
3
|
+
export type AlchemySupportedChains = ChainId[];
|
|
4
|
+
export declare class AlchemyProviderSource extends BaseHttpProvider {
|
|
5
|
+
private readonly key;
|
|
6
|
+
private readonly supported;
|
|
7
|
+
constructor({ key, onChains, config }: {
|
|
8
|
+
key: string;
|
|
9
|
+
onChains?: AlchemySupportedChains;
|
|
10
|
+
config?: HttpProviderConfig;
|
|
11
|
+
});
|
|
12
|
+
supportedChains(): ChainId[];
|
|
13
|
+
protected calculateUrl(chainId: ChainId): string;
|
|
14
|
+
}
|
|
15
|
+
export declare function alchemySupportedChains(): ChainId[];
|
|
16
|
+
export declare function buildAlchemyRPCUrl({ chainId, apiKey, protocol }: {
|
|
17
|
+
chainId: ChainId;
|
|
18
|
+
apiKey: string;
|
|
19
|
+
protocol: 'https' | 'wss';
|
|
20
|
+
}): string;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildAlchemyRPCUrl = exports.alchemySupportedChains = exports.AlchemyProviderSource = void 0;
|
|
4
|
+
const base_http_provider_1 = require("./base/base-http-provider");
|
|
5
|
+
const alchemy_1 = require("../../../shared/alchemy");
|
|
6
|
+
class AlchemyProviderSource extends base_http_provider_1.BaseHttpProvider {
|
|
7
|
+
constructor({ key, onChains, config }) {
|
|
8
|
+
super(config);
|
|
9
|
+
this.key = key;
|
|
10
|
+
if (onChains === undefined) {
|
|
11
|
+
this.supported = alchemySupportedChains();
|
|
12
|
+
}
|
|
13
|
+
else if (Array.isArray(onChains)) {
|
|
14
|
+
this.supported = onChains;
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
this.supported = alchemySupportedChains();
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
supportedChains() {
|
|
21
|
+
return this.supported;
|
|
22
|
+
}
|
|
23
|
+
calculateUrl(chainId) {
|
|
24
|
+
return buildAlchemyRPCUrl({ chainId, apiKey: this.key, protocol: 'https' });
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
exports.AlchemyProviderSource = AlchemyProviderSource;
|
|
28
|
+
function alchemySupportedChains() {
|
|
29
|
+
return Object.entries(alchemy_1.ALCHEMY_NETWORKS).map(([chainId]) => Number(chainId));
|
|
30
|
+
}
|
|
31
|
+
exports.alchemySupportedChains = alchemySupportedChains;
|
|
32
|
+
function buildAlchemyRPCUrl({ chainId, apiKey, protocol }) {
|
|
33
|
+
const { key: alchemyNetwork } = alchemy_1.ALCHEMY_NETWORKS[chainId];
|
|
34
|
+
return `${protocol}://${alchemyNetwork}.g.alchemy.com/v2/${apiKey}`;
|
|
35
|
+
}
|
|
36
|
+
exports.buildAlchemyRPCUrl = buildAlchemyRPCUrl;
|
|
37
|
+
//# sourceMappingURL=alchemy-provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alchemy-provider.js","sourceRoot":"","sources":["../../../../src/services/providers/provider-sources/alchemy-provider.ts"],"names":[],"mappings":";;;AACA,kEAAiF;AACjF,6CAAmD;AAInD,MAAa,qBAAsB,SAAQ,qCAAgB;IAIzD,YAAY,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAmF;QACpH,KAAK,CAAC,MAAM,CAAC,CAAC;QACd,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QACf,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;YAC3B,IAAI,CAAC,SAAS,GAAG,sBAAsB,EAAE,CAAC;QAC5C,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC5B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,GAAG,sBAAsB,EAAE,CAAC;QAC5C,CAAC;IACH,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAES,YAAY,CAAC,OAAgB;QACrC,OAAO,kBAAkB,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;IAC9E,CAAC;CACF;AAvBD,sDAuBC;AAED,SAAgB,sBAAsB;IACpC,OAAO,MAAM,CAAC,OAAO,CAAC,0BAAgB,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;AAC9E,CAAC;AAFD,wDAEC;AAED,SAAgB,kBAAkB,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAmE;IAC/H,MAAM,EAAE,GAAG,EAAE,cAAc,EAAE,GAAG,0BAAgB,CAAC,OAAO,CAAC,CAAC;IAC1D,OAAO,GAAG,QAAQ,MAAM,cAAc,qBAAqB,MAAM,EAAE,CAAC;AACtE,CAAC;AAHD,gDAGC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { ChainId } from '../../../types';
|
|
2
|
+
import { BaseHttpProvider, HttpProviderConfig } from './base/base-http-provider';
|
|
3
|
+
export declare class AnkrProviderSource extends BaseHttpProvider {
|
|
4
|
+
private readonly supported;
|
|
5
|
+
private readonly key;
|
|
6
|
+
constructor({ key, onChains, config }: {
|
|
7
|
+
key?: string;
|
|
8
|
+
onChains?: ChainId[];
|
|
9
|
+
config?: HttpProviderConfig;
|
|
10
|
+
});
|
|
11
|
+
supportedChains(): ChainId[];
|
|
12
|
+
protected calculateUrl(chainId: ChainId): string;
|
|
13
|
+
}
|
|
14
|
+
export declare function buildAnkrRPCUrl({ chainId, apiKey }: {
|
|
15
|
+
chainId: ChainId;
|
|
16
|
+
apiKey?: string;
|
|
17
|
+
}): string;
|
|
18
|
+
export declare function ankrSupportedChains(): ChainId[];
|