@juiceswapxyz/uniswapx-sdk 3.0.0 → 3.0.1
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,23 @@
|
|
|
1
|
+
import { Provider } from "@ethersproject/providers";
|
|
2
|
+
import { ChainId } from "@juiceswapxyz/sdk-core";
|
|
3
|
+
import { PERMISSIONED_TOKENS } from "../constants";
|
|
4
|
+
export declare class PermissionedTokenValidator {
|
|
5
|
+
/**
|
|
6
|
+
* Checks if a token is a permissioned token
|
|
7
|
+
* @param tokenAddress The address of the token
|
|
8
|
+
* @returns True if the token is a permissioned token, false otherwise
|
|
9
|
+
*/
|
|
10
|
+
static isPermissionedToken(tokenAddress: string, chainId: ChainId, permissionedTokens?: typeof PERMISSIONED_TOKENS): boolean;
|
|
11
|
+
/**
|
|
12
|
+
* Checks if a transfer would be allowed for a permissioned token
|
|
13
|
+
* @param provider The provider to use for the view call
|
|
14
|
+
* @param tokenAddress The address of the permissioned token
|
|
15
|
+
* @param from The sender's address
|
|
16
|
+
* @param to The recipient's address
|
|
17
|
+
* @param value The amount to transfer (in base units)
|
|
18
|
+
* @returns True if the token is not a permissioned token or the transfer is
|
|
19
|
+
* allowed, false otherwise
|
|
20
|
+
* @throws Will throw an exception if there is an error with the provider
|
|
21
|
+
*/
|
|
22
|
+
static preTransferCheck(provider: Provider, tokenAddress: string, from: string, to: string, value: string, permissionedTokens?: typeof PERMISSIONED_TOKENS): Promise<boolean>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PermissionedTokenValidator = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const constants_1 = require("../constants");
|
|
6
|
+
const constants_2 = require("../constants");
|
|
7
|
+
const contracts_1 = require("../contracts");
|
|
8
|
+
class PermissionedTokenValidator {
|
|
9
|
+
/**
|
|
10
|
+
* Checks if a token is a permissioned token
|
|
11
|
+
* @param tokenAddress The address of the token
|
|
12
|
+
* @returns True if the token is a permissioned token, false otherwise
|
|
13
|
+
*/
|
|
14
|
+
static isPermissionedToken(tokenAddress, chainId, permissionedTokens = constants_1.PERMISSIONED_TOKENS) {
|
|
15
|
+
return permissionedTokens.some(token => token.address.toLowerCase() === tokenAddress.toLowerCase() && token.chainId === chainId);
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Checks if a transfer would be allowed for a permissioned token
|
|
19
|
+
* @param provider The provider to use for the view call
|
|
20
|
+
* @param tokenAddress The address of the permissioned token
|
|
21
|
+
* @param from The sender's address
|
|
22
|
+
* @param to The recipient's address
|
|
23
|
+
* @param value The amount to transfer (in base units)
|
|
24
|
+
* @returns True if the token is not a permissioned token or the transfer is
|
|
25
|
+
* allowed, false otherwise
|
|
26
|
+
* @throws Will throw an exception if there is an error with the provider
|
|
27
|
+
*/
|
|
28
|
+
static preTransferCheck(provider, tokenAddress, from, to, value, permissionedTokens = constants_1.PERMISSIONED_TOKENS) {
|
|
29
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
30
|
+
const token = permissionedTokens.find(token => token.address.toLowerCase() === tokenAddress.toLowerCase());
|
|
31
|
+
// If the token is not in the list, we don't need to check anything
|
|
32
|
+
if (!token) {
|
|
33
|
+
return true;
|
|
34
|
+
}
|
|
35
|
+
// Get the resolved token contract
|
|
36
|
+
let resolvedTokenAddress = tokenAddress;
|
|
37
|
+
if (token.proxyType === constants_2.PermissionedTokenProxyType.Standard) {
|
|
38
|
+
const proxyContract = contracts_1.Proxy__factory.connect(tokenAddress, provider);
|
|
39
|
+
resolvedTokenAddress = yield proxyContract.target();
|
|
40
|
+
}
|
|
41
|
+
else if (token.proxyType === constants_2.PermissionedTokenProxyType.ERC1967) {
|
|
42
|
+
// EIP-1967 implementation slot: bytes32(uint256(keccak256('eip1967.proxy.implementation')) - 1)
|
|
43
|
+
// https://eips.ethereum.org/EIPS/eip-1967
|
|
44
|
+
const implSlot = '0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc';
|
|
45
|
+
const implStorage = yield provider.getStorageAt(tokenAddress, implSlot);
|
|
46
|
+
resolvedTokenAddress = '0x' + implStorage.slice(26);
|
|
47
|
+
}
|
|
48
|
+
// Use the appropriate interface to perform the approval check
|
|
49
|
+
if (token.interface === constants_1.PermissionedTokenInterface.DSTokenInterface) {
|
|
50
|
+
const tokenContract = contracts_1.DSTokenInterface__factory.connect(resolvedTokenAddress, provider);
|
|
51
|
+
const [code, _reason] = yield tokenContract.preTransferCheck(from, to, value);
|
|
52
|
+
return code.toNumber() === 0;
|
|
53
|
+
}
|
|
54
|
+
else if (token.interface === constants_1.PermissionedTokenInterface.ISuperstateTokenV4) {
|
|
55
|
+
const tokenContract = contracts_1.ISuperstateTokenV4__factory.connect(resolvedTokenAddress, provider);
|
|
56
|
+
const [fromAllowed, toAllowed] = yield Promise.all([
|
|
57
|
+
tokenContract.isAllowed(from),
|
|
58
|
+
tokenContract.isAllowed(to),
|
|
59
|
+
]);
|
|
60
|
+
return fromAllowed && toAllowed;
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
throw new Error("Unknown token interface: " + token.interface);
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.PermissionedTokenValidator = PermissionedTokenValidator;
|
|
69
|
+
//# sourceMappingURL=PermissionedTokenValidator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PermissionedTokenValidator.js","sourceRoot":"","sources":["../../../../src/utils/PermissionedTokenValidator.ts"],"names":[],"mappings":";;;;AAGA,4CAA+E;AAC/E,4CAA0D;AAC1D,4CAAwH;AAExH,MAAa,0BAA0B;IAErC;;;;OAIG;IACH,MAAM,CAAC,mBAAmB,CACxB,YAAoB,EACpB,OAAgB,EAChB,qBAAiD,+BAAmB;QAEpE,OAAO,kBAAkB,CAAC,IAAI,CAC5B,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,YAAY,CAAC,WAAW,EAAE,IAAI,KAAK,CAAC,OAAO,KAAK,OAAO,CACjG,CAAC;IACJ,CAAC;IAED;;;;;;;;;;OAUG;IACH,MAAM,CAAO,gBAAgB,CAC3B,QAAkB,EAClB,YAAoB,EACpB,IAAY,EACZ,EAAU,EACV,KAAa,EACb,qBAAiD,+BAAmB;;YAEpE,MAAM,KAAK,GAAG,kBAAkB,CAAC,IAAI,CACnC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,YAAY,CAAC,WAAW,EAAE,CACpE,CAAC;YACF,mEAAmE;YACnE,IAAI,CAAC,KAAK,EAAE;gBACV,OAAO,IAAI,CAAC;aACb;YAED,kCAAkC;YAClC,IAAI,oBAAoB,GAAG,YAAY,CAAC;YACxC,IAAI,KAAK,CAAC,SAAS,KAAK,sCAA0B,CAAC,QAAQ,EAAE;gBAC3D,MAAM,aAAa,GAAG,0BAAc,CAAC,OAAO,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;gBACrE,oBAAoB,GAAG,MAAM,aAAa,CAAC,MAAM,EAAE,CAAC;aACrD;iBACI,IAAI,KAAK,CAAC,SAAS,KAAK,sCAA0B,CAAC,OAAO,EAAE;gBAC/D,gGAAgG;gBAChG,0CAA0C;gBAC1C,MAAM,QAAQ,GACZ,oEAAoE,CAAC;gBACvE,MAAM,WAAW,GAAG,MAAM,QAAQ,CAAC,YAAY,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;gBACxE,oBAAoB,GAAG,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;aACrD;YAED,8DAA8D;YAC9D,IAAI,KAAK,CAAC,SAAS,KAAK,sCAA0B,CAAC,gBAAgB,EAAE;gBACnE,MAAM,aAAa,GAAqB,qCAAyB,CAAC,OAAO,CAAC,oBAAoB,EAAE,QAAQ,CAAC,CAAC;gBAC1G,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,MAAM,aAAa,CAAC,gBAAgB,CAAC,IAAI,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;gBAC9E,OAAO,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;aAC9B;iBACI,IAAI,KAAK,CAAC,SAAS,KAAK,sCAA0B,CAAC,kBAAkB,EAAE;gBAC1E,MAAM,aAAa,GAAG,uCAA2B,CAAC,OAAO,CAAC,oBAAoB,EAAE,QAAQ,CAAC,CAAC;gBAC1F,MAAM,CAAC,WAAW,EAAE,SAAS,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;oBACjD,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC;oBAC7B,aAAa,CAAC,SAAS,CAAC,EAAE,CAAC;iBAC5B,CAAC,CAAC;gBACH,OAAO,WAAW,IAAI,SAAS,CAAC;aACjC;iBACI;gBACH,MAAM,IAAI,KAAK,CAAC,2BAA2B,GAAG,KAAK,CAAC,SAAS,CAAC,CAAA;aAC/D;QACH,CAAC;KAAA;CACF;AA7ED,gEA6EC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { BigNumber } from "ethers";
|
|
2
|
+
import { NonlinearDutchDecay } from "../order";
|
|
3
|
+
declare class NonLinearDutchDecayLib {
|
|
4
|
+
static decay(curve: NonlinearDutchDecay, startAmount: BigNumber, decayStartBlock: number, currentBlock: number): BigNumber;
|
|
5
|
+
static linearDecay(startPoint: number, endPoint: number, currentPoint: number, startAmount: BigNumber, endAmount: BigNumber): BigNumber;
|
|
6
|
+
}
|
|
7
|
+
export { NonLinearDutchDecayLib };
|
|
8
|
+
export interface DutchBlockDecayConfig {
|
|
9
|
+
decayStartBlock: number;
|
|
10
|
+
startAmount: BigNumber;
|
|
11
|
+
relativeBlocks: number[];
|
|
12
|
+
relativeAmounts: bigint[];
|
|
13
|
+
}
|
|
14
|
+
export declare function getBlockDecayedAmount(config: DutchBlockDecayConfig, atBlock: number): BigNumber;
|
|
15
|
+
export declare function getEndAmount(config: Partial<DutchBlockDecayConfig>): BigNumber;
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getEndAmount = exports.getBlockDecayedAmount = exports.NonLinearDutchDecayLib = void 0;
|
|
4
|
+
const ethers_1 = require("ethers");
|
|
5
|
+
/*
|
|
6
|
+
These functions mimic the smart contract functions as closely as possible to ensure that the same results are produced.
|
|
7
|
+
Essentially Solidity translated to TypeScript.
|
|
8
|
+
*/
|
|
9
|
+
function locateArrayPosition(curve, currentRelativeBlock) {
|
|
10
|
+
const relativeBlocks = curve.relativeBlocks;
|
|
11
|
+
let prev = 0;
|
|
12
|
+
let next = 0;
|
|
13
|
+
for (; next < relativeBlocks.length; next++) {
|
|
14
|
+
if (relativeBlocks[next] >= currentRelativeBlock) {
|
|
15
|
+
return [prev, next];
|
|
16
|
+
}
|
|
17
|
+
prev = next;
|
|
18
|
+
}
|
|
19
|
+
return [next - 1, next - 1];
|
|
20
|
+
}
|
|
21
|
+
class NonLinearDutchDecayLib {
|
|
22
|
+
static decay(curve, startAmount, decayStartBlock, currentBlock) {
|
|
23
|
+
// mismatch of relativeAmounts and relativeBlocks
|
|
24
|
+
if (curve.relativeAmounts.length > 16) {
|
|
25
|
+
throw new Error("InvalidDecayCurve");
|
|
26
|
+
}
|
|
27
|
+
// handle current block before decay or no decay
|
|
28
|
+
if (decayStartBlock >= currentBlock || curve.relativeAmounts.length === 0) {
|
|
29
|
+
return startAmount;
|
|
30
|
+
}
|
|
31
|
+
const blockDelta = currentBlock - decayStartBlock;
|
|
32
|
+
// Special case for when we need to use the decayStartBlock (0)
|
|
33
|
+
if (curve.relativeBlocks[0] > blockDelta) {
|
|
34
|
+
return this.linearDecay(0, curve.relativeBlocks[0], blockDelta, startAmount, startAmount.sub(curve.relativeAmounts[0].toString()));
|
|
35
|
+
}
|
|
36
|
+
// the current pos is within or after the curve
|
|
37
|
+
const [prev, next] = locateArrayPosition(curve, blockDelta);
|
|
38
|
+
//relativeAmounts holds BigInts so we can't directly subtract without conversion
|
|
39
|
+
const lastAmount = startAmount.sub(curve.relativeAmounts[prev].toString());
|
|
40
|
+
const nextAmount = startAmount.sub(curve.relativeAmounts[next].toString());
|
|
41
|
+
return this.linearDecay(curve.relativeBlocks[prev], curve.relativeBlocks[next], blockDelta, lastAmount, nextAmount);
|
|
42
|
+
}
|
|
43
|
+
static linearDecay(startPoint, endPoint, currentPoint, startAmount, endAmount) {
|
|
44
|
+
if (currentPoint >= endPoint) {
|
|
45
|
+
return endAmount;
|
|
46
|
+
}
|
|
47
|
+
const elapsed = ethers_1.BigNumber.from(currentPoint - startPoint);
|
|
48
|
+
const duration = ethers_1.BigNumber.from(endPoint - startPoint);
|
|
49
|
+
let delta;
|
|
50
|
+
if (endAmount.lt(startAmount)) {
|
|
51
|
+
delta = ethers_1.BigNumber.from(0).sub((startAmount.sub(endAmount)).mul(elapsed).div(duration)); // mulDivDown in contract
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
delta = (endAmount.sub(startAmount)).mul(elapsed).div(duration); // mulDivDown in contract
|
|
55
|
+
}
|
|
56
|
+
return startAmount.add(delta);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
exports.NonLinearDutchDecayLib = NonLinearDutchDecayLib;
|
|
60
|
+
function getBlockDecayedAmount(config, atBlock) {
|
|
61
|
+
const { decayStartBlock, startAmount, relativeBlocks, relativeAmounts } = config;
|
|
62
|
+
return NonLinearDutchDecayLib.decay({ relativeAmounts, relativeBlocks }, startAmount, decayStartBlock, atBlock);
|
|
63
|
+
}
|
|
64
|
+
exports.getBlockDecayedAmount = getBlockDecayedAmount;
|
|
65
|
+
function getEndAmount(config) {
|
|
66
|
+
const { startAmount, relativeAmounts } = config;
|
|
67
|
+
if (!startAmount || !relativeAmounts) {
|
|
68
|
+
throw new Error("Invalid config for getting V3 decay end amount");
|
|
69
|
+
}
|
|
70
|
+
return startAmount.sub(relativeAmounts[relativeAmounts.length - 1].toString());
|
|
71
|
+
}
|
|
72
|
+
exports.getEndAmount = getEndAmount;
|
|
73
|
+
//# sourceMappingURL=dutchBlockDecay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dutchBlockDecay.js","sourceRoot":"","sources":["../../../../src/utils/dutchBlockDecay.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const ethers_1 = require("ethers");
|
|
4
|
+
const dutchBlockDecay_1 = require("./dutchBlockDecay");
|
|
5
|
+
describe("NonLinearDutchDecayLib", () => {
|
|
6
|
+
describe("linearDecay", () => {
|
|
7
|
+
it("Simple linearDecay", () => {
|
|
8
|
+
const result = dutchBlockDecay_1.NonLinearDutchDecayLib.linearDecay(0, 10, 5, ethers_1.BigNumber.from(100), ethers_1.BigNumber.from(50));
|
|
9
|
+
expect(result.toString()).toEqual('75');
|
|
10
|
+
});
|
|
11
|
+
it("Test for mulDivDown for endAmount < startAmount", () => {
|
|
12
|
+
const result = dutchBlockDecay_1.NonLinearDutchDecayLib.linearDecay(0, 10, 5, ethers_1.BigNumber.from(100), ethers_1.BigNumber.from(75));
|
|
13
|
+
expect(result.toString()).toEqual('88'); //If we successfully emulated mulDivDown then this is 88.
|
|
14
|
+
});
|
|
15
|
+
it("Simple linearDecay but with endAmount > startAmount", () => {
|
|
16
|
+
const result = dutchBlockDecay_1.NonLinearDutchDecayLib.linearDecay(0, 10, 5, ethers_1.BigNumber.from(100), ethers_1.BigNumber.from(120));
|
|
17
|
+
expect(result.toString()).toEqual('110');
|
|
18
|
+
});
|
|
19
|
+
it("Test for mulDivDown for endAmount > startAmount", () => {
|
|
20
|
+
const result = dutchBlockDecay_1.NonLinearDutchDecayLib.linearDecay(0, 10, 5, ethers_1.BigNumber.from(100), ethers_1.BigNumber.from(125));
|
|
21
|
+
//if we successfully emulated mulDivDown then this is 112
|
|
22
|
+
expect(result.toString()).toEqual('112');
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
describe("decay", () => {
|
|
26
|
+
it("Returns startAmount if decay hasnt started", () => {
|
|
27
|
+
const test_payload = {
|
|
28
|
+
curve: {
|
|
29
|
+
relativeBlocks: [1, 2, 3, 4, 5],
|
|
30
|
+
relativeAmounts: [0, 10, 20, 30, 40].map(BigInt),
|
|
31
|
+
},
|
|
32
|
+
startAmount: ethers_1.BigNumber.from(100),
|
|
33
|
+
decayStartBlock: 0,
|
|
34
|
+
currentBlock: 0,
|
|
35
|
+
};
|
|
36
|
+
const result = dutchBlockDecay_1.NonLinearDutchDecayLib.decay(test_payload.curve, test_payload.startAmount, test_payload.decayStartBlock, test_payload.currentBlock);
|
|
37
|
+
expect(result.toString()).toEqual('100');
|
|
38
|
+
});
|
|
39
|
+
it("Correctly calculates non-rounding decay", () => {
|
|
40
|
+
const test_payload = {
|
|
41
|
+
curve: {
|
|
42
|
+
relativeBlocks: [4],
|
|
43
|
+
relativeAmounts: [40].map(BigInt),
|
|
44
|
+
},
|
|
45
|
+
startAmount: ethers_1.BigNumber.from(100),
|
|
46
|
+
decayStartBlock: 0,
|
|
47
|
+
currentBlock: 2,
|
|
48
|
+
};
|
|
49
|
+
const result = dutchBlockDecay_1.NonLinearDutchDecayLib.decay(test_payload.curve, test_payload.startAmount, test_payload.decayStartBlock, test_payload.currentBlock);
|
|
50
|
+
expect(result.toString()).toEqual('80');
|
|
51
|
+
});
|
|
52
|
+
// Add a rounding decay once we clarify mulDivDown/mulDivUp
|
|
53
|
+
it("Correctly calculates non-rounding decay with multiple points", () => {
|
|
54
|
+
const test_payload = {
|
|
55
|
+
curve: {
|
|
56
|
+
relativeBlocks: [4, 6],
|
|
57
|
+
relativeAmounts: [40, 20].map(BigInt),
|
|
58
|
+
},
|
|
59
|
+
startAmount: ethers_1.BigNumber.from(100),
|
|
60
|
+
decayStartBlock: 0,
|
|
61
|
+
currentBlock: 5,
|
|
62
|
+
};
|
|
63
|
+
const result = dutchBlockDecay_1.NonLinearDutchDecayLib.decay(test_payload.curve, test_payload.startAmount, test_payload.decayStartBlock, test_payload.currentBlock);
|
|
64
|
+
expect(result.toString()).toEqual('70');
|
|
65
|
+
});
|
|
66
|
+
it("Correctly calculates non-rounding negative decay", () => {
|
|
67
|
+
const test_payload = {
|
|
68
|
+
curve: {
|
|
69
|
+
relativeBlocks: [4],
|
|
70
|
+
relativeAmounts: [BigInt(-40)],
|
|
71
|
+
},
|
|
72
|
+
startAmount: ethers_1.BigNumber.from(100),
|
|
73
|
+
decayStartBlock: 0,
|
|
74
|
+
currentBlock: 2,
|
|
75
|
+
};
|
|
76
|
+
const result = dutchBlockDecay_1.NonLinearDutchDecayLib.decay(test_payload.curve, test_payload.startAmount, test_payload.decayStartBlock, test_payload.currentBlock);
|
|
77
|
+
expect(result.toString()).toEqual('120');
|
|
78
|
+
});
|
|
79
|
+
it("Correctly calculates non-rounding negative decay with multiple points", () => {
|
|
80
|
+
const test_payload = {
|
|
81
|
+
curve: {
|
|
82
|
+
relativeBlocks: [4, 6],
|
|
83
|
+
relativeAmounts: [BigInt(-40), BigInt(-20)],
|
|
84
|
+
},
|
|
85
|
+
startAmount: ethers_1.BigNumber.from(100),
|
|
86
|
+
decayStartBlock: 0,
|
|
87
|
+
currentBlock: 5,
|
|
88
|
+
};
|
|
89
|
+
const result = dutchBlockDecay_1.NonLinearDutchDecayLib.decay(test_payload.curve, test_payload.startAmount, test_payload.decayStartBlock, test_payload.currentBlock);
|
|
90
|
+
expect(result.toString()).toEqual('130');
|
|
91
|
+
});
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
//# sourceMappingURL=dutchBlockDecay.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dutchBlockDecay.test.js","sourceRoot":"","sources":["../../../../src/utils/dutchBlockDecay.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { BigNumber } from "ethers";
|
|
2
|
+
export interface DutchDecayConfig {
|
|
3
|
+
startAmount: BigNumber;
|
|
4
|
+
endAmount: BigNumber;
|
|
5
|
+
decayStartTime: number;
|
|
6
|
+
decayEndTime: number;
|
|
7
|
+
}
|
|
8
|
+
export declare function getDecayedAmount(config: DutchDecayConfig, atTime?: number): BigNumber;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getDecayedAmount = void 0;
|
|
4
|
+
function getDecayedAmount(config, atTime = Math.floor(Date.now() / 1000)) {
|
|
5
|
+
const { startAmount, endAmount, decayStartTime, decayEndTime } = config;
|
|
6
|
+
// decay is over, return the ending amount
|
|
7
|
+
if (decayEndTime <= atTime) {
|
|
8
|
+
return endAmount;
|
|
9
|
+
}
|
|
10
|
+
// decay hasnt started, return the starting amount
|
|
11
|
+
if (decayStartTime >= atTime) {
|
|
12
|
+
return startAmount;
|
|
13
|
+
}
|
|
14
|
+
// no decay, just return the static amount
|
|
15
|
+
if (startAmount.eq(endAmount)) {
|
|
16
|
+
return startAmount;
|
|
17
|
+
}
|
|
18
|
+
const duration = decayEndTime - decayStartTime;
|
|
19
|
+
const elapsed = atTime - decayStartTime;
|
|
20
|
+
if (startAmount.gt(endAmount)) {
|
|
21
|
+
// decaying downward
|
|
22
|
+
const decay = startAmount.sub(endAmount).mul(elapsed).div(duration);
|
|
23
|
+
return startAmount.sub(decay);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
// decaying upward
|
|
27
|
+
const decay = endAmount.sub(startAmount).mul(elapsed).div(duration);
|
|
28
|
+
return startAmount.add(decay);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
exports.getDecayedAmount = getDecayedAmount;
|
|
32
|
+
//# sourceMappingURL=dutchDecay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dutchDecay.js","sourceRoot":"","sources":["../../../../src/utils/dutchDecay.ts"],"names":[],"mappings":";;;AASA,SAAgB,gBAAgB,CAC9B,MAAwB,EACxB,SAAiB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;IAE9C,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,cAAc,EAAE,YAAY,EAAE,GAAG,MAAM,CAAC;IAExE,0CAA0C;IAC1C,IAAI,YAAY,IAAI,MAAM,EAAE;QAC1B,OAAO,SAAS,CAAC;KAClB;IAED,kDAAkD;IAClD,IAAI,cAAc,IAAI,MAAM,EAAE;QAC5B,OAAO,WAAW,CAAC;KACpB;IAED,0CAA0C;IAC1C,IAAI,WAAW,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE;QAC7B,OAAO,WAAW,CAAC;KACpB;IAED,MAAM,QAAQ,GAAG,YAAY,GAAG,cAAc,CAAC;IAC/C,MAAM,OAAO,GAAG,MAAM,GAAG,cAAc,CAAC;IACxC,IAAI,WAAW,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE;QAC7B,oBAAoB;QACpB,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACpE,OAAO,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;KAC/B;SAAM;QACL,kBAAkB;QAClB,MAAM,KAAK,GAAG,SAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACpE,OAAO,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;KAC/B;AACH,CAAC;AAhCD,4CAgCC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const ethers_1 = require("ethers");
|
|
4
|
+
const dutchDecay_1 = require("./dutchDecay");
|
|
5
|
+
describe("Dutch Decay", () => {
|
|
6
|
+
it("Returns endAmount if decay is over", () => {
|
|
7
|
+
const endAmount = ethers_1.BigNumber.from("100000000");
|
|
8
|
+
expect((0, dutchDecay_1.getDecayedAmount)({
|
|
9
|
+
startAmount: endAmount.div(2),
|
|
10
|
+
endAmount: endAmount,
|
|
11
|
+
decayStartTime: 1,
|
|
12
|
+
decayEndTime: 10,
|
|
13
|
+
}, 11)).toEqual(endAmount);
|
|
14
|
+
});
|
|
15
|
+
it("Returns endAmount if eq to decayEndTime", () => {
|
|
16
|
+
const endAmount = ethers_1.BigNumber.from("100000000");
|
|
17
|
+
expect((0, dutchDecay_1.getDecayedAmount)({
|
|
18
|
+
startAmount: endAmount.div(2),
|
|
19
|
+
endAmount: endAmount,
|
|
20
|
+
decayStartTime: 1,
|
|
21
|
+
decayEndTime: 10,
|
|
22
|
+
}, 10)).toEqual(endAmount);
|
|
23
|
+
});
|
|
24
|
+
it("Returns startAmount if decay hasnt started", () => {
|
|
25
|
+
const startAmount = ethers_1.BigNumber.from("100000000");
|
|
26
|
+
expect((0, dutchDecay_1.getDecayedAmount)({
|
|
27
|
+
startAmount: startAmount,
|
|
28
|
+
endAmount: startAmount.mul(2),
|
|
29
|
+
decayStartTime: 10,
|
|
30
|
+
decayEndTime: 100,
|
|
31
|
+
}, 9)).toEqual(startAmount);
|
|
32
|
+
});
|
|
33
|
+
it("Returns startAmount if eq to decayStartTime", () => {
|
|
34
|
+
const startAmount = ethers_1.BigNumber.from("100000000");
|
|
35
|
+
expect((0, dutchDecay_1.getDecayedAmount)({
|
|
36
|
+
startAmount: startAmount,
|
|
37
|
+
endAmount: startAmount.mul(2),
|
|
38
|
+
decayStartTime: 10,
|
|
39
|
+
decayEndTime: 100,
|
|
40
|
+
}, 10)).toEqual(startAmount);
|
|
41
|
+
});
|
|
42
|
+
it("Decays linearly upwards", () => {
|
|
43
|
+
const startAmount = ethers_1.BigNumber.from("100000000");
|
|
44
|
+
expect((0, dutchDecay_1.getDecayedAmount)({
|
|
45
|
+
startAmount: startAmount,
|
|
46
|
+
endAmount: startAmount.mul(2),
|
|
47
|
+
decayStartTime: 10,
|
|
48
|
+
decayEndTime: 20,
|
|
49
|
+
}, 15)).toEqual(startAmount.mul(3).div(2));
|
|
50
|
+
});
|
|
51
|
+
it("Decays linearly downwrads", () => {
|
|
52
|
+
const endAmount = ethers_1.BigNumber.from("100000000");
|
|
53
|
+
expect((0, dutchDecay_1.getDecayedAmount)({
|
|
54
|
+
startAmount: endAmount.mul(2),
|
|
55
|
+
endAmount: endAmount,
|
|
56
|
+
decayStartTime: 10,
|
|
57
|
+
decayEndTime: 20,
|
|
58
|
+
}, 15)).toEqual(endAmount.mul(3).div(2));
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
//# sourceMappingURL=dutchDecay.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dutchDecay.test.js","sourceRoot":"","sources":["../../../../src/utils/dutchDecay.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { OrderType } from "../constants";
|
|
2
|
+
export * from "./OrderValidator";
|
|
3
|
+
export * from "./NonceManager";
|
|
4
|
+
export * from "./OrderQuoter";
|
|
5
|
+
export * from "./EventWatcher";
|
|
6
|
+
export * from "./multicall";
|
|
7
|
+
export * from "./dutchDecay";
|
|
8
|
+
export * from "./order";
|
|
9
|
+
export * from "./PermissionedTokenValidator";
|
|
10
|
+
export declare function stripHexPrefix(a: string): string;
|
|
11
|
+
export declare function getPermit2(chainId: number, permit2Address?: string): string;
|
|
12
|
+
export declare function getReactor(chainId: number, orderType: OrderType, reactorAddress?: string): string;
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getReactor = exports.getPermit2 = exports.stripHexPrefix = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const constants_1 = require("../constants");
|
|
6
|
+
const errors_1 = require("../errors");
|
|
7
|
+
tslib_1.__exportStar(require("./OrderValidator"), exports);
|
|
8
|
+
tslib_1.__exportStar(require("./NonceManager"), exports);
|
|
9
|
+
tslib_1.__exportStar(require("./OrderQuoter"), exports);
|
|
10
|
+
tslib_1.__exportStar(require("./EventWatcher"), exports);
|
|
11
|
+
tslib_1.__exportStar(require("./multicall"), exports);
|
|
12
|
+
tslib_1.__exportStar(require("./dutchDecay"), exports);
|
|
13
|
+
tslib_1.__exportStar(require("./order"), exports);
|
|
14
|
+
tslib_1.__exportStar(require("./PermissionedTokenValidator"), exports);
|
|
15
|
+
function stripHexPrefix(a) {
|
|
16
|
+
if (a.startsWith("0x")) {
|
|
17
|
+
return a.slice(2);
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
return a;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.stripHexPrefix = stripHexPrefix;
|
|
24
|
+
function getPermit2(chainId, permit2Address) {
|
|
25
|
+
if (permit2Address) {
|
|
26
|
+
return permit2Address;
|
|
27
|
+
}
|
|
28
|
+
else if (constants_1.PERMIT2_MAPPING[chainId]) {
|
|
29
|
+
return constants_1.PERMIT2_MAPPING[chainId];
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
throw new errors_1.MissingConfiguration("permit2", chainId.toString());
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
exports.getPermit2 = getPermit2;
|
|
36
|
+
function getReactor(chainId, orderType, reactorAddress) {
|
|
37
|
+
const mappedReactorAddress = constants_1.REACTOR_ADDRESS_MAPPING[chainId]
|
|
38
|
+
? constants_1.REACTOR_ADDRESS_MAPPING[chainId][orderType]
|
|
39
|
+
: undefined;
|
|
40
|
+
if (reactorAddress) {
|
|
41
|
+
return reactorAddress;
|
|
42
|
+
}
|
|
43
|
+
else if (mappedReactorAddress) {
|
|
44
|
+
return mappedReactorAddress;
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
throw new errors_1.MissingConfiguration("reactor", chainId.toString());
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
exports.getReactor = getReactor;
|
|
51
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utils/index.ts"],"names":[],"mappings":";;;;AAAA,4CAIsB;AACtB,sCAAiD;AAEjD,2DAAiC;AACjC,yDAA+B;AAC/B,wDAA8B;AAC9B,yDAA+B;AAC/B,sDAA4B;AAC5B,uDAA6B;AAC7B,kDAAwB;AACxB,uEAA6C;AAE7C,SAAgB,cAAc,CAAC,CAAS;IACtC,IAAI,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;QACtB,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KACnB;SAAM;QACL,OAAO,CAAC,CAAC;KACV;AACH,CAAC;AAND,wCAMC;AAED,SAAgB,UAAU,CAAC,OAAe,EAAE,cAAuB;IACjE,IAAI,cAAc,EAAE;QAClB,OAAO,cAAc,CAAC;KACvB;SAAM,IAAI,2BAAe,CAAC,OAAO,CAAC,EAAE;QACnC,OAAO,2BAAe,CAAC,OAAO,CAAC,CAAC;KACjC;SAAM;QACL,MAAM,IAAI,6BAAoB,CAAC,SAAS,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;KAC/D;AACH,CAAC;AARD,gCAQC;AAED,SAAgB,UAAU,CACxB,OAAe,EACf,SAAoB,EACpB,cAAuB;IAEvB,MAAM,oBAAoB,GAAG,mCAAuB,CAAC,OAAO,CAAC;QAC3D,CAAC,CAAC,mCAAuB,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;QAC7C,CAAC,CAAC,SAAS,CAAC;IACd,IAAI,cAAc,EAAE;QAClB,OAAO,cAAc,CAAC;KACvB;SAAM,IAAI,oBAAoB,EAAE;QAC/B,OAAO,oBAAoB,CAAC;KAC7B;SAAM;QACL,MAAM,IAAI,6BAAoB,CAAC,SAAS,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;KAC/D;AACH,CAAC;AAfD,gCAeC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Interface } from "@ethersproject/abi";
|
|
2
|
+
import { StaticJsonRpcProvider } from "@ethersproject/providers";
|
|
3
|
+
import { BlockOverrides } from "../order";
|
|
4
|
+
export type MulticallParams = {
|
|
5
|
+
contractInterface: Interface;
|
|
6
|
+
functionName: string;
|
|
7
|
+
};
|
|
8
|
+
export type MulticallSameContractParams<TFunctionParams> = MulticallParams & {
|
|
9
|
+
address: string;
|
|
10
|
+
functionParams: TFunctionParams[];
|
|
11
|
+
};
|
|
12
|
+
export type MulticallSameFunctionParams<TFunctionParams> = MulticallParams & {
|
|
13
|
+
addresses: string[];
|
|
14
|
+
functionParam: TFunctionParams;
|
|
15
|
+
};
|
|
16
|
+
export type MulticallResult = {
|
|
17
|
+
success: boolean;
|
|
18
|
+
returnData: string;
|
|
19
|
+
};
|
|
20
|
+
type Call = {
|
|
21
|
+
target: string;
|
|
22
|
+
callData: string;
|
|
23
|
+
};
|
|
24
|
+
export declare function multicallSameContractManyFunctions<TFunctionParams extends any[] | undefined>(provider: StaticJsonRpcProvider, params: MulticallSameContractParams<TFunctionParams>, stateOverrrides?: {
|
|
25
|
+
code?: string;
|
|
26
|
+
state?: any;
|
|
27
|
+
}, blockOverrides?: BlockOverrides): Promise<MulticallResult[]>;
|
|
28
|
+
export declare function multicallSameFunctionManyContracts<TFunctionParams extends any[] | undefined>(provider: StaticJsonRpcProvider, params: MulticallSameFunctionParams<TFunctionParams>, stateOverrrides?: {
|
|
29
|
+
code?: string;
|
|
30
|
+
state?: any;
|
|
31
|
+
}, blockOverrides?: BlockOverrides): Promise<MulticallResult[]>;
|
|
32
|
+
export declare function multicall(provider: StaticJsonRpcProvider, calls: Call[], stateOverrides?: {
|
|
33
|
+
code?: string;
|
|
34
|
+
state?: any;
|
|
35
|
+
}, blockOverrides?: BlockOverrides): Promise<MulticallResult[]>;
|
|
36
|
+
export {};
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Uses deployless multicall to fetch responses and errors for multiple calls at once
|
|
3
|
+
// https://github.com/Destiner/deployless-multicall
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.multicall = exports.multicallSameFunctionManyContracts = exports.multicallSameContractManyFunctions = void 0;
|
|
6
|
+
const tslib_1 = require("tslib");
|
|
7
|
+
const abi_1 = require("@ethersproject/abi");
|
|
8
|
+
const bytes_1 = require("@ethersproject/bytes");
|
|
9
|
+
const ethers_1 = require("ethers");
|
|
10
|
+
const deploylessMulticall2_json_1 = tslib_1.__importDefault(require("../../abis/deploylessMulticall2.json"));
|
|
11
|
+
const multicall2_json_1 = tslib_1.__importDefault(require("../../abis/multicall2.json"));
|
|
12
|
+
const constants_1 = require("../constants");
|
|
13
|
+
const contracts_1 = require("../contracts");
|
|
14
|
+
const DEPLOYLESS_MULTICALL_BYTECODE = "0x608060405234801561001057600080fd5b5060405161087538038061087583398181016040528101906100329190610666565b6000815167ffffffffffffffff81111561004f5761004e610358565b5b60405190808252806020026020018201604052801561008857816020015b6100756102da565b81526020019060019003908161006d5790505b50905060005b82518110156101d3576000808483815181106100ad576100ac6106c2565b5b60200260200101516000015173ffffffffffffffffffffffffffffffffffffffff168584815181106100e2576100e16106c2565b5b6020026020010151602001516040516100fb9190610738565b6000604051808303816000865af19150503d8060008114610138576040519150601f19603f3d011682016040523d82523d6000602084013e61013d565b606091505b509150915085156101895781610188576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161017f906107d2565b60405180910390fd5b5b60405180604001604052808315158152602001828152508484815181106101b3576101b26106c2565b5b6020026020010181905250505080806101cb9061082b565b91505061008e565b50602081516040028260405103030160408160405103036001835111156102535760005b8351811015610251578060200260208501018160200260400183018261021f57855160200281525b6000831115610244576020808303510151602083510151038060208303510180835250505b50506001810190506101f7565b505b60005b8351811015610281578060200260208501018051516040602083510151035250600181019050610256565b5060005b83518110156102ae57806020026020850101604060208083510151035250600181019050610285565b506001835114156102cb5760208301604082018451602002815250505b60208152825160208201528181f35b6040518060400160405280600015158152602001606081525090565b6000604051905090565b600080fd5b600080fd5b60008115159050919050565b61031f8161030a565b811461032a57600080fd5b50565b60008151905061033c81610316565b92915050565b600080fd5b6000601f19601f8301169050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b61039082610347565b810181811067ffffffffffffffff821117156103af576103ae610358565b5b80604052505050565b60006103c26102f6565b90506103ce8282610387565b919050565b600067ffffffffffffffff8211156103ee576103ed610358565b5b602082029050602081019050919050565b600080fd5b600080fd5b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b60006104398261040e565b9050919050565b6104498161042e565b811461045457600080fd5b50565b60008151905061046681610440565b92915050565b600080fd5b600067ffffffffffffffff82111561048c5761048b610358565b5b61049582610347565b9050602081019050919050565b60005b838110156104c05780820151818401526020810190506104a5565b838111156104cf576000848401525b50505050565b60006104e86104e384610471565b6103b8565b9050828152602081018484840111156105045761050361046c565b5b61050f8482856104a2565b509392505050565b600082601f83011261052c5761052b610342565b5b815161053c8482602086016104d5565b91505092915050565b60006040828403121561055b5761055a610404565b5b61056560406103b8565b9050600061057584828501610457565b600083015250602082015167ffffffffffffffff81111561059957610598610409565b5b6105a584828501610517565b60208301525092915050565b60006105c46105bf846103d3565b6103b8565b905080838252602082019050602084028301858111156105e7576105e66103ff565b5b835b8181101561062e57805167ffffffffffffffff81111561060c5761060b610342565b5b8086016106198982610545565b855260208501945050506020810190506105e9565b5050509392505050565b600082601f83011261064d5761064c610342565b5b815161065d8482602086016105b1565b91505092915050565b6000806040838503121561067d5761067c610300565b5b600061068b8582860161032d565b925050602083015167ffffffffffffffff8111156106ac576106ab610305565b5b6106b885828601610638565b9150509250929050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b600081519050919050565b600081905092915050565b6000610712826106f1565b61071c81856106fc565b935061072c8185602086016104a2565b80840191505092915050565b60006107448284610707565b915081905092915050565b600082825260208201905092915050565b7f4d756c746963616c6c32206167677265676174653a2063616c6c206661696c6560008201527f6400000000000000000000000000000000000000000000000000000000000000602082015250565b60006107bc60218361074f565b91506107c782610760565b604082019050919050565b600060208201905081810360008301526107eb816107af565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6000819050919050565b600061083682610821565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff821415610869576108686107f2565b5b60018201905091905056fe";
|
|
15
|
+
// Perform multiple on-chain calls in a single http request
|
|
16
|
+
// return all results including errors
|
|
17
|
+
// Uses deployless method to function properly even on chains with no multicall contract deployed
|
|
18
|
+
function multicallSameContractManyFunctions(provider, params, stateOverrrides, blockOverrides) {
|
|
19
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
20
|
+
const { address, contractInterface, functionName, functionParams } = params;
|
|
21
|
+
const fragment = contractInterface.getFunction(functionName);
|
|
22
|
+
const calls = functionParams.map((functionParam) => {
|
|
23
|
+
const callData = contractInterface.encodeFunctionData(fragment, functionParam);
|
|
24
|
+
return {
|
|
25
|
+
target: address,
|
|
26
|
+
callData,
|
|
27
|
+
};
|
|
28
|
+
});
|
|
29
|
+
return multicall(provider, calls, stateOverrrides, blockOverrides);
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
exports.multicallSameContractManyFunctions = multicallSameContractManyFunctions;
|
|
33
|
+
function multicallSameFunctionManyContracts(provider, params, stateOverrrides, blockOverrides) {
|
|
34
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
35
|
+
const { addresses, contractInterface, functionName, functionParam } = params;
|
|
36
|
+
const fragment = contractInterface.getFunction(functionName);
|
|
37
|
+
const callData = contractInterface.encodeFunctionData(fragment, functionParam);
|
|
38
|
+
const calls = addresses.map((address) => {
|
|
39
|
+
return {
|
|
40
|
+
target: address,
|
|
41
|
+
callData,
|
|
42
|
+
};
|
|
43
|
+
});
|
|
44
|
+
return multicall(provider, calls, stateOverrrides, blockOverrides);
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
exports.multicallSameFunctionManyContracts = multicallSameFunctionManyContracts;
|
|
48
|
+
function multicall(provider, calls, stateOverrides, blockOverrides) {
|
|
49
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
50
|
+
const chainId = (yield provider.getNetwork()).chainId;
|
|
51
|
+
const code = yield provider.getCode((0, constants_1.multicallAddressOn)(chainId));
|
|
52
|
+
let response;
|
|
53
|
+
if (code.length > 2) {
|
|
54
|
+
const multicall = contracts_1.Multicall2__factory.connect((0, constants_1.multicallAddressOn)(chainId), provider);
|
|
55
|
+
const params = [
|
|
56
|
+
{
|
|
57
|
+
from: ethers_1.ethers.constants.AddressZero,
|
|
58
|
+
to: multicall.address,
|
|
59
|
+
data: multicall.interface.encodeFunctionData("tryAggregate", [false, calls]),
|
|
60
|
+
},
|
|
61
|
+
'latest',
|
|
62
|
+
(stateOverrides ? stateOverrides : {}),
|
|
63
|
+
];
|
|
64
|
+
if (blockOverrides)
|
|
65
|
+
params.push(blockOverrides);
|
|
66
|
+
response = yield provider.send("eth_call", params);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
const deploylessInterface = new abi_1.Interface(deploylessMulticall2_json_1.default);
|
|
70
|
+
const args = deploylessInterface.encodeDeploy([false, calls]);
|
|
71
|
+
const data = (0, bytes_1.hexConcat)([DEPLOYLESS_MULTICALL_BYTECODE, args]);
|
|
72
|
+
const params = [
|
|
73
|
+
{
|
|
74
|
+
from: ethers_1.ethers.constants.AddressZero,
|
|
75
|
+
to: ethers_1.ethers.constants.AddressZero,
|
|
76
|
+
data,
|
|
77
|
+
},
|
|
78
|
+
'latest',
|
|
79
|
+
(stateOverrides ? stateOverrides : {}),
|
|
80
|
+
];
|
|
81
|
+
if (blockOverrides)
|
|
82
|
+
params.push(blockOverrides);
|
|
83
|
+
response = yield provider.send("eth_call", params);
|
|
84
|
+
}
|
|
85
|
+
const multicallInterface = new abi_1.Interface(multicall2_json_1.default);
|
|
86
|
+
return multicallInterface.decodeFunctionResult("tryAggregate", response)
|
|
87
|
+
.returnData;
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
exports.multicall = multicall;
|
|
91
|
+
//# sourceMappingURL=multicall.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multicall.js","sourceRoot":"","sources":["../../../../src/utils/multicall.ts"],"names":[],"mappings":"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"}
|