@arbitrum/nitro-contracts 2.0.0-beta.0 → 2.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (269) hide show
  1. package/README.md +1 -1
  2. package/build/contracts/@openzeppelin/contracts/access/Ownable.sol/Ownable.dbg.json +1 -1
  3. package/build/contracts/@openzeppelin/contracts/interfaces/draft-IERC1822.sol/IERC1822Proxiable.dbg.json +1 -1
  4. package/build/contracts/@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol/ERC1967Proxy.dbg.json +1 -1
  5. package/build/contracts/@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol/ERC1967Proxy.json +2 -2
  6. package/build/contracts/@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol/ERC1967Upgrade.dbg.json +1 -1
  7. package/build/contracts/@openzeppelin/contracts/proxy/Proxy.sol/Proxy.dbg.json +1 -1
  8. package/build/contracts/@openzeppelin/contracts/proxy/beacon/IBeacon.sol/IBeacon.dbg.json +1 -1
  9. package/build/contracts/@openzeppelin/contracts/proxy/beacon/UpgradeableBeacon.sol/UpgradeableBeacon.dbg.json +1 -1
  10. package/build/contracts/@openzeppelin/contracts/proxy/beacon/UpgradeableBeacon.sol/UpgradeableBeacon.json +2 -2
  11. package/build/contracts/@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol/ProxyAdmin.dbg.json +1 -1
  12. package/build/contracts/@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol/ProxyAdmin.json +2 -2
  13. package/build/contracts/@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol/TransparentUpgradeableProxy.dbg.json +1 -1
  14. package/build/contracts/@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol/TransparentUpgradeableProxy.json +2 -2
  15. package/build/contracts/@openzeppelin/contracts/proxy/utils/UUPSUpgradeable.sol/UUPSUpgradeable.dbg.json +1 -1
  16. package/build/contracts/@openzeppelin/contracts/security/ReentrancyGuard.sol/ReentrancyGuard.dbg.json +1 -1
  17. package/build/contracts/@openzeppelin/contracts/token/ERC20/ERC20.sol/ERC20.dbg.json +1 -1
  18. package/build/contracts/@openzeppelin/contracts/token/ERC20/ERC20.sol/ERC20.json +2 -2
  19. package/build/contracts/@openzeppelin/contracts/token/ERC20/IERC20.sol/IERC20.dbg.json +1 -1
  20. package/build/contracts/@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol/IERC20Metadata.dbg.json +1 -1
  21. package/build/contracts/@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol/SafeERC20.dbg.json +1 -1
  22. package/build/contracts/@openzeppelin/contracts/token/ERC20/utils/SafeERC20.sol/SafeERC20.json +2 -2
  23. package/build/contracts/@openzeppelin/contracts/utils/Address.sol/Address.dbg.json +1 -1
  24. package/build/contracts/@openzeppelin/contracts/utils/Address.sol/Address.json +2 -2
  25. package/build/contracts/@openzeppelin/contracts/utils/Context.sol/Context.dbg.json +1 -1
  26. package/build/contracts/@openzeppelin/contracts/utils/StorageSlot.sol/StorageSlot.dbg.json +1 -1
  27. package/build/contracts/@openzeppelin/contracts/utils/StorageSlot.sol/StorageSlot.json +2 -2
  28. package/build/contracts/@openzeppelin/contracts/utils/Strings.sol/Strings.dbg.json +1 -1
  29. package/build/contracts/@openzeppelin/contracts/utils/Strings.sol/Strings.json +2 -2
  30. package/build/contracts/@openzeppelin/contracts-upgradeable/access/AccessControlUpgradeable.sol/AccessControlUpgradeable.dbg.json +1 -1
  31. package/build/contracts/@openzeppelin/contracts-upgradeable/access/AccessControlUpgradeable.sol/AccessControlUpgradeable.json +0 -13
  32. package/build/contracts/@openzeppelin/contracts-upgradeable/access/IAccessControlUpgradeable.sol/IAccessControlUpgradeable.dbg.json +1 -1
  33. package/build/contracts/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.sol/OwnableUpgradeable.dbg.json +1 -1
  34. package/build/contracts/@openzeppelin/contracts-upgradeable/access/OwnableUpgradeable.sol/OwnableUpgradeable.json +0 -13
  35. package/build/contracts/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.sol/Initializable.dbg.json +1 -1
  36. package/build/contracts/@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.sol/Initializable.json +1 -15
  37. package/build/contracts/@openzeppelin/contracts-upgradeable/security/PausableUpgradeable.sol/PausableUpgradeable.dbg.json +1 -1
  38. package/build/contracts/@openzeppelin/contracts-upgradeable/security/PausableUpgradeable.sol/PausableUpgradeable.json +0 -13
  39. package/build/contracts/@openzeppelin/contracts-upgradeable/token/ERC20/IERC20Upgradeable.sol/IERC20Upgradeable.dbg.json +1 -1
  40. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/AddressUpgradeable.sol/AddressUpgradeable.dbg.json +1 -1
  41. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/AddressUpgradeable.sol/AddressUpgradeable.json +2 -2
  42. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable.sol/ContextUpgradeable.dbg.json +1 -1
  43. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/ContextUpgradeable.sol/ContextUpgradeable.json +1 -15
  44. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/StorageSlotUpgradeable.sol/StorageSlotUpgradeable.dbg.json +1 -1
  45. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/StorageSlotUpgradeable.sol/StorageSlotUpgradeable.json +2 -2
  46. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/StringsUpgradeable.sol/StringsUpgradeable.dbg.json +1 -1
  47. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/StringsUpgradeable.sol/StringsUpgradeable.json +2 -2
  48. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/introspection/ERC165Upgradeable.sol/ERC165Upgradeable.dbg.json +1 -1
  49. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/introspection/ERC165Upgradeable.sol/ERC165Upgradeable.json +0 -13
  50. package/build/contracts/@openzeppelin/contracts-upgradeable/utils/introspection/IERC165Upgradeable.sol/IERC165Upgradeable.dbg.json +1 -1
  51. package/build/contracts/src/bridge/AbsBridge.sol/AbsBridge.dbg.json +1 -1
  52. package/build/contracts/src/bridge/AbsBridge.sol/AbsBridge.json +0 -13
  53. package/build/contracts/src/bridge/AbsInbox.sol/AbsInbox.dbg.json +1 -1
  54. package/build/contracts/src/bridge/AbsInbox.sol/AbsInbox.json +0 -13
  55. package/build/contracts/src/bridge/AbsOutbox.sol/AbsOutbox.dbg.json +1 -1
  56. package/build/contracts/src/bridge/Bridge.sol/Bridge.dbg.json +1 -1
  57. package/build/contracts/src/bridge/Bridge.sol/Bridge.json +2 -15
  58. package/build/contracts/src/bridge/ERC20Bridge.sol/ERC20Bridge.dbg.json +1 -1
  59. package/build/contracts/src/bridge/ERC20Bridge.sol/ERC20Bridge.json +26 -15
  60. package/build/contracts/src/bridge/ERC20Inbox.sol/ERC20Inbox.dbg.json +1 -1
  61. package/build/contracts/src/bridge/ERC20Inbox.sol/ERC20Inbox.json +13 -15
  62. package/build/contracts/src/bridge/ERC20Outbox.sol/ERC20Outbox.dbg.json +1 -1
  63. package/build/contracts/src/bridge/ERC20Outbox.sol/ERC20Outbox.json +2 -2
  64. package/build/contracts/src/bridge/GasRefunder.sol/GasRefunder.dbg.json +1 -1
  65. package/build/contracts/src/bridge/GasRefunder.sol/GasRefunder.json +2 -2
  66. package/build/contracts/src/bridge/IBridge.sol/IBridge.dbg.json +1 -1
  67. package/build/contracts/src/bridge/IDelayedMessageProvider.sol/IDelayedMessageProvider.dbg.json +1 -1
  68. package/build/contracts/src/bridge/IERC20Bridge.sol/IERC20Bridge.dbg.json +1 -1
  69. package/build/contracts/src/bridge/IERC20Bridge.sol/IERC20Bridge.json +13 -0
  70. package/build/contracts/src/bridge/IERC20Inbox.sol/IERC20Inbox.dbg.json +1 -1
  71. package/build/contracts/src/bridge/IEthBridge.sol/IEthBridge.dbg.json +1 -1
  72. package/build/contracts/src/bridge/IInbox.sol/IInbox.dbg.json +1 -1
  73. package/build/contracts/src/bridge/IInboxBase.sol/IInboxBase.dbg.json +1 -1
  74. package/build/contracts/src/bridge/IOutbox.sol/IOutbox.dbg.json +1 -1
  75. package/build/contracts/src/bridge/IOwnable.sol/IOwnable.dbg.json +1 -1
  76. package/build/contracts/src/bridge/ISequencerInbox.sol/ISequencerInbox.dbg.json +1 -1
  77. package/build/contracts/src/bridge/Inbox.sol/Inbox.dbg.json +1 -1
  78. package/build/contracts/src/bridge/Inbox.sol/Inbox.json +2 -15
  79. package/build/contracts/src/bridge/Messages.sol/Messages.dbg.json +1 -1
  80. package/build/contracts/src/bridge/Outbox.sol/Outbox.dbg.json +1 -1
  81. package/build/contracts/src/bridge/Outbox.sol/Outbox.json +2 -2
  82. package/build/contracts/src/bridge/SequencerInbox.sol/SequencerInbox.dbg.json +1 -1
  83. package/build/contracts/src/bridge/SequencerInbox.sol/SequencerInbox.json +2 -2
  84. package/build/contracts/src/chain/CacheManager.sol/CacheManager.dbg.json +1 -1
  85. package/build/contracts/src/chain/CacheManager.sol/CacheManager.json +48 -21
  86. package/build/contracts/src/challenge/ChallengeLib.sol/ChallengeLib.dbg.json +1 -1
  87. package/build/contracts/src/challenge/ChallengeManager.sol/ChallengeManager.dbg.json +1 -1
  88. package/build/contracts/src/challenge/ChallengeManager.sol/ChallengeManager.json +2 -2
  89. package/build/contracts/src/challenge/IChallengeManager.sol/IChallengeManager.dbg.json +1 -1
  90. package/build/contracts/src/challenge/IChallengeResultReceiver.sol/IChallengeResultReceiver.dbg.json +1 -1
  91. package/build/contracts/src/libraries/AddressAliasHelper.sol/AddressAliasHelper.dbg.json +1 -1
  92. package/build/contracts/src/libraries/AdminFallbackProxy.sol/AdminFallbackProxy.dbg.json +1 -1
  93. package/build/contracts/src/libraries/AdminFallbackProxy.sol/AdminFallbackProxy.json +2 -2
  94. package/build/contracts/src/libraries/AdminFallbackProxy.sol/DoubleLogicERC1967Upgrade.dbg.json +1 -1
  95. package/build/contracts/src/libraries/ArbitrumChecker.sol/ArbitrumChecker.dbg.json +1 -1
  96. package/build/contracts/src/libraries/CryptographyPrimitives.sol/CryptographyPrimitives.dbg.json +1 -1
  97. package/build/contracts/src/libraries/DecimalsConverterHelper.sol/DecimalsConverterHelper.dbg.json +4 -0
  98. package/build/contracts/src/libraries/DecimalsConverterHelper.sol/DecimalsConverterHelper.json +10 -0
  99. package/build/contracts/src/libraries/DelegateCallAware.sol/DelegateCallAware.dbg.json +1 -1
  100. package/build/contracts/src/libraries/DoubleLogicUUPSUpgradeable.sol/DoubleLogicUUPSUpgradeable.dbg.json +1 -1
  101. package/build/contracts/src/libraries/GasRefundEnabled.sol/GasRefundEnabled.dbg.json +1 -1
  102. package/build/contracts/src/libraries/IGasRefunder.sol/IGasRefunder.dbg.json +1 -1
  103. package/build/contracts/src/libraries/IReader4844.sol/IReader4844.dbg.json +1 -1
  104. package/build/contracts/src/libraries/MerkleLib.sol/MerkleLib.dbg.json +1 -1
  105. package/build/contracts/src/libraries/MerkleLib.sol/MerkleLib.json +2 -2
  106. package/build/contracts/src/libraries/UUPSNotUpgradeable.sol/UUPSNotUpgradeable.dbg.json +1 -1
  107. package/build/contracts/src/mocks/Benchmarks.sol/Benchmarks.dbg.json +1 -1
  108. package/build/contracts/src/mocks/BridgeStub.sol/BridgeStub.dbg.json +1 -1
  109. package/build/contracts/src/mocks/BridgeStub.sol/BridgeStub.json +28 -2
  110. package/build/contracts/src/mocks/BridgeUnproxied.sol/BridgeUnproxied.dbg.json +1 -1
  111. package/build/contracts/src/mocks/BridgeUnproxied.sol/BridgeUnproxied.json +2 -15
  112. package/build/contracts/src/mocks/InboxStub.sol/InboxStub.dbg.json +1 -1
  113. package/build/contracts/src/mocks/InboxStub.sol/InboxStub.json +2 -2
  114. package/build/contracts/src/mocks/MockResultReceiver.sol/MockResultReceiver.dbg.json +1 -1
  115. package/build/contracts/src/mocks/MultiCallTest.sol/MultiCallTest.dbg.json +1 -1
  116. package/build/contracts/src/mocks/PendingBlkTimeAndNrAdvanceCheck.sol/PendingBlkTimeAndNrAdvanceCheck.dbg.json +1 -1
  117. package/build/contracts/src/mocks/Program.sol/ProgramTest.dbg.json +1 -1
  118. package/build/contracts/src/mocks/Program.sol/ProgramTest.json +2 -2
  119. package/build/contracts/src/mocks/ProxyAdminForBinding.sol/ProxyAdminForBinding.dbg.json +1 -1
  120. package/build/contracts/src/mocks/ProxyAdminForBinding.sol/ProxyAdminForBinding.json +2 -2
  121. package/build/contracts/src/mocks/SdkStorage.sol/SdkStorage.dbg.json +1 -1
  122. package/build/contracts/src/mocks/SequencerInboxStub.sol/SequencerInboxStub.dbg.json +1 -1
  123. package/build/contracts/src/mocks/SequencerInboxStub.sol/SequencerInboxStub.json +2 -2
  124. package/build/contracts/src/mocks/Simple.sol/Simple.dbg.json +1 -1
  125. package/build/contracts/src/mocks/SimpleCacheManager.sol/SimpleCacheManager.dbg.json +1 -1
  126. package/build/contracts/src/mocks/SimpleCacheManager.sol/SimpleCacheManager.json +2 -2
  127. package/build/contracts/src/mocks/SimpleProxy.sol/SimpleProxy.dbg.json +1 -1
  128. package/build/contracts/src/mocks/SimpleProxy.sol/SimpleProxy.json +2 -2
  129. package/build/contracts/src/mocks/SingleExecutionChallenge.sol/SingleExecutionChallenge.dbg.json +1 -1
  130. package/build/contracts/src/mocks/SingleExecutionChallenge.sol/SingleExecutionChallenge.json +2 -2
  131. package/build/contracts/src/mocks/TimedOutChallengeManager.sol/TimedOutChallengeManager.dbg.json +1 -1
  132. package/build/contracts/src/mocks/TimedOutChallengeManager.sol/TimedOutChallengeManager.json +2 -2
  133. package/build/contracts/src/mocks/UpgradeExecutorMock.sol/UpgradeExecutorMock.dbg.json +1 -1
  134. package/build/contracts/src/mocks/UpgradeExecutorMock.sol/UpgradeExecutorMock.json +2 -15
  135. package/build/contracts/src/node-interface/NodeInterface.sol/NodeInterface.dbg.json +1 -1
  136. package/build/contracts/src/node-interface/NodeInterfaceDebug.sol/NodeInterfaceDebug.dbg.json +1 -1
  137. package/build/contracts/src/osp/HashProofHelper.sol/HashProofHelper.dbg.json +1 -1
  138. package/build/contracts/src/osp/IOneStepProofEntry.sol/IOneStepProofEntry.dbg.json +1 -1
  139. package/build/contracts/src/osp/IOneStepProofEntry.sol/OneStepProofEntryLib.dbg.json +1 -1
  140. package/build/contracts/src/osp/IOneStepProver.sol/IOneStepProver.dbg.json +1 -1
  141. package/build/contracts/src/osp/OneStepProofEntry.sol/OneStepProofEntry.dbg.json +1 -1
  142. package/build/contracts/src/osp/OneStepProver0.sol/OneStepProver0.dbg.json +1 -1
  143. package/build/contracts/src/osp/OneStepProverHostIo.sol/OneStepProverHostIo.dbg.json +1 -1
  144. package/build/contracts/src/osp/OneStepProverMath.sol/OneStepProverMath.dbg.json +1 -1
  145. package/build/contracts/src/osp/OneStepProverMemory.sol/OneStepProverMemory.dbg.json +1 -1
  146. package/build/contracts/src/precompiles/ArbAddressTable.sol/ArbAddressTable.dbg.json +1 -1
  147. package/build/contracts/src/precompiles/ArbAggregator.sol/ArbAggregator.dbg.json +1 -1
  148. package/build/contracts/src/precompiles/ArbBLS.sol/ArbBLS.dbg.json +1 -1
  149. package/build/contracts/src/precompiles/ArbDebug.sol/ArbDebug.dbg.json +1 -1
  150. package/build/contracts/src/precompiles/ArbFunctionTable.sol/ArbFunctionTable.dbg.json +1 -1
  151. package/build/contracts/src/precompiles/ArbGasInfo.sol/ArbGasInfo.dbg.json +1 -1
  152. package/build/contracts/src/precompiles/ArbInfo.sol/ArbInfo.dbg.json +1 -1
  153. package/build/contracts/src/precompiles/ArbOwner.sol/ArbOwner.dbg.json +1 -1
  154. package/build/contracts/src/precompiles/ArbOwnerPublic.sol/ArbOwnerPublic.dbg.json +1 -1
  155. package/build/contracts/src/precompiles/ArbRetryableTx.sol/ArbRetryableTx.dbg.json +1 -1
  156. package/build/contracts/src/precompiles/ArbStatistics.sol/ArbStatistics.dbg.json +1 -1
  157. package/build/contracts/src/precompiles/ArbSys.sol/ArbSys.dbg.json +1 -1
  158. package/build/contracts/src/precompiles/ArbWasm.sol/ArbWasm.dbg.json +1 -1
  159. package/build/contracts/src/precompiles/ArbWasmCache.sol/ArbWasmCache.dbg.json +1 -1
  160. package/build/contracts/src/precompiles/ArbWasmCache.sol/ArbWasmCache.json +13 -0
  161. package/build/contracts/src/precompiles/ArbosActs.sol/ArbosActs.dbg.json +1 -1
  162. package/build/contracts/src/precompiles/ArbosTest.sol/ArbosTest.dbg.json +1 -1
  163. package/build/contracts/src/rollup/AbsRollupEventInbox.sol/AbsRollupEventInbox.dbg.json +1 -1
  164. package/build/contracts/src/rollup/BridgeCreator.sol/BridgeCreator.dbg.json +1 -1
  165. package/build/contracts/src/rollup/BridgeCreator.sol/BridgeCreator.json +2 -2
  166. package/build/contracts/src/rollup/DeployHelper.sol/DeployHelper.dbg.json +1 -1
  167. package/build/contracts/src/rollup/DeployHelper.sol/DeployHelper.json +2 -2
  168. package/build/contracts/src/rollup/ERC20RollupEventInbox.sol/ERC20RollupEventInbox.dbg.json +1 -1
  169. package/build/contracts/src/rollup/ERC20RollupEventInbox.sol/ERC20RollupEventInbox.json +2 -2
  170. package/build/contracts/src/rollup/FactoryDeployerHelper.sol/FactoryDeployerHelper.dbg.json +4 -0
  171. package/build/contracts/src/rollup/FactoryDeployerHelper.sol/FactoryDeployerHelper.json +68 -0
  172. package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IDeployHelper.dbg.json +4 -0
  173. package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IDeployHelper.json +58 -0
  174. package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IERC20.dbg.json +4 -0
  175. package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IERC20.json +40 -0
  176. package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IERC20Bridge.dbg.json +4 -0
  177. package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IERC20Bridge.json +24 -0
  178. package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IInboxBase.dbg.json +4 -0
  179. package/build/contracts/src/rollup/FactoryDeployerHelper.sol/IInboxBase.json +24 -0
  180. package/build/contracts/src/rollup/IRollupAdmin.sol/IRollupAdmin.dbg.json +1 -1
  181. package/build/contracts/src/rollup/IRollupCore.sol/IRollupCore.dbg.json +1 -1
  182. package/build/contracts/src/rollup/IRollupEventInbox.sol/IRollupEventInbox.dbg.json +1 -1
  183. package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUser.dbg.json +1 -1
  184. package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUser.json +18 -0
  185. package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUserAbs.dbg.json +1 -1
  186. package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUserAbs.json +18 -0
  187. package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUserERC20.dbg.json +1 -1
  188. package/build/contracts/src/rollup/IRollupLogic.sol/IRollupUserERC20.json +18 -0
  189. package/build/contracts/src/rollup/Node.sol/NodeLib.dbg.json +1 -1
  190. package/build/contracts/src/rollup/RollupAdminLogic.sol/RollupAdminLogic.dbg.json +1 -1
  191. package/build/contracts/src/rollup/RollupAdminLogic.sol/RollupAdminLogic.json +28 -15
  192. package/build/contracts/src/rollup/RollupCore.sol/RollupCore.dbg.json +1 -1
  193. package/build/contracts/src/rollup/RollupCore.sol/RollupCore.json +13 -13
  194. package/build/contracts/src/rollup/RollupCreator.sol/RollupCreator.dbg.json +1 -1
  195. package/build/contracts/src/rollup/RollupCreator.sol/RollupCreator.json +2 -2
  196. package/build/contracts/src/rollup/RollupEventInbox.sol/RollupEventInbox.dbg.json +1 -1
  197. package/build/contracts/src/rollup/RollupEventInbox.sol/RollupEventInbox.json +2 -2
  198. package/build/contracts/src/rollup/RollupLib.sol/RollupLib.dbg.json +1 -1
  199. package/build/contracts/src/rollup/RollupProxy.sol/RollupProxy.dbg.json +1 -1
  200. package/build/contracts/src/rollup/RollupProxy.sol/RollupProxy.json +2 -2
  201. package/build/contracts/src/rollup/RollupUserLogic.sol/AbsRollupUserLogic.dbg.json +1 -1
  202. package/build/contracts/src/rollup/RollupUserLogic.sol/AbsRollupUserLogic.json +31 -13
  203. package/build/contracts/src/rollup/RollupUserLogic.sol/ERC20RollupUserLogic.dbg.json +1 -1
  204. package/build/contracts/src/rollup/RollupUserLogic.sol/ERC20RollupUserLogic.json +33 -15
  205. package/build/contracts/src/rollup/RollupUserLogic.sol/RollupUserLogic.dbg.json +1 -1
  206. package/build/contracts/src/rollup/RollupUserLogic.sol/RollupUserLogic.json +33 -15
  207. package/build/contracts/src/rollup/ValidatorUtils.sol/ValidatorUtils.dbg.json +1 -1
  208. package/build/contracts/src/rollup/ValidatorUtils.sol/ValidatorUtils.json +2 -2
  209. package/build/contracts/src/rollup/ValidatorWallet.sol/ValidatorWallet.dbg.json +1 -1
  210. package/build/contracts/src/rollup/ValidatorWallet.sol/ValidatorWallet.json +2 -15
  211. package/build/contracts/src/rollup/ValidatorWalletCreator.sol/ValidatorWalletCreator.dbg.json +1 -1
  212. package/build/contracts/src/rollup/ValidatorWalletCreator.sol/ValidatorWalletCreator.json +2 -2
  213. package/build/contracts/src/state/Deserialize.sol/Deserialize.dbg.json +1 -1
  214. package/build/contracts/src/state/GlobalState.sol/GlobalStateLib.dbg.json +1 -1
  215. package/build/contracts/src/state/Instructions.sol/Instructions.dbg.json +1 -1
  216. package/build/contracts/src/state/Machine.sol/MachineLib.dbg.json +1 -1
  217. package/build/contracts/src/state/MerkleProof.sol/MerkleProofLib.dbg.json +1 -1
  218. package/build/contracts/src/state/Module.sol/ModuleLib.dbg.json +1 -1
  219. package/build/contracts/src/state/ModuleMemory.sol/ModuleMemoryLib.dbg.json +1 -1
  220. package/build/contracts/src/state/ModuleMemoryCompact.sol/ModuleMemoryCompactLib.dbg.json +1 -1
  221. package/build/contracts/src/state/MultiStack.sol/MultiStackLib.dbg.json +1 -1
  222. package/build/contracts/src/state/PcArray.sol/PcArrayLib.dbg.json +1 -1
  223. package/build/contracts/src/state/StackFrame.sol/StackFrameLib.dbg.json +1 -1
  224. package/build/contracts/src/state/Value.sol/ValueLib.dbg.json +1 -1
  225. package/build/contracts/src/state/ValueArray.sol/ValueArrayLib.dbg.json +1 -1
  226. package/build/contracts/src/state/ValueStack.sol/ValueStackLib.dbg.json +1 -1
  227. package/build/contracts/src/test-helpers/BridgeTester.sol/BridgeTester.dbg.json +1 -1
  228. package/build/contracts/src/test-helpers/BridgeTester.sol/BridgeTester.json +28 -15
  229. package/build/contracts/src/test-helpers/CryptographyPrimitivesTester.sol/CryptographyPrimitivesTester.dbg.json +1 -1
  230. package/build/contracts/src/test-helpers/EthVault.sol/EthVault.dbg.json +1 -1
  231. package/build/contracts/src/test-helpers/MessageTester.sol/MessageTester.dbg.json +1 -1
  232. package/build/contracts/src/test-helpers/OutboxWithoutOptTester.sol/OutboxWithoutOptTester.dbg.json +1 -1
  233. package/build/contracts/src/test-helpers/OutboxWithoutOptTester.sol/OutboxWithoutOptTester.json +2 -2
  234. package/build/contracts/src/test-helpers/RollupMock.sol/RollupMock.dbg.json +1 -1
  235. package/build/contracts/src/test-helpers/TestToken.sol/TestToken.dbg.json +1 -1
  236. package/build/contracts/src/test-helpers/TestToken.sol/TestToken.json +2 -2
  237. package/build/contracts/src/test-helpers/ValueArrayTester.sol/ValueArrayTester.dbg.json +1 -1
  238. package/package.json +6 -3
  239. package/src/bridge/AbsInbox.sol +16 -4
  240. package/src/bridge/AbsOutbox.sol +11 -2
  241. package/src/bridge/ERC20Bridge.sol +30 -3
  242. package/src/bridge/ERC20Inbox.sol +28 -4
  243. package/src/bridge/ERC20Outbox.sol +10 -1
  244. package/src/bridge/IERC20Bridge.sol +7 -0
  245. package/src/bridge/IERC20Inbox.sol +4 -3
  246. package/src/bridge/IInbox.sol +3 -3
  247. package/src/bridge/Inbox.sol +6 -1
  248. package/src/bridge/Outbox.sol +5 -0
  249. package/src/chain/CacheManager.sol +19 -9
  250. package/src/libraries/Constants.sol +11 -0
  251. package/src/libraries/DecimalsConverterHelper.sol +33 -0
  252. package/src/libraries/Error.sol +6 -0
  253. package/src/mocks/BridgeStub.sol +3 -0
  254. package/src/mocks/SimpleCacheManager.sol +1 -1
  255. package/src/node-interface/NodeInterface.sol +1 -1
  256. package/src/precompiles/ArbWasmCache.sol +5 -2
  257. package/src/rollup/AbsRollupEventInbox.sol +3 -4
  258. package/src/rollup/DeployHelper.sol +22 -11
  259. package/src/rollup/ERC20RollupEventInbox.sol +5 -0
  260. package/src/rollup/FactoryDeployerHelper.sol +54 -0
  261. package/src/rollup/IRollupLogic.sol +2 -0
  262. package/src/rollup/RollupAdminLogic.sol +11 -0
  263. package/src/rollup/RollupCore.sol +1 -0
  264. package/src/rollup/RollupCreator.sol +49 -1
  265. package/src/rollup/RollupEventInbox.sol +8 -0
  266. package/src/rollup/RollupUserLogic.sol +35 -13
  267. package/src/test-helpers/BridgeTester.sol +3 -0
  268. package/build/contracts/@openzeppelin/contracts/token/ERC20/extensions/draft-IERC20Permit.sol/IERC20Permit.dbg.json +0 -4
  269. package/build/contracts/@openzeppelin/contracts/token/ERC20/extensions/draft-IERC20Permit.sol/IERC20Permit.json +0 -86
@@ -7,9 +7,11 @@ pragma solidity ^0.8.0;
7
7
  import "../precompiles/ArbOwnerPublic.sol";
8
8
  import "../precompiles/ArbWasm.sol";
9
9
  import "../precompiles/ArbWasmCache.sol";
10
+ import "../libraries/DelegateCallAware.sol";
10
11
  import "solady/src/utils/MinHeapLib.sol";
12
+ import "@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.sol";
11
13
 
12
- contract CacheManager {
14
+ contract CacheManager is Initializable, DelegateCallAware {
13
15
  using MinHeapLib for MinHeapLib.Heap;
14
16
 
15
17
  ArbOwnerPublic internal constant ARB_OWNER_PUBLIC = ArbOwnerPublic(address(0x6b));
@@ -34,7 +36,7 @@ contract CacheManager {
34
36
  error BidsArePaused();
35
37
  error MakeSpaceTooLarge(uint64 size, uint64 limit);
36
38
 
37
- event InsertBid(bytes32 indexed codehash, uint192 bid, uint64 size);
39
+ event InsertBid(bytes32 indexed codehash, address program, uint192 bid, uint64 size);
38
40
  event DeleteBid(bytes32 indexed codehash, uint192 bid, uint64 size);
39
41
  event SetCacheSize(uint64 size);
40
42
  event SetDecayRate(uint64 decay);
@@ -47,7 +49,7 @@ contract CacheManager {
47
49
  uint192 bid;
48
50
  }
49
51
 
50
- constructor(uint64 initCacheSize, uint64 initDecay) {
52
+ function initialize(uint64 initCacheSize, uint64 initDecay) external initializer onlyDelegated {
51
53
  cacheSize = initCacheSize;
52
54
  decay = initDecay;
53
55
  }
@@ -151,10 +153,16 @@ contract CacheManager {
151
153
 
152
154
  /// @notice Returns the minimum bid required to cache the program with given codehash.
153
155
  /// Value returned here is the minimum bid that you can send with msg.value
154
- function getMinBid(bytes32 codehash) external view returns (uint192 min) {
156
+ function getMinBid(bytes32 codehash) public view returns (uint192 min) {
155
157
  return getMinBid(_asmSize(codehash));
156
158
  }
157
159
 
160
+ /// @notice Returns the minimum bid required to cache the program at given address.
161
+ /// Value returned here is the minimum bid that you can send with msg.value
162
+ function getMinBid(address program) external view returns (uint192 min) {
163
+ return getMinBid(program.codehash);
164
+ }
165
+
158
166
  /// @notice Sends all revenue to the network fee account.
159
167
  function sweepFunds() external {
160
168
  (bool success, bytes memory data) = ARB_OWNER_PUBLIC.getNetworkFeeAccount().call{
@@ -167,18 +175,19 @@ contract CacheManager {
167
175
  }
168
176
  }
169
177
 
170
- /// @notice Places a bid, reverting if payment is insufficient.
171
- function placeBid(bytes32 codehash) external payable {
178
+ /// Places a bid, reverting if payment is insufficient.
179
+ function placeBid(address program) external payable {
172
180
  if (isPaused) {
173
181
  revert BidsArePaused();
174
182
  }
183
+ bytes32 codehash = program.codehash;
175
184
  if (_isCached(codehash)) {
176
185
  revert AlreadyCached(codehash);
177
186
  }
178
187
 
179
188
  uint64 asm = _asmSize(codehash);
180
189
  (uint192 bid, uint64 index) = _makeSpace(asm);
181
- return _addBid(bid, codehash, asm, index);
190
+ return _addBid(bid, program, codehash, asm, index);
182
191
  }
183
192
 
184
193
  /// @notice Evicts entries until enough space exists in the cache, reverting if payment is insufficient.
@@ -230,6 +239,7 @@ contract CacheManager {
230
239
  /// @dev Adds a bid
231
240
  function _addBid(
232
241
  uint192 bid,
242
+ address program,
233
243
  bytes32 code,
234
244
  uint64 size,
235
245
  uint64 index
@@ -239,7 +249,7 @@ contract CacheManager {
239
249
  }
240
250
 
241
251
  Entry memory entry = Entry({size: size, code: code, bid: bid});
242
- ARB_WASM_CACHE.cacheCodehash(code);
252
+ ARB_WASM_CACHE.cacheProgram(program);
243
253
  bids.push(_packBid(bid, index));
244
254
  queueSize += size;
245
255
  if (index == entries.length) {
@@ -247,7 +257,7 @@ contract CacheManager {
247
257
  } else {
248
258
  entries[index] = entry;
249
259
  }
250
- emit InsertBid(code, bid, size);
260
+ emit InsertBid(code, program, bid, size);
251
261
  }
252
262
 
253
263
  /// @dev Clears the entry at the given index
@@ -8,3 +8,14 @@ uint64 constant NO_CHAL_INDEX = 0;
8
8
 
9
9
  // Expected seconds per block in Ethereum PoS
10
10
  uint256 constant ETH_POS_BLOCK_TIME = 12;
11
+
12
+ /// @dev If nativeTokenDecimals is different than 18 decimals, bridge will inflate or deflate token amounts
13
+ /// when depositing to child chain to match 18 decimal denomination. Opposite process happens when
14
+ /// amount is withdrawn back to parent chain. In order to avoid uint256 overflows we restrict max number
15
+ /// of decimals to 36 which should be enough for most practical use-cases.
16
+ uint8 constant MAX_ALLOWED_NATIVE_TOKEN_DECIMALS = uint8(36);
17
+
18
+ /// @dev Max amount of erc20 native token that can deposit when upscaling is required (i.e. < 18 decimals)
19
+ /// Amounts higher than this would risk uint256 overflows when adjusting decimals. Considering
20
+ /// 18 decimals are 60 bits, we choose 2^192 as the limit which equals to ~6.3*10^57 weis of token
21
+ uint256 constant MAX_UPSCALE_AMOUNT = type(uint192).max;
@@ -0,0 +1,33 @@
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 {ERC20} from "@openzeppelin/contracts/token/ERC20/ERC20.sol";
8
+
9
+ library DecimalsConverterHelper {
10
+ /// @notice generic function for mapping amount from one decimal denomination to another
11
+ /// @dev Ie. let's say amount is 752. If token has 16 decimals and is being adjusted to
12
+ /// 18 decimals then amount will be 75200. If token has 20 decimals adjusted amount
13
+ /// is 7. If token uses no decimals converted amount is 752*10^18.
14
+ /// When amount is adjusted from 18 decimals back to native token decimals, opposite
15
+ /// process is performed.
16
+ /// @param amount amount to convert
17
+ /// @param decimalsIn current decimals
18
+ /// @param decimalsOut target decimals
19
+ /// @return amount converted to 'decimalsOut' decimals
20
+ function adjustDecimals(
21
+ uint256 amount,
22
+ uint8 decimalsIn,
23
+ uint8 decimalsOut
24
+ ) internal pure returns (uint256) {
25
+ if (decimalsIn == decimalsOut) {
26
+ return amount;
27
+ } else if (decimalsIn < decimalsOut) {
28
+ return amount * 10**(decimalsOut - decimalsIn);
29
+ } else {
30
+ return amount / 10**(decimalsIn - decimalsOut);
31
+ }
32
+ }
33
+ }
@@ -119,6 +119,12 @@ error NotForked();
119
119
  /// @dev The provided gasLimit is larger than uint64
120
120
  error GasLimitTooLarge();
121
121
 
122
+ /// @dev The provided amount cannot be adjusted to 18 decimals due to overflow
123
+ error AmountTooLarge(uint256 amount);
124
+
125
+ /// @dev Number of native token's decimals is restricted to enable conversions to 18 decimals
126
+ error NativeTokenDecimalsTooLarge(uint256 decimals);
127
+
122
128
  // Outbox Errors
123
129
 
124
130
  /// @dev The provided proof was too long
@@ -32,6 +32,9 @@ contract BridgeStub is IBridge, IEthBridge {
32
32
  address public sequencerInbox;
33
33
  uint256 public override sequencerReportedSubMessageCount;
34
34
 
35
+ address public nativeToken;
36
+ uint8 public nativeTokenDecimals;
37
+
35
38
  function setSequencerInbox(address _sequencerInbox) external override {
36
39
  sequencerInbox = _sequencerInbox;
37
40
  emit SequencerInboxUpdated(_sequencerInbox);
@@ -7,7 +7,7 @@ import "../precompiles/ArbWasmCache.sol";
7
7
 
8
8
  contract SimpleCacheManager {
9
9
  function cacheProgram(address program) external {
10
- ArbWasmCache(address(0x72)).cacheCodehash(codehash(program));
10
+ ArbWasmCache(address(0x72)).cacheProgram(program);
11
11
  }
12
12
 
13
13
  function evictProgram(address program) external {
@@ -18,7 +18,7 @@ interface NodeInterface {
18
18
  * @param deposit amount to deposit to sender in L2
19
19
  * @param to destination L2 contract address
20
20
  * @param l2CallValue call value for retryable L2 message
21
- * @param excessFeeRefundAddress gasLimit x maxFeePerGas - execution cost gets credited here on L2 balance
21
+ * @param excessFeeRefundAddress the address which receives the difference between execution fee paid and the actual execution cost
22
22
  * @param callValueRefundAddress l2Callvalue gets credited here on L2 if retryable txn times out or gets cancelled
23
23
  * @param data ABI encoded data of L2 message
24
24
  */
@@ -16,11 +16,14 @@ interface ArbWasmCache {
16
16
  /// @return managers the list of managers.
17
17
  function allCacheManagers() external view returns (address[] memory managers);
18
18
 
19
- /// @notice Caches all programs with the given codehash.
19
+ /// @dev Deprecated, replaced with cacheProgram
20
+ function cacheCodehash(bytes32 codehash) external;
21
+
22
+ /// @notice Caches all programs with a codehash equal to the given address.
20
23
  /// @notice Reverts if the programs have expired.
21
24
  /// @notice Caller must be a cache manager or chain owner.
22
25
  /// @notice If you're looking for how to bid for position, interact with the chain's cache manager contract.
23
- function cacheCodehash(bytes32 codehash) external;
26
+ function cacheProgram(address addr) external;
24
27
 
25
28
  /// @notice Evicts all programs with the given codehash.
26
29
  /// @notice Caller must be a cache manager or chain owner.
@@ -53,10 +53,7 @@ abstract contract AbsRollupEventInbox is
53
53
  {
54
54
  require(bytes(chainConfig).length > 0, "EMPTY_CHAIN_CONFIG");
55
55
  uint8 initMsgVersion = 1;
56
- uint256 currentDataCost = block.basefee;
57
- if (ArbitrumChecker.runningOnArbitrum()) {
58
- currentDataCost += ArbGasInfo(address(0x6c)).getL1BaseFeeEstimate();
59
- }
56
+ uint256 currentDataCost = _currentDataCostToReport();
60
57
  bytes memory initMsg = abi.encodePacked(
61
58
  chainId,
62
59
  initMsgVersion,
@@ -68,4 +65,6 @@ abstract contract AbsRollupEventInbox is
68
65
  }
69
66
 
70
67
  function _enqueueInitializationMsg(bytes memory initMsg) internal virtual returns (uint256);
68
+
69
+ function _currentDataCostToReport() internal virtual returns (uint256);
71
70
  }
@@ -6,8 +6,8 @@ pragma solidity ^0.8.0;
6
6
 
7
7
  import {IInbox} from "../bridge/IInbox.sol";
8
8
  import {IInboxBase} from "../bridge/IInboxBase.sol";
9
- import {IERC20Bridge} from "../bridge/IERC20Bridge.sol";
10
9
  import {IERC20Inbox} from "../bridge/ERC20Inbox.sol";
10
+ import {ERC20} from "@openzeppelin/contracts/token/ERC20/ERC20.sol";
11
11
 
12
12
  /// @notice Helper contract for deploying some keyless deployment to Arbitrum using delayed inbox
13
13
  contract DeployHelper {
@@ -48,7 +48,7 @@ contract DeployHelper {
48
48
  uint256 _value,
49
49
  address _l2Address,
50
50
  bytes memory payload,
51
- bool _isUsingFeeToken,
51
+ address _nativeToken,
52
52
  uint256 maxFeePerGas
53
53
  ) internal {
54
54
  uint256 submissionCost = IInboxBase(inbox).calculateRetryableSubmissionFee(
@@ -58,7 +58,20 @@ contract DeployHelper {
58
58
  uint256 feeAmount = _value + submissionCost + GASLIMIT * maxFeePerGas;
59
59
 
60
60
  // fund the target L2 address
61
- if (_isUsingFeeToken) {
61
+ if (_nativeToken != address(0)) {
62
+ // calculate the fee amount in the native token's decimals
63
+ uint256 feeAmountNativeDenominated = feeAmount;
64
+ uint8 decimals = ERC20(_nativeToken).decimals();
65
+ if (decimals < 18) {
66
+ feeAmountNativeDenominated = feeAmount / (10**(18 - decimals));
67
+ // round up if necessary
68
+ if (feeAmountNativeDenominated * (10**(18 - decimals)) < feeAmount) {
69
+ feeAmountNativeDenominated++;
70
+ }
71
+ } else if (decimals > 18) {
72
+ feeAmountNativeDenominated = feeAmount * (10**(decimals - 18));
73
+ }
74
+
62
75
  IERC20Inbox(inbox).createRetryableTicket({
63
76
  to: _l2Address,
64
77
  l2CallValue: _value,
@@ -67,7 +80,7 @@ contract DeployHelper {
67
80
  callValueRefundAddress: msg.sender,
68
81
  gasLimit: GASLIMIT,
69
82
  maxFeePerGas: maxFeePerGas,
70
- tokenTotalFeeAmount: feeAmount,
83
+ tokenTotalFeeAmount: feeAmountNativeDenominated,
71
84
  data: ""
72
85
  });
73
86
  } else {
@@ -91,14 +104,12 @@ contract DeployHelper {
91
104
  address _nativeToken,
92
105
  uint256 _maxFeePerGas
93
106
  ) external payable {
94
- bool isUsingFeeToken = _nativeToken != address(0);
95
-
96
107
  _fundAndDeploy(
97
108
  _inbox,
98
109
  NICK_CREATE2_VALUE,
99
110
  NICK_CREATE2_DEPLOYER,
100
111
  NICK_CREATE2_PAYLOAD,
101
- isUsingFeeToken,
112
+ _nativeToken,
102
113
  _maxFeePerGas
103
114
  );
104
115
  _fundAndDeploy(
@@ -106,7 +117,7 @@ contract DeployHelper {
106
117
  ERC2470_VALUE,
107
118
  ERC2470_DEPLOYER,
108
119
  ERC2470_PAYLOAD,
109
- isUsingFeeToken,
120
+ _nativeToken,
110
121
  _maxFeePerGas
111
122
  );
112
123
  _fundAndDeploy(
@@ -114,7 +125,7 @@ contract DeployHelper {
114
125
  ZOLTU_VALUE,
115
126
  ZOLTU_CREATE2_DEPLOYER,
116
127
  ZOLTU_CREATE2_PAYLOAD,
117
- isUsingFeeToken,
128
+ _nativeToken,
118
129
  _maxFeePerGas
119
130
  );
120
131
  _fundAndDeploy(
@@ -122,12 +133,12 @@ contract DeployHelper {
122
133
  ERC1820_VALUE,
123
134
  ERC1820_DEPLOYER,
124
135
  ERC1820_PAYLOAD,
125
- isUsingFeeToken,
136
+ _nativeToken,
126
137
  _maxFeePerGas
127
138
  );
128
139
 
129
140
  // if paying with ETH refund the caller
130
- if (!isUsingFeeToken) {
141
+ if (_nativeToken == address(0)) {
131
142
  payable(msg.sender).transfer(address(this).balance);
132
143
  }
133
144
  }
@@ -23,4 +23,9 @@ contract ERC20RollupEventInbox is AbsRollupEventInbox {
23
23
  tokenAmount
24
24
  );
25
25
  }
26
+
27
+ function _currentDataCostToReport() internal pure override returns (uint256) {
28
+ // at the moment chains using fee token in Anytrust mode do not charge for the data posting fees
29
+ return 0;
30
+ }
26
31
  }
@@ -0,0 +1,54 @@
1
+ // SPDX-License-Identifier: GPL-3.0
2
+ pragma solidity ^0.8.0;
3
+
4
+ /**
5
+ * @title Helper contract for cross-chain deployment of deterministic factories when rollup uses custom fee token
6
+ * @notice It bundles sending the fee token to inbox and invoking the factory deployment function.
7
+ * Prerequisite: fee token must be approved for this contract to send it to inbox.
8
+ */
9
+ contract FactoryDeployerHelper {
10
+ address public constant DEPLOY_HELPER = address(0x90D68B056c411015eaE3EC0b98AD94E2C91419F1);
11
+ uint256 public constant MAX_FEE_PER_GAS = 100_000_000;
12
+
13
+ function deploy(address inbox) external {
14
+ deploy(inbox, MAX_FEE_PER_GAS);
15
+ }
16
+
17
+ function deploy(address inbox, uint256 maxFeePerGas) public {
18
+ address bridge = address(IInboxBase(inbox).bridge());
19
+ address feeToken = IERC20Bridge(bridge).nativeToken();
20
+
21
+ uint256 amount = IDeployHelper(DEPLOY_HELPER).getDeploymentTotalCost(inbox, maxFeePerGas);
22
+ IERC20(feeToken).transferFrom(msg.sender, inbox, amount);
23
+ IDeployHelper(DEPLOY_HELPER).perform(inbox, feeToken, maxFeePerGas);
24
+ }
25
+ }
26
+
27
+ interface IERC20 {
28
+ function transferFrom(
29
+ address from,
30
+ address to,
31
+ uint256 value
32
+ ) external returns (bool);
33
+ }
34
+
35
+ interface IDeployHelper {
36
+ function getDeploymentTotalCost(address inbox, uint256 maxFeePerGas)
37
+ external
38
+ view
39
+ returns (uint256);
40
+
41
+ function perform(
42
+ address _inbox,
43
+ address _nativeToken,
44
+ uint256 _maxFeePerGas
45
+ ) external payable;
46
+ }
47
+
48
+ interface IInboxBase {
49
+ function bridge() external view returns (address);
50
+ }
51
+
52
+ interface IERC20Bridge {
53
+ function nativeToken() external view returns (address);
54
+ }
@@ -24,6 +24,8 @@ interface IRollupUserAbs is IRollupCore, IOwnable {
24
24
 
25
25
  function confirmNextNode(bytes32 blockHash, bytes32 sendRoot) external;
26
26
 
27
+ function fastConfirmNextNode(bytes32 blockHash, bytes32 sendRoot) external;
28
+
27
29
  function stakeOnExistingNode(uint64 nodeNum, bytes32 nodeHash) external;
28
30
 
29
31
  function stakeOnNewNode(
@@ -379,4 +379,15 @@ contract RollupAdminLogic is RollupCore, IRollupAdmin, DoubleLogicUUPSUpgradeabl
379
379
  validatorWhitelistDisabled = _validatorWhitelistDisabled;
380
380
  emit OwnerFunctionCalled(30);
381
381
  }
382
+
383
+ /**
384
+ * @notice set the anyTrustFastConfirmer address
385
+ * must also call `setValidator` to set the same address as a validator to work
386
+ * old fast confirmer need to be removed from the validator list manually
387
+ * @param _anyTrustFastConfirmer new value of anyTrustFastConfirmer
388
+ */
389
+ function setAnyTrustFastConfirmer(address _anyTrustFastConfirmer) external {
390
+ anyTrustFastConfirmer = _anyTrustFastConfirmer;
391
+ emit OwnerFunctionCalled(31);
392
+ }
382
393
  }
@@ -77,6 +77,7 @@ abstract contract RollupCore is IRollupCore, PausableUpgradeable {
77
77
  uint64 internal constant GENESIS_NODE = 0;
78
78
 
79
79
  bool public validatorWhitelistDisabled;
80
+ address public anyTrustFastConfirmer;
80
81
 
81
82
  // If the chain this RollupCore is deployed on is an Arbitrum chain.
82
83
  bool internal immutable _hostChainIsArbitrum = ArbitrumChecker.runningOnArbitrum();
@@ -277,10 +277,58 @@ contract RollupCreator is Ownable {
277
277
  IInboxBase(_inbox),
278
278
  _maxFeePerGas
279
279
  );
280
- IERC20(_nativeToken).safeTransferFrom(msg.sender, _inbox, totalFee);
280
+
281
+ // calculate the fee amount in the native token's decimals
282
+ uint8 decimals = ERC20(_nativeToken).decimals();
283
+
284
+ uint256 totalFeeNativeDenominated = totalFee;
285
+ if (decimals < 18) {
286
+ uint256 gasCost = _maxFeePerGas * 21_000;
287
+ uint256 nickCreate2Cost = _scaleDownToNativeDecimals(
288
+ l2FactoriesDeployer.NICK_CREATE2_VALUE() + gasCost,
289
+ decimals
290
+ );
291
+ uint256 erc2470Cost = _scaleDownToNativeDecimals(
292
+ l2FactoriesDeployer.ERC2470_VALUE() + gasCost,
293
+ decimals
294
+ );
295
+ uint256 zoltuCreate2Cost = _scaleDownToNativeDecimals(
296
+ l2FactoriesDeployer.ZOLTU_VALUE() + gasCost,
297
+ decimals
298
+ );
299
+ uint256 erc1820Cost = _scaleDownToNativeDecimals(
300
+ l2FactoriesDeployer.ERC1820_VALUE() + gasCost,
301
+ decimals
302
+ );
303
+ totalFeeNativeDenominated =
304
+ nickCreate2Cost +
305
+ erc2470Cost +
306
+ zoltuCreate2Cost +
307
+ erc1820Cost;
308
+ } else if (decimals > 18) {
309
+ totalFeeNativeDenominated = totalFee * (10**(decimals - 18));
310
+ }
311
+
312
+ IERC20(_nativeToken).safeTransferFrom(msg.sender, _inbox, totalFeeNativeDenominated);
281
313
 
282
314
  // do it
283
315
  l2FactoriesDeployer.perform(_inbox, _nativeToken, _maxFeePerGas);
284
316
  }
285
317
  }
318
+
319
+ function _scaleDownToNativeDecimals(uint256 amount, uint8 decimals)
320
+ internal
321
+ pure
322
+ returns (uint256)
323
+ {
324
+ uint256 scaledAmount = amount;
325
+ if (decimals < 18) {
326
+ scaledAmount = amount / (10**(18 - decimals));
327
+ // round up if necessary
328
+ if (scaledAmount * (10**(18 - decimals)) < amount) {
329
+ scaledAmount++;
330
+ }
331
+ }
332
+ return scaledAmount;
333
+ }
286
334
  }
@@ -21,4 +21,12 @@ contract RollupEventInbox is AbsRollupEventInbox {
21
21
  keccak256(initMsg)
22
22
  );
23
23
  }
24
+
25
+ function _currentDataCostToReport() internal view override returns (uint256) {
26
+ uint256 currentDataCost = block.basefee;
27
+ if (ArbitrumChecker.runningOnArbitrum()) {
28
+ currentDataCost += ArbGasInfo(address(0x6c)).getL1BaseFeeEstimate();
29
+ }
30
+ return currentDataCost;
31
+ }
24
32
  }
@@ -116,29 +116,28 @@ abstract contract AbsRollupUserLogic is
116
116
  emit NodeRejected(firstUnresolvedNodeNum);
117
117
  }
118
118
 
119
- /**
120
- * @notice Confirm the next unresolved node
121
- * @param blockHash The block hash at the end of the assertion
122
- * @param sendRoot The send root at the end of the assertion
123
- */
124
- function confirmNextNode(bytes32 blockHash, bytes32 sendRoot)
125
- external
126
- onlyValidator
127
- whenNotPaused
128
- {
119
+ function _confirmNextNode(
120
+ bytes32 blockHash,
121
+ bytes32 sendRoot,
122
+ bool isFastConfirm
123
+ ) internal {
129
124
  requireUnresolvedExists();
130
125
 
131
126
  uint64 nodeNum = firstUnresolvedNode();
132
127
  Node storage node = getNodeStorage(nodeNum);
133
128
 
134
- // Verify the block's deadline has passed
135
- node.requirePastDeadline();
129
+ if (!isFastConfirm) {
130
+ // Verify the block's deadline has passed
131
+ node.requirePastDeadline();
132
+ }
136
133
 
137
134
  // Check that prev is latest confirmed
138
135
  assert(node.prevNum == latestConfirmed());
139
136
 
140
137
  Node storage prevNode = getNodeStorage(node.prevNum);
141
- prevNode.requirePastChildConfirmDeadline();
138
+ if (!isFastConfirm) {
139
+ prevNode.requirePastChildConfirmDeadline();
140
+ }
142
141
 
143
142
  removeOldZombies(0);
144
143
 
@@ -155,6 +154,29 @@ abstract contract AbsRollupUserLogic is
155
154
  confirmNode(nodeNum, blockHash, sendRoot);
156
155
  }
157
156
 
157
+ /**
158
+ * @notice Confirm the next unresolved node
159
+ * @param blockHash The block hash at the end of the assertion
160
+ * @param sendRoot The send root at the end of the assertion
161
+ */
162
+ function confirmNextNode(bytes32 blockHash, bytes32 sendRoot)
163
+ external
164
+ onlyValidator
165
+ whenNotPaused
166
+ {
167
+ _confirmNextNode(blockHash, sendRoot, false);
168
+ }
169
+
170
+ /**
171
+ * @notice This allow anyTrustFastConfirmer to confirm next node regardless of deadline
172
+ * the anyTrustFastConfirmer is supposed to be set only on an AnyTrust chain to
173
+ * a contract that can call this function when received sufficient signatures
174
+ */
175
+ function fastConfirmNextNode(bytes32 blockHash, bytes32 sendRoot) external whenNotPaused {
176
+ require(msg.sender == anyTrustFastConfirmer, "NOT_FAST_CONFIRMER");
177
+ _confirmNextNode(blockHash, sendRoot, true);
178
+ }
179
+
158
180
  /**
159
181
  * @notice Create a new stake
160
182
  * @param depositAmount The amount of either eth or tokens staked
@@ -46,6 +46,9 @@ contract BridgeTester is Initializable, DelegateCallAware, IBridge, IEthBridge {
46
46
  IOwnable public rollup;
47
47
  address public sequencerInbox;
48
48
 
49
+ address public nativeToken;
50
+ uint8 public nativeTokenDecimals;
51
+
49
52
  modifier onlyRollupOrOwner() {
50
53
  if (msg.sender != address(rollup)) {
51
54
  address rollupOwner = rollup.owner();
@@ -1,4 +0,0 @@
1
- {
2
- "_format": "hh-sol-dbg-1",
3
- "buildInfo": "../../../../../../build-info/83d3fd0b633e3a3120fc5455f62bf6b6.json"
4
- }