@fanx-protocol/smart-order-router 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +255 -0
- package/LICENSE +674 -0
- package/README.md +273 -0
- package/build/main/index.d.ts +3 -0
- package/build/main/index.js +20 -0
- package/build/main/providers/cache-node.d.ts +10 -0
- package/build/main/providers/cache-node.js +33 -0
- package/build/main/providers/cache.d.ts +14 -0
- package/build/main/providers/cache.js +3 -0
- package/build/main/providers/caching/route/index.d.ts +2 -0
- package/build/main/providers/caching/route/index.js +19 -0
- package/build/main/providers/caching/route/model/cache-mode.d.ts +16 -0
- package/build/main/providers/caching/route/model/cache-mode.js +21 -0
- package/build/main/providers/caching/route/model/cached-route.d.ts +29 -0
- package/build/main/providers/caching/route/model/cached-route.js +89 -0
- package/build/main/providers/caching/route/model/cached-routes.d.ts +67 -0
- package/build/main/providers/caching/route/model/cached-routes.js +81 -0
- package/build/main/providers/caching/route/model/index.d.ts +3 -0
- package/build/main/providers/caching/route/model/index.js +20 -0
- package/build/main/providers/caching/route/route-caching-provider.d.ts +88 -0
- package/build/main/providers/caching/route/route-caching-provider.js +72 -0
- package/build/main/providers/caching-gas-provider.d.ts +23 -0
- package/build/main/providers/caching-gas-provider.js +41 -0
- package/build/main/providers/caching-subgraph-provider.d.ts +33 -0
- package/build/main/providers/caching-subgraph-provider.js +37 -0
- package/build/main/providers/caching-token-list-provider.d.ts +52 -0
- package/build/main/providers/caching-token-list-provider.js +147 -0
- package/build/main/providers/caching-token-provider.d.ts +24 -0
- package/build/main/providers/caching-token-provider.js +108 -0
- package/build/main/providers/eip-1559-gas-price-provider.d.ts +31 -0
- package/build/main/providers/eip-1559-gas-price-provider.js +71 -0
- package/build/main/providers/eth-estimate-gas-provider.d.ts +19 -0
- package/build/main/providers/eth-estimate-gas-provider.js +94 -0
- package/build/main/providers/eth-gas-station-info-gas-price-provider.d.ts +19 -0
- package/build/main/providers/eth-gas-station-info-gas-price-provider.js +36 -0
- package/build/main/providers/gas-price-provider.d.ts +10 -0
- package/build/main/providers/gas-price-provider.js +10 -0
- package/build/main/providers/index.d.ts +38 -0
- package/build/main/providers/index.js +55 -0
- package/build/main/providers/legacy-gas-price-provider.d.ts +7 -0
- package/build/main/providers/legacy-gas-price-provider.js +18 -0
- package/build/main/providers/multicall-provider.d.ts +83 -0
- package/build/main/providers/multicall-provider.js +15 -0
- package/build/main/providers/multicall-uniswap-provider.d.ts +37 -0
- package/build/main/providers/multicall-uniswap-provider.js +164 -0
- package/build/main/providers/on-chain-gas-price-provider.d.ts +19 -0
- package/build/main/providers/on-chain-gas-price-provider.js +36 -0
- package/build/main/providers/on-chain-quote-provider.d.ts +258 -0
- package/build/main/providers/on-chain-quote-provider.js +693 -0
- package/build/main/providers/pool-provider.d.ts +44 -0
- package/build/main/providers/pool-provider.js +73 -0
- package/build/main/providers/portion-provider.d.ts +86 -0
- package/build/main/providers/portion-provider.js +118 -0
- package/build/main/providers/provider.d.ts +38 -0
- package/build/main/providers/provider.js +3 -0
- package/build/main/providers/simulation-provider.d.ts +43 -0
- package/build/main/providers/simulation-provider.js +136 -0
- package/build/main/providers/static-gas-price-provider.d.ts +7 -0
- package/build/main/providers/static-gas-price-provider.js +13 -0
- package/build/main/providers/subgraph-provider-with-fallback.d.ts +11 -0
- package/build/main/providers/subgraph-provider-with-fallback.js +25 -0
- package/build/main/providers/subgraph-provider.d.ts +51 -0
- package/build/main/providers/subgraph-provider.js +120 -0
- package/build/main/providers/swap-router-provider.d.ts +30 -0
- package/build/main/providers/swap-router-provider.js +42 -0
- package/build/main/providers/token-fee-fetcher.d.ts +31 -0
- package/build/main/providers/token-fee-fetcher.js +108 -0
- package/build/main/providers/token-properties-provider.d.ts +31 -0
- package/build/main/providers/token-properties-provider.js +118 -0
- package/build/main/providers/token-provider.d.ts +38 -0
- package/build/main/providers/token-provider.js +175 -0
- package/build/main/providers/token-validator-provider.d.ts +42 -0
- package/build/main/providers/token-validator-provider.js +99 -0
- package/build/main/providers/uri-subgraph-provider.d.ts +20 -0
- package/build/main/providers/uri-subgraph-provider.js +65 -0
- package/build/main/providers/v2/caching-pool-provider.d.ts +33 -0
- package/build/main/providers/v2/caching-pool-provider.js +89 -0
- package/build/main/providers/v2/caching-subgraph-provider.d.ts +19 -0
- package/build/main/providers/v2/caching-subgraph-provider.js +24 -0
- package/build/main/providers/v2/pool-provider.d.ts +63 -0
- package/build/main/providers/v2/pool-provider.js +138 -0
- package/build/main/providers/v2/quote-provider.d.ts +34 -0
- package/build/main/providers/v2/quote-provider.js +90 -0
- package/build/main/providers/v2/static-subgraph-provider.d.ts +19 -0
- package/build/main/providers/v2/static-subgraph-provider.js +75 -0
- package/build/main/providers/v2/subgraph-provider-with-fallback.d.ts +16 -0
- package/build/main/providers/v2/subgraph-provider-with-fallback.js +23 -0
- package/build/main/providers/v2/subgraph-provider.d.ts +36 -0
- package/build/main/providers/v2/subgraph-provider.js +174 -0
- package/build/main/providers/v2/uri-subgraph-provider.d.ts +4 -0
- package/build/main/providers/v2/uri-subgraph-provider.js +8 -0
- package/build/main/providers/v3/caching-pool-provider.d.ts +32 -0
- package/build/main/providers/v3/caching-pool-provider.js +84 -0
- package/build/main/providers/v3/caching-subgraph-provider.d.ts +19 -0
- package/build/main/providers/v3/caching-subgraph-provider.js +24 -0
- package/build/main/providers/v3/gas-data-provider.d.ts +39 -0
- package/build/main/providers/v3/gas-data-provider.js +26 -0
- package/build/main/providers/v3/pool-provider.d.ts +77 -0
- package/build/main/providers/v3/pool-provider.js +108 -0
- package/build/main/providers/v3/static-subgraph-provider.d.ts +21 -0
- package/build/main/providers/v3/static-subgraph-provider.js +89 -0
- package/build/main/providers/v3/subgraph-provider-with-fallback.d.ts +12 -0
- package/build/main/providers/v3/subgraph-provider-with-fallback.js +19 -0
- package/build/main/providers/v3/subgraph-provider.d.ts +46 -0
- package/build/main/providers/v3/subgraph-provider.js +54 -0
- package/build/main/providers/v3/uri-subgraph-provider.d.ts +4 -0
- package/build/main/providers/v3/uri-subgraph-provider.js +8 -0
- package/build/main/routers/alpha-router/alpha-router.d.ts +347 -0
- package/build/main/routers/alpha-router/alpha-router.js +1219 -0
- package/build/main/routers/alpha-router/config.d.ts +4 -0
- package/build/main/routers/alpha-router/config.js +40 -0
- package/build/main/routers/alpha-router/entities/index.d.ts +1 -0
- package/build/main/routers/alpha-router/entities/index.js +18 -0
- package/build/main/routers/alpha-router/entities/route-with-valid-quote.d.ts +167 -0
- package/build/main/routers/alpha-router/entities/route-with-valid-quote.js +166 -0
- package/build/main/routers/alpha-router/functions/best-swap-route.d.ts +22 -0
- package/build/main/routers/alpha-router/functions/best-swap-route.js +534 -0
- package/build/main/routers/alpha-router/functions/calculate-ratio-amount-in.d.ts +3 -0
- package/build/main/routers/alpha-router/functions/calculate-ratio-amount-in.js +18 -0
- package/build/main/routers/alpha-router/functions/compute-all-routes.d.ts +9 -0
- package/build/main/routers/alpha-router/functions/compute-all-routes.js +104 -0
- package/build/main/routers/alpha-router/functions/get-candidate-pools.d.ts +100 -0
- package/build/main/routers/alpha-router/functions/get-candidate-pools.js +1008 -0
- package/build/main/routers/alpha-router/gas-models/gas-costs.d.ts +12 -0
- package/build/main/routers/alpha-router/gas-models/gas-costs.js +90 -0
- package/build/main/routers/alpha-router/gas-models/gas-model.d.ts +106 -0
- package/build/main/routers/alpha-router/gas-models/gas-model.js +68 -0
- package/build/main/routers/alpha-router/gas-models/index.d.ts +2 -0
- package/build/main/routers/alpha-router/gas-models/index.js +19 -0
- package/build/main/routers/alpha-router/gas-models/mixedRoute/mixed-route-heuristic-gas-model.d.ts +24 -0
- package/build/main/routers/alpha-router/gas-models/mixedRoute/mixed-route-heuristic-gas-model.js +161 -0
- package/build/main/routers/alpha-router/gas-models/tick-based-heuristic-gas-model.d.ts +15 -0
- package/build/main/routers/alpha-router/gas-models/tick-based-heuristic-gas-model.js +185 -0
- package/build/main/routers/alpha-router/gas-models/v2/v2-heuristic-gas-model.d.ts +31 -0
- package/build/main/routers/alpha-router/gas-models/v2/v2-heuristic-gas-model.js +169 -0
- package/build/main/routers/alpha-router/gas-models/v3/v3-heuristic-gas-model.d.ts +26 -0
- package/build/main/routers/alpha-router/gas-models/v3/v3-heuristic-gas-model.js +41 -0
- package/build/main/routers/alpha-router/index.d.ts +4 -0
- package/build/main/routers/alpha-router/index.js +21 -0
- package/build/main/routers/alpha-router/quoters/base-quoter.d.ts +76 -0
- package/build/main/routers/alpha-router/quoters/base-quoter.js +76 -0
- package/build/main/routers/alpha-router/quoters/index.d.ts +5 -0
- package/build/main/routers/alpha-router/quoters/index.js +22 -0
- package/build/main/routers/alpha-router/quoters/mixed-quoter.d.ts +28 -0
- package/build/main/routers/alpha-router/quoters/mixed-quoter.js +154 -0
- package/build/main/routers/alpha-router/quoters/model/index.d.ts +1 -0
- package/build/main/routers/alpha-router/quoters/model/index.js +18 -0
- package/build/main/routers/alpha-router/quoters/model/results/get-quotes-result.d.ts +6 -0
- package/build/main/routers/alpha-router/quoters/model/results/get-quotes-result.js +3 -0
- package/build/main/routers/alpha-router/quoters/model/results/get-routes-result.d.ts +6 -0
- package/build/main/routers/alpha-router/quoters/model/results/get-routes-result.js +3 -0
- package/build/main/routers/alpha-router/quoters/model/results/index.d.ts +2 -0
- package/build/main/routers/alpha-router/quoters/model/results/index.js +19 -0
- package/build/main/routers/alpha-router/quoters/v2-quoter.d.ts +24 -0
- package/build/main/routers/alpha-router/quoters/v2-quoter.js +140 -0
- package/build/main/routers/alpha-router/quoters/v3-quoter.d.ts +19 -0
- package/build/main/routers/alpha-router/quoters/v3-quoter.js +117 -0
- package/build/main/routers/index.d.ts +3 -0
- package/build/main/routers/index.js +20 -0
- package/build/main/routers/router.d.ts +186 -0
- package/build/main/routers/router.js +55 -0
- package/build/main/tsconfig.tsbuildinfo +1 -0
- package/build/main/types/other/commons.d.ts +16 -0
- package/build/main/types/other/commons.js +6 -0
- package/build/main/types/other/factories/Erc20__factory.d.ts +45 -0
- package/build/main/types/other/factories/Erc20__factory.js +240 -0
- package/build/main/types/other/factories/GasDataArbitrum__factory.d.ts +18 -0
- package/build/main/types/other/factories/GasDataArbitrum__factory.js +58 -0
- package/build/main/types/other/factories/IMixedRouteQuoterV1__factory.d.ts +41 -0
- package/build/main/types/other/factories/IMixedRouteQuoterV1__factory.js +156 -0
- package/build/main/types/other/factories/ITokenValidator__factory.d.ts +22 -0
- package/build/main/types/other/factories/ITokenValidator__factory.js +78 -0
- package/build/main/types/other/factories/MixedRouteQuoterV2__factory.d.ts +86 -0
- package/build/main/types/other/factories/MixedRouteQuoterV2__factory.js +477 -0
- package/build/main/types/other/factories/Permit2__factory.d.ts +87 -0
- package/build/main/types/other/factories/Permit2__factory.js +936 -0
- package/build/main/types/other/factories/SwapRouter02__factory.d.ts +67 -0
- package/build/main/types/other/factories/SwapRouter02__factory.js +1098 -0
- package/build/main/types/other/factories/TokenFeeDetector__factory.d.ts +47 -0
- package/build/main/types/other/factories/TokenFeeDetector__factory.js +243 -0
- package/build/main/types/v2/commons.d.ts +16 -0
- package/build/main/types/v2/commons.js +6 -0
- package/build/main/types/v2/factories/IUniswapV2Pair__factory.d.ts +35 -0
- package/build/main/types/v2/factories/IUniswapV2Pair__factory.js +671 -0
- package/build/main/types/v3/commons.d.ts +16 -0
- package/build/main/types/v3/commons.js +6 -0
- package/build/main/types/v3/factories/IERC20Metadata__factory.d.ts +35 -0
- package/build/main/types/v3/factories/IERC20Metadata__factory.js +242 -0
- package/build/main/types/v3/factories/IQuoterV2__factory.d.ts +41 -0
- package/build/main/types/v3/factories/IQuoterV2__factory.js +220 -0
- package/build/main/types/v3/factories/IUniswapV3PoolState__factory.d.ts +22 -0
- package/build/main/types/v3/factories/IUniswapV3PoolState__factory.js +266 -0
- package/build/main/types/v3/factories/UniswapInterfaceMulticall__factory.d.ts +61 -0
- package/build/main/types/v3/factories/UniswapInterfaceMulticall__factory.js +127 -0
- package/build/main/util/addresses.d.ts +24 -0
- package/build/main/util/addresses.js +76 -0
- package/build/main/util/amounts.d.ts +9 -0
- package/build/main/util/amounts.js +73 -0
- package/build/main/util/chains.d.ts +31 -0
- package/build/main/util/chains.js +97 -0
- package/build/main/util/gas-factory-helpers.d.ts +33 -0
- package/build/main/util/gas-factory-helpers.js +463 -0
- package/build/main/util/index.d.ts +7 -0
- package/build/main/util/index.js +24 -0
- package/build/main/util/l2FeeChains.d.ts +2 -0
- package/build/main/util/l2FeeChains.js +13 -0
- package/build/main/util/log.d.ts +3 -0
- package/build/main/util/log.js +97 -0
- package/build/main/util/methodParameters.d.ts +5 -0
- package/build/main/util/methodParameters.js +183 -0
- package/build/main/util/metric.d.ts +48 -0
- package/build/main/util/metric.js +59 -0
- package/build/main/util/onchainQuoteProviderConfigs.d.ts +42 -0
- package/build/main/util/onchainQuoteProviderConfigs.js +74 -0
- package/build/main/util/protocols.d.ts +2 -0
- package/build/main/util/protocols.js +20 -0
- package/build/main/util/routes.d.ts +11 -0
- package/build/main/util/routes.js +149 -0
- package/build/main/util/unsupported-tokens.d.ts +37 -0
- package/build/main/util/unsupported-tokens.js +1119 -0
- package/build/module/index.d.ts +3 -0
- package/build/module/index.js +4 -0
- package/build/module/providers/cache-node.d.ts +10 -0
- package/build/module/providers/cache-node.js +29 -0
- package/build/module/providers/cache.d.ts +14 -0
- package/build/module/providers/cache.js +2 -0
- package/build/module/providers/caching/route/index.d.ts +2 -0
- package/build/module/providers/caching/route/index.js +3 -0
- package/build/module/providers/caching/route/model/cache-mode.d.ts +16 -0
- package/build/module/providers/caching/route/model/cache-mode.js +18 -0
- package/build/module/providers/caching/route/model/cached-route.d.ts +29 -0
- package/build/module/providers/caching/route/model/cached-route.js +85 -0
- package/build/module/providers/caching/route/model/cached-routes.d.ts +67 -0
- package/build/module/providers/caching/route/model/cached-routes.js +74 -0
- package/build/module/providers/caching/route/model/index.d.ts +3 -0
- package/build/module/providers/caching/route/model/index.js +4 -0
- package/build/module/providers/caching/route/route-caching-provider.d.ts +88 -0
- package/build/module/providers/caching/route/route-caching-provider.js +68 -0
- package/build/module/providers/caching-gas-provider.d.ts +23 -0
- package/build/module/providers/caching-gas-provider.js +37 -0
- package/build/module/providers/caching-subgraph-provider.d.ts +33 -0
- package/build/module/providers/caching-subgraph-provider.js +33 -0
- package/build/module/providers/caching-token-list-provider.d.ts +52 -0
- package/build/module/providers/caching-token-list-provider.js +140 -0
- package/build/module/providers/caching-token-provider.d.ts +24 -0
- package/build/module/providers/caching-token-provider.js +101 -0
- package/build/module/providers/eip-1559-gas-price-provider.d.ts +31 -0
- package/build/module/providers/eip-1559-gas-price-provider.js +64 -0
- package/build/module/providers/eth-estimate-gas-provider.d.ts +19 -0
- package/build/module/providers/eth-estimate-gas-provider.js +102 -0
- package/build/module/providers/eth-gas-station-info-gas-price-provider.d.ts +19 -0
- package/build/module/providers/eth-gas-station-info-gas-price-provider.js +29 -0
- package/build/module/providers/gas-price-provider.d.ts +10 -0
- package/build/module/providers/gas-price-provider.js +6 -0
- package/build/module/providers/index.d.ts +38 -0
- package/build/module/providers/index.js +39 -0
- package/build/module/providers/legacy-gas-price-provider.d.ts +7 -0
- package/build/module/providers/legacy-gas-price-provider.js +14 -0
- package/build/module/providers/multicall-provider.d.ts +83 -0
- package/build/module/providers/multicall-provider.js +11 -0
- package/build/module/providers/multicall-uniswap-provider.d.ts +37 -0
- package/build/module/providers/multicall-uniswap-provider.js +157 -0
- package/build/module/providers/on-chain-gas-price-provider.d.ts +19 -0
- package/build/module/providers/on-chain-gas-price-provider.js +32 -0
- package/build/module/providers/on-chain-quote-provider.d.ts +258 -0
- package/build/module/providers/on-chain-quote-provider.js +687 -0
- package/build/module/providers/pool-provider.d.ts +44 -0
- package/build/module/providers/pool-provider.js +66 -0
- package/build/module/providers/portion-provider.d.ts +86 -0
- package/build/module/providers/portion-provider.js +114 -0
- package/build/module/providers/provider.d.ts +38 -0
- package/build/module/providers/provider.js +2 -0
- package/build/module/providers/simulation-provider.d.ts +43 -0
- package/build/module/providers/simulation-provider.js +138 -0
- package/build/module/providers/static-gas-price-provider.d.ts +7 -0
- package/build/module/providers/static-gas-price-provider.js +9 -0
- package/build/module/providers/subgraph-provider-with-fallback.d.ts +11 -0
- package/build/module/providers/subgraph-provider-with-fallback.js +21 -0
- package/build/module/providers/subgraph-provider.d.ts +51 -0
- package/build/module/providers/subgraph-provider.js +113 -0
- package/build/module/providers/swap-router-provider.d.ts +30 -0
- package/build/module/providers/swap-router-provider.js +38 -0
- package/build/module/providers/token-fee-fetcher.d.ts +31 -0
- package/build/module/providers/token-fee-fetcher.js +104 -0
- package/build/module/providers/token-properties-provider.d.ts +31 -0
- package/build/module/providers/token-properties-provider.js +114 -0
- package/build/module/providers/token-provider.d.ts +38 -0
- package/build/module/providers/token-provider.js +164 -0
- package/build/module/providers/token-validator-provider.d.ts +42 -0
- package/build/module/providers/token-validator-provider.js +92 -0
- package/build/module/providers/uri-subgraph-provider.d.ts +20 -0
- package/build/module/providers/uri-subgraph-provider.js +58 -0
- package/build/module/providers/v2/caching-pool-provider.d.ts +33 -0
- package/build/module/providers/v2/caching-pool-provider.js +85 -0
- package/build/module/providers/v2/caching-subgraph-provider.d.ts +19 -0
- package/build/module/providers/v2/caching-subgraph-provider.js +20 -0
- package/build/module/providers/v2/pool-provider.d.ts +63 -0
- package/build/module/providers/v2/pool-provider.js +131 -0
- package/build/module/providers/v2/quote-provider.d.ts +34 -0
- package/build/module/providers/v2/quote-provider.js +86 -0
- package/build/module/providers/v2/static-subgraph-provider.d.ts +19 -0
- package/build/module/providers/v2/static-subgraph-provider.js +68 -0
- package/build/module/providers/v2/subgraph-provider-with-fallback.d.ts +16 -0
- package/build/module/providers/v2/subgraph-provider-with-fallback.js +19 -0
- package/build/module/providers/v2/subgraph-provider.d.ts +36 -0
- package/build/module/providers/v2/subgraph-provider.js +167 -0
- package/build/module/providers/v2/uri-subgraph-provider.d.ts +4 -0
- package/build/module/providers/v2/uri-subgraph-provider.js +4 -0
- package/build/module/providers/v3/caching-pool-provider.d.ts +32 -0
- package/build/module/providers/v3/caching-pool-provider.js +77 -0
- package/build/module/providers/v3/caching-subgraph-provider.d.ts +19 -0
- package/build/module/providers/v3/caching-subgraph-provider.js +20 -0
- package/build/module/providers/v3/gas-data-provider.d.ts +39 -0
- package/build/module/providers/v3/gas-data-provider.js +22 -0
- package/build/module/providers/v3/pool-provider.d.ts +77 -0
- package/build/module/providers/v3/pool-provider.js +101 -0
- package/build/module/providers/v3/static-subgraph-provider.d.ts +21 -0
- package/build/module/providers/v3/static-subgraph-provider.js +82 -0
- package/build/module/providers/v3/subgraph-provider-with-fallback.d.ts +12 -0
- package/build/module/providers/v3/subgraph-provider-with-fallback.js +15 -0
- package/build/module/providers/v3/subgraph-provider.d.ts +46 -0
- package/build/module/providers/v3/subgraph-provider.js +50 -0
- package/build/module/providers/v3/uri-subgraph-provider.d.ts +4 -0
- package/build/module/providers/v3/uri-subgraph-provider.js +4 -0
- package/build/module/routers/alpha-router/alpha-router.d.ts +347 -0
- package/build/module/routers/alpha-router/alpha-router.js +1229 -0
- package/build/module/routers/alpha-router/config.d.ts +4 -0
- package/build/module/routers/alpha-router/config.js +36 -0
- package/build/module/routers/alpha-router/entities/index.d.ts +1 -0
- package/build/module/routers/alpha-router/entities/index.js +2 -0
- package/build/module/routers/alpha-router/entities/route-with-valid-quote.d.ts +167 -0
- package/build/module/routers/alpha-router/entities/route-with-valid-quote.js +157 -0
- package/build/module/routers/alpha-router/functions/best-swap-route.d.ts +22 -0
- package/build/module/routers/alpha-router/functions/best-swap-route.js +526 -0
- package/build/module/routers/alpha-router/functions/calculate-ratio-amount-in.d.ts +3 -0
- package/build/module/routers/alpha-router/functions/calculate-ratio-amount-in.js +14 -0
- package/build/module/routers/alpha-router/functions/compute-all-routes.d.ts +9 -0
- package/build/module/routers/alpha-router/functions/compute-all-routes.js +97 -0
- package/build/module/routers/alpha-router/functions/get-candidate-pools.d.ts +100 -0
- package/build/module/routers/alpha-router/functions/get-candidate-pools.js +998 -0
- package/build/module/routers/alpha-router/gas-models/gas-costs.d.ts +12 -0
- package/build/module/routers/alpha-router/gas-models/gas-costs.js +79 -0
- package/build/module/routers/alpha-router/gas-models/gas-model.d.ts +106 -0
- package/build/module/routers/alpha-router/gas-models/gas-model.js +102 -0
- package/build/module/routers/alpha-router/gas-models/index.d.ts +2 -0
- package/build/module/routers/alpha-router/gas-models/index.js +3 -0
- package/build/module/routers/alpha-router/gas-models/mixedRoute/mixed-route-heuristic-gas-model.d.ts +24 -0
- package/build/module/routers/alpha-router/gas-models/mixedRoute/mixed-route-heuristic-gas-model.js +154 -0
- package/build/module/routers/alpha-router/gas-models/tick-based-heuristic-gas-model.d.ts +15 -0
- package/build/module/routers/alpha-router/gas-models/tick-based-heuristic-gas-model.js +181 -0
- package/build/module/routers/alpha-router/gas-models/v2/v2-heuristic-gas-model.d.ts +31 -0
- package/build/module/routers/alpha-router/gas-models/v2/v2-heuristic-gas-model.js +162 -0
- package/build/module/routers/alpha-router/gas-models/v3/v3-heuristic-gas-model.d.ts +26 -0
- package/build/module/routers/alpha-router/gas-models/v3/v3-heuristic-gas-model.js +37 -0
- package/build/module/routers/alpha-router/index.d.ts +4 -0
- package/build/module/routers/alpha-router/index.js +5 -0
- package/build/module/routers/alpha-router/quoters/base-quoter.d.ts +76 -0
- package/build/module/routers/alpha-router/quoters/base-quoter.js +69 -0
- package/build/module/routers/alpha-router/quoters/index.d.ts +5 -0
- package/build/module/routers/alpha-router/quoters/index.js +6 -0
- package/build/module/routers/alpha-router/quoters/mixed-quoter.d.ts +28 -0
- package/build/module/routers/alpha-router/quoters/mixed-quoter.js +152 -0
- package/build/module/routers/alpha-router/quoters/model/index.d.ts +1 -0
- package/build/module/routers/alpha-router/quoters/model/index.js +2 -0
- package/build/module/routers/alpha-router/quoters/model/results/get-quotes-result.d.ts +6 -0
- package/build/module/routers/alpha-router/quoters/model/results/get-quotes-result.js +2 -0
- package/build/module/routers/alpha-router/quoters/model/results/get-routes-result.d.ts +6 -0
- package/build/module/routers/alpha-router/quoters/model/results/get-routes-result.js +2 -0
- package/build/module/routers/alpha-router/quoters/model/results/index.d.ts +2 -0
- package/build/module/routers/alpha-router/quoters/model/results/index.js +3 -0
- package/build/module/routers/alpha-router/quoters/v2-quoter.d.ts +24 -0
- package/build/module/routers/alpha-router/quoters/v2-quoter.js +137 -0
- package/build/module/routers/alpha-router/quoters/v3-quoter.d.ts +19 -0
- package/build/module/routers/alpha-router/quoters/v3-quoter.js +110 -0
- package/build/module/routers/index.d.ts +3 -0
- package/build/module/routers/index.js +4 -0
- package/build/module/routers/router.d.ts +186 -0
- package/build/module/routers/router.js +47 -0
- package/build/module/tsconfig.module.tsbuildinfo +1 -0
- package/build/module/types/other/commons.d.ts +16 -0
- package/build/module/types/other/commons.js +5 -0
- package/build/module/types/other/factories/Erc20__factory.d.ts +45 -0
- package/build/module/types/other/factories/Erc20__factory.js +236 -0
- package/build/module/types/other/factories/GasDataArbitrum__factory.d.ts +18 -0
- package/build/module/types/other/factories/GasDataArbitrum__factory.js +54 -0
- package/build/module/types/other/factories/IMixedRouteQuoterV1__factory.d.ts +41 -0
- package/build/module/types/other/factories/IMixedRouteQuoterV1__factory.js +152 -0
- package/build/module/types/other/factories/ITokenValidator__factory.d.ts +22 -0
- package/build/module/types/other/factories/ITokenValidator__factory.js +74 -0
- package/build/module/types/other/factories/MixedRouteQuoterV2__factory.d.ts +86 -0
- package/build/module/types/other/factories/MixedRouteQuoterV2__factory.js +473 -0
- package/build/module/types/other/factories/Permit2__factory.d.ts +87 -0
- package/build/module/types/other/factories/Permit2__factory.js +932 -0
- package/build/module/types/other/factories/SwapRouter02__factory.d.ts +67 -0
- package/build/module/types/other/factories/SwapRouter02__factory.js +1094 -0
- package/build/module/types/other/factories/TokenFeeDetector__factory.d.ts +47 -0
- package/build/module/types/other/factories/TokenFeeDetector__factory.js +239 -0
- package/build/module/types/v2/commons.d.ts +16 -0
- package/build/module/types/v2/commons.js +5 -0
- package/build/module/types/v2/factories/IUniswapV2Pair__factory.d.ts +35 -0
- package/build/module/types/v2/factories/IUniswapV2Pair__factory.js +667 -0
- package/build/module/types/v3/commons.d.ts +16 -0
- package/build/module/types/v3/commons.js +5 -0
- package/build/module/types/v3/factories/IERC20Metadata__factory.d.ts +35 -0
- package/build/module/types/v3/factories/IERC20Metadata__factory.js +238 -0
- package/build/module/types/v3/factories/IQuoterV2__factory.d.ts +41 -0
- package/build/module/types/v3/factories/IQuoterV2__factory.js +216 -0
- package/build/module/types/v3/factories/IUniswapV3PoolState__factory.d.ts +22 -0
- package/build/module/types/v3/factories/IUniswapV3PoolState__factory.js +262 -0
- package/build/module/types/v3/factories/UniswapInterfaceMulticall__factory.d.ts +61 -0
- package/build/module/types/v3/factories/UniswapInterfaceMulticall__factory.js +123 -0
- package/build/module/util/addresses.d.ts +24 -0
- package/build/module/util/addresses.js +69 -0
- package/build/module/util/amounts.d.ts +9 -0
- package/build/module/util/amounts.js +62 -0
- package/build/module/util/chains.d.ts +31 -0
- package/build/module/util/chains.js +89 -0
- package/build/module/util/gas-factory-helpers.d.ts +33 -0
- package/build/module/util/gas-factory-helpers.js +446 -0
- package/build/module/util/index.d.ts +7 -0
- package/build/module/util/index.js +8 -0
- package/build/module/util/l2FeeChains.d.ts +2 -0
- package/build/module/util/l2FeeChains.js +10 -0
- package/build/module/util/log.d.ts +3 -0
- package/build/module/util/log.js +93 -0
- package/build/module/util/methodParameters.d.ts +5 -0
- package/build/module/util/methodParameters.js +181 -0
- package/build/module/util/metric.d.ts +48 -0
- package/build/module/util/metric.js +53 -0
- package/build/module/util/onchainQuoteProviderConfigs.d.ts +42 -0
- package/build/module/util/onchainQuoteProviderConfigs.js +76 -0
- package/build/module/util/protocols.d.ts +2 -0
- package/build/module/util/protocols.js +16 -0
- package/build/module/util/routes.d.ts +11 -0
- package/build/module/util/routes.js +137 -0
- package/build/module/util/unsupported-tokens.d.ts +37 -0
- package/build/module/util/unsupported-tokens.js +1116 -0
- package/package.json +133 -0
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { BigNumber } from '@ethersproject/bignumber';
|
|
2
|
+
import { ChainId, Currency } from '@fanx-protocol/sdk-core';
|
|
3
|
+
import { V3Route } from '../../router';
|
|
4
|
+
export declare const COST_PER_UNINIT_TICK: BigNumber;
|
|
5
|
+
export declare const BASE_SWAP_COST: (id: ChainId) => BigNumber;
|
|
6
|
+
export declare const COST_PER_INIT_TICK: (id: ChainId) => BigNumber;
|
|
7
|
+
export declare const COST_PER_HOP: (id: ChainId) => BigNumber;
|
|
8
|
+
export declare const SINGLE_HOP_OVERHEAD: (_id: ChainId) => BigNumber;
|
|
9
|
+
export declare const TOKEN_OVERHEAD: (_id: ChainId, _route: V3Route) => BigNumber;
|
|
10
|
+
export declare const NATIVE_WRAP_OVERHEAD: (id: ChainId) => BigNumber;
|
|
11
|
+
export declare const NATIVE_UNWRAP_OVERHEAD: (id: ChainId) => BigNumber;
|
|
12
|
+
export declare const NATIVE_OVERHEAD: (chainId: ChainId, amount: Currency, quote: Currency) => BigNumber;
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NATIVE_OVERHEAD = exports.NATIVE_UNWRAP_OVERHEAD = exports.NATIVE_WRAP_OVERHEAD = exports.TOKEN_OVERHEAD = exports.SINGLE_HOP_OVERHEAD = exports.COST_PER_HOP = exports.COST_PER_INIT_TICK = exports.BASE_SWAP_COST = exports.COST_PER_UNINIT_TICK = void 0;
|
|
4
|
+
const bignumber_1 = require("@ethersproject/bignumber");
|
|
5
|
+
const sdk_core_1 = require("@fanx-protocol/sdk-core");
|
|
6
|
+
// Cost for crossing an uninitialized tick.
|
|
7
|
+
exports.COST_PER_UNINIT_TICK = bignumber_1.BigNumber.from(0);
|
|
8
|
+
//l2 execution fee on optimism is roughly the same as mainnet
|
|
9
|
+
const BASE_SWAP_COST = (id) => {
|
|
10
|
+
switch (id) {
|
|
11
|
+
case sdk_core_1.ChainId.SPICY:
|
|
12
|
+
case sdk_core_1.ChainId.CHILIZ:
|
|
13
|
+
return bignumber_1.BigNumber.from(2000);
|
|
14
|
+
default:
|
|
15
|
+
return bignumber_1.BigNumber.from(2000);
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
exports.BASE_SWAP_COST = BASE_SWAP_COST;
|
|
19
|
+
const COST_PER_INIT_TICK = (id) => {
|
|
20
|
+
switch (id) {
|
|
21
|
+
case sdk_core_1.ChainId.SPICY:
|
|
22
|
+
case sdk_core_1.ChainId.CHILIZ:
|
|
23
|
+
return bignumber_1.BigNumber.from(31000);
|
|
24
|
+
default:
|
|
25
|
+
return bignumber_1.BigNumber.from(31000);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
exports.COST_PER_INIT_TICK = COST_PER_INIT_TICK;
|
|
29
|
+
const COST_PER_HOP = (id) => {
|
|
30
|
+
switch (id) {
|
|
31
|
+
case sdk_core_1.ChainId.SPICY:
|
|
32
|
+
case sdk_core_1.ChainId.CHILIZ:
|
|
33
|
+
return bignumber_1.BigNumber.from(80000);
|
|
34
|
+
default:
|
|
35
|
+
return bignumber_1.BigNumber.from(80000);
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
exports.COST_PER_HOP = COST_PER_HOP;
|
|
39
|
+
const SINGLE_HOP_OVERHEAD = (_id) => {
|
|
40
|
+
return bignumber_1.BigNumber.from(15000);
|
|
41
|
+
};
|
|
42
|
+
exports.SINGLE_HOP_OVERHEAD = SINGLE_HOP_OVERHEAD;
|
|
43
|
+
const TOKEN_OVERHEAD = (_id, _route /* | V4Route */) => {
|
|
44
|
+
// const currencies: Currency[] = route.tokenPath; // route.protocol === Protocol.V4 ? route.currencyPath : route.tokenPath;
|
|
45
|
+
let overhead = bignumber_1.BigNumber.from(0);
|
|
46
|
+
// AAVE and LIDO token overhead logic removed - only Chiliz and Spicy are supported
|
|
47
|
+
// if (id == ChainId.MAINNET) {
|
|
48
|
+
// // AAVE's transfer contains expensive governance snapshotting logic. We estimate
|
|
49
|
+
// // it at around 150k.
|
|
50
|
+
// if (currencies.some((t: Currency) => t.equals(AAVE_MAINNET))) {
|
|
51
|
+
// overhead = overhead.add(150000);
|
|
52
|
+
// }
|
|
53
|
+
//
|
|
54
|
+
// // LDO's reaches out to an external token controller which adds a large overhead
|
|
55
|
+
// // of around 150k.
|
|
56
|
+
// if (currencies.some((t: Currency) => t.equals(LIDO_MAINNET))) {
|
|
57
|
+
// overhead = overhead.add(150000);
|
|
58
|
+
// }
|
|
59
|
+
// }
|
|
60
|
+
return overhead;
|
|
61
|
+
};
|
|
62
|
+
exports.TOKEN_OVERHEAD = TOKEN_OVERHEAD;
|
|
63
|
+
// TODO: change per chain
|
|
64
|
+
const NATIVE_WRAP_OVERHEAD = (id) => {
|
|
65
|
+
switch (id) {
|
|
66
|
+
default:
|
|
67
|
+
return bignumber_1.BigNumber.from(27938);
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
exports.NATIVE_WRAP_OVERHEAD = NATIVE_WRAP_OVERHEAD;
|
|
71
|
+
const NATIVE_UNWRAP_OVERHEAD = (id) => {
|
|
72
|
+
switch (id) {
|
|
73
|
+
default:
|
|
74
|
+
return bignumber_1.BigNumber.from(36000);
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
exports.NATIVE_UNWRAP_OVERHEAD = NATIVE_UNWRAP_OVERHEAD;
|
|
78
|
+
const NATIVE_OVERHEAD = (chainId, amount, quote) => {
|
|
79
|
+
if (amount.isNative) {
|
|
80
|
+
// need to wrap eth in
|
|
81
|
+
return (0, exports.NATIVE_WRAP_OVERHEAD)(chainId);
|
|
82
|
+
}
|
|
83
|
+
if (quote.isNative) {
|
|
84
|
+
// need to unwrap eth out
|
|
85
|
+
return (0, exports.NATIVE_UNWRAP_OVERHEAD)(chainId);
|
|
86
|
+
}
|
|
87
|
+
return bignumber_1.BigNumber.from(0);
|
|
88
|
+
};
|
|
89
|
+
exports.NATIVE_OVERHEAD = NATIVE_OVERHEAD;
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FzLWNvc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL3JvdXRlcnMvYWxwaGEtcm91dGVyL2dhcy1tb2RlbHMvZ2FzLWNvc3RzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHdEQUFxRDtBQUNyRCxzREFBNEQ7QUFNNUQsMkNBQTJDO0FBQzlCLFFBQUEsb0JBQW9CLEdBQUcscUJBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFFdEQsNkRBQTZEO0FBQ3RELE1BQU0sY0FBYyxHQUFHLENBQUMsRUFBVyxFQUFhLEVBQUU7SUFDdkQsUUFBUSxFQUFFLEVBQUU7UUFDVixLQUFLLGtCQUFPLENBQUMsS0FBSyxDQUFDO1FBQ25CLEtBQUssa0JBQU8sQ0FBQyxNQUFNO1lBQ2pCLE9BQU8scUJBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDOUI7WUFDRSxPQUFPLHFCQUFTLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0tBQy9CO0FBQ0gsQ0FBQyxDQUFDO0FBUlcsUUFBQSxjQUFjLGtCQVF6QjtBQUNLLE1BQU0sa0JBQWtCLEdBQUcsQ0FBQyxFQUFXLEVBQWEsRUFBRTtJQUMzRCxRQUFRLEVBQUUsRUFBRTtRQUNWLEtBQUssa0JBQU8sQ0FBQyxLQUFLLENBQUM7UUFDbkIsS0FBSyxrQkFBTyxDQUFDLE1BQU07WUFDakIsT0FBTyxxQkFBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQjtZQUNFLE9BQU8scUJBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDaEM7QUFDSCxDQUFDLENBQUM7QUFSVyxRQUFBLGtCQUFrQixzQkFRN0I7QUFFSyxNQUFNLFlBQVksR0FBRyxDQUFDLEVBQVcsRUFBYSxFQUFFO0lBQ3JELFFBQVEsRUFBRSxFQUFFO1FBQ1YsS0FBSyxrQkFBTyxDQUFDLEtBQUssQ0FBQztRQUNuQixLQUFLLGtCQUFPLENBQUMsTUFBTTtZQUNqQixPQUFPLHFCQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CO1lBQ0UsT0FBTyxxQkFBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztLQUNoQztBQUNILENBQUMsQ0FBQztBQVJXLFFBQUEsWUFBWSxnQkFRdkI7QUFFSyxNQUFNLG1CQUFtQixHQUFHLENBQUMsR0FBWSxFQUFhLEVBQUU7SUFDN0QsT0FBTyxxQkFBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUMvQixDQUFDLENBQUM7QUFGVyxRQUFBLG1CQUFtQix1QkFFOUI7QUFFSyxNQUFNLGNBQWMsR0FBRyxDQUM1QixHQUFZLEVBQ1osTUFBZSxDQUFDLGVBQWUsRUFDcEIsRUFBRTtJQUNiLDRIQUE0SDtJQUM1SCxJQUFJLFFBQVEsR0FBRyxxQkFBUyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUVqQyxtRkFBbUY7SUFDbkYsK0JBQStCO0lBQy9CLHFGQUFxRjtJQUNyRiwwQkFBMEI7SUFDMUIsb0VBQW9FO0lBQ3BFLHVDQUF1QztJQUN2QyxNQUFNO0lBQ04sRUFBRTtJQUNGLHFGQUFxRjtJQUNyRix1QkFBdUI7SUFDdkIsb0VBQW9FO0lBQ3BFLHVDQUF1QztJQUN2QyxNQUFNO0lBQ04sSUFBSTtJQUVKLE9BQU8sUUFBUSxDQUFDO0FBQ2xCLENBQUMsQ0FBQztBQXZCVyxRQUFBLGNBQWMsa0JBdUJ6QjtBQUVGLHlCQUF5QjtBQUNsQixNQUFNLG9CQUFvQixHQUFHLENBQUMsRUFBVyxFQUFhLEVBQUU7SUFDN0QsUUFBUSxFQUFFLEVBQUU7UUFDVjtZQUNFLE9BQU8scUJBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDaEM7QUFDSCxDQUFDLENBQUM7QUFMVyxRQUFBLG9CQUFvQix3QkFLL0I7QUFFSyxNQUFNLHNCQUFzQixHQUFHLENBQUMsRUFBVyxFQUFhLEVBQUU7SUFDL0QsUUFBUSxFQUFFLEVBQUU7UUFDVjtZQUNFLE9BQU8scUJBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDaEM7QUFDSCxDQUFDLENBQUM7QUFMVyxRQUFBLHNCQUFzQiwwQkFLakM7QUFFSyxNQUFNLGVBQWUsR0FBRyxDQUM3QixPQUFnQixFQUNoQixNQUFnQixFQUNoQixLQUFlLEVBQ0osRUFBRTtJQUNiLElBQUksTUFBTSxDQUFDLFFBQVEsRUFBRTtRQUNuQixzQkFBc0I7UUFDdEIsT0FBTyxJQUFBLDRCQUFvQixFQUFDLE9BQU8sQ0FBQyxDQUFDO0tBQ3RDO0lBQ0QsSUFBSSxLQUFLLENBQUMsUUFBUSxFQUFFO1FBQ2xCLHlCQUF5QjtRQUN6QixPQUFPLElBQUEsOEJBQXNCLEVBQUMsT0FBTyxDQUFDLENBQUM7S0FDeEM7SUFDRCxPQUFPLHFCQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQzNCLENBQUMsQ0FBQztBQWRXLFFBQUEsZUFBZSxtQkFjMUIifQ==
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { BigNumber } from '@ethersproject/bignumber';
|
|
2
|
+
import { ChainId, CurrencyAmount as CurrencyAmountRaw, Token } from '@fanx-protocol/sdk-core';
|
|
3
|
+
import { Pair } from '@fanx-protocol/v2-sdk';
|
|
4
|
+
import { Pool } from '@fanx-protocol/v3-sdk';
|
|
5
|
+
import { ProviderConfig } from '../../../providers/provider';
|
|
6
|
+
import { IV2PoolProvider } from '../../../providers/v2/pool-provider';
|
|
7
|
+
import { ArbitrumGasData, IL2GasDataProvider } from '../../../providers/v3/gas-data-provider';
|
|
8
|
+
import { CurrencyAmount } from '../../../util/amounts';
|
|
9
|
+
import { MixedRouteWithValidQuote, RouteWithValidQuote, V2RouteWithValidQuote, V3RouteWithValidQuote } from '../entities/route-with-valid-quote';
|
|
10
|
+
export declare const usdGasTokensByChain: {
|
|
11
|
+
[chainId in ChainId]?: Token[];
|
|
12
|
+
};
|
|
13
|
+
export declare type L1ToL2GasCosts = {
|
|
14
|
+
gasUsedL1: BigNumber;
|
|
15
|
+
gasUsedL1OnL2: BigNumber;
|
|
16
|
+
gasCostL1USD: CurrencyAmount;
|
|
17
|
+
gasCostL1QuoteToken: CurrencyAmount;
|
|
18
|
+
};
|
|
19
|
+
export declare type GasModelProviderConfig = ProviderConfig & {
|
|
20
|
+
additionalGasOverhead?: BigNumber;
|
|
21
|
+
gasToken?: Token;
|
|
22
|
+
};
|
|
23
|
+
export declare type BuildOnChainGasModelFactoryType = {
|
|
24
|
+
chainId: ChainId;
|
|
25
|
+
gasPriceWei: BigNumber;
|
|
26
|
+
pools: LiquidityCalculationPools;
|
|
27
|
+
amountToken: Token;
|
|
28
|
+
quoteToken: Token;
|
|
29
|
+
v2poolProvider: IV2PoolProvider;
|
|
30
|
+
l2GasDataProvider?: IL2GasDataProvider<ArbitrumGasData>;
|
|
31
|
+
providerConfig?: GasModelProviderConfig;
|
|
32
|
+
};
|
|
33
|
+
export declare type BuildV2GasModelFactoryType = {
|
|
34
|
+
chainId: ChainId;
|
|
35
|
+
gasPriceWei: BigNumber;
|
|
36
|
+
poolProvider: IV2PoolProvider;
|
|
37
|
+
token: Token;
|
|
38
|
+
l2GasDataProvider?: IL2GasDataProvider<ArbitrumGasData>;
|
|
39
|
+
providerConfig?: GasModelProviderConfig;
|
|
40
|
+
};
|
|
41
|
+
export declare type LiquidityCalculationPools = {
|
|
42
|
+
usdPool: Pool;
|
|
43
|
+
nativeAndQuoteTokenV3Pool: Pool | null;
|
|
44
|
+
nativeAndAmountTokenV3Pool: Pool | null;
|
|
45
|
+
nativeAndSpecifiedGasTokenV3Pool: Pool | null;
|
|
46
|
+
};
|
|
47
|
+
export declare type GasModelType = {
|
|
48
|
+
v2GasModel?: IGasModel<V2RouteWithValidQuote>;
|
|
49
|
+
v3GasModel: IGasModel<V3RouteWithValidQuote>;
|
|
50
|
+
mixedRouteGasModel: IGasModel<MixedRouteWithValidQuote>;
|
|
51
|
+
};
|
|
52
|
+
/**
|
|
53
|
+
* Contains functions for generating gas estimates for given routes.
|
|
54
|
+
*
|
|
55
|
+
* We generally compute gas estimates off-chain because
|
|
56
|
+
* 1/ Calling eth_estimateGas for a swaps requires the caller to have
|
|
57
|
+
* the full balance token being swapped, and approvals.
|
|
58
|
+
* 2/ Tracking gas used using a wrapper contract is not accurate with Multicall
|
|
59
|
+
* due to EIP-2929
|
|
60
|
+
* 3/ For V2 we simulate all our swaps off-chain so have no way to track gas used.
|
|
61
|
+
*
|
|
62
|
+
* Generally these models should be optimized to return quickly by performing any
|
|
63
|
+
* long running operations (like fetching external data) outside of the functions defined.
|
|
64
|
+
* This is because the functions in the model are called once for every route and every
|
|
65
|
+
* amount that is considered in the algorithm so it is important to minimize the number of
|
|
66
|
+
* long running operations.
|
|
67
|
+
*/
|
|
68
|
+
export declare type IGasModel<TRouteWithValidQuote extends RouteWithValidQuote> = {
|
|
69
|
+
estimateGasCost(routeWithValidQuote: TRouteWithValidQuote): {
|
|
70
|
+
gasEstimate: BigNumber;
|
|
71
|
+
gasCostInToken: CurrencyAmount;
|
|
72
|
+
gasCostInUSD: CurrencyAmount;
|
|
73
|
+
gasCostInGasToken?: CurrencyAmount;
|
|
74
|
+
};
|
|
75
|
+
calculateL1GasFees?(routes: TRouteWithValidQuote[]): Promise<L1ToL2GasCosts>;
|
|
76
|
+
};
|
|
77
|
+
/**
|
|
78
|
+
* Factory for building gas models that can be used with any route to generate
|
|
79
|
+
* gas estimates.
|
|
80
|
+
*
|
|
81
|
+
* Factory model is used so that any supporting data can be fetched once and
|
|
82
|
+
* returned as part of the model.
|
|
83
|
+
*
|
|
84
|
+
* @export
|
|
85
|
+
* @abstract
|
|
86
|
+
* @class IV2GasModelFactory
|
|
87
|
+
*/
|
|
88
|
+
export declare abstract class IV2GasModelFactory {
|
|
89
|
+
abstract buildGasModel({ chainId, gasPriceWei, poolProvider, token, providerConfig, }: BuildV2GasModelFactoryType): Promise<IGasModel<V2RouteWithValidQuote>>;
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Factory for building gas models that can be used with any route to generate
|
|
93
|
+
* gas estimates.
|
|
94
|
+
*
|
|
95
|
+
* Factory model is used so that any supporting data can be fetched once and
|
|
96
|
+
* returned as part of the model.
|
|
97
|
+
*
|
|
98
|
+
* @export
|
|
99
|
+
* @abstract
|
|
100
|
+
* @class IOnChainGasModelFactory
|
|
101
|
+
*/
|
|
102
|
+
export declare abstract class IOnChainGasModelFactory<TRouteWithValidQuote extends RouteWithValidQuote> {
|
|
103
|
+
abstract buildGasModel({ chainId, gasPriceWei, pools, amountToken, quoteToken, v2poolProvider, l2GasDataProvider, providerConfig, }: BuildOnChainGasModelFactoryType): Promise<IGasModel<TRouteWithValidQuote>>;
|
|
104
|
+
protected totalInitializedTicksCrossed(initializedTicksCrossedList: number[]): number;
|
|
105
|
+
}
|
|
106
|
+
export declare const getQuoteThroughNativePool: (chainId: ChainId, nativeTokenAmount: CurrencyAmountRaw<Token>, nativeTokenPool: Pool | Pair) => CurrencyAmount;
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getQuoteThroughNativePool = exports.IOnChainGasModelFactory = exports.IV2GasModelFactory = exports.usdGasTokensByChain = void 0;
|
|
4
|
+
const sdk_core_1 = require("@fanx-protocol/sdk-core");
|
|
5
|
+
const token_provider_1 = require("../../../providers/token-provider");
|
|
6
|
+
const util_1 = require("../../../util");
|
|
7
|
+
// When adding new usd gas tokens, ensure the tokens are ordered
|
|
8
|
+
// from tokens with highest decimals to lowest decimals. For example,
|
|
9
|
+
// DAI_AVAX has 18 decimals and comes before USDC_AVAX which has 6 decimals.
|
|
10
|
+
exports.usdGasTokensByChain = {
|
|
11
|
+
[sdk_core_1.ChainId.CHILIZ]: [token_provider_1.USDC_CHILIZ],
|
|
12
|
+
[sdk_core_1.ChainId.SPICY]: [token_provider_1.USDC_SPICY],
|
|
13
|
+
};
|
|
14
|
+
/**
|
|
15
|
+
* Factory for building gas models that can be used with any route to generate
|
|
16
|
+
* gas estimates.
|
|
17
|
+
*
|
|
18
|
+
* Factory model is used so that any supporting data can be fetched once and
|
|
19
|
+
* returned as part of the model.
|
|
20
|
+
*
|
|
21
|
+
* @export
|
|
22
|
+
* @abstract
|
|
23
|
+
* @class IV2GasModelFactory
|
|
24
|
+
*/
|
|
25
|
+
class IV2GasModelFactory {
|
|
26
|
+
}
|
|
27
|
+
exports.IV2GasModelFactory = IV2GasModelFactory;
|
|
28
|
+
/**
|
|
29
|
+
* Factory for building gas models that can be used with any route to generate
|
|
30
|
+
* gas estimates.
|
|
31
|
+
*
|
|
32
|
+
* Factory model is used so that any supporting data can be fetched once and
|
|
33
|
+
* returned as part of the model.
|
|
34
|
+
*
|
|
35
|
+
* @export
|
|
36
|
+
* @abstract
|
|
37
|
+
* @class IOnChainGasModelFactory
|
|
38
|
+
*/
|
|
39
|
+
class IOnChainGasModelFactory {
|
|
40
|
+
totalInitializedTicksCrossed(initializedTicksCrossedList) {
|
|
41
|
+
let ticksCrossed = 0;
|
|
42
|
+
for (let i = 0; i < initializedTicksCrossedList.length; i++) {
|
|
43
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
44
|
+
if (initializedTicksCrossedList[i] > 0) {
|
|
45
|
+
// Quoter returns Array<number of calls to crossTick + 1>, so we need to subtract 1 here.
|
|
46
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
47
|
+
ticksCrossed += initializedTicksCrossedList[i] - 1;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return ticksCrossed;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
exports.IOnChainGasModelFactory = IOnChainGasModelFactory;
|
|
54
|
+
// Determines if native currency is token0
|
|
55
|
+
// Gets the native price of the pool, dependent on 0 or 1
|
|
56
|
+
// quotes across the pool
|
|
57
|
+
const getQuoteThroughNativePool = (chainId, nativeTokenAmount, nativeTokenPool) => {
|
|
58
|
+
const nativeCurrency = util_1.WRAPPED_NATIVE_CURRENCY[chainId];
|
|
59
|
+
const isToken0 = nativeTokenPool.token0.equals(nativeCurrency);
|
|
60
|
+
// returns mid price in terms of the native currency (the ratio of token/nativeToken)
|
|
61
|
+
const nativeTokenPrice = isToken0
|
|
62
|
+
? nativeTokenPool.token0Price
|
|
63
|
+
: nativeTokenPool.token1Price;
|
|
64
|
+
// return gas cost in terms of the non native currency
|
|
65
|
+
return nativeTokenPrice.quote(nativeTokenAmount);
|
|
66
|
+
};
|
|
67
|
+
exports.getQuoteThroughNativePool = getQuoteThroughNativePool;
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FzLW1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL3JvdXRlcnMvYWxwaGEtcm91dGVyL2dhcy1tb2RlbHMvZ2FzLW1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLHNEQUlpQztBQUtqQyxzRUF5QzJDO0FBTTNDLHdDQUF3RDtBQVN4RCxnRUFBZ0U7QUFDaEUscUVBQXFFO0FBQ3JFLDRFQUE0RTtBQUMvRCxRQUFBLG1CQUFtQixHQUF1QztJQUNyRSxDQUFDLGtCQUFPLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyw0QkFBVyxDQUFDO0lBQy9CLENBQUMsa0JBQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLDJCQUFVLENBQUM7Q0FDOUIsQ0FBQztBQThFRjs7Ozs7Ozs7OztHQVVHO0FBQ0gsTUFBc0Isa0JBQWtCO0NBUXZDO0FBUkQsZ0RBUUM7QUFFRDs7Ozs7Ozs7OztHQVVHO0FBQ0gsTUFBc0IsdUJBQXVCO0lBY2pDLDRCQUE0QixDQUNwQywyQkFBcUM7UUFFckMsSUFBSSxZQUFZLEdBQUcsQ0FBQyxDQUFDO1FBQ3JCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRywyQkFBMkIsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDM0Qsb0VBQW9FO1lBQ3BFLElBQUksMkJBQTJCLENBQUMsQ0FBQyxDQUFFLEdBQUcsQ0FBQyxFQUFFO2dCQUN2Qyx5RkFBeUY7Z0JBQ3pGLG9FQUFvRTtnQkFDcEUsWUFBWSxJQUFJLDJCQUEyQixDQUFDLENBQUMsQ0FBRSxHQUFHLENBQUMsQ0FBQzthQUNyRDtTQUNGO1FBRUQsT0FBTyxZQUFZLENBQUM7SUFDdEIsQ0FBQztDQUNGO0FBN0JELDBEQTZCQztBQUVELDBDQUEwQztBQUMxQyx5REFBeUQ7QUFDekQseUJBQXlCO0FBQ2xCLE1BQU0seUJBQXlCLEdBQUcsQ0FDdkMsT0FBZ0IsRUFDaEIsaUJBQTJDLEVBQzNDLGVBQTRCLEVBQ1osRUFBRTtJQUNsQixNQUFNLGNBQWMsR0FBRyw4QkFBdUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN4RCxNQUFNLFFBQVEsR0FBRyxlQUFlLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUMvRCxxRkFBcUY7SUFDckYsTUFBTSxnQkFBZ0IsR0FBRyxRQUFRO1FBQy9CLENBQUMsQ0FBQyxlQUFlLENBQUMsV0FBVztRQUM3QixDQUFDLENBQUMsZUFBZSxDQUFDLFdBQVcsQ0FBQztJQUNoQyxzREFBc0Q7SUFDdEQsT0FBTyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsaUJBQWlCLENBQW1CLENBQUM7QUFDckUsQ0FBQyxDQUFDO0FBYlcsUUFBQSx5QkFBeUIsNkJBYXBDIn0=
|
|
@@ -0,0 +1,19 @@
|
|
|
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("./gas-model"), exports);
|
|
18
|
+
__exportStar(require("./v3/v3-heuristic-gas-model"), exports);
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvcm91dGVycy9hbHBoYS1yb3V0ZXIvZ2FzLW1vZGVscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsOENBQTRCO0FBQzVCLDhEQUE0QyJ9
|
package/build/main/routers/alpha-router/gas-models/mixedRoute/mixed-route-heuristic-gas-model.d.ts
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { MixedRouteWithValidQuote } from '../../entities/route-with-valid-quote';
|
|
2
|
+
import { BuildOnChainGasModelFactoryType, IGasModel, IOnChainGasModelFactory } from '../gas-model';
|
|
3
|
+
/**
|
|
4
|
+
* Computes a gas estimate for a mixed route swap using heuristics.
|
|
5
|
+
* Considers number of hops in the route, number of ticks crossed
|
|
6
|
+
* and the typical base cost for a swap.
|
|
7
|
+
*
|
|
8
|
+
* We get the number of ticks crossed in a swap from the MixedRouteQuoterV1
|
|
9
|
+
* contract.
|
|
10
|
+
*
|
|
11
|
+
* We compute gas estimates off-chain because
|
|
12
|
+
* 1/ Calling eth_estimateGas for a swaps requires the caller to have
|
|
13
|
+
* the full balance token being swapped, and approvals.
|
|
14
|
+
* 2/ Tracking gas used using a wrapper contract is not accurate with Multicall
|
|
15
|
+
* due to EIP-2929. We would have to make a request for every swap we wanted to estimate.
|
|
16
|
+
* 3/ For V2 we simulate all our swaps off-chain so have no way to track gas used.
|
|
17
|
+
*
|
|
18
|
+
* @export
|
|
19
|
+
* @class MixedRouteHeuristicGasModelFactory
|
|
20
|
+
*/
|
|
21
|
+
export declare class MixedRouteHeuristicGasModelFactory extends IOnChainGasModelFactory<MixedRouteWithValidQuote> {
|
|
22
|
+
buildGasModel({ chainId, gasPriceWei, pools, quoteToken, v2poolProvider: V2poolProvider, providerConfig, }: BuildOnChainGasModelFactoryType): Promise<IGasModel<MixedRouteWithValidQuote>>;
|
|
23
|
+
private estimateGas;
|
|
24
|
+
}
|
package/build/main/routers/alpha-router/gas-models/mixedRoute/mixed-route-heuristic-gas-model.js
ADDED
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.MixedRouteHeuristicGasModelFactory = void 0;
|
|
7
|
+
const bignumber_1 = require("@ethersproject/bignumber");
|
|
8
|
+
const router_sdk_1 = require("@fanx-protocol/router-sdk");
|
|
9
|
+
const v2_sdk_1 = require("@fanx-protocol/v2-sdk");
|
|
10
|
+
const v3_sdk_1 = require("@fanx-protocol/v3-sdk");
|
|
11
|
+
// import { Pool as V4Pool } from '@fanx-protocol/v4-sdk';
|
|
12
|
+
const jsbi_1 = __importDefault(require("jsbi"));
|
|
13
|
+
const __1 = require("../../../..");
|
|
14
|
+
const util_1 = require("../../../../util");
|
|
15
|
+
const amounts_1 = require("../../../../util/amounts");
|
|
16
|
+
const gas_factory_helpers_1 = require("../../../../util/gas-factory-helpers");
|
|
17
|
+
const gas_costs_1 = require("../gas-costs");
|
|
18
|
+
const gas_model_1 = require("../gas-model");
|
|
19
|
+
const v2_heuristic_gas_model_1 = require("../v2/v2-heuristic-gas-model");
|
|
20
|
+
/**
|
|
21
|
+
* Computes a gas estimate for a mixed route swap using heuristics.
|
|
22
|
+
* Considers number of hops in the route, number of ticks crossed
|
|
23
|
+
* and the typical base cost for a swap.
|
|
24
|
+
*
|
|
25
|
+
* We get the number of ticks crossed in a swap from the MixedRouteQuoterV1
|
|
26
|
+
* contract.
|
|
27
|
+
*
|
|
28
|
+
* We compute gas estimates off-chain because
|
|
29
|
+
* 1/ Calling eth_estimateGas for a swaps requires the caller to have
|
|
30
|
+
* the full balance token being swapped, and approvals.
|
|
31
|
+
* 2/ Tracking gas used using a wrapper contract is not accurate with Multicall
|
|
32
|
+
* due to EIP-2929. We would have to make a request for every swap we wanted to estimate.
|
|
33
|
+
* 3/ For V2 we simulate all our swaps off-chain so have no way to track gas used.
|
|
34
|
+
*
|
|
35
|
+
* @export
|
|
36
|
+
* @class MixedRouteHeuristicGasModelFactory
|
|
37
|
+
*/
|
|
38
|
+
class MixedRouteHeuristicGasModelFactory extends gas_model_1.IOnChainGasModelFactory {
|
|
39
|
+
async buildGasModel({ chainId, gasPriceWei, pools, quoteToken, v2poolProvider: V2poolProvider, providerConfig, }) {
|
|
40
|
+
const nativeCurrency = __1.WRAPPED_NATIVE_CURRENCY[chainId];
|
|
41
|
+
const usdPool = pools.usdPool;
|
|
42
|
+
const usdToken = usdPool.token0.equals(nativeCurrency)
|
|
43
|
+
? usdPool.token1
|
|
44
|
+
: usdPool.token0;
|
|
45
|
+
let nativeV2Pool;
|
|
46
|
+
// Avoid fetching for a (WETH,WETH) pool here, we handle the quoteToken = wrapped native case in estimateGasCost
|
|
47
|
+
if (!quoteToken.equals(nativeCurrency) && V2poolProvider) {
|
|
48
|
+
/// MixedRoutes
|
|
49
|
+
nativeV2Pool = await (0, gas_factory_helpers_1.getV2NativePool)(quoteToken, V2poolProvider, providerConfig);
|
|
50
|
+
}
|
|
51
|
+
const estimateGasCost = (routeWithValidQuote) => {
|
|
52
|
+
var _a;
|
|
53
|
+
const { totalGasCostNativeCurrency, baseGasUse } = this.estimateGas(routeWithValidQuote, gasPriceWei, chainId, providerConfig);
|
|
54
|
+
/** ------ MARK: USD Logic -------- */
|
|
55
|
+
const gasCostInTermsOfUSD = (0, gas_model_1.getQuoteThroughNativePool)(chainId, totalGasCostNativeCurrency, usdPool);
|
|
56
|
+
/** ------ MARK: Conditional logic run if gasToken is specified -------- */
|
|
57
|
+
const nativeAndSpecifiedGasTokenPool = pools.nativeAndSpecifiedGasTokenV3Pool;
|
|
58
|
+
let gasCostInTermsOfGasToken = undefined;
|
|
59
|
+
if (nativeAndSpecifiedGasTokenPool) {
|
|
60
|
+
gasCostInTermsOfGasToken = (0, gas_model_1.getQuoteThroughNativePool)(chainId, totalGasCostNativeCurrency, nativeAndSpecifiedGasTokenPool);
|
|
61
|
+
}
|
|
62
|
+
// if the gasToken is the native currency, we can just use the totalGasCostNativeCurrency
|
|
63
|
+
else if ((_a = providerConfig === null || providerConfig === void 0 ? void 0 : providerConfig.gasToken) === null || _a === void 0 ? void 0 : _a.equals(nativeCurrency)) {
|
|
64
|
+
gasCostInTermsOfGasToken = totalGasCostNativeCurrency;
|
|
65
|
+
}
|
|
66
|
+
/** ------ MARK: return early if quoteToken is wrapped native currency ------- */
|
|
67
|
+
if (quoteToken.equals(nativeCurrency)) {
|
|
68
|
+
return {
|
|
69
|
+
gasEstimate: baseGasUse,
|
|
70
|
+
gasCostInToken: totalGasCostNativeCurrency,
|
|
71
|
+
gasCostInUSD: gasCostInTermsOfUSD,
|
|
72
|
+
gasCostInGasToken: gasCostInTermsOfGasToken,
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
/** ------ MARK: Main gas logic in terms of quote token -------- */
|
|
76
|
+
// If the quote token is not in the native currency, we convert the gas cost to be in terms of the quote token.
|
|
77
|
+
// We do this by getting the highest liquidity <quoteToken>/<nativeCurrency> pool. eg. <quoteToken>/ETH pool.
|
|
78
|
+
const nativeV3Pool = pools.nativeAndQuoteTokenV3Pool;
|
|
79
|
+
if (!nativeV3Pool && !nativeV2Pool) {
|
|
80
|
+
util_1.log.info(`Unable to find ${nativeCurrency.symbol} pool with the quote token, ${quoteToken.symbol} to produce gas adjusted costs. Route will not account for gas.`);
|
|
81
|
+
return {
|
|
82
|
+
gasEstimate: baseGasUse,
|
|
83
|
+
gasCostInToken: amounts_1.CurrencyAmount.fromRawAmount(quoteToken, 0),
|
|
84
|
+
gasCostInUSD: amounts_1.CurrencyAmount.fromRawAmount(usdToken, 0),
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
/// we will use nativeV2Pool for fallback if nativeV3 does not exist or has 0 liquidity
|
|
88
|
+
/// can use ! here because we return above if v3Pool and v2Pool are null
|
|
89
|
+
const nativePool = (!nativeV3Pool || jsbi_1.default.equal(nativeV3Pool.liquidity, jsbi_1.default.BigInt(0))) &&
|
|
90
|
+
nativeV2Pool
|
|
91
|
+
? nativeV2Pool
|
|
92
|
+
: nativeV3Pool;
|
|
93
|
+
const gasCostInTermsOfQuoteToken = (0, gas_model_1.getQuoteThroughNativePool)(chainId, totalGasCostNativeCurrency, nativePool);
|
|
94
|
+
return {
|
|
95
|
+
gasEstimate: baseGasUse,
|
|
96
|
+
gasCostInToken: gasCostInTermsOfQuoteToken,
|
|
97
|
+
gasCostInUSD: gasCostInTermsOfUSD,
|
|
98
|
+
gasCostInGasToken: gasCostInTermsOfGasToken,
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
return {
|
|
102
|
+
estimateGasCost: estimateGasCost.bind(this),
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
estimateGas(routeWithValidQuote, gasPriceWei, chainId, providerConfig) {
|
|
106
|
+
const totalInitializedTicksCrossed = this.totalInitializedTicksCrossed(routeWithValidQuote.initializedTicksCrossedList);
|
|
107
|
+
/**
|
|
108
|
+
* Since we must make a separate call to multicall for each v3 and v2 section, we will have to
|
|
109
|
+
* add the BASE_SWAP_COST to each section.
|
|
110
|
+
*/
|
|
111
|
+
let baseGasUseV2Only = bignumber_1.BigNumber.from(0);
|
|
112
|
+
let baseGasUseV3Only = bignumber_1.BigNumber.from(0);
|
|
113
|
+
let baseGasUse = bignumber_1.BigNumber.from(0);
|
|
114
|
+
let routeContainsV4Pool = false;
|
|
115
|
+
const route = routeWithValidQuote.route;
|
|
116
|
+
const res = (0, router_sdk_1.partitionMixedRouteByProtocol)(route);
|
|
117
|
+
res.map((section) => {
|
|
118
|
+
if (section.every((pool) => pool instanceof v3_sdk_1.Pool)) {
|
|
119
|
+
baseGasUseV3Only = baseGasUseV3Only.add((0, gas_costs_1.BASE_SWAP_COST)(chainId));
|
|
120
|
+
baseGasUseV3Only = baseGasUseV3Only.add((0, gas_costs_1.COST_PER_HOP)(chainId).mul(section.length));
|
|
121
|
+
baseGasUse = baseGasUse.add(baseGasUseV3Only);
|
|
122
|
+
}
|
|
123
|
+
else if (section.every((pool) => pool instanceof v2_sdk_1.Pair)) {
|
|
124
|
+
baseGasUseV2Only = baseGasUseV2Only.add(v2_heuristic_gas_model_1.BASE_SWAP_COST);
|
|
125
|
+
baseGasUseV2Only = baseGasUseV2Only.add(
|
|
126
|
+
/// same behavior in v2 heuristic gas model factory
|
|
127
|
+
v2_heuristic_gas_model_1.COST_PER_EXTRA_HOP.mul(section.length - 1));
|
|
128
|
+
baseGasUse = baseGasUse.add(baseGasUseV2Only);
|
|
129
|
+
}
|
|
130
|
+
// } else if (section.every((pool) => pool instanceof V4Pool)) {
|
|
131
|
+
// routeContainsV4Pool = true;
|
|
132
|
+
// }
|
|
133
|
+
});
|
|
134
|
+
const tickGasUse = (0, gas_costs_1.COST_PER_INIT_TICK)(chainId).mul(totalInitializedTicksCrossed);
|
|
135
|
+
const uninitializedTickGasUse = gas_costs_1.COST_PER_UNINIT_TICK.mul(0);
|
|
136
|
+
if (routeContainsV4Pool) {
|
|
137
|
+
// If the route contains a V4 pool, we know we are hitting mixed quoter V2, not mixed quoter V1,
|
|
138
|
+
// Hence we already know the v3 and v4 hops part of the quoter gas estimate.
|
|
139
|
+
// We only need to add the base gas use for the v2 part of the route,
|
|
140
|
+
// because mixed quoter doesn't have a way to estimate gas for v2 pools swaps.
|
|
141
|
+
baseGasUse = baseGasUseV2Only.add(routeWithValidQuote.quoterGasEstimate);
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
// base estimate gas used based on chainId estimates for hops and ticks gas useage
|
|
145
|
+
baseGasUse = baseGasUse.add(tickGasUse).add(uninitializedTickGasUse);
|
|
146
|
+
}
|
|
147
|
+
if (providerConfig === null || providerConfig === void 0 ? void 0 : providerConfig.additionalGasOverhead) {
|
|
148
|
+
baseGasUse = baseGasUse.add(providerConfig.additionalGasOverhead);
|
|
149
|
+
}
|
|
150
|
+
const baseGasCostWei = gasPriceWei.mul(baseGasUse);
|
|
151
|
+
const wrappedCurrency = __1.WRAPPED_NATIVE_CURRENCY[chainId];
|
|
152
|
+
const totalGasCostNativeCurrency = amounts_1.CurrencyAmount.fromRawAmount(wrappedCurrency, baseGasCostWei.toString());
|
|
153
|
+
return {
|
|
154
|
+
totalGasCostNativeCurrency,
|
|
155
|
+
totalInitializedTicksCrossed,
|
|
156
|
+
baseGasUse,
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
exports.MixedRouteHeuristicGasModelFactory = MixedRouteHeuristicGasModelFactory;
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWl4ZWQtcm91dGUtaGV1cmlzdGljLWdhcy1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9yb3V0ZXJzL2FscGhhLXJvdXRlci9nYXMtbW9kZWxzL21peGVkUm91dGUvbWl4ZWQtcm91dGUtaGV1cmlzdGljLWdhcy1tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSx3REFBcUQ7QUFDckQsMERBQTBFO0FBRTFFLGtEQUE2QztBQUM3QyxrREFBdUQ7QUFDdkQsMERBQTBEO0FBQzFELGdEQUF3QjtBQUd4QixtQ0FBc0Q7QUFDdEQsMkNBQXVDO0FBQ3ZDLHNEQUEwRDtBQUMxRCw4RUFBdUU7QUFFdkUsNENBS3NCO0FBQ3RCLDRDQU1zQjtBQUN0Qix5RUFHc0M7QUFFdEM7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUJHO0FBQ0gsTUFBYSxrQ0FBbUMsU0FBUSxtQ0FBaUQ7SUFDaEcsS0FBSyxDQUFDLGFBQWEsQ0FBQyxFQUN6QixPQUFPLEVBQ1AsV0FBVyxFQUNYLEtBQUssRUFDTCxVQUFVLEVBQ1YsY0FBYyxFQUFFLGNBQWMsRUFDOUIsY0FBYyxHQUNrQjtRQUdoQyxNQUFNLGNBQWMsR0FBRywyQkFBdUIsQ0FBQyxPQUFPLENBQUUsQ0FBQztRQUN6RCxNQUFNLE9BQU8sR0FBVyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQ3RDLE1BQU0sUUFBUSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQztZQUNwRCxDQUFDLENBQUMsT0FBTyxDQUFDLE1BQU07WUFDaEIsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUM7UUFFbkIsSUFBSSxZQUF5QixDQUFDO1FBQzlCLGdIQUFnSDtRQUNoSCxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsSUFBSSxjQUFjLEVBQUU7WUFDeEQsZUFBZTtZQUNmLFlBQVksR0FBRyxNQUFNLElBQUEscUNBQWUs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
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { BigNumber } from '@ethersproject/bignumber';
|
|
2
|
+
import { BaseProvider } from '@ethersproject/providers';
|
|
3
|
+
import { ChainId } from '@fanx-protocol/sdk-core';
|
|
4
|
+
import { V3RouteWithValidQuote } from '../entities';
|
|
5
|
+
import { BuildOnChainGasModelFactoryType, GasModelProviderConfig, IGasModel, IOnChainGasModelFactory } from './gas-model';
|
|
6
|
+
export declare abstract class TickBasedHeuristicGasModelFactory<TRouteWithValidQuote extends V3RouteWithValidQuote> extends IOnChainGasModelFactory<TRouteWithValidQuote> {
|
|
7
|
+
protected provider: BaseProvider;
|
|
8
|
+
protected constructor(provider: BaseProvider);
|
|
9
|
+
protected buildGasModelInternal({ chainId, gasPriceWei, pools, amountToken, quoteToken, l2GasDataProvider, providerConfig, }: BuildOnChainGasModelFactoryType): Promise<IGasModel<TRouteWithValidQuote>>;
|
|
10
|
+
protected estimateGas(routeWithValidQuote: TRouteWithValidQuote, gasPriceWei: BigNumber, chainId: ChainId, providerConfig?: GasModelProviderConfig): {
|
|
11
|
+
totalGasCostNativeCurrency: import("@fanx-protocol/sdk-core").CurrencyAmount<import("@fanx-protocol/sdk-core").Token>;
|
|
12
|
+
totalInitializedTicksCrossed: number;
|
|
13
|
+
baseGasUse: BigNumber;
|
|
14
|
+
};
|
|
15
|
+
}
|