@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,220 @@
|
|
|
1
|
+
import { Ether, Token, TradeType } from "@juiceswapxyz/sdk-core";
|
|
2
|
+
import { BigNumber, constants, ethers } from "ethers";
|
|
3
|
+
import { V3DutchOrderTrade } from "./V3DutchOrderTrade";
|
|
4
|
+
import { NativeAssets } from "./utils";
|
|
5
|
+
const USDC = new Token(1, "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48", 6, "USDC");
|
|
6
|
+
const DAI = new Token(1, "0x6B175474E89094C44Da98b954EedeAC495271d0F", 18, "DAI");
|
|
7
|
+
describe("V3DutchOrderTrade", () => {
|
|
8
|
+
const NON_FEE_OUTPUT_AMOUNT = BigNumber.from("1000000000000000000");
|
|
9
|
+
const NON_FEE_MINIMUM_AMOUNT_OUT = BigNumber.from("900000000000000000");
|
|
10
|
+
const orderInfo = {
|
|
11
|
+
deadline: Math.floor(new Date().getTime() / 1000) + 1000,
|
|
12
|
+
reactor: "0x0000000000000000000000000000000000000000",
|
|
13
|
+
swapper: "0x0000000000000000000000000000000000000000",
|
|
14
|
+
nonce: BigNumber.from(10),
|
|
15
|
+
cosigner: "0x0000000000000000000000000000000000000000",
|
|
16
|
+
startingBaseFee: BigNumber.from(0),
|
|
17
|
+
additionalValidationContract: ethers.constants.AddressZero,
|
|
18
|
+
additionalValidationData: "0x",
|
|
19
|
+
input: {
|
|
20
|
+
token: USDC.address,
|
|
21
|
+
startAmount: BigNumber.from(1000),
|
|
22
|
+
curve: {
|
|
23
|
+
relativeBlocks: [],
|
|
24
|
+
relativeAmounts: [],
|
|
25
|
+
},
|
|
26
|
+
maxAmount: BigNumber.from(1000),
|
|
27
|
+
adjustmentPerGweiBaseFee: BigNumber.from(0),
|
|
28
|
+
},
|
|
29
|
+
outputs: [
|
|
30
|
+
{
|
|
31
|
+
token: DAI.address,
|
|
32
|
+
startAmount: NON_FEE_OUTPUT_AMOUNT,
|
|
33
|
+
curve: {
|
|
34
|
+
relativeBlocks: [21],
|
|
35
|
+
relativeAmounts: [BigInt("100000000000000000")],
|
|
36
|
+
},
|
|
37
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
38
|
+
minAmount: NON_FEE_MINIMUM_AMOUNT_OUT,
|
|
39
|
+
adjustmentPerGweiBaseFee: BigNumber.from(0),
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
token: DAI.address,
|
|
43
|
+
startAmount: BigNumber.from("1000"),
|
|
44
|
+
curve: {
|
|
45
|
+
relativeBlocks: [21],
|
|
46
|
+
relativeAmounts: [BigInt("100")],
|
|
47
|
+
},
|
|
48
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
49
|
+
minAmount: BigNumber.from("900"),
|
|
50
|
+
adjustmentPerGweiBaseFee: BigNumber.from(0),
|
|
51
|
+
},
|
|
52
|
+
],
|
|
53
|
+
};
|
|
54
|
+
const trade = new V3DutchOrderTrade({
|
|
55
|
+
currencyIn: USDC,
|
|
56
|
+
currenciesOut: [DAI],
|
|
57
|
+
orderInfo,
|
|
58
|
+
tradeType: TradeType.EXACT_INPUT,
|
|
59
|
+
});
|
|
60
|
+
describe("Exact input", () => {
|
|
61
|
+
it("returns the right input amount for an exact-in trade", () => {
|
|
62
|
+
expect(trade.inputAmount.quotient.toString()).toEqual(orderInfo.input.startAmount.toString());
|
|
63
|
+
});
|
|
64
|
+
it("returns the correct non-fee output amount", () => {
|
|
65
|
+
expect(trade.outputAmount.quotient.toString()).toEqual(NON_FEE_OUTPUT_AMOUNT.toString());
|
|
66
|
+
});
|
|
67
|
+
it("returns the correct minimum amount out", () => {
|
|
68
|
+
expect(trade.minimumAmountOut().quotient.toString()).toEqual(NON_FEE_MINIMUM_AMOUNT_OUT.toString());
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
describe("Exact output", () => {
|
|
72
|
+
const outOrderInfo = {
|
|
73
|
+
deadline: Math.floor(new Date().getTime() / 1000) + 1000,
|
|
74
|
+
reactor: "0x0000000000000000000000000000000000000000",
|
|
75
|
+
swapper: "0x0000000000000000000000000000000000000000",
|
|
76
|
+
nonce: BigNumber.from(10),
|
|
77
|
+
cosigner: "0x0000000000000000000000000000000000000000",
|
|
78
|
+
startingBaseFee: BigNumber.from(0),
|
|
79
|
+
additionalValidationContract: ethers.constants.AddressZero,
|
|
80
|
+
additionalValidationData: "0x",
|
|
81
|
+
input: {
|
|
82
|
+
token: USDC.address,
|
|
83
|
+
startAmount: BigNumber.from(1000),
|
|
84
|
+
curve: {
|
|
85
|
+
relativeBlocks: [10],
|
|
86
|
+
relativeAmounts: [BigInt(-100)],
|
|
87
|
+
},
|
|
88
|
+
maxAmount: BigNumber.from(1100),
|
|
89
|
+
adjustmentPerGweiBaseFee: BigNumber.from(0),
|
|
90
|
+
},
|
|
91
|
+
outputs: [
|
|
92
|
+
{
|
|
93
|
+
token: DAI.address,
|
|
94
|
+
startAmount: NON_FEE_OUTPUT_AMOUNT,
|
|
95
|
+
curve: {
|
|
96
|
+
relativeBlocks: [],
|
|
97
|
+
relativeAmounts: [],
|
|
98
|
+
},
|
|
99
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
100
|
+
minAmount: NON_FEE_OUTPUT_AMOUNT,
|
|
101
|
+
adjustmentPerGweiBaseFee: BigNumber.from(0),
|
|
102
|
+
},
|
|
103
|
+
{
|
|
104
|
+
token: DAI.address,
|
|
105
|
+
startAmount: BigNumber.from("1000"),
|
|
106
|
+
curve: {
|
|
107
|
+
relativeBlocks: [],
|
|
108
|
+
relativeAmounts: [],
|
|
109
|
+
},
|
|
110
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
111
|
+
minAmount: BigNumber.from("1000"),
|
|
112
|
+
adjustmentPerGweiBaseFee: BigNumber.from(0),
|
|
113
|
+
},
|
|
114
|
+
],
|
|
115
|
+
};
|
|
116
|
+
const trade = new V3DutchOrderTrade({
|
|
117
|
+
currencyIn: USDC,
|
|
118
|
+
currenciesOut: [DAI],
|
|
119
|
+
orderInfo: outOrderInfo,
|
|
120
|
+
tradeType: TradeType.EXACT_OUTPUT,
|
|
121
|
+
});
|
|
122
|
+
it("returns the correct maximum amount in", () => {
|
|
123
|
+
expect(trade.maximumAmountIn().quotient.toString()).toEqual(outOrderInfo.input.maxAmount.toString());
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
describe("Qualitative tests", () => {
|
|
127
|
+
it("works for native output trades", () => {
|
|
128
|
+
const ethOutputOrderInfo = Object.assign(Object.assign({}, orderInfo), { outputs: [
|
|
129
|
+
{
|
|
130
|
+
token: NativeAssets.ETH,
|
|
131
|
+
startAmount: NON_FEE_OUTPUT_AMOUNT,
|
|
132
|
+
curve: {
|
|
133
|
+
relativeBlocks: [21],
|
|
134
|
+
relativeAmounts: [BigInt("100000000000000000")],
|
|
135
|
+
},
|
|
136
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
137
|
+
minAmount: NON_FEE_MINIMUM_AMOUNT_OUT,
|
|
138
|
+
adjustmentPerGweiBaseFee: BigNumber.from(0),
|
|
139
|
+
},
|
|
140
|
+
] });
|
|
141
|
+
const ethOutputTrade = new V3DutchOrderTrade({
|
|
142
|
+
currencyIn: USDC,
|
|
143
|
+
currenciesOut: [Ether.onChain(1)],
|
|
144
|
+
orderInfo: ethOutputOrderInfo,
|
|
145
|
+
tradeType: TradeType.EXACT_INPUT,
|
|
146
|
+
});
|
|
147
|
+
expect(ethOutputTrade.outputAmount.currency).toEqual(Ether.onChain(1));
|
|
148
|
+
});
|
|
149
|
+
it("works for native output trades where order info has 0 address", () => {
|
|
150
|
+
const ethOutputOrderInfo = Object.assign(Object.assign({}, orderInfo), { outputs: [
|
|
151
|
+
{
|
|
152
|
+
token: constants.AddressZero,
|
|
153
|
+
startAmount: NON_FEE_OUTPUT_AMOUNT,
|
|
154
|
+
curve: {
|
|
155
|
+
relativeBlocks: [21],
|
|
156
|
+
relativeAmounts: [BigInt("100000000000000000")],
|
|
157
|
+
},
|
|
158
|
+
recipient: "0x0000000000000000000000000000000000000000",
|
|
159
|
+
minAmount: NON_FEE_MINIMUM_AMOUNT_OUT,
|
|
160
|
+
adjustmentPerGweiBaseFee: BigNumber.from(0),
|
|
161
|
+
},
|
|
162
|
+
] });
|
|
163
|
+
const ethOutputTrade = new V3DutchOrderTrade({
|
|
164
|
+
currencyIn: USDC,
|
|
165
|
+
currenciesOut: [Ether.onChain(1)],
|
|
166
|
+
orderInfo: ethOutputOrderInfo,
|
|
167
|
+
tradeType: TradeType.EXACT_INPUT,
|
|
168
|
+
});
|
|
169
|
+
expect(ethOutputTrade.outputAmount.currency).toEqual(Ether.onChain(1));
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
describe("Expected amounts", () => {
|
|
173
|
+
const expectedAmounts = {
|
|
174
|
+
expectedAmountIn: "800",
|
|
175
|
+
expectedAmountOut: "900",
|
|
176
|
+
};
|
|
177
|
+
const tradeWithExpectedAmounts = new V3DutchOrderTrade({
|
|
178
|
+
currencyIn: USDC,
|
|
179
|
+
currenciesOut: [DAI],
|
|
180
|
+
orderInfo,
|
|
181
|
+
tradeType: TradeType.EXACT_INPUT,
|
|
182
|
+
expectedAmounts,
|
|
183
|
+
});
|
|
184
|
+
it("uses expectedAmountIn when provided", () => {
|
|
185
|
+
expect(tradeWithExpectedAmounts.inputAmount.quotient.toString()).toEqual(expectedAmounts.expectedAmountIn);
|
|
186
|
+
});
|
|
187
|
+
it("uses expectedAmountOut when provided", () => {
|
|
188
|
+
expect(tradeWithExpectedAmounts.outputAmount.quotient.toString()).toEqual(expectedAmounts.expectedAmountOut);
|
|
189
|
+
});
|
|
190
|
+
it("falls back to order amounts when expectedAmounts is not provided", () => {
|
|
191
|
+
expect(trade.inputAmount.quotient.toString()).toEqual(orderInfo.input.startAmount.toString());
|
|
192
|
+
expect(trade.outputAmount.quotient.toString()).toEqual(NON_FEE_OUTPUT_AMOUNT.toString());
|
|
193
|
+
});
|
|
194
|
+
it("throws when accessing expectedAmountIn that wasn't provided", () => {
|
|
195
|
+
const tradeWithoutExpected = new V3DutchOrderTrade({
|
|
196
|
+
currencyIn: USDC,
|
|
197
|
+
currenciesOut: [DAI],
|
|
198
|
+
orderInfo,
|
|
199
|
+
tradeType: TradeType.EXACT_INPUT,
|
|
200
|
+
});
|
|
201
|
+
// Using private method through any to test error case
|
|
202
|
+
expect(() => {
|
|
203
|
+
tradeWithoutExpected.getExpectedAmountIn();
|
|
204
|
+
}).toThrow("expectedAmountIn not set");
|
|
205
|
+
});
|
|
206
|
+
it("throws when accessing expectedAmountOut that wasn't provided", () => {
|
|
207
|
+
const tradeWithoutExpected = new V3DutchOrderTrade({
|
|
208
|
+
currencyIn: USDC,
|
|
209
|
+
currenciesOut: [DAI],
|
|
210
|
+
orderInfo,
|
|
211
|
+
tradeType: TradeType.EXACT_INPUT,
|
|
212
|
+
});
|
|
213
|
+
// Using private method through any to test error case
|
|
214
|
+
expect(() => {
|
|
215
|
+
tradeWithoutExpected.getExpectedAmountOut();
|
|
216
|
+
}).toThrow("expectedAmountOut not set");
|
|
217
|
+
});
|
|
218
|
+
});
|
|
219
|
+
});
|
|
220
|
+
//# 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 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/trade/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC"}
|
|
@@ -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,31 @@
|
|
|
1
|
+
import { ChainId } from "@juiceswapxyz/sdk-core";
|
|
2
|
+
import { constants } from "ethers";
|
|
3
|
+
export var NativeAssets;
|
|
4
|
+
(function (NativeAssets) {
|
|
5
|
+
NativeAssets["MATIC"] = "MATIC";
|
|
6
|
+
NativeAssets["BNB"] = "BNB";
|
|
7
|
+
NativeAssets["AVAX"] = "AVAX";
|
|
8
|
+
NativeAssets["ETH"] = "ETH";
|
|
9
|
+
})(NativeAssets || (NativeAssets = {}));
|
|
10
|
+
function nativeCurrencyAddressString(chainId) {
|
|
11
|
+
switch (chainId) {
|
|
12
|
+
case ChainId.POLYGON:
|
|
13
|
+
return NativeAssets.MATIC;
|
|
14
|
+
case ChainId.BNB:
|
|
15
|
+
return NativeAssets.BNB;
|
|
16
|
+
case ChainId.AVALANCHE:
|
|
17
|
+
return NativeAssets.AVAX;
|
|
18
|
+
default:
|
|
19
|
+
return NativeAssets.ETH;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
export function areCurrenciesEqual(currency, address, chainId) {
|
|
23
|
+
if (currency.chainId !== chainId)
|
|
24
|
+
return false;
|
|
25
|
+
if (currency.isNative) {
|
|
26
|
+
return (address === constants.AddressZero ||
|
|
27
|
+
address === nativeCurrencyAddressString(chainId));
|
|
28
|
+
}
|
|
29
|
+
return currency.address.toLowerCase() === (address === null || address === void 0 ? void 0 : address.toLowerCase());
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/trade/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAY,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAEnC,MAAM,CAAN,IAAY,YAKX;AALD,WAAY,YAAY;IACtB,+BAAe,CAAA;IACf,2BAAW,CAAA;IACX,6BAAa,CAAA;IACb,2BAAW,CAAA;AACb,CAAC,EALW,YAAY,KAAZ,YAAY,QAKvB;AAED,SAAS,2BAA2B,CAAC,OAAe;IAClD,QAAQ,OAAO,EAAE;QACf,KAAK,OAAO,CAAC,OAAO;YAClB,OAAO,YAAY,CAAC,KAAK,CAAC;QAC5B,KAAK,OAAO,CAAC,GAAG;YACd,OAAO,YAAY,CAAC,GAAG,CAAC;QAC1B,KAAK,OAAO,CAAC,SAAS;YACpB,OAAO,YAAY,CAAC,IAAI,CAAC;QAC3B;YACE,OAAO,YAAY,CAAC,GAAG,CAAC;KAC3B;AACH,CAAC;AAED,MAAM,UAAU,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,SAAS,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"}
|
|
@@ -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,114 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { utils } from "ethers";
|
|
3
|
+
import MockERC20Abi from "../../abis/MockERC20.json";
|
|
4
|
+
import { ExclusiveDutchOrderReactor__factory, RelayOrderReactor__factory, } from "../contracts";
|
|
5
|
+
const TRANSFER = "Transfer";
|
|
6
|
+
/**
|
|
7
|
+
* Helper for watching events
|
|
8
|
+
*/
|
|
9
|
+
class EventWatcher {
|
|
10
|
+
constructor(reactor) {
|
|
11
|
+
this.reactor = reactor;
|
|
12
|
+
}
|
|
13
|
+
getFillEvents(fromBlock, toBlock) {
|
|
14
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
15
|
+
const logs = yield this.getFillLogs(fromBlock, toBlock);
|
|
16
|
+
return logs.map((log) => log.args);
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
getFillInfo(fromBlock, toBlock) {
|
|
20
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
21
|
+
const logs = yield this.getFillLogs(fromBlock, toBlock);
|
|
22
|
+
const events = logs.map((log) => log.args);
|
|
23
|
+
// TODO: deal with batch fills for orders with the same swapper and outToken
|
|
24
|
+
const txs = logs.reduce((acc, log) => acc.add(this.reactor.provider.getTransactionReceipt(log.transactionHash)), new Set());
|
|
25
|
+
const txReceipts = yield Promise.all(txs);
|
|
26
|
+
const fills = events.map((e, i) => {
|
|
27
|
+
return {
|
|
28
|
+
orderHash: e.orderHash,
|
|
29
|
+
swapper: e.swapper,
|
|
30
|
+
filler: e.filler,
|
|
31
|
+
nonce: e.nonce,
|
|
32
|
+
txLogs: txReceipts[i].logs,
|
|
33
|
+
blockNumber: txReceipts[i].blockNumber,
|
|
34
|
+
txHash: txReceipts[i].transactionHash,
|
|
35
|
+
};
|
|
36
|
+
});
|
|
37
|
+
return fills.map((fill) => {
|
|
38
|
+
const outputs = this.getTokenTransfers(fill.txLogs, fill.swapper);
|
|
39
|
+
const inputs = this.getTokenTransfers(fill.txLogs, fill.filler);
|
|
40
|
+
return {
|
|
41
|
+
orderHash: fill.orderHash,
|
|
42
|
+
swapper: fill.swapper,
|
|
43
|
+
filler: fill.filler,
|
|
44
|
+
nonce: fill.nonce,
|
|
45
|
+
blockNumber: fill.blockNumber,
|
|
46
|
+
txHash: fill.txHash,
|
|
47
|
+
inputs: inputs,
|
|
48
|
+
outputs: outputs,
|
|
49
|
+
};
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
getTokenTransfers(logs, recipient) {
|
|
54
|
+
const ERC20Interface = new utils.Interface(MockERC20Abi.abi);
|
|
55
|
+
return logs.reduce((logAcc, log) => {
|
|
56
|
+
try {
|
|
57
|
+
const parsedLog = ERC20Interface.parseLog(log);
|
|
58
|
+
if (parsedLog.name === TRANSFER && parsedLog.args.to === recipient) {
|
|
59
|
+
logAcc.push({
|
|
60
|
+
token: log.address,
|
|
61
|
+
amount: parsedLog.args.amount,
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
return logAcc;
|
|
65
|
+
}
|
|
66
|
+
catch (e) {
|
|
67
|
+
return logAcc;
|
|
68
|
+
}
|
|
69
|
+
}, []);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
export class UniswapXEventWatcher extends EventWatcher {
|
|
73
|
+
constructor(provider, reactorAddress) {
|
|
74
|
+
const reactor = ExclusiveDutchOrderReactor__factory.connect(reactorAddress, provider);
|
|
75
|
+
super(reactor);
|
|
76
|
+
}
|
|
77
|
+
getFillLogs(fromBlock, toBlock) {
|
|
78
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
79
|
+
return yield this.reactor.queryFilter(this.reactor.filters.Fill(), fromBlock, toBlock);
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
onFill(callback) {
|
|
83
|
+
this.reactor.on(this.reactor.filters.Fill(), (orderHash, filler, swapper, nonce, event) => {
|
|
84
|
+
callback({
|
|
85
|
+
orderHash,
|
|
86
|
+
filler,
|
|
87
|
+
nonce,
|
|
88
|
+
swapper,
|
|
89
|
+
}, event);
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
export class RelayEventWatcher extends EventWatcher {
|
|
94
|
+
constructor(provider, reactorAddress) {
|
|
95
|
+
const reactor = RelayOrderReactor__factory.connect(reactorAddress, provider);
|
|
96
|
+
super(reactor);
|
|
97
|
+
}
|
|
98
|
+
getFillLogs(fromBlock, toBlock) {
|
|
99
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
100
|
+
return yield this.reactor.queryFilter(this.reactor.filters.Relay(), fromBlock, toBlock);
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
onFill(callback) {
|
|
104
|
+
this.reactor.on(this.reactor.filters.Relay(), (orderHash, filler, swapper, nonce, event) => {
|
|
105
|
+
callback({
|
|
106
|
+
orderHash,
|
|
107
|
+
filler,
|
|
108
|
+
nonce,
|
|
109
|
+
swapper,
|
|
110
|
+
}, event);
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
//# 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,124 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { BigNumber, ethers } from "ethers";
|
|
3
|
+
import { PERMIT2_MAPPING } from "../constants";
|
|
4
|
+
import { Permit2__factory } from "../contracts";
|
|
5
|
+
import { MissingConfiguration } from "../errors";
|
|
6
|
+
/**
|
|
7
|
+
* Helper to track Permit2 nonces for addresses
|
|
8
|
+
*/
|
|
9
|
+
export class NonceManager {
|
|
10
|
+
constructor(provider, chainId, permit2Address) {
|
|
11
|
+
this.provider = provider;
|
|
12
|
+
if (permit2Address) {
|
|
13
|
+
this.permit2 = Permit2__factory.connect(permit2Address, provider);
|
|
14
|
+
}
|
|
15
|
+
else if (PERMIT2_MAPPING[chainId]) {
|
|
16
|
+
this.permit2 = Permit2__factory.connect(PERMIT2_MAPPING[chainId], this.provider);
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
throw new MissingConfiguration("permit2", chainId.toString());
|
|
20
|
+
}
|
|
21
|
+
this.currentWord = new Map();
|
|
22
|
+
this.currentBitmap = new Map();
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Finds the next unused nonce and returns it
|
|
26
|
+
* Marks the nonce as used so it won't be returned again from this instance
|
|
27
|
+
* NOTE: if any nonce usages are in-flight and created outside of this instance,
|
|
28
|
+
* this function will not know about them and will return duplicates
|
|
29
|
+
*/
|
|
30
|
+
useNonce(address) {
|
|
31
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
32
|
+
const { word, bitmap } = yield this.getNextOpenWord(address);
|
|
33
|
+
const bitPos = getFirstUnsetBit(bitmap);
|
|
34
|
+
this.currentWord.set(address, word);
|
|
35
|
+
this.currentBitmap.set(address, setBit(bitmap, bitPos));
|
|
36
|
+
return buildNonce(word, bitPos);
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
isUsed(address, nonce) {
|
|
40
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
+
const { word, bitPos } = splitNonce(nonce);
|
|
42
|
+
const bitmap = yield this.permit2.nonceBitmap(address, word);
|
|
43
|
+
return bitmap.div(BigNumber.from(2).pow(bitPos)).mod(2).eq(1);
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
// Returns the first word that contains empty bits
|
|
47
|
+
getNextOpenWord(address) {
|
|
48
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
49
|
+
let currentWord = this.currentWord.get(address) || BigNumber.from(0);
|
|
50
|
+
let bitmap = this.currentBitmap.get(address) ||
|
|
51
|
+
(yield this.permit2.nonceBitmap(address, currentWord));
|
|
52
|
+
while (bitmap.eq(ethers.constants.MaxUint256)) {
|
|
53
|
+
currentWord = currentWord.add(1);
|
|
54
|
+
bitmap = yield this.permit2.nonceBitmap(address, currentWord);
|
|
55
|
+
}
|
|
56
|
+
return {
|
|
57
|
+
word: currentWord,
|
|
58
|
+
bitmap: bitmap,
|
|
59
|
+
};
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
// Splits a permit2 nonce into the word and bitPos
|
|
64
|
+
export function splitNonce(nonce) {
|
|
65
|
+
const word = nonce.div(256);
|
|
66
|
+
const bitPos = nonce.mod(256);
|
|
67
|
+
return { word, bitPos };
|
|
68
|
+
}
|
|
69
|
+
// Builds a permit2 nonce from the given word and bitPos
|
|
70
|
+
export function buildNonce(word, bitPos) {
|
|
71
|
+
// word << 8
|
|
72
|
+
const shiftedWord = word.mul(256);
|
|
73
|
+
return shiftedWord.add(bitPos);
|
|
74
|
+
}
|
|
75
|
+
// Returns the position of the first unset bit
|
|
76
|
+
// Returns -1 if all bits are set
|
|
77
|
+
export function getFirstUnsetBit(bitmap) {
|
|
78
|
+
// Optimization if switch to library w/ bitwise operators:
|
|
79
|
+
// return ~bitmap + (bitmap + 1)
|
|
80
|
+
// instead we have to do a loop
|
|
81
|
+
for (let i = 0; i < 256; i++) {
|
|
82
|
+
if (bitmap.div(BigNumber.from(2).pow(i)).mod(2).eq(0)) {
|
|
83
|
+
return i;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
return -1;
|
|
87
|
+
}
|
|
88
|
+
// Returns the given bignumber with the given bit set
|
|
89
|
+
// Does nothing if the given bit is already set
|
|
90
|
+
export function setBit(bitmap, bitPos) {
|
|
91
|
+
// Optimization if switch to library w/ bitwise operators:
|
|
92
|
+
// return bitmap & (1 << bitPos)
|
|
93
|
+
const mask = BigNumber.from(2).pow(bitPos);
|
|
94
|
+
if (bitmap.div(mask).mod(2).eq(1)) {
|
|
95
|
+
return bitmap;
|
|
96
|
+
}
|
|
97
|
+
return bitmap.add(mask);
|
|
98
|
+
}
|
|
99
|
+
// Get parameters to cancel a nonce
|
|
100
|
+
export function getCancelSingleParams(nonceToCancel) {
|
|
101
|
+
const { word, bitPos } = splitNonce(nonceToCancel);
|
|
102
|
+
const mask = BigNumber.from(2).pow(bitPos);
|
|
103
|
+
return { word, mask };
|
|
104
|
+
}
|
|
105
|
+
// Get parameters to cancel multiple nonces
|
|
106
|
+
export function getCancelMultipleParams(noncesToCancel) {
|
|
107
|
+
const splitNonces = noncesToCancel.map(splitNonce);
|
|
108
|
+
const splitNoncesByWord = {};
|
|
109
|
+
splitNonces.forEach((splitNonce) => {
|
|
110
|
+
const word = splitNonce.word.toString();
|
|
111
|
+
if (!splitNoncesByWord[word]) {
|
|
112
|
+
splitNoncesByWord[word] = [];
|
|
113
|
+
}
|
|
114
|
+
splitNoncesByWord[word].push(splitNonce);
|
|
115
|
+
});
|
|
116
|
+
return Object.entries(splitNoncesByWord).map(([word, splitNonce]) => {
|
|
117
|
+
let mask = BigNumber.from(0);
|
|
118
|
+
splitNonce.forEach((splitNonce) => {
|
|
119
|
+
mask = mask.or(BigNumber.from(2).pow(splitNonce.bitPos));
|
|
120
|
+
});
|
|
121
|
+
return { word: BigNumber.from(word), mask };
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=NonceManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NonceManager.js","sourceRoot":"","sources":["../../../../src/utils/NonceManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|