@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 @@
|
|
|
1
|
+
{"version":3,"file":"polygon-gas-station-gas-price-source.js","sourceRoot":"","sources":["../../../../src/services/gas/gas-price-sources/polygon-gas-station-gas-price-source.ts"],"names":[],"mappings":";;;AAGA,qCAAiC;AACjC,+BAAkC;AAGlC,MAAa,+BAA+B;IAC1C,YAA6B,YAA2B;QAA3B,iBAAY,GAAZ,YAAY,CAAe;IAAG,CAAC;IAE5D,eAAe;QACb,MAAM,OAAO,GAA6B,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;QACvG,OAAO,EAAE,CAAC,gBAAM,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,CAAC;IAC/C,CAAC;IAED,KAAK,CAAC,WAAW,CAAqD,EACpE,OAAO,EACP,MAAM,GAIP;QACC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,6CAA6C,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC;QAC5H,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,GAA+C,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QACtG,OAAO;YACL,QAAQ,EAAE,YAAY,CAAC,OAAO,CAAC;YAC/B,IAAI,EAAE,YAAY,CAAC,QAAQ,CAAC;YAC5B,OAAO,EAAE,YAAY,CAAC,IAAI,CAAC;SACe,CAAC;IAC/C,CAAC;CACF;AAvBD,0EAuBC;AAED,SAAS,YAAY,CAAC,GAAQ;IAC5B,OAAO;QACL,YAAY,EAAE,IAAA,iBAAU,EAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAgB,EAAE,CAAC,CAAC;QACjE,oBAAoB,EAAE,IAAA,iBAAU,EAAC,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAgB,EAAE,CAAC,CAAC;KAClF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { ChainId, FieldsRequirements, TimeString } from '../../../types';
|
|
2
|
+
import { GasPriceResult, IGasPriceSource, MergeGasValues } from '../types';
|
|
3
|
+
export declare class PrioritizedGasPriceSourceCombinator<Sources extends IGasPriceSource<object>[] | []> implements IGasPriceSource<MergeGasValues<Sources>> {
|
|
4
|
+
private readonly sources;
|
|
5
|
+
constructor(sources: Sources);
|
|
6
|
+
supportedSpeeds(): Record<ChainId, import("../../../types").SupportInChain<MergeGasValues<Sources>>>;
|
|
7
|
+
getGasPrice<Requirements extends FieldsRequirements<MergeGasValues<Sources>>>({ chainId, config, }: {
|
|
8
|
+
chainId: ChainId;
|
|
9
|
+
config?: {
|
|
10
|
+
fields?: Requirements;
|
|
11
|
+
timeout?: TimeString;
|
|
12
|
+
};
|
|
13
|
+
}): Promise<GasPriceResult<MergeGasValues<Sources>, Requirements>>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PrioritizedGasPriceSourceCombinator = void 0;
|
|
4
|
+
const requirements_and_support_1 = require("../../../shared/requirements-and-support");
|
|
5
|
+
// This source will take a list of sources, sorted by priority, and use the first one possible
|
|
6
|
+
// that supports the given chain
|
|
7
|
+
class PrioritizedGasPriceSourceCombinator {
|
|
8
|
+
constructor(sources) {
|
|
9
|
+
this.sources = sources;
|
|
10
|
+
if (sources.length === 0)
|
|
11
|
+
throw new Error('No sources were specified');
|
|
12
|
+
}
|
|
13
|
+
supportedSpeeds() {
|
|
14
|
+
return (0, requirements_and_support_1.combineSourcesSupport)(this.sources, (source) => source.supportedSpeeds());
|
|
15
|
+
}
|
|
16
|
+
async getGasPrice({ chainId, config, }) {
|
|
17
|
+
const sourcesInChain = this.sources.filter((source) => chainId in source.supportedSpeeds() && (0, requirements_and_support_1.couldSupportMeetRequirements)(source.supportedSpeeds()[chainId], config?.fields));
|
|
18
|
+
if (sourcesInChain.length === 0)
|
|
19
|
+
throw new Error(`Chain with id ${chainId} cannot support the given requirements`);
|
|
20
|
+
const gasResults = sourcesInChain.map((source) => source.getGasPrice({ chainId, config }).catch(() => ({})));
|
|
21
|
+
return new Promise(async (resolve, reject) => {
|
|
22
|
+
for (let i = 0; i < gasResults.length; i++) {
|
|
23
|
+
const response = await gasResults[i];
|
|
24
|
+
if (Object.keys(response).length > 0 && (0, requirements_and_support_1.doesResponseMeetRequirements)(response, config?.fields)) {
|
|
25
|
+
resolve(response);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
reject(new Error('Could not fetch gas prices that met the given requirements'));
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
exports.PrioritizedGasPriceSourceCombinator = PrioritizedGasPriceSourceCombinator;
|
|
33
|
+
//# sourceMappingURL=prioritized-gas-price-source-combinator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prioritized-gas-price-source-combinator.js","sourceRoot":"","sources":["../../../../src/services/gas/gas-price-sources/prioritized-gas-price-source-combinator.ts"],"names":[],"mappings":";;;AAAA,+EAAqI;AAIrI,8FAA8F;AAC9F,gCAAgC;AAChC,MAAa,mCAAmC;IAG9C,YAA6B,OAAgB;QAAhB,YAAO,GAAP,OAAO,CAAS;QAC3C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;IACzE,CAAC;IAED,eAAe;QACb,OAAO,IAAA,gDAAqB,EAAmD,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC,CAAC;IACrI,CAAC;IAED,KAAK,CAAC,WAAW,CAAmE,EAClF,OAAO,EACP,MAAM,GAIP;QACC,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CACxC,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO,IAAI,MAAM,CAAC,eAAe,EAAE,IAAI,IAAA,uDAA4B,EAAC,MAAM,CAAC,eAAe,EAAE,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,CACnI,CAAC;QACF,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,OAAO,wCAAwC,CAAC,CAAC;QACnH,MAAM,UAAU,GAAG,cAAc,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7G,OAAO,IAAI,OAAO,CAAwD,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE;YAClG,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC3C,MAAM,QAAQ,GAAG,MAAM,UAAU,CAAC,CAAC,CAAC,CAAC;gBACrC,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,IAAA,uDAA4B,EAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;oBAC/F,OAAO,CAAC,QAAiE,CAAC,CAAC;gBAC7E,CAAC;YACH,CAAC;YACD,MAAM,CAAC,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC,CAAC;QAClF,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAjCD,kFAiCC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { ChainId, FieldsRequirements, SupportRecord, TimeString } from '../../../types';
|
|
2
|
+
import { IProviderService } from '../../providers/types';
|
|
3
|
+
import { GasPriceResult, GasValueForVersions, IGasPriceSource } from '../types';
|
|
4
|
+
type GasValues = GasValueForVersions<'standard'>;
|
|
5
|
+
export declare class RPCGasPriceSource implements IGasPriceSource<GasValues> {
|
|
6
|
+
private readonly providerService;
|
|
7
|
+
constructor(providerService: IProviderService);
|
|
8
|
+
supportedSpeeds(): {
|
|
9
|
+
[k: string]: SupportRecord<GasValues>;
|
|
10
|
+
};
|
|
11
|
+
getGasPrice<Requirements extends FieldsRequirements<GasValues>>({ chainId, config }: {
|
|
12
|
+
chainId: ChainId;
|
|
13
|
+
config?: {
|
|
14
|
+
timeout?: TimeString;
|
|
15
|
+
};
|
|
16
|
+
}): Promise<GasPriceResult<GasValues, Requirements>>;
|
|
17
|
+
}
|
|
18
|
+
export {};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RPCGasPriceSource = void 0;
|
|
4
|
+
const timeouts_1 = require("../../../shared/timeouts");
|
|
5
|
+
class RPCGasPriceSource {
|
|
6
|
+
constructor(providerService) {
|
|
7
|
+
this.providerService = providerService;
|
|
8
|
+
}
|
|
9
|
+
supportedSpeeds() {
|
|
10
|
+
const support = { standard: 'present' };
|
|
11
|
+
return Object.fromEntries(this.providerService.supportedChains().map((chainId) => [Number(chainId), support]));
|
|
12
|
+
}
|
|
13
|
+
getGasPrice({ chainId, config }) {
|
|
14
|
+
const client = this.providerService.getViemPublicClient({ chainId });
|
|
15
|
+
const promise = calculatePrice(client);
|
|
16
|
+
return (0, timeouts_1.timeoutPromise)(promise, config?.timeout);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
exports.RPCGasPriceSource = RPCGasPriceSource;
|
|
20
|
+
async function calculatePrice(client) {
|
|
21
|
+
// We need to specify a type, or viem will default to eip1559 and fail if the chain doesn't support it. So we've looked into what viem does
|
|
22
|
+
// and we realized that it will fetch a block, and then return the latest price. So we fetch it first to determine the time, and then pass
|
|
23
|
+
// it to viem, even though it doesn't accept it "publicly". But it does use it nevertheless and it doesn't fetch a new one
|
|
24
|
+
const block = await client.getBlock();
|
|
25
|
+
const type = typeof block.baseFeePerGas === 'bigint' ? 'eip1559' : 'legacy';
|
|
26
|
+
const feeData = await client.estimateFeesPerGas({ block, type });
|
|
27
|
+
const gasPrice = feeData.maxFeePerGas !== undefined && feeData.maxPriorityFeePerGas !== undefined
|
|
28
|
+
? { standard: { maxFeePerGas: feeData.maxFeePerGas, maxPriorityFeePerGas: feeData.maxPriorityFeePerGas } }
|
|
29
|
+
: { standard: { gasPrice: feeData.gasPrice } };
|
|
30
|
+
return gasPrice;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=rpc-gas-price-source.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rpc-gas-price-source.js","sourceRoot":"","sources":["../../../../src/services/gas/gas-price-sources/rpc-gas-price-source.ts"],"names":[],"mappings":";;;AAIA,+CAAkD;AAIlD,MAAa,iBAAiB;IAC5B,YAA6B,eAAiC;QAAjC,oBAAe,GAAf,eAAe,CAAkB;IAAG,CAAC;IAElE,eAAe;QACb,MAAM,OAAO,GAA6B,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;QAClE,OAAO,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,eAAe,CAAC,eAAe,EAAE,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACjH,CAAC;IAED,WAAW,CAAqD,EAAE,OAAO,EAAE,MAAM,EAA2D;QAC1I,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;QACrE,MAAM,OAAO,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;QACvC,OAAO,IAAA,yBAAc,EAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAqD,CAAC;IACtG,CAAC;CACF;AAbD,8CAaC;AAED,KAAK,UAAU,cAAc,CAAC,MAAoB;IAChD,2IAA2I;IAC3I,0IAA0I;IAC1I,0HAA0H;IAC1H,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,QAAQ,EAAE,CAAC;IACtC,MAAM,IAAI,GAAG,OAAO,KAAK,CAAC,aAAa,KAAK,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC;IAC5E,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,kBAAkB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAS,CAAC,CAAC;IACxE,MAAM,QAAQ,GACZ,OAAO,CAAC,YAAY,KAAK,SAAS,IAAI,OAAO,CAAC,oBAAoB,KAAK,SAAS;QAC9E,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,YAAY,EAAE,OAAO,CAAC,YAAY,EAAE,oBAAoB,EAAE,OAAO,CAAC,oBAAoB,EAAE,EAAE;QAC1G,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,OAAO,CAAC,QAAS,EAAE,EAAE,CAAC;IACpD,OAAO,QAAQ,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { BigIntish, ChainId, DefaultRequirements, FieldsRequirements, TimeString, InputTransaction } from '../../types';
|
|
2
|
+
import { IProviderService } from '../providers/types';
|
|
3
|
+
import { IGasService, IQuickGasCostCalculator, SupportedGasValues, IGasPriceSource, GasEstimation } from './types';
|
|
4
|
+
type ConstructorParameters<GasValues extends SupportedGasValues> = {
|
|
5
|
+
providerService: IProviderService;
|
|
6
|
+
gasPriceSource: IGasPriceSource<GasValues>;
|
|
7
|
+
};
|
|
8
|
+
export declare class GasService<GasValues extends SupportedGasValues> implements IGasService<GasValues> {
|
|
9
|
+
private readonly providerService;
|
|
10
|
+
private readonly gasPriceSource;
|
|
11
|
+
constructor({ providerService, gasPriceSource }: ConstructorParameters<GasValues>);
|
|
12
|
+
supportedChains(): ChainId[];
|
|
13
|
+
supportedSpeeds(): {
|
|
14
|
+
[k: string]: import("../../types").SupportInChain<GasValues>;
|
|
15
|
+
};
|
|
16
|
+
estimateGas({ chainId, tx, config }: {
|
|
17
|
+
chainId: ChainId;
|
|
18
|
+
tx: InputTransaction;
|
|
19
|
+
config?: {
|
|
20
|
+
timeout?: TimeString;
|
|
21
|
+
};
|
|
22
|
+
}): Promise<bigint>;
|
|
23
|
+
getQuickGasCalculator<Requirements extends FieldsRequirements<GasValues> = DefaultRequirements<GasValues>>({ chainId, config, }: {
|
|
24
|
+
chainId: ChainId;
|
|
25
|
+
config?: {
|
|
26
|
+
timeout?: TimeString;
|
|
27
|
+
fields?: Requirements;
|
|
28
|
+
};
|
|
29
|
+
}): Promise<IQuickGasCostCalculator<GasValues, Requirements>>;
|
|
30
|
+
getGasPrice<Requirements extends FieldsRequirements<GasValues> = DefaultRequirements<GasValues>>({ chainId, config, }: {
|
|
31
|
+
chainId: ChainId;
|
|
32
|
+
config?: {
|
|
33
|
+
timeout?: TimeString;
|
|
34
|
+
fields?: Requirements;
|
|
35
|
+
};
|
|
36
|
+
}): Promise<import("./types").GasPriceResult<GasValues, Requirements>>;
|
|
37
|
+
calculateGasCost<Requirements extends FieldsRequirements<GasValues> = DefaultRequirements<GasValues>>({ chainId, gasEstimation, tx, config, }: {
|
|
38
|
+
chainId: ChainId;
|
|
39
|
+
gasEstimation: BigIntish;
|
|
40
|
+
tx?: InputTransaction;
|
|
41
|
+
config?: {
|
|
42
|
+
timeout?: TimeString;
|
|
43
|
+
fields?: Requirements;
|
|
44
|
+
};
|
|
45
|
+
}): Promise<GasEstimation<GasValues, Requirements>>;
|
|
46
|
+
private estimateGasInternal;
|
|
47
|
+
}
|
|
48
|
+
export {};
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GasService = void 0;
|
|
4
|
+
const _chains_1 = require("../../chains");
|
|
5
|
+
const timeouts_1 = require("../../shared/timeouts");
|
|
6
|
+
const requirements_and_support_1 = require("../../shared/requirements-and-support");
|
|
7
|
+
const viem_1 = require("../../shared/viem");
|
|
8
|
+
class GasService {
|
|
9
|
+
constructor({ providerService, gasPriceSource }) {
|
|
10
|
+
this.providerService = providerService;
|
|
11
|
+
this.gasPriceSource = gasPriceSource;
|
|
12
|
+
}
|
|
13
|
+
supportedChains() {
|
|
14
|
+
return (0, _chains_1.chainsIntersection)(this.providerService.supportedChains(), Object.keys(this.gasPriceSource.supportedSpeeds()).map(Number));
|
|
15
|
+
}
|
|
16
|
+
supportedSpeeds() {
|
|
17
|
+
const supportedChains = this.supportedChains();
|
|
18
|
+
const entries = Object.entries(this.gasPriceSource.supportedSpeeds()).filter(([chainId]) => supportedChains.includes(Number(chainId)));
|
|
19
|
+
return Object.fromEntries(entries);
|
|
20
|
+
}
|
|
21
|
+
estimateGas({ chainId, tx, config }) {
|
|
22
|
+
const promise = this.estimateGasInternal(chainId, tx);
|
|
23
|
+
return (0, timeouts_1.timeoutPromise)(promise, config?.timeout);
|
|
24
|
+
}
|
|
25
|
+
async getQuickGasCalculator({ chainId, config, }) {
|
|
26
|
+
(0, requirements_and_support_1.validateRequirements)(this.supportedSpeeds(), [chainId], config?.fields);
|
|
27
|
+
const support = this.supportedSpeeds()[chainId];
|
|
28
|
+
const gasPriceData = await (0, timeouts_1.timeoutPromise)(this.gasPriceSource.getGasPrice({ chainId, config }), config?.timeout);
|
|
29
|
+
if (!(0, requirements_and_support_1.doesResponseMeetRequirements)(gasPriceData, config?.fields)) {
|
|
30
|
+
throw new Error('Failed to fetch gas prices that meet the given requirements');
|
|
31
|
+
}
|
|
32
|
+
return {
|
|
33
|
+
supportedSpeeds: () => support,
|
|
34
|
+
getGasPrice: () => gasPriceData,
|
|
35
|
+
calculateGasCost: ({ gasEstimation }) => {
|
|
36
|
+
const result = {};
|
|
37
|
+
for (const [speed, gasPriceForSpeed] of Object.entries(gasPriceData)) {
|
|
38
|
+
const actualGasPrice = 'maxFeePerGas' in gasPriceForSpeed ? gasPriceForSpeed.maxFeePerGas : gasPriceForSpeed.gasPrice;
|
|
39
|
+
const gasCostNativeToken = (BigInt(gasEstimation) * BigInt(actualGasPrice)).toString();
|
|
40
|
+
result[speed] = { gasCostNativeToken, ...gasPriceForSpeed };
|
|
41
|
+
}
|
|
42
|
+
return result;
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
async getGasPrice({ chainId, config, }) {
|
|
47
|
+
const gasCalculator = await this.getQuickGasCalculator({ chainId, config });
|
|
48
|
+
return gasCalculator.getGasPrice();
|
|
49
|
+
}
|
|
50
|
+
async calculateGasCost({ chainId, gasEstimation, tx, config, }) {
|
|
51
|
+
const gasCalculator = await this.getQuickGasCalculator({ chainId, config });
|
|
52
|
+
return gasCalculator.calculateGasCost({ gasEstimation, tx });
|
|
53
|
+
}
|
|
54
|
+
async estimateGasInternal(chainId, tx) {
|
|
55
|
+
const viemTx = (0, viem_1.mapTxToViemTx)(tx);
|
|
56
|
+
const client = this.providerService.getViemPublicClient({ chainId });
|
|
57
|
+
const estimateGasPromise = client.estimateGas(viemTx);
|
|
58
|
+
// Note: in most chains, calling `estimateGas` would reject if the transaction were to revert. However, in RSK
|
|
59
|
+
// it doesn't work that way. In order to be consistent, when we are estimating gas for RSK, we also simulate
|
|
60
|
+
// the transaction using `call` to make sure it doesn't revert.
|
|
61
|
+
const callPromise = chainId === _chains_1.Chains.ROOTSTOCK.chainId ? client.call(viemTx) : Promise.resolve();
|
|
62
|
+
const [estimatedGas] = await Promise.all([estimateGasPromise, callPromise]);
|
|
63
|
+
return estimatedGas;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
exports.GasService = GasService;
|
|
67
|
+
//# sourceMappingURL=gas-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gas-service.js","sourceRoot":"","sources":["../../../src/services/gas/gas-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AVAILABLE_GAS_SPEEDS = void 0;
|
|
4
|
+
var types_1 = require("./types");
|
|
5
|
+
Object.defineProperty(exports, "AVAILABLE_GAS_SPEEDS", { enumerable: true, get: function () { return types_1.AVAILABLE_GAS_SPEEDS; } });
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/gas/index.ts"],"names":[],"mappings":";;;AAAA,iCAUiB;AATf,6GAAA,oBAAoB,OAAA"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { BigIntish, BasedOnRequirements, ChainId, DefaultRequirements, FieldsRequirements, SupportInChain, TimeString, InputTransaction } from '../../types';
|
|
2
|
+
import { UnionMerge } from '../../utility-types';
|
|
3
|
+
export declare const AVAILABLE_GAS_SPEEDS: readonly ["standard", "fast", "instant"];
|
|
4
|
+
export type GasPrice = LegacyGasPrice | EIP1159GasPrice;
|
|
5
|
+
export type GasSpeed = (typeof AVAILABLE_GAS_SPEEDS)[number];
|
|
6
|
+
export type GasEstimation<GasValues extends SupportedGasValues, Requirements extends FieldsRequirements<GasValues> = DefaultRequirements<AddGasCost<GasValues>>> = GasPriceResult<AddGasCost<GasValues>, Requirements>;
|
|
7
|
+
export type IGasService<GasValues extends SupportedGasValues = DefaultGasValues> = {
|
|
8
|
+
supportedChains(): ChainId[];
|
|
9
|
+
supportedSpeeds(): Record<ChainId, SupportInChain<GasValues>>;
|
|
10
|
+
estimateGas(_: {
|
|
11
|
+
chainId: ChainId;
|
|
12
|
+
tx: InputTransaction;
|
|
13
|
+
config?: {
|
|
14
|
+
timeout?: TimeString;
|
|
15
|
+
};
|
|
16
|
+
}): Promise<bigint>;
|
|
17
|
+
getGasPrice<Requirements extends FieldsRequirements<GasValues> = DefaultRequirements<GasValues>>(_: {
|
|
18
|
+
chainId: ChainId;
|
|
19
|
+
config?: {
|
|
20
|
+
timeout?: TimeString;
|
|
21
|
+
fields?: Requirements;
|
|
22
|
+
};
|
|
23
|
+
}): Promise<GasPriceResult<GasValues, Requirements>>;
|
|
24
|
+
calculateGasCost<Requirements extends FieldsRequirements<GasValues> = DefaultRequirements<GasValues>>(_: {
|
|
25
|
+
chainId: ChainId;
|
|
26
|
+
gasEstimation: BigIntish;
|
|
27
|
+
tx?: InputTransaction;
|
|
28
|
+
config?: {
|
|
29
|
+
timeout?: TimeString;
|
|
30
|
+
fields?: Requirements;
|
|
31
|
+
};
|
|
32
|
+
}): Promise<GasEstimation<GasValues, Requirements>>;
|
|
33
|
+
getQuickGasCalculator<Requirements extends FieldsRequirements<GasValues> = DefaultRequirements<GasValues>>(_: {
|
|
34
|
+
chainId: ChainId;
|
|
35
|
+
config?: {
|
|
36
|
+
timeout?: TimeString;
|
|
37
|
+
fields?: Requirements;
|
|
38
|
+
};
|
|
39
|
+
}): Promise<IQuickGasCostCalculator<GasValues, Requirements>>;
|
|
40
|
+
};
|
|
41
|
+
export type IQuickGasCostCalculator<GasValues extends SupportedGasValues = DefaultGasValues, Requirements extends FieldsRequirements<GasValues> = DefaultRequirements<GasValues>> = {
|
|
42
|
+
supportedSpeeds(): SupportInChain<GasValues>;
|
|
43
|
+
getGasPrice(): GasPriceResult<GasValues, Requirements>;
|
|
44
|
+
calculateGasCost(_: {
|
|
45
|
+
gasEstimation: BigIntish;
|
|
46
|
+
tx?: InputTransaction;
|
|
47
|
+
}): GasEstimation<GasValues, Requirements>;
|
|
48
|
+
};
|
|
49
|
+
export type IGasPriceSource<GasValues extends SupportedGasValues> = {
|
|
50
|
+
supportedSpeeds(): Record<ChainId, SupportInChain<GasValues>>;
|
|
51
|
+
getGasPrice<Requirements extends FieldsRequirements<GasValues>>(_: {
|
|
52
|
+
chainId: ChainId;
|
|
53
|
+
config?: {
|
|
54
|
+
fields?: Requirements;
|
|
55
|
+
timeout?: TimeString;
|
|
56
|
+
};
|
|
57
|
+
}): Promise<GasPriceResult<GasValues, Requirements>>;
|
|
58
|
+
};
|
|
59
|
+
export type SupportedGasValues = Partial<Record<GasSpeed, EIP1159GasPrice | LegacyGasPrice>>;
|
|
60
|
+
export type GasValueForVersion<Speed extends GasSpeed, GasPriceVersion extends GasPrice> = Record<Speed, GasPriceVersion>;
|
|
61
|
+
export type GasValueForVersions<Speed extends GasSpeed> = Record<Speed, EIP1159GasPrice | LegacyGasPrice>;
|
|
62
|
+
export type GasPriceResult<GasValues extends SupportedGasValues, Requirements extends FieldsRequirements<GasValues> = DefaultRequirements<GasValues>> = BasedOnRequirements<GasValues, Requirements>;
|
|
63
|
+
export type MergeGasValues<Sources extends IGasPriceSource<object>[] | []> = UnionMerge<{
|
|
64
|
+
[K in keyof Sources]: ExtractGasValues<Sources[K]>;
|
|
65
|
+
}[number]>;
|
|
66
|
+
export type ExtractGasValues<Source extends IGasPriceSource<object>> = Source extends IGasPriceSource<infer R> ? R : never;
|
|
67
|
+
export type EIP1159GasPrice = {
|
|
68
|
+
maxFeePerGas: bigint;
|
|
69
|
+
maxPriorityFeePerGas: bigint;
|
|
70
|
+
};
|
|
71
|
+
export type LegacyGasPrice = {
|
|
72
|
+
gasPrice: bigint;
|
|
73
|
+
};
|
|
74
|
+
export type DefaultGasValues = GasValueForVersions<GasSpeed>;
|
|
75
|
+
type AddGasCost<GasValues extends SupportedGasValues> = {
|
|
76
|
+
[K in keyof GasValues]: GasValues[K] & {
|
|
77
|
+
gasCostNativeToken: bigint;
|
|
78
|
+
};
|
|
79
|
+
};
|
|
80
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/services/gas/types.ts"],"names":[],"mappings":";;;AAYa,QAAA,oBAAoB,GAAG,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,CAAU,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { DefaultRequirements, FieldsRequirements } from '../../types';
|
|
2
|
+
import { EIP1159GasPrice, GasPriceResult, SupportedGasValues } from './types';
|
|
3
|
+
export declare function isEIP1159Compatible<GasValues extends SupportedGasValues, Requirements extends FieldsRequirements<GasValues> = DefaultRequirements<GasValues>>(gasPriceForSpeed: GasPriceResult<object, Requirements>): gasPriceForSpeed is GasPriceResult<OnlyEIP1559<GasValues>, Requirements>;
|
|
4
|
+
type OnlyEIP1559<GasValues extends SupportedGasValues> = {
|
|
5
|
+
[K in keyof GasValues]: GasValues[K] extends EIP1159GasPrice ? GasValues[K] : never;
|
|
6
|
+
};
|
|
7
|
+
export declare function isValidGasPriceValue(value: any): boolean;
|
|
8
|
+
export declare function filterOutInvalidSpeeds(result: GasPriceResult<object>): {
|
|
9
|
+
[k: string]: unknown;
|
|
10
|
+
};
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.filterOutInvalidSpeeds = exports.isValidGasPriceValue = exports.isEIP1159Compatible = void 0;
|
|
4
|
+
const utils_1 = require("../../shared/utils");
|
|
5
|
+
function isEIP1159Compatible(gasPriceForSpeed) {
|
|
6
|
+
const keys = Object.keys(gasPriceForSpeed);
|
|
7
|
+
if (keys.length === 0) {
|
|
8
|
+
throw new Error(`Found a gas price result with nothing on it. This shouldn't happen`);
|
|
9
|
+
}
|
|
10
|
+
const gasPrice = gasPriceForSpeed[keys[0]];
|
|
11
|
+
if ('maxFeePerGas' in gasPrice && (0, utils_1.isBigIntish)(gasPrice.maxFeePerGas)) {
|
|
12
|
+
return true;
|
|
13
|
+
}
|
|
14
|
+
return false;
|
|
15
|
+
}
|
|
16
|
+
exports.isEIP1159Compatible = isEIP1159Compatible;
|
|
17
|
+
function isValidGasPriceValue(value) {
|
|
18
|
+
return ('maxFeePerGas' in value && (0, utils_1.isBigIntish)(value.maxFeePerGas)) || ('gasPrice' in value && (0, utils_1.isBigIntish)(value.gasPrice));
|
|
19
|
+
}
|
|
20
|
+
exports.isValidGasPriceValue = isValidGasPriceValue;
|
|
21
|
+
function filterOutInvalidSpeeds(result) {
|
|
22
|
+
return Object.fromEntries(Object.entries(result).filter(([, value]) => isValidGasPriceValue(value)));
|
|
23
|
+
}
|
|
24
|
+
exports.filterOutInvalidSpeeds = filterOutInvalidSpeeds;
|
|
25
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/services/gas/utils.ts"],"names":[],"mappings":";;;AACA,yCAA4C;AAG5C,SAAgB,mBAAmB,CAGjC,gBAAsD;IACtD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC3C,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACtB,MAAM,IAAI,KAAK,CAAC,oEAAoE,CAAC,CAAC;IACxF,CAAC;IACD,MAAM,QAAQ,GAAI,gBAAwB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACpD,IAAI,cAAc,IAAI,QAAQ,IAAI,IAAA,mBAAW,EAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;QACrE,OAAO,IAAI,CAAC;IACd,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAbD,kDAaC;AAMD,SAAgB,oBAAoB,CAAC,KAAU;IAC7C,OAAO,CAAC,cAAc,IAAI,KAAK,IAAI,IAAA,mBAAW,EAAC,KAAK,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,KAAK,IAAI,IAAA,mBAAW,EAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;AAC9H,CAAC;AAFD,oDAEC;AAED,SAAgB,sBAAsB,CAAC,MAA8B;IACnE,OAAO,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACvG,CAAC;AAFD,wDAEC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * from './balances';
|
|
2
|
+
export * from './allowances';
|
|
3
|
+
export * from './fetch';
|
|
4
|
+
export * from './gas';
|
|
5
|
+
export * from './providers';
|
|
6
|
+
export * from './quotes';
|
|
7
|
+
export * from './metadata';
|
|
8
|
+
export * from './prices';
|
|
9
|
+
export * from './logs';
|
|
10
|
+
export * from './blocks';
|
|
@@ -0,0 +1,27 @@
|
|
|
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("./balances"), exports);
|
|
18
|
+
__exportStar(require("./allowances"), exports);
|
|
19
|
+
__exportStar(require("./fetch"), exports);
|
|
20
|
+
__exportStar(require("./gas"), exports);
|
|
21
|
+
__exportStar(require("./providers"), exports);
|
|
22
|
+
__exportStar(require("./quotes"), exports);
|
|
23
|
+
__exportStar(require("./metadata"), exports);
|
|
24
|
+
__exportStar(require("./prices"), exports);
|
|
25
|
+
__exportStar(require("./logs"), exports);
|
|
26
|
+
__exportStar(require("./blocks"), exports);
|
|
27
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/services/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B;AAC3B,+CAA6B;AAC7B,0CAAwB;AACxB,wCAAsB;AACtB,8CAA4B;AAC5B,2CAAyB;AACzB,6CAA2B;AAC3B,2CAAyB;AACzB,yCAAuB;AACvB,2CAAyB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { LogLevel, ILogger, ILogsService } from './types';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/logs/index.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { ILogger, LogLevel } from '../types';
|
|
2
|
+
export declare class ConsoleLogger implements ILogger {
|
|
3
|
+
private readonly name;
|
|
4
|
+
private readonly level;
|
|
5
|
+
constructor(name: string, level: LogLevel);
|
|
6
|
+
log(message?: any, ...optionalParams: any[]): void;
|
|
7
|
+
debug(message?: any, ...optionalParams: any[]): void;
|
|
8
|
+
info(message?: any, ...optionalParams: any[]): void;
|
|
9
|
+
warn(message?: any, ...optionalParams: any[]): void;
|
|
10
|
+
error(message?: any, ...optionalParams: any[]): void;
|
|
11
|
+
private print;
|
|
12
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ConsoleLogger = void 0;
|
|
4
|
+
const utils_1 = require("../utils");
|
|
5
|
+
class ConsoleLogger {
|
|
6
|
+
constructor(name, level) {
|
|
7
|
+
this.name = name;
|
|
8
|
+
this.level = level;
|
|
9
|
+
}
|
|
10
|
+
log(message, ...optionalParams) {
|
|
11
|
+
this.print('LOG', message, optionalParams);
|
|
12
|
+
}
|
|
13
|
+
debug(message, ...optionalParams) {
|
|
14
|
+
this.print('DEBUG', message, optionalParams);
|
|
15
|
+
}
|
|
16
|
+
info(message, ...optionalParams) {
|
|
17
|
+
this.print('INFO', message, optionalParams);
|
|
18
|
+
}
|
|
19
|
+
warn(message, ...optionalParams) {
|
|
20
|
+
this.print('WARN', message, optionalParams);
|
|
21
|
+
}
|
|
22
|
+
error(message, ...optionalParams) {
|
|
23
|
+
this.print('ERROR', message, optionalParams);
|
|
24
|
+
}
|
|
25
|
+
print(level, message, optionalParams) {
|
|
26
|
+
if ((0, utils_1.shouldPrintLog)(level, this.level)) {
|
|
27
|
+
if (optionalParams.length > 1) {
|
|
28
|
+
return console.log(new Date().toISOString() + ' [' + level + '] (' + this.name + '): ' + (message ?? ''), ...optionalParams);
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
return console.log(new Date().toISOString() + ' [' + level + '] (' + this.name + '): ' + (message ?? ''));
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
exports.ConsoleLogger = ConsoleLogger;
|
|
37
|
+
//# sourceMappingURL=console-logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"console-logger.js","sourceRoot":"","sources":["../../../../src/services/logs/loggers/console-logger.ts"],"names":[],"mappings":";;;AACA,oCAA0C;AAE1C,MAAa,aAAa;IACxB,YAA6B,IAAY,EAAmB,KAAe;QAA9C,SAAI,GAAJ,IAAI,CAAQ;QAAmB,UAAK,GAAL,KAAK,CAAU;IAAG,CAAC;IAE/E,GAAG,CAAC,OAAa,EAAE,GAAG,cAAqB;QACzC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,EAAE,cAAc,CAAC,CAAC;IAC7C,CAAC;IAED,KAAK,CAAC,OAAa,EAAE,GAAG,cAAqB;QAC3C,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,cAAc,CAAC,CAAC;IAC/C,CAAC;IAED,IAAI,CAAC,OAAa,EAAE,GAAG,cAAqB;QAC1C,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,EAAE,cAAc,CAAC,CAAC;IAC9C,CAAC;IAED,IAAI,CAAC,OAAa,EAAE,GAAG,cAAqB;QAC1C,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,EAAE,cAAc,CAAC,CAAC;IAC9C,CAAC;IAED,KAAK,CAAC,OAAa,EAAE,GAAG,cAAqB;QAC3C,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,cAAc,CAAC,CAAC;IAC/C,CAAC;IAEO,KAAK,CAAC,KAAe,EAAE,OAAwB,EAAE,cAAqB;QAC5E,IAAI,IAAA,sBAAc,EAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YACtC,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC9B,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,GAAG,IAAI,GAAG,KAAK,GAAG,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,KAAK,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE,GAAG,cAAc,CAAC,CAAC;YAC/H,CAAC;iBAAM,CAAC;gBACN,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,GAAG,IAAI,GAAG,KAAK,GAAG,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,KAAK,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,CAAC;YAC5G,CAAC;QACH,CAAC;IACH,CAAC;CACF;AAhCD,sCAgCC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LogsService = void 0;
|
|
4
|
+
const console_logger_1 = require("./loggers/console-logger");
|
|
5
|
+
class LogsService {
|
|
6
|
+
constructor(defaultLevel) {
|
|
7
|
+
this.defaultLevel = defaultLevel;
|
|
8
|
+
}
|
|
9
|
+
getLogger({ name }) {
|
|
10
|
+
return new console_logger_1.ConsoleLogger(name, this.defaultLevel);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.LogsService = LogsService;
|
|
14
|
+
//# sourceMappingURL=logs-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logs-service.js","sourceRoot":"","sources":["../../../src/services/logs/logs-service.ts"],"names":[],"mappings":";;;AACA,6DAAyD;AAEzD,MAAa,WAAW;IACtB,YAA6B,YAAsB;QAAtB,iBAAY,GAAZ,YAAY,CAAU;IAAG,CAAC;IAEvD,SAAS,CAAC,EAAE,IAAI,EAAoB;QAClC,OAAO,IAAI,8BAAa,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IACpD,CAAC;CACF;AAND,kCAMC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export type LogLevel = 'ALL' | 'LOG' | 'DEBUG' | 'INFO' | 'WARN' | 'ERROR' | 'OFF';
|
|
2
|
+
export type ILogsService = {
|
|
3
|
+
getLogger({ name }: {
|
|
4
|
+
name: string;
|
|
5
|
+
}): ILogger;
|
|
6
|
+
};
|
|
7
|
+
export type ILogger = {
|
|
8
|
+
log(message?: any, ...optionalParams: any[]): void;
|
|
9
|
+
debug(message?: any, ...optionalParams: any[]): void;
|
|
10
|
+
info(message?: any, ...optionalParams: any[]): void;
|
|
11
|
+
warn(message?: any, ...optionalParams: any[]): void;
|
|
12
|
+
error(message?: any, ...optionalParams: any[]): void;
|
|
13
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/services/logs/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.shouldPrintLog = void 0;
|
|
4
|
+
function shouldPrintLog(logType, currentLevel) {
|
|
5
|
+
return getLogPriority(logType) >= getLogPriority(currentLevel);
|
|
6
|
+
}
|
|
7
|
+
exports.shouldPrintLog = shouldPrintLog;
|
|
8
|
+
function getLogPriority(level) {
|
|
9
|
+
switch (level) {
|
|
10
|
+
case 'ALL':
|
|
11
|
+
return 0;
|
|
12
|
+
case 'LOG':
|
|
13
|
+
case 'DEBUG':
|
|
14
|
+
return 10;
|
|
15
|
+
case 'INFO':
|
|
16
|
+
return 20;
|
|
17
|
+
case 'WARN':
|
|
18
|
+
return 30;
|
|
19
|
+
case 'ERROR':
|
|
20
|
+
return 40;
|
|
21
|
+
case 'OFF':
|
|
22
|
+
return Infinity;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/services/logs/utils.ts"],"names":[],"mappings":";;;AAEA,SAAgB,cAAc,CAAC,OAAiB,EAAE,YAAsB;IACtE,OAAO,cAAc,CAAC,OAAO,CAAC,IAAI,cAAc,CAAC,YAAY,CAAC,CAAC;AACjE,CAAC;AAFD,wCAEC;AAED,SAAS,cAAc,CAAC,KAAe;IACrC,QAAQ,KAAK,EAAE,CAAC;QACd,KAAK,KAAK;YACR,OAAO,CAAC,CAAC;QACX,KAAK,KAAK,CAAC;QACX,KAAK,OAAO;YACV,OAAO,EAAE,CAAC;QACZ,KAAK,MAAM;YACT,OAAO,EAAE,CAAC;QACZ,KAAK,MAAM;YACT,OAAO,EAAE,CAAC;QACZ,KAAK,OAAO;YACV,OAAO,EAAE,CAAC;QACZ,KAAK,KAAK;YACR,OAAO,QAAQ,CAAC;IACpB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { IMetadataService, IMetadataSource, MetadataResult, MetadataInput } from './types';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/metadata/index.ts"],"names":[],"mappings":""}
|