@paraswap/dex-lib 4.7.27 → 4.8.0
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/build/abi/PendleRouterStatic.json +19 -0
- package/build/abi/apex-defi/ApexDefiFactory.abi.json +1749 -0
- package/build/abi/apex-defi/ApexDefiRouter.abi.json +1120 -0
- package/build/abi/apex-defi/ApexDefiToken.abi.json +229 -0
- package/build/abi/apex-defi/ApexDefiWrapper.abi.json +92 -0
- package/build/abi/apex-defi/ApexDefiWrapperFactory.abi.json +1107 -0
- package/build/abi/ekubo-v3/core.json +797 -0
- package/build/abi/ekubo-v3/mev-capture-router.json +936 -0
- package/build/abi/ekubo-v3/quote-data-fetcher.json +161 -0
- package/build/abi/ekubo-v3/twamm-data-fetcher.json +216 -0
- package/build/abi/ekubo-v3/twamm.json +613 -0
- package/build/abi/idle-dao/idle-cdo-factory.json +38 -0
- package/build/abi/idle-dao/idle-cdo.json +1245 -0
- package/build/abi/infusion/InfusionFactory.json +147 -0
- package/build/abi/infusion/InfusionPair.json +658 -0
- package/build/abi/infusion/InfusionRouter.json +442 -0
- package/build/abi/maker-psm/pot.json +322 -0
- package/build/abi/maker-psm/psm.json +243 -0
- package/build/abi/maker-psm/vat.json +363 -0
- package/build/abi/nomiswap-v2/nomiswap-v2-pool.json +773 -0
- package/build/abi/pangolin-v3/PangolinV3StateMulticall.abi.json +796 -0
- package/build/abi/pendle/pendle-deployer.abi.json +520 -0
- package/build/abi/pendle/pendle-oracle.abi.json +413 -0
- package/build/abi/quick-perps/fast-price-events.json +70 -0
- package/build/abi/quick-perps/fast-price-feed.json +741 -0
- package/build/abi/quick-perps/reader.json +313 -0
- package/build/abi/quick-perps/vault-price-feed.json +323 -0
- package/build/abi/quick-perps/vault.json +1953 -0
- package/build/abi/ring-v2/few-wrapped-token.json +587 -0
- package/build/abi/ring-v2/ring-v2-factory.json +125 -0
- package/build/abi/ring-v2/ring-v2-pool.json +461 -0
- package/build/abi/ring-v2/ring-v2-router.json +332 -0
- package/build/abi/stabull/stabull-curve.json +738 -0
- package/build/abi/stabull/stabull-router.json +76 -0
- package/build/abi/uniswap-v2/excalibur-pool.json +881 -0
- package/build/abi/uniswap-v2/mdex-factory.json +759 -0
- package/build/abi/uniswap-v4/hooks/SpotDynamicFeeManager.json +26 -0
- package/build/abi/uniswap-v4/hooks/SpotHook.json +54 -0
- package/build/abi/uniswap-v4/hooks/SpotPolicyManager.json +45 -0
- package/build/abi/uniswap-v4/hooks/cabalcoin-hook.abi.json +682 -0
- package/build/abi/uniswap-v4/hooks/fee-hook.abi.json +1335 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying-factory.d.ts +29 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying-factory.js +153 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying-factory.js.map +1 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying.d.ts +40 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying.js +323 -0
- package/build/dex/aave-pt-to-underlying/aave-pt-to-underlying.js.map +1 -0
- package/build/dex/aave-pt-to-underlying/config.d.ts +3 -0
- package/build/dex/aave-pt-to-underlying/config.js +24 -0
- package/build/dex/aave-pt-to-underlying/config.js.map +1 -0
- package/build/dex/aave-pt-to-underlying/constants.d.ts +2 -0
- package/build/dex/aave-pt-to-underlying/constants.js +6 -0
- package/build/dex/aave-pt-to-underlying/constants.js.map +1 -0
- package/build/dex/aave-pt-to-underlying/types.d.ts +24 -0
- package/build/dex/aave-pt-to-underlying/types.js +3 -0
- package/build/dex/aave-pt-to-underlying/types.js.map +1 -0
- package/build/dex/aave-pt-to-usdc/aave-pt-to-usdc.d.ts +39 -0
- package/build/dex/aave-pt-to-usdc/aave-pt-to-usdc.js +244 -0
- package/build/dex/aave-pt-to-usdc/aave-pt-to-usdc.js.map +1 -0
- package/build/dex/aave-pt-to-usdc/config.d.ts +3 -0
- package/build/dex/aave-pt-to-usdc/config.js +47 -0
- package/build/dex/aave-pt-to-usdc/config.js.map +1 -0
- package/build/dex/aave-pt-to-usdc/constants.d.ts +2 -0
- package/build/dex/aave-pt-to-usdc/constants.js +6 -0
- package/build/dex/aave-pt-to-usdc/constants.js.map +1 -0
- package/build/dex/aave-pt-to-usdc/types.d.ts +22 -0
- package/build/dex/aave-pt-to-usdc/types.js +3 -0
- package/build/dex/aave-pt-to-usdc/types.js.map +1 -0
- package/build/dex/algebra/config.js +0 -30
- package/build/dex/algebra/config.js.map +1 -1
- package/build/dex/algebra-integral/config.js +0 -7
- package/build/dex/algebra-integral/config.js.map +1 -1
- package/build/dex/angle-staked-stable/config.js +0 -32
- package/build/dex/angle-staked-stable/config.js.map +1 -1
- package/build/dex/angle-transmuter/config.js +0 -20
- package/build/dex/angle-transmuter/config.js.map +1 -1
- package/build/dex/apex-defi/apex-defi-factory.d.ts +26 -0
- package/build/dex/apex-defi/apex-defi-factory.js +53 -0
- package/build/dex/apex-defi/apex-defi-factory.js.map +1 -0
- package/build/dex/apex-defi/apex-defi-pool.d.ts +55 -0
- package/build/dex/apex-defi/apex-defi-pool.js +247 -0
- package/build/dex/apex-defi/apex-defi-pool.js.map +1 -0
- package/build/dex/apex-defi/apex-defi-wrapper-factory.d.ts +57 -0
- package/build/dex/apex-defi/apex-defi-wrapper-factory.js +250 -0
- package/build/dex/apex-defi/apex-defi-wrapper-factory.js.map +1 -0
- package/build/dex/apex-defi/apex-defi.d.ts +97 -0
- package/build/dex/apex-defi/apex-defi.js +1021 -0
- package/build/dex/apex-defi/apex-defi.js.map +1 -0
- package/build/dex/apex-defi/config.d.ts +4 -0
- package/build/dex/apex-defi/config.js +138 -0
- package/build/dex/apex-defi/config.js.map +1 -0
- package/build/dex/apex-defi/types.d.ts +32 -0
- package/build/dex/apex-defi/types.js +3 -0
- package/build/dex/apex-defi/types.js.map +1 -0
- package/build/dex/apex-defi/utils.d.ts +46 -0
- package/build/dex/apex-defi/utils.js +133 -0
- package/build/dex/apex-defi/utils.js.map +1 -0
- package/build/dex/curve-v1/constants.js +2 -4
- package/build/dex/curve-v1/constants.js.map +1 -1
- package/build/dex/dodo-v1/config.js +0 -10
- package/build/dex/dodo-v1/config.js.map +1 -1
- package/build/dex/dodo-v2.js +0 -3
- package/build/dex/dodo-v2.js.map +1 -1
- package/build/dex/ekubo/pools/base-pool.d.ts +47 -0
- package/build/dex/ekubo/pools/base-pool.js +184 -0
- package/build/dex/ekubo/pools/base-pool.js.map +1 -0
- package/build/dex/ekubo/pools/iface.d.ts +46 -0
- package/build/dex/ekubo/pools/iface.js +75 -0
- package/build/dex/ekubo/pools/iface.js.map +1 -0
- package/build/dex/ekubo/pools/math/price.d.ts +7 -0
- package/build/dex/ekubo/pools/math/price.js +112 -0
- package/build/dex/ekubo/pools/math/price.js.map +1 -0
- package/build/dex/ekubo/pools/oracle-pool.d.ts +10 -0
- package/build/dex/ekubo/pools/oracle-pool.js +19 -0
- package/build/dex/ekubo/pools/oracle-pool.js.map +1 -0
- package/build/dex/ekubo/pools/pool-utils.d.ts +44 -0
- package/build/dex/ekubo/pools/pool-utils.js +240 -0
- package/build/dex/ekubo/pools/pool-utils.js.map +1 -0
- package/build/dex/ekubo-v3/config.d.ts +13 -0
- package/build/dex/ekubo-v3/config.js +23 -0
- package/build/dex/ekubo-v3/config.js.map +1 -0
- package/build/dex/ekubo-v3/ekubo-v3-pool-manager.d.ts +34 -0
- package/build/dex/ekubo-v3/ekubo-v3-pool-manager.js +421 -0
- package/build/dex/ekubo-v3/ekubo-v3-pool-manager.js.map +1 -0
- package/build/dex/ekubo-v3/ekubo-v3.d.ts +38 -0
- package/build/dex/ekubo-v3/ekubo-v3.js +274 -0
- package/build/dex/ekubo-v3/ekubo-v3.js.map +1 -0
- package/build/dex/ekubo-v3/pools/base.d.ts +42 -0
- package/build/dex/ekubo-v3/pools/base.js +307 -0
- package/build/dex/ekubo-v3/pools/base.js.map +1 -0
- package/build/dex/ekubo-v3/pools/full-range.d.ts +25 -0
- package/build/dex/ekubo-v3/pools/full-range.js +105 -0
- package/build/dex/ekubo-v3/pools/full-range.js.map +1 -0
- package/build/dex/ekubo-v3/pools/math/constants.d.ts +12 -0
- package/build/dex/ekubo-v3/pools/math/constants.js +16 -0
- package/build/dex/ekubo-v3/pools/math/constants.js.map +1 -0
- package/build/dex/ekubo-v3/pools/math/delta.d.ts +2 -0
- package/build/dex/ekubo-v3/pools/math/delta.js +51 -0
- package/build/dex/ekubo-v3/pools/math/delta.js.map +1 -0
- package/build/dex/ekubo-v3/pools/math/sqrt-ratio.d.ts +8 -0
- package/build/dex/ekubo-v3/pools/math/sqrt-ratio.js +113 -0
- package/build/dex/ekubo-v3/pools/math/sqrt-ratio.js.map +1 -0
- package/build/dex/ekubo-v3/pools/math/swap.d.ts +18 -0
- package/build/dex/ekubo-v3/pools/math/swap.js +128 -0
- package/build/dex/ekubo-v3/pools/math/swap.js.map +1 -0
- package/build/dex/ekubo-v3/pools/math/tick.d.ts +8 -0
- package/build/dex/ekubo-v3/pools/math/tick.js +129 -0
- package/build/dex/ekubo-v3/pools/math/tick.js.map +1 -0
- package/build/dex/ekubo-v3/pools/math/twamm/exp2.d.ts +1 -0
- package/build/dex/ekubo-v3/pools/math/twamm/exp2.js +86 -0
- package/build/dex/ekubo-v3/pools/math/twamm/exp2.js.map +1 -0
- package/build/dex/ekubo-v3/pools/math/twamm/sqrt-ratio.d.ts +1 -0
- package/build/dex/ekubo-v3/pools/math/twamm/sqrt-ratio.js +56 -0
- package/build/dex/ekubo-v3/pools/math/twamm/sqrt-ratio.js.map +1 -0
- package/build/dex/ekubo-v3/pools/mev-capture.d.ts +8 -0
- package/build/dex/ekubo-v3/pools/mev-capture.js +42 -0
- package/build/dex/ekubo-v3/pools/mev-capture.js.map +1 -0
- package/build/dex/ekubo-v3/pools/oracle.d.ts +8 -0
- package/build/dex/ekubo-v3/pools/oracle.js +18 -0
- package/build/dex/ekubo-v3/pools/oracle.js.map +1 -0
- package/build/dex/ekubo-v3/pools/pool.d.ts +56 -0
- package/build/dex/ekubo-v3/pools/pool.js +88 -0
- package/build/dex/ekubo-v3/pools/pool.js.map +1 -0
- package/build/dex/ekubo-v3/pools/stableswap.d.ts +22 -0
- package/build/dex/ekubo-v3/pools/stableswap.js +123 -0
- package/build/dex/ekubo-v3/pools/stableswap.js.map +1 -0
- package/build/dex/ekubo-v3/pools/twamm.d.ts +40 -0
- package/build/dex/ekubo-v3/pools/twamm.js +265 -0
- package/build/dex/ekubo-v3/pools/twamm.js.map +1 -0
- package/build/dex/ekubo-v3/pools/utils.d.ts +62 -0
- package/build/dex/ekubo-v3/pools/utils.js +160 -0
- package/build/dex/ekubo-v3/pools/utils.js.map +1 -0
- package/build/dex/ekubo-v3/types.d.ts +58 -0
- package/build/dex/ekubo-v3/types.js +3 -0
- package/build/dex/ekubo-v3/types.js.map +1 -0
- package/build/dex/ekubo-v3/utils.d.ts +10 -0
- package/build/dex/ekubo-v3/utils.js +54 -0
- package/build/dex/ekubo-v3/utils.js.map +1 -0
- package/build/dex/erc4626/config.js +0 -22
- package/build/dex/erc4626/config.js.map +1 -1
- package/build/dex/generic-rfq/validators.js +1 -1
- package/build/dex/generic-rfq/validators.js.map +1 -1
- package/build/dex/idle-dao/config.d.ts +5 -0
- package/build/dex/idle-dao/config.js +24 -0
- package/build/dex/idle-dao/config.js.map +1 -0
- package/build/dex/idle-dao/idle-dao.d.ts +42 -0
- package/build/dex/idle-dao/idle-dao.js +279 -0
- package/build/dex/idle-dao/idle-dao.js.map +1 -0
- package/build/dex/idle-dao/token_list.d.ts +4 -0
- package/build/dex/idle-dao/token_list.js +289 -0
- package/build/dex/idle-dao/token_list.js.map +1 -0
- package/build/dex/idle-dao/tokens.d.ts +9 -0
- package/build/dex/idle-dao/tokens.js +68 -0
- package/build/dex/idle-dao/tokens.js.map +1 -0
- package/build/dex/idle-dao/types.d.ts +35 -0
- package/build/dex/idle-dao/types.js +11 -0
- package/build/dex/idle-dao/types.js.map +1 -0
- package/build/dex/idle-dao/utils.d.ts +8 -0
- package/build/dex/idle-dao/utils.js +149 -0
- package/build/dex/idle-dao/utils.js.map +1 -0
- package/build/dex/index.js +0 -28
- package/build/dex/index.js.map +1 -1
- package/build/dex/infusion/config.d.ts +3 -0
- package/build/dex/infusion/config.js +20 -0
- package/build/dex/infusion/config.js.map +1 -0
- package/build/dex/infusion/infusion-stable-pool.d.ts +4 -0
- package/build/dex/infusion/infusion-stable-pool.js +74 -0
- package/build/dex/infusion/infusion-stable-pool.js.map +1 -0
- package/build/dex/infusion/infusion.d.ts +51 -0
- package/build/dex/infusion/infusion.js +461 -0
- package/build/dex/infusion/infusion.js.map +1 -0
- package/build/dex/infusion/types.d.ts +45 -0
- package/build/dex/infusion/types.js +3 -0
- package/build/dex/infusion/types.js.map +1 -0
- package/build/dex/infusion/utils/isStablePair.d.ts +2 -0
- package/build/dex/infusion/utils/isStablePair.js +18 -0
- package/build/dex/infusion/utils/isStablePair.js.map +1 -0
- package/build/dex/maker-psm/config.d.ts +11 -0
- package/build/dex/maker-psm/config.js +53 -0
- package/build/dex/maker-psm/config.js.map +1 -0
- package/build/dex/maker-psm/maker-psm-event-pool.d.ts +43 -0
- package/build/dex/maker-psm/maker-psm-event-pool.js +132 -0
- package/build/dex/maker-psm/maker-psm-event-pool.js.map +1 -0
- package/build/dex/maker-psm/maker-psm.d.ts +103 -0
- package/build/dex/maker-psm/maker-psm.js +493 -0
- package/build/dex/maker-psm/maker-psm.js.map +1 -0
- package/build/dex/maker-psm/types.d.ts +39 -0
- package/build/dex/maker-psm/types.js +3 -0
- package/build/dex/maker-psm/types.js.map +1 -0
- package/build/dex/miro-migrator/miro-migrator-state.d.ts +27 -0
- package/build/dex/miro-migrator/miro-migrator-state.js +89 -0
- package/build/dex/miro-migrator/miro-migrator-state.js.map +1 -0
- package/build/dex/nerve/config.js +0 -435
- package/build/dex/nerve/config.js.map +1 -1
- package/build/dex/oswap/oswap-pool.js.map +1 -1
- package/build/dex/quick-perps/config.d.ts +11 -0
- package/build/dex/quick-perps/config.js +27 -0
- package/build/dex/quick-perps/config.js.map +1 -0
- package/build/dex/quick-perps/fast-price-feed.d.ts +26 -0
- package/build/dex/quick-perps/fast-price-feed.js +184 -0
- package/build/dex/quick-perps/fast-price-feed.js.map +1 -0
- package/build/dex/quick-perps/pool.d.ts +21 -0
- package/build/dex/quick-perps/pool.js +229 -0
- package/build/dex/quick-perps/pool.js.map +1 -0
- package/build/dex/quick-perps/quick-perps.d.ts +53 -0
- package/build/dex/quick-perps/quick-perps.js +247 -0
- package/build/dex/quick-perps/quick-perps.js.map +1 -0
- package/build/dex/quick-perps/types.d.ts +98 -0
- package/build/dex/quick-perps/types.js +3 -0
- package/build/dex/quick-perps/types.js.map +1 -0
- package/build/dex/quick-perps/usdq.d.ts +15 -0
- package/build/dex/quick-perps/usdq.js +62 -0
- package/build/dex/quick-perps/usdq.js.map +1 -0
- package/build/dex/quick-perps/vault-price-feed.d.ts +43 -0
- package/build/dex/quick-perps/vault-price-feed.js +203 -0
- package/build/dex/quick-perps/vault-price-feed.js.map +1 -0
- package/build/dex/quick-perps/vault-utils.d.ts +8 -0
- package/build/dex/quick-perps/vault-utils.js +42 -0
- package/build/dex/quick-perps/vault-utils.js.map +1 -0
- package/build/dex/quick-perps/vault.d.ts +46 -0
- package/build/dex/quick-perps/vault.js +182 -0
- package/build/dex/quick-perps/vault.js.map +1 -0
- package/build/dex/solidly/forks-override/aerodrome.d.ts +14 -0
- package/build/dex/solidly/forks-override/aerodrome.js +50 -0
- package/build/dex/solidly/forks-override/aerodrome.js.map +1 -0
- package/build/dex/solidly/forks-override/chronos.d.ts +23 -0
- package/build/dex/solidly/forks-override/chronos.js +141 -0
- package/build/dex/solidly/forks-override/chronos.js.map +1 -0
- package/build/dex/solidly/forks-override/usdfi.d.ts +8 -0
- package/build/dex/solidly/forks-override/usdfi.js +15 -0
- package/build/dex/solidly/forks-override/usdfi.js.map +1 -0
- package/build/dex/solidly/forks-override/velocimeter.d.ts +23 -0
- package/build/dex/solidly/forks-override/velocimeter.js +77 -0
- package/build/dex/solidly/forks-override/velocimeter.js.map +1 -0
- package/build/dex/stable-pool/stable-pool.js +1 -1
- package/build/dex/stable-pool/stable-pool.js.map +1 -1
- package/build/dex/stabull/config.d.ts +3 -0
- package/build/dex/stabull/config.js +177 -0
- package/build/dex/stabull/config.js.map +1 -0
- package/build/dex/stabull/stabull-pool.d.ts +46 -0
- package/build/dex/stabull/stabull-pool.js +113 -0
- package/build/dex/stabull/stabull-pool.js.map +1 -0
- package/build/dex/stabull/stabull.d.ts +55 -0
- package/build/dex/stabull/stabull.js +286 -0
- package/build/dex/stabull/stabull.js.map +1 -0
- package/build/dex/stabull/types.d.ts +21 -0
- package/build/dex/stabull/types.js +3 -0
- package/build/dex/stabull/types.js.map +1 -0
- package/build/dex/trader-joe-v2.1/config.d.ts +0 -3
- package/build/dex/trader-joe-v2.1/config.js +1 -8
- package/build/dex/trader-joe-v2.1/config.js.map +1 -1
- package/build/dex/uniswap-v2/config.js +0 -8
- package/build/dex/uniswap-v2/config.js.map +1 -1
- package/build/dex/uniswap-v2/dfyn.d.ts +19 -0
- package/build/dex/uniswap-v2/dfyn.js +61 -0
- package/build/dex/uniswap-v2/dfyn.js.map +1 -0
- package/build/dex/uniswap-v2/excalibur.d.ts +24 -0
- package/build/dex/uniswap-v2/excalibur.js +47 -0
- package/build/dex/uniswap-v2/excalibur.js.map +1 -0
- package/build/dex/uniswap-v2/mdex.d.ts +24 -0
- package/build/dex/uniswap-v2/mdex.js +50 -0
- package/build/dex/uniswap-v2/mdex.js.map +1 -0
- package/build/dex/uniswap-v2/nomiswap-v2.d.ts +24 -0
- package/build/dex/uniswap-v2/nomiswap-v2.js +57 -0
- package/build/dex/uniswap-v2/nomiswap-v2.js.map +1 -0
- package/build/dex/uniswap-v2/uniswap-v2.js +0 -10
- package/build/dex/uniswap-v2/uniswap-v2.js.map +1 -1
- package/build/dex/uniswap-v3/forks/pangolin-v3/utils.d.ts +4 -0
- package/build/dex/uniswap-v3/forks/pangolin-v3/utils.js +56 -0
- package/build/dex/uniswap-v3/forks/pangolin-v3/utils.js.map +1 -0
- package/build/dex/uniswap-v4/contract-math/Position.d.ts +9 -0
- package/build/dex/uniswap-v4/contract-math/Position.js +39 -0
- package/build/dex/uniswap-v4/contract-math/Position.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/arena.d.ts +6 -0
- package/build/dex/uniswap-v4/hooks/arena.js +10 -0
- package/build/dex/uniswap-v4/hooks/arena.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/base-fee/base-fee-hook.d.ts +0 -0
- package/build/dex/uniswap-v4/hooks/base-fee/base-fee-hook.js +2 -0
- package/build/dex/uniswap-v4/hooks/base-fee/base-fee-hook.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/cabalcoin-hook-pool.d.ts +7 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/cabalcoin-hook-pool.js +28 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/cabalcoin-hook-pool.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/types.d.ts +0 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/types.js +2 -0
- package/build/dex/uniswap-v4/hooks/cabalcoin-hook/types.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/fee-hook-pool.d.ts +7 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/fee-hook-pool.js +28 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/fee-hook-pool.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/types.d.ts +0 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/types.js +2 -0
- package/build/dex/uniswap-v4/hooks/fee-hook/types.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/index.d.ts +1 -0
- package/build/dex/uniswap-v4/hooks/index.js +18 -0
- package/build/dex/uniswap-v4/hooks/index.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/spot.d.ts +15 -0
- package/build/dex/uniswap-v4/hooks/spot.js +109 -0
- package/build/dex/uniswap-v4/hooks/spot.js.map +1 -0
- package/build/dex/uniswap-v4/hooks/template.d.ts +150 -0
- package/build/dex/uniswap-v4/hooks/template.js +104 -0
- package/build/dex/uniswap-v4/hooks/template.js.map +1 -0
- package/build/dex/usdc-transmuter/usdc-transmuter-pool.d.ts +26 -0
- package/build/dex/usdc-transmuter/usdc-transmuter-pool.js +75 -0
- package/build/dex/usdc-transmuter/usdc-transmuter-pool.js.map +1 -0
- package/build/dex/usual/usual-usdc-usdc.d.ts +17 -0
- package/build/dex/usual/usual-usdc-usdc.js +59 -0
- package/build/dex/usual/usual-usdc-usdc.js.map +1 -0
- package/build/dex/wombat/config.js +0 -12
- package/build/dex/wombat/config.js.map +1 -1
- package/build/dex/yo/config.d.ts +3 -0
- package/build/dex/yo/config.js +21 -0
- package/build/dex/yo/config.js.map +1 -0
- package/build/dex/yo/types.d.ts +13 -0
- package/build/dex/yo/types.js +3 -0
- package/build/dex/yo/types.js.map +1 -0
- package/build/dex/yo/yo-pool.d.ts +13 -0
- package/build/dex/yo/yo-pool.js +26 -0
- package/build/dex/yo/yo-pool.js.map +1 -0
- package/build/dex/yo/yo.d.ts +39 -0
- package/build/dex/yo/yo.js +248 -0
- package/build/dex/yo/yo.js.map +1 -0
- package/build/implementations/api-paraswap-sdk.d.ts +25 -0
- package/build/implementations/api-paraswap-sdk.js +102 -0
- package/build/implementations/api-paraswap-sdk.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,53 @@
|
|
|
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.ApexDefiFactory = void 0;
|
|
7
|
+
const abi_1 = require("@ethersproject/abi");
|
|
8
|
+
const ApexDefiFactory_abi_json_1 = __importDefault(require("../../abi/apex-defi/ApexDefiFactory.abi.json"));
|
|
9
|
+
const stateful_event_subscriber_1 = require("../../stateful-event-subscriber");
|
|
10
|
+
/*
|
|
11
|
+
* "Stateless" event subscriber in order to capture "PoolCreated" event on new pools created.
|
|
12
|
+
* State is present, but it's a placeholder to actually make the events reach handlers (if there's no previous state - `processBlockLogs` is not called)
|
|
13
|
+
*/
|
|
14
|
+
class ApexDefiFactory extends stateful_event_subscriber_1.StatefulEventSubscriber {
|
|
15
|
+
dexHelper;
|
|
16
|
+
factoryAddress;
|
|
17
|
+
onPoolCreated;
|
|
18
|
+
handlers = {};
|
|
19
|
+
logDecoder;
|
|
20
|
+
factoryIface = new abi_1.Interface(ApexDefiFactory_abi_json_1.default);
|
|
21
|
+
constructor(dexHelper, parentName, factoryAddress, logger, onPoolCreated) {
|
|
22
|
+
super(parentName, `${parentName} Factory`, dexHelper, logger);
|
|
23
|
+
this.dexHelper = dexHelper;
|
|
24
|
+
this.factoryAddress = factoryAddress;
|
|
25
|
+
this.onPoolCreated = onPoolCreated;
|
|
26
|
+
this.addressesSubscribed = [factoryAddress];
|
|
27
|
+
this.logDecoder = (log) => this.factoryIface.parseLog(log);
|
|
28
|
+
this.handlers['TokenCreated'] = this.handleTokenCreated.bind(this);
|
|
29
|
+
}
|
|
30
|
+
generateState() {
|
|
31
|
+
return {};
|
|
32
|
+
}
|
|
33
|
+
async processLog(_, log) {
|
|
34
|
+
const event = this.logDecoder(log);
|
|
35
|
+
if (event.name in this.handlers) {
|
|
36
|
+
await this.handlers[event.name](event, log);
|
|
37
|
+
}
|
|
38
|
+
return {};
|
|
39
|
+
}
|
|
40
|
+
async handleTokenCreated(event, log) {
|
|
41
|
+
const pairAddress = event.args.ammAddress.toLowerCase();
|
|
42
|
+
await this.onPoolCreated({ pairAddress, blockNumber: log.blockNumber });
|
|
43
|
+
}
|
|
44
|
+
// Add this method
|
|
45
|
+
releaseResources() {
|
|
46
|
+
// Clear handlers
|
|
47
|
+
this.handlers = {};
|
|
48
|
+
// Clear addresses subscribed
|
|
49
|
+
this.addressesSubscribed = [];
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
exports.ApexDefiFactory = ApexDefiFactory;
|
|
53
|
+
//# sourceMappingURL=apex-defi-factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apex-defi-factory.js","sourceRoot":"","sources":["../../../src/dex/apex-defi/apex-defi-factory.ts"],"names":[],"mappings":";;;;;;AAAA,4CAA+C;AAE/C,4GAA8E;AAE9E,+EAA0E;AAc1E;;;GAGG;AACH,MAAa,eAAgB,SAAQ,mDAAqC;IAU7D;IAEU;IAEA;IAbrB,QAAQ,GAEJ,EAAE,CAAC;IAEP,UAAU,CAAoB;IAEd,YAAY,GAAG,IAAI,eAAS,CAAC,kCAAkB,CAAC,CAAC;IAEjE,YACW,SAAqB,EAC9B,UAAkB,EACC,cAAuB,EAC1C,MAAc,EACK,aAAoC;QAEvD,KAAK,CAAC,UAAU,EAAE,GAAG,UAAU,UAAU,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QANrD,cAAS,GAAT,SAAS,CAAY;QAEX,mBAAc,GAAd,cAAc,CAAS;QAEvB,kBAAa,GAAb,aAAa,CAAuB;QAIvD,IAAI,CAAC,mBAAmB,GAAG,CAAC,cAAc,CAAC,CAAC;QAE5C,IAAI,CAAC,UAAU,GAAG,CAAC,GAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAEhE,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACrE,CAAC;IAED,aAAa;QACX,OAAO,EAAE,CAAC;IACZ,CAAC;IAES,KAAK,CAAC,UAAU,CACxB,CAA6B,EAC7B,GAAkB;QAElB,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACnC,IAAI,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChC,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QAC9C,CAAC;QAED,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,KAAqB,EAAE,GAAkB;QAChE,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;QAExD,MAAM,IAAI,CAAC,aAAa,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC;IAC1E,CAAC;IAED,kBAAkB;IAClB,gBAAgB;QACd,iBAAiB;QACjB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QAEnB,6BAA6B;QAC7B,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;IAChC,CAAC;CACF;AAvDD,0CAuDC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Interface } from '@ethersproject/abi';
|
|
2
|
+
import { DeepReadonly } from 'ts-essentials';
|
|
3
|
+
import { Address, Log, Logger } from '../../types';
|
|
4
|
+
import { StatefulEventSubscriber } from '../../stateful-event-subscriber';
|
|
5
|
+
import { IDexHelper } from '../../dex-helper/idex-helper';
|
|
6
|
+
import { ApexDefiPoolState } from './types';
|
|
7
|
+
import { AbiCoder } from '@ethersproject/abi';
|
|
8
|
+
export declare class ApexDefiEventPool extends StatefulEventSubscriber<ApexDefiPoolState> {
|
|
9
|
+
readonly parentName: string;
|
|
10
|
+
protected network: number;
|
|
11
|
+
protected dexHelper: IDexHelper;
|
|
12
|
+
protected apexDefiFactoryAddress: Address;
|
|
13
|
+
protected apexDefiFactoryIface: Interface;
|
|
14
|
+
protected apexDefiTokenIface: Interface;
|
|
15
|
+
handlers: {
|
|
16
|
+
[event: string]: (event: any, state: DeepReadonly<ApexDefiPoolState>, log: Readonly<Log>) => DeepReadonly<ApexDefiPoolState> | null;
|
|
17
|
+
};
|
|
18
|
+
logDecoder: (log: Log) => any;
|
|
19
|
+
coder: AbiCoder;
|
|
20
|
+
addressesSubscribed: string[];
|
|
21
|
+
readonly token0: Address;
|
|
22
|
+
readonly token1: Address;
|
|
23
|
+
private _poolAddress?;
|
|
24
|
+
constructor(parentName: string, network: number, dexHelper: IDexHelper, token0: Address, token1: Address, poolAddress: Address, logger: Logger, apexDefiFactoryAddress: Address, apexDefiFactoryIface?: Interface, apexDefiTokenIface?: Interface);
|
|
25
|
+
get poolAddress(): Address;
|
|
26
|
+
set poolAddress(address: Address);
|
|
27
|
+
/**
|
|
28
|
+
* The function is called every time any of the subscribed
|
|
29
|
+
* addresses release log. The function accepts the current
|
|
30
|
+
* state, updates the state according to the log, and returns
|
|
31
|
+
* the updated state.
|
|
32
|
+
* @param state - Current state of event subscriber
|
|
33
|
+
* @param log - Log released by one of the subscribed addresses
|
|
34
|
+
* @returns Updates state of the event subscriber after the log
|
|
35
|
+
*/
|
|
36
|
+
protected processLog(state: DeepReadonly<ApexDefiPoolState>, log: Readonly<Log>): DeepReadonly<ApexDefiPoolState> | null;
|
|
37
|
+
getStateOrGenerate(blockNumber: number): Promise<Readonly<ApexDefiPoolState>>;
|
|
38
|
+
/**
|
|
39
|
+
* The function generates state using on-chain calls. This
|
|
40
|
+
* function is called to regenerate state if the event based
|
|
41
|
+
* system fails to fetch events and the local state is no
|
|
42
|
+
* more correct.
|
|
43
|
+
* @param blockNumber - Blocknumber for which the state should
|
|
44
|
+
* should be generated
|
|
45
|
+
* @returns state of the event subscriber at blocknumber
|
|
46
|
+
*/
|
|
47
|
+
generateState(blockNumber: number): Promise<DeepReadonly<ApexDefiPoolState>>;
|
|
48
|
+
handleSwap(event: any, state: DeepReadonly<ApexDefiPoolState>, log: Readonly<Log>): DeepReadonly<ApexDefiPoolState> | null;
|
|
49
|
+
handleAddLiquidity(event: any, state: DeepReadonly<ApexDefiPoolState>, log: Readonly<Log>): DeepReadonly<ApexDefiPoolState> | null;
|
|
50
|
+
handleRemoveLiquidity(event: any, state: DeepReadonly<ApexDefiPoolState>, log: Readonly<Log>): DeepReadonly<ApexDefiPoolState> | null;
|
|
51
|
+
/**
|
|
52
|
+
* Release any resources held by this event pool
|
|
53
|
+
*/
|
|
54
|
+
releaseResources(): void;
|
|
55
|
+
}
|
|
@@ -0,0 +1,247 @@
|
|
|
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.ApexDefiEventPool = void 0;
|
|
7
|
+
const abi_1 = require("@ethersproject/abi");
|
|
8
|
+
const utils_1 = require("../../utils");
|
|
9
|
+
const stateful_event_subscriber_1 = require("../../stateful-event-subscriber");
|
|
10
|
+
const ApexDefiToken_abi_json_1 = __importDefault(require("../../abi/apex-defi/ApexDefiToken.abi.json"));
|
|
11
|
+
const ApexDefiFactory_abi_json_1 = __importDefault(require("../../abi/apex-defi/ApexDefiFactory.abi.json"));
|
|
12
|
+
const abi_2 = require("@ethersproject/abi");
|
|
13
|
+
const utils_2 = require("./utils");
|
|
14
|
+
const constants_1 = require("../../constants");
|
|
15
|
+
class ApexDefiEventPool extends stateful_event_subscriber_1.StatefulEventSubscriber {
|
|
16
|
+
parentName;
|
|
17
|
+
network;
|
|
18
|
+
dexHelper;
|
|
19
|
+
apexDefiFactoryAddress;
|
|
20
|
+
apexDefiFactoryIface;
|
|
21
|
+
apexDefiTokenIface;
|
|
22
|
+
handlers = {};
|
|
23
|
+
logDecoder;
|
|
24
|
+
coder = new abi_2.AbiCoder();
|
|
25
|
+
addressesSubscribed;
|
|
26
|
+
token0;
|
|
27
|
+
token1;
|
|
28
|
+
_poolAddress;
|
|
29
|
+
constructor(parentName, network, dexHelper, token0, token1, poolAddress, logger, apexDefiFactoryAddress, apexDefiFactoryIface = new abi_1.Interface(ApexDefiFactory_abi_json_1.default), apexDefiTokenIface = new abi_1.Interface(ApexDefiToken_abi_json_1.default)) {
|
|
30
|
+
super(parentName, poolAddress, dexHelper, logger);
|
|
31
|
+
this.parentName = parentName;
|
|
32
|
+
this.network = network;
|
|
33
|
+
this.dexHelper = dexHelper;
|
|
34
|
+
this.apexDefiFactoryAddress = apexDefiFactoryAddress;
|
|
35
|
+
this.apexDefiFactoryIface = apexDefiFactoryIface;
|
|
36
|
+
this.apexDefiTokenIface = apexDefiTokenIface;
|
|
37
|
+
this.token0 = token0.toLowerCase();
|
|
38
|
+
this.token1 = token1.toLowerCase();
|
|
39
|
+
this._poolAddress = poolAddress.toLowerCase();
|
|
40
|
+
this.logDecoder = (log) => this.apexDefiTokenIface.parseLog(log);
|
|
41
|
+
this.addressesSubscribed = new Array(1).fill(poolAddress);
|
|
42
|
+
// Add handlers
|
|
43
|
+
this.handlers['Swap'] = this.handleSwap.bind(this);
|
|
44
|
+
this.handlers['AddLiquidity'] = this.handleAddLiquidity.bind(this);
|
|
45
|
+
this.handlers['RemoveLiquidity'] = this.handleRemoveLiquidity.bind(this);
|
|
46
|
+
}
|
|
47
|
+
get poolAddress() {
|
|
48
|
+
// If the pool address is not set, compute it
|
|
49
|
+
// ApexDefi pools are always in the format of WETH/token
|
|
50
|
+
// If the token0 is WETH, then the pool address is the token1 address
|
|
51
|
+
// Otherwise, the pool address is the token0 address
|
|
52
|
+
if (this._poolAddress === undefined) {
|
|
53
|
+
if (this.token0.toLowerCase() === constants_1.ETHER_ADDRESS.toLowerCase()) {
|
|
54
|
+
this._poolAddress = this.token1;
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
this._poolAddress = this.token0;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return this._poolAddress;
|
|
61
|
+
}
|
|
62
|
+
set poolAddress(address) {
|
|
63
|
+
this._poolAddress = address.toLowerCase();
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* The function is called every time any of the subscribed
|
|
67
|
+
* addresses release log. The function accepts the current
|
|
68
|
+
* state, updates the state according to the log, and returns
|
|
69
|
+
* the updated state.
|
|
70
|
+
* @param state - Current state of event subscriber
|
|
71
|
+
* @param log - Log released by one of the subscribed addresses
|
|
72
|
+
* @returns Updates state of the event subscriber after the log
|
|
73
|
+
*/
|
|
74
|
+
processLog(state, log) {
|
|
75
|
+
try {
|
|
76
|
+
const event = this.logDecoder(log);
|
|
77
|
+
if (event.name in this.handlers) {
|
|
78
|
+
return this.handlers[event.name](event, state, log);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
catch (e) {
|
|
82
|
+
(0, utils_1.catchParseLogError)(e, this.logger);
|
|
83
|
+
}
|
|
84
|
+
return null;
|
|
85
|
+
}
|
|
86
|
+
async getStateOrGenerate(blockNumber) {
|
|
87
|
+
const eventState = this.getState(blockNumber);
|
|
88
|
+
if (eventState)
|
|
89
|
+
return eventState;
|
|
90
|
+
const onChainState = await this.generateState(blockNumber);
|
|
91
|
+
this.setState(onChainState, blockNumber);
|
|
92
|
+
return onChainState;
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* The function generates state using on-chain calls. This
|
|
96
|
+
* function is called to regenerate state if the event based
|
|
97
|
+
* system fails to fetch events and the local state is no
|
|
98
|
+
* more correct.
|
|
99
|
+
* @param blockNumber - Blocknumber for which the state should
|
|
100
|
+
* should be generated
|
|
101
|
+
* @returns state of the event subscriber at blocknumber
|
|
102
|
+
*/
|
|
103
|
+
async generateState(blockNumber) {
|
|
104
|
+
const poolData = await (0, utils_2.fetchApexDefiOnChainPoolData)(this.poolAddress, this.network, blockNumber, this.dexHelper, this.apexDefiTokenIface, this.apexDefiFactoryIface, this.logger);
|
|
105
|
+
if (!poolData) {
|
|
106
|
+
throw new Error('No pool data found');
|
|
107
|
+
}
|
|
108
|
+
const state = {
|
|
109
|
+
reserve0: (0, utils_2.toBigInt)(poolData.reserve0),
|
|
110
|
+
reserve1: (0, utils_2.toBigInt)(poolData.reserve1),
|
|
111
|
+
baseSwapRate: poolData.baseSwapRate,
|
|
112
|
+
protocolFee: poolData.protocolFee,
|
|
113
|
+
lpFee: poolData.lpFee,
|
|
114
|
+
tradingFee: poolData.tradingFee,
|
|
115
|
+
isLegacy: poolData.isLegacy,
|
|
116
|
+
tradingEnabled: poolData.tradingEnabled,
|
|
117
|
+
};
|
|
118
|
+
return state;
|
|
119
|
+
}
|
|
120
|
+
// Handle swap events to update pool state
|
|
121
|
+
handleSwap(event, state, log) {
|
|
122
|
+
try {
|
|
123
|
+
const { amountTokenIn, amountNativeIn, amountTokenOut, amountNativeOut } = event.args;
|
|
124
|
+
// Use bigIntify for safety
|
|
125
|
+
const tokenIn = (0, utils_1.bigIntify)(amountTokenIn);
|
|
126
|
+
const nativeIn = (0, utils_1.bigIntify)(amountNativeIn);
|
|
127
|
+
const tokenOut = (0, utils_1.bigIntify)(amountTokenOut);
|
|
128
|
+
const nativeOut = (0, utils_1.bigIntify)(amountNativeOut);
|
|
129
|
+
// Convert state reserves to BigInt
|
|
130
|
+
const currentReserve0 = (0, utils_2.toBigInt)(state.reserve0);
|
|
131
|
+
const currentReserve1 = (0, utils_2.toBigInt)(state.reserve1);
|
|
132
|
+
// Exact on-chain calculation trace
|
|
133
|
+
const inputAmount = tokenIn > 0n ? tokenIn : nativeIn;
|
|
134
|
+
// Step 1: Calculate trading fee (exactly like contract)
|
|
135
|
+
const tradingFees = (inputAmount * BigInt(state.tradingFee)) / 10000n;
|
|
136
|
+
// Step 2: Calculate factory fee (different for V1 vs V2)
|
|
137
|
+
let factoryFees;
|
|
138
|
+
if (state.isLegacy) {
|
|
139
|
+
// V1 token - calculate total fee and factory fee separately
|
|
140
|
+
// const totalFee = (inputAmount * BigInt(state.baseSwapRate)) / 10000n; // 30
|
|
141
|
+
factoryFees = (inputAmount * BigInt(state.protocolFee)) / 10000n; // 25
|
|
142
|
+
// const lpFees = totalFee - factoryFees; // 5
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
// V2 token - use protocol fee breakdown
|
|
146
|
+
const totalFactoryFee = (inputAmount * BigInt(state.baseSwapRate)) / 10000n;
|
|
147
|
+
const protocolFee = (totalFactoryFee * BigInt(state.protocolFee)) / 10000n;
|
|
148
|
+
// const lpFee = (totalFactoryFee * BigInt(state.lpFee)) / 10000n;
|
|
149
|
+
factoryFees = protocolFee;
|
|
150
|
+
}
|
|
151
|
+
// Step 3: Calculate total fees to set aside
|
|
152
|
+
const totalFeesToSetAside = tradingFees + factoryFees;
|
|
153
|
+
// Step 4: Calculate net amount for reserves
|
|
154
|
+
const netAmountForReserves = inputAmount - totalFeesToSetAside;
|
|
155
|
+
// Step 6: Update reserves (exactly like contract _swap function)
|
|
156
|
+
let newReserve0 = currentReserve0;
|
|
157
|
+
let newReserve1 = currentReserve1;
|
|
158
|
+
if (nativeIn > 0n) {
|
|
159
|
+
// Native to token swap
|
|
160
|
+
newReserve0 = currentReserve0 + netAmountForReserves;
|
|
161
|
+
newReserve1 = currentReserve1 - tokenOut;
|
|
162
|
+
}
|
|
163
|
+
else if (tokenIn > 0n) {
|
|
164
|
+
// Token to native swap
|
|
165
|
+
newReserve0 = currentReserve0 - nativeOut;
|
|
166
|
+
newReserve1 = currentReserve1 + netAmountForReserves;
|
|
167
|
+
}
|
|
168
|
+
return {
|
|
169
|
+
...state,
|
|
170
|
+
tradingEnabled: true, // if we are here, the pool is trading
|
|
171
|
+
reserve0: newReserve0,
|
|
172
|
+
reserve1: newReserve1,
|
|
173
|
+
};
|
|
174
|
+
}
|
|
175
|
+
catch (error) {
|
|
176
|
+
this.logger.error('Error in handleSwap:', error);
|
|
177
|
+
this.logger.error('Error stack:', error.stack);
|
|
178
|
+
return null;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
// Handle AddLiquidity events to update pool state
|
|
182
|
+
handleAddLiquidity(event, state, log) {
|
|
183
|
+
try {
|
|
184
|
+
const { nativeAmount, tokenAmount } = event.args;
|
|
185
|
+
// Use bigIntify for safety
|
|
186
|
+
const nativeAdded = (0, utils_1.bigIntify)(nativeAmount);
|
|
187
|
+
const tokenAdded = (0, utils_1.bigIntify)(tokenAmount);
|
|
188
|
+
// Convert state reserves to BigInt
|
|
189
|
+
const currentReserve0 = (0, utils_2.toBigInt)(state.reserve0);
|
|
190
|
+
const currentReserve1 = (0, utils_2.toBigInt)(state.reserve1);
|
|
191
|
+
// Add liquidity to reserves
|
|
192
|
+
// Note: In ApexDefi, reserve0 is always native (AVAX) and reserve1 is always token
|
|
193
|
+
const newReserve0 = currentReserve0 + nativeAdded;
|
|
194
|
+
const newReserve1 = currentReserve1 + tokenAdded;
|
|
195
|
+
return {
|
|
196
|
+
...state,
|
|
197
|
+
reserve0: newReserve0,
|
|
198
|
+
reserve1: newReserve1,
|
|
199
|
+
};
|
|
200
|
+
}
|
|
201
|
+
catch (error) {
|
|
202
|
+
this.logger.error('Error in handleAddLiquidity:', error);
|
|
203
|
+
this.logger.error('Error stack:', error.stack);
|
|
204
|
+
return null;
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
// Handle RemoveLiquidity events to update pool state
|
|
208
|
+
handleRemoveLiquidity(event, state, log) {
|
|
209
|
+
try {
|
|
210
|
+
const { nativeAmount, tokenAmount } = event.args;
|
|
211
|
+
// Use bigIntify for safety
|
|
212
|
+
const nativeRemoved = (0, utils_1.bigIntify)(nativeAmount);
|
|
213
|
+
const tokenRemoved = (0, utils_1.bigIntify)(tokenAmount);
|
|
214
|
+
// Convert state reserves to BigInt
|
|
215
|
+
const currentReserve0 = (0, utils_2.toBigInt)(state.reserve0);
|
|
216
|
+
const currentReserve1 = (0, utils_2.toBigInt)(state.reserve1);
|
|
217
|
+
// Remove liquidity from reserves
|
|
218
|
+
// Note: In ApexDefi, reserve0 is always native (AVAX) and reserve1 is always token
|
|
219
|
+
const newReserve0 = currentReserve0 - nativeRemoved;
|
|
220
|
+
const newReserve1 = currentReserve1 - tokenRemoved;
|
|
221
|
+
// Ensure reserves don't go negative (safety check)
|
|
222
|
+
if (newReserve0 < 0n || newReserve1 < 0n) {
|
|
223
|
+
this.logger.warn('Reserves would go negative, keeping current state');
|
|
224
|
+
return state;
|
|
225
|
+
}
|
|
226
|
+
return {
|
|
227
|
+
...state,
|
|
228
|
+
reserve0: newReserve0,
|
|
229
|
+
reserve1: newReserve1,
|
|
230
|
+
};
|
|
231
|
+
}
|
|
232
|
+
catch (error) {
|
|
233
|
+
this.logger.error('Error in handleRemoveLiquidity:', error);
|
|
234
|
+
this.logger.error('Error stack:', error.stack);
|
|
235
|
+
return null;
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
/**
|
|
239
|
+
* Release any resources held by this event pool
|
|
240
|
+
*/
|
|
241
|
+
releaseResources() {
|
|
242
|
+
// Clean up any subscriptions or timers if needed
|
|
243
|
+
this.addressesSubscribed = [];
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
exports.ApexDefiEventPool = ApexDefiEventPool;
|
|
247
|
+
//# sourceMappingURL=apex-defi-pool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"apex-defi-pool.js","sourceRoot":"","sources":["../../../src/dex/apex-defi/apex-defi-pool.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Interface } from '@ethersproject/abi';
|
|
2
|
+
import { DeepReadonly } from 'ts-essentials';
|
|
3
|
+
import { IDexHelper } from '../../dex-helper/idex-helper';
|
|
4
|
+
import { StatefulEventSubscriber } from '../../stateful-event-subscriber';
|
|
5
|
+
import { Address, Log, Logger } from '../../types';
|
|
6
|
+
import { LogDescription } from 'ethers/lib/utils';
|
|
7
|
+
export interface WrapperInfo {
|
|
8
|
+
wrapperAddress: Address;
|
|
9
|
+
originalToken: Address;
|
|
10
|
+
wrappedToken: Address;
|
|
11
|
+
originalTokenDecimals: number;
|
|
12
|
+
wrappedTokenDecimals: number;
|
|
13
|
+
}
|
|
14
|
+
export type WrapperFactoryState = Record<Address, WrapperInfo>;
|
|
15
|
+
export type OnWrapperCreatedCallback = ({ wrapperInfo, blockNumber, }: {
|
|
16
|
+
wrapperInfo: WrapperInfo;
|
|
17
|
+
blockNumber: number;
|
|
18
|
+
}) => Promise<void>;
|
|
19
|
+
export declare class ApexDefiWrapperFactory extends StatefulEventSubscriber<WrapperFactoryState> {
|
|
20
|
+
readonly dexHelper: IDexHelper;
|
|
21
|
+
protected readonly wrapperFactoryAddress: Address;
|
|
22
|
+
protected readonly onWrapperCreated: OnWrapperCreatedCallback;
|
|
23
|
+
handlers: {
|
|
24
|
+
[event: string]: (event: any, log: Readonly<Log>) => Promise<void>;
|
|
25
|
+
};
|
|
26
|
+
logDecoder: (log: Log) => any;
|
|
27
|
+
readonly wrapperFactoryIface: Interface;
|
|
28
|
+
readonly wrapperIface: Interface;
|
|
29
|
+
private wrapperCache;
|
|
30
|
+
private originalTokenToWrapper;
|
|
31
|
+
private wrappedTokenToWrapper;
|
|
32
|
+
constructor(dexHelper: IDexHelper, parentName: string, wrapperFactoryAddress: Address, logger: Logger, onWrapperCreated: OnWrapperCreatedCallback);
|
|
33
|
+
generateState(): WrapperFactoryState;
|
|
34
|
+
protected processLog(_: DeepReadonly<WrapperFactoryState>, log: Readonly<Log>): Promise<WrapperFactoryState>;
|
|
35
|
+
handleWrapperCreated(event: LogDescription, log: Readonly<Log>): Promise<void>;
|
|
36
|
+
private fetchWrapperInfo;
|
|
37
|
+
initialize(blockNumber: number): Promise<void>;
|
|
38
|
+
getWrapperInfo(wrapperAddress: Address): WrapperInfo | undefined;
|
|
39
|
+
getWrapperByOriginalToken(originalToken: Address): Address | undefined;
|
|
40
|
+
getWrapperByWrappedToken(wrappedToken: Address): Address | undefined;
|
|
41
|
+
isWrappedToken(tokenAddress: Address): boolean;
|
|
42
|
+
isOriginalToken(tokenAddress: Address): boolean;
|
|
43
|
+
getAllWrappers(): WrapperInfo[];
|
|
44
|
+
/**
|
|
45
|
+
* Check if two tokens form a wrapper pair and return wrapper info
|
|
46
|
+
*/
|
|
47
|
+
getWrapperPairInfo(srcToken: Address, destToken: Address): {
|
|
48
|
+
wrapperAddress: Address;
|
|
49
|
+
isWrap: boolean;
|
|
50
|
+
wrapperInfo: WrapperInfo;
|
|
51
|
+
} | null;
|
|
52
|
+
/**
|
|
53
|
+
* Check if two tokens form a wrapper operation
|
|
54
|
+
*/
|
|
55
|
+
isWrapperOperation(srcToken: Address, destToken: Address): boolean;
|
|
56
|
+
releaseResources(): void;
|
|
57
|
+
}
|