@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
@@ -0,0 +1,74 @@
|
|
1
|
+
// Copyright 2023, Offchain Labs, Inc.
|
2
|
+
// For license information, see https://github.com/offchainlabs/bold/blob/main/LICENSE
|
3
|
+
// SPDX-License-Identifier: BUSL-1.1
|
4
|
+
//
|
5
|
+
pragma solidity ^0.8.17;
|
6
|
+
|
7
|
+
/// @title Uint utils library
|
8
|
+
/// @notice Some additional bit inspection tools
|
9
|
+
library UintUtilsLib {
|
10
|
+
/// @notice The least significant bit in the bit representation of a uint
|
11
|
+
/// @dev Zero indexed from the least sig bit. Eg 1010 => 1, 1100 => 2, 1001 => 0
|
12
|
+
/// Finds lsb in linear (uint size) time
|
13
|
+
/// @param x Cannot be zero, since zero that has no signficant bits
|
14
|
+
function leastSignificantBit(
|
15
|
+
uint256 x
|
16
|
+
) internal pure returns (uint256 msb) {
|
17
|
+
require(x > 0, "Zero has no significant bits");
|
18
|
+
|
19
|
+
// isolate the least sig bit
|
20
|
+
uint256 isolated = ((x - 1) & x) ^ x;
|
21
|
+
|
22
|
+
// since we removed all higher bits, least sig == most sig
|
23
|
+
return mostSignificantBit(isolated);
|
24
|
+
}
|
25
|
+
|
26
|
+
/// @notice The most significant bit in the bit representation of a uint
|
27
|
+
/// @dev Zero indexed from the least sig bit. Eg 1010 => 3, 110 => 2, 1 => 0
|
28
|
+
/// Taken from https://solidity-by-example.org/bitwise/
|
29
|
+
/// Finds msb in log (uint size) time
|
30
|
+
/// @param x Cannot be zero, since zero has no sigificant bits
|
31
|
+
function mostSignificantBit(
|
32
|
+
uint256 x
|
33
|
+
) internal pure returns (uint256 msb) {
|
34
|
+
require(x != 0, "Zero has no significant bits");
|
35
|
+
|
36
|
+
// x >= 2 ** 128
|
37
|
+
if (x >= 0x100000000000000000000000000000000) {
|
38
|
+
x >>= 128;
|
39
|
+
msb += 128;
|
40
|
+
}
|
41
|
+
// x >= 2 ** 64
|
42
|
+
if (x >= 0x10000000000000000) {
|
43
|
+
x >>= 64;
|
44
|
+
msb += 64;
|
45
|
+
}
|
46
|
+
// x >= 2 ** 32
|
47
|
+
if (x >= 0x100000000) {
|
48
|
+
x >>= 32;
|
49
|
+
msb += 32;
|
50
|
+
}
|
51
|
+
// x >= 2 ** 16
|
52
|
+
if (x >= 0x10000) {
|
53
|
+
x >>= 16;
|
54
|
+
msb += 16;
|
55
|
+
}
|
56
|
+
// x >= 2 ** 8
|
57
|
+
if (x >= 0x100) {
|
58
|
+
x >>= 8;
|
59
|
+
msb += 8;
|
60
|
+
}
|
61
|
+
// x >= 2 ** 4
|
62
|
+
if (x >= 0x10) {
|
63
|
+
x >>= 4;
|
64
|
+
msb += 4;
|
65
|
+
}
|
66
|
+
// x >= 2 ** 2
|
67
|
+
if (x >= 0x4) {
|
68
|
+
x >>= 2;
|
69
|
+
msb += 2;
|
70
|
+
}
|
71
|
+
// x >= 2 ** 1
|
72
|
+
if (x >= 0x2) msb += 1;
|
73
|
+
}
|
74
|
+
}
|
@@ -11,7 +11,9 @@ library AddressAliasHelper {
|
|
11
11
|
/// the inbox to the msg.sender viewed in the L2
|
12
12
|
/// @param l1Address the address in the L1 that triggered the tx to L2
|
13
13
|
/// @return l2Address L2 address as viewed in msg.sender
|
14
|
-
function applyL1ToL2Alias(
|
14
|
+
function applyL1ToL2Alias(
|
15
|
+
address l1Address
|
16
|
+
) internal pure returns (address l2Address) {
|
15
17
|
unchecked {
|
16
18
|
l2Address = address(uint160(l1Address) + OFFSET);
|
17
19
|
}
|
@@ -21,7 +23,9 @@ library AddressAliasHelper {
|
|
21
23
|
/// address in the L1 that submitted a tx to the inbox
|
22
24
|
/// @param l2Address L2 address as viewed in msg.sender
|
23
25
|
/// @return l1Address the address in the L1 that triggered the tx to L2
|
24
|
-
function undoL1ToL2Alias(
|
26
|
+
function undoL1ToL2Alias(
|
27
|
+
address l2Address
|
28
|
+
) internal pure returns (address l1Address) {
|
25
29
|
unchecked {
|
26
30
|
l1Address = address(uint160(l2Address) - OFFSET);
|
27
31
|
}
|
@@ -34,7 +34,9 @@ abstract contract DoubleLogicERC1967Upgrade is ERC1967Upgrade {
|
|
34
34
|
/**
|
35
35
|
* @dev Stores a new address in the EIP1967 implementation slot.
|
36
36
|
*/
|
37
|
-
function _setSecondaryImplementation(
|
37
|
+
function _setSecondaryImplementation(
|
38
|
+
address newImplementation
|
39
|
+
) private {
|
38
40
|
require(
|
39
41
|
Address.isContract(newImplementation),
|
40
42
|
"ERC1967: new secondary implementation is not a contract"
|
@@ -47,7 +49,9 @@ abstract contract DoubleLogicERC1967Upgrade is ERC1967Upgrade {
|
|
47
49
|
*
|
48
50
|
* Emits an {UpgradedSecondary} event.
|
49
51
|
*/
|
50
|
-
function _upgradeSecondaryTo(
|
52
|
+
function _upgradeSecondaryTo(
|
53
|
+
address newImplementation
|
54
|
+
) internal {
|
51
55
|
_setSecondaryImplementation(newImplementation);
|
52
56
|
emit UpgradedSecondary(newImplementation);
|
53
57
|
}
|
@@ -119,8 +123,8 @@ contract AdminFallbackProxy is Proxy, DoubleLogicERC1967Upgrade {
|
|
119
123
|
_IMPLEMENTATION_SLOT == bytes32(uint256(keccak256("eip1967.proxy.implementation")) - 1)
|
120
124
|
);
|
121
125
|
assert(
|
122
|
-
_IMPLEMENTATION_SECONDARY_SLOT
|
123
|
-
bytes32(uint256(keccak256("eip1967.proxy.implementation.secondary")) - 1)
|
126
|
+
_IMPLEMENTATION_SECONDARY_SLOT
|
127
|
+
== bytes32(uint256(keccak256("eip1967.proxy.implementation.secondary")) - 1)
|
124
128
|
);
|
125
129
|
_changeAdmin(adminAddr);
|
126
130
|
_upgradeToAndCall(adminLogic, adminData, false);
|
@@ -1,5 +1,5 @@
|
|
1
1
|
// Copyright 2021-2022, Offchain Labs, Inc.
|
2
|
-
// For license information, see https://github.com/nitro/blob/
|
2
|
+
// For license information, see https://github.com/OffchainLabs/nitro-contracts/blob/main/LICENSE
|
3
3
|
// SPDX-License-Identifier: BUSL-1.1
|
4
4
|
|
5
5
|
pragma solidity ^0.8.0;
|
@@ -8,9 +8,8 @@ import "../precompiles/ArbSys.sol";
|
|
8
8
|
|
9
9
|
library ArbitrumChecker {
|
10
10
|
function runningOnArbitrum() internal view returns (bool) {
|
11
|
-
(bool ok, bytes memory data) =
|
12
|
-
abi.encodeWithSelector(ArbSys.arbOSVersion.selector)
|
13
|
-
);
|
11
|
+
(bool ok, bytes memory data) =
|
12
|
+
address(100).staticcall(abi.encodeWithSelector(ArbSys.arbOSVersion.selector));
|
14
13
|
return ok && data.length == 32;
|
15
14
|
}
|
16
15
|
}
|
@@ -0,0 +1,18 @@
|
|
1
|
+
// Copyright 2021-2024, 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
|
+
library CallerChecker {
|
8
|
+
/**
|
9
|
+
* @notice A EIP-7702 safe check to ensure the caller is the origin and is codeless
|
10
|
+
* @return bool true if the caller is the origin and is codeless, false otherwise
|
11
|
+
* @dev If the caller is the origin and is codeless, then msg.data is guaranteed to be same as tx.data
|
12
|
+
* It also mean the caller would not be able to call a contract multiple times with the same transaction
|
13
|
+
*/
|
14
|
+
function isCallerCodelessOrigin() internal view returns (bool) {
|
15
|
+
// solhint-disable-next-line avoid-tx-origin
|
16
|
+
return msg.sender == tx.origin && msg.sender.code.length == 0;
|
17
|
+
}
|
18
|
+
}
|
@@ -9,7 +9,9 @@ library CryptographyPrimitives {
|
|
9
9
|
// WARNING: This function has the keccak state in a weird order.
|
10
10
|
// If the normal Keccak state is [0, 1, 2, 3, 4, 5, 6, ..., 24]
|
11
11
|
// this function has its state as [0, 5, 10, 15, 20, 1, 6, 11, ..., 24]
|
12
|
-
function keccakF(
|
12
|
+
function keccakF(
|
13
|
+
uint256[25] memory a
|
14
|
+
) internal pure returns (uint256[25] memory) {
|
13
15
|
uint256[5] memory c;
|
14
16
|
uint256[5] memory d;
|
15
17
|
//uint D_0; uint D_1; uint D_2; uint D_3; uint D_4;
|
@@ -60,11 +62,11 @@ library CryptographyPrimitives {
|
|
60
62
|
D[x] = C[(x+4)%5]^((C[(x+1)%5] * 2)&0xffffffffffffffff | (C[(x+1)%5]/(2**63)));
|
61
63
|
}*/
|
62
64
|
|
63
|
-
d[0] = c[4] ^ (((c[1] * 2) & 0xffffffffffffffff) | (c[1] / (2**63)));
|
64
|
-
d[1] = c[0] ^ (((c[2] * 2) & 0xffffffffffffffff) | (c[2] / (2**63)));
|
65
|
-
d[2] = c[1] ^ (((c[3] * 2) & 0xffffffffffffffff) | (c[3] / (2**63)));
|
66
|
-
d[3] = c[2] ^ (((c[4] * 2) & 0xffffffffffffffff) | (c[4] / (2**63)));
|
67
|
-
d[4] = c[3] ^ (((c[0] * 2) & 0xffffffffffffffff) | (c[0] / (2**63)));
|
65
|
+
d[0] = c[4] ^ (((c[1] * 2) & 0xffffffffffffffff) | (c[1] / (2 ** 63)));
|
66
|
+
d[1] = c[0] ^ (((c[2] * 2) & 0xffffffffffffffff) | (c[2] / (2 ** 63)));
|
67
|
+
d[2] = c[1] ^ (((c[3] * 2) & 0xffffffffffffffff) | (c[3] / (2 ** 63)));
|
68
|
+
d[3] = c[2] ^ (((c[4] * 2) & 0xffffffffffffffff) | (c[4] / (2 ** 63)));
|
69
|
+
d[4] = c[3] ^ (((c[0] * 2) & 0xffffffffffffffff) | (c[0] / (2 ** 63)));
|
68
70
|
|
69
71
|
/*
|
70
72
|
for( x = 0 ; x < 5 ; x++ ) {
|
@@ -101,30 +103,30 @@ library CryptographyPrimitives {
|
|
101
103
|
|
102
104
|
/*Rho and pi steps*/
|
103
105
|
b[0] = a[0];
|
104
|
-
b[8] = (((a[1] * (2**36)) & 0xffffffffffffffff) | (a[1] / (2**28)));
|
105
|
-
b[11] = (((a[2] * (2**3)) & 0xffffffffffffffff) | (a[2] / (2**61)));
|
106
|
-
b[19] = (((a[3] * (2**41)) & 0xffffffffffffffff) | (a[3] / (2**23)));
|
107
|
-
b[22] = (((a[4] * (2**18)) & 0xffffffffffffffff) | (a[4] / (2**46)));
|
108
|
-
b[2] = (((a[5] * (2**1)) & 0xffffffffffffffff) | (a[5] / (2**63)));
|
109
|
-
b[5] = (((a[6] * (2**44)) & 0xffffffffffffffff) | (a[6] / (2**20)));
|
110
|
-
b[13] = (((a[7] * (2**10)) & 0xffffffffffffffff) | (a[7] / (2**54)));
|
111
|
-
b[16] = (((a[8] * (2**45)) & 0xffffffffffffffff) | (a[8] / (2**19)));
|
112
|
-
b[24] = (((a[9] * (2**2)) & 0xffffffffffffffff) | (a[9] / (2**62)));
|
113
|
-
b[4] = (((a[10] * (2**62)) & 0xffffffffffffffff) | (a[10] / (2**2)));
|
114
|
-
b[7] = (((a[11] * (2**6)) & 0xffffffffffffffff) | (a[11] / (2**58)));
|
115
|
-
b[10] = (((a[12] * (2**43)) & 0xffffffffffffffff) | (a[12] / (2**21)));
|
116
|
-
b[18] = (((a[13] * (2**15)) & 0xffffffffffffffff) | (a[13] / (2**49)));
|
117
|
-
b[21] = (((a[14] * (2**61)) & 0xffffffffffffffff) | (a[14] / (2**3)));
|
118
|
-
b[1] = (((a[15] * (2**28)) & 0xffffffffffffffff) | (a[15] / (2**36)));
|
119
|
-
b[9] = (((a[16] * (2**55)) & 0xffffffffffffffff) | (a[16] / (2**9)));
|
120
|
-
b[12] = (((a[17] * (2**25)) & 0xffffffffffffffff) | (a[17] / (2**39)));
|
121
|
-
b[15] = (((a[18] * (2**21)) & 0xffffffffffffffff) | (a[18] / (2**43)));
|
122
|
-
b[23] = (((a[19] * (2**56)) & 0xffffffffffffffff) | (a[19] / (2**8)));
|
123
|
-
b[3] = (((a[20] * (2**27)) & 0xffffffffffffffff) | (a[20] / (2**37)));
|
124
|
-
b[6] = (((a[21] * (2**20)) & 0xffffffffffffffff) | (a[21] / (2**44)));
|
125
|
-
b[14] = (((a[22] * (2**39)) & 0xffffffffffffffff) | (a[22] / (2**25)));
|
126
|
-
b[17] = (((a[23] * (2**8)) & 0xffffffffffffffff) | (a[23] / (2**56)));
|
127
|
-
b[20] = (((a[24] * (2**14)) & 0xffffffffffffffff) | (a[24] / (2**50)));
|
106
|
+
b[8] = (((a[1] * (2 ** 36)) & 0xffffffffffffffff) | (a[1] / (2 ** 28)));
|
107
|
+
b[11] = (((a[2] * (2 ** 3)) & 0xffffffffffffffff) | (a[2] / (2 ** 61)));
|
108
|
+
b[19] = (((a[3] * (2 ** 41)) & 0xffffffffffffffff) | (a[3] / (2 ** 23)));
|
109
|
+
b[22] = (((a[4] * (2 ** 18)) & 0xffffffffffffffff) | (a[4] / (2 ** 46)));
|
110
|
+
b[2] = (((a[5] * (2 ** 1)) & 0xffffffffffffffff) | (a[5] / (2 ** 63)));
|
111
|
+
b[5] = (((a[6] * (2 ** 44)) & 0xffffffffffffffff) | (a[6] / (2 ** 20)));
|
112
|
+
b[13] = (((a[7] * (2 ** 10)) & 0xffffffffffffffff) | (a[7] / (2 ** 54)));
|
113
|
+
b[16] = (((a[8] * (2 ** 45)) & 0xffffffffffffffff) | (a[8] / (2 ** 19)));
|
114
|
+
b[24] = (((a[9] * (2 ** 2)) & 0xffffffffffffffff) | (a[9] / (2 ** 62)));
|
115
|
+
b[4] = (((a[10] * (2 ** 62)) & 0xffffffffffffffff) | (a[10] / (2 ** 2)));
|
116
|
+
b[7] = (((a[11] * (2 ** 6)) & 0xffffffffffffffff) | (a[11] / (2 ** 58)));
|
117
|
+
b[10] = (((a[12] * (2 ** 43)) & 0xffffffffffffffff) | (a[12] / (2 ** 21)));
|
118
|
+
b[18] = (((a[13] * (2 ** 15)) & 0xffffffffffffffff) | (a[13] / (2 ** 49)));
|
119
|
+
b[21] = (((a[14] * (2 ** 61)) & 0xffffffffffffffff) | (a[14] / (2 ** 3)));
|
120
|
+
b[1] = (((a[15] * (2 ** 28)) & 0xffffffffffffffff) | (a[15] / (2 ** 36)));
|
121
|
+
b[9] = (((a[16] * (2 ** 55)) & 0xffffffffffffffff) | (a[16] / (2 ** 9)));
|
122
|
+
b[12] = (((a[17] * (2 ** 25)) & 0xffffffffffffffff) | (a[17] / (2 ** 39)));
|
123
|
+
b[15] = (((a[18] * (2 ** 21)) & 0xffffffffffffffff) | (a[18] / (2 ** 43)));
|
124
|
+
b[23] = (((a[19] * (2 ** 56)) & 0xffffffffffffffff) | (a[19] / (2 ** 8)));
|
125
|
+
b[3] = (((a[20] * (2 ** 27)) & 0xffffffffffffffff) | (a[20] / (2 ** 37)));
|
126
|
+
b[6] = (((a[21] * (2 ** 20)) & 0xffffffffffffffff) | (a[21] / (2 ** 44)));
|
127
|
+
b[14] = (((a[22] * (2 ** 39)) & 0xffffffffffffffff) | (a[22] / (2 ** 25)));
|
128
|
+
b[17] = (((a[23] * (2 ** 8)) & 0xffffffffffffffff) | (a[23] / (2 ** 56)));
|
129
|
+
b[20] = (((a[24] * (2 ** 14)) & 0xffffffffffffffff) | (a[24] / (2 ** 50)));
|
128
130
|
|
129
131
|
/*Xi state*/
|
130
132
|
/*
|
@@ -172,11 +174,7 @@ library CryptographyPrimitives {
|
|
172
174
|
return ((x) >> (n)) | ((x) << (32 - (n)));
|
173
175
|
}
|
174
176
|
|
175
|
-
function ch(
|
176
|
-
uint32 e,
|
177
|
-
uint32 f,
|
178
|
-
uint32 g
|
179
|
-
) internal pure returns (uint32) {
|
177
|
+
function ch(uint32 e, uint32 f, uint32 g) internal pure returns (uint32) {
|
180
178
|
return ((e & f) ^ ((~e) & g));
|
181
179
|
}
|
182
180
|
|
@@ -184,11 +182,10 @@ library CryptographyPrimitives {
|
|
184
182
|
// Note that the input must be padded by the caller
|
185
183
|
// For the initial chunk, the initial values from the SHA256 spec should be passed in as hashState
|
186
184
|
// For subsequent rounds, hashState is the output from the previous round
|
187
|
-
function sha256Block(
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
{
|
185
|
+
function sha256Block(
|
186
|
+
uint256[2] memory inputChunk,
|
187
|
+
uint256 hashState
|
188
|
+
) internal pure returns (uint256) {
|
192
189
|
unchecked {
|
193
190
|
uint32[64] memory k = [
|
194
191
|
0x428a2f98,
|
@@ -285,14 +282,10 @@ library CryptographyPrimitives {
|
|
285
282
|
|
286
283
|
for (i = 0; i < 64; i++) {
|
287
284
|
s1 =
|
288
|
-
rightRotate(state[4], 6) ^
|
289
|
-
rightRotate(state[4], 11) ^
|
290
|
-
rightRotate(state[4], 25);
|
285
|
+
rightRotate(state[4], 6) ^ rightRotate(state[4], 11) ^ rightRotate(state[4], 25);
|
291
286
|
temp1 = state[7] + s1 + ch(state[4], state[5], state[6]) + k[i] + w[i];
|
292
287
|
s0 =
|
293
|
-
rightRotate(state[0], 2) ^
|
294
|
-
rightRotate(state[0], 13) ^
|
295
|
-
rightRotate(state[0], 22);
|
288
|
+
rightRotate(state[0], 2) ^ rightRotate(state[0], 13) ^ rightRotate(state[0], 22);
|
296
289
|
|
297
290
|
maj = (state[0] & (state[1] ^ state[2])) ^ (state[1] & state[2]);
|
298
291
|
temp2 = s0 + maj;
|
@@ -4,8 +4,6 @@
|
|
4
4
|
|
5
5
|
pragma solidity ^0.8.0;
|
6
6
|
|
7
|
-
import {ERC20} from "@openzeppelin/contracts/token/ERC20/ERC20.sol";
|
8
|
-
|
9
7
|
library DecimalsConverterHelper {
|
10
8
|
/// @notice generic function for mapping amount from one decimal denomination to another
|
11
9
|
/// @dev Ie. let's say amount is 752. If token has 16 decimals and is being adjusted to
|
@@ -25,9 +23,9 @@ library DecimalsConverterHelper {
|
|
25
23
|
if (decimalsIn == decimalsOut) {
|
26
24
|
return amount;
|
27
25
|
} else if (decimalsIn < decimalsOut) {
|
28
|
-
return amount * 10**(decimalsOut - decimalsIn);
|
26
|
+
return amount * 10 ** (decimalsOut - decimalsIn);
|
29
27
|
} else {
|
30
|
-
return amount / 10**(decimalsIn - decimalsOut);
|
28
|
+
return amount / 10 ** (decimalsIn - decimalsOut);
|
31
29
|
}
|
32
30
|
}
|
33
31
|
}
|
@@ -26,7 +26,9 @@ abstract contract DoubleLogicUUPSUpgradeable is UUPSUpgradeable, DoubleLogicERC1
|
|
26
26
|
* function _authorizeSecondaryUpgrade(address) internal override onlyOwner {}
|
27
27
|
* ```
|
28
28
|
*/
|
29
|
-
function _authorizeSecondaryUpgrade(
|
29
|
+
function _authorizeSecondaryUpgrade(
|
30
|
+
address newImplementation
|
31
|
+
) internal virtual;
|
30
32
|
|
31
33
|
/**
|
32
34
|
* @dev Upgrade the secondary implementation of the proxy to `newImplementation`.
|
@@ -35,7 +37,9 @@ abstract contract DoubleLogicUUPSUpgradeable is UUPSUpgradeable, DoubleLogicERC1
|
|
35
37
|
*
|
36
38
|
* Emits an {UpgradedSecondary} event.
|
37
39
|
*/
|
38
|
-
function upgradeSecondaryTo(
|
40
|
+
function upgradeSecondaryTo(
|
41
|
+
address newImplementation
|
42
|
+
) external onlyProxy {
|
39
43
|
_authorizeSecondaryUpgrade(newImplementation);
|
40
44
|
_upgradeSecondaryToAndCallUUPS(newImplementation, new bytes(0), false);
|
41
45
|
}
|
@@ -48,11 +52,10 @@ abstract contract DoubleLogicUUPSUpgradeable is UUPSUpgradeable, DoubleLogicERC1
|
|
48
52
|
*
|
49
53
|
* Emits an {UpgradedSecondary} event.
|
50
54
|
*/
|
51
|
-
function upgradeSecondaryToAndCall(
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
{
|
55
|
+
function upgradeSecondaryToAndCall(
|
56
|
+
address newImplementation,
|
57
|
+
bytes memory data
|
58
|
+
) external payable onlyProxy {
|
56
59
|
_authorizeSecondaryUpgrade(newImplementation);
|
57
60
|
_upgradeSecondaryToAndCallUUPS(newImplementation, data, true);
|
58
61
|
}
|
package/src/libraries/Error.sol
CHANGED
@@ -13,6 +13,9 @@ error HadZeroInit();
|
|
13
13
|
/// @dev Thrown when post upgrade init validation fails
|
14
14
|
error BadPostUpgradeInit();
|
15
15
|
|
16
|
+
/// @dev Thrown when the caller is not a codeless origin
|
17
|
+
error NotCodelessOrigin();
|
18
|
+
|
16
19
|
/// @dev Thrown when non owner tries to access an only-owner function
|
17
20
|
/// @param sender The msg.sender who is not the owner
|
18
21
|
/// @param owner The owner address
|
@@ -149,9 +152,6 @@ error DelayedTooFar();
|
|
149
152
|
/// @dev Force include can only read messages more blocks old than the delay period
|
150
153
|
error ForceIncludeBlockTooSoon();
|
151
154
|
|
152
|
-
/// @dev Force include can only read messages more seconds old than the delay period
|
153
|
-
error ForceIncludeTimeTooSoon();
|
154
|
-
|
155
155
|
/// @dev The message provided did not match the hash in the delayed inbox
|
156
156
|
error IncorrectMessagePreimage();
|
157
157
|
|
@@ -176,6 +176,15 @@ error NotBatchPosterManager(address);
|
|
176
176
|
/// @dev Thrown when a data blob feature is attempted to be used on a chain that doesnt support it
|
177
177
|
error DataBlobsNotSupported();
|
178
178
|
|
179
|
+
/// @dev Thrown when batches are posted without buffer proof, this is only allowed in a sync state or when no new delayed messages are read
|
180
|
+
error DelayProofRequired();
|
181
|
+
|
182
|
+
/// @dev The DelayedAccPreimage is invalid
|
183
|
+
error InvalidDelayedAccPreimage();
|
184
|
+
|
185
|
+
/// @dev Thrown when the sequencer attempts to post a batch with delay / sync proofs without delay bufferability enabled
|
186
|
+
error NotDelayBufferable();
|
187
|
+
|
179
188
|
/// @dev Thrown when an init param was supplied as empty
|
180
189
|
error InitParamZero(string name);
|
181
190
|
|
@@ -196,3 +205,12 @@ error Deprecated();
|
|
196
205
|
|
197
206
|
/// @dev Thrown when any component of maxTimeVariation is over uint64
|
198
207
|
error BadMaxTimeVariation();
|
208
|
+
|
209
|
+
/// @dev Thrown when any component of bufferConfig is zero
|
210
|
+
error BadBufferConfig();
|
211
|
+
|
212
|
+
/// @dev Thrown when extra gas is not a uint64
|
213
|
+
error ExtraGasNotUint64();
|
214
|
+
|
215
|
+
/// @dev Thrown when keysetBytes is too large
|
216
|
+
error KeysetTooLarge();
|
@@ -7,9 +7,10 @@ pragma solidity ^0.8.0;
|
|
7
7
|
|
8
8
|
import "./IReader4844.sol";
|
9
9
|
import "./IGasRefunder.sol";
|
10
|
+
import "../libraries/CallerChecker.sol";
|
10
11
|
|
11
12
|
abstract contract GasRefundEnabled {
|
12
|
-
uint256 internal immutable gasPerBlob = 2**17;
|
13
|
+
uint256 internal immutable gasPerBlob = 2 ** 17;
|
13
14
|
|
14
15
|
/// @dev this refunds the sender for execution costs of the tx
|
15
16
|
/// calldata costs are only refunded if `msg.sender == tx.origin` to guarantee the value refunded relates to charging
|
@@ -21,11 +22,10 @@ abstract contract GasRefundEnabled {
|
|
21
22
|
uint256 calldataSize = msg.data.length;
|
22
23
|
uint256 calldataWords = (calldataSize + 31) / 32;
|
23
24
|
// account for the CALLDATACOPY cost of the proxy contract, including the memory expansion cost
|
24
|
-
startGasLeft += calldataWords * 6 + (calldataWords**2) / 512;
|
25
|
+
startGasLeft += calldataWords * 6 + (calldataWords ** 2) / 512;
|
25
26
|
// if triggered in a contract call, the spender may be overrefunded by appending dummy data to the call
|
26
27
|
// so we check if it is a top level call, which would mean the sender paid calldata as part of tx.input
|
27
|
-
|
28
|
-
if (msg.sender != tx.origin) {
|
28
|
+
if (!CallerChecker.isCallerCodelessOrigin()) {
|
29
29
|
// We can't be sure if this calldata came from the top level tx,
|
30
30
|
// so to be safe we tell the gas refunder there was no calldata.
|
31
31
|
calldataSize = 0;
|
@@ -39,8 +39,7 @@ abstract contract GasRefundEnabled {
|
|
39
39
|
if (dataHashes.length != 0) {
|
40
40
|
uint256 blobBasefee = reader4844.getBlobBaseFee();
|
41
41
|
startGasLeft +=
|
42
|
-
(dataHashes.length * gasPerBlob * blobBasefee) /
|
43
|
-
block.basefee;
|
42
|
+
(dataHashes.length * gasPerBlob * blobBasefee) / block.basefee;
|
44
43
|
}
|
45
44
|
} catch {}
|
46
45
|
}
|
@@ -7,15 +7,16 @@ pragma solidity ^0.8.4;
|
|
7
7
|
import {MerkleProofTooLong} from "./Error.sol";
|
8
8
|
|
9
9
|
library MerkleLib {
|
10
|
-
function generateRoot(
|
10
|
+
function generateRoot(
|
11
|
+
bytes32[] memory _hashes
|
12
|
+
) internal pure returns (bytes32) {
|
11
13
|
bytes32[] memory prevLayer = _hashes;
|
12
14
|
while (prevLayer.length > 1) {
|
13
15
|
bytes32[] memory nextLayer = new bytes32[]((prevLayer.length + 1) / 2);
|
14
16
|
for (uint256 i = 0; i < nextLayer.length; i++) {
|
15
17
|
if (2 * i + 1 < prevLayer.length) {
|
16
|
-
nextLayer[i] =
|
17
|
-
abi.encodePacked(prevLayer[2 * i], prevLayer[2 * i + 1])
|
18
|
-
);
|
18
|
+
nextLayer[i] =
|
19
|
+
keccak256(abi.encodePacked(prevLayer[2 * i], prevLayer[2 * i + 1]));
|
19
20
|
} else {
|
20
21
|
nextLayer[i] = prevLayer[2 * i];
|
21
22
|
}
|
@@ -33,7 +34,7 @@ library MerkleLib {
|
|
33
34
|
uint256 proofItems = nodes.length;
|
34
35
|
if (proofItems > 256) revert MerkleProofTooLong(proofItems, 256);
|
35
36
|
bytes32 h = item;
|
36
|
-
for (uint256 i = 0; i < proofItems;
|
37
|
+
for (uint256 i = 0; i < proofItems;) {
|
37
38
|
bytes32 node = nodes[i];
|
38
39
|
if ((route & (1 << i)) == 0) {
|
39
40
|
assembly {
|
@@ -24,8 +24,7 @@ abstract contract UUPSNotUpgradeable is IERC1822Proxiable, DoubleLogicERC1967Upg
|
|
24
24
|
modifier onlyProxy() {
|
25
25
|
require(address(this) != __self, "Function must be called through delegatecall");
|
26
26
|
require(
|
27
|
-
_getSecondaryImplementation() == __self,
|
28
|
-
"Function must be called through active proxy"
|
27
|
+
_getSecondaryImplementation() == __self, "Function must be called through active proxy"
|
29
28
|
);
|
30
29
|
_;
|
31
30
|
}
|
@@ -36,8 +35,7 @@ abstract contract UUPSNotUpgradeable is IERC1822Proxiable, DoubleLogicERC1967Upg
|
|
36
35
|
*/
|
37
36
|
modifier notDelegated() {
|
38
37
|
require(
|
39
|
-
address(this) == __self,
|
40
|
-
"UUPSNotUpgradeable: must not be called through delegatecall"
|
38
|
+
address(this) == __self, "UUPSNotUpgradeable: must not be called through delegatecall"
|
41
39
|
);
|
42
40
|
_;
|
43
41
|
}
|
package/src/mocks/BridgeStub.sol
CHANGED
@@ -35,20 +35,28 @@ contract BridgeStub is IBridge, IEthBridge {
|
|
35
35
|
address public nativeToken;
|
36
36
|
uint8 public nativeTokenDecimals;
|
37
37
|
|
38
|
-
function setSequencerInbox(
|
38
|
+
function setSequencerInbox(
|
39
|
+
address _sequencerInbox
|
40
|
+
) external override {
|
39
41
|
sequencerInbox = _sequencerInbox;
|
40
42
|
emit SequencerInboxUpdated(_sequencerInbox);
|
41
43
|
}
|
42
44
|
|
43
|
-
function allowedDelayedInboxes(
|
45
|
+
function allowedDelayedInboxes(
|
46
|
+
address inbox
|
47
|
+
) external view override returns (bool) {
|
44
48
|
return allowedDelayedInboxesMap[inbox].allowed;
|
45
49
|
}
|
46
50
|
|
47
|
-
function allowedOutboxes(
|
51
|
+
function allowedOutboxes(
|
52
|
+
address
|
53
|
+
) external pure override returns (bool) {
|
48
54
|
revert("NOT_IMPLEMENTED");
|
49
55
|
}
|
50
56
|
|
51
|
-
function updateRollupAddress(
|
57
|
+
function updateRollupAddress(
|
58
|
+
IOwnable
|
59
|
+
) external pure {
|
52
60
|
revert("NOT_IMPLEMENTED");
|
53
61
|
}
|
54
62
|
|
@@ -58,15 +66,14 @@ contract BridgeStub is IBridge, IEthBridge {
|
|
58
66
|
bytes32 messageDataHash
|
59
67
|
) external payable override returns (uint256) {
|
60
68
|
require(allowedDelayedInboxesMap[msg.sender].allowed, "NOT_FROM_INBOX");
|
61
|
-
return
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
);
|
69
|
+
return addMessageToDelayedAccumulator(
|
70
|
+
kind,
|
71
|
+
sender,
|
72
|
+
block.number,
|
73
|
+
block.timestamp, // solhint-disable-line not-rely-on-time
|
74
|
+
block.basefee,
|
75
|
+
messageDataHash
|
76
|
+
);
|
70
77
|
}
|
71
78
|
|
72
79
|
function enqueueSequencerMessage(
|
@@ -76,17 +83,11 @@ contract BridgeStub is IBridge, IEthBridge {
|
|
76
83
|
uint256 newMessageCount
|
77
84
|
)
|
78
85
|
external
|
79
|
-
returns (
|
80
|
-
uint256 seqMessageIndex,
|
81
|
-
bytes32 beforeAcc,
|
82
|
-
bytes32 delayedAcc,
|
83
|
-
bytes32 acc
|
84
|
-
)
|
86
|
+
returns (uint256 seqMessageIndex, bytes32 beforeAcc, bytes32 delayedAcc, bytes32 acc)
|
85
87
|
{
|
86
88
|
if (
|
87
|
-
sequencerReportedSubMessageCount != prevMessageCount &&
|
88
|
-
|
89
|
-
sequencerReportedSubMessageCount != 0
|
89
|
+
sequencerReportedSubMessageCount != prevMessageCount && prevMessageCount != 0
|
90
|
+
&& sequencerReportedSubMessageCount != 0
|
90
91
|
) {
|
91
92
|
revert BadSequencerMessageNumber(sequencerReportedSubMessageCount, prevMessageCount);
|
92
93
|
}
|
@@ -102,10 +103,10 @@ contract BridgeStub is IBridge, IEthBridge {
|
|
102
103
|
sequencerInboxAccs.push(acc);
|
103
104
|
}
|
104
105
|
|
105
|
-
function submitBatchSpendingReport(
|
106
|
-
|
107
|
-
|
108
|
-
{
|
106
|
+
function submitBatchSpendingReport(
|
107
|
+
address batchPoster,
|
108
|
+
bytes32 dataHash
|
109
|
+
) external returns (uint256) {
|
109
110
|
// TODO: implement stub
|
110
111
|
}
|
111
112
|
|
@@ -118,15 +119,8 @@ contract BridgeStub is IBridge, IEthBridge {
|
|
118
119
|
bytes32 messageDataHash
|
119
120
|
) internal returns (uint256) {
|
120
121
|
uint256 count = delayedInboxAccs.length;
|
121
|
-
bytes32 messageHash =
|
122
|
-
0,
|
123
|
-
address(uint160(0)),
|
124
|
-
0,
|
125
|
-
0,
|
126
|
-
0,
|
127
|
-
0,
|
128
|
-
messageDataHash
|
129
|
-
);
|
122
|
+
bytes32 messageHash =
|
123
|
+
Messages.messageHash(0, address(uint160(0)), 0, 0, 0, 0, messageDataHash);
|
130
124
|
bytes32 prevAcc = 0;
|
131
125
|
if (count > 0) {
|
132
126
|
prevAcc = delayedInboxAccs[count - 1];
|
@@ -136,11 +130,21 @@ contract BridgeStub is IBridge, IEthBridge {
|
|
136
130
|
}
|
137
131
|
|
138
132
|
function executeCall(
|
139
|
-
address,
|
140
|
-
uint256,
|
141
|
-
bytes calldata
|
142
|
-
) external
|
143
|
-
|
133
|
+
address to,
|
134
|
+
uint256 value,
|
135
|
+
bytes calldata data
|
136
|
+
) external override returns (bool success, bytes memory returnData) {
|
137
|
+
(success, returnData) = _executeLowLevelCall(to, value, data);
|
138
|
+
emit BridgeCallTriggered(msg.sender, to, value, data);
|
139
|
+
}
|
140
|
+
|
141
|
+
function _executeLowLevelCall(
|
142
|
+
address to,
|
143
|
+
uint256 value,
|
144
|
+
bytes memory data
|
145
|
+
) internal returns (bool success, bytes memory returnData) {
|
146
|
+
// solhint-disable-next-line avoid-low-level-calls
|
147
|
+
(success, returnData) = to.call{value: value}(data);
|
144
148
|
}
|
145
149
|
|
146
150
|
function setDelayedInbox(address inbox, bool enabled) external override {
|
@@ -154,19 +158,15 @@ contract BridgeStub is IBridge, IEthBridge {
|
|
154
158
|
allowedDelayedInboxesMap[inbox] = InOutInfo(allowedDelayedInboxList.length, true);
|
155
159
|
allowedDelayedInboxList.push(inbox);
|
156
160
|
} else {
|
157
|
-
allowedDelayedInboxList[info.index] =
|
158
|
-
allowedDelayedInboxList.length - 1
|
159
|
-
];
|
161
|
+
allowedDelayedInboxList[info.index] =
|
162
|
+
allowedDelayedInboxList[allowedDelayedInboxList.length - 1];
|
160
163
|
allowedDelayedInboxesMap[allowedDelayedInboxList[info.index]].index = info.index;
|
161
164
|
allowedDelayedInboxList.pop();
|
162
165
|
delete allowedDelayedInboxesMap[inbox];
|
163
166
|
}
|
164
167
|
}
|
165
168
|
|
166
|
-
function setOutbox(
|
167
|
-
address, /* outbox */
|
168
|
-
bool /* enabled*/
|
169
|
-
) external pure override {
|
169
|
+
function setOutbox(address, /* outbox */ bool /* enabled*/ ) external pure override {
|
170
170
|
revert("NOT_IMPLEMENTED");
|
171
171
|
}
|
172
172
|
|
@@ -184,7 +184,9 @@ contract BridgeStub is IBridge, IEthBridge {
|
|
184
184
|
|
185
185
|
function acceptFundsFromOldBridge() external payable {}
|
186
186
|
|
187
|
-
function initialize(
|
187
|
+
function initialize(
|
188
|
+
IOwnable
|
189
|
+
) external pure {
|
188
190
|
revert("NOT_IMPLEMENTED");
|
189
191
|
}
|
190
192
|
}
|