web3gbit-cli 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (989) hide show
  1. package/--broadcast +0 -0
  2. package/--private-key +0 -0
  3. package/--rpc-url +0 -0
  4. package/.github/workflows/test.yml +38 -0
  5. package/.gitmodules +3 -0
  6. package/GbitToken_flat.sol +2 -0
  7. package/GbitToken_flat.solnpx +0 -0
  8. package/README.md +72 -0
  9. package/admin-cli.js +413 -0
  10. package/cache/solidity-files-cache.json +1 -0
  11. package/foundry.lock +8 -0
  12. package/foundry.toml +6 -0
  13. package/lib/forge-std/.gitattributes +1 -0
  14. package/lib/forge-std/.github/CODEOWNERS +1 -0
  15. package/lib/forge-std/.github/dependabot.yml +6 -0
  16. package/lib/forge-std/.github/workflows/ci.yml +125 -0
  17. package/lib/forge-std/.github/workflows/sync.yml +36 -0
  18. package/lib/forge-std/CONTRIBUTING.md +193 -0
  19. package/lib/forge-std/LICENSE-APACHE +203 -0
  20. package/lib/forge-std/LICENSE-MIT +25 -0
  21. package/lib/forge-std/README.md +268 -0
  22. package/lib/forge-std/RELEASE_CHECKLIST.md +12 -0
  23. package/lib/forge-std/foundry.toml +18 -0
  24. package/lib/forge-std/package.json +16 -0
  25. package/lib/forge-std/scripts/vm.py +636 -0
  26. package/lib/forge-std/src/Base.sol +48 -0
  27. package/lib/forge-std/src/Config.sol +60 -0
  28. package/lib/forge-std/src/LibVariable.sol +477 -0
  29. package/lib/forge-std/src/Script.sol +28 -0
  30. package/lib/forge-std/src/StdAssertions.sol +779 -0
  31. package/lib/forge-std/src/StdChains.sol +295 -0
  32. package/lib/forge-std/src/StdCheats.sol +825 -0
  33. package/lib/forge-std/src/StdConfig.sol +632 -0
  34. package/lib/forge-std/src/StdConstants.sol +30 -0
  35. package/lib/forge-std/src/StdError.sol +15 -0
  36. package/lib/forge-std/src/StdInvariant.sol +120 -0
  37. package/lib/forge-std/src/StdJson.sol +275 -0
  38. package/lib/forge-std/src/StdMath.sol +47 -0
  39. package/lib/forge-std/src/StdStorage.sol +475 -0
  40. package/lib/forge-std/src/StdStyle.sol +333 -0
  41. package/lib/forge-std/src/StdToml.sol +275 -0
  42. package/lib/forge-std/src/StdUtils.sol +200 -0
  43. package/lib/forge-std/src/Test.sol +32 -0
  44. package/lib/forge-std/src/Vm.sol +2500 -0
  45. package/lib/forge-std/src/console.sol +1551 -0
  46. package/lib/forge-std/src/console2.sol +4 -0
  47. package/lib/forge-std/src/interfaces/IERC1155.sol +105 -0
  48. package/lib/forge-std/src/interfaces/IERC165.sol +12 -0
  49. package/lib/forge-std/src/interfaces/IERC20.sol +43 -0
  50. package/lib/forge-std/src/interfaces/IERC4626.sol +190 -0
  51. package/lib/forge-std/src/interfaces/IERC6909.sol +72 -0
  52. package/lib/forge-std/src/interfaces/IERC721.sol +164 -0
  53. package/lib/forge-std/src/interfaces/IERC7540.sol +144 -0
  54. package/lib/forge-std/src/interfaces/IERC7575.sol +241 -0
  55. package/lib/forge-std/src/interfaces/IMulticall3.sol +68 -0
  56. package/lib/forge-std/src/safeconsole.sol +13248 -0
  57. package/lib/forge-std/test/CommonBase.t.sol +44 -0
  58. package/lib/forge-std/test/Config.t.sol +381 -0
  59. package/lib/forge-std/test/LibVariable.t.sol +452 -0
  60. package/lib/forge-std/test/StdAssertions.t.sol +141 -0
  61. package/lib/forge-std/test/StdChains.t.sol +227 -0
  62. package/lib/forge-std/test/StdCheats.t.sol +638 -0
  63. package/lib/forge-std/test/StdConstants.t.sol +38 -0
  64. package/lib/forge-std/test/StdError.t.sol +119 -0
  65. package/lib/forge-std/test/StdJson.t.sol +49 -0
  66. package/lib/forge-std/test/StdMath.t.sol +202 -0
  67. package/lib/forge-std/test/StdStorage.t.sol +485 -0
  68. package/lib/forge-std/test/StdStyle.t.sol +110 -0
  69. package/lib/forge-std/test/StdToml.t.sol +49 -0
  70. package/lib/forge-std/test/StdUtils.t.sol +342 -0
  71. package/lib/forge-std/test/Vm.t.sol +18 -0
  72. package/lib/forge-std/test/compilation/CompilationScript.sol +8 -0
  73. package/lib/forge-std/test/compilation/CompilationScriptBase.sol +8 -0
  74. package/lib/forge-std/test/compilation/CompilationTest.sol +8 -0
  75. package/lib/forge-std/test/compilation/CompilationTestBase.sol +8 -0
  76. package/lib/forge-std/test/fixtures/broadcast.log.json +187 -0
  77. package/lib/forge-std/test/fixtures/config.toml +81 -0
  78. package/lib/forge-std/test/fixtures/test.json +8 -0
  79. package/lib/forge-std/test/fixtures/test.toml +6 -0
  80. package/lib/openzeppelin-contracts/.changeset/blue-mirrors-agree.md +5 -0
  81. package/lib/openzeppelin-contracts/.changeset/bright-webs-create.md +5 -0
  82. package/lib/openzeppelin-contracts/.changeset/clean-worlds-end.md +5 -0
  83. package/lib/openzeppelin-contracts/.changeset/config.json +12 -0
  84. package/lib/openzeppelin-contracts/.changeset/curly-pandas-flow.md +5 -0
  85. package/lib/openzeppelin-contracts/.changeset/flat-ideas-count.md +5 -0
  86. package/lib/openzeppelin-contracts/.changeset/fluffy-facts-brake.md +5 -0
  87. package/lib/openzeppelin-contracts/.changeset/forty-ads-design.md +5 -0
  88. package/lib/openzeppelin-contracts/.changeset/full-emus-hear.md +5 -0
  89. package/lib/openzeppelin-contracts/.changeset/fuzzy-lizards-do.md +5 -0
  90. package/lib/openzeppelin-contracts/.changeset/grumpy-cats-brake.md +5 -0
  91. package/lib/openzeppelin-contracts/.changeset/khaki-crews-join.md +5 -0
  92. package/lib/openzeppelin-contracts/.changeset/new-socks-deny.md +5 -0
  93. package/lib/openzeppelin-contracts/.changeset/shaky-phones-mix.md +5 -0
  94. package/lib/openzeppelin-contracts/.changeset/social-tools-sniff.md +5 -0
  95. package/lib/openzeppelin-contracts/.changeset/spotty-plums-brush.md +5 -0
  96. package/lib/openzeppelin-contracts/.changeset/stale-lizards-cheat.md +5 -0
  97. package/lib/openzeppelin-contracts/.changeset/swift-planets-juggle.md +5 -0
  98. package/lib/openzeppelin-contracts/.changeset/tame-monkeys-make.md +5 -0
  99. package/lib/openzeppelin-contracts/.changeset/tender-pans-yawn.md +5 -0
  100. package/lib/openzeppelin-contracts/.changeset/thick-banks-relate.md +5 -0
  101. package/lib/openzeppelin-contracts/.changeset/vast-worlds-pull.md +5 -0
  102. package/lib/openzeppelin-contracts/.changeset/whole-turkeys-swim.md +5 -0
  103. package/lib/openzeppelin-contracts/.changeset/yellow-clowns-mate.md +5 -0
  104. package/lib/openzeppelin-contracts/.changeset/young-corners-help.md +5 -0
  105. package/lib/openzeppelin-contracts/.codecov.yml +16 -0
  106. package/lib/openzeppelin-contracts/.editorconfig +21 -0
  107. package/lib/openzeppelin-contracts/.gitattributes +3 -0
  108. package/lib/openzeppelin-contracts/.github/CODEOWNERS +10 -0
  109. package/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/bug_report.md +21 -0
  110. package/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/config.yml +4 -0
  111. package/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/feature_request.md +14 -0
  112. package/lib/openzeppelin-contracts/.github/PULL_REQUEST_TEMPLATE.md +20 -0
  113. package/lib/openzeppelin-contracts/.github/actions/gas-compare/action.yml +51 -0
  114. package/lib/openzeppelin-contracts/.github/actions/setup/action.yml +108 -0
  115. package/lib/openzeppelin-contracts/.github/actions/storage-layout/action.yml +57 -0
  116. package/lib/openzeppelin-contracts/.github/workflows/actionlint.yml +18 -0
  117. package/lib/openzeppelin-contracts/.github/workflows/changeset.yml +28 -0
  118. package/lib/openzeppelin-contracts/.github/workflows/checks.yml +132 -0
  119. package/lib/openzeppelin-contracts/.github/workflows/docs.yml +19 -0
  120. package/lib/openzeppelin-contracts/.github/workflows/formal-verification.yml +63 -0
  121. package/lib/openzeppelin-contracts/.github/workflows/release-cycle.yml +212 -0
  122. package/lib/openzeppelin-contracts/.github/workflows/release-upgradeable.yml +95 -0
  123. package/lib/openzeppelin-contracts/.github/workflows/upgradeable.yml +35 -0
  124. package/lib/openzeppelin-contracts/.gitmodules +10 -0
  125. package/lib/openzeppelin-contracts/.husky/pre-commit +2 -0
  126. package/lib/openzeppelin-contracts/.mocharc.js +4 -0
  127. package/lib/openzeppelin-contracts/.prettierrc +15 -0
  128. package/lib/openzeppelin-contracts/.solcover.js +21 -0
  129. package/lib/openzeppelin-contracts/CHANGELOG.md +1364 -0
  130. package/lib/openzeppelin-contracts/CODE_OF_CONDUCT.md +73 -0
  131. package/lib/openzeppelin-contracts/CONTRIBUTING.md +36 -0
  132. package/lib/openzeppelin-contracts/FUNDING.json +10 -0
  133. package/lib/openzeppelin-contracts/GUIDELINES.md +170 -0
  134. package/lib/openzeppelin-contracts/LICENSE +22 -0
  135. package/lib/openzeppelin-contracts/README.md +122 -0
  136. package/lib/openzeppelin-contracts/RELEASING.md +45 -0
  137. package/lib/openzeppelin-contracts/SECURITY.md +43 -0
  138. package/lib/openzeppelin-contracts/audits/2017-03.md +292 -0
  139. package/lib/openzeppelin-contracts/audits/2018-10.pdf +0 -0
  140. package/lib/openzeppelin-contracts/audits/2022-10-Checkpoints.pdf +0 -0
  141. package/lib/openzeppelin-contracts/audits/2022-10-ERC4626.pdf +0 -0
  142. package/lib/openzeppelin-contracts/audits/2023-05-v4.9.pdf +0 -0
  143. package/lib/openzeppelin-contracts/audits/2023-10-v5.0.pdf +0 -0
  144. package/lib/openzeppelin-contracts/audits/2024-10-v5.1.pdf +0 -0
  145. package/lib/openzeppelin-contracts/audits/2024-12-v5.2.pdf +0 -0
  146. package/lib/openzeppelin-contracts/audits/2025-04-v5.3.pdf +0 -0
  147. package/lib/openzeppelin-contracts/audits/2025-07-v5.4.pdf +0 -0
  148. package/lib/openzeppelin-contracts/audits/2025-10-v5.5.pdf +0 -0
  149. package/lib/openzeppelin-contracts/audits/README.md +22 -0
  150. package/lib/openzeppelin-contracts/contracts/access/AccessControl.sol +207 -0
  151. package/lib/openzeppelin-contracts/contracts/access/IAccessControl.sol +98 -0
  152. package/lib/openzeppelin-contracts/contracts/access/Ownable.sol +100 -0
  153. package/lib/openzeppelin-contracts/contracts/access/Ownable2Step.sol +67 -0
  154. package/lib/openzeppelin-contracts/contracts/access/README.adoc +45 -0
  155. package/lib/openzeppelin-contracts/contracts/access/extensions/AccessControlDefaultAdminRules.sol +372 -0
  156. package/lib/openzeppelin-contracts/contracts/access/extensions/AccessControlEnumerable.sol +81 -0
  157. package/lib/openzeppelin-contracts/contracts/access/extensions/IAccessControlDefaultAdminRules.sol +192 -0
  158. package/lib/openzeppelin-contracts/contracts/access/extensions/IAccessControlEnumerable.sol +31 -0
  159. package/lib/openzeppelin-contracts/contracts/access/manager/AccessManaged.sol +112 -0
  160. package/lib/openzeppelin-contracts/contracts/access/manager/AccessManager.sol +741 -0
  161. package/lib/openzeppelin-contracts/contracts/access/manager/AuthorityUtils.sol +36 -0
  162. package/lib/openzeppelin-contracts/contracts/access/manager/IAccessManaged.sol +32 -0
  163. package/lib/openzeppelin-contracts/contracts/access/manager/IAccessManager.sol +403 -0
  164. package/lib/openzeppelin-contracts/contracts/access/manager/IAuthority.sol +14 -0
  165. package/lib/openzeppelin-contracts/contracts/account/Account.sol +151 -0
  166. package/lib/openzeppelin-contracts/contracts/account/README.adoc +30 -0
  167. package/lib/openzeppelin-contracts/contracts/account/extensions/draft-AccountERC7579.sol +420 -0
  168. package/lib/openzeppelin-contracts/contracts/account/extensions/draft-AccountERC7579Hooked.sol +107 -0
  169. package/lib/openzeppelin-contracts/contracts/account/extensions/draft-ERC7821.sol +70 -0
  170. package/lib/openzeppelin-contracts/contracts/account/utils/EIP7702Utils.sol +21 -0
  171. package/lib/openzeppelin-contracts/contracts/account/utils/draft-ERC4337Utils.sol +279 -0
  172. package/lib/openzeppelin-contracts/contracts/account/utils/draft-ERC7579Utils.sol +280 -0
  173. package/lib/openzeppelin-contracts/contracts/crosschain/CrosschainLinked.sol +108 -0
  174. package/lib/openzeppelin-contracts/contracts/crosschain/ERC7786Recipient.sol +70 -0
  175. package/lib/openzeppelin-contracts/contracts/crosschain/README.adoc +29 -0
  176. package/lib/openzeppelin-contracts/contracts/crosschain/bridges/BridgeERC20.sol +36 -0
  177. package/lib/openzeppelin-contracts/contracts/crosschain/bridges/BridgeERC20Core.sol +79 -0
  178. package/lib/openzeppelin-contracts/contracts/crosschain/bridges/BridgeERC7802.sol +33 -0
  179. package/lib/openzeppelin-contracts/contracts/finance/README.adoc +14 -0
  180. package/lib/openzeppelin-contracts/contracts/finance/VestingWallet.sol +160 -0
  181. package/lib/openzeppelin-contracts/contracts/finance/VestingWalletCliff.sol +54 -0
  182. package/lib/openzeppelin-contracts/contracts/governance/Governor.sol +819 -0
  183. package/lib/openzeppelin-contracts/contracts/governance/IGovernor.sol +454 -0
  184. package/lib/openzeppelin-contracts/contracts/governance/README.adoc +197 -0
  185. package/lib/openzeppelin-contracts/contracts/governance/TimelockController.sol +470 -0
  186. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorCountingFractional.sol +190 -0
  187. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorCountingOverridable.sol +222 -0
  188. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorCountingSimple.sol +96 -0
  189. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorNoncesKeyed.sol +91 -0
  190. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorPreventLateQuorum.sol +92 -0
  191. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorProposalGuardian.sol +59 -0
  192. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSequentialProposalId.sol +75 -0
  193. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSettings.sol +106 -0
  194. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorStorage.sol +134 -0
  195. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSuperQuorum.sol +59 -0
  196. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockAccess.sol +346 -0
  197. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockCompound.sol +165 -0
  198. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockControl.sol +167 -0
  199. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotes.sol +63 -0
  200. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesQuorumFraction.sol +113 -0
  201. package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesSuperQuorumFraction.sol +135 -0
  202. package/lib/openzeppelin-contracts/contracts/governance/utils/IVotes.sol +60 -0
  203. package/lib/openzeppelin-contracts/contracts/governance/utils/Votes.sol +253 -0
  204. package/lib/openzeppelin-contracts/contracts/governance/utils/VotesExtended.sol +85 -0
  205. package/lib/openzeppelin-contracts/contracts/interfaces/IERC1155.sol +6 -0
  206. package/lib/openzeppelin-contracts/contracts/interfaces/IERC1155MetadataURI.sol +6 -0
  207. package/lib/openzeppelin-contracts/contracts/interfaces/IERC1155Receiver.sol +6 -0
  208. package/lib/openzeppelin-contracts/contracts/interfaces/IERC1271.sol +17 -0
  209. package/lib/openzeppelin-contracts/contracts/interfaces/IERC1363.sol +86 -0
  210. package/lib/openzeppelin-contracts/contracts/interfaces/IERC1363Receiver.sol +32 -0
  211. package/lib/openzeppelin-contracts/contracts/interfaces/IERC1363Spender.sol +26 -0
  212. package/lib/openzeppelin-contracts/contracts/interfaces/IERC165.sol +6 -0
  213. package/lib/openzeppelin-contracts/contracts/interfaces/IERC1820Implementer.sol +20 -0
  214. package/lib/openzeppelin-contracts/contracts/interfaces/IERC1820Registry.sol +112 -0
  215. package/lib/openzeppelin-contracts/contracts/interfaces/IERC1967.sol +24 -0
  216. package/lib/openzeppelin-contracts/contracts/interfaces/IERC20.sol +6 -0
  217. package/lib/openzeppelin-contracts/contracts/interfaces/IERC20Metadata.sol +6 -0
  218. package/lib/openzeppelin-contracts/contracts/interfaces/IERC2309.sol +19 -0
  219. package/lib/openzeppelin-contracts/contracts/interfaces/IERC2612.sol +8 -0
  220. package/lib/openzeppelin-contracts/contracts/interfaces/IERC2981.sol +26 -0
  221. package/lib/openzeppelin-contracts/contracts/interfaces/IERC3156.sol +7 -0
  222. package/lib/openzeppelin-contracts/contracts/interfaces/IERC3156FlashBorrower.sol +27 -0
  223. package/lib/openzeppelin-contracts/contracts/interfaces/IERC3156FlashLender.sol +41 -0
  224. package/lib/openzeppelin-contracts/contracts/interfaces/IERC4626.sol +230 -0
  225. package/lib/openzeppelin-contracts/contracts/interfaces/IERC4906.sol +20 -0
  226. package/lib/openzeppelin-contracts/contracts/interfaces/IERC5267.sol +28 -0
  227. package/lib/openzeppelin-contracts/contracts/interfaces/IERC5313.sol +16 -0
  228. package/lib/openzeppelin-contracts/contracts/interfaces/IERC5805.sol +9 -0
  229. package/lib/openzeppelin-contracts/contracts/interfaces/IERC6372.sol +17 -0
  230. package/lib/openzeppelin-contracts/contracts/interfaces/IERC6909.sol +125 -0
  231. package/lib/openzeppelin-contracts/contracts/interfaces/IERC721.sol +6 -0
  232. package/lib/openzeppelin-contracts/contracts/interfaces/IERC721Enumerable.sol +6 -0
  233. package/lib/openzeppelin-contracts/contracts/interfaces/IERC721Metadata.sol +6 -0
  234. package/lib/openzeppelin-contracts/contracts/interfaces/IERC721Receiver.sol +6 -0
  235. package/lib/openzeppelin-contracts/contracts/interfaces/IERC7751.sol +12 -0
  236. package/lib/openzeppelin-contracts/contracts/interfaces/IERC777.sol +200 -0
  237. package/lib/openzeppelin-contracts/contracts/interfaces/IERC777Recipient.sol +35 -0
  238. package/lib/openzeppelin-contracts/contracts/interfaces/IERC777Sender.sol +35 -0
  239. package/lib/openzeppelin-contracts/contracts/interfaces/IERC7913.sol +18 -0
  240. package/lib/openzeppelin-contracts/contracts/interfaces/README.adoc +138 -0
  241. package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC1822.sol +20 -0
  242. package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC4337.sol +255 -0
  243. package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC6093.sol +162 -0
  244. package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7579.sol +227 -0
  245. package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7674.sol +17 -0
  246. package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7786.sol +64 -0
  247. package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7802.sol +32 -0
  248. package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7821.sol +44 -0
  249. package/lib/openzeppelin-contracts/contracts/metatx/ERC2771Context.sol +90 -0
  250. package/lib/openzeppelin-contracts/contracts/metatx/ERC2771Forwarder.sol +372 -0
  251. package/lib/openzeppelin-contracts/contracts/metatx/README.adoc +17 -0
  252. package/lib/openzeppelin-contracts/contracts/mocks/AccessManagedTarget.sol +34 -0
  253. package/lib/openzeppelin-contracts/contracts/mocks/AccessManagerMock.sol +20 -0
  254. package/lib/openzeppelin-contracts/contracts/mocks/ArraysMock.sol +171 -0
  255. package/lib/openzeppelin-contracts/contracts/mocks/AuthorityMock.sol +69 -0
  256. package/lib/openzeppelin-contracts/contracts/mocks/Base64Dirty.sol +19 -0
  257. package/lib/openzeppelin-contracts/contracts/mocks/BatchCaller.sol +20 -0
  258. package/lib/openzeppelin-contracts/contracts/mocks/CallReceiverMock.sol +106 -0
  259. package/lib/openzeppelin-contracts/contracts/mocks/ConstructorMock.sol +34 -0
  260. package/lib/openzeppelin-contracts/contracts/mocks/ContextMock.sol +35 -0
  261. package/lib/openzeppelin-contracts/contracts/mocks/DummyImplementation.sol +61 -0
  262. package/lib/openzeppelin-contracts/contracts/mocks/EIP712Verifier.sol +16 -0
  263. package/lib/openzeppelin-contracts/contracts/mocks/ERC1271WalletMock.sol +24 -0
  264. package/lib/openzeppelin-contracts/contracts/mocks/ERC165Mock.sol +100 -0
  265. package/lib/openzeppelin-contracts/contracts/mocks/ERC2771ContextMock.sol +28 -0
  266. package/lib/openzeppelin-contracts/contracts/mocks/ERC3156FlashBorrowerMock.sol +53 -0
  267. package/lib/openzeppelin-contracts/contracts/mocks/EtherReceiverMock.sol +17 -0
  268. package/lib/openzeppelin-contracts/contracts/mocks/InitializableMock.sol +130 -0
  269. package/lib/openzeppelin-contracts/contracts/mocks/MerkleProofCustomHashMock.sol +62 -0
  270. package/lib/openzeppelin-contracts/contracts/mocks/MerkleTreeMock.sol +52 -0
  271. package/lib/openzeppelin-contracts/contracts/mocks/MulticallHelper.sol +23 -0
  272. package/lib/openzeppelin-contracts/contracts/mocks/MultipleInheritanceInitializableMocks.sol +131 -0
  273. package/lib/openzeppelin-contracts/contracts/mocks/PausableMock.sol +31 -0
  274. package/lib/openzeppelin-contracts/contracts/mocks/ReentrancyAttack.sol +17 -0
  275. package/lib/openzeppelin-contracts/contracts/mocks/ReentrancyMock.sol +59 -0
  276. package/lib/openzeppelin-contracts/contracts/mocks/ReentrancyTransientMock.sol +59 -0
  277. package/lib/openzeppelin-contracts/contracts/mocks/RegressionImplementation.sol +61 -0
  278. package/lib/openzeppelin-contracts/contracts/mocks/SingleInheritanceInitializableMocks.sol +49 -0
  279. package/lib/openzeppelin-contracts/contracts/mocks/Stateless.sol +62 -0
  280. package/lib/openzeppelin-contracts/contracts/mocks/StorageSlotMock.sol +87 -0
  281. package/lib/openzeppelin-contracts/contracts/mocks/TimelockReentrant.sol +26 -0
  282. package/lib/openzeppelin-contracts/contracts/mocks/TransientSlotMock.sol +61 -0
  283. package/lib/openzeppelin-contracts/contracts/mocks/UpgradeableBeaconMock.sol +27 -0
  284. package/lib/openzeppelin-contracts/contracts/mocks/VotesExtendedMock.sol +42 -0
  285. package/lib/openzeppelin-contracts/contracts/mocks/VotesMock.sol +42 -0
  286. package/lib/openzeppelin-contracts/contracts/mocks/account/AccountMock.sol +181 -0
  287. package/lib/openzeppelin-contracts/contracts/mocks/account/modules/ERC7579Mock.sol +128 -0
  288. package/lib/openzeppelin-contracts/contracts/mocks/account/utils/ERC7579UtilsMock.sol +23 -0
  289. package/lib/openzeppelin-contracts/contracts/mocks/compound/CompTimelock.sol +174 -0
  290. package/lib/openzeppelin-contracts/contracts/mocks/crosschain/ERC7786GatewayMock.sol +56 -0
  291. package/lib/openzeppelin-contracts/contracts/mocks/crosschain/ERC7786RecipientMock.sol +31 -0
  292. package/lib/openzeppelin-contracts/contracts/mocks/docs/AccessManagerEnumerable.sol +161 -0
  293. package/lib/openzeppelin-contracts/contracts/mocks/docs/ERC20WithAutoMinerReward.sol +22 -0
  294. package/lib/openzeppelin-contracts/contracts/mocks/docs/ERC4626Fees.sol +109 -0
  295. package/lib/openzeppelin-contracts/contracts/mocks/docs/MyNFT.sol +9 -0
  296. package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintBase.sol +25 -0
  297. package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintMissing.sol +24 -0
  298. package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintOnlyRole.sol +23 -0
  299. package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlModified.sol +14 -0
  300. package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessManagedERC20MintBase.sol +16 -0
  301. package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/MyContractOwnable.sol +17 -0
  302. package/lib/openzeppelin-contracts/contracts/mocks/docs/account/MyAccountEIP7702.sol +20 -0
  303. package/lib/openzeppelin-contracts/contracts/mocks/docs/account/MyFactoryAccount.sol +37 -0
  304. package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyGovernor.sol +80 -0
  305. package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyToken.sol +21 -0
  306. package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenTimestampBased.sol +32 -0
  307. package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenWrapped.sol +28 -0
  308. package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC1155/GameItems.sol +21 -0
  309. package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC1155/MyERC115HolderContract.sol +7 -0
  310. package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC20/GLDToken.sol +11 -0
  311. package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC6909/ERC6909GameItems.sol +26 -0
  312. package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC721/GameItem.sol +19 -0
  313. package/lib/openzeppelin-contracts/contracts/mocks/docs/utilities/Base64NFT.sol +27 -0
  314. package/lib/openzeppelin-contracts/contracts/mocks/docs/utilities/Multicall.sol +15 -0
  315. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorCountingOverridableMock.sol +18 -0
  316. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorFractionalMock.sol +14 -0
  317. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorMock.sol +14 -0
  318. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorNoncesKeyedMock.sol +44 -0
  319. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorPreventLateQuorumMock.sol +40 -0
  320. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorProposalGuardianMock.sol +27 -0
  321. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorSequentialProposalIdMock.sol +39 -0
  322. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorStorageMock.sol +79 -0
  323. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorSuperQuorumMock.sol +95 -0
  324. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockAccessMock.sol +70 -0
  325. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockCompoundMock.sol +69 -0
  326. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockControlMock.sol +69 -0
  327. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorVoteMock.sol +20 -0
  328. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorVotesSuperQuorumFractionMock.sol +37 -0
  329. package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorWithParamsMock.sol +51 -0
  330. package/lib/openzeppelin-contracts/contracts/mocks/proxy/BadBeacon.sol +11 -0
  331. package/lib/openzeppelin-contracts/contracts/mocks/proxy/ClashingImplementation.sol +19 -0
  332. package/lib/openzeppelin-contracts/contracts/mocks/proxy/ERC1967ProxyUnsafe.sol +13 -0
  333. package/lib/openzeppelin-contracts/contracts/mocks/proxy/UUPSUpgradeableMock.sol +35 -0
  334. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1155ReceiverMock.sol +74 -0
  335. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363ForceApproveMock.sol +13 -0
  336. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363NoReturnMock.sol +33 -0
  337. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363ReceiverMock.sol +52 -0
  338. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363ReturnFalseMock.sol +34 -0
  339. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363SpenderMock.sol +47 -0
  340. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ApprovalMock.sol +10 -0
  341. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20BridgeableMock.sol +30 -0
  342. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20DecimalsMock.sol +17 -0
  343. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ExcessDecimalsMock.sol +9 -0
  344. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20FlashMintMock.sol +26 -0
  345. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ForceApproveMock.sol +13 -0
  346. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20GetterHelper.sol +38 -0
  347. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20Mock.sol +16 -0
  348. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20MulticallMock.sol +8 -0
  349. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20NoReturnMock.sol +30 -0
  350. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20Reentrant.sol +39 -0
  351. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ReturnFalseMock.sol +19 -0
  352. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20VotesAdditionalCheckpointsMock.sol +31 -0
  353. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20VotesLegacyMock.sol +253 -0
  354. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20VotesTimestampMock.sol +29 -0
  355. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC4626LimitsMock.sol +23 -0
  356. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC4626Mock.sol +17 -0
  357. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC4626OffsetMock.sol +17 -0
  358. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC4646FeesMock.sol +40 -0
  359. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ConsecutiveEnumerableMock.sol +42 -0
  360. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ConsecutiveMock.sol +61 -0
  361. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ReceiverMock.sol +47 -0
  362. package/lib/openzeppelin-contracts/contracts/mocks/token/ERC721URIStorageMock.sol +17 -0
  363. package/lib/openzeppelin-contracts/contracts/mocks/utils/cryptography/ERC7739Mock.sol +12 -0
  364. package/lib/openzeppelin-contracts/contracts/package.json +32 -0
  365. package/lib/openzeppelin-contracts/contracts/proxy/Clones.sol +294 -0
  366. package/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Proxy.sol +62 -0
  367. package/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Utils.sol +177 -0
  368. package/lib/openzeppelin-contracts/contracts/proxy/Proxy.sol +69 -0
  369. package/lib/openzeppelin-contracts/contracts/proxy/README.adoc +87 -0
  370. package/lib/openzeppelin-contracts/contracts/proxy/beacon/BeaconProxy.sol +57 -0
  371. package/lib/openzeppelin-contracts/contracts/proxy/beacon/IBeacon.sol +16 -0
  372. package/lib/openzeppelin-contracts/contracts/proxy/beacon/UpgradeableBeacon.sol +70 -0
  373. package/lib/openzeppelin-contracts/contracts/proxy/transparent/ProxyAdmin.sol +45 -0
  374. package/lib/openzeppelin-contracts/contracts/proxy/transparent/TransparentUpgradeableProxy.sol +118 -0
  375. package/lib/openzeppelin-contracts/contracts/proxy/utils/Initializable.sol +238 -0
  376. package/lib/openzeppelin-contracts/contracts/proxy/utils/UUPSUpgradeable.sol +148 -0
  377. package/lib/openzeppelin-contracts/contracts/token/ERC1155/ERC1155.sol +416 -0
  378. package/lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155.sol +123 -0
  379. package/lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155Receiver.sol +59 -0
  380. package/lib/openzeppelin-contracts/contracts/token/ERC1155/README.adoc +43 -0
  381. package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Burnable.sol +28 -0
  382. package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Pausable.sol +38 -0
  383. package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Supply.sol +88 -0
  384. package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155URIStorage.sol +58 -0
  385. package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/IERC1155MetadataURI.sol +20 -0
  386. package/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Holder.sol +42 -0
  387. package/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Utils.sol +88 -0
  388. package/lib/openzeppelin-contracts/contracts/token/ERC20/ERC20.sol +305 -0
  389. package/lib/openzeppelin-contracts/contracts/token/ERC20/IERC20.sol +79 -0
  390. package/lib/openzeppelin-contracts/contracts/token/ERC20/README.adoc +81 -0
  391. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC1363.sol +135 -0
  392. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Burnable.sol +39 -0
  393. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Capped.sol +54 -0
  394. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Crosschain.sol +38 -0
  395. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20FlashMint.sol +130 -0
  396. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Pausable.sol +33 -0
  397. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Permit.sol +77 -0
  398. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Votes.sol +83 -0
  399. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Wrapper.sol +89 -0
  400. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC4626.sol +315 -0
  401. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Metadata.sol +26 -0
  402. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Permit.sol +90 -0
  403. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-ERC20Bridgeable.sol +51 -0
  404. package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-ERC20TemporaryApproval.sol +119 -0
  405. package/lib/openzeppelin-contracts/contracts/token/ERC20/utils/ERC1363Utils.sol +95 -0
  406. package/lib/openzeppelin-contracts/contracts/token/ERC20/utils/SafeERC20.sol +280 -0
  407. package/lib/openzeppelin-contracts/contracts/token/ERC6909/ERC6909.sol +224 -0
  408. package/lib/openzeppelin-contracts/contracts/token/ERC6909/README.adoc +27 -0
  409. package/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/ERC6909ContentURI.sol +59 -0
  410. package/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/ERC6909Metadata.sol +83 -0
  411. package/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/ERC6909TokenSupply.sol +41 -0
  412. package/lib/openzeppelin-contracts/contracts/token/ERC721/ERC721.sol +433 -0
  413. package/lib/openzeppelin-contracts/contracts/token/ERC721/IERC721.sol +135 -0
  414. package/lib/openzeppelin-contracts/contracts/token/ERC721/IERC721Receiver.sol +28 -0
  415. package/lib/openzeppelin-contracts/contracts/token/ERC721/README.adoc +69 -0
  416. package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Burnable.sol +26 -0
  417. package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Consecutive.sol +176 -0
  418. package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Enumerable.sol +165 -0
  419. package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Pausable.sol +37 -0
  420. package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Royalty.sol +26 -0
  421. package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721URIStorage.sol +62 -0
  422. package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Votes.sol +47 -0
  423. package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Wrapper.sol +102 -0
  424. package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/IERC721Enumerable.sol +29 -0
  425. package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/IERC721Metadata.sol +27 -0
  426. package/lib/openzeppelin-contracts/contracts/token/ERC721/utils/ERC721Holder.sol +26 -0
  427. package/lib/openzeppelin-contracts/contracts/token/ERC721/utils/ERC721Utils.sol +50 -0
  428. package/lib/openzeppelin-contracts/contracts/token/common/ERC2981.sol +139 -0
  429. package/lib/openzeppelin-contracts/contracts/token/common/README.adoc +10 -0
  430. package/lib/openzeppelin-contracts/contracts/utils/Address.sol +167 -0
  431. package/lib/openzeppelin-contracts/contracts/utils/Arrays.sol +888 -0
  432. package/lib/openzeppelin-contracts/contracts/utils/Base58.sol +240 -0
  433. package/lib/openzeppelin-contracts/contracts/utils/Base64.sol +234 -0
  434. package/lib/openzeppelin-contracts/contracts/utils/Blockhash.sol +54 -0
  435. package/lib/openzeppelin-contracts/contracts/utils/Bytes.sol +332 -0
  436. package/lib/openzeppelin-contracts/contracts/utils/CAIP10.sol +54 -0
  437. package/lib/openzeppelin-contracts/contracts/utils/CAIP2.sol +51 -0
  438. package/lib/openzeppelin-contracts/contracts/utils/Calldata.sol +25 -0
  439. package/lib/openzeppelin-contracts/contracts/utils/Comparators.sol +19 -0
  440. package/lib/openzeppelin-contracts/contracts/utils/Context.sol +28 -0
  441. package/lib/openzeppelin-contracts/contracts/utils/Create2.sol +91 -0
  442. package/lib/openzeppelin-contracts/contracts/utils/Errors.sol +34 -0
  443. package/lib/openzeppelin-contracts/contracts/utils/LowLevelCall.sol +127 -0
  444. package/lib/openzeppelin-contracts/contracts/utils/Memory.sol +146 -0
  445. package/lib/openzeppelin-contracts/contracts/utils/Multicall.sol +37 -0
  446. package/lib/openzeppelin-contracts/contracts/utils/Nonces.sol +46 -0
  447. package/lib/openzeppelin-contracts/contracts/utils/NoncesKeyed.sol +74 -0
  448. package/lib/openzeppelin-contracts/contracts/utils/Packing.sol +1656 -0
  449. package/lib/openzeppelin-contracts/contracts/utils/Panic.sol +57 -0
  450. package/lib/openzeppelin-contracts/contracts/utils/Pausable.sol +112 -0
  451. package/lib/openzeppelin-contracts/contracts/utils/README.adoc +160 -0
  452. package/lib/openzeppelin-contracts/contracts/utils/RLP.sol +476 -0
  453. package/lib/openzeppelin-contracts/contracts/utils/ReentrancyGuard.sol +119 -0
  454. package/lib/openzeppelin-contracts/contracts/utils/ReentrancyGuardTransient.sol +84 -0
  455. package/lib/openzeppelin-contracts/contracts/utils/RelayedCall.sol +133 -0
  456. package/lib/openzeppelin-contracts/contracts/utils/ShortStrings.sol +122 -0
  457. package/lib/openzeppelin-contracts/contracts/utils/SlotDerivation.sol +155 -0
  458. package/lib/openzeppelin-contracts/contracts/utils/StorageSlot.sol +143 -0
  459. package/lib/openzeppelin-contracts/contracts/utils/Strings.sol +508 -0
  460. package/lib/openzeppelin-contracts/contracts/utils/TransientSlot.sol +183 -0
  461. package/lib/openzeppelin-contracts/contracts/utils/cryptography/ECDSA.sol +284 -0
  462. package/lib/openzeppelin-contracts/contracts/utils/cryptography/EIP712.sol +160 -0
  463. package/lib/openzeppelin-contracts/contracts/utils/cryptography/Hashes.sol +31 -0
  464. package/lib/openzeppelin-contracts/contracts/utils/cryptography/MerkleProof.sol +510 -0
  465. package/lib/openzeppelin-contracts/contracts/utils/cryptography/MessageHashUtils.sol +228 -0
  466. package/lib/openzeppelin-contracts/contracts/utils/cryptography/P256.sol +408 -0
  467. package/lib/openzeppelin-contracts/contracts/utils/cryptography/README.adoc +76 -0
  468. package/lib/openzeppelin-contracts/contracts/utils/cryptography/RSA.sol +154 -0
  469. package/lib/openzeppelin-contracts/contracts/utils/cryptography/SignatureChecker.sol +191 -0
  470. package/lib/openzeppelin-contracts/contracts/utils/cryptography/TrieProof.sol +230 -0
  471. package/lib/openzeppelin-contracts/contracts/utils/cryptography/WebAuthn.sol +261 -0
  472. package/lib/openzeppelin-contracts/contracts/utils/cryptography/draft-ERC7739Utils.sol +207 -0
  473. package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/AbstractSigner.sol +23 -0
  474. package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/MultiSignerERC7913.sol +259 -0
  475. package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/MultiSignerERC7913Weighted.sol +208 -0
  476. package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerECDSA.sol +56 -0
  477. package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerEIP7702.sol +25 -0
  478. package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerERC7913.sol +63 -0
  479. package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerP256.sol +64 -0
  480. package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerRSA.sol +65 -0
  481. package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerWebAuthn.sol +51 -0
  482. package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/draft-ERC7739.sol +98 -0
  483. package/lib/openzeppelin-contracts/contracts/utils/cryptography/verifiers/ERC7913P256Verifier.sol +29 -0
  484. package/lib/openzeppelin-contracts/contracts/utils/cryptography/verifiers/ERC7913RSAVerifier.sol +23 -0
  485. package/lib/openzeppelin-contracts/contracts/utils/cryptography/verifiers/ERC7913WebAuthnVerifier.sol +35 -0
  486. package/lib/openzeppelin-contracts/contracts/utils/draft-InteroperableAddress.sol +235 -0
  487. package/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165.sol +25 -0
  488. package/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165Checker.sol +142 -0
  489. package/lib/openzeppelin-contracts/contracts/utils/introspection/IERC165.sol +25 -0
  490. package/lib/openzeppelin-contracts/contracts/utils/math/Math.sol +763 -0
  491. package/lib/openzeppelin-contracts/contracts/utils/math/SafeCast.sol +1162 -0
  492. package/lib/openzeppelin-contracts/contracts/utils/math/SignedMath.sol +68 -0
  493. package/lib/openzeppelin-contracts/contracts/utils/structs/Accumulators.sol +130 -0
  494. package/lib/openzeppelin-contracts/contracts/utils/structs/BitMaps.sol +60 -0
  495. package/lib/openzeppelin-contracts/contracts/utils/structs/Checkpoints.sol +833 -0
  496. package/lib/openzeppelin-contracts/contracts/utils/structs/CircularBuffer.sol +152 -0
  497. package/lib/openzeppelin-contracts/contracts/utils/structs/DoubleEndedQueue.sol +237 -0
  498. package/lib/openzeppelin-contracts/contracts/utils/structs/EnumerableMap.sol +1443 -0
  499. package/lib/openzeppelin-contracts/contracts/utils/structs/EnumerableSet.sol +895 -0
  500. package/lib/openzeppelin-contracts/contracts/utils/structs/Heap.sol +259 -0
  501. package/lib/openzeppelin-contracts/contracts/utils/structs/MerkleTree.sol +267 -0
  502. package/lib/openzeppelin-contracts/contracts/utils/types/Time.sol +133 -0
  503. package/lib/openzeppelin-contracts/contracts/vendor/compound/ICompoundTimelock.sol +86 -0
  504. package/lib/openzeppelin-contracts/contracts/vendor/compound/LICENSE +11 -0
  505. package/lib/openzeppelin-contracts/docs/README.md +16 -0
  506. package/lib/openzeppelin-contracts/docs/antora.yml +7 -0
  507. package/lib/openzeppelin-contracts/docs/config.js +21 -0
  508. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-control-multiple.svg +97 -0
  509. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-manager-functions.svg +47 -0
  510. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-manager.svg +99 -0
  511. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3a.png +0 -0
  512. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3b.png +0 -0
  513. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-6.png +0 -0
  514. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack.png +0 -0
  515. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-deposit.png +0 -0
  516. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-mint.png +0 -0
  517. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-linear.png +0 -0
  518. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglog.png +0 -0
  519. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglogext.png +0 -0
  520. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-exec.png +0 -0
  521. package/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-vote.png +0 -0
  522. package/lib/openzeppelin-contracts/docs/modules/ROOT/nav.adoc +29 -0
  523. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/access-control.adoc +339 -0
  524. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/account-abstraction.adoc +100 -0
  525. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/accounts.adoc +354 -0
  526. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/backwards-compatibility.adoc +50 -0
  527. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/eoa-delegation.adoc +143 -0
  528. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc1155.adoc +118 -0
  529. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20-supply.adoc +71 -0
  530. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20.adoc +67 -0
  531. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc4626.adoc +214 -0
  532. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc6909.adoc +47 -0
  533. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc721.adoc +58 -0
  534. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/extending-contracts.adoc +51 -0
  535. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/faq.adoc +13 -0
  536. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/governance.adoc +242 -0
  537. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/index.adoc +100 -0
  538. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/multisig.adoc +308 -0
  539. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/tokens.adoc +31 -0
  540. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/upgradeable.adoc +77 -0
  541. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/utilities.adoc +634 -0
  542. package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/wizard.adoc +15 -0
  543. package/lib/openzeppelin-contracts/docs/templates/contract.hbs +141 -0
  544. package/lib/openzeppelin-contracts/docs/templates/helpers.js +46 -0
  545. package/lib/openzeppelin-contracts/docs/templates/page.hbs +4 -0
  546. package/lib/openzeppelin-contracts/docs/templates/properties.js +88 -0
  547. package/lib/openzeppelin-contracts/eslint.config.mjs +29 -0
  548. package/lib/openzeppelin-contracts/foundry.toml +20 -0
  549. package/lib/openzeppelin-contracts/fv/Makefile +54 -0
  550. package/lib/openzeppelin-contracts/fv/README.md +60 -0
  551. package/lib/openzeppelin-contracts/fv/diff/access_manager_AccessManager.sol.patch +97 -0
  552. package/lib/openzeppelin-contracts/fv/diff/account_extensions_draft-AccountERC7579.sol.patch +25 -0
  553. package/lib/openzeppelin-contracts/fv/diff/token_ERC721_ERC721.sol.patch +11 -0
  554. package/lib/openzeppelin-contracts/fv/harnesses/AccessControlDefaultAdminRulesHarness.sol +46 -0
  555. package/lib/openzeppelin-contracts/fv/harnesses/AccessControlHarness.sol +6 -0
  556. package/lib/openzeppelin-contracts/fv/harnesses/AccessManagedHarness.sol +36 -0
  557. package/lib/openzeppelin-contracts/fv/harnesses/AccessManagerHarness.sol +116 -0
  558. package/lib/openzeppelin-contracts/fv/harnesses/AccountHarness.sol +60 -0
  559. package/lib/openzeppelin-contracts/fv/harnesses/DoubleEndedQueueHarness.sol +58 -0
  560. package/lib/openzeppelin-contracts/fv/harnesses/ERC20FlashMintHarness.sol +36 -0
  561. package/lib/openzeppelin-contracts/fv/harnesses/ERC20PermitHarness.sol +16 -0
  562. package/lib/openzeppelin-contracts/fv/harnesses/ERC20WrapperHarness.sol +22 -0
  563. package/lib/openzeppelin-contracts/fv/harnesses/ERC3156FlashBorrowerHarness.sol +13 -0
  564. package/lib/openzeppelin-contracts/fv/harnesses/ERC721Harness.sol +37 -0
  565. package/lib/openzeppelin-contracts/fv/harnesses/ERC721ReceiverHarness.sol +11 -0
  566. package/lib/openzeppelin-contracts/fv/harnesses/EnumerableMapHarness.sol +55 -0
  567. package/lib/openzeppelin-contracts/fv/harnesses/EnumerableSetHarness.sol +35 -0
  568. package/lib/openzeppelin-contracts/fv/harnesses/InitializableHarness.sol +23 -0
  569. package/lib/openzeppelin-contracts/fv/harnesses/NoncesHarness.sol +14 -0
  570. package/lib/openzeppelin-contracts/fv/harnesses/Ownable2StepHarness.sol +10 -0
  571. package/lib/openzeppelin-contracts/fv/harnesses/OwnableHarness.sol +10 -0
  572. package/lib/openzeppelin-contracts/fv/harnesses/PausableHarness.sol +18 -0
  573. package/lib/openzeppelin-contracts/fv/harnesses/TimelockControllerHarness.sol +13 -0
  574. package/lib/openzeppelin-contracts/fv/reports/2021-10.pdf +0 -0
  575. package/lib/openzeppelin-contracts/fv/reports/2022-03.pdf +0 -0
  576. package/lib/openzeppelin-contracts/fv/reports/2022-05.pdf +0 -0
  577. package/lib/openzeppelin-contracts/fv/run.js +68 -0
  578. package/lib/openzeppelin-contracts/fv/specs/AccessControl.conf +8 -0
  579. package/lib/openzeppelin-contracts/fv/specs/AccessControl.spec +119 -0
  580. package/lib/openzeppelin-contracts/fv/specs/AccessControlDefaultAdminRules.conf +8 -0
  581. package/lib/openzeppelin-contracts/fv/specs/AccessControlDefaultAdminRules.spec +467 -0
  582. package/lib/openzeppelin-contracts/fv/specs/AccessManaged.conf +14 -0
  583. package/lib/openzeppelin-contracts/fv/specs/AccessManaged.spec +49 -0
  584. package/lib/openzeppelin-contracts/fv/specs/AccessManager.conf +10 -0
  585. package/lib/openzeppelin-contracts/fv/specs/AccessManager.spec +837 -0
  586. package/lib/openzeppelin-contracts/fv/specs/Account.conf +9 -0
  587. package/lib/openzeppelin-contracts/fv/specs/Account.spec +490 -0
  588. package/lib/openzeppelin-contracts/fv/specs/DoubleEndedQueue.conf +8 -0
  589. package/lib/openzeppelin-contracts/fv/specs/DoubleEndedQueue.spec +300 -0
  590. package/lib/openzeppelin-contracts/fv/specs/ERC20.conf +9 -0
  591. package/lib/openzeppelin-contracts/fv/specs/ERC20.spec +352 -0
  592. package/lib/openzeppelin-contracts/fv/specs/ERC20FlashMint.conf +10 -0
  593. package/lib/openzeppelin-contracts/fv/specs/ERC20FlashMint.spec +55 -0
  594. package/lib/openzeppelin-contracts/fv/specs/ERC20Wrapper.conf +13 -0
  595. package/lib/openzeppelin-contracts/fv/specs/ERC20Wrapper.spec +226 -0
  596. package/lib/openzeppelin-contracts/fv/specs/ERC721.conf +10 -0
  597. package/lib/openzeppelin-contracts/fv/specs/ERC721.spec +695 -0
  598. package/lib/openzeppelin-contracts/fv/specs/EnumerableMap.conf +8 -0
  599. package/lib/openzeppelin-contracts/fv/specs/EnumerableMap.spec +364 -0
  600. package/lib/openzeppelin-contracts/fv/specs/EnumerableSet.conf +8 -0
  601. package/lib/openzeppelin-contracts/fv/specs/EnumerableSet.spec +272 -0
  602. package/lib/openzeppelin-contracts/fv/specs/Initializable.conf +8 -0
  603. package/lib/openzeppelin-contracts/fv/specs/Initializable.spec +176 -0
  604. package/lib/openzeppelin-contracts/fv/specs/Nonces.conf +8 -0
  605. package/lib/openzeppelin-contracts/fv/specs/Nonces.spec +92 -0
  606. package/lib/openzeppelin-contracts/fv/specs/Ownable.conf +8 -0
  607. package/lib/openzeppelin-contracts/fv/specs/Ownable.spec +77 -0
  608. package/lib/openzeppelin-contracts/fv/specs/Ownable2Step.conf +8 -0
  609. package/lib/openzeppelin-contracts/fv/specs/Ownable2Step.spec +108 -0
  610. package/lib/openzeppelin-contracts/fv/specs/Pausable.conf +8 -0
  611. package/lib/openzeppelin-contracts/fv/specs/Pausable.spec +96 -0
  612. package/lib/openzeppelin-contracts/fv/specs/TimelockController.conf +10 -0
  613. package/lib/openzeppelin-contracts/fv/specs/TimelockController.spec +299 -0
  614. package/lib/openzeppelin-contracts/fv/specs/helpers/helpers.spec +13 -0
  615. package/lib/openzeppelin-contracts/fv/specs/methods/IAccessControl.spec +8 -0
  616. package/lib/openzeppelin-contracts/fv/specs/methods/IAccessControlDefaultAdminRules.spec +36 -0
  617. package/lib/openzeppelin-contracts/fv/specs/methods/IAccessManaged.spec +5 -0
  618. package/lib/openzeppelin-contracts/fv/specs/methods/IAccessManager.spec +33 -0
  619. package/lib/openzeppelin-contracts/fv/specs/methods/IAccount.spec +34 -0
  620. package/lib/openzeppelin-contracts/fv/specs/methods/IERC20.spec +11 -0
  621. package/lib/openzeppelin-contracts/fv/specs/methods/IERC2612.spec +5 -0
  622. package/lib/openzeppelin-contracts/fv/specs/methods/IERC3156FlashBorrower.spec +3 -0
  623. package/lib/openzeppelin-contracts/fv/specs/methods/IERC3156FlashLender.spec +5 -0
  624. package/lib/openzeppelin-contracts/fv/specs/methods/IERC5313.spec +3 -0
  625. package/lib/openzeppelin-contracts/fv/specs/methods/IERC721.spec +17 -0
  626. package/lib/openzeppelin-contracts/fv/specs/methods/IERC721Receiver.spec +3 -0
  627. package/lib/openzeppelin-contracts/fv/specs/methods/IOwnable.spec +5 -0
  628. package/lib/openzeppelin-contracts/fv/specs/methods/IOwnable2Step.spec +7 -0
  629. package/lib/openzeppelin-contracts/fv-requirements.txt +4 -0
  630. package/lib/openzeppelin-contracts/hardhat/async-test-sanity.js +10 -0
  631. package/lib/openzeppelin-contracts/hardhat/env-artifacts.js +29 -0
  632. package/lib/openzeppelin-contracts/hardhat/ignore-unreachable-warnings.js +45 -0
  633. package/lib/openzeppelin-contracts/hardhat/remappings.js +18 -0
  634. package/lib/openzeppelin-contracts/hardhat/skip-foundry-tests.js +6 -0
  635. package/lib/openzeppelin-contracts/hardhat/task-test-get-files.js +25 -0
  636. package/lib/openzeppelin-contracts/hardhat.config.js +124 -0
  637. package/lib/openzeppelin-contracts/logo.svg +15 -0
  638. package/lib/openzeppelin-contracts/netlify.toml +3 -0
  639. package/lib/openzeppelin-contracts/package-lock.json +11140 -0
  640. package/lib/openzeppelin-contracts/package.json +108 -0
  641. package/lib/openzeppelin-contracts/remappings.txt +1 -0
  642. package/lib/openzeppelin-contracts/renovate.json +4 -0
  643. package/lib/openzeppelin-contracts/scripts/checks/compare-layout.js +28 -0
  644. package/lib/openzeppelin-contracts/scripts/checks/compareGasReports.js +249 -0
  645. package/lib/openzeppelin-contracts/scripts/checks/coverage.sh +24 -0
  646. package/lib/openzeppelin-contracts/scripts/checks/extract-layout.js +39 -0
  647. package/lib/openzeppelin-contracts/scripts/checks/generation.sh +6 -0
  648. package/lib/openzeppelin-contracts/scripts/checks/inheritance-ordering.js +55 -0
  649. package/lib/openzeppelin-contracts/scripts/checks/pragma-validity.js +45 -0
  650. package/lib/openzeppelin-contracts/scripts/fetch-common-contracts.js +50 -0
  651. package/lib/openzeppelin-contracts/scripts/gen-nav.js +81 -0
  652. package/lib/openzeppelin-contracts/scripts/generate/format-lines.js +16 -0
  653. package/lib/openzeppelin-contracts/scripts/generate/helpers/sanitize.js +5 -0
  654. package/lib/openzeppelin-contracts/scripts/generate/run.js +61 -0
  655. package/lib/openzeppelin-contracts/scripts/generate/templates/Arrays.js +505 -0
  656. package/lib/openzeppelin-contracts/scripts/generate/templates/Arrays.opts.js +9 -0
  657. package/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.js +242 -0
  658. package/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.opts.js +18 -0
  659. package/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.t.js +141 -0
  660. package/lib/openzeppelin-contracts/scripts/generate/templates/Enumerable.opts.js +56 -0
  661. package/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableMap.js +464 -0
  662. package/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableSet.js +470 -0
  663. package/lib/openzeppelin-contracts/scripts/generate/templates/MerkleProof.js +186 -0
  664. package/lib/openzeppelin-contracts/scripts/generate/templates/MerkleProof.opts.js +11 -0
  665. package/lib/openzeppelin-contracts/scripts/generate/templates/Packing.js +92 -0
  666. package/lib/openzeppelin-contracts/scripts/generate/templates/Packing.opts.js +3 -0
  667. package/lib/openzeppelin-contracts/scripts/generate/templates/Packing.t.js +48 -0
  668. package/lib/openzeppelin-contracts/scripts/generate/templates/SafeCast.js +136 -0
  669. package/lib/openzeppelin-contracts/scripts/generate/templates/Slot.opts.js +15 -0
  670. package/lib/openzeppelin-contracts/scripts/generate/templates/SlotDerivation.js +119 -0
  671. package/lib/openzeppelin-contracts/scripts/generate/templates/SlotDerivation.t.js +127 -0
  672. package/lib/openzeppelin-contracts/scripts/generate/templates/StorageSlot.js +77 -0
  673. package/lib/openzeppelin-contracts/scripts/generate/templates/StorageSlotMock.js +57 -0
  674. package/lib/openzeppelin-contracts/scripts/generate/templates/TransientSlot.js +80 -0
  675. package/lib/openzeppelin-contracts/scripts/generate/templates/TransientSlotMock.js +35 -0
  676. package/lib/openzeppelin-contracts/scripts/generate/templates/conversion.js +34 -0
  677. package/lib/openzeppelin-contracts/scripts/get-contracts-metadata.js +55 -0
  678. package/lib/openzeppelin-contracts/scripts/git-user-config.sh +6 -0
  679. package/lib/openzeppelin-contracts/scripts/helpers.js +7 -0
  680. package/lib/openzeppelin-contracts/scripts/minimize-pragma.js +140 -0
  681. package/lib/openzeppelin-contracts/scripts/prepack.sh +23 -0
  682. package/lib/openzeppelin-contracts/scripts/prepare-docs.sh +26 -0
  683. package/lib/openzeppelin-contracts/scripts/release/format-changelog.js +33 -0
  684. package/lib/openzeppelin-contracts/scripts/release/synchronize-versions.js +15 -0
  685. package/lib/openzeppelin-contracts/scripts/release/update-comment.js +34 -0
  686. package/lib/openzeppelin-contracts/scripts/release/version.sh +11 -0
  687. package/lib/openzeppelin-contracts/scripts/release/workflow/check-upgradeable.sh +27 -0
  688. package/lib/openzeppelin-contracts/scripts/release/workflow/exit-prerelease.sh +8 -0
  689. package/lib/openzeppelin-contracts/scripts/release/workflow/github-release.js +48 -0
  690. package/lib/openzeppelin-contracts/scripts/release/workflow/integrity-check.sh +20 -0
  691. package/lib/openzeppelin-contracts/scripts/release/workflow/pack.sh +26 -0
  692. package/lib/openzeppelin-contracts/scripts/release/workflow/publish.sh +26 -0
  693. package/lib/openzeppelin-contracts/scripts/release/workflow/rerun.js +7 -0
  694. package/lib/openzeppelin-contracts/scripts/release/workflow/set-changesets-pr-title.js +17 -0
  695. package/lib/openzeppelin-contracts/scripts/release/workflow/start.sh +35 -0
  696. package/lib/openzeppelin-contracts/scripts/release/workflow/state.js +112 -0
  697. package/lib/openzeppelin-contracts/scripts/remove-ignored-artifacts.js +45 -0
  698. package/lib/openzeppelin-contracts/scripts/set-max-old-space-size.sh +10 -0
  699. package/lib/openzeppelin-contracts/scripts/solc-versions.js +15 -0
  700. package/lib/openzeppelin-contracts/scripts/solhint-custom/index.js +118 -0
  701. package/lib/openzeppelin-contracts/scripts/solhint-custom/package.json +8 -0
  702. package/lib/openzeppelin-contracts/scripts/update-docs-branch.js +65 -0
  703. package/lib/openzeppelin-contracts/scripts/upgradeable/README.md +21 -0
  704. package/lib/openzeppelin-contracts/scripts/upgradeable/alias/Initializable.sol +5 -0
  705. package/lib/openzeppelin-contracts/scripts/upgradeable/alias/UUPSUpgradeable.sol +5 -0
  706. package/lib/openzeppelin-contracts/scripts/upgradeable/patch-apply.sh +19 -0
  707. package/lib/openzeppelin-contracts/scripts/upgradeable/patch-save.sh +18 -0
  708. package/lib/openzeppelin-contracts/scripts/upgradeable/transpile-onto.sh +54 -0
  709. package/lib/openzeppelin-contracts/scripts/upgradeable/transpile.sh +50 -0
  710. package/lib/openzeppelin-contracts/scripts/upgradeable/upgradeable.patch +390 -0
  711. package/lib/openzeppelin-contracts/slither.config.json +4 -0
  712. package/lib/openzeppelin-contracts/solhint.config.js +29 -0
  713. package/lib/openzeppelin-contracts/test/TESTING.md +3 -0
  714. package/lib/openzeppelin-contracts/test/access/AccessControl.behavior.js +874 -0
  715. package/lib/openzeppelin-contracts/test/access/AccessControl.test.js +19 -0
  716. package/lib/openzeppelin-contracts/test/access/Ownable.test.js +79 -0
  717. package/lib/openzeppelin-contracts/test/access/Ownable2Step.test.js +102 -0
  718. package/lib/openzeppelin-contracts/test/access/extensions/AccessControlDefaultAdminRules.test.js +32 -0
  719. package/lib/openzeppelin-contracts/test/access/extensions/AccessControlEnumerable.test.js +24 -0
  720. package/lib/openzeppelin-contracts/test/access/manager/AccessManaged.test.js +146 -0
  721. package/lib/openzeppelin-contracts/test/access/manager/AccessManager.behavior.js +257 -0
  722. package/lib/openzeppelin-contracts/test/access/manager/AccessManager.predicate.js +456 -0
  723. package/lib/openzeppelin-contracts/test/access/manager/AccessManager.test.js +2489 -0
  724. package/lib/openzeppelin-contracts/test/access/manager/AuthorityUtils.test.js +112 -0
  725. package/lib/openzeppelin-contracts/test/account/Account.behavior.js +144 -0
  726. package/lib/openzeppelin-contracts/test/account/Account.test.js +48 -0
  727. package/lib/openzeppelin-contracts/test/account/AccountECDSA.test.js +52 -0
  728. package/lib/openzeppelin-contracts/test/account/AccountEIP7702.t.sol +116 -0
  729. package/lib/openzeppelin-contracts/test/account/AccountEIP7702.test.js +52 -0
  730. package/lib/openzeppelin-contracts/test/account/AccountERC7913.test.js +138 -0
  731. package/lib/openzeppelin-contracts/test/account/AccountMultiSigner.test.js +326 -0
  732. package/lib/openzeppelin-contracts/test/account/AccountMultiSignerWeighted.test.js +312 -0
  733. package/lib/openzeppelin-contracts/test/account/AccountP256.test.js +58 -0
  734. package/lib/openzeppelin-contracts/test/account/AccountRSA.test.js +58 -0
  735. package/lib/openzeppelin-contracts/test/account/AccountWebAuthn.test.js +88 -0
  736. package/lib/openzeppelin-contracts/test/account/examples/AccountEIP7702WithModulesMock.test.js +99 -0
  737. package/lib/openzeppelin-contracts/test/account/extensions/AccountERC7579.behavior.js +621 -0
  738. package/lib/openzeppelin-contracts/test/account/extensions/AccountERC7579.test.js +60 -0
  739. package/lib/openzeppelin-contracts/test/account/extensions/AccountERC7579Hooked.test.js +60 -0
  740. package/lib/openzeppelin-contracts/test/account/extensions/ERC7821.behavior.js +145 -0
  741. package/lib/openzeppelin-contracts/test/account/utils/EIP7702Utils.test.js +53 -0
  742. package/lib/openzeppelin-contracts/test/account/utils/draft-ERC4337Utils.test.js +594 -0
  743. package/lib/openzeppelin-contracts/test/account/utils/draft-ERC7579Utils.t.sol +434 -0
  744. package/lib/openzeppelin-contracts/test/account/utils/draft-ERC7579Utils.test.js +399 -0
  745. package/lib/openzeppelin-contracts/test/crosschain/BridgeERC20.behavior.js +163 -0
  746. package/lib/openzeppelin-contracts/test/crosschain/BridgeERC20.test.js +46 -0
  747. package/lib/openzeppelin-contracts/test/crosschain/ERC7786Recipient.test.js +73 -0
  748. package/lib/openzeppelin-contracts/test/finance/VestingWallet.behavior.js +87 -0
  749. package/lib/openzeppelin-contracts/test/finance/VestingWallet.test.js +65 -0
  750. package/lib/openzeppelin-contracts/test/finance/VestingWalletCliff.test.js +70 -0
  751. package/lib/openzeppelin-contracts/test/governance/Governor.t.sol +59 -0
  752. package/lib/openzeppelin-contracts/test/governance/Governor.test.js +980 -0
  753. package/lib/openzeppelin-contracts/test/governance/TimelockController.test.js +1279 -0
  754. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorCountingFractional.test.js +248 -0
  755. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorCountingOverridable.test.js +346 -0
  756. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorERC721.test.js +131 -0
  757. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorNoncesKeyed.test.js +243 -0
  758. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorPreventLateQuorum.test.js +185 -0
  759. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorProposalGuardian.test.js +132 -0
  760. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorSequentialProposalId.test.js +202 -0
  761. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorStorage.test.js +175 -0
  762. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorSuperQuorum.test.js +168 -0
  763. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorSuperQuorumGreaterThanQuorum.t.sol +83 -0
  764. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockAccess.test.js +864 -0
  765. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockCompound.test.js +448 -0
  766. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockControl.test.js +504 -0
  767. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorVotesQuorumFraction.test.js +165 -0
  768. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorVotesSuperQuorumFraction.test.js +160 -0
  769. package/lib/openzeppelin-contracts/test/governance/extensions/GovernorWithParams.test.js +245 -0
  770. package/lib/openzeppelin-contracts/test/governance/utils/ERC6372.behavior.js +28 -0
  771. package/lib/openzeppelin-contracts/test/governance/utils/Votes.behavior.js +325 -0
  772. package/lib/openzeppelin-contracts/test/governance/utils/Votes.test.js +102 -0
  773. package/lib/openzeppelin-contracts/test/governance/utils/VotesExtended.test.js +152 -0
  774. package/lib/openzeppelin-contracts/test/helpers/access-manager.js +85 -0
  775. package/lib/openzeppelin-contracts/test/helpers/account.js +16 -0
  776. package/lib/openzeppelin-contracts/test/helpers/chains.js +56 -0
  777. package/lib/openzeppelin-contracts/test/helpers/constants.js +7 -0
  778. package/lib/openzeppelin-contracts/test/helpers/deploy.js +14 -0
  779. package/lib/openzeppelin-contracts/test/helpers/eip712-types.js +61 -0
  780. package/lib/openzeppelin-contracts/test/helpers/eip712.js +45 -0
  781. package/lib/openzeppelin-contracts/test/helpers/enums.js +15 -0
  782. package/lib/openzeppelin-contracts/test/helpers/erc4337.js +244 -0
  783. package/lib/openzeppelin-contracts/test/helpers/erc7579.js +58 -0
  784. package/lib/openzeppelin-contracts/test/helpers/erc7739.js +118 -0
  785. package/lib/openzeppelin-contracts/test/helpers/governance.js +218 -0
  786. package/lib/openzeppelin-contracts/test/helpers/iterate.js +41 -0
  787. package/lib/openzeppelin-contracts/test/helpers/math.js +33 -0
  788. package/lib/openzeppelin-contracts/test/helpers/methods.js +14 -0
  789. package/lib/openzeppelin-contracts/test/helpers/precompiles.js +12 -0
  790. package/lib/openzeppelin-contracts/test/helpers/random.js +26 -0
  791. package/lib/openzeppelin-contracts/test/helpers/signers.js +222 -0
  792. package/lib/openzeppelin-contracts/test/helpers/storage.js +48 -0
  793. package/lib/openzeppelin-contracts/test/helpers/strings.js +5 -0
  794. package/lib/openzeppelin-contracts/test/helpers/time.js +33 -0
  795. package/lib/openzeppelin-contracts/test/helpers/trie.js +79 -0
  796. package/lib/openzeppelin-contracts/test/helpers/txpool.js +28 -0
  797. package/lib/openzeppelin-contracts/test/metatx/ERC2771Context.test.js +109 -0
  798. package/lib/openzeppelin-contracts/test/metatx/ERC2771Forwarder.t.sol +279 -0
  799. package/lib/openzeppelin-contracts/test/metatx/ERC2771Forwarder.test.js +384 -0
  800. package/lib/openzeppelin-contracts/test/proxy/Clones.behaviour.js +160 -0
  801. package/lib/openzeppelin-contracts/test/proxy/Clones.t.sol +91 -0
  802. package/lib/openzeppelin-contracts/test/proxy/Clones.test.js +177 -0
  803. package/lib/openzeppelin-contracts/test/proxy/ERC1967/ERC1967Proxy.test.js +36 -0
  804. package/lib/openzeppelin-contracts/test/proxy/ERC1967/ERC1967Utils.test.js +162 -0
  805. package/lib/openzeppelin-contracts/test/proxy/Proxy.behaviour.js +198 -0
  806. package/lib/openzeppelin-contracts/test/proxy/beacon/BeaconProxy.test.js +141 -0
  807. package/lib/openzeppelin-contracts/test/proxy/beacon/UpgradeableBeacon.test.js +55 -0
  808. package/lib/openzeppelin-contracts/test/proxy/transparent/ProxyAdmin.test.js +82 -0
  809. package/lib/openzeppelin-contracts/test/proxy/transparent/TransparentUpgradeableProxy.behaviour.js +367 -0
  810. package/lib/openzeppelin-contracts/test/proxy/transparent/TransparentUpgradeableProxy.test.js +28 -0
  811. package/lib/openzeppelin-contracts/test/proxy/utils/Initializable.test.js +216 -0
  812. package/lib/openzeppelin-contracts/test/proxy/utils/UUPSUpgradeable.test.js +120 -0
  813. package/lib/openzeppelin-contracts/test/sanity.test.js +27 -0
  814. package/lib/openzeppelin-contracts/test/token/ERC1155/ERC1155.behavior.js +865 -0
  815. package/lib/openzeppelin-contracts/test/token/ERC1155/ERC1155.test.js +258 -0
  816. package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Burnable.test.js +66 -0
  817. package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Pausable.test.js +105 -0
  818. package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Supply.test.js +119 -0
  819. package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155URIStorage.test.js +70 -0
  820. package/lib/openzeppelin-contracts/test/token/ERC1155/utils/ERC1155Holder.test.js +56 -0
  821. package/lib/openzeppelin-contracts/test/token/ERC1155/utils/ERC1155Utils.test.js +299 -0
  822. package/lib/openzeppelin-contracts/test/token/ERC20/ERC20.behavior.js +269 -0
  823. package/lib/openzeppelin-contracts/test/token/ERC20/ERC20.test.js +199 -0
  824. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC1363.test.js +370 -0
  825. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Burnable.test.js +105 -0
  826. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Capped.test.js +55 -0
  827. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Crosschain.test.js +83 -0
  828. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20FlashMint.test.js +164 -0
  829. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Pausable.test.js +129 -0
  830. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Permit.test.js +109 -0
  831. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Votes.test.js +546 -0
  832. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Wrapper.test.js +203 -0
  833. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC4626.t.sol +41 -0
  834. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC4626.test.js +888 -0
  835. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/draft-ERC20Bridgeable.test.js +89 -0
  836. package/lib/openzeppelin-contracts/test/token/ERC20/extensions/draft-ERC20TemporaryApproval.test.js +142 -0
  837. package/lib/openzeppelin-contracts/test/token/ERC20/utils/SafeERC20.test.js +463 -0
  838. package/lib/openzeppelin-contracts/test/token/ERC6909/ERC6909.behavior.js +216 -0
  839. package/lib/openzeppelin-contracts/test/token/ERC6909/ERC6909.test.js +104 -0
  840. package/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909ContentURI.test.js +52 -0
  841. package/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909Metadata.test.js +62 -0
  842. package/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909TokenSupply.test.js +56 -0
  843. package/lib/openzeppelin-contracts/test/token/ERC721/ERC721.behavior.js +954 -0
  844. package/lib/openzeppelin-contracts/test/token/ERC721/ERC721.test.js +23 -0
  845. package/lib/openzeppelin-contracts/test/token/ERC721/ERC721Enumerable.test.js +28 -0
  846. package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Burnable.test.js +77 -0
  847. package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Consecutive.t.sol +187 -0
  848. package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Consecutive.test.js +228 -0
  849. package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Pausable.test.js +81 -0
  850. package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Royalty.test.js +57 -0
  851. package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721URIStorage.test.js +134 -0
  852. package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Votes.test.js +194 -0
  853. package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Wrapper.test.js +201 -0
  854. package/lib/openzeppelin-contracts/test/token/ERC721/utils/ERC721Holder.test.js +20 -0
  855. package/lib/openzeppelin-contracts/test/token/ERC721/utils/ERC721Utils.test.js +94 -0
  856. package/lib/openzeppelin-contracts/test/token/common/ERC2981.behavior.js +152 -0
  857. package/lib/openzeppelin-contracts/test/utils/Address.test.js +332 -0
  858. package/lib/openzeppelin-contracts/test/utils/Arrays.t.sol +416 -0
  859. package/lib/openzeppelin-contracts/test/utils/Arrays.test.js +284 -0
  860. package/lib/openzeppelin-contracts/test/utils/Base58.t.sol +24 -0
  861. package/lib/openzeppelin-contracts/test/utils/Base58.test.js +65 -0
  862. package/lib/openzeppelin-contracts/test/utils/Base64.t.sol +36 -0
  863. package/lib/openzeppelin-contracts/test/utils/Base64.test.js +79 -0
  864. package/lib/openzeppelin-contracts/test/utils/Blockhash.t.sol +101 -0
  865. package/lib/openzeppelin-contracts/test/utils/Blockhash.test.js +59 -0
  866. package/lib/openzeppelin-contracts/test/utils/Bytes.t.sol +322 -0
  867. package/lib/openzeppelin-contracts/test/utils/Bytes.test.js +371 -0
  868. package/lib/openzeppelin-contracts/test/utils/CAIP.test.js +56 -0
  869. package/lib/openzeppelin-contracts/test/utils/Calldata.test.js +22 -0
  870. package/lib/openzeppelin-contracts/test/utils/Context.behavior.js +48 -0
  871. package/lib/openzeppelin-contracts/test/utils/Context.test.js +18 -0
  872. package/lib/openzeppelin-contracts/test/utils/Create2.t.sol +17 -0
  873. package/lib/openzeppelin-contracts/test/utils/Create2.test.js +190 -0
  874. package/lib/openzeppelin-contracts/test/utils/LowLevelCall.test.js +257 -0
  875. package/lib/openzeppelin-contracts/test/utils/Memory.t.sol +63 -0
  876. package/lib/openzeppelin-contracts/test/utils/Memory.test.js +106 -0
  877. package/lib/openzeppelin-contracts/test/utils/Multicall.test.js +72 -0
  878. package/lib/openzeppelin-contracts/test/utils/Nonces.behavior.js +189 -0
  879. package/lib/openzeppelin-contracts/test/utils/Nonces.test.js +16 -0
  880. package/lib/openzeppelin-contracts/test/utils/NoncesKeyed.t.sol +51 -0
  881. package/lib/openzeppelin-contracts/test/utils/NoncesKeyed.test.js +17 -0
  882. package/lib/openzeppelin-contracts/test/utils/Packing.t.sol +993 -0
  883. package/lib/openzeppelin-contracts/test/utils/Packing.test.js +70 -0
  884. package/lib/openzeppelin-contracts/test/utils/Panic.test.js +37 -0
  885. package/lib/openzeppelin-contracts/test/utils/Pausable.test.js +90 -0
  886. package/lib/openzeppelin-contracts/test/utils/RLP.t.sol +144 -0
  887. package/lib/openzeppelin-contracts/test/utils/RLP.test.js +224 -0
  888. package/lib/openzeppelin-contracts/test/utils/ReentrancyGuard.test.js +58 -0
  889. package/lib/openzeppelin-contracts/test/utils/RelayedCall.test.js +217 -0
  890. package/lib/openzeppelin-contracts/test/utils/ShortStrings.t.sol +109 -0
  891. package/lib/openzeppelin-contracts/test/utils/ShortStrings.test.js +64 -0
  892. package/lib/openzeppelin-contracts/test/utils/SlotDerivation.t.sol +248 -0
  893. package/lib/openzeppelin-contracts/test/utils/SlotDerivation.test.js +58 -0
  894. package/lib/openzeppelin-contracts/test/utils/StorageSlot.test.js +73 -0
  895. package/lib/openzeppelin-contracts/test/utils/Strings.t.sol +50 -0
  896. package/lib/openzeppelin-contracts/test/utils/Strings.test.js +360 -0
  897. package/lib/openzeppelin-contracts/test/utils/TransientSlot.test.js +59 -0
  898. package/lib/openzeppelin-contracts/test/utils/cryptography/ECDSA.test.js +322 -0
  899. package/lib/openzeppelin-contracts/test/utils/cryptography/EIP712.test.js +105 -0
  900. package/lib/openzeppelin-contracts/test/utils/cryptography/ERC1271.behavior.js +111 -0
  901. package/lib/openzeppelin-contracts/test/utils/cryptography/ERC7739.test.js +42 -0
  902. package/lib/openzeppelin-contracts/test/utils/cryptography/ERC7739Utils.test.js +203 -0
  903. package/lib/openzeppelin-contracts/test/utils/cryptography/MerkleProof.test.js +216 -0
  904. package/lib/openzeppelin-contracts/test/utils/cryptography/MessageHashUtils.t.sol +33 -0
  905. package/lib/openzeppelin-contracts/test/utils/cryptography/MessageHashUtils.test.js +149 -0
  906. package/lib/openzeppelin-contracts/test/utils/cryptography/P256.t.sol +45 -0
  907. package/lib/openzeppelin-contracts/test/utils/cryptography/P256.test.js +182 -0
  908. package/lib/openzeppelin-contracts/test/utils/cryptography/RSA.helper.js +17 -0
  909. package/lib/openzeppelin-contracts/test/utils/cryptography/RSA.test.js +102 -0
  910. package/lib/openzeppelin-contracts/test/utils/cryptography/SigVer15_186-3.rsp +3850 -0
  911. package/lib/openzeppelin-contracts/test/utils/cryptography/SignatureChecker.test.js +427 -0
  912. package/lib/openzeppelin-contracts/test/utils/cryptography/TrieProof.test.js +659 -0
  913. package/lib/openzeppelin-contracts/test/utils/cryptography/WebAuthn.t.sol +298 -0
  914. package/lib/openzeppelin-contracts/test/utils/cryptography/ecdsa_secp256r1_sha256_p1363_test.json +3719 -0
  915. package/lib/openzeppelin-contracts/test/utils/draft-InteroperableAddress.t.sol +99 -0
  916. package/lib/openzeppelin-contracts/test/utils/draft-InteroperableAddress.test.js +170 -0
  917. package/lib/openzeppelin-contracts/test/utils/introspection/ERC165.test.js +18 -0
  918. package/lib/openzeppelin-contracts/test/utils/introspection/ERC165Checker.test.js +272 -0
  919. package/lib/openzeppelin-contracts/test/utils/introspection/SupportsInterface.behavior.js +169 -0
  920. package/lib/openzeppelin-contracts/test/utils/math/Math.t.sol +370 -0
  921. package/lib/openzeppelin-contracts/test/utils/math/Math.test.js +746 -0
  922. package/lib/openzeppelin-contracts/test/utils/math/SafeCast.test.js +159 -0
  923. package/lib/openzeppelin-contracts/test/utils/math/SignedMath.t.sol +81 -0
  924. package/lib/openzeppelin-contracts/test/utils/math/SignedMath.test.js +53 -0
  925. package/lib/openzeppelin-contracts/test/utils/structs/Accumulators.t.sol +35 -0
  926. package/lib/openzeppelin-contracts/test/utils/structs/BitMap.test.js +149 -0
  927. package/lib/openzeppelin-contracts/test/utils/structs/Checkpoints.t.sol +440 -0
  928. package/lib/openzeppelin-contracts/test/utils/structs/Checkpoints.test.js +147 -0
  929. package/lib/openzeppelin-contracts/test/utils/structs/CircularBuffer.test.js +83 -0
  930. package/lib/openzeppelin-contracts/test/utils/structs/DoubleEndedQueue.test.js +144 -0
  931. package/lib/openzeppelin-contracts/test/utils/structs/EnumerableMap.behavior.js +214 -0
  932. package/lib/openzeppelin-contracts/test/utils/structs/EnumerableMap.test.js +83 -0
  933. package/lib/openzeppelin-contracts/test/utils/structs/EnumerableSet.behavior.js +175 -0
  934. package/lib/openzeppelin-contracts/test/utils/structs/EnumerableSet.test.js +66 -0
  935. package/lib/openzeppelin-contracts/test/utils/structs/Heap.t.sol +74 -0
  936. package/lib/openzeppelin-contracts/test/utils/structs/Heap.test.js +113 -0
  937. package/lib/openzeppelin-contracts/test/utils/structs/MerkleTree.test.js +180 -0
  938. package/lib/openzeppelin-contracts/test/utils/types/Time.test.js +135 -0
  939. package/lucro.txt +1 -0
  940. package/out/Base.sol/CommonBase.json +1 -0
  941. package/out/Base.sol/ScriptBase.json +1 -0
  942. package/out/Base.sol/TestBase.json +1 -0
  943. package/out/Context.sol/Context.json +1 -0
  944. package/out/Counter.s.sol/CounterScript.json +1 -0
  945. package/out/Counter.sol/Counter.json +1 -0
  946. package/out/Counter.t.sol/CounterTest.json +1 -0
  947. package/out/ERC20.sol/ERC20.json +1 -0
  948. package/out/GbitToken.sol/GbitToken.json +1 -0
  949. package/out/Guestbook.sol/Guestbook.json +1 -0
  950. package/out/IERC20.sol/IERC20.json +1 -0
  951. package/out/IERC20Metadata.sol/IERC20Metadata.json +1 -0
  952. package/out/IMulticall3.sol/IMulticall3.json +1 -0
  953. package/out/Script.sol/Script.json +1 -0
  954. package/out/StdAssertions.sol/StdAssertions.json +1 -0
  955. package/out/StdChains.sol/StdChains.json +1 -0
  956. package/out/StdCheats.sol/StdCheats.json +1 -0
  957. package/out/StdCheats.sol/StdCheatsSafe.json +1 -0
  958. package/out/StdConstants.sol/StdConstants.json +1 -0
  959. package/out/StdError.sol/stdError.json +1 -0
  960. package/out/StdInvariant.sol/StdInvariant.json +1 -0
  961. package/out/StdJson.sol/stdJson.json +1 -0
  962. package/out/StdMath.sol/stdMath.json +1 -0
  963. package/out/StdStorage.sol/stdStorage.json +1 -0
  964. package/out/StdStorage.sol/stdStorageSafe.json +1 -0
  965. package/out/StdStyle.sol/StdStyle.json +1 -0
  966. package/out/StdToml.sol/stdToml.json +1 -0
  967. package/out/StdUtils.sol/StdUtils.json +1 -0
  968. package/out/Test.sol/Test.json +1 -0
  969. package/out/Vm.sol/Vm.json +1 -0
  970. package/out/Vm.sol/VmSafe.json +1 -0
  971. package/out/Web3HubCore.sol/Web3HubCore.json +1 -0
  972. package/out/build-info/8a1d781106536b7b.json +1 -0
  973. package/out/build-info/aac4797350a36a99.json +1 -0
  974. package/out/build-info/c34d5a7881e6beba.json +1 -0
  975. package/out/build-info/ce38d811b8078146.json +1 -0
  976. package/out/build-info/db34a3531e47e196.json +1 -0
  977. package/out/console.sol/console.json +1 -0
  978. package/out/draft-IERC6093.sol/IERC1155Errors.json +1 -0
  979. package/out/draft-IERC6093.sol/IERC20Errors.json +1 -0
  980. package/out/draft-IERC6093.sol/IERC721Errors.json +1 -0
  981. package/out/safeconsole.sol/safeconsole.json +1 -0
  982. package/package.json +25 -0
  983. package/remappings.txt +1 -0
  984. package/script/Counter.s.sol +19 -0
  985. package/src/Counter.sol +14 -0
  986. package/src/GbitToken.sol +72 -0
  987. package/src/Guestbook.sol +28 -0
  988. package/src/Web3HubCore.sol +42 -0
  989. package/test/Counter.t.sol +24 -0
@@ -0,0 +1,1279 @@
1
+ const { ethers } = require('hardhat');
2
+ const { expect } = require('chai');
3
+ const { loadFixture } = require('@nomicfoundation/hardhat-network-helpers');
4
+ const { PANIC_CODES } = require('@nomicfoundation/hardhat-chai-matchers/panic');
5
+
6
+ const { GovernorHelper } = require('../helpers/governance');
7
+ const { OperationState } = require('../helpers/enums');
8
+ const time = require('../helpers/time');
9
+
10
+ const { shouldSupportInterfaces } = require('../utils/introspection/SupportsInterface.behavior');
11
+
12
+ const salt = '0x025e7b0be353a74631ad648c667493c0e1cd31caa4cc2d3520fdc171ea0cc726'; // a random value
13
+
14
+ const MINDELAY = time.duration.days(1);
15
+ const DEFAULT_ADMIN_ROLE = ethers.ZeroHash;
16
+ const PROPOSER_ROLE = ethers.id('PROPOSER_ROLE');
17
+ const EXECUTOR_ROLE = ethers.id('EXECUTOR_ROLE');
18
+ const CANCELLER_ROLE = ethers.id('CANCELLER_ROLE');
19
+
20
+ const getAddress = obj => obj.address ?? obj.target ?? obj;
21
+
22
+ function genOperation(target, value, data, predecessor, salt) {
23
+ const id = ethers.keccak256(
24
+ ethers.AbiCoder.defaultAbiCoder().encode(
25
+ ['address', 'uint256', 'bytes', 'uint256', 'bytes32'],
26
+ [getAddress(target), value, data, predecessor, salt],
27
+ ),
28
+ );
29
+ return { id, target, value, data, predecessor, salt };
30
+ }
31
+
32
+ function genOperationBatch(targets, values, payloads, predecessor, salt) {
33
+ const id = ethers.keccak256(
34
+ ethers.AbiCoder.defaultAbiCoder().encode(
35
+ ['address[]', 'uint256[]', 'bytes[]', 'uint256', 'bytes32'],
36
+ [targets.map(getAddress), values, payloads, predecessor, salt],
37
+ ),
38
+ );
39
+ return { id, targets, values, payloads, predecessor, salt };
40
+ }
41
+
42
+ async function fixture() {
43
+ const [admin, proposer, canceller, executor, other] = await ethers.getSigners();
44
+
45
+ const mock = await ethers.deployContract('TimelockController', [MINDELAY, [proposer], [executor], admin]);
46
+ const callreceivermock = await ethers.deployContract('CallReceiverMock');
47
+ const implementation2 = await ethers.deployContract('Implementation2');
48
+
49
+ expect(await mock.hasRole(CANCELLER_ROLE, proposer)).to.be.true;
50
+ await mock.connect(admin).revokeRole(CANCELLER_ROLE, proposer);
51
+ await mock.connect(admin).grantRole(CANCELLER_ROLE, canceller);
52
+
53
+ return {
54
+ admin,
55
+ proposer,
56
+ canceller,
57
+ executor,
58
+ other,
59
+ mock,
60
+ callreceivermock,
61
+ implementation2,
62
+ };
63
+ }
64
+
65
+ describe('TimelockController', function () {
66
+ beforeEach(async function () {
67
+ Object.assign(this, await loadFixture(fixture));
68
+ });
69
+
70
+ shouldSupportInterfaces(['ERC1155Receiver']);
71
+
72
+ it('initial state', async function () {
73
+ expect(await this.mock.getMinDelay()).to.equal(MINDELAY);
74
+
75
+ expect(await this.mock.DEFAULT_ADMIN_ROLE()).to.equal(DEFAULT_ADMIN_ROLE);
76
+ expect(await this.mock.PROPOSER_ROLE()).to.equal(PROPOSER_ROLE);
77
+ expect(await this.mock.EXECUTOR_ROLE()).to.equal(EXECUTOR_ROLE);
78
+ expect(await this.mock.CANCELLER_ROLE()).to.equal(CANCELLER_ROLE);
79
+
80
+ expect(
81
+ await Promise.all(
82
+ [PROPOSER_ROLE, CANCELLER_ROLE, EXECUTOR_ROLE].map(role => this.mock.hasRole(role, this.proposer)),
83
+ ),
84
+ ).to.deep.equal([true, false, false]);
85
+
86
+ expect(
87
+ await Promise.all(
88
+ [PROPOSER_ROLE, CANCELLER_ROLE, EXECUTOR_ROLE].map(role => this.mock.hasRole(role, this.canceller)),
89
+ ),
90
+ ).to.deep.equal([false, true, false]);
91
+
92
+ expect(
93
+ await Promise.all(
94
+ [PROPOSER_ROLE, CANCELLER_ROLE, EXECUTOR_ROLE].map(role => this.mock.hasRole(role, this.executor)),
95
+ ),
96
+ ).to.deep.equal([false, false, true]);
97
+ });
98
+
99
+ it('optional admin', async function () {
100
+ const mock = await ethers.deployContract('TimelockController', [
101
+ MINDELAY,
102
+ [this.proposer],
103
+ [this.executor],
104
+ ethers.ZeroAddress,
105
+ ]);
106
+ expect(await mock.hasRole(DEFAULT_ADMIN_ROLE, this.admin)).to.be.false;
107
+ expect(await mock.hasRole(DEFAULT_ADMIN_ROLE, mock.target)).to.be.true;
108
+ });
109
+
110
+ describe('methods', function () {
111
+ describe('operation hashing', function () {
112
+ it('hashOperation', async function () {
113
+ this.operation = genOperation(
114
+ '0x29cebefe301c6ce1bb36b58654fea275e1cacc83',
115
+ '0xf94fdd6e21da21d2',
116
+ '0xa3bc5104',
117
+ '0xba41db3be0a9929145cfe480bd0f1f003689104d275ae912099f925df424ef94',
118
+ '0x60d9109846ab510ed75c15f979ae366a8a2ace11d34ba9788c13ac296db50e6e',
119
+ );
120
+ expect(
121
+ await this.mock.hashOperation(
122
+ this.operation.target,
123
+ this.operation.value,
124
+ this.operation.data,
125
+ this.operation.predecessor,
126
+ this.operation.salt,
127
+ ),
128
+ ).to.equal(this.operation.id);
129
+ });
130
+
131
+ it('hashOperationBatch', async function () {
132
+ this.operation = genOperationBatch(
133
+ Array(8).fill('0x2d5f21620e56531c1d59c2df9b8e95d129571f71'),
134
+ Array(8).fill('0x2b993cfce932ccee'),
135
+ Array(8).fill('0xcf51966b'),
136
+ '0xce8f45069cc71d25f71ba05062de1a3974f9849b004de64a70998bca9d29c2e7',
137
+ '0x8952d74c110f72bfe5accdf828c74d53a7dfb71235dfa8a1e8c75d8576b372ff',
138
+ );
139
+ expect(
140
+ await this.mock.hashOperationBatch(
141
+ this.operation.targets,
142
+ this.operation.values,
143
+ this.operation.payloads,
144
+ this.operation.predecessor,
145
+ this.operation.salt,
146
+ ),
147
+ ).to.equal(this.operation.id);
148
+ });
149
+ });
150
+ describe('simple', function () {
151
+ describe('schedule', function () {
152
+ beforeEach(async function () {
153
+ this.operation = genOperation(
154
+ '0x31754f590B97fD975Eb86938f18Cc304E264D2F2',
155
+ 0n,
156
+ '0x3bf92ccc',
157
+ ethers.ZeroHash,
158
+ salt,
159
+ );
160
+ });
161
+
162
+ it('proposer can schedule', async function () {
163
+ const tx = await this.mock
164
+ .connect(this.proposer)
165
+ .schedule(
166
+ this.operation.target,
167
+ this.operation.value,
168
+ this.operation.data,
169
+ this.operation.predecessor,
170
+ this.operation.salt,
171
+ MINDELAY,
172
+ );
173
+
174
+ await expect(tx)
175
+ .to.emit(this.mock, 'CallScheduled')
176
+ .withArgs(
177
+ this.operation.id,
178
+ 0n,
179
+ this.operation.target,
180
+ this.operation.value,
181
+ this.operation.data,
182
+ this.operation.predecessor,
183
+ MINDELAY,
184
+ )
185
+ .to.emit(this.mock, 'CallSalt')
186
+ .withArgs(this.operation.id, this.operation.salt);
187
+
188
+ expect(await this.mock.getTimestamp(this.operation.id)).to.equal(
189
+ (await time.clockFromReceipt.timestamp(tx)) + MINDELAY,
190
+ );
191
+ });
192
+
193
+ it('prevent overwriting active operation', async function () {
194
+ await this.mock
195
+ .connect(this.proposer)
196
+ .schedule(
197
+ this.operation.target,
198
+ this.operation.value,
199
+ this.operation.data,
200
+ this.operation.predecessor,
201
+ this.operation.salt,
202
+ MINDELAY,
203
+ );
204
+
205
+ await expect(
206
+ this.mock
207
+ .connect(this.proposer)
208
+ .schedule(
209
+ this.operation.target,
210
+ this.operation.value,
211
+ this.operation.data,
212
+ this.operation.predecessor,
213
+ this.operation.salt,
214
+ MINDELAY,
215
+ ),
216
+ )
217
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
218
+ .withArgs(this.operation.id, GovernorHelper.proposalStatesToBitMap(OperationState.Unset));
219
+ });
220
+
221
+ it('prevent non-proposer from committing', async function () {
222
+ await expect(
223
+ this.mock
224
+ .connect(this.other)
225
+ .schedule(
226
+ this.operation.target,
227
+ this.operation.value,
228
+ this.operation.data,
229
+ this.operation.predecessor,
230
+ this.operation.salt,
231
+ MINDELAY,
232
+ ),
233
+ )
234
+ .to.be.revertedWithCustomError(this.mock, 'AccessControlUnauthorizedAccount')
235
+ .withArgs(this.other, PROPOSER_ROLE);
236
+ });
237
+
238
+ it('enforce minimum delay', async function () {
239
+ await expect(
240
+ this.mock
241
+ .connect(this.proposer)
242
+ .schedule(
243
+ this.operation.target,
244
+ this.operation.value,
245
+ this.operation.data,
246
+ this.operation.predecessor,
247
+ this.operation.salt,
248
+ MINDELAY - 1n,
249
+ ),
250
+ )
251
+ .to.be.revertedWithCustomError(this.mock, 'TimelockInsufficientDelay')
252
+ .withArgs(MINDELAY - 1n, MINDELAY);
253
+ });
254
+
255
+ it('schedule operation with salt zero', async function () {
256
+ await expect(
257
+ this.mock
258
+ .connect(this.proposer)
259
+ .schedule(
260
+ this.operation.target,
261
+ this.operation.value,
262
+ this.operation.data,
263
+ this.operation.predecessor,
264
+ ethers.ZeroHash,
265
+ MINDELAY,
266
+ ),
267
+ ).to.not.emit(this.mock, 'CallSalt');
268
+ });
269
+ });
270
+
271
+ describe('execute', function () {
272
+ beforeEach(async function () {
273
+ this.operation = genOperation(
274
+ '0xAe22104DCD970750610E6FE15E623468A98b15f7',
275
+ 0n,
276
+ '0x13e414de',
277
+ ethers.ZeroHash,
278
+ '0xc1059ed2dc130227aa1d1d539ac94c641306905c020436c636e19e3fab56fc7f',
279
+ );
280
+ });
281
+
282
+ it('revert if operation is not scheduled', async function () {
283
+ await expect(
284
+ this.mock
285
+ .connect(this.executor)
286
+ .execute(
287
+ this.operation.target,
288
+ this.operation.value,
289
+ this.operation.data,
290
+ this.operation.predecessor,
291
+ this.operation.salt,
292
+ ),
293
+ )
294
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
295
+ .withArgs(this.operation.id, GovernorHelper.proposalStatesToBitMap(OperationState.Ready));
296
+ });
297
+
298
+ describe('with scheduled operation', function () {
299
+ beforeEach(async function () {
300
+ await this.mock
301
+ .connect(this.proposer)
302
+ .schedule(
303
+ this.operation.target,
304
+ this.operation.value,
305
+ this.operation.data,
306
+ this.operation.predecessor,
307
+ this.operation.salt,
308
+ MINDELAY,
309
+ );
310
+ });
311
+
312
+ it('revert if execution comes too early 1/2', async function () {
313
+ await expect(
314
+ this.mock
315
+ .connect(this.executor)
316
+ .execute(
317
+ this.operation.target,
318
+ this.operation.value,
319
+ this.operation.data,
320
+ this.operation.predecessor,
321
+ this.operation.salt,
322
+ ),
323
+ )
324
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
325
+ .withArgs(this.operation.id, GovernorHelper.proposalStatesToBitMap(OperationState.Ready));
326
+ });
327
+
328
+ it('revert if execution comes too early 2/2', async function () {
329
+ // -1 is too tight, test sometime fails
330
+ await this.mock.getTimestamp(this.operation.id).then(clock => time.increaseTo.timestamp(clock - 5n));
331
+
332
+ await expect(
333
+ this.mock
334
+ .connect(this.executor)
335
+ .execute(
336
+ this.operation.target,
337
+ this.operation.value,
338
+ this.operation.data,
339
+ this.operation.predecessor,
340
+ this.operation.salt,
341
+ ),
342
+ )
343
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
344
+ .withArgs(this.operation.id, GovernorHelper.proposalStatesToBitMap(OperationState.Ready));
345
+ });
346
+
347
+ describe('on time', function () {
348
+ beforeEach(async function () {
349
+ await this.mock.getTimestamp(this.operation.id).then(time.increaseTo.timestamp);
350
+ });
351
+
352
+ it('executor can reveal', async function () {
353
+ await expect(
354
+ this.mock
355
+ .connect(this.executor)
356
+ .execute(
357
+ this.operation.target,
358
+ this.operation.value,
359
+ this.operation.data,
360
+ this.operation.predecessor,
361
+ this.operation.salt,
362
+ ),
363
+ )
364
+ .to.emit(this.mock, 'CallExecuted')
365
+ .withArgs(this.operation.id, 0n, this.operation.target, this.operation.value, this.operation.data);
366
+ });
367
+
368
+ it('prevent non-executor from revealing', async function () {
369
+ await expect(
370
+ this.mock
371
+ .connect(this.other)
372
+ .execute(
373
+ this.operation.target,
374
+ this.operation.value,
375
+ this.operation.data,
376
+ this.operation.predecessor,
377
+ this.operation.salt,
378
+ ),
379
+ )
380
+ .to.be.revertedWithCustomError(this.mock, 'AccessControlUnauthorizedAccount')
381
+ .withArgs(this.other, EXECUTOR_ROLE);
382
+ });
383
+
384
+ it('prevents reentrancy execution', async function () {
385
+ // Create operation
386
+ const reentrant = await ethers.deployContract('$TimelockReentrant');
387
+ const reentrantOperation = genOperation(
388
+ reentrant,
389
+ 0n,
390
+ reentrant.interface.encodeFunctionData('reenter'),
391
+ ethers.ZeroHash,
392
+ salt,
393
+ );
394
+
395
+ // Schedule so it can be executed
396
+ await this.mock
397
+ .connect(this.proposer)
398
+ .schedule(
399
+ reentrantOperation.target,
400
+ reentrantOperation.value,
401
+ reentrantOperation.data,
402
+ reentrantOperation.predecessor,
403
+ reentrantOperation.salt,
404
+ MINDELAY,
405
+ );
406
+
407
+ // Advance on time to make the operation executable
408
+ await this.mock.getTimestamp(reentrantOperation.id).then(time.increaseTo.timestamp);
409
+
410
+ // Grant executor role to the reentrant contract
411
+ await this.mock.connect(this.admin).grantRole(EXECUTOR_ROLE, reentrant);
412
+
413
+ // Prepare reenter
414
+ const data = this.mock.interface.encodeFunctionData('execute', [
415
+ getAddress(reentrantOperation.target),
416
+ reentrantOperation.value,
417
+ reentrantOperation.data,
418
+ reentrantOperation.predecessor,
419
+ reentrantOperation.salt,
420
+ ]);
421
+ await reentrant.enableReentrancy(this.mock, data);
422
+
423
+ // Expect to fail
424
+ await expect(
425
+ this.mock
426
+ .connect(this.executor)
427
+ .execute(
428
+ reentrantOperation.target,
429
+ reentrantOperation.value,
430
+ reentrantOperation.data,
431
+ reentrantOperation.predecessor,
432
+ reentrantOperation.salt,
433
+ ),
434
+ )
435
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
436
+ .withArgs(reentrantOperation.id, GovernorHelper.proposalStatesToBitMap(OperationState.Ready));
437
+
438
+ // Disable reentrancy
439
+ await reentrant.disableReentrancy();
440
+ const nonReentrantOperation = reentrantOperation; // Not anymore
441
+
442
+ // Try again successfully
443
+ await expect(
444
+ this.mock
445
+ .connect(this.executor)
446
+ .execute(
447
+ nonReentrantOperation.target,
448
+ nonReentrantOperation.value,
449
+ nonReentrantOperation.data,
450
+ nonReentrantOperation.predecessor,
451
+ nonReentrantOperation.salt,
452
+ ),
453
+ )
454
+ .to.emit(this.mock, 'CallExecuted')
455
+ .withArgs(
456
+ nonReentrantOperation.id,
457
+ 0n,
458
+ getAddress(nonReentrantOperation),
459
+ nonReentrantOperation.value,
460
+ nonReentrantOperation.data,
461
+ );
462
+ });
463
+ });
464
+ });
465
+ });
466
+ });
467
+
468
+ describe('batch', function () {
469
+ describe('schedule', function () {
470
+ beforeEach(async function () {
471
+ this.operation = genOperationBatch(
472
+ Array(8).fill('0xEd912250835c812D4516BBD80BdaEA1bB63a293C'),
473
+ Array(8).fill(0n),
474
+ Array(8).fill('0x2fcb7a88'),
475
+ ethers.ZeroHash,
476
+ '0x6cf9d042ade5de78bed9ffd075eb4b2a4f6b1736932c2dc8af517d6e066f51f5',
477
+ );
478
+ });
479
+
480
+ it('proposer can schedule', async function () {
481
+ const tx = this.mock
482
+ .connect(this.proposer)
483
+ .scheduleBatch(
484
+ this.operation.targets,
485
+ this.operation.values,
486
+ this.operation.payloads,
487
+ this.operation.predecessor,
488
+ this.operation.salt,
489
+ MINDELAY,
490
+ );
491
+ for (const i in this.operation.targets) {
492
+ await expect(tx)
493
+ .to.emit(this.mock, 'CallScheduled')
494
+ .withArgs(
495
+ this.operation.id,
496
+ i,
497
+ getAddress(this.operation.targets[i]),
498
+ this.operation.values[i],
499
+ this.operation.payloads[i],
500
+ this.operation.predecessor,
501
+ MINDELAY,
502
+ )
503
+ .to.emit(this.mock, 'CallSalt')
504
+ .withArgs(this.operation.id, this.operation.salt);
505
+ }
506
+
507
+ expect(await this.mock.getTimestamp(this.operation.id)).to.equal(
508
+ (await time.clockFromReceipt.timestamp(tx)) + MINDELAY,
509
+ );
510
+ });
511
+
512
+ it('prevent overwriting active operation', async function () {
513
+ await this.mock
514
+ .connect(this.proposer)
515
+ .scheduleBatch(
516
+ this.operation.targets,
517
+ this.operation.values,
518
+ this.operation.payloads,
519
+ this.operation.predecessor,
520
+ this.operation.salt,
521
+ MINDELAY,
522
+ );
523
+
524
+ await expect(
525
+ this.mock
526
+ .connect(this.proposer)
527
+ .scheduleBatch(
528
+ this.operation.targets,
529
+ this.operation.values,
530
+ this.operation.payloads,
531
+ this.operation.predecessor,
532
+ this.operation.salt,
533
+ MINDELAY,
534
+ ),
535
+ )
536
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
537
+ .withArgs(this.operation.id, GovernorHelper.proposalStatesToBitMap(OperationState.Unset));
538
+ });
539
+
540
+ it('length of batch parameter must match #1', async function () {
541
+ await expect(
542
+ this.mock
543
+ .connect(this.proposer)
544
+ .scheduleBatch(
545
+ this.operation.targets,
546
+ [],
547
+ this.operation.payloads,
548
+ this.operation.predecessor,
549
+ this.operation.salt,
550
+ MINDELAY,
551
+ ),
552
+ )
553
+ .to.be.revertedWithCustomError(this.mock, 'TimelockInvalidOperationLength')
554
+ .withArgs(this.operation.targets.length, this.operation.payloads.length, 0n);
555
+ });
556
+
557
+ it('length of batch parameter must match #1', async function () {
558
+ await expect(
559
+ this.mock
560
+ .connect(this.proposer)
561
+ .scheduleBatch(
562
+ this.operation.targets,
563
+ this.operation.values,
564
+ [],
565
+ this.operation.predecessor,
566
+ this.operation.salt,
567
+ MINDELAY,
568
+ ),
569
+ )
570
+ .to.be.revertedWithCustomError(this.mock, 'TimelockInvalidOperationLength')
571
+ .withArgs(this.operation.targets.length, 0n, this.operation.payloads.length);
572
+ });
573
+
574
+ it('prevent non-proposer from committing', async function () {
575
+ await expect(
576
+ this.mock
577
+ .connect(this.other)
578
+ .scheduleBatch(
579
+ this.operation.targets,
580
+ this.operation.values,
581
+ this.operation.payloads,
582
+ this.operation.predecessor,
583
+ this.operation.salt,
584
+ MINDELAY,
585
+ ),
586
+ )
587
+ .to.be.revertedWithCustomError(this.mock, 'AccessControlUnauthorizedAccount')
588
+ .withArgs(this.other, PROPOSER_ROLE);
589
+ });
590
+
591
+ it('enforce minimum delay', async function () {
592
+ await expect(
593
+ this.mock
594
+ .connect(this.proposer)
595
+ .scheduleBatch(
596
+ this.operation.targets,
597
+ this.operation.values,
598
+ this.operation.payloads,
599
+ this.operation.predecessor,
600
+ this.operation.salt,
601
+ MINDELAY - 1n,
602
+ ),
603
+ )
604
+ .to.be.revertedWithCustomError(this.mock, 'TimelockInsufficientDelay')
605
+ .withArgs(MINDELAY - 1n, MINDELAY);
606
+ });
607
+ });
608
+
609
+ describe('execute', function () {
610
+ beforeEach(async function () {
611
+ this.operation = genOperationBatch(
612
+ Array(8).fill('0x76E53CcEb05131Ef5248553bEBDb8F70536830b1'),
613
+ Array(8).fill(0n),
614
+ Array(8).fill('0x58a60f63'),
615
+ ethers.ZeroHash,
616
+ '0x9545eeabc7a7586689191f78a5532443698538e54211b5bd4d7dc0fc0102b5c7',
617
+ );
618
+ });
619
+
620
+ it('revert if operation is not scheduled', async function () {
621
+ await expect(
622
+ this.mock
623
+ .connect(this.executor)
624
+ .executeBatch(
625
+ this.operation.targets,
626
+ this.operation.values,
627
+ this.operation.payloads,
628
+ this.operation.predecessor,
629
+ this.operation.salt,
630
+ ),
631
+ )
632
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
633
+ .withArgs(this.operation.id, GovernorHelper.proposalStatesToBitMap(OperationState.Ready));
634
+ });
635
+
636
+ describe('with scheduled operation', function () {
637
+ beforeEach(async function () {
638
+ await this.mock
639
+ .connect(this.proposer)
640
+ .scheduleBatch(
641
+ this.operation.targets,
642
+ this.operation.values,
643
+ this.operation.payloads,
644
+ this.operation.predecessor,
645
+ this.operation.salt,
646
+ MINDELAY,
647
+ );
648
+ });
649
+
650
+ it('revert if execution comes too early 1/2', async function () {
651
+ await expect(
652
+ this.mock
653
+ .connect(this.executor)
654
+ .executeBatch(
655
+ this.operation.targets,
656
+ this.operation.values,
657
+ this.operation.payloads,
658
+ this.operation.predecessor,
659
+ this.operation.salt,
660
+ ),
661
+ )
662
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
663
+ .withArgs(this.operation.id, GovernorHelper.proposalStatesToBitMap(OperationState.Ready));
664
+ });
665
+
666
+ it('revert if execution comes too early 2/2', async function () {
667
+ // -1 is to tight, test sometime fails
668
+ await this.mock.getTimestamp(this.operation.id).then(clock => time.increaseTo.timestamp(clock - 5n));
669
+
670
+ await expect(
671
+ this.mock
672
+ .connect(this.executor)
673
+ .executeBatch(
674
+ this.operation.targets,
675
+ this.operation.values,
676
+ this.operation.payloads,
677
+ this.operation.predecessor,
678
+ this.operation.salt,
679
+ ),
680
+ )
681
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
682
+ .withArgs(this.operation.id, GovernorHelper.proposalStatesToBitMap(OperationState.Ready));
683
+ });
684
+
685
+ describe('on time', function () {
686
+ beforeEach(async function () {
687
+ await this.mock.getTimestamp(this.operation.id).then(time.increaseTo.timestamp);
688
+ });
689
+
690
+ it('executor can reveal', async function () {
691
+ const tx = this.mock
692
+ .connect(this.executor)
693
+ .executeBatch(
694
+ this.operation.targets,
695
+ this.operation.values,
696
+ this.operation.payloads,
697
+ this.operation.predecessor,
698
+ this.operation.salt,
699
+ );
700
+ for (const i in this.operation.targets) {
701
+ await expect(tx)
702
+ .to.emit(this.mock, 'CallExecuted')
703
+ .withArgs(
704
+ this.operation.id,
705
+ i,
706
+ this.operation.targets[i],
707
+ this.operation.values[i],
708
+ this.operation.payloads[i],
709
+ );
710
+ }
711
+ });
712
+
713
+ it('prevent non-executor from revealing', async function () {
714
+ await expect(
715
+ this.mock
716
+ .connect(this.other)
717
+ .executeBatch(
718
+ this.operation.targets,
719
+ this.operation.values,
720
+ this.operation.payloads,
721
+ this.operation.predecessor,
722
+ this.operation.salt,
723
+ ),
724
+ )
725
+ .to.be.revertedWithCustomError(this.mock, 'AccessControlUnauthorizedAccount')
726
+ .withArgs(this.other, EXECUTOR_ROLE);
727
+ });
728
+
729
+ it('length mismatch #1', async function () {
730
+ await expect(
731
+ this.mock
732
+ .connect(this.executor)
733
+ .executeBatch(
734
+ [],
735
+ this.operation.values,
736
+ this.operation.payloads,
737
+ this.operation.predecessor,
738
+ this.operation.salt,
739
+ ),
740
+ )
741
+ .to.be.revertedWithCustomError(this.mock, 'TimelockInvalidOperationLength')
742
+ .withArgs(0n, this.operation.payloads.length, this.operation.values.length);
743
+ });
744
+
745
+ it('length mismatch #2', async function () {
746
+ await expect(
747
+ this.mock
748
+ .connect(this.executor)
749
+ .executeBatch(
750
+ this.operation.targets,
751
+ [],
752
+ this.operation.payloads,
753
+ this.operation.predecessor,
754
+ this.operation.salt,
755
+ ),
756
+ )
757
+ .to.be.revertedWithCustomError(this.mock, 'TimelockInvalidOperationLength')
758
+ .withArgs(this.operation.targets.length, this.operation.payloads.length, 0n);
759
+ });
760
+
761
+ it('length mismatch #3', async function () {
762
+ await expect(
763
+ this.mock
764
+ .connect(this.executor)
765
+ .executeBatch(
766
+ this.operation.targets,
767
+ this.operation.values,
768
+ [],
769
+ this.operation.predecessor,
770
+ this.operation.salt,
771
+ ),
772
+ )
773
+ .to.be.revertedWithCustomError(this.mock, 'TimelockInvalidOperationLength')
774
+ .withArgs(this.operation.targets.length, 0n, this.operation.values.length);
775
+ });
776
+
777
+ it('prevents reentrancy execution', async function () {
778
+ // Create operation
779
+ const reentrant = await ethers.deployContract('$TimelockReentrant');
780
+ const reentrantBatchOperation = genOperationBatch(
781
+ [reentrant],
782
+ [0n],
783
+ [reentrant.interface.encodeFunctionData('reenter')],
784
+ ethers.ZeroHash,
785
+ salt,
786
+ );
787
+
788
+ // Schedule so it can be executed
789
+ await this.mock
790
+ .connect(this.proposer)
791
+ .scheduleBatch(
792
+ reentrantBatchOperation.targets,
793
+ reentrantBatchOperation.values,
794
+ reentrantBatchOperation.payloads,
795
+ reentrantBatchOperation.predecessor,
796
+ reentrantBatchOperation.salt,
797
+ MINDELAY,
798
+ );
799
+
800
+ // Advance on time to make the operation executable
801
+ await this.mock.getTimestamp(reentrantBatchOperation.id).then(time.increaseTo.timestamp);
802
+
803
+ // Grant executor role to the reentrant contract
804
+ await this.mock.connect(this.admin).grantRole(EXECUTOR_ROLE, reentrant);
805
+
806
+ // Prepare reenter
807
+ const data = this.mock.interface.encodeFunctionData('executeBatch', [
808
+ reentrantBatchOperation.targets.map(getAddress),
809
+ reentrantBatchOperation.values,
810
+ reentrantBatchOperation.payloads,
811
+ reentrantBatchOperation.predecessor,
812
+ reentrantBatchOperation.salt,
813
+ ]);
814
+ await reentrant.enableReentrancy(this.mock, data);
815
+
816
+ // Expect to fail
817
+ await expect(
818
+ this.mock
819
+ .connect(this.executor)
820
+ .executeBatch(
821
+ reentrantBatchOperation.targets,
822
+ reentrantBatchOperation.values,
823
+ reentrantBatchOperation.payloads,
824
+ reentrantBatchOperation.predecessor,
825
+ reentrantBatchOperation.salt,
826
+ ),
827
+ )
828
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
829
+ .withArgs(reentrantBatchOperation.id, GovernorHelper.proposalStatesToBitMap(OperationState.Ready));
830
+
831
+ // Disable reentrancy
832
+ await reentrant.disableReentrancy();
833
+ const nonReentrantBatchOperation = reentrantBatchOperation; // Not anymore
834
+
835
+ // Try again successfully
836
+ const tx = this.mock
837
+ .connect(this.executor)
838
+ .executeBatch(
839
+ nonReentrantBatchOperation.targets,
840
+ nonReentrantBatchOperation.values,
841
+ nonReentrantBatchOperation.payloads,
842
+ nonReentrantBatchOperation.predecessor,
843
+ nonReentrantBatchOperation.salt,
844
+ );
845
+ for (const i in nonReentrantBatchOperation.targets) {
846
+ await expect(tx)
847
+ .to.emit(this.mock, 'CallExecuted')
848
+ .withArgs(
849
+ nonReentrantBatchOperation.id,
850
+ i,
851
+ nonReentrantBatchOperation.targets[i],
852
+ nonReentrantBatchOperation.values[i],
853
+ nonReentrantBatchOperation.payloads[i],
854
+ );
855
+ }
856
+ });
857
+ });
858
+ });
859
+
860
+ it('partial execution', async function () {
861
+ const operation = genOperationBatch(
862
+ [this.callreceivermock, this.callreceivermock, this.callreceivermock],
863
+ [0n, 0n, 0n],
864
+ [
865
+ this.callreceivermock.interface.encodeFunctionData('mockFunction'),
866
+ this.callreceivermock.interface.encodeFunctionData('mockFunctionRevertsNoReason'),
867
+ this.callreceivermock.interface.encodeFunctionData('mockFunction'),
868
+ ],
869
+ ethers.ZeroHash,
870
+ '0x8ac04aa0d6d66b8812fb41d39638d37af0a9ab11da507afd65c509f8ed079d3e',
871
+ );
872
+
873
+ await this.mock
874
+ .connect(this.proposer)
875
+ .scheduleBatch(
876
+ operation.targets,
877
+ operation.values,
878
+ operation.payloads,
879
+ operation.predecessor,
880
+ operation.salt,
881
+ MINDELAY,
882
+ );
883
+
884
+ await this.mock.getTimestamp(operation.id).then(time.increaseTo.timestamp);
885
+
886
+ await expect(
887
+ this.mock
888
+ .connect(this.executor)
889
+ .executeBatch(
890
+ operation.targets,
891
+ operation.values,
892
+ operation.payloads,
893
+ operation.predecessor,
894
+ operation.salt,
895
+ ),
896
+ ).to.be.revertedWithCustomError(this.mock, 'FailedCall');
897
+ });
898
+ });
899
+ });
900
+
901
+ describe('cancel', function () {
902
+ beforeEach(async function () {
903
+ this.operation = genOperation(
904
+ '0xC6837c44AA376dbe1d2709F13879E040CAb653ca',
905
+ 0n,
906
+ '0x296e58dd',
907
+ ethers.ZeroHash,
908
+ '0xa2485763600634800df9fc9646fb2c112cf98649c55f63dd1d9c7d13a64399d9',
909
+ );
910
+ await this.mock
911
+ .connect(this.proposer)
912
+ .schedule(
913
+ this.operation.target,
914
+ this.operation.value,
915
+ this.operation.data,
916
+ this.operation.predecessor,
917
+ this.operation.salt,
918
+ MINDELAY,
919
+ );
920
+ });
921
+
922
+ it('canceller can cancel', async function () {
923
+ await expect(this.mock.connect(this.canceller).cancel(this.operation.id))
924
+ .to.emit(this.mock, 'Cancelled')
925
+ .withArgs(this.operation.id);
926
+ });
927
+
928
+ it('cannot cancel invalid operation', async function () {
929
+ await expect(this.mock.connect(this.canceller).cancel(ethers.ZeroHash))
930
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexpectedOperationState')
931
+ .withArgs(
932
+ ethers.ZeroHash,
933
+ GovernorHelper.proposalStatesToBitMap([OperationState.Waiting, OperationState.Ready]),
934
+ );
935
+ });
936
+
937
+ it('prevent non-canceller from canceling', async function () {
938
+ await expect(this.mock.connect(this.other).cancel(this.operation.id))
939
+ .to.be.revertedWithCustomError(this.mock, 'AccessControlUnauthorizedAccount')
940
+ .withArgs(this.other, CANCELLER_ROLE);
941
+ });
942
+ });
943
+ });
944
+
945
+ describe('maintenance', function () {
946
+ it('prevent unauthorized maintenance', async function () {
947
+ await expect(this.mock.connect(this.other).updateDelay(0n))
948
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnauthorizedCaller')
949
+ .withArgs(this.other);
950
+ });
951
+
952
+ it('timelock scheduled maintenance', async function () {
953
+ const newDelay = time.duration.hours(6);
954
+ const operation = genOperation(
955
+ this.mock,
956
+ 0n,
957
+ this.mock.interface.encodeFunctionData('updateDelay', [newDelay]),
958
+ ethers.ZeroHash,
959
+ '0xf8e775b2c5f4d66fb5c7fa800f35ef518c262b6014b3c0aee6ea21bff157f108',
960
+ );
961
+
962
+ await this.mock
963
+ .connect(this.proposer)
964
+ .schedule(operation.target, operation.value, operation.data, operation.predecessor, operation.salt, MINDELAY);
965
+
966
+ await this.mock.getTimestamp(operation.id).then(time.increaseTo.timestamp);
967
+
968
+ await expect(
969
+ this.mock
970
+ .connect(this.executor)
971
+ .execute(operation.target, operation.value, operation.data, operation.predecessor, operation.salt),
972
+ )
973
+ .to.emit(this.mock, 'MinDelayChange')
974
+ .withArgs(MINDELAY, newDelay);
975
+
976
+ expect(await this.mock.getMinDelay()).to.equal(newDelay);
977
+ });
978
+ });
979
+
980
+ describe('dependency', function () {
981
+ beforeEach(async function () {
982
+ this.operation1 = genOperation(
983
+ '0xdE66bD4c97304200A95aE0AadA32d6d01A867E39',
984
+ 0n,
985
+ '0x01dc731a',
986
+ ethers.ZeroHash,
987
+ '0x64e932133c7677402ead2926f86205e2ca4686aebecf5a8077627092b9bb2feb',
988
+ );
989
+ this.operation2 = genOperation(
990
+ '0x3c7944a3F1ee7fc8c5A5134ba7c79D11c3A1FCa3',
991
+ 0n,
992
+ '0x8f531849',
993
+ this.operation1.id,
994
+ '0x036e1311cac523f9548e6461e29fb1f8f9196b91910a41711ea22f5de48df07d',
995
+ );
996
+ await this.mock
997
+ .connect(this.proposer)
998
+ .schedule(
999
+ this.operation1.target,
1000
+ this.operation1.value,
1001
+ this.operation1.data,
1002
+ this.operation1.predecessor,
1003
+ this.operation1.salt,
1004
+ MINDELAY,
1005
+ );
1006
+ await this.mock
1007
+ .connect(this.proposer)
1008
+ .schedule(
1009
+ this.operation2.target,
1010
+ this.operation2.value,
1011
+ this.operation2.data,
1012
+ this.operation2.predecessor,
1013
+ this.operation2.salt,
1014
+ MINDELAY,
1015
+ );
1016
+
1017
+ await this.mock.getTimestamp(this.operation2.id).then(time.increaseTo.timestamp);
1018
+ });
1019
+
1020
+ it('cannot execute before dependency', async function () {
1021
+ await expect(
1022
+ this.mock
1023
+ .connect(this.executor)
1024
+ .execute(
1025
+ this.operation2.target,
1026
+ this.operation2.value,
1027
+ this.operation2.data,
1028
+ this.operation2.predecessor,
1029
+ this.operation2.salt,
1030
+ ),
1031
+ )
1032
+ .to.be.revertedWithCustomError(this.mock, 'TimelockUnexecutedPredecessor')
1033
+ .withArgs(this.operation1.id);
1034
+ });
1035
+
1036
+ it('can execute after dependency', async function () {
1037
+ await this.mock
1038
+ .connect(this.executor)
1039
+ .execute(
1040
+ this.operation1.target,
1041
+ this.operation1.value,
1042
+ this.operation1.data,
1043
+ this.operation1.predecessor,
1044
+ this.operation1.salt,
1045
+ );
1046
+ await this.mock
1047
+ .connect(this.executor)
1048
+ .execute(
1049
+ this.operation2.target,
1050
+ this.operation2.value,
1051
+ this.operation2.data,
1052
+ this.operation2.predecessor,
1053
+ this.operation2.salt,
1054
+ );
1055
+ });
1056
+ });
1057
+
1058
+ describe('usage scenario', function () {
1059
+ this.timeout(10000);
1060
+
1061
+ it('call', async function () {
1062
+ const operation = genOperation(
1063
+ this.implementation2,
1064
+ 0n,
1065
+ this.implementation2.interface.encodeFunctionData('setValue', [42n]),
1066
+ ethers.ZeroHash,
1067
+ '0x8043596363daefc89977b25f9d9b4d06c3910959ef0c4d213557a903e1b555e2',
1068
+ );
1069
+
1070
+ await this.mock
1071
+ .connect(this.proposer)
1072
+ .schedule(operation.target, operation.value, operation.data, operation.predecessor, operation.salt, MINDELAY);
1073
+
1074
+ await this.mock.getTimestamp(operation.id).then(time.increaseTo.timestamp);
1075
+
1076
+ await this.mock
1077
+ .connect(this.executor)
1078
+ .execute(operation.target, operation.value, operation.data, operation.predecessor, operation.salt);
1079
+
1080
+ expect(await this.implementation2.getValue()).to.equal(42n);
1081
+ });
1082
+
1083
+ it('call reverting', async function () {
1084
+ const operation = genOperation(
1085
+ this.callreceivermock,
1086
+ 0n,
1087
+ this.callreceivermock.interface.encodeFunctionData('mockFunctionRevertsNoReason'),
1088
+ ethers.ZeroHash,
1089
+ '0xb1b1b276fdf1a28d1e00537ea73b04d56639128b08063c1a2f70a52e38cba693',
1090
+ );
1091
+
1092
+ await this.mock
1093
+ .connect(this.proposer)
1094
+ .schedule(operation.target, operation.value, operation.data, operation.predecessor, operation.salt, MINDELAY);
1095
+
1096
+ await this.mock.getTimestamp(operation.id).then(time.increaseTo.timestamp);
1097
+
1098
+ await expect(
1099
+ this.mock
1100
+ .connect(this.executor)
1101
+ .execute(operation.target, operation.value, operation.data, operation.predecessor, operation.salt),
1102
+ ).to.be.revertedWithCustomError(this.mock, 'FailedCall');
1103
+ });
1104
+
1105
+ it('call throw', async function () {
1106
+ const operation = genOperation(
1107
+ this.callreceivermock,
1108
+ 0n,
1109
+ this.callreceivermock.interface.encodeFunctionData('mockFunctionThrows'),
1110
+ ethers.ZeroHash,
1111
+ '0xe5ca79f295fc8327ee8a765fe19afb58f4a0cbc5053642bfdd7e73bc68e0fc67',
1112
+ );
1113
+
1114
+ await this.mock
1115
+ .connect(this.proposer)
1116
+ .schedule(operation.target, operation.value, operation.data, operation.predecessor, operation.salt, MINDELAY);
1117
+
1118
+ await this.mock.getTimestamp(operation.id).then(time.increaseTo.timestamp);
1119
+
1120
+ // Targeted function reverts with a panic code (0x1) + the timelock bubble the panic code
1121
+ await expect(
1122
+ this.mock
1123
+ .connect(this.executor)
1124
+ .execute(operation.target, operation.value, operation.data, operation.predecessor, operation.salt),
1125
+ ).to.be.revertedWithPanic(PANIC_CODES.ASSERTION_ERROR);
1126
+ });
1127
+
1128
+ it('call out of gas', async function () {
1129
+ const operation = genOperation(
1130
+ this.callreceivermock,
1131
+ 0n,
1132
+ this.callreceivermock.interface.encodeFunctionData('mockFunctionOutOfGas'),
1133
+ ethers.ZeroHash,
1134
+ '0xf3274ce7c394c5b629d5215723563a744b817e1730cca5587c567099a14578fd',
1135
+ );
1136
+
1137
+ await this.mock
1138
+ .connect(this.proposer)
1139
+ .schedule(operation.target, operation.value, operation.data, operation.predecessor, operation.salt, MINDELAY);
1140
+
1141
+ await this.mock.getTimestamp(operation.id).then(time.increaseTo.timestamp);
1142
+
1143
+ await expect(
1144
+ this.mock
1145
+ .connect(this.executor)
1146
+ .execute(operation.target, operation.value, operation.data, operation.predecessor, operation.salt, {
1147
+ gasLimit: '100000',
1148
+ }),
1149
+ ).to.be.revertedWithCustomError(this.mock, 'FailedCall');
1150
+ });
1151
+
1152
+ it('call payable with eth', async function () {
1153
+ const operation = genOperation(
1154
+ this.callreceivermock,
1155
+ 1n,
1156
+ this.callreceivermock.interface.encodeFunctionData('mockFunction'),
1157
+ ethers.ZeroHash,
1158
+ '0x5ab73cd33477dcd36c1e05e28362719d0ed59a7b9ff14939de63a43073dc1f44',
1159
+ );
1160
+
1161
+ await this.mock
1162
+ .connect(this.proposer)
1163
+ .schedule(operation.target, operation.value, operation.data, operation.predecessor, operation.salt, MINDELAY);
1164
+
1165
+ await this.mock.getTimestamp(operation.id).then(time.increaseTo.timestamp);
1166
+
1167
+ expect(await ethers.provider.getBalance(this.mock)).to.equal(0n);
1168
+ expect(await ethers.provider.getBalance(this.callreceivermock)).to.equal(0n);
1169
+
1170
+ await this.mock
1171
+ .connect(this.executor)
1172
+ .execute(operation.target, operation.value, operation.data, operation.predecessor, operation.salt, {
1173
+ value: 1n,
1174
+ });
1175
+
1176
+ expect(await ethers.provider.getBalance(this.mock)).to.equal(0n);
1177
+ expect(await ethers.provider.getBalance(this.callreceivermock)).to.equal(1n);
1178
+ });
1179
+
1180
+ it('call nonpayable with eth', async function () {
1181
+ const operation = genOperation(
1182
+ this.callreceivermock,
1183
+ 1,
1184
+ this.callreceivermock.interface.encodeFunctionData('mockFunctionNonPayable'),
1185
+ ethers.ZeroHash,
1186
+ '0xb78edbd920c7867f187e5aa6294ae5a656cfbf0dea1ccdca3751b740d0f2bdf8',
1187
+ );
1188
+
1189
+ await this.mock
1190
+ .connect(this.proposer)
1191
+ .schedule(operation.target, operation.value, operation.data, operation.predecessor, operation.salt, MINDELAY);
1192
+
1193
+ await this.mock.getTimestamp(operation.id).then(time.increaseTo.timestamp);
1194
+
1195
+ expect(await ethers.provider.getBalance(this.mock)).to.equal(0n);
1196
+ expect(await ethers.provider.getBalance(this.callreceivermock)).to.equal(0n);
1197
+
1198
+ await expect(
1199
+ this.mock
1200
+ .connect(this.executor)
1201
+ .execute(operation.target, operation.value, operation.data, operation.predecessor, operation.salt),
1202
+ ).to.be.revertedWithCustomError(this.mock, 'FailedCall');
1203
+
1204
+ expect(await ethers.provider.getBalance(this.mock)).to.equal(0n);
1205
+ expect(await ethers.provider.getBalance(this.callreceivermock)).to.equal(0n);
1206
+ });
1207
+
1208
+ it('call reverting with eth', async function () {
1209
+ const operation = genOperation(
1210
+ this.callreceivermock,
1211
+ 1,
1212
+ this.callreceivermock.interface.encodeFunctionData('mockFunctionRevertsNoReason'),
1213
+ ethers.ZeroHash,
1214
+ '0xdedb4563ef0095db01d81d3f2decf57cf83e4a72aa792af14c43a792b56f4de6',
1215
+ );
1216
+
1217
+ await this.mock
1218
+ .connect(this.proposer)
1219
+ .schedule(operation.target, operation.value, operation.data, operation.predecessor, operation.salt, MINDELAY);
1220
+
1221
+ await this.mock.getTimestamp(operation.id).then(time.increaseTo.timestamp);
1222
+
1223
+ expect(await ethers.provider.getBalance(this.mock)).to.equal(0n);
1224
+ expect(await ethers.provider.getBalance(this.callreceivermock)).to.equal(0n);
1225
+
1226
+ await expect(
1227
+ this.mock
1228
+ .connect(this.executor)
1229
+ .execute(operation.target, operation.value, operation.data, operation.predecessor, operation.salt),
1230
+ ).to.be.revertedWithCustomError(this.mock, 'FailedCall');
1231
+
1232
+ expect(await ethers.provider.getBalance(this.mock)).to.equal(0n);
1233
+ expect(await ethers.provider.getBalance(this.callreceivermock)).to.equal(0n);
1234
+ });
1235
+ });
1236
+
1237
+ describe('safe receive', function () {
1238
+ describe('ERC721', function () {
1239
+ const tokenId = 1n;
1240
+
1241
+ beforeEach(async function () {
1242
+ this.token = await ethers.deployContract('$ERC721', ['Non Fungible Token', 'NFT']);
1243
+ await this.token.$_mint(this.other, tokenId);
1244
+ });
1245
+
1246
+ it('can receive an ERC721 safeTransfer', async function () {
1247
+ await this.token.connect(this.other).safeTransferFrom(this.other, this.mock, tokenId);
1248
+ });
1249
+ });
1250
+
1251
+ describe('ERC1155', function () {
1252
+ const tokenIds = {
1253
+ 1: 1000n,
1254
+ 2: 2000n,
1255
+ 3: 3000n,
1256
+ };
1257
+
1258
+ beforeEach(async function () {
1259
+ this.token = await ethers.deployContract('$ERC1155', ['https://token-cdn-domain/{id}.json']);
1260
+ await this.token.$_mintBatch(this.other, Object.keys(tokenIds), Object.values(tokenIds), '0x');
1261
+ });
1262
+
1263
+ it('can receive ERC1155 safeTransfer', async function () {
1264
+ await this.token.connect(this.other).safeTransferFrom(
1265
+ this.other,
1266
+ this.mock,
1267
+ ...Object.entries(tokenIds)[0], // id + amount
1268
+ '0x',
1269
+ );
1270
+ });
1271
+
1272
+ it('can receive ERC1155 safeBatchTransfer', async function () {
1273
+ await this.token
1274
+ .connect(this.other)
1275
+ .safeBatchTransferFrom(this.other, this.mock, Object.keys(tokenIds), Object.values(tokenIds), '0x');
1276
+ });
1277
+ });
1278
+ });
1279
+ });