symbiosis-js-sdk 3.7.5 → 3.7.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/constants.d.ts +207 -0
- package/dist/constants.js +278 -0
- package/dist/constants.js.map +1 -0
- package/dist/crosschain/abis/ERC20.json +222 -0
- package/dist/crosschain/cache.d.ts +8 -0
- package/dist/crosschain/cache.js +43 -0
- package/dist/crosschain/cache.js.map +1 -0
- package/dist/crosschain/chainUtils/btc.d.ts +14 -0
- package/dist/crosschain/chainUtils/btc.js +94 -0
- package/dist/crosschain/chainUtils/btc.js.map +1 -0
- package/dist/crosschain/chainUtils/evm.d.ts +53 -0
- package/dist/crosschain/chainUtils/evm.js +210 -0
- package/dist/crosschain/chainUtils/evm.js.map +1 -0
- package/dist/crosschain/chainUtils/index.d.ts +5 -0
- package/dist/crosschain/chainUtils/index.js +6 -0
- package/dist/crosschain/chainUtils/index.js.map +1 -0
- package/dist/crosschain/chainUtils/solana.d.ts +10 -0
- package/dist/crosschain/chainUtils/solana.js +55 -0
- package/dist/crosschain/chainUtils/solana.js.map +1 -0
- package/dist/crosschain/chainUtils/ton.d.ts +69 -0
- package/dist/crosschain/chainUtils/ton.js +272 -0
- package/dist/crosschain/chainUtils/ton.js.map +1 -0
- package/dist/crosschain/chainUtils/tron.d.ts +36 -0
- package/dist/crosschain/chainUtils/tron.js +68 -0
- package/dist/crosschain/chainUtils/tron.js.map +1 -0
- package/dist/crosschain/coingecko/coingecko.d.ts +18 -0
- package/dist/crosschain/coingecko/coingecko.js +123 -0
- package/dist/crosschain/coingecko/coingecko.js.map +1 -0
- package/dist/crosschain/coingecko/constants.d.ts +3 -0
- package/dist/crosschain/coingecko/constants.js +103 -0
- package/dist/crosschain/coingecko/constants.js.map +1 -0
- package/dist/crosschain/coingecko/getTokenPriceUsd.d.ts +5 -0
- package/dist/crosschain/coingecko/getTokenPriceUsd.js +116 -0
- package/dist/crosschain/coingecko/getTokenPriceUsd.js.map +1 -0
- package/dist/crosschain/coingecko/index.d.ts +2 -0
- package/dist/crosschain/coingecko/index.js +3 -0
- package/dist/crosschain/coingecko/index.js.map +1 -0
- package/dist/crosschain/config/beta.d.ts +2 -0
- package/dist/crosschain/config/beta.js +2466 -0
- package/dist/crosschain/config/beta.js.map +1 -0
- package/dist/crosschain/config/cache/beta.json +4034 -0
- package/dist/crosschain/config/cache/builder.d.ts +42 -0
- package/dist/crosschain/config/cache/builder.js +332 -0
- package/dist/crosschain/config/cache/builder.js.map +1 -0
- package/dist/crosschain/config/cache/cache.d.ts +20 -0
- package/dist/crosschain/config/cache/cache.js +143 -0
- package/dist/crosschain/config/cache/cache.js.map +1 -0
- package/dist/crosschain/config/cache/cmd/build.d.ts +1 -0
- package/dist/crosschain/config/cache/cmd/build.js +8 -0
- package/dist/crosschain/config/cache/cmd/build.js.map +1 -0
- package/dist/crosschain/config/cache/dev.json +14 -0
- package/dist/crosschain/config/cache/mainnet.json +4034 -0
- package/dist/crosschain/config/cache/testnet.json +183 -0
- package/dist/crosschain/config/dev.d.ts +2 -0
- package/dist/crosschain/config/dev.js +40 -0
- package/dist/crosschain/config/dev.js.map +1 -0
- package/dist/crosschain/config/index.d.ts +3 -0
- package/dist/crosschain/config/index.js +4 -0
- package/dist/crosschain/config/index.js.map +1 -0
- package/dist/crosschain/config/mainnet.d.ts +2 -0
- package/dist/crosschain/config/mainnet.js +2466 -0
- package/dist/crosschain/config/mainnet.js.map +1 -0
- package/dist/crosschain/config/testnet.d.ts +2 -0
- package/dist/crosschain/config/testnet.js +214 -0
- package/dist/crosschain/config/testnet.js.map +1 -0
- package/dist/crosschain/constants.d.ts +86 -0
- package/dist/crosschain/constants.js +706 -0
- package/dist/crosschain/constants.js.map +1 -0
- package/dist/crosschain/contracts/AdaRouter.d.ts +485 -0
- package/dist/crosschain/contracts/AdaRouter.js +2 -0
- package/dist/crosschain/contracts/AdaRouter.js.map +1 -0
- package/dist/crosschain/contracts/AvaxRouter.d.ts +485 -0
- package/dist/crosschain/contracts/AvaxRouter.js +2 -0
- package/dist/crosschain/contracts/AvaxRouter.js.map +1 -0
- package/dist/crosschain/contracts/BranchedUnlocker.d.ts +140 -0
- package/dist/crosschain/contracts/BranchedUnlocker.js +2 -0
- package/dist/crosschain/contracts/BranchedUnlocker.js.map +1 -0
- package/dist/crosschain/contracts/Bridge.d.ts +352 -0
- package/dist/crosschain/contracts/Bridge.js +2 -0
- package/dist/crosschain/contracts/Bridge.js.map +1 -0
- package/dist/crosschain/contracts/BtcRefundUnlocker.d.ts +135 -0
- package/dist/crosschain/contracts/BtcRefundUnlocker.js +2 -0
- package/dist/crosschain/contracts/BtcRefundUnlocker.js.map +1 -0
- package/dist/crosschain/contracts/DragonswapRouter.d.ts +485 -0
- package/dist/crosschain/contracts/DragonswapRouter.js +2 -0
- package/dist/crosschain/contracts/DragonswapRouter.js.map +1 -0
- package/dist/crosschain/contracts/ERC20.d.ts +165 -0
- package/dist/crosschain/contracts/ERC20.js +2 -0
- package/dist/crosschain/contracts/ERC20.js.map +1 -0
- package/dist/crosschain/contracts/Fabric.d.ts +201 -0
- package/dist/crosschain/contracts/Fabric.js +2 -0
- package/dist/crosschain/contracts/Fabric.js.map +1 -0
- package/dist/crosschain/contracts/FeeCollector.d.ts +184 -0
- package/dist/crosschain/contracts/FeeCollector.js +2 -0
- package/dist/crosschain/contracts/FeeCollector.js.map +1 -0
- package/dist/crosschain/contracts/HyperSwapRouter.d.ts +367 -0
- package/dist/crosschain/contracts/HyperSwapRouter.js +2 -0
- package/dist/crosschain/contracts/HyperSwapRouter.js.map +1 -0
- package/dist/crosschain/contracts/IDepository.d.ts +343 -0
- package/dist/crosschain/contracts/IDepository.js +2 -0
- package/dist/crosschain/contracts/IDepository.js.map +1 -0
- package/dist/crosschain/contracts/IRouter.d.ts +67 -0
- package/dist/crosschain/contracts/IRouter.js +2 -0
- package/dist/crosschain/contracts/IRouter.js.map +1 -0
- package/dist/crosschain/contracts/IzumiFactory.d.ts +229 -0
- package/dist/crosschain/contracts/IzumiFactory.js +2 -0
- package/dist/crosschain/contracts/IzumiFactory.js.map +1 -0
- package/dist/crosschain/contracts/IzumiPool.d.ts +990 -0
- package/dist/crosschain/contracts/IzumiPool.js +2 -0
- package/dist/crosschain/contracts/IzumiPool.js.map +1 -0
- package/dist/crosschain/contracts/IzumiQuoter.d.ts +271 -0
- package/dist/crosschain/contracts/IzumiQuoter.js +2 -0
- package/dist/crosschain/contracts/IzumiQuoter.js.map +1 -0
- package/dist/crosschain/contracts/IzumiSwap.d.ts +337 -0
- package/dist/crosschain/contracts/IzumiSwap.js +2 -0
- package/dist/crosschain/contracts/IzumiSwap.js.map +1 -0
- package/dist/crosschain/contracts/KavaRouter.d.ts +629 -0
- package/dist/crosschain/contracts/KavaRouter.js +2 -0
- package/dist/crosschain/contracts/KavaRouter.js.map +1 -0
- package/dist/crosschain/contracts/KimRouter.d.ts +454 -0
- package/dist/crosschain/contracts/KimRouter.js +2 -0
- package/dist/crosschain/contracts/KimRouter.js.map +1 -0
- package/dist/crosschain/contracts/MetaRouter.d.ts +202 -0
- package/dist/crosschain/contracts/MetaRouter.js +2 -0
- package/dist/crosschain/contracts/MetaRouter.js.map +1 -0
- package/dist/crosschain/contracts/Multicall.d.ts +219 -0
- package/dist/crosschain/contracts/Multicall.js +2 -0
- package/dist/crosschain/contracts/Multicall.js.map +1 -0
- package/dist/crosschain/contracts/MulticallRouter.d.ts +58 -0
- package/dist/crosschain/contracts/MulticallRouter.js +2 -0
- package/dist/crosschain/contracts/MulticallRouter.js.map +1 -0
- package/dist/crosschain/contracts/MulticallRouterV2.d.ts +59 -0
- package/dist/crosschain/contracts/MulticallRouterV2.js +2 -0
- package/dist/crosschain/contracts/MulticallRouterV2.js.map +1 -0
- package/dist/crosschain/contracts/OctoPoolFeeCollector.d.ts +190 -0
- package/dist/crosschain/contracts/OctoPoolFeeCollector.js +2 -0
- package/dist/crosschain/contracts/OctoPoolFeeCollector.js.map +1 -0
- package/dist/crosschain/contracts/OmniPool.d.ts +1033 -0
- package/dist/crosschain/contracts/OmniPool.js +2 -0
- package/dist/crosschain/contracts/OmniPool.js.map +1 -0
- package/dist/crosschain/contracts/OmniPoolOracle.d.ts +303 -0
- package/dist/crosschain/contracts/OmniPoolOracle.js +2 -0
- package/dist/crosschain/contracts/OmniPoolOracle.js.map +1 -0
- package/dist/crosschain/contracts/OneInchOracle.d.ts +293 -0
- package/dist/crosschain/contracts/OneInchOracle.js +2 -0
- package/dist/crosschain/contracts/OneInchOracle.js.map +1 -0
- package/dist/crosschain/contracts/PartnerFeeCollector.d.ts +357 -0
- package/dist/crosschain/contracts/PartnerFeeCollector.js +2 -0
- package/dist/crosschain/contracts/PartnerFeeCollector.js.map +1 -0
- package/dist/crosschain/contracts/Portal.d.ts +781 -0
- package/dist/crosschain/contracts/Portal.js +2 -0
- package/dist/crosschain/contracts/Portal.js.map +1 -0
- package/dist/crosschain/contracts/SymBtc.d.ts +252 -0
- package/dist/crosschain/contracts/SymBtc.js +2 -0
- package/dist/crosschain/contracts/SymBtc.js.map +1 -0
- package/dist/crosschain/contracts/Synthesis.d.ts +953 -0
- package/dist/crosschain/contracts/Synthesis.js +2 -0
- package/dist/crosschain/contracts/Synthesis.js.map +1 -0
- package/dist/crosschain/contracts/ThorRouter.d.ts +256 -0
- package/dist/crosschain/contracts/ThorRouter.js +2 -0
- package/dist/crosschain/contracts/ThorRouter.js.map +1 -0
- package/dist/crosschain/contracts/TimedSwapUnlocker.d.ts +170 -0
- package/dist/crosschain/contracts/TimedSwapUnlocker.js +2 -0
- package/dist/crosschain/contracts/TimedSwapUnlocker.js.map +1 -0
- package/dist/crosschain/contracts/TimedUnlocker.d.ts +131 -0
- package/dist/crosschain/contracts/TimedUnlocker.js +2 -0
- package/dist/crosschain/contracts/TimedUnlocker.js.map +1 -0
- package/dist/crosschain/contracts/TonBridge.d.ts +272 -0
- package/dist/crosschain/contracts/TonBridge.js +2 -0
- package/dist/crosschain/contracts/TonBridge.js.map +1 -0
- package/dist/crosschain/contracts/UniLikeRouter.d.ts +485 -0
- package/dist/crosschain/contracts/UniLikeRouter.js +2 -0
- package/dist/crosschain/contracts/UniLikeRouter.js.map +1 -0
- package/dist/crosschain/contracts/UniV2Pair.d.ts +464 -0
- package/dist/crosschain/contracts/UniV2Pair.js +2 -0
- package/dist/crosschain/contracts/UniV2Pair.js.map +1 -0
- package/dist/crosschain/contracts/UniV3Factory.d.ts +198 -0
- package/dist/crosschain/contracts/UniV3Factory.js +2 -0
- package/dist/crosschain/contracts/UniV3Factory.js.map +1 -0
- package/dist/crosschain/contracts/UniV3Quoter.d.ts +205 -0
- package/dist/crosschain/contracts/UniV3Quoter.js +2 -0
- package/dist/crosschain/contracts/UniV3Quoter.js.map +1 -0
- package/dist/crosschain/contracts/UniV3Router.d.ts +419 -0
- package/dist/crosschain/contracts/UniV3Router.js +2 -0
- package/dist/crosschain/contracts/UniV3Router.js.map +1 -0
- package/dist/crosschain/contracts/UniV3Router02.d.ts +778 -0
- package/dist/crosschain/contracts/UniV3Router02.js +2 -0
- package/dist/crosschain/contracts/UniV3Router02.js.map +1 -0
- package/dist/crosschain/contracts/Unwrapper.d.ts +130 -0
- package/dist/crosschain/contracts/Unwrapper.js +2 -0
- package/dist/crosschain/contracts/Unwrapper.js.map +1 -0
- package/dist/crosschain/contracts/WTON.d.ts +450 -0
- package/dist/crosschain/contracts/WTON.js +2 -0
- package/dist/crosschain/contracts/WTON.js.map +1 -0
- package/dist/crosschain/contracts/Weth.d.ts +218 -0
- package/dist/crosschain/contracts/Weth.js +2 -0
- package/dist/crosschain/contracts/Weth.js.map +1 -0
- package/dist/crosschain/contracts/WithdrawUnlocker.d.ts +122 -0
- package/dist/crosschain/contracts/WithdrawUnlocker.js +2 -0
- package/dist/crosschain/contracts/WithdrawUnlocker.js.map +1 -0
- package/dist/crosschain/contracts/common.d.ts +21 -0
- package/dist/crosschain/contracts/common.js +2 -0
- package/dist/crosschain/contracts/common.js.map +1 -0
- package/dist/crosschain/contracts/factories/AdaRouter__factory.d.ts +759 -0
- package/dist/crosschain/contracts/factories/AdaRouter__factory.js +987 -0
- package/dist/crosschain/contracts/factories/AdaRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/AvaxRouter__factory.d.ts +759 -0
- package/dist/crosschain/contracts/factories/AvaxRouter__factory.js +987 -0
- package/dist/crosschain/contracts/factories/AvaxRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/BranchedUnlocker__factory.d.ts +171 -0
- package/dist/crosschain/contracts/factories/BranchedUnlocker__factory.js +240 -0
- package/dist/crosschain/contracts/factories/BranchedUnlocker__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/Bridge__factory.d.ts +372 -0
- package/dist/crosschain/contracts/factories/Bridge__factory.js +493 -0
- package/dist/crosschain/contracts/factories/Bridge__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/BtcRefundUnlocker__factory.d.ts +160 -0
- package/dist/crosschain/contracts/factories/BtcRefundUnlocker__factory.js +225 -0
- package/dist/crosschain/contracts/factories/BtcRefundUnlocker__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/DragonswapRouter__factory.d.ts +759 -0
- package/dist/crosschain/contracts/factories/DragonswapRouter__factory.js +987 -0
- package/dist/crosschain/contracts/factories/DragonswapRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/ERC20__factory.d.ts +175 -0
- package/dist/crosschain/contracts/factories/ERC20__factory.js +236 -0
- package/dist/crosschain/contracts/factories/ERC20__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/Fabric__factory.d.ts +211 -0
- package/dist/crosschain/contracts/factories/Fabric__factory.js +286 -0
- package/dist/crosschain/contracts/factories/Fabric__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/FeeCollector__factory.d.ts +159 -0
- package/dist/crosschain/contracts/factories/FeeCollector__factory.js +208 -0
- package/dist/crosschain/contracts/factories/FeeCollector__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/HyperSwapRouter__factory.d.ts +555 -0
- package/dist/crosschain/contracts/factories/HyperSwapRouter__factory.js +720 -0
- package/dist/crosschain/contracts/factories/HyperSwapRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/IDepository__factory.d.ts +495 -0
- package/dist/crosschain/contracts/factories/IDepository__factory.js +658 -0
- package/dist/crosschain/contracts/factories/IDepository__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/IRouter__factory.d.ts +60 -0
- package/dist/crosschain/contracts/factories/IRouter__factory.js +83 -0
- package/dist/crosschain/contracts/factories/IRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/IzumiFactory__factory.d.ts +263 -0
- package/dist/crosschain/contracts/factories/IzumiFactory__factory.js +345 -0
- package/dist/crosschain/contracts/factories/IzumiFactory__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/IzumiPool__factory.d.ts +1096 -0
- package/dist/crosschain/contracts/factories/IzumiPool__factory.js +1420 -0
- package/dist/crosschain/contracts/factories/IzumiPool__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/IzumiQuoter__factory.d.ts +333 -0
- package/dist/crosschain/contracts/factories/IzumiQuoter__factory.js +438 -0
- package/dist/crosschain/contracts/factories/IzumiQuoter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/IzumiSwap__factory.d.ts +419 -0
- package/dist/crosschain/contracts/factories/IzumiSwap__factory.js +546 -0
- package/dist/crosschain/contracts/factories/IzumiSwap__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/KavaRouter__factory.d.ts +975 -0
- package/dist/crosschain/contracts/factories/KavaRouter__factory.js +1266 -0
- package/dist/crosschain/contracts/factories/KavaRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/KimRouter__factory.d.ts +632 -0
- package/dist/crosschain/contracts/factories/KimRouter__factory.js +820 -0
- package/dist/crosschain/contracts/factories/KimRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/MetaRouter__factory.d.ts +230 -0
- package/dist/crosschain/contracts/factories/MetaRouter__factory.js +306 -0
- package/dist/crosschain/contracts/factories/MetaRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/MulticallRouterV2__factory.d.ts +59 -0
- package/dist/crosschain/contracts/factories/MulticallRouterV2__factory.js +89 -0
- package/dist/crosschain/contracts/factories/MulticallRouterV2__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/MulticallRouter__factory.d.ts +52 -0
- package/dist/crosschain/contracts/factories/MulticallRouter__factory.js +80 -0
- package/dist/crosschain/contracts/factories/MulticallRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/Multicall__factory.d.ts +243 -0
- package/dist/crosschain/contracts/factories/Multicall__factory.js +327 -0
- package/dist/crosschain/contracts/factories/Multicall__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/OctoPoolFeeCollector__factory.d.ts +174 -0
- package/dist/crosschain/contracts/factories/OctoPoolFeeCollector__factory.js +237 -0
- package/dist/crosschain/contracts/factories/OctoPoolFeeCollector__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/OmniPoolOracle__factory.d.ts +273 -0
- package/dist/crosschain/contracts/factories/OmniPoolOracle__factory.js +366 -0
- package/dist/crosschain/contracts/factories/OmniPoolOracle__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/OmniPool__factory.d.ts +1126 -0
- package/dist/crosschain/contracts/factories/OmniPool__factory.js +1459 -0
- package/dist/crosschain/contracts/factories/OmniPool__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/OneInchOracle__factory.d.ts +265 -0
- package/dist/crosschain/contracts/factories/OneInchOracle__factory.js +348 -0
- package/dist/crosschain/contracts/factories/OneInchOracle__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/PartnerFeeCollector__factory.d.ts +340 -0
- package/dist/crosschain/contracts/factories/PartnerFeeCollector__factory.js +442 -0
- package/dist/crosschain/contracts/factories/PartnerFeeCollector__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/Portal__factory.d.ts +906 -0
- package/dist/crosschain/contracts/factories/Portal__factory.js +1172 -0
- package/dist/crosschain/contracts/factories/Portal__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/SymBtc__factory.d.ts +359 -0
- package/dist/crosschain/contracts/factories/SymBtc__factory.js +473 -0
- package/dist/crosschain/contracts/factories/SymBtc__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/Synthesis__factory.d.ts +1139 -0
- package/dist/crosschain/contracts/factories/Synthesis__factory.js +1458 -0
- package/dist/crosschain/contracts/factories/Synthesis__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/ThorRouter__factory.d.ts +356 -0
- package/dist/crosschain/contracts/factories/ThorRouter__factory.js +456 -0
- package/dist/crosschain/contracts/factories/ThorRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/TimedSwapUnlocker__factory.d.ts +245 -0
- package/dist/crosschain/contracts/factories/TimedSwapUnlocker__factory.js +330 -0
- package/dist/crosschain/contracts/factories/TimedSwapUnlocker__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/TimedUnlocker__factory.d.ts +170 -0
- package/dist/crosschain/contracts/factories/TimedUnlocker__factory.js +236 -0
- package/dist/crosschain/contracts/factories/TimedUnlocker__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/TonBridge__factory.d.ts +214 -0
- package/dist/crosschain/contracts/factories/TonBridge__factory.js +282 -0
- package/dist/crosschain/contracts/factories/TonBridge__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/UniLikeRouter__factory.d.ts +744 -0
- package/dist/crosschain/contracts/factories/UniLikeRouter__factory.js +967 -0
- package/dist/crosschain/contracts/factories/UniLikeRouter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/UniV2Pair__factory.d.ts +567 -0
- package/dist/crosschain/contracts/factories/UniV2Pair__factory.js +721 -0
- package/dist/crosschain/contracts/factories/UniV2Pair__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/UniV3Factory__factory.d.ts +190 -0
- package/dist/crosschain/contracts/factories/UniV3Factory__factory.js +250 -0
- package/dist/crosschain/contracts/factories/UniV3Factory__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/UniV3Quoter__factory.d.ts +212 -0
- package/dist/crosschain/contracts/factories/UniV3Quoter__factory.js +281 -0
- package/dist/crosschain/contracts/factories/UniV3Quoter__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/UniV3Router02__factory.d.ts +827 -0
- package/dist/crosschain/contracts/factories/UniV3Router02__factory.js +1077 -0
- package/dist/crosschain/contracts/factories/UniV3Router02__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/UniV3Router__factory.d.ts +445 -0
- package/dist/crosschain/contracts/factories/UniV3Router__factory.js +579 -0
- package/dist/crosschain/contracts/factories/UniV3Router__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/Unwrapper__factory.d.ts +91 -0
- package/dist/crosschain/contracts/factories/Unwrapper__factory.js +123 -0
- package/dist/crosschain/contracts/factories/Unwrapper__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/WTON__factory.d.ts +637 -0
- package/dist/crosschain/contracts/factories/WTON__factory.js +837 -0
- package/dist/crosschain/contracts/factories/WTON__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/Weth__factory.d.ts +220 -0
- package/dist/crosschain/contracts/factories/Weth__factory.js +293 -0
- package/dist/crosschain/contracts/factories/Weth__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/WithdrawUnlocker__factory.d.ts +144 -0
- package/dist/crosschain/contracts/factories/WithdrawUnlocker__factory.js +201 -0
- package/dist/crosschain/contracts/factories/WithdrawUnlocker__factory.js.map +1 -0
- package/dist/crosschain/contracts/factories/index.d.ts +44 -0
- package/dist/crosschain/contracts/factories/index.js +48 -0
- package/dist/crosschain/contracts/factories/index.js.map +1 -0
- package/dist/crosschain/contracts/index.d.ts +89 -0
- package/dist/crosschain/contracts/index.js +46 -0
- package/dist/crosschain/contracts/index.js.map +1 -0
- package/dist/crosschain/depository.d.ts +60 -0
- package/dist/crosschain/depository.js +194 -0
- package/dist/crosschain/depository.js.map +1 -0
- package/dist/crosschain/feeCall/getPartnerFeeCall.d.ts +9 -0
- package/dist/crosschain/feeCall/getPartnerFeeCall.js +86 -0
- package/dist/crosschain/feeCall/getPartnerFeeCall.js.map +1 -0
- package/dist/crosschain/feeCall/getVolumeFeeCall.d.ts +7 -0
- package/dist/crosschain/feeCall/getVolumeFeeCall.js +42 -0
- package/dist/crosschain/feeCall/getVolumeFeeCall.js.map +1 -0
- package/dist/crosschain/index.d.ts +22 -0
- package/dist/crosschain/index.js +22 -0
- package/dist/crosschain/index.js.map +1 -0
- package/dist/crosschain/mempool.d.ts +1 -0
- package/dist/crosschain/mempool.js +12 -0
- package/dist/crosschain/mempool.js.map +1 -0
- package/dist/crosschain/multicall.d.ts +7 -0
- package/dist/crosschain/multicall.js +16 -0
- package/dist/crosschain/multicall.js.map +1 -0
- package/dist/crosschain/omniLiquidity.d.ts +17 -0
- package/dist/crosschain/omniLiquidity.js +43 -0
- package/dist/crosschain/omniLiquidity.js.map +1 -0
- package/dist/crosschain/revert.d.ts +43 -0
- package/dist/crosschain/revert.js +478 -0
- package/dist/crosschain/revert.js.map +1 -0
- package/dist/crosschain/revertRequest.d.ts +46 -0
- package/dist/crosschain/revertRequest.js +237 -0
- package/dist/crosschain/revertRequest.js.map +1 -0
- package/dist/crosschain/sdkError.d.ts +63 -0
- package/dist/crosschain/sdkError.js +140 -0
- package/dist/crosschain/sdkError.js.map +1 -0
- package/dist/crosschain/swapExactIn/aggregatorsSwap.d.ts +2 -0
- package/dist/crosschain/swapExactIn/aggregatorsSwap.js +50 -0
- package/dist/crosschain/swapExactIn/aggregatorsSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/bridge.d.ts +3 -0
- package/dist/crosschain/swapExactIn/bridge.js +303 -0
- package/dist/crosschain/swapExactIn/bridge.js.map +1 -0
- package/dist/crosschain/swapExactIn/crosschainSwap/bestPoolSwapping.d.ts +17 -0
- package/dist/crosschain/swapExactIn/crosschainSwap/bestPoolSwapping.js +162 -0
- package/dist/crosschain/swapExactIn/crosschainSwap/bestPoolSwapping.js.map +1 -0
- package/dist/crosschain/swapExactIn/crosschainSwap/crosschainSwap.d.ts +2 -0
- package/dist/crosschain/swapExactIn/crosschainSwap/crosschainSwap.js +11 -0
- package/dist/crosschain/swapExactIn/crosschainSwap/crosschainSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/crosschainSwap/index.d.ts +1 -0
- package/dist/crosschain/swapExactIn/crosschainSwap/index.js +2 -0
- package/dist/crosschain/swapExactIn/crosschainSwap/index.js.map +1 -0
- package/dist/crosschain/swapExactIn/dedustSwap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/dedustSwap.js +47 -0
- package/dist/crosschain/swapExactIn/dedustSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/feeCollectorSwap.d.ts +6 -0
- package/dist/crosschain/swapExactIn/feeCollectorSwap.js +143 -0
- package/dist/crosschain/swapExactIn/feeCollectorSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/fromBtcSwap.d.ts +18 -0
- package/dist/crosschain/swapExactIn/fromBtcSwap.js +638 -0
- package/dist/crosschain/swapExactIn/fromBtcSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/index.d.ts +4 -0
- package/dist/crosschain/swapExactIn/index.js +5 -0
- package/dist/crosschain/swapExactIn/index.js.map +1 -0
- package/dist/crosschain/swapExactIn/octoPoolSwap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/octoPoolSwap.js +52 -0
- package/dist/crosschain/swapExactIn/octoPoolSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/onChainSolanaSwap/index.d.ts +1 -0
- package/dist/crosschain/swapExactIn/onChainSolanaSwap/index.js +2 -0
- package/dist/crosschain/swapExactIn/onChainSolanaSwap/index.js.map +1 -0
- package/dist/crosschain/swapExactIn/onChainSolanaSwap/onChainSolanaSwap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/onChainSolanaSwap/onChainSolanaSwap.js +64 -0
- package/dist/crosschain/swapExactIn/onChainSolanaSwap/onChainSolanaSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/onchainSwap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/onchainSwap.js +28 -0
- package/dist/crosschain/swapExactIn/onchainSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/preparePayload.d.ts +12 -0
- package/dist/crosschain/swapExactIn/preparePayload.js +34 -0
- package/dist/crosschain/swapExactIn/preparePayload.js.map +1 -0
- package/dist/crosschain/swapExactIn/raydiumSwap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/raydiumSwap.js +51 -0
- package/dist/crosschain/swapExactIn/raydiumSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/stonfiSwap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/stonfiSwap.js +52 -0
- package/dist/crosschain/swapExactIn/stonfiSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/btcChainFlipSwap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/btcChainFlipSwap.js +57 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/btcChainFlipSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/index.d.ts +2 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/index.js +3 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/index.js.map +1 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/solanaChainFlipSwap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/solanaChainFlipSwap.js +76 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/solanaChainFlipSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/types.d.ts +33 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/types.js +22 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/types.js.map +1 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/utils.d.ts +16 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/utils.js +89 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/utils.js.map +1 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/zappingCrossChainChainFlip.d.ts +34 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/zappingCrossChainChainFlip.js +170 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/zappingCrossChainChainFlip.js.map +1 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/zappingOnChainChainFlip.d.ts +3 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/zappingOnChainChainFlip.js +250 -0
- package/dist/crosschain/swapExactIn/swapChainFlip/zappingOnChainChainFlip.js.map +1 -0
- package/dist/crosschain/swapExactIn/swapExactIn.d.ts +3 -0
- package/dist/crosschain/swapExactIn/swapExactIn.js +54 -0
- package/dist/crosschain/swapExactIn/swapExactIn.js.map +1 -0
- package/dist/crosschain/swapExactIn/thorChainSwap.d.ts +4 -0
- package/dist/crosschain/swapExactIn/thorChainSwap.js +46 -0
- package/dist/crosschain/swapExactIn/thorChainSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/toBtc/burnSyntheticBtc.d.ts +2 -0
- package/dist/crosschain/swapExactIn/toBtc/burnSyntheticBtc.js +50 -0
- package/dist/crosschain/swapExactIn/toBtc/burnSyntheticBtc.js.map +1 -0
- package/dist/crosschain/swapExactIn/toBtc/zappingBtcOnChain.d.ts +3 -0
- package/dist/crosschain/swapExactIn/toBtc/zappingBtcOnChain.js +208 -0
- package/dist/crosschain/swapExactIn/toBtc/zappingBtcOnChain.js.map +1 -0
- package/dist/crosschain/swapExactIn/toBtcSwap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/toBtcSwap.js +34 -0
- package/dist/crosschain/swapExactIn/toBtcSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/toSolanaSwap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/toSolanaSwap.js +19 -0
- package/dist/crosschain/swapExactIn/toSolanaSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/toTonSwap.d.ts +2 -0
- package/dist/crosschain/swapExactIn/toTonSwap.js +29 -0
- package/dist/crosschain/swapExactIn/toTonSwap.js.map +1 -0
- package/dist/crosschain/swapExactIn/unwrap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/unwrap.js +53 -0
- package/dist/crosschain/swapExactIn/unwrap.js.map +1 -0
- package/dist/crosschain/swapExactIn/utils.d.ts +2 -0
- package/dist/crosschain/swapExactIn/utils.js +30 -0
- package/dist/crosschain/swapExactIn/utils.js.map +1 -0
- package/dist/crosschain/swapExactIn/wrap.d.ts +3 -0
- package/dist/crosschain/swapExactIn/wrap.js +59 -0
- package/dist/crosschain/swapExactIn/wrap.js.map +1 -0
- package/dist/crosschain/swapping/baseSwapping.d.ts +111 -0
- package/dist/crosschain/swapping/baseSwapping.js +852 -0
- package/dist/crosschain/swapping/baseSwapping.js.map +1 -0
- package/dist/crosschain/swapping/index.d.ts +6 -0
- package/dist/crosschain/swapping/index.js +7 -0
- package/dist/crosschain/swapping/index.js.map +1 -0
- package/dist/crosschain/swapping/swapping.d.ts +5 -0
- package/dist/crosschain/swapping/swapping.js +7 -0
- package/dist/crosschain/swapping/swapping.js.map +1 -0
- package/dist/crosschain/swapping/swappingMiddleware.d.ts +11 -0
- package/dist/crosschain/swapping/swappingMiddleware.js +84 -0
- package/dist/crosschain/swapping/swappingMiddleware.js.map +1 -0
- package/dist/crosschain/swapping/swappingToTon.d.ts +18 -0
- package/dist/crosschain/swapping/swappingToTon.js +71 -0
- package/dist/crosschain/swapping/swappingToTon.js.map +1 -0
- package/dist/crosschain/swapping/zappingBtc.d.ts +37 -0
- package/dist/crosschain/swapping/zappingBtc.js +191 -0
- package/dist/crosschain/swapping/zappingBtc.js.map +1 -0
- package/dist/crosschain/swapping/zappingThor.d.ts +66 -0
- package/dist/crosschain/swapping/zappingThor.js +226 -0
- package/dist/crosschain/swapping/zappingThor.js.map +1 -0
- package/dist/crosschain/symbiosis.d.ts +125 -0
- package/dist/crosschain/symbiosis.js +613 -0
- package/dist/crosschain/symbiosis.js.map +1 -0
- package/dist/crosschain/tracing.d.ts +49 -0
- package/dist/crosschain/tracing.js +98 -0
- package/dist/crosschain/tracing.js.map +1 -0
- package/dist/crosschain/trade/aggregatorTrade.d.ts +43 -0
- package/dist/crosschain/trade/aggregatorTrade.js +300 -0
- package/dist/crosschain/trade/aggregatorTrade.js.map +1 -0
- package/dist/crosschain/trade/dedustTrade.d.ts +71 -0
- package/dist/crosschain/trade/dedustTrade.js +297 -0
- package/dist/crosschain/trade/dedustTrade.js.map +1 -0
- package/dist/crosschain/trade/depositoryTrade.d.ts +14 -0
- package/dist/crosschain/trade/depositoryTrade.js +39 -0
- package/dist/crosschain/trade/depositoryTrade.js.map +1 -0
- package/dist/crosschain/trade/index.d.ts +13 -0
- package/dist/crosschain/trade/index.js +13 -0
- package/dist/crosschain/trade/index.js.map +1 -0
- package/dist/crosschain/trade/izumiTrade.d.ts +33 -0
- package/dist/crosschain/trade/izumiTrade.js +473 -0
- package/dist/crosschain/trade/izumiTrade.js.map +1 -0
- package/dist/crosschain/trade/jupiterTrade.d.ts +62 -0
- package/dist/crosschain/trade/jupiterTrade.js +65 -0
- package/dist/crosschain/trade/jupiterTrade.js.map +1 -0
- package/dist/crosschain/trade/octoPoolTrade.d.ts +20 -0
- package/dist/crosschain/trade/octoPoolTrade.js +65 -0
- package/dist/crosschain/trade/octoPoolTrade.js.map +1 -0
- package/dist/crosschain/trade/oneInchTrade.d.ts +24 -0
- package/dist/crosschain/trade/oneInchTrade.js +293 -0
- package/dist/crosschain/trade/oneInchTrade.js.map +1 -0
- package/dist/crosschain/trade/openOceanTrade.d.ts +29 -0
- package/dist/crosschain/trade/openOceanTrade.js +294 -0
- package/dist/crosschain/trade/openOceanTrade.js.map +1 -0
- package/dist/crosschain/trade/raydiumTrade.d.ts +28 -0
- package/dist/crosschain/trade/raydiumTrade.js +110 -0
- package/dist/crosschain/trade/raydiumTrade.js.map +1 -0
- package/dist/crosschain/trade/stonfiTrade.d.ts +27 -0
- package/dist/crosschain/trade/stonfiTrade.js +119 -0
- package/dist/crosschain/trade/stonfiTrade.js.map +1 -0
- package/dist/crosschain/trade/symbiosisTrade.d.ts +55 -0
- package/dist/crosschain/trade/symbiosisTrade.js +160 -0
- package/dist/crosschain/trade/symbiosisTrade.js.map +1 -0
- package/dist/crosschain/trade/uniV2Trade.d.ts +29 -0
- package/dist/crosschain/trade/uniV2Trade.js +250 -0
- package/dist/crosschain/trade/uniV2Trade.js.map +1 -0
- package/dist/crosschain/trade/uniV3Trade.d.ts +23 -0
- package/dist/crosschain/trade/uniV3Trade.js +375 -0
- package/dist/crosschain/trade/uniV3Trade.js.map +1 -0
- package/dist/crosschain/trade/uniV3TradeImpl/getOutputQuote.d.ts +5 -0
- package/dist/crosschain/trade/uniV3TradeImpl/getOutputQuote.js +14 -0
- package/dist/crosschain/trade/uniV3TradeImpl/getOutputQuote.js.map +1 -0
- package/dist/crosschain/trade/uniV3TradeImpl/pool.d.ts +5 -0
- package/dist/crosschain/trade/uniV3TradeImpl/pool.js +31 -0
- package/dist/crosschain/trade/uniV3TradeImpl/pool.js.map +1 -0
- package/dist/crosschain/trade/uniV3TradeImpl/toUniTypes.d.ts +13 -0
- package/dist/crosschain/trade/uniV3TradeImpl/toUniTypes.js +34 -0
- package/dist/crosschain/trade/uniV3TradeImpl/toUniTypes.js.map +1 -0
- package/dist/crosschain/trade/wrapTrade.d.ts +11 -0
- package/dist/crosschain/trade/wrapTrade.js +105 -0
- package/dist/crosschain/trade/wrapTrade.js.map +1 -0
- package/dist/crosschain/transit.d.ts +69 -0
- package/dist/crosschain/transit.js +331 -0
- package/dist/crosschain/transit.js.map +1 -0
- package/dist/crosschain/tronAbis/index.d.ts +3 -0
- package/dist/crosschain/tronAbis/index.js +4 -0
- package/dist/crosschain/tronAbis/index.js.map +1 -0
- package/dist/crosschain/tronAbis/tronMetaRouterAbi.d.ts +209 -0
- package/dist/crosschain/tronAbis/tronMetaRouterAbi.js +267 -0
- package/dist/crosschain/tronAbis/tronMetaRouterAbi.js.map +1 -0
- package/dist/crosschain/tronAbis/tronPortalAbi.d.ts +990 -0
- package/dist/crosschain/tronAbis/tronPortalAbi.js +1267 -0
- package/dist/crosschain/tronAbis/tronPortalAbi.js.map +1 -0
- package/dist/crosschain/tronAbis/tronTRC20Abi.d.ts +171 -0
- package/dist/crosschain/tronAbis/tronTRC20Abi.js +128 -0
- package/dist/crosschain/tronAbis/tronTRC20Abi.js.map +1 -0
- package/dist/crosschain/types.d.ts +265 -0
- package/dist/crosschain/types.js +6 -0
- package/dist/crosschain/types.js.map +1 -0
- package/dist/crosschain/utils.d.ts +9 -0
- package/dist/crosschain/utils.js +25 -0
- package/dist/crosschain/utils.js.map +1 -0
- package/dist/crosschain/waitForComplete/constants.d.ts +5 -0
- package/dist/crosschain/waitForComplete/constants.js +9 -0
- package/dist/crosschain/waitForComplete/constants.js.map +1 -0
- package/dist/crosschain/waitForComplete/getTxTonBridgeInfo.d.ts +3 -0
- package/dist/crosschain/waitForComplete/getTxTonBridgeInfo.js +68 -0
- package/dist/crosschain/waitForComplete/getTxTonBridgeInfo.js.map +1 -0
- package/dist/crosschain/waitForComplete/index.d.ts +7 -0
- package/dist/crosschain/waitForComplete/index.js +7 -0
- package/dist/crosschain/waitForComplete/index.js.map +1 -0
- package/dist/crosschain/waitForComplete/tryToFindExtraStepsAndWait.d.ts +13 -0
- package/dist/crosschain/waitForComplete/tryToFindExtraStepsAndWait.js +172 -0
- package/dist/crosschain/waitForComplete/tryToFindExtraStepsAndWait.js.map +1 -0
- package/dist/crosschain/waitForComplete/types.d.ts +13 -0
- package/dist/crosschain/waitForComplete/types.js +2 -0
- package/dist/crosschain/waitForComplete/types.js.map +1 -0
- package/dist/crosschain/waitForComplete/utils.d.ts +10 -0
- package/dist/crosschain/waitForComplete/utils.js +41 -0
- package/dist/crosschain/waitForComplete/utils.js.map +1 -0
- package/dist/crosschain/waitForComplete/waitForBtcCommitTxMined.d.ts +11 -0
- package/dist/crosschain/waitForComplete/waitForBtcCommitTxMined.js +34 -0
- package/dist/crosschain/waitForComplete/waitForBtcCommitTxMined.js.map +1 -0
- package/dist/crosschain/waitForComplete/waitForBtcDepositAccepted.d.ts +6 -0
- package/dist/crosschain/waitForComplete/waitForBtcDepositAccepted.js +27 -0
- package/dist/crosschain/waitForComplete/waitForBtcDepositAccepted.js.map +1 -0
- package/dist/crosschain/waitForComplete/waitForBtcEvmTxIssued.d.ts +3 -0
- package/dist/crosschain/waitForComplete/waitForBtcEvmTxIssued.js +20 -0
- package/dist/crosschain/waitForComplete/waitForBtcEvmTxIssued.js.map +1 -0
- package/dist/crosschain/waitForComplete/waitForComplete.d.ts +17 -0
- package/dist/crosschain/waitForComplete/waitForComplete.js +171 -0
- package/dist/crosschain/waitForComplete/waitForComplete.js.map +1 -0
- package/dist/crosschain/waitForComplete/waitForDepositUnlocked.d.ts +4 -0
- package/dist/crosschain/waitForComplete/waitForDepositUnlocked.js +30 -0
- package/dist/crosschain/waitForComplete/waitForDepositUnlocked.js.map +1 -0
- package/dist/crosschain/waitForComplete/waitForTonDepositTxMined.d.ts +3 -0
- package/dist/crosschain/waitForComplete/waitForTonDepositTxMined.js +84 -0
- package/dist/crosschain/waitForComplete/waitForTonDepositTxMined.js.map +1 -0
- package/dist/crosschain/waitForComplete/waitFromTonTxMined.d.ts +8 -0
- package/dist/crosschain/waitForComplete/waitFromTonTxMined.js +61 -0
- package/dist/crosschain/waitForComplete/waitFromTonTxMined.js.map +1 -0
- package/dist/crosschain/zapping.d.ts +43 -0
- package/dist/crosschain/zapping.js +347 -0
- package/dist/crosschain/zapping.js.map +1 -0
- package/dist/entities/chain.d.ts +13 -0
- package/dist/entities/chain.js +824 -0
- package/dist/entities/chain.js.map +1 -0
- package/dist/entities/fractions/fraction.d.ts +21 -0
- package/dist/entities/fractions/fraction.js +93 -0
- package/dist/entities/fractions/fraction.js.map +1 -0
- package/dist/entities/fractions/index.d.ts +4 -0
- package/dist/entities/fractions/index.js +5 -0
- package/dist/entities/fractions/index.js.map +1 -0
- package/dist/entities/fractions/percent.d.ts +6 -0
- package/dist/entities/fractions/percent.js +12 -0
- package/dist/entities/fractions/percent.js.map +1 -0
- package/dist/entities/fractions/price.d.ts +19 -0
- package/dist/entities/fractions/price.js +53 -0
- package/dist/entities/fractions/price.js.map +1 -0
- package/dist/entities/fractions/tokenAmount.d.ts +18 -0
- package/dist/entities/fractions/tokenAmount.js +45 -0
- package/dist/entities/fractions/tokenAmount.js.map +1 -0
- package/dist/entities/gasToken.d.ts +3 -0
- package/dist/entities/gasToken.js +107 -0
- package/dist/entities/gasToken.js.map +1 -0
- package/dist/entities/index.d.ts +8 -0
- package/dist/entities/index.js +9 -0
- package/dist/entities/index.js.map +1 -0
- package/dist/entities/pair.d.ts +50 -0
- package/dist/entities/pair.js +209 -0
- package/dist/entities/pair.js.map +1 -0
- package/dist/entities/profiler.d.ts +14 -0
- package/dist/entities/profiler.js +33 -0
- package/dist/entities/profiler.js.map +1 -0
- package/dist/entities/route.d.ts +13 -0
- package/dist/entities/route.js +34 -0
- package/dist/entities/route.js.map +1 -0
- package/dist/entities/token.d.ts +148 -0
- package/dist/entities/token.js +1009 -0
- package/dist/entities/token.js.map +1 -0
- package/dist/entities/trade.d.ts +114 -0
- package/dist/entities/trade.js +306 -0
- package/dist/entities/trade.js.map +1 -0
- package/dist/errors.d.ts +14 -0
- package/dist/errors.js +21 -0
- package/dist/errors.js.map +1 -0
- package/dist/index.d.ts +8 -37140
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/dist/router.d.ts +63 -0
- package/dist/router.js +129 -0
- package/dist/router.js.map +1 -0
- package/dist/utils.d.ts +10 -0
- package/dist/utils.js +78 -0
- package/dist/utils.js.map +1 -0
- package/package.json +8 -6
- package/dist/index.esm.js +0 -54532
- package/dist/index.esm.js.map +0 -1
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
[
|
|
2
|
+
{
|
|
3
|
+
"constant": true,
|
|
4
|
+
"inputs": [],
|
|
5
|
+
"name": "name",
|
|
6
|
+
"outputs": [
|
|
7
|
+
{
|
|
8
|
+
"name": "",
|
|
9
|
+
"type": "string"
|
|
10
|
+
}
|
|
11
|
+
],
|
|
12
|
+
"payable": false,
|
|
13
|
+
"stateMutability": "view",
|
|
14
|
+
"type": "function"
|
|
15
|
+
},
|
|
16
|
+
{
|
|
17
|
+
"constant": false,
|
|
18
|
+
"inputs": [
|
|
19
|
+
{
|
|
20
|
+
"name": "_spender",
|
|
21
|
+
"type": "address"
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
"name": "_value",
|
|
25
|
+
"type": "uint256"
|
|
26
|
+
}
|
|
27
|
+
],
|
|
28
|
+
"name": "approve",
|
|
29
|
+
"outputs": [
|
|
30
|
+
{
|
|
31
|
+
"name": "",
|
|
32
|
+
"type": "bool"
|
|
33
|
+
}
|
|
34
|
+
],
|
|
35
|
+
"payable": false,
|
|
36
|
+
"stateMutability": "nonpayable",
|
|
37
|
+
"type": "function"
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
"constant": true,
|
|
41
|
+
"inputs": [],
|
|
42
|
+
"name": "totalSupply",
|
|
43
|
+
"outputs": [
|
|
44
|
+
{
|
|
45
|
+
"name": "",
|
|
46
|
+
"type": "uint256"
|
|
47
|
+
}
|
|
48
|
+
],
|
|
49
|
+
"payable": false,
|
|
50
|
+
"stateMutability": "view",
|
|
51
|
+
"type": "function"
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
"constant": false,
|
|
55
|
+
"inputs": [
|
|
56
|
+
{
|
|
57
|
+
"name": "_from",
|
|
58
|
+
"type": "address"
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
"name": "_to",
|
|
62
|
+
"type": "address"
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
"name": "_value",
|
|
66
|
+
"type": "uint256"
|
|
67
|
+
}
|
|
68
|
+
],
|
|
69
|
+
"name": "transferFrom",
|
|
70
|
+
"outputs": [
|
|
71
|
+
{
|
|
72
|
+
"name": "",
|
|
73
|
+
"type": "bool"
|
|
74
|
+
}
|
|
75
|
+
],
|
|
76
|
+
"payable": false,
|
|
77
|
+
"stateMutability": "nonpayable",
|
|
78
|
+
"type": "function"
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
"constant": true,
|
|
82
|
+
"inputs": [],
|
|
83
|
+
"name": "decimals",
|
|
84
|
+
"outputs": [
|
|
85
|
+
{
|
|
86
|
+
"name": "",
|
|
87
|
+
"type": "uint8"
|
|
88
|
+
}
|
|
89
|
+
],
|
|
90
|
+
"payable": false,
|
|
91
|
+
"stateMutability": "view",
|
|
92
|
+
"type": "function"
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
"constant": true,
|
|
96
|
+
"inputs": [
|
|
97
|
+
{
|
|
98
|
+
"name": "_owner",
|
|
99
|
+
"type": "address"
|
|
100
|
+
}
|
|
101
|
+
],
|
|
102
|
+
"name": "balanceOf",
|
|
103
|
+
"outputs": [
|
|
104
|
+
{
|
|
105
|
+
"name": "balance",
|
|
106
|
+
"type": "uint256"
|
|
107
|
+
}
|
|
108
|
+
],
|
|
109
|
+
"payable": false,
|
|
110
|
+
"stateMutability": "view",
|
|
111
|
+
"type": "function"
|
|
112
|
+
},
|
|
113
|
+
{
|
|
114
|
+
"constant": true,
|
|
115
|
+
"inputs": [],
|
|
116
|
+
"name": "symbol",
|
|
117
|
+
"outputs": [
|
|
118
|
+
{
|
|
119
|
+
"name": "",
|
|
120
|
+
"type": "string"
|
|
121
|
+
}
|
|
122
|
+
],
|
|
123
|
+
"payable": false,
|
|
124
|
+
"stateMutability": "view",
|
|
125
|
+
"type": "function"
|
|
126
|
+
},
|
|
127
|
+
{
|
|
128
|
+
"constant": false,
|
|
129
|
+
"inputs": [
|
|
130
|
+
{
|
|
131
|
+
"name": "_to",
|
|
132
|
+
"type": "address"
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
"name": "_value",
|
|
136
|
+
"type": "uint256"
|
|
137
|
+
}
|
|
138
|
+
],
|
|
139
|
+
"name": "transfer",
|
|
140
|
+
"outputs": [
|
|
141
|
+
{
|
|
142
|
+
"name": "",
|
|
143
|
+
"type": "bool"
|
|
144
|
+
}
|
|
145
|
+
],
|
|
146
|
+
"payable": false,
|
|
147
|
+
"stateMutability": "nonpayable",
|
|
148
|
+
"type": "function"
|
|
149
|
+
},
|
|
150
|
+
{
|
|
151
|
+
"constant": true,
|
|
152
|
+
"inputs": [
|
|
153
|
+
{
|
|
154
|
+
"name": "_owner",
|
|
155
|
+
"type": "address"
|
|
156
|
+
},
|
|
157
|
+
{
|
|
158
|
+
"name": "_spender",
|
|
159
|
+
"type": "address"
|
|
160
|
+
}
|
|
161
|
+
],
|
|
162
|
+
"name": "allowance",
|
|
163
|
+
"outputs": [
|
|
164
|
+
{
|
|
165
|
+
"name": "",
|
|
166
|
+
"type": "uint256"
|
|
167
|
+
}
|
|
168
|
+
],
|
|
169
|
+
"payable": false,
|
|
170
|
+
"stateMutability": "view",
|
|
171
|
+
"type": "function"
|
|
172
|
+
},
|
|
173
|
+
{
|
|
174
|
+
"payable": true,
|
|
175
|
+
"stateMutability": "payable",
|
|
176
|
+
"type": "fallback"
|
|
177
|
+
},
|
|
178
|
+
{
|
|
179
|
+
"anonymous": false,
|
|
180
|
+
"inputs": [
|
|
181
|
+
{
|
|
182
|
+
"indexed": true,
|
|
183
|
+
"name": "owner",
|
|
184
|
+
"type": "address"
|
|
185
|
+
},
|
|
186
|
+
{
|
|
187
|
+
"indexed": true,
|
|
188
|
+
"name": "spender",
|
|
189
|
+
"type": "address"
|
|
190
|
+
},
|
|
191
|
+
{
|
|
192
|
+
"indexed": false,
|
|
193
|
+
"name": "value",
|
|
194
|
+
"type": "uint256"
|
|
195
|
+
}
|
|
196
|
+
],
|
|
197
|
+
"name": "Approval",
|
|
198
|
+
"type": "event"
|
|
199
|
+
},
|
|
200
|
+
{
|
|
201
|
+
"anonymous": false,
|
|
202
|
+
"inputs": [
|
|
203
|
+
{
|
|
204
|
+
"indexed": true,
|
|
205
|
+
"name": "from",
|
|
206
|
+
"type": "address"
|
|
207
|
+
},
|
|
208
|
+
{
|
|
209
|
+
"indexed": true,
|
|
210
|
+
"name": "to",
|
|
211
|
+
"type": "address"
|
|
212
|
+
},
|
|
213
|
+
{
|
|
214
|
+
"indexed": false,
|
|
215
|
+
"name": "value",
|
|
216
|
+
"type": "uint256"
|
|
217
|
+
}
|
|
218
|
+
],
|
|
219
|
+
"name": "Transfer",
|
|
220
|
+
"type": "event"
|
|
221
|
+
}
|
|
222
|
+
]
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
type NotVoid<T> = void extends T ? never : T;
|
|
2
|
+
export declare class Cache {
|
|
3
|
+
maxSize?: number | undefined;
|
|
4
|
+
private data;
|
|
5
|
+
constructor(maxSize?: number | undefined);
|
|
6
|
+
get<T>(key: string[], func: () => Promise<NotVoid<T>>, ttl?: number, cacheExceptions?: boolean): Promise<T>;
|
|
7
|
+
}
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { withSpan } from './tracing.js';
|
|
2
|
+
export class Cache {
|
|
3
|
+
maxSize;
|
|
4
|
+
data = new Map();
|
|
5
|
+
constructor(maxSize) {
|
|
6
|
+
this.maxSize = maxSize;
|
|
7
|
+
}
|
|
8
|
+
async get(key, func, ttl = Number.MAX_SAFE_INTEGER, cacheExceptions = false) {
|
|
9
|
+
const stringKey = key.join('-');
|
|
10
|
+
return await withSpan('Cache.get', { cacheKey: stringKey }, async (span) => {
|
|
11
|
+
const now = Math.floor(Date.now() / 1000);
|
|
12
|
+
const cached = this.data.get(stringKey);
|
|
13
|
+
if (cached)
|
|
14
|
+
span.setAttribute('expiresAt', cached.expiresAt);
|
|
15
|
+
if (cached && now < cached.expiresAt) {
|
|
16
|
+
if (cached.exception)
|
|
17
|
+
throw cached.exception;
|
|
18
|
+
else
|
|
19
|
+
return cached.result;
|
|
20
|
+
}
|
|
21
|
+
span.setAttribute('miss', true);
|
|
22
|
+
const set = (result, exception) => {
|
|
23
|
+
if (this.maxSize === undefined || this.data.size < this.maxSize)
|
|
24
|
+
this.data.set(stringKey, {
|
|
25
|
+
result: result,
|
|
26
|
+
exception: exception,
|
|
27
|
+
expiresAt: now + ttl,
|
|
28
|
+
});
|
|
29
|
+
};
|
|
30
|
+
try {
|
|
31
|
+
const result = await func();
|
|
32
|
+
set(result);
|
|
33
|
+
return result;
|
|
34
|
+
}
|
|
35
|
+
catch (exc) {
|
|
36
|
+
if (cacheExceptions)
|
|
37
|
+
set(undefined, exc);
|
|
38
|
+
throw exc;
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=cache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../src/crosschain/cache.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAA;AAUpC,MAAM,OAAO,KAAK;IAGK;IAFX,IAAI,GAAG,IAAI,GAAG,EAAqB,CAAA;IAE3C,YAAmB,OAAgB;QAAhB,YAAO,GAAP,OAAO,CAAS;IAAG,CAAC;IAEvC,KAAK,CAAC,GAAG,CACL,GAAa,EACb,IAA+B,EAC/B,MAAc,MAAM,CAAC,gBAAgB,EACrC,kBAA2B,KAAK;QAEhC,MAAM,SAAS,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC/B,OAAO,MAAM,QAAQ,CAAC,WAAW,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,EAAE,KAAK,EAAE,IAAU,EAAE,EAAE;YAC7E,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAA;YACzC,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;YACvC,IAAI,MAAM;gBAAE,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,MAAM,CAAC,SAAS,CAAC,CAAA;YAC5D,IAAI,MAAM,IAAI,GAAG,GAAG,MAAM,CAAC,SAAS,EAAE,CAAC;gBACnC,IAAI,MAAM,CAAC,SAAS;oBAAE,MAAM,MAAM,CAAC,SAAS,CAAA;;oBACvC,OAAO,MAAM,CAAC,MAAW,CAAA;YAClC,CAAC;YACD,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;YAC/B,MAAM,GAAG,GAAG,CAAC,MAAU,EAAE,SAAmB,EAAE,EAAE;gBAC5C,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO;oBAC3D,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE;wBACrB,MAAM,EAAE,MAAM;wBACd,SAAS,EAAE,SAAS;wBACpB,SAAS,EAAE,GAAG,GAAG,GAAG;qBACvB,CAAC,CAAA;YACV,CAAC,CAAA;YAED,IAAI,CAAC;gBACD,MAAM,MAAM,GAAG,MAAM,IAAI,EAAE,CAAA;gBAC3B,GAAG,CAAC,MAAM,CAAC,CAAA;gBACX,OAAO,MAAM,CAAA;YACjB,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACX,IAAI,eAAe;oBAAE,GAAG,CAAC,SAAS,EAAE,GAAG,CAAC,CAAA;gBACxC,MAAM,GAAG,CAAA;YACb,CAAC;QACL,CAAC,CAAC,CAAA;IACN,CAAC;CACJ"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Network } from 'bitcoinjs-lib';
|
|
2
|
+
import { ChainId } from '../../constants';
|
|
3
|
+
import { TokenAmount } from '../../entities';
|
|
4
|
+
import type { Cache } from '../cache';
|
|
5
|
+
import type { Synthesis } from '../contracts';
|
|
6
|
+
export declare const getThreshold: (syBtcAmount: TokenAmount, synthesis: Synthesis, cache: Cache) => Promise<TokenAmount>;
|
|
7
|
+
export declare const getToBtcFee: (syBtcAmount: TokenAmount, synthesis: Synthesis, cache: Cache) => Promise<TokenAmount>;
|
|
8
|
+
export declare function isBtcChainId(chainId: ChainId | undefined): boolean;
|
|
9
|
+
export declare const BTC_NETWORKS: Partial<Record<ChainId, Network>>;
|
|
10
|
+
export declare function getPkScriptForChain(addr: string, btcChain: Network): Buffer;
|
|
11
|
+
export declare function getPkScript(addr: string, btcChainId: ChainId): Buffer;
|
|
12
|
+
export declare function getAddress(pkScript: string, btcChain: Network): string;
|
|
13
|
+
export declare function getBtcPortalFee(forwarderUrl: string, cache: Cache): Promise<string>;
|
|
14
|
+
export declare function getUnwrapDustLimit(forwarderUrl: string, cache: Cache): Promise<string>;
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { address, networks } from 'bitcoinjs-lib';
|
|
2
|
+
import { BigNumber } from 'ethers';
|
|
3
|
+
import { ChainId } from '../../constants.js';
|
|
4
|
+
import { TokenAmount } from '../../entities/index.js';
|
|
5
|
+
import { getFastestFee } from '../mempool.js';
|
|
6
|
+
export const getThreshold = async (syBtcAmount, synthesis, cache) => {
|
|
7
|
+
const syBtc = syBtcAmount.token;
|
|
8
|
+
const threshold = await cache.get(['tokenThreshold', synthesis.address, syBtc.address], async () => {
|
|
9
|
+
return synthesis.tokenThreshold(syBtc.address);
|
|
10
|
+
}, 24 * 60 * 60 // 24 hours
|
|
11
|
+
);
|
|
12
|
+
return new TokenAmount(syBtc, threshold.toString());
|
|
13
|
+
};
|
|
14
|
+
export const getToBtcFee = async (syBtcAmount, synthesis, cache) => {
|
|
15
|
+
const syBtc = syBtcAmount.token;
|
|
16
|
+
let fee = await cache.get(['syntToMinFeeBTC', synthesis.address, syBtc.address], async () => {
|
|
17
|
+
return synthesis.syntToMinFeeBTC(syBtc.address);
|
|
18
|
+
}, 600 // 10 minutes
|
|
19
|
+
);
|
|
20
|
+
try {
|
|
21
|
+
const fastestFee = await cache.get(['getFastestFee'], getFastestFee, 60); // 1 minute
|
|
22
|
+
const recommendedFee = BigNumber.from(fastestFee * 300); // 300 vByte
|
|
23
|
+
if (recommendedFee.gt(fee)) {
|
|
24
|
+
fee = recommendedFee;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
catch {
|
|
28
|
+
/* nothing */
|
|
29
|
+
}
|
|
30
|
+
return new TokenAmount(syBtc, fee.toString());
|
|
31
|
+
};
|
|
32
|
+
export function isBtcChainId(chainId) {
|
|
33
|
+
if (!chainId)
|
|
34
|
+
return false;
|
|
35
|
+
return chainId in BTC_NETWORKS;
|
|
36
|
+
}
|
|
37
|
+
export const BTC_NETWORKS = {
|
|
38
|
+
[ChainId.BTC_MAINNET]: networks.bitcoin,
|
|
39
|
+
[ChainId.BTC_MUTINY]: networks.testnet,
|
|
40
|
+
[ChainId.BTC_TESTNET4]: networks.testnet,
|
|
41
|
+
};
|
|
42
|
+
export function getPkScriptForChain(addr, btcChain) {
|
|
43
|
+
return address.toOutputScript(addr, btcChain);
|
|
44
|
+
}
|
|
45
|
+
export function getPkScript(addr, btcChainId) {
|
|
46
|
+
const network = BTC_NETWORKS[btcChainId];
|
|
47
|
+
if (!network) {
|
|
48
|
+
throw new Error(`Unknown BTC network ${btcChainId}`);
|
|
49
|
+
}
|
|
50
|
+
return getPkScriptForChain(addr, network);
|
|
51
|
+
}
|
|
52
|
+
export function getAddress(pkScript, btcChain) {
|
|
53
|
+
return address.fromOutputScript(Buffer.from(pkScript.substring(2), 'hex'), btcChain);
|
|
54
|
+
}
|
|
55
|
+
async function getPortalSettings(forwarderUrl) {
|
|
56
|
+
// kind of the state: 0=finalized 1=pending 2=best
|
|
57
|
+
const portalApiUrl = new URL(`${forwarderUrl}/portal?kind=2`);
|
|
58
|
+
const response = await fetch(portalApiUrl);
|
|
59
|
+
if (!response.ok) {
|
|
60
|
+
const text = await response.text();
|
|
61
|
+
const json = JSON.parse(text);
|
|
62
|
+
throw new Error(json.message ?? text);
|
|
63
|
+
}
|
|
64
|
+
return response.json();
|
|
65
|
+
}
|
|
66
|
+
export async function getBtcPortalFee(forwarderUrl, cache) {
|
|
67
|
+
let fee = await cache.get(['getMinBtcFee', forwarderUrl], async () => {
|
|
68
|
+
const response = await getPortalSettings(forwarderUrl);
|
|
69
|
+
const { state: { minBtcFee }, } = response;
|
|
70
|
+
return Number(minBtcFee);
|
|
71
|
+
}, 600 // 10 minutes
|
|
72
|
+
);
|
|
73
|
+
try {
|
|
74
|
+
const fastestFee = await cache.get(['getFastestFee'], getFastestFee, 60); // 1 minute
|
|
75
|
+
const recommendedFee = fastestFee * 200; // 200 vByte
|
|
76
|
+
if (recommendedFee > fee) {
|
|
77
|
+
fee = recommendedFee;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
catch {
|
|
81
|
+
/* nothing */
|
|
82
|
+
}
|
|
83
|
+
return fee.toString();
|
|
84
|
+
}
|
|
85
|
+
export async function getUnwrapDustLimit(forwarderUrl, cache) {
|
|
86
|
+
const unwrapDustLimit = await cache.get(['getUnwrapDustLimit', forwarderUrl], async () => {
|
|
87
|
+
const response = await getPortalSettings(forwarderUrl);
|
|
88
|
+
const { state: { unwrapDustLimit }, } = response;
|
|
89
|
+
return Number(unwrapDustLimit);
|
|
90
|
+
}, 60 * 60 // 1 hour
|
|
91
|
+
);
|
|
92
|
+
return unwrapDustLimit.toString();
|
|
93
|
+
}
|
|
94
|
+
//# sourceMappingURL=btc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"btc.js","sourceRoot":"","sources":["../../../src/crosschain/chainUtils/btc.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import type { Filter, Log } from '@ethersproject/providers';
|
|
2
|
+
import { BigNumber } from 'ethers';
|
|
3
|
+
import JSBI from 'jsbi';
|
|
4
|
+
import type { BigintIsh, ChainId } from '../../constants';
|
|
5
|
+
import type { Token, Trade } from '../../entities';
|
|
6
|
+
import { Percent, TokenAmount } from '../../entities';
|
|
7
|
+
import type { Symbiosis } from '../symbiosis';
|
|
8
|
+
import { Field } from '../types';
|
|
9
|
+
interface GetInternalIdParams {
|
|
10
|
+
contractAddress: string;
|
|
11
|
+
requestCount: BigNumber;
|
|
12
|
+
chainId: ChainId;
|
|
13
|
+
}
|
|
14
|
+
interface GetExternalIdParams {
|
|
15
|
+
internalId: string;
|
|
16
|
+
contractAddress: string;
|
|
17
|
+
revertableAddress: string;
|
|
18
|
+
chainId: ChainId;
|
|
19
|
+
}
|
|
20
|
+
export declare function isEvmChainId(chainId: ChainId | undefined): boolean;
|
|
21
|
+
export declare function getInternalId({ contractAddress, requestCount, chainId }: GetInternalIdParams): string;
|
|
22
|
+
export declare function getExternalId({ internalId, contractAddress, revertableAddress, chainId, }: GetExternalIdParams): string;
|
|
23
|
+
export declare function calculateGasMargin(value: BigNumber): BigNumber;
|
|
24
|
+
export declare function computeTradePriceBreakdown(trade?: Trade, dexFee?: number): {
|
|
25
|
+
priceImpactWithoutFee?: Percent;
|
|
26
|
+
realizedLPFee?: TokenAmount;
|
|
27
|
+
};
|
|
28
|
+
export declare function basisPointsToPercent(num: number): Percent;
|
|
29
|
+
export declare function getMinAmount(slippage: number, amount: BigintIsh): JSBI;
|
|
30
|
+
export declare function computeSlippageAdjustedAmounts(trade: Trade | undefined, allowedSlippage: number): {
|
|
31
|
+
[field in Field]?: TokenAmount;
|
|
32
|
+
};
|
|
33
|
+
export declare function calculatePriceImpact(tokenAmountIn: TokenAmount, tokenAmountOut: TokenAmount): Percent;
|
|
34
|
+
export declare class GetLogTimeoutExceededError extends Error {
|
|
35
|
+
readonly filter: Filter;
|
|
36
|
+
constructor(filter: Filter);
|
|
37
|
+
}
|
|
38
|
+
export declare const DEFAULT_EXCEED_DELAY: number;
|
|
39
|
+
interface GetLogsWithTimeoutParams {
|
|
40
|
+
symbiosis: Symbiosis;
|
|
41
|
+
chainId: ChainId;
|
|
42
|
+
filter: Filter;
|
|
43
|
+
exceedDelay?: number;
|
|
44
|
+
}
|
|
45
|
+
export declare function getLogWithTimeout({ symbiosis, chainId, filter, exceedDelay: exceedTimeout, }: GetLogsWithTimeoutParams): Promise<Log>;
|
|
46
|
+
export declare function getAllPairCombinations(tokenIn: Token, tokenOut: Token): [Token, Token][];
|
|
47
|
+
export interface DetailedSlippage {
|
|
48
|
+
A: number;
|
|
49
|
+
B: number;
|
|
50
|
+
C: number;
|
|
51
|
+
}
|
|
52
|
+
export declare function splitSlippage(totalSlippage: number, hasTradeA: boolean, hasTradeC: boolean): DetailedSlippage;
|
|
53
|
+
export {};
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
import { parseUnits } from '@ethersproject/units';
|
|
2
|
+
import { BigNumber, utils } from 'ethers';
|
|
3
|
+
import JSBI from 'jsbi';
|
|
4
|
+
import flatMap from 'lodash.flatmap';
|
|
5
|
+
import { ONE } from '../../constants.js';
|
|
6
|
+
import { Fraction, Percent, TokenAmount, wrappedToken } from '../../entities/index.js';
|
|
7
|
+
import { BASES_TO_CHECK_TRADES_AGAINST, BIPS_BASE, CUSTOM_BASES } from '../constants.js';
|
|
8
|
+
import { SdkError } from '../sdkError.js';
|
|
9
|
+
import { Field } from '../types.js';
|
|
10
|
+
import { isBtcChainId } from './btc.js';
|
|
11
|
+
import { isSolanaChainId } from './solana.js';
|
|
12
|
+
import { isTonChainId } from './ton.js';
|
|
13
|
+
import { isTronChainId } from './tron.js';
|
|
14
|
+
export function isEvmChainId(chainId) {
|
|
15
|
+
if (!chainId)
|
|
16
|
+
return false;
|
|
17
|
+
return !isBtcChainId(chainId) && !isTronChainId(chainId) && !isTonChainId(chainId) && !isSolanaChainId(chainId);
|
|
18
|
+
}
|
|
19
|
+
export function getInternalId({ contractAddress, requestCount, chainId }) {
|
|
20
|
+
return utils.solidityKeccak256(['address', 'uint256', 'uint256'], [contractAddress, requestCount, chainId]);
|
|
21
|
+
}
|
|
22
|
+
export function getExternalId({ internalId, contractAddress, revertableAddress, chainId, }) {
|
|
23
|
+
return utils.solidityKeccak256(['bytes32', 'address', 'address', 'uint256'], [internalId, contractAddress, revertableAddress, chainId]);
|
|
24
|
+
}
|
|
25
|
+
export function calculateGasMargin(value) {
|
|
26
|
+
return value.mul(BigNumber.from(10000).add(BigNumber.from(5000))).div(BigNumber.from(10000));
|
|
27
|
+
}
|
|
28
|
+
// computes price breakdown for the trade
|
|
29
|
+
export function computeTradePriceBreakdown(trade, dexFee) {
|
|
30
|
+
const BASE_FEE = new Percent(JSBI.BigInt(dexFee || 30), JSBI.BigInt(10000));
|
|
31
|
+
const ONE_HUNDRED_PERCENT = new Percent(JSBI.BigInt(10000), JSBI.BigInt(10000));
|
|
32
|
+
const INPUT_FRACTION_AFTER_FEE = ONE_HUNDRED_PERCENT.subtract(BASE_FEE);
|
|
33
|
+
// for each hop in our trade, take away the x*y=k price impact from 0.3% fees
|
|
34
|
+
// e.g. for 3 tokens/2 hops: 1 - ((1 - .03) * (1-.03))
|
|
35
|
+
const realizedLPFee = !trade
|
|
36
|
+
? undefined
|
|
37
|
+
: ONE_HUNDRED_PERCENT.subtract(trade.route.pairs.reduce((currentFee) => currentFee.multiply(INPUT_FRACTION_AFTER_FEE), ONE_HUNDRED_PERCENT));
|
|
38
|
+
// remove lp fees from price impact
|
|
39
|
+
const priceImpactWithoutFeeFraction = trade && realizedLPFee ? trade.priceImpact.subtract(realizedLPFee) : undefined;
|
|
40
|
+
// the x*y=k impact
|
|
41
|
+
const priceImpactWithoutFeePercent = priceImpactWithoutFeeFraction
|
|
42
|
+
? new Percent(JSBI.multiply(priceImpactWithoutFeeFraction?.numerator, JSBI.BigInt('-1')), priceImpactWithoutFeeFraction?.denominator)
|
|
43
|
+
: undefined;
|
|
44
|
+
// the amount of the input that accrues to LPs
|
|
45
|
+
const realizedLPFeeAmount = realizedLPFee &&
|
|
46
|
+
trade &&
|
|
47
|
+
new TokenAmount(trade.inputAmount.token, realizedLPFee.multiply(trade.inputAmount.raw).quotient);
|
|
48
|
+
return {
|
|
49
|
+
priceImpactWithoutFee: priceImpactWithoutFeePercent,
|
|
50
|
+
realizedLPFee: realizedLPFeeAmount,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
// converts a basis points value to a sdk percent
|
|
54
|
+
export function basisPointsToPercent(num) {
|
|
55
|
+
return new Percent(JSBI.BigInt(Math.floor(num)), JSBI.BigInt(10000));
|
|
56
|
+
}
|
|
57
|
+
export function getMinAmount(slippage, amount) {
|
|
58
|
+
const slippageTolerance = basisPointsToPercent(slippage);
|
|
59
|
+
return new Fraction(ONE).subtract(slippageTolerance).multiply(amount).quotient;
|
|
60
|
+
}
|
|
61
|
+
// computes the minimum amount out and maximum amount in for a trade given a user specified allowed slippage in bips
|
|
62
|
+
export function computeSlippageAdjustedAmounts(trade, allowedSlippage) {
|
|
63
|
+
const pct = basisPointsToPercent(allowedSlippage);
|
|
64
|
+
return {
|
|
65
|
+
[Field.INPUT]: trade?.maximumAmountIn(pct),
|
|
66
|
+
[Field.OUTPUT]: trade?.minimumAmountOut(pct),
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
export function calculatePriceImpact(tokenAmountIn, tokenAmountOut) {
|
|
70
|
+
const typedValueParsed = parseUnits(tokenAmountOut.toExact(tokenAmountIn.token.decimals), tokenAmountIn.token.decimals).toString();
|
|
71
|
+
if (typedValueParsed === '0') {
|
|
72
|
+
throw new SdkError('Cannot parse amountOut with decimals');
|
|
73
|
+
}
|
|
74
|
+
const amountIn = tokenAmountIn.raw;
|
|
75
|
+
const amountOut = JSBI.BigInt(typedValueParsed);
|
|
76
|
+
const diff = JSBI.subtract(amountOut, amountIn);
|
|
77
|
+
const value = JSBI.divide(JSBI.multiply(diff, BIPS_BASE), amountIn);
|
|
78
|
+
return new Percent(value, BIPS_BASE);
|
|
79
|
+
}
|
|
80
|
+
export class GetLogTimeoutExceededError extends Error {
|
|
81
|
+
filter;
|
|
82
|
+
constructor(filter) {
|
|
83
|
+
super(`Timed out waiting for logs matching filter: ${JSON.stringify(filter)}`);
|
|
84
|
+
this.filter = filter;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
export const DEFAULT_EXCEED_DELAY = 1000 * 60 * 20; // 20 minutes
|
|
88
|
+
function _promiseRaceResolved(promises) {
|
|
89
|
+
let rejectCounter = 0;
|
|
90
|
+
const totalPromises = promises.length;
|
|
91
|
+
return new Promise((resolve, reject) => {
|
|
92
|
+
const onReject = () => {
|
|
93
|
+
rejectCounter++;
|
|
94
|
+
if (rejectCounter === totalPromises) {
|
|
95
|
+
reject(new SdkError('All promises were rejected.'));
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
promises.forEach((promise) => {
|
|
99
|
+
// Promise.resolve to "promisify" any value
|
|
100
|
+
Promise.resolve(promise).then(resolve).catch(onReject);
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
export async function getLogWithTimeout({ symbiosis, chainId, filter, exceedDelay: exceedTimeout = DEFAULT_EXCEED_DELAY, }) {
|
|
105
|
+
const spareRpcs = symbiosis.config.chains.find((chain) => chain.id === chainId)?.spareRpcs ?? [];
|
|
106
|
+
const spareProviders = spareRpcs.map((rpc) => symbiosis.getProvider(chainId, rpc));
|
|
107
|
+
const provider = symbiosis.getProvider(chainId);
|
|
108
|
+
let activeFilter = filter;
|
|
109
|
+
if (!activeFilter.fromBlock) {
|
|
110
|
+
const fromBlock = await symbiosis.getFromBlockWithOffset(chainId);
|
|
111
|
+
activeFilter = { ...filter, fromBlock };
|
|
112
|
+
}
|
|
113
|
+
return new Promise((resolve, reject) => {
|
|
114
|
+
const period = 1000 * 10; // 10 seconds
|
|
115
|
+
let pastTime = 0;
|
|
116
|
+
let logs = [];
|
|
117
|
+
const getLogs = async () => {
|
|
118
|
+
pastTime += period;
|
|
119
|
+
if (pastTime > exceedTimeout) {
|
|
120
|
+
clearInterval(interval);
|
|
121
|
+
reject(new GetLogTimeoutExceededError(activeFilter));
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
try {
|
|
125
|
+
logs = await provider.getLogs(activeFilter);
|
|
126
|
+
}
|
|
127
|
+
catch (error) {
|
|
128
|
+
logs = await _promiseRaceResolved(spareProviders.map((spareProvider) => spareProvider.getLogs(activeFilter)));
|
|
129
|
+
}
|
|
130
|
+
finally {
|
|
131
|
+
if (logs.length > 0) {
|
|
132
|
+
resolve(logs[0]);
|
|
133
|
+
clearInterval(interval);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
const interval = setInterval(getLogs, period);
|
|
138
|
+
getLogs();
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
export function getAllPairCombinations(tokenIn, tokenOut) {
|
|
142
|
+
const chainId = tokenIn.chainId;
|
|
143
|
+
// Base tokens for building intermediary trading routes
|
|
144
|
+
const bases = BASES_TO_CHECK_TRADES_AGAINST[chainId] || [];
|
|
145
|
+
// All pairs from base tokens
|
|
146
|
+
const basePairs = flatMap(bases, (base) => bases.map((otherBase) => [base, otherBase])).filter(([t0, t1]) => t0.address !== t1.address);
|
|
147
|
+
const [tokenA, tokenB] = [wrappedToken(tokenIn), wrappedToken(tokenOut)];
|
|
148
|
+
if (!tokenA || !tokenB) {
|
|
149
|
+
return [];
|
|
150
|
+
}
|
|
151
|
+
return ([
|
|
152
|
+
// the direct pair
|
|
153
|
+
[tokenA, tokenB],
|
|
154
|
+
// token A against all bases
|
|
155
|
+
...bases.map((base) => [tokenA, base]),
|
|
156
|
+
// token B against all bases
|
|
157
|
+
...bases.map((base) => [tokenB, base]),
|
|
158
|
+
// each base against all bases
|
|
159
|
+
...basePairs,
|
|
160
|
+
]
|
|
161
|
+
.filter((tokens) => Boolean(tokens[0] && tokens[1]))
|
|
162
|
+
.filter(([t0, t1]) => t0.address !== t1.address)
|
|
163
|
+
// This filter will remove all the pairs that are not supported by the CUSTOM_BASES settings
|
|
164
|
+
// This option is currently not used on Pancake swap
|
|
165
|
+
.filter(([t0, t1]) => {
|
|
166
|
+
if (!chainId)
|
|
167
|
+
return true;
|
|
168
|
+
const customBases = CUSTOM_BASES[chainId];
|
|
169
|
+
if (!customBases)
|
|
170
|
+
return true;
|
|
171
|
+
const customBasesA = customBases[t0.address];
|
|
172
|
+
const customBasesB = customBases[t1.address];
|
|
173
|
+
if (!customBasesA && !customBasesB)
|
|
174
|
+
return true;
|
|
175
|
+
if (customBasesA && !customBasesA.find((base) => t1.equals(base)))
|
|
176
|
+
return false;
|
|
177
|
+
if (customBasesB && !customBasesB.find((base) => t0.equals(base)))
|
|
178
|
+
return false;
|
|
179
|
+
return true;
|
|
180
|
+
}));
|
|
181
|
+
}
|
|
182
|
+
export function splitSlippage(totalSlippage, hasTradeA, hasTradeC) {
|
|
183
|
+
const minSlippage = 20; // 0.2%
|
|
184
|
+
if (totalSlippage < minSlippage) {
|
|
185
|
+
throw new SdkError(`Slippage cannot be less than ${(minSlippage / 100).toString()}%`);
|
|
186
|
+
}
|
|
187
|
+
let extraSwapsCount = 0;
|
|
188
|
+
if (hasTradeA) {
|
|
189
|
+
extraSwapsCount += 1;
|
|
190
|
+
}
|
|
191
|
+
if (hasTradeC) {
|
|
192
|
+
extraSwapsCount += 1;
|
|
193
|
+
}
|
|
194
|
+
const swapsCount = extraSwapsCount + 1;
|
|
195
|
+
const avg = totalSlippage / swapsCount;
|
|
196
|
+
let addition = 0;
|
|
197
|
+
let symbiosisPoolSlippage = avg;
|
|
198
|
+
const symbiosisPoolMaxSlippage = 20; // 0.2%
|
|
199
|
+
if (avg > symbiosisPoolMaxSlippage) {
|
|
200
|
+
const rest = avg - symbiosisPoolMaxSlippage;
|
|
201
|
+
symbiosisPoolSlippage = symbiosisPoolMaxSlippage;
|
|
202
|
+
addition = extraSwapsCount > 0 ? rest / extraSwapsCount : 0;
|
|
203
|
+
}
|
|
204
|
+
return {
|
|
205
|
+
A: hasTradeA ? Math.floor((avg + addition) * 100) / 100 : 0,
|
|
206
|
+
B: Math.floor(symbiosisPoolSlippage * 100) / 100,
|
|
207
|
+
C: hasTradeC ? Math.floor((avg + addition) * 100) / 100 : 0,
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
//# sourceMappingURL=evm.js.map
|