@arbitrum/nitro-contracts 2.1.1-beta.0 → 3.0.0-alpha.1
Sign up to get free protection for your applications and to get access to all the features.
- package/build/contracts/@openzeppelin/contracts/access/Ownable.sol/Ownable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/interfaces/draft-IERC1822.sol/IERC1822Proxiable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol/ERC1967Proxy.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol/ERC1967Proxy.json +2 -2
- package/build/contracts/@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol/ERC1967Upgrade.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/proxy/Proxy.sol/Proxy.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/proxy/beacon/IBeacon.sol/IBeacon.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/proxy/beacon/UpgradeableBeacon.sol/UpgradeableBeacon.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/proxy/beacon/UpgradeableBeacon.sol/UpgradeableBeacon.json +2 -2
- package/build/contracts/@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol/ProxyAdmin.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol/ProxyAdmin.json +2 -2
- package/build/contracts/@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol/TransparentUpgradeableProxy.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol/TransparentUpgradeableProxy.json +2 -2
- package/build/contracts/@openzeppelin/contracts/proxy/utils/UUPSUpgradeable.sol/UUPSUpgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/security/ReentrancyGuard.sol/ReentrancyGuard.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/token/ERC20/ERC20.sol/ERC20.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/token/ERC20/ERC20.sol/ERC20.json +2 -2
- package/build/contracts/@openzeppelin/contracts/token/ERC20/IERC20.sol/IERC20.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol/IERC20Metadata.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/token/ERC20/extensions/draft-IERC20Permit.sol/IERC20Permit.dbg.json +4 -0
- package/build/contracts/@openzeppelin/contracts/token/ERC20/extensions/draft-IERC20Permit.sol/IERC20Permit.json +86 -0
- package/build/contracts/@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol/SafeERC20.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol/SafeERC20.json +2 -2
- package/build/contracts/@openzeppelin/contracts/utils/Address.sol/Address.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/utils/Address.sol/Address.json +2 -2
- package/build/contracts/@openzeppelin/contracts/utils/Context.sol/Context.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/utils/Create2.sol/Create2.dbg.json +4 -0
- package/build/contracts/{src/express-lane-auction/ELCRound.sol/LatestELCRoundsLib.json → @openzeppelin/contracts/utils/Create2.sol/Create2.json} +4 -4
- package/build/contracts/@openzeppelin/contracts/utils/StorageSlot.sol/StorageSlot.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/utils/StorageSlot.sol/StorageSlot.json +2 -2
- package/build/contracts/@openzeppelin/contracts/utils/Strings.sol/Strings.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts/utils/Strings.sol/Strings.json +2 -2
- package/build/contracts/@openzeppelin/contracts-upgradeable/access/AccessControlUpgradeable.sol/AccessControlUpgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/access/AccessControlUpgradeable.sol/AccessControlUpgradeable.json +13 -0
- package/build/contracts/@openzeppelin/contracts-upgradeable/access/IAccessControlUpgradeable.sol/IAccessControlUpgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.sol/OwnableUpgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.sol/OwnableUpgradeable.json +13 -0
- package/build/contracts/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.sol/Initializable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.sol/Initializable.json +15 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/security/PausableUpgradeable.sol/PausableUpgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/security/PausableUpgradeable.sol/PausableUpgradeable.json +13 -0
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/AddressUpgradeable.sol/AddressUpgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/AddressUpgradeable.sol/AddressUpgradeable.json +2 -2
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable.sol/ContextUpgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable.sol/ContextUpgradeable.json +15 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/Create2Upgradeable.sol/Create2Upgradeable.dbg.json +4 -0
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/Create2Upgradeable.sol/Create2Upgradeable.json +10 -0
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/StorageSlotUpgradeable.sol/StorageSlotUpgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/StorageSlotUpgradeable.sol/StorageSlotUpgradeable.json +2 -2
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/StringsUpgradeable.sol/StringsUpgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/StringsUpgradeable.sol/StringsUpgradeable.json +2 -2
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/introspection/ERC165Upgradeable.sol/ERC165Upgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/introspection/ERC165Upgradeable.sol/ERC165Upgradeable.json +13 -0
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/introspection/IERC165Upgradeable.sol/IERC165Upgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/structs/EnumerableSetUpgradeable.sol/EnumerableSetUpgradeable.dbg.json +1 -1
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/structs/EnumerableSetUpgradeable.sol/EnumerableSetUpgradeable.json +2 -2
- package/build/contracts/src/assertionStakingPool/AbsBoldStakingPool.sol/AbsBoldStakingPool.dbg.json +4 -0
- package/build/contracts/{@openzeppelin/contracts-upgradeable/token/ERC20/IERC20Upgradeable.sol/IERC20Upgradeable.json → src/assertionStakingPool/AbsBoldStakingPool.sol/AbsBoldStakingPool.json} +41 -95
- package/build/contracts/src/assertionStakingPool/AssertionStakingPool.sol/AssertionStakingPool.dbg.json +4 -0
- package/build/contracts/src/assertionStakingPool/AssertionStakingPool.sol/AssertionStakingPool.json +340 -0
- package/build/contracts/src/assertionStakingPool/AssertionStakingPoolCreator.sol/AssertionStakingPoolCreator.dbg.json +4 -0
- package/build/contracts/src/assertionStakingPool/AssertionStakingPoolCreator.sol/AssertionStakingPoolCreator.json +89 -0
- package/build/contracts/src/assertionStakingPool/EdgeStakingPool.sol/EdgeStakingPool.dbg.json +4 -0
- package/build/contracts/src/assertionStakingPool/EdgeStakingPool.sol/EdgeStakingPool.json +248 -0
- package/build/contracts/src/assertionStakingPool/EdgeStakingPoolCreator.sol/EdgeStakingPoolCreator.dbg.json +4 -0
- package/build/contracts/src/assertionStakingPool/EdgeStakingPoolCreator.sol/EdgeStakingPoolCreator.json +83 -0
- package/build/contracts/src/assertionStakingPool/StakingPoolCreatorUtils.sol/StakingPoolCreatorUtils.dbg.json +4 -0
- package/build/contracts/src/assertionStakingPool/StakingPoolCreatorUtils.sol/StakingPoolCreatorUtils.json +16 -0
- package/build/contracts/src/assertionStakingPool/interfaces/IAbsBoldStakingPool.sol/IAbsBoldStakingPool.dbg.json +4 -0
- package/build/contracts/src/assertionStakingPool/interfaces/IAbsBoldStakingPool.sol/IAbsBoldStakingPool.json +140 -0
- package/build/contracts/src/assertionStakingPool/interfaces/IAssertionStakingPool.sol/IAssertionStakingPool.dbg.json +4 -0
- package/build/contracts/src/assertionStakingPool/interfaces/IAssertionStakingPool.sol/IAssertionStakingPool.json +324 -0
- package/build/contracts/src/assertionStakingPool/interfaces/IAssertionStakingPoolCreator.sol/IAssertionStakingPoolCreator.dbg.json +4 -0
- package/build/contracts/src/assertionStakingPool/interfaces/IAssertionStakingPoolCreator.sol/IAssertionStakingPoolCreator.json +84 -0
- package/build/contracts/src/assertionStakingPool/interfaces/IEdgeStakingPool.sol/IEdgeStakingPool.dbg.json +4 -0
- package/build/contracts/{@openzeppelin/contracts-upgradeable/token/ERC20/extensions/IERC20MetadataUpgradeable.sol/IERC20MetadataUpgradeable.json → src/assertionStakingPool/interfaces/IEdgeStakingPool.sol/IEdgeStakingPool.json} +109 -110
- package/build/contracts/src/assertionStakingPool/interfaces/IEdgeStakingPoolCreator.sol/IEdgeStakingPoolCreator.dbg.json +4 -0
- package/build/contracts/src/assertionStakingPool/interfaces/IEdgeStakingPoolCreator.sol/IEdgeStakingPoolCreator.json +78 -0
- package/build/contracts/src/bridge/AbsBridge.sol/AbsBridge.dbg.json +1 -1
- package/build/contracts/src/bridge/AbsBridge.sol/AbsBridge.json +13 -0
- package/build/contracts/src/bridge/AbsInbox.sol/AbsInbox.dbg.json +1 -1
- package/build/contracts/src/bridge/AbsInbox.sol/AbsInbox.json +14 -1
- package/build/contracts/src/bridge/AbsOutbox.sol/AbsOutbox.dbg.json +1 -1
- package/build/contracts/src/bridge/Bridge.sol/Bridge.dbg.json +1 -1
- package/build/contracts/src/bridge/Bridge.sol/Bridge.json +15 -2
- package/build/contracts/src/bridge/DelayBuffer.sol/DelayBuffer.dbg.json +4 -0
- package/build/contracts/src/bridge/DelayBuffer.sol/DelayBuffer.json +24 -0
- package/build/contracts/src/bridge/ERC20Bridge.sol/ERC20Bridge.dbg.json +1 -1
- package/build/contracts/src/bridge/ERC20Bridge.sol/ERC20Bridge.json +15 -2
- package/build/contracts/src/bridge/ERC20Inbox.sol/ERC20Inbox.dbg.json +1 -1
- package/build/contracts/src/bridge/ERC20Inbox.sol/ERC20Inbox.json +16 -3
- package/build/contracts/src/bridge/ERC20Outbox.sol/ERC20Outbox.dbg.json +1 -1
- package/build/contracts/src/bridge/ERC20Outbox.sol/ERC20Outbox.json +2 -2
- package/build/contracts/src/bridge/GasRefunder.sol/GasRefunder.dbg.json +1 -1
- package/build/contracts/src/bridge/GasRefunder.sol/GasRefunder.json +2 -2
- package/build/contracts/src/bridge/IBridge.sol/IBridge.dbg.json +1 -1
- package/build/contracts/src/bridge/IDelayedMessageProvider.sol/IDelayedMessageProvider.dbg.json +1 -1
- package/build/contracts/src/bridge/IERC20Bridge.sol/IERC20Bridge.dbg.json +1 -1
- package/build/contracts/src/bridge/IERC20Inbox.sol/IERC20Inbox.dbg.json +1 -1
- package/build/contracts/src/bridge/IEthBridge.sol/IEthBridge.dbg.json +1 -1
- package/build/contracts/src/bridge/IInbox.sol/IInbox.dbg.json +1 -1
- package/build/contracts/src/bridge/IInboxBase.sol/IInboxBase.dbg.json +1 -1
- package/build/contracts/src/bridge/IOutbox.sol/IOutbox.dbg.json +1 -1
- package/build/contracts/src/bridge/IOwnable.sol/IOwnable.dbg.json +1 -1
- package/build/contracts/src/bridge/ISequencerInbox.sol/ISequencerInbox.dbg.json +1 -1
- package/build/contracts/src/bridge/ISequencerInbox.sol/ISequencerInbox.json +441 -0
- package/build/contracts/src/bridge/Inbox.sol/Inbox.dbg.json +1 -1
- package/build/contracts/src/bridge/Inbox.sol/Inbox.json +20 -2
- package/build/contracts/src/bridge/Messages.sol/Messages.dbg.json +1 -1
- package/build/contracts/src/bridge/Messages.sol/Messages.json +2 -2
- package/build/contracts/src/bridge/Outbox.sol/Outbox.dbg.json +1 -1
- package/build/contracts/src/bridge/Outbox.sol/Outbox.json +2 -2
- package/build/contracts/src/bridge/SequencerInbox.sol/SequencerInbox.dbg.json +1 -1
- package/build/contracts/src/bridge/SequencerInbox.sol/SequencerInbox.json +566 -9
- package/build/contracts/src/chain/CacheManager.sol/CacheManager.dbg.json +1 -1
- package/build/contracts/src/chain/CacheManager.sol/CacheManager.json +15 -2
- package/build/contracts/src/challengeV2/EdgeChallengeManager.sol/EdgeChallengeManager.dbg.json +4 -0
- package/build/contracts/src/challengeV2/EdgeChallengeManager.sol/EdgeChallengeManager.json +1631 -0
- package/build/contracts/src/challengeV2/IAssertionChain.sol/IAssertionChain.dbg.json +4 -0
- package/build/contracts/src/challengeV2/IAssertionChain.sol/IAssertionChain.json +247 -0
- package/build/contracts/src/challengeV2/IEdgeChallengeManager.sol/IEdgeChallengeManager.dbg.json +4 -0
- package/build/contracts/src/challengeV2/IEdgeChallengeManager.sol/IEdgeChallengeManager.json +762 -0
- package/build/contracts/src/challengeV2/libraries/ArrayUtilsLib.sol/ArrayUtilsLib.dbg.json +4 -0
- package/build/contracts/src/challengeV2/libraries/ArrayUtilsLib.sol/ArrayUtilsLib.json +10 -0
- package/build/contracts/src/challengeV2/libraries/ChallengeEdgeLib.sol/ChallengeEdgeLib.dbg.json +4 -0
- package/build/contracts/{@openzeppelin/contracts/utils/cryptography/ECDSA.sol/ECDSA.json → src/challengeV2/libraries/ChallengeEdgeLib.sol/ChallengeEdgeLib.json} +4 -4
- package/build/contracts/src/challengeV2/libraries/EdgeChallengeManagerLib.sol/EdgeChallengeManagerLib.dbg.json +4 -0
- package/build/contracts/src/challengeV2/libraries/EdgeChallengeManagerLib.sol/EdgeChallengeManagerLib.json +24 -0
- package/build/contracts/src/challengeV2/libraries/MerkleTreeAccumulatorLib.sol/MerkleTreeAccumulatorLib.dbg.json +4 -0
- package/build/contracts/src/challengeV2/libraries/MerkleTreeAccumulatorLib.sol/MerkleTreeAccumulatorLib.json +24 -0
- package/build/contracts/src/challengeV2/libraries/UintUtilsLib.sol/UintUtilsLib.dbg.json +4 -0
- package/build/contracts/src/challengeV2/libraries/UintUtilsLib.sol/UintUtilsLib.json +10 -0
- package/build/contracts/src/libraries/AddressAliasHelper.sol/AddressAliasHelper.dbg.json +1 -1
- package/build/contracts/src/libraries/AddressAliasHelper.sol/AddressAliasHelper.json +2 -2
- package/build/contracts/src/libraries/AdminFallbackProxy.sol/AdminFallbackProxy.dbg.json +1 -1
- package/build/contracts/src/libraries/AdminFallbackProxy.sol/AdminFallbackProxy.json +2 -2
- package/build/contracts/src/libraries/AdminFallbackProxy.sol/DoubleLogicERC1967Upgrade.dbg.json +1 -1
- package/build/contracts/src/libraries/ArbitrumChecker.sol/ArbitrumChecker.dbg.json +1 -1
- package/build/contracts/src/libraries/ArbitrumChecker.sol/ArbitrumChecker.json +2 -2
- package/build/contracts/src/libraries/CallerChecker.sol/CallerChecker.dbg.json +4 -0
- package/build/contracts/src/{challenge/ChallengeLib.sol/ChallengeLib.json → libraries/CallerChecker.sol/CallerChecker.json} +4 -4
- package/build/contracts/src/libraries/CryptographyPrimitives.sol/CryptographyPrimitives.dbg.json +1 -1
- package/build/contracts/src/libraries/CryptographyPrimitives.sol/CryptographyPrimitives.json +2 -2
- package/build/contracts/src/libraries/DecimalsConverterHelper.sol/DecimalsConverterHelper.dbg.json +1 -1
- package/build/contracts/src/libraries/DecimalsConverterHelper.sol/DecimalsConverterHelper.json +2 -2
- package/build/contracts/src/libraries/DelegateCallAware.sol/DelegateCallAware.dbg.json +1 -1
- package/build/contracts/src/libraries/DoubleLogicUUPSUpgradeable.sol/DoubleLogicUUPSUpgradeable.dbg.json +1 -1
- package/build/contracts/src/libraries/GasRefundEnabled.sol/GasRefundEnabled.dbg.json +1 -1
- package/build/contracts/src/libraries/IGasRefunder.sol/IGasRefunder.dbg.json +1 -1
- package/build/contracts/src/libraries/IReader4844.sol/IReader4844.dbg.json +1 -1
- package/build/contracts/src/libraries/MerkleLib.sol/MerkleLib.dbg.json +1 -1
- package/build/contracts/src/libraries/MerkleLib.sol/MerkleLib.json +2 -2
- package/build/contracts/src/libraries/UUPSNotUpgradeable.sol/UUPSNotUpgradeable.dbg.json +1 -1
- package/build/contracts/src/mocks/Benchmarks.sol/Benchmarks.dbg.json +1 -1
- package/build/contracts/src/mocks/Benchmarks.sol/Benchmarks.json +2 -2
- package/build/contracts/src/mocks/BridgeStub.sol/BridgeStub.dbg.json +1 -1
- package/build/contracts/src/mocks/BridgeStub.sol/BridgeStub.json +8 -8
- package/build/contracts/src/mocks/BridgeUnproxied.sol/BridgeUnproxied.dbg.json +1 -1
- package/build/contracts/src/mocks/BridgeUnproxied.sol/BridgeUnproxied.json +15 -2
- package/build/contracts/src/mocks/CreateTest.sol/CreateTest.dbg.json +1 -1
- package/build/contracts/src/mocks/CreateTest.sol/CreateTest.json +2 -2
- package/build/contracts/src/mocks/HostioTest.sol/HostioTest.dbg.json +1 -1
- package/build/contracts/src/mocks/HostioTest.sol/HostioTest.json +2 -2
- package/build/contracts/src/mocks/InboxStub.sol/InboxStub.dbg.json +1 -1
- package/build/contracts/src/mocks/InboxStub.sol/InboxStub.json +2 -2
- package/build/contracts/src/mocks/MerkleTreeAccess.sol/MerkleTreeAccess.dbg.json +4 -0
- package/build/contracts/src/mocks/MerkleTreeAccess.sol/MerkleTreeAccess.json +227 -0
- package/build/contracts/src/mocks/MockRollupEventInbox.sol/MockRollupEventInbox.dbg.json +4 -0
- package/build/contracts/src/mocks/MockRollupEventInbox.sol/MockRollupEventInbox.json +133 -0
- package/build/contracts/src/mocks/MultiCallTest.sol/MultiCallTest.dbg.json +1 -1
- package/build/contracts/src/mocks/MultiCallTest.sol/MultiCallTest.json +2 -2
- package/build/contracts/src/mocks/PendingBlkTimeAndNrAdvanceCheck.sol/PendingBlkTimeAndNrAdvanceCheck.dbg.json +1 -1
- package/build/contracts/src/mocks/PendingBlkTimeAndNrAdvanceCheck.sol/PendingBlkTimeAndNrAdvanceCheck.json +2 -2
- package/build/contracts/src/mocks/Program.sol/ProgramTest.dbg.json +1 -1
- package/build/contracts/src/mocks/Program.sol/ProgramTest.json +2 -2
- package/build/contracts/src/mocks/ProxyAdminForBinding.sol/ProxyAdminForBinding.dbg.json +1 -1
- package/build/contracts/src/mocks/ProxyAdminForBinding.sol/ProxyAdminForBinding.json +2 -2
- package/build/contracts/src/mocks/SdkStorage.sol/SdkStorage.dbg.json +1 -1
- package/build/contracts/src/mocks/SdkStorage.sol/SdkStorage.json +2 -2
- package/build/contracts/src/mocks/SequencerInboxBlobMock.sol/SequencerInboxBlobMock.dbg.json +4 -0
- package/build/contracts/src/mocks/SequencerInboxBlobMock.sol/SequencerInboxBlobMock.json +1632 -0
- package/build/contracts/src/mocks/SequencerInboxStub.sol/SequencerInboxStub.dbg.json +1 -1
- package/build/contracts/src/mocks/SequencerInboxStub.sol/SequencerInboxStub.json +566 -9
- package/build/contracts/src/mocks/Simple.sol/Simple.dbg.json +1 -1
- package/build/contracts/src/mocks/Simple.sol/Simple.json +2 -2
- package/build/contracts/src/mocks/SimpleCacheManager.sol/SimpleCacheManager.dbg.json +1 -1
- package/build/contracts/src/mocks/SimpleCacheManager.sol/SimpleCacheManager.json +2 -2
- package/build/contracts/src/mocks/SimpleOneStepProofEntry.sol/SimpleOneStepProofEntry.dbg.json +4 -0
- package/build/contracts/src/mocks/SimpleOneStepProofEntry.sol/SimpleOneStepProofEntry.json +142 -0
- package/build/contracts/src/mocks/SimpleProxy.sol/SimpleProxy.dbg.json +1 -1
- package/build/contracts/src/mocks/SimpleProxy.sol/SimpleProxy.json +2 -2
- package/build/contracts/src/mocks/TestWETH9.sol/IWETH9.dbg.json +4 -0
- package/build/contracts/src/mocks/TestWETH9.sol/IWETH9.json +31 -0
- package/build/contracts/src/mocks/TestWETH9.sol/TestWETH9.dbg.json +4 -0
- package/build/contracts/src/mocks/TestWETH9.sol/TestWETH9.json +317 -0
- package/build/contracts/src/mocks/UpgradeExecutorMock.sol/UpgradeExecutorMock.dbg.json +1 -1
- package/build/contracts/src/mocks/UpgradeExecutorMock.sol/UpgradeExecutorMock.json +15 -2
- package/build/contracts/src/node-interface/NodeInterface.sol/NodeInterface.dbg.json +1 -1
- package/build/contracts/src/node-interface/NodeInterfaceDebug.sol/NodeInterfaceDebug.dbg.json +1 -1
- package/build/contracts/src/osp/HashProofHelper.sol/HashProofHelper.dbg.json +1 -1
- package/build/contracts/src/osp/HashProofHelper.sol/HashProofHelper.json +2 -2
- package/build/contracts/src/osp/IOneStepProofEntry.sol/IOneStepProofEntry.dbg.json +1 -1
- package/build/contracts/src/osp/IOneStepProofEntry.sol/IOneStepProofEntry.json +33 -9
- package/build/contracts/src/osp/IOneStepProofEntry.sol/OneStepProofEntryLib.dbg.json +1 -1
- package/build/contracts/src/osp/IOneStepProofEntry.sol/OneStepProofEntryLib.json +2 -2
- package/build/contracts/src/osp/IOneStepProver.sol/IOneStepProver.dbg.json +1 -1
- package/build/contracts/src/osp/IOneStepProver.sol/IOneStepProver.json +5 -0
- package/build/contracts/src/osp/OneStepProofEntry.sol/OneStepProofEntry.dbg.json +1 -1
- package/build/contracts/src/osp/OneStepProofEntry.sol/OneStepProofEntry.json +35 -11
- package/build/contracts/src/osp/OneStepProver0.sol/OneStepProver0.dbg.json +1 -1
- package/build/contracts/src/osp/OneStepProver0.sol/OneStepProver0.json +7 -2
- package/build/contracts/src/osp/OneStepProverHostIo.sol/OneStepProverHostIo.dbg.json +1 -1
- package/build/contracts/src/osp/OneStepProverHostIo.sol/OneStepProverHostIo.json +7 -2
- package/build/contracts/src/osp/OneStepProverMath.sol/OneStepProverMath.dbg.json +1 -1
- package/build/contracts/src/osp/OneStepProverMath.sol/OneStepProverMath.json +7 -2
- package/build/contracts/src/osp/OneStepProverMemory.sol/OneStepProverMemory.dbg.json +1 -1
- package/build/contracts/src/osp/OneStepProverMemory.sol/OneStepProverMemory.json +7 -2
- package/build/contracts/src/precompiles/ArbAddressTable.sol/ArbAddressTable.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbAggregator.sol/ArbAggregator.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbBLS.sol/ArbBLS.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbDebug.sol/ArbDebug.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbFunctionTable.sol/ArbFunctionTable.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbGasInfo.sol/ArbGasInfo.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbInfo.sol/ArbInfo.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbOwner.sol/ArbOwner.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbOwnerPublic.sol/ArbOwnerPublic.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbRetryableTx.sol/ArbRetryableTx.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbStatistics.sol/ArbStatistics.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbSys.sol/ArbSys.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbWasm.sol/ArbWasm.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbWasmCache.sol/ArbWasmCache.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbosActs.sol/ArbosActs.dbg.json +1 -1
- package/build/contracts/src/precompiles/ArbosTest.sol/ArbosTest.dbg.json +1 -1
- package/build/contracts/src/rollup/AbsRollupEventInbox.sol/AbsRollupEventInbox.dbg.json +1 -1
- package/build/contracts/src/rollup/Assertion.sol/AssertionNodeLib.dbg.json +4 -0
- package/build/contracts/src/rollup/{Node.sol/NodeLib.json → Assertion.sol/AssertionNodeLib.json} +4 -4
- package/build/contracts/src/rollup/AssertionState.sol/AssertionStateLib.dbg.json +4 -0
- package/build/contracts/src/{express-lane-auction/Balance.sol/BalanceLib.json → rollup/AssertionState.sol/AssertionStateLib.json} +4 -4
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/BOLDUpgradeAction.dbg.json +4 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/BOLDUpgradeAction.json +807 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/ConstantArrayStorage.dbg.json +4 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/ConstantArrayStorage.json +35 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/IOldRollup.dbg.json +4 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/IOldRollup.json +361 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/IOldRollupAdmin.dbg.json +4 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/IOldRollupAdmin.json +38 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/ISeqInboxPostUpgradeInit.dbg.json +4 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/ISeqInboxPostUpgradeInit.json +41 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/RollupReader.dbg.json +4 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/RollupReader.json +385 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/StateHashPreImageLookup.dbg.json +4 -0
- package/build/contracts/src/rollup/BOLDUpgradeAction.sol/StateHashPreImageLookup.json +203 -0
- package/build/contracts/src/rollup/BridgeCreator.sol/BridgeCreator.dbg.json +1 -1
- package/build/contracts/src/rollup/BridgeCreator.sol/BridgeCreator.json +62 -10
- package/build/contracts/src/rollup/DeployHelper.sol/DeployHelper.dbg.json +1 -1
- package/build/contracts/src/rollup/DeployHelper.sol/DeployHelper.json +2 -2
- package/build/contracts/src/rollup/ERC20RollupEventInbox.sol/ERC20RollupEventInbox.dbg.json +1 -1
- package/build/contracts/src/rollup/ERC20RollupEventInbox.sol/ERC20RollupEventInbox.json +2 -2
- package/build/contracts/src/rollup/FactoryDeployerHelper.sol/FactoryDeployerHelper.dbg.json +1 -1
- package/build/contracts/src/rollup/FactoryDeployerHelper.sol/FactoryDeployerHelper.json +2 -2
- package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IDeployHelper.dbg.json +1 -1
- package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IERC20.dbg.json +1 -1
- package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IERC20Bridge.dbg.json +1 -1
- package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IInboxBase.dbg.json +1 -1
- package/build/contracts/src/rollup/IRollupAdmin.sol/IRollupAdmin.dbg.json +1 -1
- package/build/contracts/src/rollup/IRollupAdmin.sol/IRollupAdmin.json +473 -99
- package/build/contracts/src/rollup/IRollupCore.sol/IRollupCore.dbg.json +1 -1
- package/build/contracts/src/rollup/IRollupCore.sol/IRollupCore.json +315 -221
- package/build/contracts/src/rollup/IRollupEventInbox.sol/IRollupEventInbox.dbg.json +1 -1
- package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUser.dbg.json +1 -1
- package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUser.json +678 -499
- package/build/contracts/src/rollup/RollupAdminLogic.sol/RollupAdminLogic.dbg.json +1 -1
- package/build/contracts/src/rollup/RollupAdminLogic.sol/RollupAdminLogic.json +806 -435
- package/build/contracts/src/rollup/RollupCore.sol/RollupCore.dbg.json +1 -1
- package/build/contracts/src/rollup/RollupCore.sol/RollupCore.json +323 -235
- package/build/contracts/src/rollup/RollupCreator.sol/RollupCreator.dbg.json +1 -1
- package/build/contracts/src/rollup/RollupCreator.sol/RollupCreator.json +98 -36
- package/build/contracts/src/rollup/RollupEventInbox.sol/RollupEventInbox.dbg.json +1 -1
- package/build/contracts/src/rollup/RollupEventInbox.sol/RollupEventInbox.json +2 -2
- package/build/contracts/src/rollup/RollupLib.sol/RollupLib.dbg.json +1 -1
- package/build/contracts/src/rollup/RollupLib.sol/RollupLib.json +2 -2
- package/build/contracts/src/rollup/RollupProxy.sol/RollupProxy.dbg.json +1 -1
- package/build/contracts/src/rollup/RollupProxy.sol/RollupProxy.json +97 -16
- package/build/contracts/src/rollup/RollupUserLogic.sol/RollupUserLogic.dbg.json +1 -1
- package/build/contracts/src/rollup/RollupUserLogic.sol/RollupUserLogic.json +924 -535
- package/build/contracts/src/rollup/ValidatorWallet.sol/ValidatorWallet.dbg.json +1 -1
- package/build/contracts/src/rollup/ValidatorWallet.sol/ValidatorWallet.json +15 -43
- package/build/contracts/src/rollup/ValidatorWalletCreator.sol/ValidatorWalletCreator.dbg.json +1 -1
- package/build/contracts/src/rollup/ValidatorWalletCreator.sol/ValidatorWalletCreator.json +2 -2
- package/build/contracts/src/state/Deserialize.sol/Deserialize.dbg.json +1 -1
- package/build/contracts/src/state/Deserialize.sol/Deserialize.json +2 -2
- package/build/contracts/src/state/GlobalState.sol/GlobalStateLib.dbg.json +1 -1
- package/build/contracts/src/state/GlobalState.sol/GlobalStateLib.json +2 -2
- package/build/contracts/src/state/Instructions.sol/Instructions.dbg.json +1 -1
- package/build/contracts/src/state/Instructions.sol/Instructions.json +2 -2
- package/build/contracts/src/state/Machine.sol/MachineLib.dbg.json +1 -1
- package/build/contracts/src/state/Machine.sol/MachineLib.json +2 -2
- package/build/contracts/src/state/MerkleProof.sol/MerkleProofLib.dbg.json +1 -1
- package/build/contracts/src/state/MerkleProof.sol/MerkleProofLib.json +2 -2
- package/build/contracts/src/state/Module.sol/ModuleLib.dbg.json +1 -1
- package/build/contracts/src/state/Module.sol/ModuleLib.json +2 -2
- package/build/contracts/src/state/ModuleMemory.sol/ModuleMemoryLib.dbg.json +1 -1
- package/build/contracts/src/state/ModuleMemory.sol/ModuleMemoryLib.json +2 -2
- package/build/contracts/src/state/ModuleMemoryCompact.sol/ModuleMemoryCompactLib.dbg.json +1 -1
- package/build/contracts/src/state/ModuleMemoryCompact.sol/ModuleMemoryCompactLib.json +2 -2
- package/build/contracts/src/state/MultiStack.sol/MultiStackLib.dbg.json +1 -1
- package/build/contracts/src/state/MultiStack.sol/MultiStackLib.json +2 -2
- package/build/contracts/src/state/PcArray.sol/PcArrayLib.dbg.json +1 -1
- package/build/contracts/src/state/PcArray.sol/PcArrayLib.json +2 -2
- package/build/contracts/src/state/StackFrame.sol/StackFrameLib.dbg.json +1 -1
- package/build/contracts/src/state/StackFrame.sol/StackFrameLib.json +2 -2
- package/build/contracts/src/state/Value.sol/ValueLib.dbg.json +1 -1
- package/build/contracts/src/state/Value.sol/ValueLib.json +2 -2
- package/build/contracts/src/state/ValueArray.sol/ValueArrayLib.dbg.json +1 -1
- package/build/contracts/src/state/ValueArray.sol/ValueArrayLib.json +2 -2
- package/build/contracts/src/state/ValueStack.sol/ValueStackLib.dbg.json +1 -1
- package/build/contracts/src/state/ValueStack.sol/ValueStackLib.json +2 -2
- package/build/contracts/src/test-helpers/BridgeTester.sol/BridgeTester.dbg.json +1 -1
- package/build/contracts/src/test-helpers/BridgeTester.sol/BridgeTester.json +15 -2
- package/build/contracts/src/test-helpers/CryptographyPrimitivesTester.sol/CryptographyPrimitivesTester.dbg.json +1 -1
- package/build/contracts/src/test-helpers/CryptographyPrimitivesTester.sol/CryptographyPrimitivesTester.json +2 -2
- package/build/contracts/src/test-helpers/EthVault.sol/EthVault.dbg.json +1 -1
- package/build/contracts/src/test-helpers/EthVault.sol/EthVault.json +2 -2
- package/build/contracts/src/test-helpers/MessageTester.sol/MessageTester.dbg.json +1 -1
- package/build/contracts/src/test-helpers/MessageTester.sol/MessageTester.json +2 -2
- package/build/contracts/src/test-helpers/OutboxWithoutOptTester.sol/OutboxWithoutOptTester.dbg.json +1 -1
- package/build/contracts/src/test-helpers/OutboxWithoutOptTester.sol/OutboxWithoutOptTester.json +2 -2
- package/build/contracts/src/test-helpers/RollupMock.sol/RollupMock.dbg.json +1 -1
- package/build/contracts/src/test-helpers/RollupMock.sol/RollupMock.json +2 -15
- package/build/contracts/src/test-helpers/TestToken.sol/TestToken.dbg.json +1 -1
- package/build/contracts/src/test-helpers/TestToken.sol/TestToken.json +2 -2
- package/build/contracts/src/test-helpers/ValueArrayTester.sol/ValueArrayTester.dbg.json +1 -1
- package/build/contracts/src/test-helpers/ValueArrayTester.sol/ValueArrayTester.json +2 -2
- package/out/yul/Reader4844.yul/Reader4844.json +1 -1
- package/package.json +11 -4
- package/src/assertionStakingPool/AbsBoldStakingPool.sol +66 -0
- package/src/assertionStakingPool/AssertionStakingPool.sol +70 -0
- package/src/assertionStakingPool/AssertionStakingPoolCreator.sol +35 -0
- package/src/assertionStakingPool/EdgeStakingPool.sol +57 -0
- package/src/assertionStakingPool/EdgeStakingPoolCreator.sol +34 -0
- package/src/assertionStakingPool/StakingPoolCreatorUtils.sol +25 -0
- package/src/assertionStakingPool/interfaces/IAbsBoldStakingPool.sol +41 -0
- package/src/assertionStakingPool/interfaces/IAssertionStakingPool.sol +36 -0
- package/src/assertionStakingPool/interfaces/IAssertionStakingPoolCreator.sol +31 -0
- package/src/assertionStakingPool/interfaces/IEdgeStakingPool.sol +27 -0
- package/src/assertionStakingPool/interfaces/IEdgeStakingPoolCreator.sol +28 -0
- package/src/bridge/AbsBridge.sol +38 -48
- package/src/bridge/AbsInbox.sol +89 -92
- package/src/bridge/AbsOutbox.sol +23 -37
- package/src/bridge/Bridge.sol +6 -4
- package/src/bridge/DelayBuffer.sol +123 -0
- package/src/bridge/DelayBufferTypes.sol +38 -0
- package/src/bridge/ERC20Bridge.sol +8 -4
- package/src/bridge/ERC20Inbox.sol +46 -53
- package/src/bridge/ERC20Outbox.sol +7 -3
- package/src/bridge/GasRefunder.sol +38 -24
- package/src/bridge/IBridge.sol +30 -21
- package/src/bridge/IERC20Bridge.sol +1 -1
- package/src/bridge/IERC20Inbox.sol +4 -2
- package/src/bridge/IEthBridge.sol +4 -2
- package/src/bridge/IInbox.sol +4 -2
- package/src/bridge/IInboxBase.sol +16 -8
- package/src/bridge/IOutbox.sol +13 -8
- package/src/bridge/ISequencerInbox.sol +118 -13
- package/src/bridge/Inbox.sol +134 -151
- package/src/bridge/Messages.sol +48 -18
- package/src/bridge/Outbox.sol +6 -2
- package/src/bridge/SequencerInbox.sol +343 -279
- package/src/chain/CacheManager.sol +49 -18
- package/src/challengeV2/EdgeChallengeManager.sol +559 -0
- package/src/challengeV2/IAssertionChain.sol +39 -0
- package/src/challengeV2/IEdgeChallengeManager.sol +233 -0
- package/src/challengeV2/libraries/ArrayUtilsLib.sol +61 -0
- package/src/challengeV2/libraries/ChallengeEdgeLib.sol +277 -0
- package/src/challengeV2/libraries/ChallengeErrors.sol +108 -0
- package/src/challengeV2/libraries/EdgeChallengeManagerLib.sol +819 -0
- package/src/challengeV2/libraries/Enums.sol +26 -0
- package/src/challengeV2/libraries/MerkleTreeAccumulatorLib.sol +390 -0
- package/src/challengeV2/libraries/Structs.sol +176 -0
- package/src/challengeV2/libraries/UintUtilsLib.sol +74 -0
- package/src/libraries/AddressAliasHelper.sol +6 -2
- package/src/libraries/AdminFallbackProxy.sol +8 -4
- package/src/libraries/ArbitrumChecker.sol +3 -4
- package/src/libraries/CallerChecker.sol +18 -0
- package/src/libraries/CryptographyPrimitives.sol +39 -46
- package/src/libraries/DecimalsConverterHelper.sol +2 -4
- package/src/libraries/DoubleLogicUUPSUpgradeable.sol +10 -7
- package/src/libraries/Error.sol +21 -3
- package/src/libraries/GasRefundEnabled.sol +5 -6
- package/src/libraries/MerkleLib.sol +6 -5
- package/src/libraries/UUPSNotUpgradeable.sol +2 -4
- package/src/mocks/BridgeStub.sol +50 -48
- package/src/mocks/CreateTest.sol +3 -1
- package/src/mocks/HostioTest.sol +20 -16
- package/src/mocks/InboxStub.sol +22 -17
- package/src/mocks/MerkleTreeAccess.sol +72 -0
- package/src/mocks/MockRollupEventInbox.sol +59 -0
- package/src/mocks/MultiCallTest.sol +3 -1
- package/src/mocks/PendingBlkTimeAndNrAdvanceCheck.sol +3 -1
- package/src/mocks/Program.sol +9 -7
- package/src/mocks/SequencerInboxBlobMock.sol +38 -0
- package/src/mocks/SequencerInboxStub.sol +9 -12
- package/src/mocks/Simple.sol +13 -25
- package/src/mocks/SimpleCacheManager.sol +10 -3
- package/src/mocks/SimpleOneStepProofEntry.sol +60 -0
- package/src/mocks/SimpleProxy.sol +3 -1
- package/src/mocks/TestWETH9.sol +30 -0
- package/src/mocks/UpgradeExecutorMock.sol +10 -17
- package/src/node-interface/NodeInterface.sol +23 -22
- package/src/node-interface/NodeInterfaceDebug.sol +5 -3
- package/src/osp/HashProofHelper.sol +9 -10
- package/src/osp/IOneStepProofEntry.sol +14 -9
- package/src/osp/IOneStepProver.sol +1 -0
- package/src/osp/OneStepProofEntry.sol +63 -54
- package/src/osp/OneStepProver0.sol +14 -27
- package/src/osp/OneStepProverHostIo.sol +31 -58
- package/src/osp/OneStepProverMath.sol +15 -23
- package/src/osp/OneStepProverMemory.sol +9 -23
- package/src/precompiles/ArbAddressTable.sol +19 -9
- package/src/precompiles/ArbAggregator.sol +12 -4
- package/src/precompiles/ArbBLS.sol +1 -3
- package/src/precompiles/ArbDebug.sol +5 -11
- package/src/precompiles/ArbFunctionTable.sol +7 -10
- package/src/precompiles/ArbGasInfo.sol +9 -43
- package/src/precompiles/ArbInfo.sol +6 -2
- package/src/precompiles/ArbOwner.sol +101 -34
- package/src/precompiles/ArbOwnerPublic.sol +6 -2
- package/src/precompiles/ArbRetryableTx.sol +15 -5
- package/src/precompiles/ArbStatistics.sol +1 -8
- package/src/precompiles/ArbSys.sol +16 -18
- package/src/precompiles/ArbWasm.sol +24 -14
- package/src/precompiles/ArbWasmCache.sol +15 -5
- package/src/precompiles/ArbosTest.sol +3 -1
- package/src/rollup/AbsRollupEventInbox.sol +15 -16
- package/src/rollup/Assertion.sol +100 -0
- package/src/rollup/AssertionState.sol +29 -0
- package/src/rollup/BOLDUpgradeAction.sol +631 -0
- package/src/rollup/BridgeCreator.sol +42 -15
- package/src/rollup/Config.sol +15 -7
- package/src/rollup/DeployHelper.sol +12 -31
- package/src/rollup/ERC20RollupEventInbox.sol +8 -9
- package/src/rollup/FactoryDeployerHelper.sol +8 -10
- package/src/rollup/IRollupAdmin.sol +127 -45
- package/src/rollup/IRollupCore.sol +64 -84
- package/src/rollup/IRollupEventInbox.sol +3 -1
- package/src/rollup/IRollupLogic.sol +35 -72
- package/src/rollup/RollupAdminLogic.sol +224 -203
- package/src/rollup/RollupCore.sol +407 -428
- package/src/rollup/RollupCreator.sol +84 -71
- package/src/rollup/RollupEventInbox.sol +7 -7
- package/src/rollup/RollupLib.sol +50 -86
- package/src/rollup/RollupProxy.sol +8 -12
- package/src/rollup/RollupUserLogic.sol +279 -644
- package/src/rollup/ValidatorUtils.sol +0 -242
- package/src/rollup/ValidatorWallet.sol +22 -38
- package/src/rollup/ValidatorWalletCreator.sol +8 -8
- package/src/state/Deserialize.sol +74 -96
- package/src/state/GlobalState.sol +74 -20
- package/src/state/Instructions.sol +4 -3
- package/src/state/Machine.sol +18 -19
- package/src/state/Module.sol +14 -13
- package/src/state/ModuleMemory.sol +6 -25
- package/src/state/ModuleMemoryCompact.sol +3 -1
- package/src/state/MultiStack.sol +16 -20
- package/src/state/PcArray.sol +7 -7
- package/src/state/StackFrame.sol +21 -14
- package/src/state/Value.sol +18 -6
- package/src/state/ValueArray.sol +7 -7
- package/src/state/ValueStack.sol +9 -3
- package/src/test-helpers/BridgeTester.sol +32 -42
- package/src/test-helpers/CryptographyPrimitivesTester.sol +12 -13
- package/src/test-helpers/EthVault.sol +4 -2
- package/src/test-helpers/InterfaceCompatibilityTester.sol +1 -1
- package/src/test-helpers/MessageTester.sol +3 -10
- package/src/test-helpers/OutboxWithoutOptTester.sol +12 -19
- package/src/test-helpers/RollupMock.sol +3 -7
- package/src/test-helpers/TestToken.sol +4 -2
- package/build/contracts/@openzeppelin/contracts/utils/cryptography/ECDSA.sol/ECDSA.dbg.json +0 -4
- package/build/contracts/@openzeppelin/contracts-upgradeable/access/AccessControlEnumerableUpgradeable.sol/AccessControlEnumerableUpgradeable.dbg.json +0 -4
- package/build/contracts/@openzeppelin/contracts-upgradeable/access/AccessControlEnumerableUpgradeable.sol/AccessControlEnumerableUpgradeable.json +0 -258
- package/build/contracts/@openzeppelin/contracts-upgradeable/access/IAccessControlEnumerableUpgradeable.sol/IAccessControlEnumerableUpgradeable.dbg.json +0 -4
- package/build/contracts/@openzeppelin/contracts-upgradeable/access/IAccessControlEnumerableUpgradeable.sol/IAccessControlEnumerableUpgradeable.json +0 -226
- package/build/contracts/@openzeppelin/contracts-upgradeable/token/ERC20/ERC20Upgradeable.sol/ERC20Upgradeable.dbg.json +0 -4
- package/build/contracts/@openzeppelin/contracts-upgradeable/token/ERC20/ERC20Upgradeable.sol/ERC20Upgradeable.json +0 -281
- package/build/contracts/@openzeppelin/contracts-upgradeable/token/ERC20/IERC20Upgradeable.sol/IERC20Upgradeable.dbg.json +0 -4
- package/build/contracts/@openzeppelin/contracts-upgradeable/token/ERC20/extensions/ERC20BurnableUpgradeable.sol/ERC20BurnableUpgradeable.dbg.json +0 -4
- package/build/contracts/@openzeppelin/contracts-upgradeable/token/ERC20/extensions/ERC20BurnableUpgradeable.sol/ERC20BurnableUpgradeable.json +0 -312
- package/build/contracts/@openzeppelin/contracts-upgradeable/token/ERC20/extensions/IERC20MetadataUpgradeable.sol/IERC20MetadataUpgradeable.dbg.json +0 -4
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/cryptography/ECDSAUpgradeable.sol/ECDSAUpgradeable.dbg.json +0 -4
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/cryptography/ECDSAUpgradeable.sol/ECDSAUpgradeable.json +0 -10
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/cryptography/draft-EIP712Upgradeable.sol/EIP712Upgradeable.dbg.json +0 -4
- package/build/contracts/@openzeppelin/contracts-upgradeable/utils/cryptography/draft-EIP712Upgradeable.sol/EIP712Upgradeable.json +0 -10
- package/build/contracts/src/challenge/ChallengeLib.sol/ChallengeLib.dbg.json +0 -4
- package/build/contracts/src/challenge/ChallengeManager.sol/ChallengeManager.dbg.json +0 -4
- package/build/contracts/src/challenge/ChallengeManager.sol/ChallengeManager.json +0 -746
- package/build/contracts/src/challenge/IChallengeManager.sol/IChallengeManager.dbg.json +0 -4
- package/build/contracts/src/challenge/IChallengeManager.sol/IChallengeManager.json +0 -441
- package/build/contracts/src/challenge/IChallengeResultReceiver.sol/IChallengeResultReceiver.dbg.json +0 -4
- package/build/contracts/src/challenge/IChallengeResultReceiver.sol/IChallengeResultReceiver.json +0 -34
- package/build/contracts/src/express-lane-auction/Balance.sol/BalanceLib.dbg.json +0 -4
- package/build/contracts/src/express-lane-auction/Burner.sol/Burner.dbg.json +0 -4
- package/build/contracts/src/express-lane-auction/Burner.sol/Burner.json +0 -47
- package/build/contracts/src/express-lane-auction/ELCRound.sol/LatestELCRoundsLib.dbg.json +0 -4
- package/build/contracts/src/express-lane-auction/ExpressLaneAuction.sol/ExpressLaneAuction.dbg.json +0 -4
- package/build/contracts/src/express-lane-auction/ExpressLaneAuction.sol/ExpressLaneAuction.json +0 -1588
- package/build/contracts/src/express-lane-auction/IExpressLaneAuction.sol/IExpressLaneAuction.dbg.json +0 -4
- package/build/contracts/src/express-lane-auction/IExpressLaneAuction.sol/IExpressLaneAuction.json +0 -1296
- package/build/contracts/src/express-lane-auction/RoundTimingInfo.sol/RoundTimingInfoLib.dbg.json +0 -4
- package/build/contracts/src/express-lane-auction/RoundTimingInfo.sol/RoundTimingInfoLib.json +0 -10
- package/build/contracts/src/mocks/MockResultReceiver.sol/MockResultReceiver.dbg.json +0 -4
- package/build/contracts/src/mocks/MockResultReceiver.sol/MockResultReceiver.json +0 -188
- package/build/contracts/src/mocks/SingleExecutionChallenge.sol/SingleExecutionChallenge.dbg.json +0 -4
- package/build/contracts/src/mocks/SingleExecutionChallenge.sol/SingleExecutionChallenge.json +0 -797
- package/build/contracts/src/mocks/TimedOutChallengeManager.sol/TimedOutChallengeManager.dbg.json +0 -4
- package/build/contracts/src/mocks/TimedOutChallengeManager.sol/TimedOutChallengeManager.json +0 -746
- package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUserAbs.dbg.json +0 -4
- package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUserAbs.json +0 -1332
- package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUserERC20.dbg.json +0 -4
- package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUserERC20.json +0 -1466
- package/build/contracts/src/rollup/Node.sol/NodeLib.dbg.json +0 -4
- package/build/contracts/src/rollup/RollupUserLogic.sol/AbsRollupUserLogic.dbg.json +0 -4
- package/build/contracts/src/rollup/RollupUserLogic.sol/AbsRollupUserLogic.json +0 -1614
- package/build/contracts/src/rollup/RollupUserLogic.sol/ERC20RollupUserLogic.dbg.json +0 -4
- package/build/contracts/src/rollup/RollupUserLogic.sol/ERC20RollupUserLogic.json +0 -1748
- package/build/contracts/src/rollup/ValidatorUtils.sol/ValidatorUtils.dbg.json +0 -4
- package/build/contracts/src/rollup/ValidatorUtils.sol/ValidatorUtils.json +0 -379
- package/src/challenge/ChallengeLib.sol +0 -88
- package/src/challenge/ChallengeManager.sol +0 -375
- package/src/challenge/IChallengeManager.sol +0 -86
- package/src/challenge/IChallengeResultReceiver.sol +0 -13
- package/src/express-lane-auction/Balance.sol +0 -142
- package/src/express-lane-auction/Burner.sol +0 -25
- package/src/express-lane-auction/ELCRound.sol +0 -73
- package/src/express-lane-auction/Errors.sol +0 -31
- package/src/express-lane-auction/ExpressLaneAuction.sol +0 -565
- package/src/express-lane-auction/IExpressLaneAuction.sol +0 -421
- package/src/express-lane-auction/RoundTimingInfo.sol +0 -115
- package/src/mocks/MockResultReceiver.sol +0 -59
- package/src/mocks/SingleExecutionChallenge.sol +0 -41
- package/src/mocks/TimedOutChallengeManager.sol +0 -13
- package/src/rollup/Node.sol +0 -113
@@ -1,375 +0,0 @@
|
|
1
|
-
// Copyright 2021-2022, Offchain Labs, Inc.
|
2
|
-
// For license information, see https://github.com/OffchainLabs/nitro-contracts/blob/main/LICENSE
|
3
|
-
// SPDX-License-Identifier: BUSL-1.1
|
4
|
-
|
5
|
-
pragma solidity ^0.8.0;
|
6
|
-
|
7
|
-
import "../libraries/DelegateCallAware.sol";
|
8
|
-
import "../osp/IOneStepProofEntry.sol";
|
9
|
-
import "../state/GlobalState.sol";
|
10
|
-
import "./IChallengeResultReceiver.sol";
|
11
|
-
import "./ChallengeLib.sol";
|
12
|
-
import "./IChallengeManager.sol";
|
13
|
-
|
14
|
-
import {NO_CHAL_INDEX} from "../libraries/Constants.sol";
|
15
|
-
|
16
|
-
contract ChallengeManager is DelegateCallAware, IChallengeManager {
|
17
|
-
using GlobalStateLib for GlobalState;
|
18
|
-
using MachineLib for Machine;
|
19
|
-
using ChallengeLib for ChallengeLib.Challenge;
|
20
|
-
|
21
|
-
enum ChallengeModeRequirement {
|
22
|
-
ANY,
|
23
|
-
BLOCK,
|
24
|
-
EXECUTION
|
25
|
-
}
|
26
|
-
|
27
|
-
string private constant NO_CHAL = "NO_CHAL";
|
28
|
-
uint256 private constant MAX_CHALLENGE_DEGREE = 40;
|
29
|
-
|
30
|
-
uint64 public totalChallengesCreated;
|
31
|
-
mapping(uint256 => ChallengeLib.Challenge) public challenges;
|
32
|
-
|
33
|
-
IChallengeResultReceiver public resultReceiver;
|
34
|
-
|
35
|
-
ISequencerInbox public sequencerInbox;
|
36
|
-
IBridge public bridge;
|
37
|
-
IOneStepProofEntry public osp;
|
38
|
-
mapping(bytes32 => IOneStepProofEntry) public ospCond;
|
39
|
-
|
40
|
-
function challengeInfo(uint64 challengeIndex)
|
41
|
-
external
|
42
|
-
view
|
43
|
-
override
|
44
|
-
returns (ChallengeLib.Challenge memory)
|
45
|
-
{
|
46
|
-
return challenges[challengeIndex];
|
47
|
-
}
|
48
|
-
|
49
|
-
modifier takeTurn(
|
50
|
-
uint64 challengeIndex,
|
51
|
-
ChallengeLib.SegmentSelection calldata selection,
|
52
|
-
ChallengeModeRequirement expectedMode
|
53
|
-
) {
|
54
|
-
ChallengeLib.Challenge storage challenge = challenges[challengeIndex];
|
55
|
-
require(msg.sender == currentResponder(challengeIndex), "CHAL_SENDER");
|
56
|
-
require(!isTimedOut(challengeIndex), "CHAL_DEADLINE");
|
57
|
-
|
58
|
-
if (expectedMode == ChallengeModeRequirement.ANY) {
|
59
|
-
require(challenge.mode != ChallengeLib.ChallengeMode.NONE, NO_CHAL);
|
60
|
-
} else if (expectedMode == ChallengeModeRequirement.BLOCK) {
|
61
|
-
require(challenge.mode == ChallengeLib.ChallengeMode.BLOCK, "CHAL_NOT_BLOCK");
|
62
|
-
} else if (expectedMode == ChallengeModeRequirement.EXECUTION) {
|
63
|
-
require(challenge.mode == ChallengeLib.ChallengeMode.EXECUTION, "CHAL_NOT_EXECUTION");
|
64
|
-
} else {
|
65
|
-
assert(false);
|
66
|
-
}
|
67
|
-
|
68
|
-
require(
|
69
|
-
challenge.challengeStateHash ==
|
70
|
-
ChallengeLib.hashChallengeState(
|
71
|
-
selection.oldSegmentsStart,
|
72
|
-
selection.oldSegmentsLength,
|
73
|
-
selection.oldSegments
|
74
|
-
),
|
75
|
-
"BIS_STATE"
|
76
|
-
);
|
77
|
-
if (
|
78
|
-
selection.oldSegments.length < 2 ||
|
79
|
-
selection.challengePosition >= selection.oldSegments.length - 1
|
80
|
-
) {
|
81
|
-
revert("BAD_CHALLENGE_POS");
|
82
|
-
}
|
83
|
-
|
84
|
-
_;
|
85
|
-
|
86
|
-
if (challenge.mode == ChallengeLib.ChallengeMode.NONE) {
|
87
|
-
// Early return since challenge must have terminated
|
88
|
-
return;
|
89
|
-
}
|
90
|
-
|
91
|
-
ChallengeLib.Participant memory current = challenge.current;
|
92
|
-
current.timeLeft -= block.timestamp - challenge.lastMoveTimestamp;
|
93
|
-
|
94
|
-
challenge.current = challenge.next;
|
95
|
-
challenge.next = current;
|
96
|
-
|
97
|
-
challenge.lastMoveTimestamp = block.timestamp;
|
98
|
-
}
|
99
|
-
|
100
|
-
function initialize(
|
101
|
-
IChallengeResultReceiver resultReceiver_,
|
102
|
-
ISequencerInbox sequencerInbox_,
|
103
|
-
IBridge bridge_,
|
104
|
-
IOneStepProofEntry osp_
|
105
|
-
) external override onlyDelegated {
|
106
|
-
require(address(resultReceiver) == address(0), "ALREADY_INIT");
|
107
|
-
require(address(resultReceiver_) != address(0), "NO_RESULT_RECEIVER");
|
108
|
-
resultReceiver = resultReceiver_;
|
109
|
-
sequencerInbox = sequencerInbox_;
|
110
|
-
bridge = bridge_;
|
111
|
-
osp = osp_;
|
112
|
-
}
|
113
|
-
|
114
|
-
/// @dev A osp breaking change is introduced as part of Stylus upgrade, where the new osp would not support
|
115
|
-
/// pre-Stylus legacy wasmModuleRoot. To ensure that the new osp is not used for legacy wasmModuleRoot,
|
116
|
-
/// we introduce a conditional OSP where condRoot should be set to the pre-Stylus root and condOsp should
|
117
|
-
/// be set to the pre-Stylus osp. The correct value should be handled by the upgrade action contract.
|
118
|
-
function postUpgradeInit(
|
119
|
-
IOneStepProofEntry osp_,
|
120
|
-
bytes32 condRoot,
|
121
|
-
IOneStepProofEntry condOsp
|
122
|
-
) external onlyDelegated onlyProxyOwner {
|
123
|
-
ospCond[condRoot] = condOsp;
|
124
|
-
osp = osp_;
|
125
|
-
}
|
126
|
-
|
127
|
-
function getOsp(bytes32 wasmModuleRoot) public view returns (IOneStepProofEntry) {
|
128
|
-
IOneStepProofEntry t = ospCond[wasmModuleRoot];
|
129
|
-
if (address(t) == address(0)) {
|
130
|
-
return osp;
|
131
|
-
} else {
|
132
|
-
return t;
|
133
|
-
}
|
134
|
-
}
|
135
|
-
|
136
|
-
function createChallenge(
|
137
|
-
bytes32 wasmModuleRoot_,
|
138
|
-
MachineStatus[2] calldata startAndEndMachineStatuses_,
|
139
|
-
GlobalState[2] calldata startAndEndGlobalStates_,
|
140
|
-
uint64 numBlocks,
|
141
|
-
address asserter_,
|
142
|
-
address challenger_,
|
143
|
-
uint256 asserterTimeLeft_,
|
144
|
-
uint256 challengerTimeLeft_
|
145
|
-
) external override returns (uint64) {
|
146
|
-
require(msg.sender == address(resultReceiver), "ONLY_ROLLUP_CHAL");
|
147
|
-
bytes32[] memory segments = new bytes32[](2);
|
148
|
-
segments[0] = ChallengeLib.blockStateHash(
|
149
|
-
startAndEndMachineStatuses_[0],
|
150
|
-
startAndEndGlobalStates_[0].hash()
|
151
|
-
);
|
152
|
-
segments[1] = ChallengeLib.blockStateHash(
|
153
|
-
startAndEndMachineStatuses_[1],
|
154
|
-
startAndEndGlobalStates_[1].hash()
|
155
|
-
);
|
156
|
-
|
157
|
-
uint64 challengeIndex = ++totalChallengesCreated;
|
158
|
-
// The following is an assertion since it should never be possible, but it's an important invariant
|
159
|
-
assert(challengeIndex != NO_CHAL_INDEX);
|
160
|
-
ChallengeLib.Challenge storage challenge = challenges[challengeIndex];
|
161
|
-
challenge.wasmModuleRoot = wasmModuleRoot_;
|
162
|
-
|
163
|
-
// See validator/assertion.go ExecutionState RequiredBatches() for reasoning
|
164
|
-
uint64 maxInboxMessagesRead = startAndEndGlobalStates_[1].getInboxPosition();
|
165
|
-
if (
|
166
|
-
startAndEndMachineStatuses_[1] == MachineStatus.ERRORED ||
|
167
|
-
startAndEndGlobalStates_[1].getPositionInMessage() > 0
|
168
|
-
) {
|
169
|
-
maxInboxMessagesRead++;
|
170
|
-
}
|
171
|
-
challenge.maxInboxMessages = maxInboxMessagesRead;
|
172
|
-
challenge.next = ChallengeLib.Participant({addr: asserter_, timeLeft: asserterTimeLeft_});
|
173
|
-
challenge.current = ChallengeLib.Participant({
|
174
|
-
addr: challenger_,
|
175
|
-
timeLeft: challengerTimeLeft_
|
176
|
-
});
|
177
|
-
challenge.lastMoveTimestamp = block.timestamp;
|
178
|
-
challenge.mode = ChallengeLib.ChallengeMode.BLOCK;
|
179
|
-
|
180
|
-
emit InitiatedChallenge(
|
181
|
-
challengeIndex,
|
182
|
-
startAndEndGlobalStates_[0],
|
183
|
-
startAndEndGlobalStates_[1]
|
184
|
-
);
|
185
|
-
completeBisection(challengeIndex, 0, numBlocks, segments);
|
186
|
-
return challengeIndex;
|
187
|
-
}
|
188
|
-
|
189
|
-
/**
|
190
|
-
* @notice Initiate the next round in the bisection by objecting to execution correctness with a bisection
|
191
|
-
* of an execution segment with the same length but a different endpoint. This is either the initial move
|
192
|
-
* or follows another execution objection
|
193
|
-
*/
|
194
|
-
function bisectExecution(
|
195
|
-
uint64 challengeIndex,
|
196
|
-
ChallengeLib.SegmentSelection calldata selection,
|
197
|
-
bytes32[] calldata newSegments
|
198
|
-
) external takeTurn(challengeIndex, selection, ChallengeModeRequirement.ANY) {
|
199
|
-
(uint256 challengeStart, uint256 challengeLength) = ChallengeLib.extractChallengeSegment(
|
200
|
-
selection
|
201
|
-
);
|
202
|
-
require(challengeLength > 1, "TOO_SHORT");
|
203
|
-
{
|
204
|
-
uint256 expectedDegree = challengeLength;
|
205
|
-
if (expectedDegree > MAX_CHALLENGE_DEGREE) {
|
206
|
-
expectedDegree = MAX_CHALLENGE_DEGREE;
|
207
|
-
}
|
208
|
-
require(newSegments.length == expectedDegree + 1, "WRONG_DEGREE");
|
209
|
-
}
|
210
|
-
|
211
|
-
requireValidBisection(selection, newSegments[0], newSegments[newSegments.length - 1]);
|
212
|
-
|
213
|
-
completeBisection(challengeIndex, challengeStart, challengeLength, newSegments);
|
214
|
-
}
|
215
|
-
|
216
|
-
function challengeExecution(
|
217
|
-
uint64 challengeIndex,
|
218
|
-
ChallengeLib.SegmentSelection calldata selection,
|
219
|
-
MachineStatus[2] calldata machineStatuses,
|
220
|
-
bytes32[2] calldata globalStateHashes,
|
221
|
-
uint256 numSteps
|
222
|
-
) external takeTurn(challengeIndex, selection, ChallengeModeRequirement.BLOCK) {
|
223
|
-
require(numSteps >= 1, "CHALLENGE_TOO_SHORT");
|
224
|
-
require(numSteps <= OneStepProofEntryLib.MAX_STEPS, "CHALLENGE_TOO_LONG");
|
225
|
-
requireValidBisection(
|
226
|
-
selection,
|
227
|
-
ChallengeLib.blockStateHash(machineStatuses[0], globalStateHashes[0]),
|
228
|
-
ChallengeLib.blockStateHash(machineStatuses[1], globalStateHashes[1])
|
229
|
-
);
|
230
|
-
|
231
|
-
ChallengeLib.Challenge storage challenge = challenges[challengeIndex];
|
232
|
-
(uint256 executionChallengeAtSteps, uint256 challengeLength) = ChallengeLib
|
233
|
-
.extractChallengeSegment(selection);
|
234
|
-
require(challengeLength == 1, "TOO_LONG");
|
235
|
-
|
236
|
-
if (machineStatuses[0] != MachineStatus.FINISHED) {
|
237
|
-
// If the machine is in a halted state, it can't change
|
238
|
-
require(
|
239
|
-
machineStatuses[0] == machineStatuses[1] &&
|
240
|
-
globalStateHashes[0] == globalStateHashes[1],
|
241
|
-
"HALTED_CHANGE"
|
242
|
-
);
|
243
|
-
_currentWin(challengeIndex, ChallengeTerminationType.BLOCK_PROOF);
|
244
|
-
return;
|
245
|
-
}
|
246
|
-
|
247
|
-
if (machineStatuses[1] == MachineStatus.ERRORED) {
|
248
|
-
// If the machine errors, it must return to the previous global state
|
249
|
-
require(globalStateHashes[0] == globalStateHashes[1], "ERROR_CHANGE");
|
250
|
-
}
|
251
|
-
|
252
|
-
bytes32[] memory segments = new bytes32[](2);
|
253
|
-
IOneStepProofEntry _osp = getOsp(challenge.wasmModuleRoot);
|
254
|
-
segments[0] = _osp.getStartMachineHash(globalStateHashes[0], challenge.wasmModuleRoot);
|
255
|
-
segments[1] = _osp.getEndMachineHash(machineStatuses[1], globalStateHashes[1]);
|
256
|
-
|
257
|
-
challenge.mode = ChallengeLib.ChallengeMode.EXECUTION;
|
258
|
-
|
259
|
-
completeBisection(challengeIndex, 0, numSteps, segments);
|
260
|
-
|
261
|
-
emit ExecutionChallengeBegun(challengeIndex, executionChallengeAtSteps);
|
262
|
-
}
|
263
|
-
|
264
|
-
function oneStepProveExecution(
|
265
|
-
uint64 challengeIndex,
|
266
|
-
ChallengeLib.SegmentSelection calldata selection,
|
267
|
-
bytes calldata proof
|
268
|
-
) external takeTurn(challengeIndex, selection, ChallengeModeRequirement.EXECUTION) {
|
269
|
-
ChallengeLib.Challenge storage challenge = challenges[challengeIndex];
|
270
|
-
uint256 challengeStart;
|
271
|
-
{
|
272
|
-
uint256 challengeLength;
|
273
|
-
(challengeStart, challengeLength) = ChallengeLib.extractChallengeSegment(selection);
|
274
|
-
require(challengeLength == 1, "TOO_LONG");
|
275
|
-
}
|
276
|
-
|
277
|
-
bytes32 afterHash = getOsp(challenge.wasmModuleRoot).proveOneStep(
|
278
|
-
ExecutionContext({maxInboxMessagesRead: challenge.maxInboxMessages, bridge: bridge}),
|
279
|
-
challengeStart,
|
280
|
-
selection.oldSegments[selection.challengePosition],
|
281
|
-
proof
|
282
|
-
);
|
283
|
-
require(
|
284
|
-
afterHash != selection.oldSegments[selection.challengePosition + 1],
|
285
|
-
"SAME_OSP_END"
|
286
|
-
);
|
287
|
-
|
288
|
-
emit OneStepProofCompleted(challengeIndex);
|
289
|
-
_currentWin(challengeIndex, ChallengeTerminationType.EXECUTION_PROOF);
|
290
|
-
}
|
291
|
-
|
292
|
-
function timeout(uint64 challengeIndex) external override {
|
293
|
-
require(challenges[challengeIndex].mode != ChallengeLib.ChallengeMode.NONE, NO_CHAL);
|
294
|
-
require(isTimedOut(challengeIndex), "TIMEOUT_DEADLINE");
|
295
|
-
_nextWin(challengeIndex, ChallengeTerminationType.TIMEOUT);
|
296
|
-
}
|
297
|
-
|
298
|
-
function clearChallenge(uint64 challengeIndex) external override {
|
299
|
-
require(msg.sender == address(resultReceiver), "NOT_RES_RECEIVER");
|
300
|
-
require(challenges[challengeIndex].mode != ChallengeLib.ChallengeMode.NONE, NO_CHAL);
|
301
|
-
delete challenges[challengeIndex];
|
302
|
-
emit ChallengeEnded(challengeIndex, ChallengeTerminationType.CLEARED);
|
303
|
-
}
|
304
|
-
|
305
|
-
function currentResponder(uint64 challengeIndex) public view override returns (address) {
|
306
|
-
return challenges[challengeIndex].current.addr;
|
307
|
-
}
|
308
|
-
|
309
|
-
function isTimedOut(uint64 challengeIndex) public view virtual override returns (bool) {
|
310
|
-
return challenges[challengeIndex].isTimedOut();
|
311
|
-
}
|
312
|
-
|
313
|
-
function requireValidBisection(
|
314
|
-
ChallengeLib.SegmentSelection calldata selection,
|
315
|
-
bytes32 startHash,
|
316
|
-
bytes32 endHash
|
317
|
-
) private pure {
|
318
|
-
require(selection.oldSegments[selection.challengePosition] == startHash, "WRONG_START");
|
319
|
-
require(selection.oldSegments[selection.challengePosition + 1] != endHash, "SAME_END");
|
320
|
-
}
|
321
|
-
|
322
|
-
function completeBisection(
|
323
|
-
uint64 challengeIndex,
|
324
|
-
uint256 challengeStart,
|
325
|
-
uint256 challengeLength,
|
326
|
-
bytes32[] memory newSegments
|
327
|
-
) private {
|
328
|
-
assert(challengeLength >= 1);
|
329
|
-
assert(newSegments.length >= 2);
|
330
|
-
|
331
|
-
bytes32 challengeStateHash = ChallengeLib.hashChallengeState(
|
332
|
-
challengeStart,
|
333
|
-
challengeLength,
|
334
|
-
newSegments
|
335
|
-
);
|
336
|
-
challenges[challengeIndex].challengeStateHash = challengeStateHash;
|
337
|
-
|
338
|
-
emit Bisected(
|
339
|
-
challengeIndex,
|
340
|
-
challengeStateHash,
|
341
|
-
challengeStart,
|
342
|
-
challengeLength,
|
343
|
-
newSegments
|
344
|
-
);
|
345
|
-
}
|
346
|
-
|
347
|
-
/// @dev This function causes the mode of the challenge to be set to NONE by deleting the challenge
|
348
|
-
function _nextWin(uint64 challengeIndex, ChallengeTerminationType reason) private {
|
349
|
-
ChallengeLib.Challenge storage challenge = challenges[challengeIndex];
|
350
|
-
address next = challenge.next.addr;
|
351
|
-
address current = challenge.current.addr;
|
352
|
-
delete challenges[challengeIndex];
|
353
|
-
resultReceiver.completeChallenge(challengeIndex, next, current);
|
354
|
-
emit ChallengeEnded(challengeIndex, reason);
|
355
|
-
}
|
356
|
-
|
357
|
-
/**
|
358
|
-
* @dev this currently sets a challenge hash of 0 - no move is possible for the next participant to progress the
|
359
|
-
* state. It is assumed that wherever this function is consumed, the turn is then adjusted for the opposite party
|
360
|
-
* to timeout. This is done as a safety measure so challenges can only be resolved by timeouts during mainnet beta.
|
361
|
-
*/
|
362
|
-
function _currentWin(
|
363
|
-
uint64 challengeIndex,
|
364
|
-
ChallengeTerminationType /* reason */
|
365
|
-
) private {
|
366
|
-
ChallengeLib.Challenge storage challenge = challenges[challengeIndex];
|
367
|
-
challenge.challengeStateHash = bytes32(0);
|
368
|
-
|
369
|
-
// address next = challenge.next.addr;
|
370
|
-
// address current = challenge.current.addr;
|
371
|
-
// delete challenges[challengeIndex];
|
372
|
-
// resultReceiver.completeChallenge(challengeIndex, current, next);
|
373
|
-
// emit ChallengeEnded(challengeIndex, reason);
|
374
|
-
}
|
375
|
-
}
|
@@ -1,86 +0,0 @@
|
|
1
|
-
// Copyright 2021-2022, Offchain Labs, Inc.
|
2
|
-
// For license information, see https://github.com/OffchainLabs/nitro-contracts/blob/main/LICENSE
|
3
|
-
// SPDX-License-Identifier: BUSL-1.1
|
4
|
-
|
5
|
-
pragma solidity ^0.8.0;
|
6
|
-
|
7
|
-
import "../state/Machine.sol";
|
8
|
-
import "../bridge/IBridge.sol";
|
9
|
-
import "../bridge/ISequencerInbox.sol";
|
10
|
-
import "../osp/IOneStepProofEntry.sol";
|
11
|
-
|
12
|
-
import "./IChallengeResultReceiver.sol";
|
13
|
-
|
14
|
-
import "./ChallengeLib.sol";
|
15
|
-
|
16
|
-
interface IChallengeManager {
|
17
|
-
enum ChallengeTerminationType {
|
18
|
-
TIMEOUT,
|
19
|
-
BLOCK_PROOF,
|
20
|
-
EXECUTION_PROOF,
|
21
|
-
CLEARED
|
22
|
-
}
|
23
|
-
|
24
|
-
event InitiatedChallenge(
|
25
|
-
uint64 indexed challengeIndex,
|
26
|
-
GlobalState startState,
|
27
|
-
GlobalState endState
|
28
|
-
);
|
29
|
-
|
30
|
-
event Bisected(
|
31
|
-
uint64 indexed challengeIndex,
|
32
|
-
bytes32 indexed challengeRoot,
|
33
|
-
uint256 challengedSegmentStart,
|
34
|
-
uint256 challengedSegmentLength,
|
35
|
-
bytes32[] chainHashes
|
36
|
-
);
|
37
|
-
|
38
|
-
event ExecutionChallengeBegun(uint64 indexed challengeIndex, uint256 blockSteps);
|
39
|
-
event OneStepProofCompleted(uint64 indexed challengeIndex);
|
40
|
-
|
41
|
-
event ChallengeEnded(uint64 indexed challengeIndex, ChallengeTerminationType kind);
|
42
|
-
|
43
|
-
function initialize(
|
44
|
-
IChallengeResultReceiver resultReceiver_,
|
45
|
-
ISequencerInbox sequencerInbox_,
|
46
|
-
IBridge bridge_,
|
47
|
-
IOneStepProofEntry osp_
|
48
|
-
) external;
|
49
|
-
|
50
|
-
function postUpgradeInit(
|
51
|
-
IOneStepProofEntry osp_,
|
52
|
-
bytes32 condRoot,
|
53
|
-
IOneStepProofEntry condOsp
|
54
|
-
) external;
|
55
|
-
|
56
|
-
/// @notice Get the default osp, which is used for all wasm module roots that don't have a conditional OSP set
|
57
|
-
/// Use getOsp(wasmModuleRoot) to get the OSP for a specific wasm module root
|
58
|
-
function osp() external view returns (IOneStepProofEntry);
|
59
|
-
|
60
|
-
/// @notice Get the OSP for a given wasm module root
|
61
|
-
function getOsp(bytes32 wasmModuleRoot) external view returns (IOneStepProofEntry);
|
62
|
-
|
63
|
-
function createChallenge(
|
64
|
-
bytes32 wasmModuleRoot_,
|
65
|
-
MachineStatus[2] calldata startAndEndMachineStatuses_,
|
66
|
-
GlobalState[2] calldata startAndEndGlobalStates_,
|
67
|
-
uint64 numBlocks,
|
68
|
-
address asserter_,
|
69
|
-
address challenger_,
|
70
|
-
uint256 asserterTimeLeft_,
|
71
|
-
uint256 challengerTimeLeft_
|
72
|
-
) external returns (uint64);
|
73
|
-
|
74
|
-
function challengeInfo(uint64 challengeIndex_)
|
75
|
-
external
|
76
|
-
view
|
77
|
-
returns (ChallengeLib.Challenge memory);
|
78
|
-
|
79
|
-
function currentResponder(uint64 challengeIndex) external view returns (address);
|
80
|
-
|
81
|
-
function isTimedOut(uint64 challengeIndex) external view returns (bool);
|
82
|
-
|
83
|
-
function clearChallenge(uint64 challengeIndex_) external;
|
84
|
-
|
85
|
-
function timeout(uint64 challengeIndex_) external;
|
86
|
-
}
|
@@ -1,13 +0,0 @@
|
|
1
|
-
// Copyright 2021-2022, Offchain Labs, Inc.
|
2
|
-
// For license information, see https://github.com/OffchainLabs/nitro-contracts/blob/main/LICENSE
|
3
|
-
// SPDX-License-Identifier: BUSL-1.1
|
4
|
-
|
5
|
-
pragma solidity ^0.8.0;
|
6
|
-
|
7
|
-
interface IChallengeResultReceiver {
|
8
|
-
function completeChallenge(
|
9
|
-
uint256 challengeIndex,
|
10
|
-
address winner,
|
11
|
-
address loser
|
12
|
-
) external;
|
13
|
-
}
|
@@ -1,142 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: BUSL-1.1
|
2
|
-
pragma solidity ^0.8.0;
|
3
|
-
|
4
|
-
import "./Errors.sol";
|
5
|
-
|
6
|
-
/// @notice Account balance and the round at which it can be withdrawn
|
7
|
-
/// Balances are withdrawn as part of a two step process - initiation and finalization
|
8
|
-
/// This is so that a bidder can't withdraw their balance after making a bid
|
9
|
-
/// Instead, if they initiate their withdrawal in round r, they must wait until the beginning of
|
10
|
-
/// round r+2 before they can withdraw the balance. In the mean time their balance can be used to
|
11
|
-
/// resolve an auction if it is part of a valid bid, however the auctioneer may choose to
|
12
|
-
/// reject bids from accounts with an initiated balance withdrawal
|
13
|
-
struct Balance {
|
14
|
-
/// @notice The amount of balance in the account
|
15
|
-
uint256 balance;
|
16
|
-
/// @notice The round at which all of the balance can be withdrawn
|
17
|
-
/// Is set to uint64.max when no withdrawal has been intiated
|
18
|
-
uint64 withdrawalRound;
|
19
|
-
}
|
20
|
-
|
21
|
-
/// @notice Balance mutation and view functionality. This is in it's own library so that we can
|
22
|
-
// reason about and test how the different ways balance mutations interact with each other
|
23
|
-
library BalanceLib {
|
24
|
-
/// @notice The available balance at the supplied round. Returns 0 if a withdrawal has been initiated and has
|
25
|
-
/// past the withdrawal round.
|
26
|
-
/// @param bal The balance to query
|
27
|
-
/// @param round The round to check the balance in
|
28
|
-
function balanceAtRound(Balance storage bal, uint64 round) internal view returns (uint256) {
|
29
|
-
return bal.balance - withdrawableBalanceAtRound(bal, round);
|
30
|
-
}
|
31
|
-
|
32
|
-
/// @notice The withdrawable balance at the supplied round. If a withdrawal has been initiated, the
|
33
|
-
/// supplied round is past the withdrawal round and has yet to be finalized, then the balance
|
34
|
-
/// of this account is returned. Otherwise 0.
|
35
|
-
/// @param bal The balance to query
|
36
|
-
/// @param round The round to check the withdrawable balance in
|
37
|
-
function withdrawableBalanceAtRound(Balance storage bal, uint64 round)
|
38
|
-
internal
|
39
|
-
view
|
40
|
-
returns (uint256)
|
41
|
-
{
|
42
|
-
return round >= bal.withdrawalRound ? bal.balance : 0;
|
43
|
-
}
|
44
|
-
|
45
|
-
/// @notice Increase a balance by a specified amount
|
46
|
-
/// Will cancel a withdrawal if called after a withdrawal has been initiated
|
47
|
-
/// @param bal The balance info
|
48
|
-
/// @param amount The amount to increase the balance by
|
49
|
-
function increase(Balance storage bal, uint256 amount) internal {
|
50
|
-
// no point increasing if no amount is being supplied
|
51
|
-
if (amount == 0) {
|
52
|
-
revert ZeroAmount();
|
53
|
-
}
|
54
|
-
|
55
|
-
// if the balance have never been used before then balance and withdrawal round will be 0
|
56
|
-
// in this case we initialize the balance by setting the withdrawal round into the future
|
57
|
-
// if a withdrawal for the balance has been initialized (withdrawal round != 0 and != max)
|
58
|
-
// then we cancel that initiated withdrawal. We do this since if a increase is being made that
|
59
|
-
// means a user wishes to increase their balance, not withdraw it.
|
60
|
-
if (bal.withdrawalRound != type(uint64).max) {
|
61
|
-
bal.withdrawalRound = type(uint64).max;
|
62
|
-
}
|
63
|
-
|
64
|
-
bal.balance += amount;
|
65
|
-
}
|
66
|
-
|
67
|
-
/// @notice Reduce a balance immediately. The balance must already be greater than the amount
|
68
|
-
/// and a withdrawal has been initiated for this balance it must be occuring in
|
69
|
-
/// a round after the supplied round. Withdrawals earlier than that will block this reduce.
|
70
|
-
/// @param bal The balance to reduce
|
71
|
-
/// @param amount The amount to reduce by
|
72
|
-
/// @param round The round to check withdrawals against. A withdrawal after this round will be ignored
|
73
|
-
/// and the balance reduced anyway, withdrawals before or on this round will be respected
|
74
|
-
/// and the reduce will revert
|
75
|
-
function reduce(
|
76
|
-
Balance storage bal,
|
77
|
-
uint256 amount,
|
78
|
-
uint64 round
|
79
|
-
) internal {
|
80
|
-
uint256 balRnd = balanceAtRound(bal, round);
|
81
|
-
// we add a zero check since it's possible for the amount to be zero
|
82
|
-
// but even in that case the user must have some balance
|
83
|
-
// to enforce that parties that havent done the deposit step cannot take part in the auction
|
84
|
-
if (balRnd == 0 || balRnd < amount) {
|
85
|
-
revert InsufficientBalance(amount, balRnd);
|
86
|
-
}
|
87
|
-
|
88
|
-
bal.balance -= amount;
|
89
|
-
}
|
90
|
-
|
91
|
-
/// @notice Initiate a withdrawal. A withdrawal is a reduction of the full amount.
|
92
|
-
/// Withdrawal is a two step process initialization and finalization. Finalization is only
|
93
|
-
/// after the supplied round parameter. The expected usage is to specify a round that is 2
|
94
|
-
/// in the future to ensure that the balance cannot be reduced unexpectedly without notice.
|
95
|
-
// An external observer can see that a withdrawal has been initiated, and will therefore
|
96
|
-
/// be able to take it into account and not rely on the balance being there.
|
97
|
-
/// In the case of the auction contract this allows the bidders to withdraw their
|
98
|
-
/// balance, but an auctioneer will know not to accept there bids in the mean time
|
99
|
-
/// @param bal The balance to iniate a reduction on
|
100
|
-
/// @param round The round that the withdrawal will be available in. Cannot be specified as the max round
|
101
|
-
function initiateWithdrawal(Balance storage bal, uint64 round) internal {
|
102
|
-
if (bal.balance == 0) {
|
103
|
-
revert ZeroAmount();
|
104
|
-
}
|
105
|
-
|
106
|
-
if (round == type(uint64).max) {
|
107
|
-
// we use max round to specify that a withdrawal is not taking place
|
108
|
-
// so we dont allow it as a withdrawal round. In practice max round should never
|
109
|
-
// be reached so this isnt an issue, we just put this here as an additional
|
110
|
-
// safety check
|
111
|
-
revert WithdrawalMaxRound();
|
112
|
-
}
|
113
|
-
|
114
|
-
if (bal.withdrawalRound != type(uint64).max) {
|
115
|
-
revert WithdrawalInProgress();
|
116
|
-
}
|
117
|
-
|
118
|
-
bal.withdrawalRound = round;
|
119
|
-
}
|
120
|
-
|
121
|
-
/// @notice Finalize an already initialized withdrawal. Reduces the balance to 0.
|
122
|
-
/// Can only be called two round after the withdrawal was initiated.
|
123
|
-
/// @param bal The balance to finalize
|
124
|
-
/// @param round The round to check whether withdrawal is valid in. Usually the current round. Cannot be max round.
|
125
|
-
function finalizeWithdrawal(Balance storage bal, uint64 round) internal returns (uint256) {
|
126
|
-
if (round == type(uint64).max) {
|
127
|
-
// we use max round to specify that a withdrawal is not taking place
|
128
|
-
// so we dont allow it as a withdrawal round. In practice max round should never
|
129
|
-
// be reached so this isnt an issue, we just put this here as an additional
|
130
|
-
// safety check
|
131
|
-
revert WithdrawalMaxRound();
|
132
|
-
}
|
133
|
-
|
134
|
-
uint256 withdrawableBalance = withdrawableBalanceAtRound(bal, round);
|
135
|
-
if (withdrawableBalance == 0) {
|
136
|
-
revert NothingToWithdraw();
|
137
|
-
}
|
138
|
-
|
139
|
-
bal.balance = 0;
|
140
|
-
return withdrawableBalance;
|
141
|
-
}
|
142
|
-
}
|
@@ -1,25 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: BUSL-1.1
|
2
|
-
pragma solidity ^0.8.0;
|
3
|
-
|
4
|
-
import {
|
5
|
-
ERC20BurnableUpgradeable
|
6
|
-
} from "@openzeppelin/contracts-upgradeable/token/ERC20/extensions/ERC20BurnableUpgradeable.sol";
|
7
|
-
import "./Errors.sol";
|
8
|
-
|
9
|
-
/// @notice A simple contract that can burn any tokens that are transferred to it
|
10
|
-
/// Token must support the ERC20BurnableUpgradeable.burn(uint256) interface
|
11
|
-
contract Burner {
|
12
|
-
ERC20BurnableUpgradeable public immutable token;
|
13
|
-
|
14
|
-
constructor(address _token) {
|
15
|
-
if (_token == address(0)) {
|
16
|
-
revert ZeroAddress();
|
17
|
-
}
|
18
|
-
token = ERC20BurnableUpgradeable(_token);
|
19
|
-
}
|
20
|
-
|
21
|
-
/// @notice Can be called at any time by anyone to burn any tokens held by this burner
|
22
|
-
function burn() external {
|
23
|
-
token.burn(token.balanceOf(address(this)));
|
24
|
-
}
|
25
|
-
}
|