@cronos-labs/rfq-sdk 0.2.3
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/LICENSE +21 -0
- package/README.md +120 -0
- 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/HybridOrderBuilder.d.ts +40 -0
- package/dist/cjs/src/builder/HybridOrderBuilder.js +257 -0
- package/dist/cjs/src/builder/HybridOrderBuilder.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/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/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/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/index.d.ts +7 -0
- package/dist/cjs/src/builder/index.js +11 -0
- package/dist/cjs/src/builder/index.js.map +1 -0
- package/dist/cjs/src/constants/v4.d.ts +44 -0
- package/dist/cjs/src/constants/v4.js +58 -0
- package/dist/cjs/src/constants/v4.js.map +1 -0
- package/dist/cjs/src/constants.d.ts +76 -0
- package/dist/cjs/src/constants.js +148 -0
- package/dist/cjs/src/constants.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/HybridAuctionResolver.d.ts +148 -0
- package/dist/cjs/src/contracts/HybridAuctionResolver.js +3 -0
- package/dist/cjs/src/contracts/HybridAuctionResolver.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/OrderQuoterV4.d.ts +150 -0
- package/dist/cjs/src/contracts/OrderQuoterV4.js +3 -0
- package/dist/cjs/src/contracts/OrderQuoterV4.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/Reactor.d.ts +207 -0
- package/dist/cjs/src/contracts/Reactor.js +3 -0
- package/dist/cjs/src/contracts/Reactor.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/TokenTransferHook.d.ts +144 -0
- package/dist/cjs/src/contracts/TokenTransferHook.js +3 -0
- package/dist/cjs/src/contracts/TokenTransferHook.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/HybridAuctionResolver__factory.d.ts +204 -0
- package/dist/cjs/src/contracts/factories/HybridAuctionResolver__factory.js +279 -0
- package/dist/cjs/src/contracts/factories/HybridAuctionResolver__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/OrderQuoterV4__factory.d.ts +262 -0
- package/dist/cjs/src/contracts/factories/OrderQuoterV4__factory.js +354 -0
- package/dist/cjs/src/contracts/factories/OrderQuoterV4__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/Reactor__factory.d.ts +313 -0
- package/dist/cjs/src/contracts/factories/Reactor__factory.js +421 -0
- package/dist/cjs/src/contracts/factories/Reactor__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/TokenTransferHook__factory.d.ts +159 -0
- package/dist/cjs/src/contracts/factories/TokenTransferHook__factory.js +221 -0
- package/dist/cjs/src/contracts/factories/TokenTransferHook__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 +22 -0
- package/dist/cjs/src/contracts/factories/index.js +51 -0
- package/dist/cjs/src/contracts/factories/index.js.map +1 -0
- package/dist/cjs/src/contracts/index.d.ts +45 -0
- package/dist/cjs/src/contracts/index.js +50 -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/PriorityOrder.d.ts +121 -0
- package/dist/cjs/src/order/PriorityOrder.js +397 -0
- package/dist/cjs/src/order/PriorityOrder.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/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/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/index.d.ts +18 -0
- package/dist/cjs/src/order/index.js +13 -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/v4/HybridOrder.d.ts +83 -0
- package/dist/cjs/src/order/v4/HybridOrder.js +665 -0
- package/dist/cjs/src/order/v4/HybridOrder.js.map +1 -0
- package/dist/cjs/src/order/v4/hashing.d.ts +87 -0
- package/dist/cjs/src/order/v4/hashing.js +431 -0
- package/dist/cjs/src/order/v4/hashing.js.map +1 -0
- package/dist/cjs/src/order/v4/index.d.ts +3 -0
- package/dist/cjs/src/order/v4/index.js +10 -0
- package/dist/cjs/src/order/v4/index.js.map +1 -0
- package/dist/cjs/src/order/v4/types.d.ts +244 -0
- package/dist/cjs/src/order/v4/types.js +3 -0
- package/dist/cjs/src/order/v4/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/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/HybridOrderTrade.d.ts +61 -0
- package/dist/cjs/src/trade/HybridOrderTrade.js +104 -0
- package/dist/cjs/src/trade/HybridOrderTrade.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/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/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/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/index.d.ts +6 -0
- package/dist/cjs/src/trade/index.js +10 -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 +120 -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/OrderQuoter.d.ts +144 -0
- package/dist/cjs/src/utils/OrderQuoter.js +517 -0
- package/dist/cjs/src/utils/OrderQuoter.js.map +1 -0
- package/dist/cjs/src/utils/OrderValidator.d.ts +19 -0
- package/dist/cjs/src/utils/OrderValidator.js +69 -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 +70 -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/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/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 +93 -0
- package/dist/cjs/src/utils/multicall.js.map +1 -0
- package/dist/cjs/src/utils/order.d.ts +52 -0
- package/dist/cjs/src/utils/order.js +182 -0
- package/dist/cjs/src/utils/order.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/HybridOrderBuilder.d.ts +40 -0
- package/dist/esm/src/builder/HybridOrderBuilder.js +252 -0
- package/dist/esm/src/builder/HybridOrderBuilder.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/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/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/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/index.d.ts +7 -0
- package/dist/esm/src/builder/index.js +8 -0
- package/dist/esm/src/builder/index.js.map +1 -0
- package/dist/esm/src/constants/v4.d.ts +44 -0
- package/dist/esm/src/constants/v4.js +52 -0
- package/dist/esm/src/constants/v4.js.map +1 -0
- package/dist/esm/src/constants.d.ts +76 -0
- package/dist/esm/src/constants.js +143 -0
- package/dist/esm/src/constants.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/HybridAuctionResolver.d.ts +148 -0
- package/dist/esm/src/contracts/HybridAuctionResolver.js +2 -0
- package/dist/esm/src/contracts/HybridAuctionResolver.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/OrderQuoterV4.d.ts +150 -0
- package/dist/esm/src/contracts/OrderQuoterV4.js +2 -0
- package/dist/esm/src/contracts/OrderQuoterV4.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/Reactor.d.ts +207 -0
- package/dist/esm/src/contracts/Reactor.js +2 -0
- package/dist/esm/src/contracts/Reactor.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/TokenTransferHook.d.ts +144 -0
- package/dist/esm/src/contracts/TokenTransferHook.js +2 -0
- package/dist/esm/src/contracts/TokenTransferHook.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/HybridAuctionResolver__factory.d.ts +204 -0
- package/dist/esm/src/contracts/factories/HybridAuctionResolver__factory.js +275 -0
- package/dist/esm/src/contracts/factories/HybridAuctionResolver__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/OrderQuoterV4__factory.d.ts +262 -0
- package/dist/esm/src/contracts/factories/OrderQuoterV4__factory.js +350 -0
- package/dist/esm/src/contracts/factories/OrderQuoterV4__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/Reactor__factory.d.ts +313 -0
- package/dist/esm/src/contracts/factories/Reactor__factory.js +417 -0
- package/dist/esm/src/contracts/factories/Reactor__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/TokenTransferHook__factory.d.ts +159 -0
- package/dist/esm/src/contracts/factories/TokenTransferHook__factory.js +217 -0
- package/dist/esm/src/contracts/factories/TokenTransferHook__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 +22 -0
- package/dist/esm/src/contracts/factories/index.js +26 -0
- package/dist/esm/src/contracts/factories/index.js.map +1 -0
- package/dist/esm/src/contracts/index.d.ts +45 -0
- package/dist/esm/src/contracts/index.js +24 -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/PriorityOrder.d.ts +121 -0
- package/dist/esm/src/order/PriorityOrder.js +391 -0
- package/dist/esm/src/order/PriorityOrder.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/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/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/index.d.ts +18 -0
- package/dist/esm/src/order/index.js +10 -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/v4/HybridOrder.d.ts +83 -0
- package/dist/esm/src/order/v4/HybridOrder.js +657 -0
- package/dist/esm/src/order/v4/HybridOrder.js.map +1 -0
- package/dist/esm/src/order/v4/hashing.d.ts +87 -0
- package/dist/esm/src/order/v4/hashing.js +422 -0
- package/dist/esm/src/order/v4/hashing.js.map +1 -0
- package/dist/esm/src/order/v4/index.d.ts +3 -0
- package/dist/esm/src/order/v4/index.js +7 -0
- package/dist/esm/src/order/v4/index.js.map +1 -0
- package/dist/esm/src/order/v4/types.d.ts +244 -0
- package/dist/esm/src/order/v4/types.js +2 -0
- package/dist/esm/src/order/v4/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/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/HybridOrderTrade.d.ts +61 -0
- package/dist/esm/src/trade/HybridOrderTrade.js +100 -0
- package/dist/esm/src/trade/HybridOrderTrade.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/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/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/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/index.d.ts +6 -0
- package/dist/esm/src/trade/index.js +7 -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 +115 -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/OrderQuoter.d.ts +144 -0
- package/dist/esm/src/utils/OrderQuoter.js +511 -0
- package/dist/esm/src/utils/OrderQuoter.js.map +1 -0
- package/dist/esm/src/utils/OrderValidator.d.ts +19 -0
- package/dist/esm/src/utils/OrderValidator.js +63 -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 +66 -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/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/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 +87 -0
- package/dist/esm/src/utils/multicall.js.map +1 -0
- package/dist/esm/src/utils/order.d.ts +52 -0
- package/dist/esm/src/utils/order.js +176 -0
- package/dist/esm/src/utils/order.js.map +1 -0
- package/dist/types/src/builder/DutchOrderBuilder.d.ts +25 -0
- package/dist/types/src/builder/HybridOrderBuilder.d.ts +40 -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/RelayOrderBuilder.d.ts +22 -0
- package/dist/types/src/builder/V2DutchOrderBuilder.d.ts +33 -0
- package/dist/types/src/builder/V3DutchOrderBuilder.d.ts +36 -0
- package/dist/types/src/builder/index.d.ts +7 -0
- package/dist/types/src/constants/v4.d.ts +44 -0
- package/dist/types/src/constants.d.ts +76 -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/HybridAuctionResolver.d.ts +148 -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/OrderQuoterV4.d.ts +150 -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/Reactor.d.ts +207 -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/TokenTransferHook.d.ts +144 -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/HybridAuctionResolver__factory.d.ts +204 -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/OrderQuoterV4__factory.d.ts +262 -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/Reactor__factory.d.ts +313 -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/TokenTransferHook__factory.d.ts +159 -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 +22 -0
- package/dist/types/src/contracts/index.d.ts +45 -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/PriorityOrder.d.ts +121 -0
- package/dist/types/src/order/RelayOrder.d.ts +75 -0
- package/dist/types/src/order/V2DutchOrder.d.ts +103 -0
- package/dist/types/src/order/V3DutchOrder.d.ts +105 -0
- package/dist/types/src/order/index.d.ts +18 -0
- package/dist/types/src/order/types.d.ts +158 -0
- package/dist/types/src/order/v4/HybridOrder.d.ts +83 -0
- package/dist/types/src/order/v4/hashing.d.ts +87 -0
- package/dist/types/src/order/v4/index.d.ts +3 -0
- package/dist/types/src/order/v4/types.d.ts +244 -0
- package/dist/types/src/order/validation.d.ts +24 -0
- package/dist/types/src/trade/DutchOrderTrade.d.ts +33 -0
- package/dist/types/src/trade/HybridOrderTrade.d.ts +61 -0
- package/dist/types/src/trade/PriorityOrderTrade.d.ts +43 -0
- package/dist/types/src/trade/RelayOrderTrade.d.ts +34 -0
- package/dist/types/src/trade/V2DutchOrderTrade.d.ts +33 -0
- package/dist/types/src/trade/V3DutchOrderTrade.d.ts +41 -0
- package/dist/types/src/trade/index.d.ts +6 -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/OrderQuoter.d.ts +144 -0
- package/dist/types/src/utils/OrderValidator.d.ts +19 -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/dutchDecay.d.ts +8 -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 +52 -0
- package/package.json +83 -0
|
@@ -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,120 @@
|
|
|
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
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
69
|
+
}
|
|
70
|
+
catch (_e) {
|
|
71
|
+
return logAcc;
|
|
72
|
+
}
|
|
73
|
+
}, []);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
class UniswapXEventWatcher extends EventWatcher {
|
|
77
|
+
constructor(provider, reactorAddress) {
|
|
78
|
+
const reactor = contracts_1.ExclusiveDutchOrderReactor__factory.connect(reactorAddress, provider);
|
|
79
|
+
super(reactor);
|
|
80
|
+
}
|
|
81
|
+
getFillLogs(fromBlock, toBlock) {
|
|
82
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
83
|
+
return yield this.reactor.queryFilter(this.reactor.filters.Fill(), fromBlock, toBlock);
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
onFill(callback) {
|
|
87
|
+
this.reactor.on(this.reactor.filters.Fill(), (orderHash, filler, swapper, nonce, event) => {
|
|
88
|
+
callback({
|
|
89
|
+
orderHash,
|
|
90
|
+
filler,
|
|
91
|
+
nonce,
|
|
92
|
+
swapper,
|
|
93
|
+
}, event);
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
exports.UniswapXEventWatcher = UniswapXEventWatcher;
|
|
98
|
+
class RelayEventWatcher extends EventWatcher {
|
|
99
|
+
constructor(provider, reactorAddress) {
|
|
100
|
+
const reactor = contracts_1.RelayOrderReactor__factory.connect(reactorAddress, provider);
|
|
101
|
+
super(reactor);
|
|
102
|
+
}
|
|
103
|
+
getFillLogs(fromBlock, toBlock) {
|
|
104
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
105
|
+
return yield this.reactor.queryFilter(this.reactor.filters.Relay(), fromBlock, toBlock);
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
onFill(callback) {
|
|
109
|
+
this.reactor.on(this.reactor.filters.Relay(), (orderHash, filler, swapper, nonce, event) => {
|
|
110
|
+
callback({
|
|
111
|
+
orderHash,
|
|
112
|
+
filler,
|
|
113
|
+
nonce,
|
|
114
|
+
swapper,
|
|
115
|
+
}, event);
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
exports.RelayEventWatcher = RelayEventWatcher;
|
|
120
|
+
//# sourceMappingURL=EventWatcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EventWatcher.js","sourceRoot":"","sources":["../../../../src/utils/EventWatcher.ts"],"names":[],"mappings":";;;;AAKA,mCAA+D;AAE/D,uFAAqD;AACrD,4CAKsB;AAGtB,MAAM,QAAQ,GAAG,UAAU,CAAC;AAqB5B;;GAEG;AACH,MAAe,YAAY;IACzB,YAAsB,OAAiB;QAAjB,YAAO,GAAP,OAAO,CAAU;IAAG,CAAC;IAQrC,aAAa,CACjB,SAAiB,EACjB,OAAgB;;YAEhB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;YACxD,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACrC,CAAC;KAAA;IAEK,WAAW,CAAC,SAAiB,EAAE,OAAgB;;YACnD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;YACxD,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAE3C,4EAA4E;YAC5E,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CACrB,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CACX,GAAG,CAAC,GAAG,CACL,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,qBAAqB,CAAC,GAAG,CAAC,eAAe,CAAC,CACjE,EACH,IAAI,GAAG,EAA+B,CACvC,CAAC;YACF,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAC1C,MAAM,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAChC,OAAO;oBACL,SAAS,EAAE,CAAC,CAAC,SAAS;oBACtB,OAAO,EAAE,CAAC,CAAC,OAAO;oBAClB,MAAM,EAAE,CAAC,CAAC,MAAM;oBAChB,KAAK,EAAE,CAAC,CAAC,KAAK;oBACd,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI;oBAC1B,WAAW,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,WAAW;oBACtC,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,eAAe;iBACtC,CAAC;YACJ,CAAC,CAAC,CAAC;YAEH,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;gBACxB,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;gBAClE,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;gBAEhE,OAAO;oBACL,SAAS,EAAE,IAAI,CAAC,SAAS;oBACzB,OAAO,EAAE,IAAI,CAAC,OAAO;oBACrB,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,WAAW,EAAE,IAAI,CAAC,WAAW;oBAC7B,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,MAAM,EAAE,MAAM;oBACd,OAAO,EAAE,OAAO;iBACjB,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC;KAAA;IAED,iBAAiB,CAAC,IAAW,EAAE,SAAiB;QAC9C,MAAM,cAAc,GAAG,IAAI,cAAK,CAAC,SAAS,CAAC,wBAAY,CAAC,GAAG,CAAC,CAAC;QAC7D,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE;YACjC,IAAI;gBACF,MAAM,SAAS,GAAG,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;gBAC/C,IAAI,SAAS,CAAC,IAAI,KAAK,QAAQ,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE,KAAK,SAAS,EAAE;oBAClE,MAAM,CAAC,IAAI,CAAC;wBACV,KAAK,EAAE,GAAG,CAAC,OAAO;wBAClB,MAAM,EAAE,SAAS,CAAC,IAAI,CAAC,MAAM;qBAC9B,CAAC,CAAC;iBACJ;gBACD,OAAO,MAAM,CAAC;gBACd,6DAA6D;aAC9D;YAAC,OAAO,EAAE,EAAE;gBACX,OAAO,MAAM,CAAC;aACf;QACH,CAAC,EAAE,EAA4C,CAAC,CAAC;IACnD,CAAC;CACF;AAED,MAAa,oBAAqB,SAAQ,YAAwC;IAChF,YAAY,QAAsB,EAAE,cAAsB;QACxD,MAAM,OAAO,GAAG,+CAAmC,CAAC,OAAO,CACzD,cAAc,EACd,QAAQ,CACT,CAAC;QACF,KAAK,CAAC,OAAO,CAAC,CAAC;IACjB,CAAC;IAEK,WAAW,CAAC,SAAiB,EAAE,OAAgB;;YACnD,OAAO,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CACnC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,EAC3B,SAAS,EACT,OAAO,CACR,CAAC;QACJ,CAAC;KAAA;IAED,MAAM,CAAC,QAAoD;QACzD,IAAI,CAAC,OAAO,CAAC,EAAE,CACb,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,EAC3B,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE;YAC3C,QAAQ,CACN;gBACE,SAAS;gBACT,MAAM;gBACN,KAAK;gBACL,OAAO;aACR,EACD,KAAK,CACN,CAAC;QACJ,CAAC,CACF,CAAC;IACJ,CAAC;CACF;AAjCD,oDAiCC;AAED,MAAa,iBAAkB,SAAQ,YAA+B;IACpE,YAAY,QAAsB,EAAE,cAAsB;QACxD,MAAM,OAAO,GAAG,sCAA0B,CAAC,OAAO,CAChD,cAAc,EACd,QAAQ,CACT,CAAC;QACF,KAAK,CAAC,OAAO,CAAC,CAAC;IACjB,CAAC;IAEK,WAAW,CAAC,SAAiB,EAAE,OAAgB;;YACnD,OAAO,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CACnC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,EAC5B,SAAS,EACT,OAAO,CACR,CAAC;QACJ,CAAC;KAAA;IAED,MAAM,CAAC,QAAoD;QACzD,IAAI,CAAC,OAAO,CAAC,EAAE,CACb,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,EAC5B,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE;YAC3C,QAAQ,CACN;gBACE,SAAS;gBACT,MAAM;gBACN,KAAK;gBACL,OAAO;aACR,EACD,KAAK,CACN,CAAC;QACJ,CAAC,CACF,CAAC;IACJ,CAAC;CACF;AAjCD,8CAiCC"}
|
|
@@ -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
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NonceManager.js","sourceRoot":"","sources":["../../../../src/utils/NonceManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { StaticJsonRpcProvider } from "@ethersproject/providers";
|
|
2
|
+
import { OrderQuoter as OrderQuoterContract, OrderQuoterV4 as OrderQuoterV4Contract, RelayOrderReactor } from "../contracts";
|
|
3
|
+
import { CosignedPriorityOrderInfo, CosignedV2DutchOrderInfo, CosignedV3DutchOrderInfo, DutchOrderInfo, Order, RelayOrder, ResolvedRelayFee, TokenAmount, UniswapXOrder, UnsignedPriorityOrderInfo, UnsignedV2DutchOrderInfo, UnsignedV3DutchOrderInfo } from "../order";
|
|
4
|
+
export declare enum OrderValidation {
|
|
5
|
+
Expired = 0,
|
|
6
|
+
NonceUsed = 1,
|
|
7
|
+
InsufficientFunds = 2,
|
|
8
|
+
InvalidSignature = 3,
|
|
9
|
+
InvalidOrderFields = 4,
|
|
10
|
+
UnknownError = 5,
|
|
11
|
+
ValidationFailed = 6,
|
|
12
|
+
ExclusivityPeriod = 7,
|
|
13
|
+
OrderNotFillableYet = 8,
|
|
14
|
+
InvalidGasPrice = 9,
|
|
15
|
+
InvalidCosignature = 10,
|
|
16
|
+
OK = 11
|
|
17
|
+
}
|
|
18
|
+
export interface ResolvedUniswapXOrder {
|
|
19
|
+
input: TokenAmount;
|
|
20
|
+
outputs: TokenAmount[];
|
|
21
|
+
}
|
|
22
|
+
export interface UniswapXOrderQuote {
|
|
23
|
+
validation: OrderValidation;
|
|
24
|
+
quote: ResolvedUniswapXOrder | undefined;
|
|
25
|
+
}
|
|
26
|
+
export interface ResolvedRelayOrder {
|
|
27
|
+
fee: ResolvedRelayFee;
|
|
28
|
+
}
|
|
29
|
+
export interface RelayOrderQuote {
|
|
30
|
+
validation: OrderValidation;
|
|
31
|
+
quote: ResolvedRelayOrder | undefined;
|
|
32
|
+
}
|
|
33
|
+
export type LegacyOrderInfoTypes = DutchOrderInfo | UnsignedV2DutchOrderInfo | CosignedV2DutchOrderInfo | UnsignedV3DutchOrderInfo | CosignedV3DutchOrderInfo | UnsignedPriorityOrderInfo | CosignedPriorityOrderInfo;
|
|
34
|
+
export interface SignedUniswapXOrder {
|
|
35
|
+
order: UniswapXOrder;
|
|
36
|
+
signature: string;
|
|
37
|
+
}
|
|
38
|
+
export interface SignedRelayOrder {
|
|
39
|
+
order: RelayOrder;
|
|
40
|
+
signature: string;
|
|
41
|
+
}
|
|
42
|
+
export interface SignedOrder {
|
|
43
|
+
order: Order;
|
|
44
|
+
signature: string;
|
|
45
|
+
}
|
|
46
|
+
interface OrderQuoter<TOrder, TQuote> {
|
|
47
|
+
quote(order: TOrder): Promise<TQuote>;
|
|
48
|
+
quoteBatch(orders: TOrder[]): Promise<TQuote[]>;
|
|
49
|
+
orderQuoterAddress: string;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* UniswapX order quoter
|
|
53
|
+
*/
|
|
54
|
+
export declare class UniswapXOrderQuoter implements OrderQuoter<SignedUniswapXOrder, UniswapXOrderQuote> {
|
|
55
|
+
protected provider: StaticJsonRpcProvider;
|
|
56
|
+
protected chainId: number;
|
|
57
|
+
protected quoter: OrderQuoterContract;
|
|
58
|
+
constructor(provider: StaticJsonRpcProvider, chainId: number, orderQuoterAddress?: string);
|
|
59
|
+
quote(order: SignedUniswapXOrder): Promise<UniswapXOrderQuote>;
|
|
60
|
+
quoteBatch(orders: SignedUniswapXOrder[]): Promise<UniswapXOrderQuote[]>;
|
|
61
|
+
private getValidations;
|
|
62
|
+
private getMulticallResults;
|
|
63
|
+
get orderQuoterAddress(): string;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Relay order quoter
|
|
67
|
+
*/
|
|
68
|
+
export declare class RelayOrderQuoter implements OrderQuoter<SignedRelayOrder, RelayOrderQuote> {
|
|
69
|
+
protected provider: StaticJsonRpcProvider;
|
|
70
|
+
protected chainId: number;
|
|
71
|
+
protected quoter: RelayOrderReactor;
|
|
72
|
+
private quoteFunctionSelector;
|
|
73
|
+
constructor(provider: StaticJsonRpcProvider, chainId: number, reactorAddress?: string);
|
|
74
|
+
quote(order: SignedRelayOrder): Promise<RelayOrderQuote>;
|
|
75
|
+
quoteBatch(orders: SignedRelayOrder[]): Promise<RelayOrderQuote[]>;
|
|
76
|
+
private getMulticallResults;
|
|
77
|
+
private getValidations;
|
|
78
|
+
get orderQuoterAddress(): string;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* V4 resolved order from quoter
|
|
82
|
+
*/
|
|
83
|
+
export interface ResolvedV4Order {
|
|
84
|
+
input: TokenAmount;
|
|
85
|
+
outputs: TokenAmount[];
|
|
86
|
+
auctionResolver: string;
|
|
87
|
+
witnessTypeString: string;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* V4 order quote result
|
|
91
|
+
*/
|
|
92
|
+
export interface V4OrderQuote {
|
|
93
|
+
validation: OrderValidation;
|
|
94
|
+
quote: ResolvedV4Order | undefined;
|
|
95
|
+
/**
|
|
96
|
+
* Debug info when `validation !== OK`.
|
|
97
|
+
* This is the raw revert data returned by multicall (hex string, usually starting with `0x`).
|
|
98
|
+
*/
|
|
99
|
+
validationErrorData?: string;
|
|
100
|
+
/**
|
|
101
|
+
* Best-effort decoded error text (e.g. `Error(string)` / `Panic(uint256)` / custom error selector).
|
|
102
|
+
*/
|
|
103
|
+
validationErrorText?: string;
|
|
104
|
+
/**
|
|
105
|
+
* Optional debug trace of the underlying `eth_call` performed by the quoter.
|
|
106
|
+
* Captures the JSON-RPC method + params (payload), and the raw RPC result/error (when available).
|
|
107
|
+
* Present only when `validation !== OK`.
|
|
108
|
+
*/
|
|
109
|
+
rpcCalls?: V4RpcCallTrace[];
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Signed V4 order (Hybrid orders)
|
|
113
|
+
*/
|
|
114
|
+
export interface SignedV4Order {
|
|
115
|
+
order: UniswapXOrder;
|
|
116
|
+
signature: string;
|
|
117
|
+
}
|
|
118
|
+
export type V4RpcCallTrace = {
|
|
119
|
+
method: string;
|
|
120
|
+
params: unknown[];
|
|
121
|
+
result?: unknown;
|
|
122
|
+
error?: {
|
|
123
|
+
message?: string;
|
|
124
|
+
code?: unknown;
|
|
125
|
+
data?: unknown;
|
|
126
|
+
body?: unknown;
|
|
127
|
+
error?: unknown;
|
|
128
|
+
};
|
|
129
|
+
};
|
|
130
|
+
/**
|
|
131
|
+
* V4 order quoter for Hybrid orders
|
|
132
|
+
*/
|
|
133
|
+
export declare class V4OrderQuoter implements OrderQuoter<SignedV4Order, V4OrderQuote> {
|
|
134
|
+
protected provider: StaticJsonRpcProvider;
|
|
135
|
+
protected chainId: number;
|
|
136
|
+
protected quoter: OrderQuoterV4Contract;
|
|
137
|
+
constructor(provider: StaticJsonRpcProvider, chainId: number, orderQuoterAddress?: string);
|
|
138
|
+
quote(order: SignedV4Order): Promise<V4OrderQuote>;
|
|
139
|
+
quoteBatch(orders: SignedV4Order[]): Promise<V4OrderQuote[]>;
|
|
140
|
+
private getValidations;
|
|
141
|
+
private getMulticallResults;
|
|
142
|
+
get orderQuoterAddress(): string;
|
|
143
|
+
}
|
|
144
|
+
export {};
|