@juiceswapxyz/uniswapx-sdk 3.0.0 → 3.0.2
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/cjs/abis/MockERC20.json +1606 -0
- package/dist/cjs/abis/deploylessMulticall2.json +30 -0
- package/dist/cjs/abis/multicall2.json +315 -0
- package/dist/cjs/src/builder/DutchOrderBuilder.d.ts +25 -0
- package/dist/cjs/src/builder/DutchOrderBuilder.js +143 -0
- package/dist/cjs/src/builder/DutchOrderBuilder.js.map +1 -0
- package/dist/cjs/src/builder/DutchOrderBuilder.test.d.ts +1 -0
- package/dist/cjs/src/builder/DutchOrderBuilder.test.js +386 -0
- package/dist/cjs/src/builder/DutchOrderBuilder.test.js.map +1 -0
- package/dist/cjs/src/builder/OrderBuilder.d.ts +17 -0
- package/dist/cjs/src/builder/OrderBuilder.js +59 -0
- package/dist/cjs/src/builder/OrderBuilder.js.map +1 -0
- package/dist/cjs/src/builder/PriorityOrderBuilder.d.ts +29 -0
- package/dist/cjs/src/builder/PriorityOrderBuilder.js +174 -0
- package/dist/cjs/src/builder/PriorityOrderBuilder.js.map +1 -0
- package/dist/cjs/src/builder/PriorityOrderBuilder.test.d.ts +1 -0
- package/dist/cjs/src/builder/PriorityOrderBuilder.test.js +206 -0
- package/dist/cjs/src/builder/PriorityOrderBuilder.test.js.map +1 -0
- package/dist/cjs/src/builder/RelayOrderBuilder.d.ts +22 -0
- package/dist/cjs/src/builder/RelayOrderBuilder.js +109 -0
- package/dist/cjs/src/builder/RelayOrderBuilder.js.map +1 -0
- package/dist/cjs/src/builder/RelayOrderBuilder.test.d.ts +1 -0
- package/dist/cjs/src/builder/RelayOrderBuilder.test.js +224 -0
- package/dist/cjs/src/builder/RelayOrderBuilder.test.js.map +1 -0
- package/dist/cjs/src/builder/V2DutchOrderBuilder.d.ts +33 -0
- package/dist/cjs/src/builder/V2DutchOrderBuilder.js +240 -0
- package/dist/cjs/src/builder/V2DutchOrderBuilder.js.map +1 -0
- package/dist/cjs/src/builder/V2DutchOrderBuilder.test.d.ts +1 -0
- package/dist/cjs/src/builder/V2DutchOrderBuilder.test.js +534 -0
- package/dist/cjs/src/builder/V2DutchOrderBuilder.test.js.map +1 -0
- package/dist/cjs/src/builder/V3DutchOrderBuilder.d.ts +36 -0
- package/dist/cjs/src/builder/V3DutchOrderBuilder.js +253 -0
- package/dist/cjs/src/builder/V3DutchOrderBuilder.js.map +1 -0
- package/dist/cjs/src/builder/V3DutchOrderBuilder.test.d.ts +1 -0
- package/dist/cjs/src/builder/V3DutchOrderBuilder.test.js +895 -0
- package/dist/cjs/src/builder/V3DutchOrderBuilder.test.js.map +1 -0
- package/dist/cjs/src/builder/index.d.ts +6 -0
- package/dist/cjs/src/builder/index.js +10 -0
- package/dist/cjs/src/builder/index.js.map +1 -0
- package/dist/cjs/src/constants.d.ts +58 -0
- package/dist/cjs/src/constants.js +127 -0
- package/dist/cjs/src/constants.js.map +1 -0
- package/dist/cjs/src/constants.test.d.ts +1 -0
- package/dist/cjs/src/constants.test.js +56 -0
- package/dist/cjs/src/constants.test.js.map +1 -0
- package/dist/cjs/src/contracts/DSTokenInterface.d.ts +372 -0
- package/dist/cjs/src/contracts/DSTokenInterface.js +3 -0
- package/dist/cjs/src/contracts/DSTokenInterface.js.map +1 -0
- package/dist/cjs/src/contracts/DeploylessMulticall2.d.ts +37 -0
- package/dist/cjs/src/contracts/DeploylessMulticall2.js +3 -0
- package/dist/cjs/src/contracts/DeploylessMulticall2.js.map +1 -0
- package/dist/cjs/src/contracts/DutchLimitOrderReactor.d.ts +191 -0
- package/dist/cjs/src/contracts/DutchLimitOrderReactor.js +3 -0
- package/dist/cjs/src/contracts/DutchLimitOrderReactor.js.map +1 -0
- package/dist/cjs/src/contracts/DutchOrderReactor.d.ts +191 -0
- package/dist/cjs/src/contracts/DutchOrderReactor.js +3 -0
- package/dist/cjs/src/contracts/DutchOrderReactor.js.map +1 -0
- package/dist/cjs/src/contracts/ERC1967Proxy.d.ts +39 -0
- package/dist/cjs/src/contracts/ERC1967Proxy.js +3 -0
- package/dist/cjs/src/contracts/ERC1967Proxy.js.map +1 -0
- package/dist/cjs/src/contracts/ExclusiveDutchOrderReactor.d.ts +207 -0
- package/dist/cjs/src/contracts/ExclusiveDutchOrderReactor.js +3 -0
- package/dist/cjs/src/contracts/ExclusiveDutchOrderReactor.js.map +1 -0
- package/dist/cjs/src/contracts/ExclusiveFillerValidation.d.ts +105 -0
- package/dist/cjs/src/contracts/ExclusiveFillerValidation.js +3 -0
- package/dist/cjs/src/contracts/ExclusiveFillerValidation.js.map +1 -0
- package/dist/cjs/src/contracts/ISuperstateTokenV4.d.ts +628 -0
- package/dist/cjs/src/contracts/ISuperstateTokenV4.js +3 -0
- package/dist/cjs/src/contracts/ISuperstateTokenV4.js.map +1 -0
- package/dist/cjs/src/contracts/MockDSTokenInterface.d.ts +62 -0
- package/dist/cjs/src/contracts/MockDSTokenInterface.js +3 -0
- package/dist/cjs/src/contracts/MockDSTokenInterface.js.map +1 -0
- package/dist/cjs/src/contracts/MockERC20.d.ts +242 -0
- package/dist/cjs/src/contracts/MockERC20.js +3 -0
- package/dist/cjs/src/contracts/MockERC20.js.map +1 -0
- package/dist/cjs/src/contracts/MockSuperstateTokenV4.d.ts +58 -0
- package/dist/cjs/src/contracts/MockSuperstateTokenV4.js +3 -0
- package/dist/cjs/src/contracts/MockSuperstateTokenV4.js.map +1 -0
- package/dist/cjs/src/contracts/Multicall2.d.ts +218 -0
- package/dist/cjs/src/contracts/Multicall2.js +3 -0
- package/dist/cjs/src/contracts/Multicall2.js.map +1 -0
- package/dist/cjs/src/contracts/OrderQuoter.d.ts +131 -0
- package/dist/cjs/src/contracts/OrderQuoter.js +3 -0
- package/dist/cjs/src/contracts/OrderQuoter.js.map +1 -0
- package/dist/cjs/src/contracts/Permit2.d.ts +533 -0
- package/dist/cjs/src/contracts/Permit2.js +3 -0
- package/dist/cjs/src/contracts/Permit2.js.map +1 -0
- package/dist/cjs/src/contracts/PriorityOrderReactor.d.ts +207 -0
- package/dist/cjs/src/contracts/PriorityOrderReactor.js +3 -0
- package/dist/cjs/src/contracts/PriorityOrderReactor.js.map +1 -0
- package/dist/cjs/src/contracts/Proxy.d.ts +106 -0
- package/dist/cjs/src/contracts/Proxy.js +3 -0
- package/dist/cjs/src/contracts/Proxy.js.map +1 -0
- package/dist/cjs/src/contracts/RelayOrderReactor.d.ts +150 -0
- package/dist/cjs/src/contracts/RelayOrderReactor.js +3 -0
- package/dist/cjs/src/contracts/RelayOrderReactor.js.map +1 -0
- package/dist/cjs/src/contracts/SwapRouter02Executor.d.ts +240 -0
- package/dist/cjs/src/contracts/SwapRouter02Executor.js +3 -0
- package/dist/cjs/src/contracts/SwapRouter02Executor.js.map +1 -0
- package/dist/cjs/src/contracts/V2DutchOrderReactor.d.ts +207 -0
- package/dist/cjs/src/contracts/V2DutchOrderReactor.js +3 -0
- package/dist/cjs/src/contracts/V2DutchOrderReactor.js.map +1 -0
- package/dist/cjs/src/contracts/V3DutchOrderReactor.d.ts +207 -0
- package/dist/cjs/src/contracts/V3DutchOrderReactor.js +3 -0
- package/dist/cjs/src/contracts/V3DutchOrderReactor.js.map +1 -0
- package/dist/cjs/src/contracts/common.d.ts +22 -0
- package/dist/cjs/src/contracts/common.js +3 -0
- package/dist/cjs/src/contracts/common.js.map +1 -0
- package/dist/cjs/src/contracts/factories/DSTokenInterface__factory.d.ts +368 -0
- package/dist/cjs/src/contracts/factories/DSTokenInterface__factory.js +506 -0
- package/dist/cjs/src/contracts/factories/DSTokenInterface__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/DeploylessMulticall2__factory.d.ts +29 -0
- package/dist/cjs/src/contracts/factories/DeploylessMulticall2__factory.js +48 -0
- package/dist/cjs/src/contracts/factories/DeploylessMulticall2__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/DutchLimitOrderReactor__factory.d.ts +87 -0
- package/dist/cjs/src/contracts/factories/DutchLimitOrderReactor__factory.js +385 -0
- package/dist/cjs/src/contracts/factories/DutchLimitOrderReactor__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/DutchOrderReactor__factory.d.ts +87 -0
- package/dist/cjs/src/contracts/factories/DutchOrderReactor__factory.js +385 -0
- package/dist/cjs/src/contracts/factories/DutchOrderReactor__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/ERC1967Proxy__factory.d.ts +70 -0
- package/dist/cjs/src/contracts/factories/ERC1967Proxy__factory.js +108 -0
- package/dist/cjs/src/contracts/factories/ERC1967Proxy__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/ExclusiveDutchOrderReactor__factory.d.ts +297 -0
- package/dist/cjs/src/contracts/factories/ExclusiveDutchOrderReactor__factory.js +400 -0
- package/dist/cjs/src/contracts/factories/ExclusiveDutchOrderReactor__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/ExclusiveFillerValidation__factory.d.ts +115 -0
- package/dist/cjs/src/contracts/factories/ExclusiveFillerValidation__factory.js +165 -0
- package/dist/cjs/src/contracts/factories/ExclusiveFillerValidation__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/ISuperstateTokenV4__factory.d.ts +714 -0
- package/dist/cjs/src/contracts/factories/ISuperstateTokenV4__factory.js +918 -0
- package/dist/cjs/src/contracts/factories/ISuperstateTokenV4__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/MockDSTokenInterface__factory.d.ts +61 -0
- package/dist/cjs/src/contracts/factories/MockDSTokenInterface__factory.js +95 -0
- package/dist/cjs/src/contracts/factories/MockDSTokenInterface__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/MockERC20__factory.d.ts +301 -0
- package/dist/cjs/src/contracts/factories/MockERC20__factory.js +408 -0
- package/dist/cjs/src/contracts/factories/MockERC20__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/MockSuperstateTokenV4__factory.d.ts +49 -0
- package/dist/cjs/src/contracts/factories/MockSuperstateTokenV4__factory.js +80 -0
- package/dist/cjs/src/contracts/factories/MockSuperstateTokenV4__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/Multicall2__factory.d.ts +245 -0
- package/dist/cjs/src/contracts/factories/Multicall2__factory.js +333 -0
- package/dist/cjs/src/contracts/factories/Multicall2__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/OrderQuoter__factory.d.ts +215 -0
- package/dist/cjs/src/contracts/factories/OrderQuoter__factory.js +295 -0
- package/dist/cjs/src/contracts/factories/OrderQuoter__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/Permit2__factory.d.ts +720 -0
- package/dist/cjs/src/contracts/factories/Permit2__factory.js +942 -0
- package/dist/cjs/src/contracts/factories/Permit2__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/PriorityOrderReactor__factory.d.ts +293 -0
- package/dist/cjs/src/contracts/factories/PriorityOrderReactor__factory.js +395 -0
- package/dist/cjs/src/contracts/factories/PriorityOrderReactor__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/Proxy__factory.d.ts +88 -0
- package/dist/cjs/src/contracts/factories/Proxy__factory.js +130 -0
- package/dist/cjs/src/contracts/factories/Proxy__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/RelayOrderReactor__factory.d.ts +188 -0
- package/dist/cjs/src/contracts/factories/RelayOrderReactor__factory.js +258 -0
- package/dist/cjs/src/contracts/factories/RelayOrderReactor__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/SwapRouter02Executor__factory.d.ts +257 -0
- package/dist/cjs/src/contracts/factories/SwapRouter02Executor__factory.js +348 -0
- package/dist/cjs/src/contracts/factories/SwapRouter02Executor__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/V2DutchOrderReactor__factory.d.ts +297 -0
- package/dist/cjs/src/contracts/factories/V2DutchOrderReactor__factory.js +400 -0
- package/dist/cjs/src/contracts/factories/V2DutchOrderReactor__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/V3DutchOrderReactor__factory.d.ts +297 -0
- package/dist/cjs/src/contracts/factories/V3DutchOrderReactor__factory.js +400 -0
- package/dist/cjs/src/contracts/factories/V3DutchOrderReactor__factory.js.map +1 -0
- package/dist/cjs/src/contracts/factories/index.d.ts +18 -0
- package/dist/cjs/src/contracts/factories/index.js +43 -0
- package/dist/cjs/src/contracts/factories/index.js.map +1 -0
- package/dist/cjs/src/contracts/index.d.ts +37 -0
- package/dist/cjs/src/contracts/index.js +42 -0
- package/dist/cjs/src/contracts/index.js.map +1 -0
- package/dist/cjs/src/errors.d.ts +3 -0
- package/dist/cjs/src/errors.js +11 -0
- package/dist/cjs/src/errors.js.map +1 -0
- package/dist/cjs/src/index.d.ts +5 -0
- package/dist/cjs/src/index.js +9 -0
- package/dist/cjs/src/index.js.map +1 -0
- package/dist/cjs/src/order/DutchOrder.d.ts +67 -0
- package/dist/cjs/src/order/DutchOrder.js +291 -0
- package/dist/cjs/src/order/DutchOrder.js.map +1 -0
- package/dist/cjs/src/order/DutchOrder.test.d.ts +1 -0
- package/dist/cjs/src/order/DutchOrder.test.js +165 -0
- package/dist/cjs/src/order/DutchOrder.test.js.map +1 -0
- package/dist/cjs/src/order/PriorityOrder.d.ts +121 -0
- package/dist/cjs/src/order/PriorityOrder.js +396 -0
- package/dist/cjs/src/order/PriorityOrder.js.map +1 -0
- package/dist/cjs/src/order/PriorityOrder.test.d.ts +1 -0
- package/dist/cjs/src/order/PriorityOrder.test.js +87 -0
- package/dist/cjs/src/order/PriorityOrder.test.js.map +1 -0
- package/dist/cjs/src/order/RelayOrder.d.ts +75 -0
- package/dist/cjs/src/order/RelayOrder.js +228 -0
- package/dist/cjs/src/order/RelayOrder.js.map +1 -0
- package/dist/cjs/src/order/RelayOrder.test.d.ts +1 -0
- package/dist/cjs/src/order/RelayOrder.test.js +73 -0
- package/dist/cjs/src/order/RelayOrder.test.js.map +1 -0
- package/dist/cjs/src/order/V2DutchOrder.d.ts +103 -0
- package/dist/cjs/src/order/V2DutchOrder.js +389 -0
- package/dist/cjs/src/order/V2DutchOrder.js.map +1 -0
- package/dist/cjs/src/order/V2DutchOrder.test.d.ts +1 -0
- package/dist/cjs/src/order/V2DutchOrder.test.js +272 -0
- package/dist/cjs/src/order/V2DutchOrder.test.js.map +1 -0
- package/dist/cjs/src/order/V3DutchOrder.d.ts +105 -0
- package/dist/cjs/src/order/V3DutchOrder.js +433 -0
- package/dist/cjs/src/order/V3DutchOrder.js.map +1 -0
- package/dist/cjs/src/order/V3DutchOrder.test.d.ts +1 -0
- package/dist/cjs/src/order/V3DutchOrder.test.js +226 -0
- package/dist/cjs/src/order/V3DutchOrder.test.js.map +1 -0
- package/dist/cjs/src/order/index.d.ts +14 -0
- package/dist/cjs/src/order/index.js +11 -0
- package/dist/cjs/src/order/index.js.map +1 -0
- package/dist/cjs/src/order/types.d.ts +158 -0
- package/dist/cjs/src/order/types.js +3 -0
- package/dist/cjs/src/order/types.js.map +1 -0
- package/dist/cjs/src/order/validation.d.ts +24 -0
- package/dist/cjs/src/order/validation.js +61 -0
- package/dist/cjs/src/order/validation.js.map +1 -0
- package/dist/cjs/src/order/validation.test.d.ts +1 -0
- package/dist/cjs/src/order/validation.test.js +58 -0
- package/dist/cjs/src/order/validation.test.js.map +1 -0
- package/dist/cjs/src/trade/DutchOrderTrade.d.ts +33 -0
- package/dist/cjs/src/trade/DutchOrderTrade.js +81 -0
- package/dist/cjs/src/trade/DutchOrderTrade.js.map +1 -0
- package/dist/cjs/src/trade/DutchOrderTrade.test.d.ts +1 -0
- package/dist/cjs/src/trade/DutchOrderTrade.test.js +93 -0
- package/dist/cjs/src/trade/DutchOrderTrade.test.js.map +1 -0
- package/dist/cjs/src/trade/PriorityOrderTrade.d.ts +43 -0
- package/dist/cjs/src/trade/PriorityOrderTrade.js +101 -0
- package/dist/cjs/src/trade/PriorityOrderTrade.js.map +1 -0
- package/dist/cjs/src/trade/PriorityOrderTrade.test.d.ts +1 -0
- package/dist/cjs/src/trade/PriorityOrderTrade.test.js +106 -0
- package/dist/cjs/src/trade/PriorityOrderTrade.test.js.map +1 -0
- package/dist/cjs/src/trade/RelayOrderTrade.d.ts +34 -0
- package/dist/cjs/src/trade/RelayOrderTrade.js +87 -0
- package/dist/cjs/src/trade/RelayOrderTrade.js.map +1 -0
- package/dist/cjs/src/trade/RelayOrderTrade.test.d.ts +1 -0
- package/dist/cjs/src/trade/RelayOrderTrade.test.js +103 -0
- package/dist/cjs/src/trade/RelayOrderTrade.test.js.map +1 -0
- package/dist/cjs/src/trade/V2DutchOrderTrade.d.ts +33 -0
- package/dist/cjs/src/trade/V2DutchOrderTrade.js +81 -0
- package/dist/cjs/src/trade/V2DutchOrderTrade.js.map +1 -0
- package/dist/cjs/src/trade/V2DutchOrderTrade.test.d.ts +1 -0
- package/dist/cjs/src/trade/V2DutchOrderTrade.test.js +90 -0
- package/dist/cjs/src/trade/V2DutchOrderTrade.test.js.map +1 -0
- package/dist/cjs/src/trade/V3DutchOrderTrade.d.ts +41 -0
- package/dist/cjs/src/trade/V3DutchOrderTrade.js +91 -0
- package/dist/cjs/src/trade/V3DutchOrderTrade.js.map +1 -0
- package/dist/cjs/src/trade/V3DutchOrderTrade.test.d.ts +1 -0
- package/dist/cjs/src/trade/V3DutchOrderTrade.test.js +222 -0
- package/dist/cjs/src/trade/V3DutchOrderTrade.test.js.map +1 -0
- package/dist/cjs/src/trade/index.d.ts +5 -0
- package/dist/cjs/src/trade/index.js +9 -0
- package/dist/cjs/src/trade/index.js.map +1 -0
- package/dist/cjs/src/trade/utils.d.ts +8 -0
- package/dist/cjs/src/trade/utils.js +35 -0
- package/dist/cjs/src/trade/utils.js.map +1 -0
- package/dist/cjs/src/utils/EventWatcher.d.ts +46 -0
- package/dist/cjs/src/utils/EventWatcher.js +119 -0
- package/dist/cjs/src/utils/EventWatcher.js.map +1 -0
- package/dist/cjs/src/utils/NonceManager.d.ts +36 -0
- package/dist/cjs/src/utils/NonceManager.js +134 -0
- package/dist/cjs/src/utils/NonceManager.js.map +1 -0
- package/dist/cjs/src/utils/NonceManager.test.d.ts +1 -0
- package/dist/cjs/src/utils/NonceManager.test.js +131 -0
- package/dist/cjs/src/utils/NonceManager.test.js.map +1 -0
- package/dist/cjs/src/utils/OrderQuoter.d.ts +79 -0
- package/dist/cjs/src/utils/OrderQuoter.js +318 -0
- package/dist/cjs/src/utils/OrderQuoter.js.map +1 -0
- package/dist/cjs/src/utils/OrderValidator.d.ts +12 -0
- package/dist/cjs/src/utils/OrderValidator.js +47 -0
- package/dist/cjs/src/utils/OrderValidator.js.map +1 -0
- package/dist/cjs/src/utils/PermissionedTokenValidator.d.ts +23 -0
- package/dist/cjs/src/utils/PermissionedTokenValidator.js +69 -0
- package/dist/cjs/src/utils/PermissionedTokenValidator.js.map +1 -0
- package/dist/cjs/src/utils/dutchBlockDecay.d.ts +15 -0
- package/dist/cjs/src/utils/dutchBlockDecay.js +73 -0
- package/dist/cjs/src/utils/dutchBlockDecay.js.map +1 -0
- package/dist/cjs/src/utils/dutchBlockDecay.test.d.ts +1 -0
- package/dist/cjs/src/utils/dutchBlockDecay.test.js +94 -0
- package/dist/cjs/src/utils/dutchBlockDecay.test.js.map +1 -0
- package/dist/cjs/src/utils/dutchDecay.d.ts +8 -0
- package/dist/cjs/src/utils/dutchDecay.js +32 -0
- package/dist/cjs/src/utils/dutchDecay.js.map +1 -0
- package/dist/cjs/src/utils/dutchDecay.test.d.ts +1 -0
- package/dist/cjs/src/utils/dutchDecay.test.js +61 -0
- package/dist/cjs/src/utils/dutchDecay.test.js.map +1 -0
- package/dist/cjs/src/utils/index.d.ts +12 -0
- package/dist/cjs/src/utils/index.js +51 -0
- package/dist/cjs/src/utils/index.js.map +1 -0
- package/dist/cjs/src/utils/multicall.d.ts +36 -0
- package/dist/cjs/src/utils/multicall.js +91 -0
- package/dist/cjs/src/utils/multicall.js.map +1 -0
- package/dist/cjs/src/utils/order.d.ts +42 -0
- package/dist/cjs/src/utils/order.js +135 -0
- package/dist/cjs/src/utils/order.js.map +1 -0
- package/dist/cjs/src/utils/order.test.d.ts +1 -0
- package/dist/cjs/src/utils/order.test.js +340 -0
- package/dist/cjs/src/utils/order.test.js.map +1 -0
- package/dist/esm/abis/MockERC20.json +1606 -0
- package/dist/esm/abis/deploylessMulticall2.json +30 -0
- package/dist/esm/abis/multicall2.json +315 -0
- package/dist/esm/src/builder/DutchOrderBuilder.d.ts +25 -0
- package/dist/esm/src/builder/DutchOrderBuilder.js +138 -0
- package/dist/esm/src/builder/DutchOrderBuilder.js.map +1 -0
- package/dist/esm/src/builder/DutchOrderBuilder.test.d.ts +1 -0
- package/dist/esm/src/builder/DutchOrderBuilder.test.js +384 -0
- package/dist/esm/src/builder/DutchOrderBuilder.test.js.map +1 -0
- package/dist/esm/src/builder/OrderBuilder.d.ts +17 -0
- package/dist/esm/src/builder/OrderBuilder.js +54 -0
- package/dist/esm/src/builder/OrderBuilder.js.map +1 -0
- package/dist/esm/src/builder/PriorityOrderBuilder.d.ts +29 -0
- package/dist/esm/src/builder/PriorityOrderBuilder.js +169 -0
- package/dist/esm/src/builder/PriorityOrderBuilder.js.map +1 -0
- package/dist/esm/src/builder/PriorityOrderBuilder.test.d.ts +1 -0
- package/dist/esm/src/builder/PriorityOrderBuilder.test.js +204 -0
- package/dist/esm/src/builder/PriorityOrderBuilder.test.js.map +1 -0
- package/dist/esm/src/builder/RelayOrderBuilder.d.ts +22 -0
- package/dist/esm/src/builder/RelayOrderBuilder.js +104 -0
- package/dist/esm/src/builder/RelayOrderBuilder.js.map +1 -0
- package/dist/esm/src/builder/RelayOrderBuilder.test.d.ts +1 -0
- package/dist/esm/src/builder/RelayOrderBuilder.test.js +222 -0
- package/dist/esm/src/builder/RelayOrderBuilder.test.js.map +1 -0
- package/dist/esm/src/builder/V2DutchOrderBuilder.d.ts +33 -0
- package/dist/esm/src/builder/V2DutchOrderBuilder.js +235 -0
- package/dist/esm/src/builder/V2DutchOrderBuilder.js.map +1 -0
- package/dist/esm/src/builder/V2DutchOrderBuilder.test.d.ts +1 -0
- package/dist/esm/src/builder/V2DutchOrderBuilder.test.js +532 -0
- package/dist/esm/src/builder/V2DutchOrderBuilder.test.js.map +1 -0
- package/dist/esm/src/builder/V3DutchOrderBuilder.d.ts +36 -0
- package/dist/esm/src/builder/V3DutchOrderBuilder.js +248 -0
- package/dist/esm/src/builder/V3DutchOrderBuilder.js.map +1 -0
- package/dist/esm/src/builder/V3DutchOrderBuilder.test.d.ts +1 -0
- package/dist/esm/src/builder/V3DutchOrderBuilder.test.js +893 -0
- package/dist/esm/src/builder/V3DutchOrderBuilder.test.js.map +1 -0
- package/dist/esm/src/builder/index.d.ts +6 -0
- package/dist/esm/src/builder/index.js +7 -0
- package/dist/esm/src/builder/index.js.map +1 -0
- package/dist/esm/src/constants.d.ts +58 -0
- package/dist/esm/src/constants.js +122 -0
- package/dist/esm/src/constants.js.map +1 -0
- package/dist/esm/src/constants.test.d.ts +1 -0
- package/dist/esm/src/constants.test.js +54 -0
- package/dist/esm/src/constants.test.js.map +1 -0
- package/dist/esm/src/contracts/DSTokenInterface.d.ts +372 -0
- package/dist/esm/src/contracts/DSTokenInterface.js +2 -0
- package/dist/esm/src/contracts/DSTokenInterface.js.map +1 -0
- package/dist/esm/src/contracts/DeploylessMulticall2.d.ts +37 -0
- package/dist/esm/src/contracts/DeploylessMulticall2.js +2 -0
- package/dist/esm/src/contracts/DeploylessMulticall2.js.map +1 -0
- package/dist/esm/src/contracts/DutchLimitOrderReactor.d.ts +191 -0
- package/dist/esm/src/contracts/DutchLimitOrderReactor.js +2 -0
- package/dist/esm/src/contracts/DutchLimitOrderReactor.js.map +1 -0
- package/dist/esm/src/contracts/DutchOrderReactor.d.ts +191 -0
- package/dist/esm/src/contracts/DutchOrderReactor.js +2 -0
- package/dist/esm/src/contracts/DutchOrderReactor.js.map +1 -0
- package/dist/esm/src/contracts/ERC1967Proxy.d.ts +39 -0
- package/dist/esm/src/contracts/ERC1967Proxy.js +2 -0
- package/dist/esm/src/contracts/ERC1967Proxy.js.map +1 -0
- package/dist/esm/src/contracts/ExclusiveDutchOrderReactor.d.ts +207 -0
- package/dist/esm/src/contracts/ExclusiveDutchOrderReactor.js +2 -0
- package/dist/esm/src/contracts/ExclusiveDutchOrderReactor.js.map +1 -0
- package/dist/esm/src/contracts/ExclusiveFillerValidation.d.ts +105 -0
- package/dist/esm/src/contracts/ExclusiveFillerValidation.js +2 -0
- package/dist/esm/src/contracts/ExclusiveFillerValidation.js.map +1 -0
- package/dist/esm/src/contracts/ISuperstateTokenV4.d.ts +628 -0
- package/dist/esm/src/contracts/ISuperstateTokenV4.js +2 -0
- package/dist/esm/src/contracts/ISuperstateTokenV4.js.map +1 -0
- package/dist/esm/src/contracts/MockDSTokenInterface.d.ts +62 -0
- package/dist/esm/src/contracts/MockDSTokenInterface.js +2 -0
- package/dist/esm/src/contracts/MockDSTokenInterface.js.map +1 -0
- package/dist/esm/src/contracts/MockERC20.d.ts +242 -0
- package/dist/esm/src/contracts/MockERC20.js +2 -0
- package/dist/esm/src/contracts/MockERC20.js.map +1 -0
- package/dist/esm/src/contracts/MockSuperstateTokenV4.d.ts +58 -0
- package/dist/esm/src/contracts/MockSuperstateTokenV4.js +2 -0
- package/dist/esm/src/contracts/MockSuperstateTokenV4.js.map +1 -0
- package/dist/esm/src/contracts/Multicall2.d.ts +218 -0
- package/dist/esm/src/contracts/Multicall2.js +2 -0
- package/dist/esm/src/contracts/Multicall2.js.map +1 -0
- package/dist/esm/src/contracts/OrderQuoter.d.ts +131 -0
- package/dist/esm/src/contracts/OrderQuoter.js +2 -0
- package/dist/esm/src/contracts/OrderQuoter.js.map +1 -0
- package/dist/esm/src/contracts/Permit2.d.ts +533 -0
- package/dist/esm/src/contracts/Permit2.js +2 -0
- package/dist/esm/src/contracts/Permit2.js.map +1 -0
- package/dist/esm/src/contracts/PriorityOrderReactor.d.ts +207 -0
- package/dist/esm/src/contracts/PriorityOrderReactor.js +2 -0
- package/dist/esm/src/contracts/PriorityOrderReactor.js.map +1 -0
- package/dist/esm/src/contracts/Proxy.d.ts +106 -0
- package/dist/esm/src/contracts/Proxy.js +2 -0
- package/dist/esm/src/contracts/Proxy.js.map +1 -0
- package/dist/esm/src/contracts/RelayOrderReactor.d.ts +150 -0
- package/dist/esm/src/contracts/RelayOrderReactor.js +2 -0
- package/dist/esm/src/contracts/RelayOrderReactor.js.map +1 -0
- package/dist/esm/src/contracts/SwapRouter02Executor.d.ts +240 -0
- package/dist/esm/src/contracts/SwapRouter02Executor.js +2 -0
- package/dist/esm/src/contracts/SwapRouter02Executor.js.map +1 -0
- package/dist/esm/src/contracts/V2DutchOrderReactor.d.ts +207 -0
- package/dist/esm/src/contracts/V2DutchOrderReactor.js +2 -0
- package/dist/esm/src/contracts/V2DutchOrderReactor.js.map +1 -0
- package/dist/esm/src/contracts/V3DutchOrderReactor.d.ts +207 -0
- package/dist/esm/src/contracts/V3DutchOrderReactor.js +2 -0
- package/dist/esm/src/contracts/V3DutchOrderReactor.js.map +1 -0
- package/dist/esm/src/contracts/common.d.ts +22 -0
- package/dist/esm/src/contracts/common.js +2 -0
- package/dist/esm/src/contracts/common.js.map +1 -0
- package/dist/esm/src/contracts/factories/DSTokenInterface__factory.d.ts +368 -0
- package/dist/esm/src/contracts/factories/DSTokenInterface__factory.js +502 -0
- package/dist/esm/src/contracts/factories/DSTokenInterface__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/DeploylessMulticall2__factory.d.ts +29 -0
- package/dist/esm/src/contracts/factories/DeploylessMulticall2__factory.js +44 -0
- package/dist/esm/src/contracts/factories/DeploylessMulticall2__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/DutchLimitOrderReactor__factory.d.ts +87 -0
- package/dist/esm/src/contracts/factories/DutchLimitOrderReactor__factory.js +381 -0
- package/dist/esm/src/contracts/factories/DutchLimitOrderReactor__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/DutchOrderReactor__factory.d.ts +87 -0
- package/dist/esm/src/contracts/factories/DutchOrderReactor__factory.js +381 -0
- package/dist/esm/src/contracts/factories/DutchOrderReactor__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/ERC1967Proxy__factory.d.ts +70 -0
- package/dist/esm/src/contracts/factories/ERC1967Proxy__factory.js +104 -0
- package/dist/esm/src/contracts/factories/ERC1967Proxy__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/ExclusiveDutchOrderReactor__factory.d.ts +297 -0
- package/dist/esm/src/contracts/factories/ExclusiveDutchOrderReactor__factory.js +396 -0
- package/dist/esm/src/contracts/factories/ExclusiveDutchOrderReactor__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/ExclusiveFillerValidation__factory.d.ts +115 -0
- package/dist/esm/src/contracts/factories/ExclusiveFillerValidation__factory.js +161 -0
- package/dist/esm/src/contracts/factories/ExclusiveFillerValidation__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/ISuperstateTokenV4__factory.d.ts +714 -0
- package/dist/esm/src/contracts/factories/ISuperstateTokenV4__factory.js +914 -0
- package/dist/esm/src/contracts/factories/ISuperstateTokenV4__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/MockDSTokenInterface__factory.d.ts +61 -0
- package/dist/esm/src/contracts/factories/MockDSTokenInterface__factory.js +91 -0
- package/dist/esm/src/contracts/factories/MockDSTokenInterface__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/MockERC20__factory.d.ts +301 -0
- package/dist/esm/src/contracts/factories/MockERC20__factory.js +404 -0
- package/dist/esm/src/contracts/factories/MockERC20__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/MockSuperstateTokenV4__factory.d.ts +49 -0
- package/dist/esm/src/contracts/factories/MockSuperstateTokenV4__factory.js +76 -0
- package/dist/esm/src/contracts/factories/MockSuperstateTokenV4__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/Multicall2__factory.d.ts +245 -0
- package/dist/esm/src/contracts/factories/Multicall2__factory.js +329 -0
- package/dist/esm/src/contracts/factories/Multicall2__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/OrderQuoter__factory.d.ts +215 -0
- package/dist/esm/src/contracts/factories/OrderQuoter__factory.js +291 -0
- package/dist/esm/src/contracts/factories/OrderQuoter__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/Permit2__factory.d.ts +720 -0
- package/dist/esm/src/contracts/factories/Permit2__factory.js +938 -0
- package/dist/esm/src/contracts/factories/Permit2__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/PriorityOrderReactor__factory.d.ts +293 -0
- package/dist/esm/src/contracts/factories/PriorityOrderReactor__factory.js +391 -0
- package/dist/esm/src/contracts/factories/PriorityOrderReactor__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/Proxy__factory.d.ts +88 -0
- package/dist/esm/src/contracts/factories/Proxy__factory.js +126 -0
- package/dist/esm/src/contracts/factories/Proxy__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/RelayOrderReactor__factory.d.ts +188 -0
- package/dist/esm/src/contracts/factories/RelayOrderReactor__factory.js +254 -0
- package/dist/esm/src/contracts/factories/RelayOrderReactor__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/SwapRouter02Executor__factory.d.ts +257 -0
- package/dist/esm/src/contracts/factories/SwapRouter02Executor__factory.js +344 -0
- package/dist/esm/src/contracts/factories/SwapRouter02Executor__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/V2DutchOrderReactor__factory.d.ts +297 -0
- package/dist/esm/src/contracts/factories/V2DutchOrderReactor__factory.js +396 -0
- package/dist/esm/src/contracts/factories/V2DutchOrderReactor__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/V3DutchOrderReactor__factory.d.ts +297 -0
- package/dist/esm/src/contracts/factories/V3DutchOrderReactor__factory.js +396 -0
- package/dist/esm/src/contracts/factories/V3DutchOrderReactor__factory.js.map +1 -0
- package/dist/esm/src/contracts/factories/index.d.ts +18 -0
- package/dist/esm/src/contracts/factories/index.js +22 -0
- package/dist/esm/src/contracts/factories/index.js.map +1 -0
- package/dist/esm/src/contracts/index.d.ts +37 -0
- package/dist/esm/src/contracts/index.js +20 -0
- package/dist/esm/src/contracts/index.js.map +1 -0
- package/dist/esm/src/errors.d.ts +3 -0
- package/dist/esm/src/errors.js +7 -0
- package/dist/esm/src/errors.js.map +1 -0
- package/dist/esm/src/index.d.ts +5 -0
- package/dist/esm/src/index.js +6 -0
- package/dist/esm/src/index.js.map +1 -0
- package/dist/esm/src/order/DutchOrder.d.ts +67 -0
- package/dist/esm/src/order/DutchOrder.js +286 -0
- package/dist/esm/src/order/DutchOrder.js.map +1 -0
- package/dist/esm/src/order/DutchOrder.test.d.ts +1 -0
- package/dist/esm/src/order/DutchOrder.test.js +163 -0
- package/dist/esm/src/order/DutchOrder.test.js.map +1 -0
- package/dist/esm/src/order/PriorityOrder.d.ts +121 -0
- package/dist/esm/src/order/PriorityOrder.js +390 -0
- package/dist/esm/src/order/PriorityOrder.js.map +1 -0
- package/dist/esm/src/order/PriorityOrder.test.d.ts +1 -0
- package/dist/esm/src/order/PriorityOrder.test.js +88 -0
- package/dist/esm/src/order/PriorityOrder.test.js.map +1 -0
- package/dist/esm/src/order/RelayOrder.d.ts +75 -0
- package/dist/esm/src/order/RelayOrder.js +224 -0
- package/dist/esm/src/order/RelayOrder.js.map +1 -0
- package/dist/esm/src/order/RelayOrder.test.d.ts +1 -0
- package/dist/esm/src/order/RelayOrder.test.js +71 -0
- package/dist/esm/src/order/RelayOrder.test.js.map +1 -0
- package/dist/esm/src/order/V2DutchOrder.d.ts +103 -0
- package/dist/esm/src/order/V2DutchOrder.js +384 -0
- package/dist/esm/src/order/V2DutchOrder.js.map +1 -0
- package/dist/esm/src/order/V2DutchOrder.test.d.ts +1 -0
- package/dist/esm/src/order/V2DutchOrder.test.js +270 -0
- package/dist/esm/src/order/V2DutchOrder.test.js.map +1 -0
- package/dist/esm/src/order/V3DutchOrder.d.ts +105 -0
- package/dist/esm/src/order/V3DutchOrder.js +427 -0
- package/dist/esm/src/order/V3DutchOrder.js.map +1 -0
- package/dist/esm/src/order/V3DutchOrder.test.d.ts +1 -0
- package/dist/esm/src/order/V3DutchOrder.test.js +224 -0
- package/dist/esm/src/order/V3DutchOrder.test.js.map +1 -0
- package/dist/esm/src/order/index.d.ts +14 -0
- package/dist/esm/src/order/index.js +8 -0
- package/dist/esm/src/order/index.js.map +1 -0
- package/dist/esm/src/order/types.d.ts +158 -0
- package/dist/esm/src/order/types.js +2 -0
- package/dist/esm/src/order/types.js.map +1 -0
- package/dist/esm/src/order/validation.d.ts +24 -0
- package/dist/esm/src/order/validation.js +55 -0
- package/dist/esm/src/order/validation.js.map +1 -0
- package/dist/esm/src/order/validation.test.d.ts +1 -0
- package/dist/esm/src/order/validation.test.js +56 -0
- package/dist/esm/src/order/validation.test.js.map +1 -0
- package/dist/esm/src/trade/DutchOrderTrade.d.ts +33 -0
- package/dist/esm/src/trade/DutchOrderTrade.js +77 -0
- package/dist/esm/src/trade/DutchOrderTrade.js.map +1 -0
- package/dist/esm/src/trade/DutchOrderTrade.test.d.ts +1 -0
- package/dist/esm/src/trade/DutchOrderTrade.test.js +91 -0
- package/dist/esm/src/trade/DutchOrderTrade.test.js.map +1 -0
- package/dist/esm/src/trade/PriorityOrderTrade.d.ts +43 -0
- package/dist/esm/src/trade/PriorityOrderTrade.js +97 -0
- package/dist/esm/src/trade/PriorityOrderTrade.js.map +1 -0
- package/dist/esm/src/trade/PriorityOrderTrade.test.d.ts +1 -0
- package/dist/esm/src/trade/PriorityOrderTrade.test.js +104 -0
- package/dist/esm/src/trade/PriorityOrderTrade.test.js.map +1 -0
- package/dist/esm/src/trade/RelayOrderTrade.d.ts +34 -0
- package/dist/esm/src/trade/RelayOrderTrade.js +83 -0
- package/dist/esm/src/trade/RelayOrderTrade.js.map +1 -0
- package/dist/esm/src/trade/RelayOrderTrade.test.d.ts +1 -0
- package/dist/esm/src/trade/RelayOrderTrade.test.js +101 -0
- package/dist/esm/src/trade/RelayOrderTrade.test.js.map +1 -0
- package/dist/esm/src/trade/V2DutchOrderTrade.d.ts +33 -0
- package/dist/esm/src/trade/V2DutchOrderTrade.js +77 -0
- package/dist/esm/src/trade/V2DutchOrderTrade.js.map +1 -0
- package/dist/esm/src/trade/V2DutchOrderTrade.test.d.ts +1 -0
- package/dist/esm/src/trade/V2DutchOrderTrade.test.js +88 -0
- package/dist/esm/src/trade/V2DutchOrderTrade.test.js.map +1 -0
- package/dist/esm/src/trade/V3DutchOrderTrade.d.ts +41 -0
- package/dist/esm/src/trade/V3DutchOrderTrade.js +87 -0
- package/dist/esm/src/trade/V3DutchOrderTrade.js.map +1 -0
- package/dist/esm/src/trade/V3DutchOrderTrade.test.d.ts +1 -0
- package/dist/esm/src/trade/V3DutchOrderTrade.test.js +220 -0
- package/dist/esm/src/trade/V3DutchOrderTrade.test.js.map +1 -0
- package/dist/esm/src/trade/index.d.ts +5 -0
- package/dist/esm/src/trade/index.js +6 -0
- package/dist/esm/src/trade/index.js.map +1 -0
- package/dist/esm/src/trade/utils.d.ts +8 -0
- package/dist/esm/src/trade/utils.js +31 -0
- package/dist/esm/src/trade/utils.js.map +1 -0
- package/dist/esm/src/utils/EventWatcher.d.ts +46 -0
- package/dist/esm/src/utils/EventWatcher.js +114 -0
- package/dist/esm/src/utils/EventWatcher.js.map +1 -0
- package/dist/esm/src/utils/NonceManager.d.ts +36 -0
- package/dist/esm/src/utils/NonceManager.js +124 -0
- package/dist/esm/src/utils/NonceManager.js.map +1 -0
- package/dist/esm/src/utils/NonceManager.test.d.ts +1 -0
- package/dist/esm/src/utils/NonceManager.test.js +129 -0
- package/dist/esm/src/utils/NonceManager.test.js.map +1 -0
- package/dist/esm/src/utils/OrderQuoter.d.ts +79 -0
- package/dist/esm/src/utils/OrderQuoter.js +313 -0
- package/dist/esm/src/utils/OrderQuoter.js.map +1 -0
- package/dist/esm/src/utils/OrderValidator.d.ts +12 -0
- package/dist/esm/src/utils/OrderValidator.js +42 -0
- package/dist/esm/src/utils/OrderValidator.js.map +1 -0
- package/dist/esm/src/utils/PermissionedTokenValidator.d.ts +23 -0
- package/dist/esm/src/utils/PermissionedTokenValidator.js +65 -0
- package/dist/esm/src/utils/PermissionedTokenValidator.js.map +1 -0
- package/dist/esm/src/utils/dutchBlockDecay.d.ts +15 -0
- package/dist/esm/src/utils/dutchBlockDecay.js +68 -0
- package/dist/esm/src/utils/dutchBlockDecay.js.map +1 -0
- package/dist/esm/src/utils/dutchBlockDecay.test.d.ts +1 -0
- package/dist/esm/src/utils/dutchBlockDecay.test.js +92 -0
- package/dist/esm/src/utils/dutchBlockDecay.test.js.map +1 -0
- package/dist/esm/src/utils/dutchDecay.d.ts +8 -0
- package/dist/esm/src/utils/dutchDecay.js +28 -0
- package/dist/esm/src/utils/dutchDecay.js.map +1 -0
- package/dist/esm/src/utils/dutchDecay.test.d.ts +1 -0
- package/dist/esm/src/utils/dutchDecay.test.js +59 -0
- package/dist/esm/src/utils/dutchDecay.test.js.map +1 -0
- package/dist/esm/src/utils/index.d.ts +12 -0
- package/dist/esm/src/utils/index.js +44 -0
- package/dist/esm/src/utils/index.js.map +1 -0
- package/dist/esm/src/utils/multicall.d.ts +36 -0
- package/dist/esm/src/utils/multicall.js +85 -0
- package/dist/esm/src/utils/multicall.js.map +1 -0
- package/dist/esm/src/utils/order.d.ts +42 -0
- package/dist/esm/src/utils/order.js +129 -0
- package/dist/esm/src/utils/order.js.map +1 -0
- package/dist/esm/src/utils/order.test.d.ts +1 -0
- package/dist/esm/src/utils/order.test.js +338 -0
- package/dist/esm/src/utils/order.test.js.map +1 -0
- package/dist/types/src/builder/DutchOrderBuilder.d.ts +25 -0
- package/dist/types/src/builder/DutchOrderBuilder.test.d.ts +1 -0
- package/dist/types/src/builder/OrderBuilder.d.ts +17 -0
- package/dist/types/src/builder/PriorityOrderBuilder.d.ts +29 -0
- package/dist/types/src/builder/PriorityOrderBuilder.test.d.ts +1 -0
- package/dist/types/src/builder/RelayOrderBuilder.d.ts +22 -0
- package/dist/types/src/builder/RelayOrderBuilder.test.d.ts +1 -0
- package/dist/types/src/builder/V2DutchOrderBuilder.d.ts +33 -0
- package/dist/types/src/builder/V2DutchOrderBuilder.test.d.ts +1 -0
- package/dist/types/src/builder/V3DutchOrderBuilder.d.ts +36 -0
- package/dist/types/src/builder/V3DutchOrderBuilder.test.d.ts +1 -0
- package/dist/types/src/builder/index.d.ts +6 -0
- package/dist/types/src/constants.d.ts +58 -0
- package/dist/types/src/constants.test.d.ts +1 -0
- package/dist/types/src/contracts/DSTokenInterface.d.ts +372 -0
- package/dist/types/src/contracts/DeploylessMulticall2.d.ts +37 -0
- package/dist/types/src/contracts/DutchLimitOrderReactor.d.ts +191 -0
- package/dist/types/src/contracts/DutchOrderReactor.d.ts +191 -0
- package/dist/types/src/contracts/ERC1967Proxy.d.ts +39 -0
- package/dist/types/src/contracts/ExclusiveDutchOrderReactor.d.ts +207 -0
- package/dist/types/src/contracts/ExclusiveFillerValidation.d.ts +105 -0
- package/dist/types/src/contracts/ISuperstateTokenV4.d.ts +628 -0
- package/dist/types/src/contracts/MockDSTokenInterface.d.ts +62 -0
- package/dist/types/src/contracts/MockERC20.d.ts +242 -0
- package/dist/types/src/contracts/MockSuperstateTokenV4.d.ts +58 -0
- package/dist/types/src/contracts/Multicall2.d.ts +218 -0
- package/dist/types/src/contracts/OrderQuoter.d.ts +131 -0
- package/dist/types/src/contracts/Permit2.d.ts +533 -0
- package/dist/types/src/contracts/PriorityOrderReactor.d.ts +207 -0
- package/dist/types/src/contracts/Proxy.d.ts +106 -0
- package/dist/types/src/contracts/RelayOrderReactor.d.ts +150 -0
- package/dist/types/src/contracts/SwapRouter02Executor.d.ts +240 -0
- package/dist/types/src/contracts/V2DutchOrderReactor.d.ts +207 -0
- package/dist/types/src/contracts/V3DutchOrderReactor.d.ts +207 -0
- package/dist/types/src/contracts/common.d.ts +22 -0
- package/dist/types/src/contracts/factories/DSTokenInterface__factory.d.ts +368 -0
- package/dist/types/src/contracts/factories/DeploylessMulticall2__factory.d.ts +29 -0
- package/dist/types/src/contracts/factories/DutchLimitOrderReactor__factory.d.ts +87 -0
- package/dist/types/src/contracts/factories/DutchOrderReactor__factory.d.ts +87 -0
- package/dist/types/src/contracts/factories/ERC1967Proxy__factory.d.ts +70 -0
- package/dist/types/src/contracts/factories/ExclusiveDutchOrderReactor__factory.d.ts +297 -0
- package/dist/types/src/contracts/factories/ExclusiveFillerValidation__factory.d.ts +115 -0
- package/dist/types/src/contracts/factories/ISuperstateTokenV4__factory.d.ts +714 -0
- package/dist/types/src/contracts/factories/MockDSTokenInterface__factory.d.ts +61 -0
- package/dist/types/src/contracts/factories/MockERC20__factory.d.ts +301 -0
- package/dist/types/src/contracts/factories/MockSuperstateTokenV4__factory.d.ts +49 -0
- package/dist/types/src/contracts/factories/Multicall2__factory.d.ts +245 -0
- package/dist/types/src/contracts/factories/OrderQuoter__factory.d.ts +215 -0
- package/dist/types/src/contracts/factories/Permit2__factory.d.ts +720 -0
- package/dist/types/src/contracts/factories/PriorityOrderReactor__factory.d.ts +293 -0
- package/dist/types/src/contracts/factories/Proxy__factory.d.ts +88 -0
- package/dist/types/src/contracts/factories/RelayOrderReactor__factory.d.ts +188 -0
- package/dist/types/src/contracts/factories/SwapRouter02Executor__factory.d.ts +257 -0
- package/dist/types/src/contracts/factories/V2DutchOrderReactor__factory.d.ts +297 -0
- package/dist/types/src/contracts/factories/V3DutchOrderReactor__factory.d.ts +297 -0
- package/dist/types/src/contracts/factories/index.d.ts +18 -0
- package/dist/types/src/contracts/index.d.ts +37 -0
- package/dist/types/src/errors.d.ts +3 -0
- package/dist/types/src/index.d.ts +5 -0
- package/dist/types/src/order/DutchOrder.d.ts +67 -0
- package/dist/types/src/order/DutchOrder.test.d.ts +1 -0
- package/dist/types/src/order/PriorityOrder.d.ts +121 -0
- package/dist/types/src/order/PriorityOrder.test.d.ts +1 -0
- package/dist/types/src/order/RelayOrder.d.ts +75 -0
- package/dist/types/src/order/RelayOrder.test.d.ts +1 -0
- package/dist/types/src/order/V2DutchOrder.d.ts +103 -0
- package/dist/types/src/order/V2DutchOrder.test.d.ts +1 -0
- package/dist/types/src/order/V3DutchOrder.d.ts +105 -0
- package/dist/types/src/order/V3DutchOrder.test.d.ts +1 -0
- package/dist/types/src/order/index.d.ts +14 -0
- package/dist/types/src/order/types.d.ts +158 -0
- package/dist/types/src/order/validation.d.ts +24 -0
- package/dist/types/src/order/validation.test.d.ts +1 -0
- package/dist/types/src/trade/DutchOrderTrade.d.ts +33 -0
- package/dist/types/src/trade/DutchOrderTrade.test.d.ts +1 -0
- package/dist/types/src/trade/PriorityOrderTrade.d.ts +43 -0
- package/dist/types/src/trade/PriorityOrderTrade.test.d.ts +1 -0
- package/dist/types/src/trade/RelayOrderTrade.d.ts +34 -0
- package/dist/types/src/trade/RelayOrderTrade.test.d.ts +1 -0
- package/dist/types/src/trade/V2DutchOrderTrade.d.ts +33 -0
- package/dist/types/src/trade/V2DutchOrderTrade.test.d.ts +1 -0
- package/dist/types/src/trade/V3DutchOrderTrade.d.ts +41 -0
- package/dist/types/src/trade/V3DutchOrderTrade.test.d.ts +1 -0
- package/dist/types/src/trade/index.d.ts +5 -0
- package/dist/types/src/trade/utils.d.ts +8 -0
- package/dist/types/src/utils/EventWatcher.d.ts +46 -0
- package/dist/types/src/utils/NonceManager.d.ts +36 -0
- package/dist/types/src/utils/NonceManager.test.d.ts +1 -0
- package/dist/types/src/utils/OrderQuoter.d.ts +79 -0
- package/dist/types/src/utils/OrderValidator.d.ts +12 -0
- package/dist/types/src/utils/PermissionedTokenValidator.d.ts +23 -0
- package/dist/types/src/utils/dutchBlockDecay.d.ts +15 -0
- package/dist/types/src/utils/dutchBlockDecay.test.d.ts +1 -0
- package/dist/types/src/utils/dutchDecay.d.ts +8 -0
- package/dist/types/src/utils/dutchDecay.test.d.ts +1 -0
- package/dist/types/src/utils/index.d.ts +12 -0
- package/dist/types/src/utils/multicall.d.ts +36 -0
- package/dist/types/src/utils/order.d.ts +42 -0
- package/dist/types/src/utils/order.test.d.ts +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const sdk_core_1 = require("@juiceswapxyz/sdk-core");
|
|
4
|
+
const ethers_1 = require("ethers");
|
|
5
|
+
const V3DutchOrderTrade_1 = require("./V3DutchOrderTrade");
|
|
6
|
+
const utils_1 = require("./utils");
|
|
7
|
+
const USDC = new sdk_core_1.Token(1, "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48", 6, "USDC");
|
|
8
|
+
const DAI = new sdk_core_1.Token(1, "0x6B175474E89094C44Da98b954EedeAC495271d0F", 18, "DAI");
|
|
9
|
+
describe("V3DutchOrderTrade", () => {
|
|
10
|
+
const NON_FEE_OUTPUT_AMOUNT = ethers_1.BigNumber.from("1000000000000000000");
|
|
11
|
+
const NON_FEE_MINIMUM_AMOUNT_OUT = ethers_1.BigNumber.from("900000000000000000");
|
|
12
|
+
const orderInfo = {
|
|
13
|
+
deadline: Math.floor(new Date().getTime() / 1000) + 1000,
|
|
14
|
+
reactor: "0x0000000000000000000000000000000000000000",
|
|
15
|
+
swapper: "0x0000000000000000000000000000000000000000",
|
|
16
|
+
nonce: ethers_1.BigNumber.from(10),
|
|
17
|
+
cosigner: "0x0000000000000000000000000000000000000000",
|
|
18
|
+
startingBaseFee: ethers_1.BigNumber.from(0),
|
|
19
|
+
additionalValidationContract: ethers_1.ethers.constants.AddressZero,
|
|
20
|
+
additionalValidationData: "0x",
|
|
21
|
+
input: {
|
|
22
|
+
token: USDC.address,
|
|
23
|
+
startAmount: ethers_1.BigNumber.from(1000),
|
|
24
|
+
curve: {
|
|
25
|
+
relativeBlocks: [],
|
|
26
|
+
relativeAmounts: [],
|
|
27
|
+
},
|
|
28
|
+
maxAmount: ethers_1.BigNumber.from(1000),
|
|
29
|
+
adjustmentPerGweiBaseFee: ethers_1.BigNumber.from(0),
|
|
30
|
+
},
|
|
31
|
+
outputs: [
|
|
32
|
+
{
|
|
33
|
+
token: DAI.address,
|
|
34
|
+
startAmount: NON_FEE_OUTPUT_AMOUNT,
|
|
35
|
+
curve: {
|
|
36
|
+
relativeBlocks: [21],
|
|
37
|
+
relativeAmounts: [BigInt("100000000000000000")],
|
|
38
|
+
},
|
|
39
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
40
|
+
minAmount: NON_FEE_MINIMUM_AMOUNT_OUT,
|
|
41
|
+
adjustmentPerGweiBaseFee: ethers_1.BigNumber.from(0),
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
token: DAI.address,
|
|
45
|
+
startAmount: ethers_1.BigNumber.from("1000"),
|
|
46
|
+
curve: {
|
|
47
|
+
relativeBlocks: [21],
|
|
48
|
+
relativeAmounts: [BigInt("100")],
|
|
49
|
+
},
|
|
50
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
51
|
+
minAmount: ethers_1.BigNumber.from("900"),
|
|
52
|
+
adjustmentPerGweiBaseFee: ethers_1.BigNumber.from(0),
|
|
53
|
+
},
|
|
54
|
+
],
|
|
55
|
+
};
|
|
56
|
+
const trade = new V3DutchOrderTrade_1.V3DutchOrderTrade({
|
|
57
|
+
currencyIn: USDC,
|
|
58
|
+
currenciesOut: [DAI],
|
|
59
|
+
orderInfo,
|
|
60
|
+
tradeType: sdk_core_1.TradeType.EXACT_INPUT,
|
|
61
|
+
});
|
|
62
|
+
describe("Exact input", () => {
|
|
63
|
+
it("returns the right input amount for an exact-in trade", () => {
|
|
64
|
+
expect(trade.inputAmount.quotient.toString()).toEqual(orderInfo.input.startAmount.toString());
|
|
65
|
+
});
|
|
66
|
+
it("returns the correct non-fee output amount", () => {
|
|
67
|
+
expect(trade.outputAmount.quotient.toString()).toEqual(NON_FEE_OUTPUT_AMOUNT.toString());
|
|
68
|
+
});
|
|
69
|
+
it("returns the correct minimum amount out", () => {
|
|
70
|
+
expect(trade.minimumAmountOut().quotient.toString()).toEqual(NON_FEE_MINIMUM_AMOUNT_OUT.toString());
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
describe("Exact output", () => {
|
|
74
|
+
const outOrderInfo = {
|
|
75
|
+
deadline: Math.floor(new Date().getTime() / 1000) + 1000,
|
|
76
|
+
reactor: "0x0000000000000000000000000000000000000000",
|
|
77
|
+
swapper: "0x0000000000000000000000000000000000000000",
|
|
78
|
+
nonce: ethers_1.BigNumber.from(10),
|
|
79
|
+
cosigner: "0x0000000000000000000000000000000000000000",
|
|
80
|
+
startingBaseFee: ethers_1.BigNumber.from(0),
|
|
81
|
+
additionalValidationContract: ethers_1.ethers.constants.AddressZero,
|
|
82
|
+
additionalValidationData: "0x",
|
|
83
|
+
input: {
|
|
84
|
+
token: USDC.address,
|
|
85
|
+
startAmount: ethers_1.BigNumber.from(1000),
|
|
86
|
+
curve: {
|
|
87
|
+
relativeBlocks: [10],
|
|
88
|
+
relativeAmounts: [BigInt(-100)],
|
|
89
|
+
},
|
|
90
|
+
maxAmount: ethers_1.BigNumber.from(1100),
|
|
91
|
+
adjustmentPerGweiBaseFee: ethers_1.BigNumber.from(0),
|
|
92
|
+
},
|
|
93
|
+
outputs: [
|
|
94
|
+
{
|
|
95
|
+
token: DAI.address,
|
|
96
|
+
startAmount: NON_FEE_OUTPUT_AMOUNT,
|
|
97
|
+
curve: {
|
|
98
|
+
relativeBlocks: [],
|
|
99
|
+
relativeAmounts: [],
|
|
100
|
+
},
|
|
101
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
102
|
+
minAmount: NON_FEE_OUTPUT_AMOUNT,
|
|
103
|
+
adjustmentPerGweiBaseFee: ethers_1.BigNumber.from(0),
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
token: DAI.address,
|
|
107
|
+
startAmount: ethers_1.BigNumber.from("1000"),
|
|
108
|
+
curve: {
|
|
109
|
+
relativeBlocks: [],
|
|
110
|
+
relativeAmounts: [],
|
|
111
|
+
},
|
|
112
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
113
|
+
minAmount: ethers_1.BigNumber.from("1000"),
|
|
114
|
+
adjustmentPerGweiBaseFee: ethers_1.BigNumber.from(0),
|
|
115
|
+
},
|
|
116
|
+
],
|
|
117
|
+
};
|
|
118
|
+
const trade = new V3DutchOrderTrade_1.V3DutchOrderTrade({
|
|
119
|
+
currencyIn: USDC,
|
|
120
|
+
currenciesOut: [DAI],
|
|
121
|
+
orderInfo: outOrderInfo,
|
|
122
|
+
tradeType: sdk_core_1.TradeType.EXACT_OUTPUT,
|
|
123
|
+
});
|
|
124
|
+
it("returns the correct maximum amount in", () => {
|
|
125
|
+
expect(trade.maximumAmountIn().quotient.toString()).toEqual(outOrderInfo.input.maxAmount.toString());
|
|
126
|
+
});
|
|
127
|
+
});
|
|
128
|
+
describe("Qualitative tests", () => {
|
|
129
|
+
it("works for native output trades", () => {
|
|
130
|
+
const ethOutputOrderInfo = Object.assign(Object.assign({}, orderInfo), { outputs: [
|
|
131
|
+
{
|
|
132
|
+
token: utils_1.NativeAssets.ETH,
|
|
133
|
+
startAmount: NON_FEE_OUTPUT_AMOUNT,
|
|
134
|
+
curve: {
|
|
135
|
+
relativeBlocks: [21],
|
|
136
|
+
relativeAmounts: [BigInt("100000000000000000")],
|
|
137
|
+
},
|
|
138
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
139
|
+
minAmount: NON_FEE_MINIMUM_AMOUNT_OUT,
|
|
140
|
+
adjustmentPerGweiBaseFee: ethers_1.BigNumber.from(0),
|
|
141
|
+
},
|
|
142
|
+
] });
|
|
143
|
+
const ethOutputTrade = new V3DutchOrderTrade_1.V3DutchOrderTrade({
|
|
144
|
+
currencyIn: USDC,
|
|
145
|
+
currenciesOut: [sdk_core_1.Ether.onChain(1)],
|
|
146
|
+
orderInfo: ethOutputOrderInfo,
|
|
147
|
+
tradeType: sdk_core_1.TradeType.EXACT_INPUT,
|
|
148
|
+
});
|
|
149
|
+
expect(ethOutputTrade.outputAmount.currency).toEqual(sdk_core_1.Ether.onChain(1));
|
|
150
|
+
});
|
|
151
|
+
it("works for native output trades where order info has 0 address", () => {
|
|
152
|
+
const ethOutputOrderInfo = Object.assign(Object.assign({}, orderInfo), { outputs: [
|
|
153
|
+
{
|
|
154
|
+
token: ethers_1.constants.AddressZero,
|
|
155
|
+
startAmount: NON_FEE_OUTPUT_AMOUNT,
|
|
156
|
+
curve: {
|
|
157
|
+
relativeBlocks: [21],
|
|
158
|
+
relativeAmounts: [BigInt("100000000000000000")],
|
|
159
|
+
},
|
|
160
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
161
|
+
minAmount: NON_FEE_MINIMUM_AMOUNT_OUT,
|
|
162
|
+
adjustmentPerGweiBaseFee: ethers_1.BigNumber.from(0),
|
|
163
|
+
},
|
|
164
|
+
] });
|
|
165
|
+
const ethOutputTrade = new V3DutchOrderTrade_1.V3DutchOrderTrade({
|
|
166
|
+
currencyIn: USDC,
|
|
167
|
+
currenciesOut: [sdk_core_1.Ether.onChain(1)],
|
|
168
|
+
orderInfo: ethOutputOrderInfo,
|
|
169
|
+
tradeType: sdk_core_1.TradeType.EXACT_INPUT,
|
|
170
|
+
});
|
|
171
|
+
expect(ethOutputTrade.outputAmount.currency).toEqual(sdk_core_1.Ether.onChain(1));
|
|
172
|
+
});
|
|
173
|
+
});
|
|
174
|
+
describe("Expected amounts", () => {
|
|
175
|
+
const expectedAmounts = {
|
|
176
|
+
expectedAmountIn: "800",
|
|
177
|
+
expectedAmountOut: "900",
|
|
178
|
+
};
|
|
179
|
+
const tradeWithExpectedAmounts = new V3DutchOrderTrade_1.V3DutchOrderTrade({
|
|
180
|
+
currencyIn: USDC,
|
|
181
|
+
currenciesOut: [DAI],
|
|
182
|
+
orderInfo,
|
|
183
|
+
tradeType: sdk_core_1.TradeType.EXACT_INPUT,
|
|
184
|
+
expectedAmounts,
|
|
185
|
+
});
|
|
186
|
+
it("uses expectedAmountIn when provided", () => {
|
|
187
|
+
expect(tradeWithExpectedAmounts.inputAmount.quotient.toString()).toEqual(expectedAmounts.expectedAmountIn);
|
|
188
|
+
});
|
|
189
|
+
it("uses expectedAmountOut when provided", () => {
|
|
190
|
+
expect(tradeWithExpectedAmounts.outputAmount.quotient.toString()).toEqual(expectedAmounts.expectedAmountOut);
|
|
191
|
+
});
|
|
192
|
+
it("falls back to order amounts when expectedAmounts is not provided", () => {
|
|
193
|
+
expect(trade.inputAmount.quotient.toString()).toEqual(orderInfo.input.startAmount.toString());
|
|
194
|
+
expect(trade.outputAmount.quotient.toString()).toEqual(NON_FEE_OUTPUT_AMOUNT.toString());
|
|
195
|
+
});
|
|
196
|
+
it("throws when accessing expectedAmountIn that wasn't provided", () => {
|
|
197
|
+
const tradeWithoutExpected = new V3DutchOrderTrade_1.V3DutchOrderTrade({
|
|
198
|
+
currencyIn: USDC,
|
|
199
|
+
currenciesOut: [DAI],
|
|
200
|
+
orderInfo,
|
|
201
|
+
tradeType: sdk_core_1.TradeType.EXACT_INPUT,
|
|
202
|
+
});
|
|
203
|
+
// Using private method through any to test error case
|
|
204
|
+
expect(() => {
|
|
205
|
+
tradeWithoutExpected.getExpectedAmountIn();
|
|
206
|
+
}).toThrow("expectedAmountIn not set");
|
|
207
|
+
});
|
|
208
|
+
it("throws when accessing expectedAmountOut that wasn't provided", () => {
|
|
209
|
+
const tradeWithoutExpected = new V3DutchOrderTrade_1.V3DutchOrderTrade({
|
|
210
|
+
currencyIn: USDC,
|
|
211
|
+
currenciesOut: [DAI],
|
|
212
|
+
orderInfo,
|
|
213
|
+
tradeType: sdk_core_1.TradeType.EXACT_INPUT,
|
|
214
|
+
});
|
|
215
|
+
// Using private method through any to test error case
|
|
216
|
+
expect(() => {
|
|
217
|
+
tradeWithoutExpected.getExpectedAmountOut();
|
|
218
|
+
}).toThrow("expectedAmountOut not set");
|
|
219
|
+
});
|
|
220
|
+
});
|
|
221
|
+
});
|
|
222
|
+
//# sourceMappingURL=V3DutchOrderTrade.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"V3DutchOrderTrade.test.js","sourceRoot":"","sources":["../../../../src/trade/V3DutchOrderTrade.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
tslib_1.__exportStar(require("./DutchOrderTrade"), exports);
|
|
5
|
+
tslib_1.__exportStar(require("./V2DutchOrderTrade"), exports);
|
|
6
|
+
tslib_1.__exportStar(require("./PriorityOrderTrade"), exports);
|
|
7
|
+
tslib_1.__exportStar(require("./RelayOrderTrade"), exports);
|
|
8
|
+
tslib_1.__exportStar(require("./V3DutchOrderTrade"), exports);
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/trade/index.ts"],"names":[],"mappings":";;;AAAA,4DAAkC;AAClC,8DAAoC;AACpC,+DAAqC;AACrC,4DAAkC;AAClC,8DAAoC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Currency } from "@juiceswapxyz/sdk-core";
|
|
2
|
+
export declare enum NativeAssets {
|
|
3
|
+
MATIC = "MATIC",
|
|
4
|
+
BNB = "BNB",
|
|
5
|
+
AVAX = "AVAX",
|
|
6
|
+
ETH = "ETH"
|
|
7
|
+
}
|
|
8
|
+
export declare function areCurrenciesEqual(currency: Currency, address: string | null, chainId: number): boolean;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.areCurrenciesEqual = exports.NativeAssets = void 0;
|
|
4
|
+
const sdk_core_1 = require("@juiceswapxyz/sdk-core");
|
|
5
|
+
const ethers_1 = require("ethers");
|
|
6
|
+
var NativeAssets;
|
|
7
|
+
(function (NativeAssets) {
|
|
8
|
+
NativeAssets["MATIC"] = "MATIC";
|
|
9
|
+
NativeAssets["BNB"] = "BNB";
|
|
10
|
+
NativeAssets["AVAX"] = "AVAX";
|
|
11
|
+
NativeAssets["ETH"] = "ETH";
|
|
12
|
+
})(NativeAssets = exports.NativeAssets || (exports.NativeAssets = {}));
|
|
13
|
+
function nativeCurrencyAddressString(chainId) {
|
|
14
|
+
switch (chainId) {
|
|
15
|
+
case sdk_core_1.ChainId.POLYGON:
|
|
16
|
+
return NativeAssets.MATIC;
|
|
17
|
+
case sdk_core_1.ChainId.BNB:
|
|
18
|
+
return NativeAssets.BNB;
|
|
19
|
+
case sdk_core_1.ChainId.AVALANCHE:
|
|
20
|
+
return NativeAssets.AVAX;
|
|
21
|
+
default:
|
|
22
|
+
return NativeAssets.ETH;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
function areCurrenciesEqual(currency, address, chainId) {
|
|
26
|
+
if (currency.chainId !== chainId)
|
|
27
|
+
return false;
|
|
28
|
+
if (currency.isNative) {
|
|
29
|
+
return (address === ethers_1.constants.AddressZero ||
|
|
30
|
+
address === nativeCurrencyAddressString(chainId));
|
|
31
|
+
}
|
|
32
|
+
return currency.address.toLowerCase() === (address === null || address === void 0 ? void 0 : address.toLowerCase());
|
|
33
|
+
}
|
|
34
|
+
exports.areCurrenciesEqual = areCurrenciesEqual;
|
|
35
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/trade/utils.ts"],"names":[],"mappings":";;;AAAA,qDAA2D;AAC3D,mCAAmC;AAEnC,IAAY,YAKX;AALD,WAAY,YAAY;IACtB,+BAAe,CAAA;IACf,2BAAW,CAAA;IACX,6BAAa,CAAA;IACb,2BAAW,CAAA;AACb,CAAC,EALW,YAAY,GAAZ,oBAAY,KAAZ,oBAAY,QAKvB;AAED,SAAS,2BAA2B,CAAC,OAAe;IAClD,QAAQ,OAAO,EAAE;QACf,KAAK,kBAAO,CAAC,OAAO;YAClB,OAAO,YAAY,CAAC,KAAK,CAAC;QAC5B,KAAK,kBAAO,CAAC,GAAG;YACd,OAAO,YAAY,CAAC,GAAG,CAAC;QAC1B,KAAK,kBAAO,CAAC,SAAS;YACpB,OAAO,YAAY,CAAC,IAAI,CAAC;QAC3B;YACE,OAAO,YAAY,CAAC,GAAG,CAAC;KAC3B;AACH,CAAC;AAED,SAAgB,kBAAkB,CAChC,QAAkB,EAClB,OAAsB,EACtB,OAAe;IAEf,IAAI,QAAQ,CAAC,OAAO,KAAK,OAAO;QAAE,OAAO,KAAK,CAAC;IAE/C,IAAI,QAAQ,CAAC,QAAQ,EAAE;QACrB,OAAO,CACL,OAAO,KAAK,kBAAS,CAAC,WAAW;YACjC,OAAO,KAAK,2BAA2B,CAAC,OAAO,CAAC,CACjD,CAAC;KACH;IAED,OAAO,QAAQ,CAAC,OAAO,CAAC,WAAW,EAAE,MAAK,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,WAAW,EAAE,CAAA,CAAC;AACnE,CAAC;AAfD,gDAeC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { BaseProvider, Log } from "@ethersproject/providers";
|
|
2
|
+
import { BaseContract, BigNumber, Event } from "ethers";
|
|
3
|
+
import { ExclusiveDutchOrderReactor, RelayOrderReactor } from "../contracts";
|
|
4
|
+
import { FillEvent } from "../contracts/DutchOrderReactor";
|
|
5
|
+
export type TokenTransfer = {
|
|
6
|
+
token: string;
|
|
7
|
+
amount: BigNumber;
|
|
8
|
+
};
|
|
9
|
+
export interface FillData {
|
|
10
|
+
orderHash: string;
|
|
11
|
+
filler: string;
|
|
12
|
+
nonce: BigNumber;
|
|
13
|
+
swapper: string;
|
|
14
|
+
}
|
|
15
|
+
export interface FillInfo extends FillData {
|
|
16
|
+
blockNumber: number;
|
|
17
|
+
txHash: string;
|
|
18
|
+
inputs: TokenTransfer[];
|
|
19
|
+
outputs: TokenTransfer[];
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Helper for watching events
|
|
23
|
+
*/
|
|
24
|
+
declare abstract class EventWatcher<TReactor extends BaseContract> {
|
|
25
|
+
protected reactor: TReactor;
|
|
26
|
+
constructor(reactor: TReactor);
|
|
27
|
+
abstract getFillLogs(fromBlock: number, toBlock?: number): Promise<FillEvent[]>;
|
|
28
|
+
abstract onFill(callback: (fillData: FillData, event: Event) => void): void;
|
|
29
|
+
getFillEvents(fromBlock: number, toBlock?: number): Promise<FillData[]>;
|
|
30
|
+
getFillInfo(fromBlock: number, toBlock?: number): Promise<FillInfo[]>;
|
|
31
|
+
getTokenTransfers(logs: Log[], recipient: string): {
|
|
32
|
+
token: string;
|
|
33
|
+
amount: BigNumber;
|
|
34
|
+
}[];
|
|
35
|
+
}
|
|
36
|
+
export declare class UniswapXEventWatcher extends EventWatcher<ExclusiveDutchOrderReactor> {
|
|
37
|
+
constructor(provider: BaseProvider, reactorAddress: string);
|
|
38
|
+
getFillLogs(fromBlock: number, toBlock?: number): Promise<FillEvent[]>;
|
|
39
|
+
onFill(callback: (fillData: FillData, event: Event) => void): void;
|
|
40
|
+
}
|
|
41
|
+
export declare class RelayEventWatcher extends EventWatcher<RelayOrderReactor> {
|
|
42
|
+
constructor(provider: BaseProvider, reactorAddress: string);
|
|
43
|
+
getFillLogs(fromBlock: number, toBlock?: number): Promise<FillEvent[]>;
|
|
44
|
+
onFill(callback: (fillData: FillData, event: Event) => void): void;
|
|
45
|
+
}
|
|
46
|
+
export {};
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RelayEventWatcher = exports.UniswapXEventWatcher = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const ethers_1 = require("ethers");
|
|
6
|
+
const MockERC20_json_1 = tslib_1.__importDefault(require("../../abis/MockERC20.json"));
|
|
7
|
+
const contracts_1 = require("../contracts");
|
|
8
|
+
const TRANSFER = "Transfer";
|
|
9
|
+
/**
|
|
10
|
+
* Helper for watching events
|
|
11
|
+
*/
|
|
12
|
+
class EventWatcher {
|
|
13
|
+
constructor(reactor) {
|
|
14
|
+
this.reactor = reactor;
|
|
15
|
+
}
|
|
16
|
+
getFillEvents(fromBlock, toBlock) {
|
|
17
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
18
|
+
const logs = yield this.getFillLogs(fromBlock, toBlock);
|
|
19
|
+
return logs.map((log) => log.args);
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
getFillInfo(fromBlock, toBlock) {
|
|
23
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
24
|
+
const logs = yield this.getFillLogs(fromBlock, toBlock);
|
|
25
|
+
const events = logs.map((log) => log.args);
|
|
26
|
+
// TODO: deal with batch fills for orders with the same swapper and outToken
|
|
27
|
+
const txs = logs.reduce((acc, log) => acc.add(this.reactor.provider.getTransactionReceipt(log.transactionHash)), new Set());
|
|
28
|
+
const txReceipts = yield Promise.all(txs);
|
|
29
|
+
const fills = events.map((e, i) => {
|
|
30
|
+
return {
|
|
31
|
+
orderHash: e.orderHash,
|
|
32
|
+
swapper: e.swapper,
|
|
33
|
+
filler: e.filler,
|
|
34
|
+
nonce: e.nonce,
|
|
35
|
+
txLogs: txReceipts[i].logs,
|
|
36
|
+
blockNumber: txReceipts[i].blockNumber,
|
|
37
|
+
txHash: txReceipts[i].transactionHash,
|
|
38
|
+
};
|
|
39
|
+
});
|
|
40
|
+
return fills.map((fill) => {
|
|
41
|
+
const outputs = this.getTokenTransfers(fill.txLogs, fill.swapper);
|
|
42
|
+
const inputs = this.getTokenTransfers(fill.txLogs, fill.filler);
|
|
43
|
+
return {
|
|
44
|
+
orderHash: fill.orderHash,
|
|
45
|
+
swapper: fill.swapper,
|
|
46
|
+
filler: fill.filler,
|
|
47
|
+
nonce: fill.nonce,
|
|
48
|
+
blockNumber: fill.blockNumber,
|
|
49
|
+
txHash: fill.txHash,
|
|
50
|
+
inputs: inputs,
|
|
51
|
+
outputs: outputs,
|
|
52
|
+
};
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
getTokenTransfers(logs, recipient) {
|
|
57
|
+
const ERC20Interface = new ethers_1.utils.Interface(MockERC20_json_1.default.abi);
|
|
58
|
+
return logs.reduce((logAcc, log) => {
|
|
59
|
+
try {
|
|
60
|
+
const parsedLog = ERC20Interface.parseLog(log);
|
|
61
|
+
if (parsedLog.name === TRANSFER && parsedLog.args.to === recipient) {
|
|
62
|
+
logAcc.push({
|
|
63
|
+
token: log.address,
|
|
64
|
+
amount: parsedLog.args.amount,
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
return logAcc;
|
|
68
|
+
}
|
|
69
|
+
catch (e) {
|
|
70
|
+
return logAcc;
|
|
71
|
+
}
|
|
72
|
+
}, []);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
class UniswapXEventWatcher extends EventWatcher {
|
|
76
|
+
constructor(provider, reactorAddress) {
|
|
77
|
+
const reactor = contracts_1.ExclusiveDutchOrderReactor__factory.connect(reactorAddress, provider);
|
|
78
|
+
super(reactor);
|
|
79
|
+
}
|
|
80
|
+
getFillLogs(fromBlock, toBlock) {
|
|
81
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
82
|
+
return yield this.reactor.queryFilter(this.reactor.filters.Fill(), fromBlock, toBlock);
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
onFill(callback) {
|
|
86
|
+
this.reactor.on(this.reactor.filters.Fill(), (orderHash, filler, swapper, nonce, event) => {
|
|
87
|
+
callback({
|
|
88
|
+
orderHash,
|
|
89
|
+
filler,
|
|
90
|
+
nonce,
|
|
91
|
+
swapper,
|
|
92
|
+
}, event);
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
exports.UniswapXEventWatcher = UniswapXEventWatcher;
|
|
97
|
+
class RelayEventWatcher extends EventWatcher {
|
|
98
|
+
constructor(provider, reactorAddress) {
|
|
99
|
+
const reactor = contracts_1.RelayOrderReactor__factory.connect(reactorAddress, provider);
|
|
100
|
+
super(reactor);
|
|
101
|
+
}
|
|
102
|
+
getFillLogs(fromBlock, toBlock) {
|
|
103
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
104
|
+
return yield this.reactor.queryFilter(this.reactor.filters.Relay(), fromBlock, toBlock);
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
onFill(callback) {
|
|
108
|
+
this.reactor.on(this.reactor.filters.Relay(), (orderHash, filler, swapper, nonce, event) => {
|
|
109
|
+
callback({
|
|
110
|
+
orderHash,
|
|
111
|
+
filler,
|
|
112
|
+
nonce,
|
|
113
|
+
swapper,
|
|
114
|
+
}, event);
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
exports.RelayEventWatcher = RelayEventWatcher;
|
|
119
|
+
//# sourceMappingURL=EventWatcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EventWatcher.js","sourceRoot":"","sources":["../../../../src/utils/EventWatcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { BaseProvider } from "@ethersproject/providers";
|
|
2
|
+
import { BigNumber } from "ethers";
|
|
3
|
+
/**
|
|
4
|
+
* Helper to track Permit2 nonces for addresses
|
|
5
|
+
*/
|
|
6
|
+
export declare class NonceManager {
|
|
7
|
+
private provider;
|
|
8
|
+
private permit2;
|
|
9
|
+
private currentWord;
|
|
10
|
+
private currentBitmap;
|
|
11
|
+
constructor(provider: BaseProvider, chainId: number, permit2Address?: string);
|
|
12
|
+
/**
|
|
13
|
+
* Finds the next unused nonce and returns it
|
|
14
|
+
* Marks the nonce as used so it won't be returned again from this instance
|
|
15
|
+
* NOTE: if any nonce usages are in-flight and created outside of this instance,
|
|
16
|
+
* this function will not know about them and will return duplicates
|
|
17
|
+
*/
|
|
18
|
+
useNonce(address: string): Promise<BigNumber>;
|
|
19
|
+
isUsed(address: string, nonce: BigNumber): Promise<boolean>;
|
|
20
|
+
private getNextOpenWord;
|
|
21
|
+
}
|
|
22
|
+
interface SplitNonce {
|
|
23
|
+
word: BigNumber;
|
|
24
|
+
bitPos: BigNumber;
|
|
25
|
+
}
|
|
26
|
+
export declare function splitNonce(nonce: BigNumber): SplitNonce;
|
|
27
|
+
export declare function buildNonce(word: BigNumber, bitPos: number): BigNumber;
|
|
28
|
+
export declare function getFirstUnsetBit(bitmap: BigNumber): number;
|
|
29
|
+
export declare function setBit(bitmap: BigNumber, bitPos: number): BigNumber;
|
|
30
|
+
interface CancelParams {
|
|
31
|
+
word: BigNumber;
|
|
32
|
+
mask: BigNumber;
|
|
33
|
+
}
|
|
34
|
+
export declare function getCancelSingleParams(nonceToCancel: BigNumber): CancelParams;
|
|
35
|
+
export declare function getCancelMultipleParams(noncesToCancel: BigNumber[]): CancelParams[];
|
|
36
|
+
export {};
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getCancelMultipleParams = exports.getCancelSingleParams = exports.setBit = exports.getFirstUnsetBit = exports.buildNonce = exports.splitNonce = exports.NonceManager = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const ethers_1 = require("ethers");
|
|
6
|
+
const constants_1 = require("../constants");
|
|
7
|
+
const contracts_1 = require("../contracts");
|
|
8
|
+
const errors_1 = require("../errors");
|
|
9
|
+
/**
|
|
10
|
+
* Helper to track Permit2 nonces for addresses
|
|
11
|
+
*/
|
|
12
|
+
class NonceManager {
|
|
13
|
+
constructor(provider, chainId, permit2Address) {
|
|
14
|
+
this.provider = provider;
|
|
15
|
+
if (permit2Address) {
|
|
16
|
+
this.permit2 = contracts_1.Permit2__factory.connect(permit2Address, provider);
|
|
17
|
+
}
|
|
18
|
+
else if (constants_1.PERMIT2_MAPPING[chainId]) {
|
|
19
|
+
this.permit2 = contracts_1.Permit2__factory.connect(constants_1.PERMIT2_MAPPING[chainId], this.provider);
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
throw new errors_1.MissingConfiguration("permit2", chainId.toString());
|
|
23
|
+
}
|
|
24
|
+
this.currentWord = new Map();
|
|
25
|
+
this.currentBitmap = new Map();
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Finds the next unused nonce and returns it
|
|
29
|
+
* Marks the nonce as used so it won't be returned again from this instance
|
|
30
|
+
* NOTE: if any nonce usages are in-flight and created outside of this instance,
|
|
31
|
+
* this function will not know about them and will return duplicates
|
|
32
|
+
*/
|
|
33
|
+
useNonce(address) {
|
|
34
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
35
|
+
const { word, bitmap } = yield this.getNextOpenWord(address);
|
|
36
|
+
const bitPos = getFirstUnsetBit(bitmap);
|
|
37
|
+
this.currentWord.set(address, word);
|
|
38
|
+
this.currentBitmap.set(address, setBit(bitmap, bitPos));
|
|
39
|
+
return buildNonce(word, bitPos);
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
isUsed(address, nonce) {
|
|
43
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
44
|
+
const { word, bitPos } = splitNonce(nonce);
|
|
45
|
+
const bitmap = yield this.permit2.nonceBitmap(address, word);
|
|
46
|
+
return bitmap.div(ethers_1.BigNumber.from(2).pow(bitPos)).mod(2).eq(1);
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
// Returns the first word that contains empty bits
|
|
50
|
+
getNextOpenWord(address) {
|
|
51
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
52
|
+
let currentWord = this.currentWord.get(address) || ethers_1.BigNumber.from(0);
|
|
53
|
+
let bitmap = this.currentBitmap.get(address) ||
|
|
54
|
+
(yield this.permit2.nonceBitmap(address, currentWord));
|
|
55
|
+
while (bitmap.eq(ethers_1.ethers.constants.MaxUint256)) {
|
|
56
|
+
currentWord = currentWord.add(1);
|
|
57
|
+
bitmap = yield this.permit2.nonceBitmap(address, currentWord);
|
|
58
|
+
}
|
|
59
|
+
return {
|
|
60
|
+
word: currentWord,
|
|
61
|
+
bitmap: bitmap,
|
|
62
|
+
};
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
exports.NonceManager = NonceManager;
|
|
67
|
+
// Splits a permit2 nonce into the word and bitPos
|
|
68
|
+
function splitNonce(nonce) {
|
|
69
|
+
const word = nonce.div(256);
|
|
70
|
+
const bitPos = nonce.mod(256);
|
|
71
|
+
return { word, bitPos };
|
|
72
|
+
}
|
|
73
|
+
exports.splitNonce = splitNonce;
|
|
74
|
+
// Builds a permit2 nonce from the given word and bitPos
|
|
75
|
+
function buildNonce(word, bitPos) {
|
|
76
|
+
// word << 8
|
|
77
|
+
const shiftedWord = word.mul(256);
|
|
78
|
+
return shiftedWord.add(bitPos);
|
|
79
|
+
}
|
|
80
|
+
exports.buildNonce = buildNonce;
|
|
81
|
+
// Returns the position of the first unset bit
|
|
82
|
+
// Returns -1 if all bits are set
|
|
83
|
+
function getFirstUnsetBit(bitmap) {
|
|
84
|
+
// Optimization if switch to library w/ bitwise operators:
|
|
85
|
+
// return ~bitmap + (bitmap + 1)
|
|
86
|
+
// instead we have to do a loop
|
|
87
|
+
for (let i = 0; i < 256; i++) {
|
|
88
|
+
if (bitmap.div(ethers_1.BigNumber.from(2).pow(i)).mod(2).eq(0)) {
|
|
89
|
+
return i;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return -1;
|
|
93
|
+
}
|
|
94
|
+
exports.getFirstUnsetBit = getFirstUnsetBit;
|
|
95
|
+
// Returns the given bignumber with the given bit set
|
|
96
|
+
// Does nothing if the given bit is already set
|
|
97
|
+
function setBit(bitmap, bitPos) {
|
|
98
|
+
// Optimization if switch to library w/ bitwise operators:
|
|
99
|
+
// return bitmap & (1 << bitPos)
|
|
100
|
+
const mask = ethers_1.BigNumber.from(2).pow(bitPos);
|
|
101
|
+
if (bitmap.div(mask).mod(2).eq(1)) {
|
|
102
|
+
return bitmap;
|
|
103
|
+
}
|
|
104
|
+
return bitmap.add(mask);
|
|
105
|
+
}
|
|
106
|
+
exports.setBit = setBit;
|
|
107
|
+
// Get parameters to cancel a nonce
|
|
108
|
+
function getCancelSingleParams(nonceToCancel) {
|
|
109
|
+
const { word, bitPos } = splitNonce(nonceToCancel);
|
|
110
|
+
const mask = ethers_1.BigNumber.from(2).pow(bitPos);
|
|
111
|
+
return { word, mask };
|
|
112
|
+
}
|
|
113
|
+
exports.getCancelSingleParams = getCancelSingleParams;
|
|
114
|
+
// Get parameters to cancel multiple nonces
|
|
115
|
+
function getCancelMultipleParams(noncesToCancel) {
|
|
116
|
+
const splitNonces = noncesToCancel.map(splitNonce);
|
|
117
|
+
const splitNoncesByWord = {};
|
|
118
|
+
splitNonces.forEach((splitNonce) => {
|
|
119
|
+
const word = splitNonce.word.toString();
|
|
120
|
+
if (!splitNoncesByWord[word]) {
|
|
121
|
+
splitNoncesByWord[word] = [];
|
|
122
|
+
}
|
|
123
|
+
splitNoncesByWord[word].push(splitNonce);
|
|
124
|
+
});
|
|
125
|
+
return Object.entries(splitNoncesByWord).map(([word, splitNonce]) => {
|
|
126
|
+
let mask = ethers_1.BigNumber.from(0);
|
|
127
|
+
splitNonce.forEach((splitNonce) => {
|
|
128
|
+
mask = mask.or(ethers_1.BigNumber.from(2).pow(splitNonce.bitPos));
|
|
129
|
+
});
|
|
130
|
+
return { word: ethers_1.BigNumber.from(word), mask };
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
exports.getCancelMultipleParams = getCancelMultipleParams;
|
|
134
|
+
//# sourceMappingURL=NonceManager.js.map
|