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,259 @@
1
+ // SPDX-License-Identifier: MIT
2
+ // OpenZeppelin Contracts (last updated v5.4.0) (utils/cryptography/signers/MultiSignerERC7913.sol)
3
+
4
+ pragma solidity ^0.8.26;
5
+
6
+ import {AbstractSigner} from "./AbstractSigner.sol";
7
+ import {SignatureChecker} from "../SignatureChecker.sol";
8
+ import {EnumerableSet} from "../../structs/EnumerableSet.sol";
9
+
10
+ /**
11
+ * @dev Implementation of {AbstractSigner} using multiple ERC-7913 signers with a threshold-based
12
+ * signature verification system.
13
+ *
14
+ * This contract allows managing a set of authorized signers and requires a minimum number of
15
+ * signatures (threshold) to approve operations. It uses ERC-7913 formatted signers, which
16
+ * makes it natively compatible with ECDSA and ERC-1271 signers.
17
+ *
18
+ * Example of usage:
19
+ *
20
+ * ```solidity
21
+ * contract MyMultiSignerAccount is Account, MultiSignerERC7913, Initializable {
22
+ * function initialize(bytes[] memory signers, uint64 threshold) public initializer {
23
+ * _addSigners(signers);
24
+ * _setThreshold(threshold);
25
+ * }
26
+ *
27
+ * function addSigners(bytes[] memory signers) public onlyEntryPointOrSelf {
28
+ * _addSigners(signers);
29
+ * }
30
+ *
31
+ * function removeSigners(bytes[] memory signers) public onlyEntryPointOrSelf {
32
+ * _removeSigners(signers);
33
+ * }
34
+ *
35
+ * function setThreshold(uint64 threshold) public onlyEntryPointOrSelf {
36
+ * _setThreshold(threshold);
37
+ * }
38
+ * }
39
+ * ```
40
+ *
41
+ * IMPORTANT: Failing to properly initialize the signers and threshold either during construction
42
+ * (if used standalone) or during initialization (if used as a clone) may leave the contract
43
+ * either front-runnable or unusable.
44
+ */
45
+ abstract contract MultiSignerERC7913 is AbstractSigner {
46
+ using EnumerableSet for EnumerableSet.BytesSet;
47
+ using SignatureChecker for *;
48
+
49
+ EnumerableSet.BytesSet private _signers;
50
+ uint64 private _threshold;
51
+
52
+ /// @dev Emitted when a signer is added.
53
+ event ERC7913SignerAdded(bytes indexed signers);
54
+
55
+ /// @dev Emitted when a signers is removed.
56
+ event ERC7913SignerRemoved(bytes indexed signers);
57
+
58
+ /// @dev Emitted when the threshold is updated.
59
+ event ERC7913ThresholdSet(uint64 threshold);
60
+
61
+ /// @dev The `signer` already exists.
62
+ error MultiSignerERC7913AlreadyExists(bytes signer);
63
+
64
+ /// @dev The `signer` does not exist.
65
+ error MultiSignerERC7913NonexistentSigner(bytes signer);
66
+
67
+ /// @dev The `signer` is less than 20 bytes long.
68
+ error MultiSignerERC7913InvalidSigner(bytes signer);
69
+
70
+ /// @dev The `threshold` is zero.
71
+ error MultiSignerERC7913ZeroThreshold();
72
+
73
+ /// @dev The `threshold` is unreachable given the number of `signers`.
74
+ error MultiSignerERC7913UnreachableThreshold(uint64 signers, uint64 threshold);
75
+
76
+ constructor(bytes[] memory signers_, uint64 threshold_) {
77
+ _addSigners(signers_);
78
+ _setThreshold(threshold_);
79
+ }
80
+
81
+ /**
82
+ * @dev Returns a slice of the set of authorized signers.
83
+ *
84
+ * Using `start = 0` and `end = type(uint64).max` will return the entire set of signers.
85
+ *
86
+ * WARNING: Depending on the `start` and `end`, this operation can copy a large amount of data to memory, which
87
+ * can be expensive. This is designed for view accessors queried without gas fees. Using it in state-changing
88
+ * functions may become uncallable if the slice grows too large.
89
+ */
90
+ function getSigners(uint64 start, uint64 end) public view virtual returns (bytes[] memory) {
91
+ return _signers.values(start, end);
92
+ }
93
+
94
+ /// @dev Returns the number of authorized signers
95
+ function getSignerCount() public view virtual returns (uint256) {
96
+ return _signers.length();
97
+ }
98
+
99
+ /// @dev Returns whether the `signer` is an authorized signer.
100
+ function isSigner(bytes memory signer) public view virtual returns (bool) {
101
+ return _signers.contains(signer);
102
+ }
103
+
104
+ /// @dev Returns the minimum number of signers required to approve a multisignature operation.
105
+ function threshold() public view virtual returns (uint64) {
106
+ return _threshold;
107
+ }
108
+
109
+ /**
110
+ * @dev Adds the `newSigners` to those allowed to sign on behalf of this contract.
111
+ * Internal version without access control.
112
+ *
113
+ * Requirements:
114
+ *
115
+ * * Each of `newSigners` must be at least 20 bytes long. Reverts with {MultiSignerERC7913InvalidSigner} if not.
116
+ * * Each of `newSigners` must not be authorized. See {isSigner}. Reverts with {MultiSignerERC7913AlreadyExists} if so.
117
+ *
118
+ * NOTE: This function does not validate that signers are controlled or represent appropriate entities. Integrators
119
+ * must ensure signers are properly validated before adding them. Problematic signers can compromise
120
+ * the multisig's security or functionality. Examples include uncontrolled addresses (e.g., `address(0)`),
121
+ * the account's own address (which may cause recursive validation loops), or contracts that may unintentionally
122
+ * allow arbitrary validation (e.g. using the identity precompile at `address(0x04)`, which would return the
123
+ * ERC-1271 magic value for any `isValidSignature` call).
124
+ */
125
+ function _addSigners(bytes[] memory newSigners) internal virtual {
126
+ for (uint256 i = 0; i < newSigners.length; ++i) {
127
+ bytes memory signer = newSigners[i];
128
+ require(signer.length >= 20, MultiSignerERC7913InvalidSigner(signer));
129
+ require(_signers.add(signer), MultiSignerERC7913AlreadyExists(signer));
130
+ emit ERC7913SignerAdded(signer);
131
+ }
132
+ }
133
+
134
+ /**
135
+ * @dev Removes the `oldSigners` from the authorized signers. Internal version without access control.
136
+ *
137
+ * Requirements:
138
+ *
139
+ * * Each of `oldSigners` must be authorized. See {isSigner}. Otherwise {MultiSignerERC7913NonexistentSigner} is thrown.
140
+ * * See {_validateReachableThreshold} for the threshold validation.
141
+ */
142
+ function _removeSigners(bytes[] memory oldSigners) internal virtual {
143
+ for (uint256 i = 0; i < oldSigners.length; ++i) {
144
+ bytes memory signer = oldSigners[i];
145
+ require(_signers.remove(signer), MultiSignerERC7913NonexistentSigner(signer));
146
+ emit ERC7913SignerRemoved(signer);
147
+ }
148
+ _validateReachableThreshold();
149
+ }
150
+
151
+ /**
152
+ * @dev Sets the signatures `threshold` required to approve a multisignature operation.
153
+ * Internal version without access control.
154
+ *
155
+ * Requirements:
156
+ *
157
+ * * See {_validateReachableThreshold} for the threshold validation.
158
+ */
159
+ function _setThreshold(uint64 newThreshold) internal virtual {
160
+ require(newThreshold > 0, MultiSignerERC7913ZeroThreshold());
161
+ _threshold = newThreshold;
162
+ _validateReachableThreshold();
163
+ emit ERC7913ThresholdSet(newThreshold);
164
+ }
165
+
166
+ /**
167
+ * @dev Validates the current threshold is reachable.
168
+ *
169
+ * Requirements:
170
+ *
171
+ * * The {getSignerCount} must be greater or equal than to the {threshold}. Throws
172
+ * {MultiSignerERC7913UnreachableThreshold} if not.
173
+ */
174
+ function _validateReachableThreshold() internal view virtual {
175
+ uint256 signersLength = _signers.length();
176
+ uint64 currentThreshold = threshold();
177
+ require(
178
+ signersLength >= currentThreshold,
179
+ MultiSignerERC7913UnreachableThreshold(
180
+ uint64(signersLength), // Safe cast. Economically impossible to overflow.
181
+ currentThreshold
182
+ )
183
+ );
184
+ }
185
+
186
+ /**
187
+ * @dev Decodes, validates the signature and checks the signers are authorized.
188
+ * See {_validateSignatures} and {_validateThreshold} for more details.
189
+ *
190
+ * Example of signature encoding:
191
+ *
192
+ * ```solidity
193
+ * // Encode signers (verifier || key)
194
+ * bytes memory signer1 = abi.encodePacked(verifier1, key1);
195
+ * bytes memory signer2 = abi.encodePacked(verifier2, key2);
196
+ *
197
+ * // Order signers by their id
198
+ * if (keccak256(signer1) > keccak256(signer2)) {
199
+ * (signer1, signer2) = (signer2, signer1);
200
+ * (signature1, signature2) = (signature2, signature1);
201
+ * }
202
+ *
203
+ * // Assign ordered signers and signatures
204
+ * bytes[] memory signers = new bytes[](2);
205
+ * bytes[] memory signatures = new bytes[](2);
206
+ * signers[0] = signer1;
207
+ * signatures[0] = signature1;
208
+ * signers[1] = signer2;
209
+ * signatures[1] = signature2;
210
+ *
211
+ * // Encode the multi signature
212
+ * bytes memory signature = abi.encode(signers, signatures);
213
+ * ```
214
+ *
215
+ * Requirements:
216
+ *
217
+ * * The `signature` must be encoded as `abi.encode(signers, signatures)`.
218
+ */
219
+ function _rawSignatureValidation(
220
+ bytes32 hash,
221
+ bytes calldata signature
222
+ ) internal view virtual override returns (bool) {
223
+ if (signature.length == 0) return false; // For ERC-7739 compatibility
224
+ (bytes[] memory signers, bytes[] memory signatures) = abi.decode(signature, (bytes[], bytes[]));
225
+ return _validateThreshold(signers) && _validateSignatures(hash, signers, signatures);
226
+ }
227
+
228
+ /**
229
+ * @dev Validates the signatures using the signers and their corresponding signatures.
230
+ * Returns whether the signers are authorized and the signatures are valid for the given hash.
231
+ *
232
+ * IMPORTANT: Sorting the signers by their `keccak256` hash will improve the gas efficiency of this function.
233
+ * See {SignatureChecker-areValidSignaturesNow-bytes32-bytes[]-bytes[]} for more details.
234
+ *
235
+ * Requirements:
236
+ *
237
+ * * The `signatures` and `signers` arrays must be equal in length. Returns false otherwise.
238
+ */
239
+ function _validateSignatures(
240
+ bytes32 hash,
241
+ bytes[] memory signers,
242
+ bytes[] memory signatures
243
+ ) internal view virtual returns (bool valid) {
244
+ for (uint256 i = 0; i < signers.length; ++i) {
245
+ if (!isSigner(signers[i])) {
246
+ return false;
247
+ }
248
+ }
249
+ return hash.areValidSignaturesNow(signers, signatures);
250
+ }
251
+
252
+ /**
253
+ * @dev Validates that the number of signers meets the {threshold} requirement.
254
+ * Assumes the signers were already validated. See {_validateSignatures} for more details.
255
+ */
256
+ function _validateThreshold(bytes[] memory validatingSigners) internal view virtual returns (bool) {
257
+ return validatingSigners.length >= threshold();
258
+ }
259
+ }
@@ -0,0 +1,208 @@
1
+ // SPDX-License-Identifier: MIT
2
+ // OpenZeppelin Contracts (last updated v5.4.0) (utils/cryptography/signers/MultiSignerERC7913Weighted.sol)
3
+
4
+ pragma solidity ^0.8.26;
5
+
6
+ import {SafeCast} from "../../math/SafeCast.sol";
7
+ import {MultiSignerERC7913} from "./MultiSignerERC7913.sol";
8
+
9
+ /**
10
+ * @dev Extension of {MultiSignerERC7913} that supports weighted signatures.
11
+ *
12
+ * This contract allows assigning different weights to each signer, enabling more
13
+ * flexible governance schemes. For example, some signers could have higher weight
14
+ * than others, allowing for weighted voting or prioritized authorization.
15
+ *
16
+ * Example of usage:
17
+ *
18
+ * ```solidity
19
+ * contract MyWeightedMultiSignerAccount is Account, MultiSignerERC7913Weighted, Initializable {
20
+ * function initialize(bytes[] memory signers, uint64[] memory weights, uint64 threshold) public initializer {
21
+ * _addSigners(signers);
22
+ * _setSignerWeights(signers, weights);
23
+ * _setThreshold(threshold);
24
+ * }
25
+ *
26
+ * function addSigners(bytes[] memory signers) public onlyEntryPointOrSelf {
27
+ * _addSigners(signers);
28
+ * }
29
+ *
30
+ * function removeSigners(bytes[] memory signers) public onlyEntryPointOrSelf {
31
+ * _removeSigners(signers);
32
+ * }
33
+ *
34
+ * function setThreshold(uint64 threshold) public onlyEntryPointOrSelf {
35
+ * _setThreshold(threshold);
36
+ * }
37
+ *
38
+ * function setSignerWeights(bytes[] memory signers, uint64[] memory weights) public onlyEntryPointOrSelf {
39
+ * _setSignerWeights(signers, weights);
40
+ * }
41
+ * }
42
+ * ```
43
+ *
44
+ * IMPORTANT: When setting a threshold value, ensure it matches the scale used for signer weights.
45
+ * For example, if signers have weights like 1, 2, or 3, then a threshold of 4 would require at
46
+ * least two signers (e.g., one with weight 1 and one with weight 3). See {signerWeight}.
47
+ */
48
+ abstract contract MultiSignerERC7913Weighted is MultiSignerERC7913 {
49
+ using SafeCast for *;
50
+
51
+ // Sum of all the extra weights of all signers. Storage packed with `MultiSignerERC7913._threshold`
52
+ uint64 private _totalExtraWeight;
53
+
54
+ // Mapping from signer to extraWeight (in addition to all authorized signers having weight 1)
55
+ mapping(bytes signer => uint64) private _extraWeights;
56
+
57
+ /**
58
+ * @dev Emitted when a signer's weight is changed.
59
+ *
60
+ * NOTE: Not emitted in {_addSigners} or {_removeSigners}. Indexers must rely on {ERC7913SignerAdded}
61
+ * and {ERC7913SignerRemoved} to index a default weight of 1. See {signerWeight}.
62
+ */
63
+ event ERC7913SignerWeightChanged(bytes indexed signer, uint64 weight);
64
+
65
+ /// @dev Thrown when a signer's weight is invalid.
66
+ error MultiSignerERC7913WeightedInvalidWeight(bytes signer, uint64 weight);
67
+
68
+ /// @dev Thrown when the arrays lengths don't match. See {_setSignerWeights}.
69
+ error MultiSignerERC7913WeightedMismatchedLength();
70
+
71
+ constructor(bytes[] memory signers_, uint64[] memory weights_, uint64 threshold_) MultiSignerERC7913(signers_, 1) {
72
+ _setSignerWeights(signers_, weights_);
73
+ _setThreshold(threshold_);
74
+ }
75
+
76
+ /// @dev Gets the weight of a signer. Returns 0 if the signer is not authorized.
77
+ function signerWeight(bytes memory signer) public view virtual returns (uint64) {
78
+ unchecked {
79
+ // Safe cast, _setSignerWeights guarantees 1+_extraWeights is a uint64
80
+ return uint64(isSigner(signer).toUint() * (1 + _extraWeights[signer]));
81
+ }
82
+ }
83
+
84
+ /// @dev Gets the total weight of all signers.
85
+ function totalWeight() public view virtual returns (uint64) {
86
+ return (getSignerCount() + _totalExtraWeight).toUint64();
87
+ }
88
+
89
+ /**
90
+ * @dev Sets weights for multiple signers at once. Internal version without access control.
91
+ *
92
+ * Requirements:
93
+ *
94
+ * * `signers` and `weights` arrays must have the same length. Reverts with {MultiSignerERC7913WeightedMismatchedLength} on mismatch.
95
+ * * Each signer must exist in the set of authorized signers. Otherwise reverts with {MultiSignerERC7913NonexistentSigner}
96
+ * * Each weight must be greater than 0. Otherwise reverts with {MultiSignerERC7913WeightedInvalidWeight}
97
+ * * See {_validateReachableThreshold} for the threshold validation.
98
+ *
99
+ * Emits {ERC7913SignerWeightChanged} for each signer.
100
+ */
101
+ function _setSignerWeights(bytes[] memory signers, uint64[] memory weights) internal virtual {
102
+ require(signers.length == weights.length, MultiSignerERC7913WeightedMismatchedLength());
103
+
104
+ uint256 extraWeightAdded = 0;
105
+ uint256 extraWeightRemoved = 0;
106
+ for (uint256 i = 0; i < signers.length; ++i) {
107
+ bytes memory signer = signers[i];
108
+ require(isSigner(signer), MultiSignerERC7913NonexistentSigner(signer));
109
+
110
+ uint64 weight = weights[i];
111
+ require(weight > 0, MultiSignerERC7913WeightedInvalidWeight(signer, weight));
112
+
113
+ unchecked {
114
+ uint64 oldExtraWeight = _extraWeights[signer];
115
+ uint64 newExtraWeight = weight - 1;
116
+
117
+ if (oldExtraWeight != newExtraWeight) {
118
+ // Overflow impossible: weight values are bounded by uint64 and economic constraints
119
+ extraWeightRemoved += oldExtraWeight;
120
+ extraWeightAdded += _extraWeights[signer] = newExtraWeight;
121
+ emit ERC7913SignerWeightChanged(signer, weight);
122
+ }
123
+ }
124
+ }
125
+ unchecked {
126
+ // Safe from underflow: `extraWeightRemoved` is bounded by `_totalExtraWeight` by construction
127
+ // and weight values are bounded by uint64 and economic constraints
128
+ _totalExtraWeight = (uint256(_totalExtraWeight) + extraWeightAdded - extraWeightRemoved).toUint64();
129
+ }
130
+ _validateReachableThreshold();
131
+ }
132
+
133
+ /**
134
+ * @dev See {MultiSignerERC7913-_addSigners}.
135
+ *
136
+ * In cases where {totalWeight} is almost `type(uint64).max` (due to a large `_totalExtraWeight`), adding new
137
+ * signers could cause the {totalWeight} computation to overflow. Adding a {totalWeight} calls after the new
138
+ * signers are added ensures no such overflow happens.
139
+ */
140
+ function _addSigners(bytes[] memory newSigners) internal virtual override {
141
+ super._addSigners(newSigners);
142
+
143
+ // This will revert if the new signers cause an overflow
144
+ _validateReachableThreshold();
145
+ }
146
+
147
+ /**
148
+ * @dev See {MultiSignerERC7913-_removeSigners}.
149
+ *
150
+ * Just like {_addSigners}, this function does not emit {ERC7913SignerWeightChanged} events. The
151
+ * {ERC7913SignerRemoved} event emitted by {MultiSignerERC7913-_removeSigners} is enough to track weights here.
152
+ */
153
+ function _removeSigners(bytes[] memory signers) internal virtual override {
154
+ // Clean up weights for removed signers
155
+ //
156
+ // The `extraWeightRemoved` is bounded by `_totalExtraWeight`. The `super._removeSigners` function will revert
157
+ // if the signers array contains any duplicates, ensuring each signer's weight is only counted once. Since
158
+ // `_totalExtraWeight` is stored as a `uint64`, the final subtraction operation is also safe.
159
+ unchecked {
160
+ uint64 extraWeightRemoved = 0;
161
+ for (uint256 i = 0; i < signers.length; ++i) {
162
+ bytes memory signer = signers[i];
163
+
164
+ extraWeightRemoved += _extraWeights[signer];
165
+ delete _extraWeights[signer];
166
+ }
167
+ _totalExtraWeight -= extraWeightRemoved;
168
+ }
169
+ super._removeSigners(signers);
170
+ }
171
+
172
+ /**
173
+ * @dev Sets the threshold for the multisignature operation. Internal version without access control.
174
+ *
175
+ * Requirements:
176
+ *
177
+ * * The {totalWeight} must be `>=` the {threshold}. Otherwise reverts with {MultiSignerERC7913UnreachableThreshold}
178
+ *
179
+ * NOTE: This function intentionally does not call `super._validateReachableThreshold` because the base implementation
180
+ * assumes each signer has a weight of 1, which is a subset of this weighted implementation. Consider that multiple
181
+ * implementations of this function may exist in the contract, so important side effects may be missed
182
+ * depending on the linearization order.
183
+ */
184
+ function _validateReachableThreshold() internal view virtual override {
185
+ uint64 weight = totalWeight();
186
+ uint64 currentThreshold = threshold();
187
+ require(weight >= currentThreshold, MultiSignerERC7913UnreachableThreshold(weight, currentThreshold));
188
+ }
189
+
190
+ /**
191
+ * @dev Validates that the total weight of signers meets the threshold requirement.
192
+ *
193
+ * NOTE: This function intentionally does not call `super._validateThreshold` because the base implementation
194
+ * assumes each signer has a weight of 1, which is a subset of this weighted implementation. Consider that multiple
195
+ * implementations of this function may exist in the contract, so important side effects may be missed
196
+ * depending on the linearization order.
197
+ */
198
+ function _validateThreshold(bytes[] memory signers) internal view virtual override returns (bool) {
199
+ unchecked {
200
+ uint64 weight = 0;
201
+ for (uint256 i = 0; i < signers.length; ++i) {
202
+ // Overflow impossible: weight values are bounded by uint64 and economic constraints
203
+ weight += signerWeight(signers[i]);
204
+ }
205
+ return weight >= threshold();
206
+ }
207
+ }
208
+ }
@@ -0,0 +1,56 @@
1
+ // SPDX-License-Identifier: MIT
2
+ // OpenZeppelin Contracts (last updated v5.4.0) (utils/cryptography/signers/SignerECDSA.sol)
3
+
4
+ pragma solidity ^0.8.20;
5
+
6
+ import {AbstractSigner} from "./AbstractSigner.sol";
7
+ import {ECDSA} from "../ECDSA.sol";
8
+
9
+ /**
10
+ * @dev Implementation of {AbstractSigner} using xref:api:utils/cryptography#ECDSA[ECDSA] signatures.
11
+ *
12
+ * For {Account} usage, a {_setSigner} function is provided to set the {signer} address.
13
+ * Doing so is easier for a factory, who is likely to use initializable clones of this contract.
14
+ *
15
+ * Example of usage:
16
+ *
17
+ * ```solidity
18
+ * contract MyAccountECDSA is Account, SignerECDSA, Initializable {
19
+ * function initialize(address signerAddr) public initializer {
20
+ * _setSigner(signerAddr);
21
+ * }
22
+ * }
23
+ * ```
24
+ *
25
+ * IMPORTANT: Failing to call {_setSigner} either during construction (if used standalone)
26
+ * or during initialization (if used as a clone) may leave the signer either front-runnable or unusable.
27
+ */
28
+ abstract contract SignerECDSA is AbstractSigner {
29
+ address private _signer;
30
+
31
+ constructor(address signerAddr) {
32
+ _setSigner(signerAddr);
33
+ }
34
+
35
+ /**
36
+ * @dev Sets the signer with the address of the native signer. This function should be called during construction
37
+ * or through an initializer.
38
+ */
39
+ function _setSigner(address signerAddr) internal {
40
+ _signer = signerAddr;
41
+ }
42
+
43
+ /// @dev Return the signer's address.
44
+ function signer() public view virtual returns (address) {
45
+ return _signer;
46
+ }
47
+
48
+ /// @inheritdoc AbstractSigner
49
+ function _rawSignatureValidation(
50
+ bytes32 hash,
51
+ bytes calldata signature
52
+ ) internal view virtual override returns (bool) {
53
+ (address recovered, ECDSA.RecoverError err, ) = ECDSA.tryRecoverCalldata(hash, signature);
54
+ return signer() == recovered && err == ECDSA.RecoverError.NoError;
55
+ }
56
+ }
@@ -0,0 +1,25 @@
1
+ // SPDX-License-Identifier: MIT
2
+ // OpenZeppelin Contracts (last updated v5.5.0) (utils/cryptography/signers/SignerEIP7702.sol)
3
+
4
+ pragma solidity ^0.8.20;
5
+
6
+ import {AbstractSigner} from "./AbstractSigner.sol";
7
+ import {ECDSA} from "../ECDSA.sol";
8
+
9
+ /**
10
+ * @dev Implementation of {AbstractSigner} for implementation for an EOA. Useful for EIP-7702 accounts.
11
+ *
12
+ * @custom:stateless
13
+ */
14
+ abstract contract SignerEIP7702 is AbstractSigner {
15
+ /**
16
+ * @dev Validates the signature using the EOA's address (i.e. `address(this)`).
17
+ */
18
+ function _rawSignatureValidation(
19
+ bytes32 hash,
20
+ bytes calldata signature
21
+ ) internal view virtual override returns (bool) {
22
+ (address recovered, ECDSA.RecoverError err, ) = ECDSA.tryRecoverCalldata(hash, signature);
23
+ return address(this) == recovered && err == ECDSA.RecoverError.NoError;
24
+ }
25
+ }
@@ -0,0 +1,63 @@
1
+ // SPDX-License-Identifier: MIT
2
+ // OpenZeppelin Contracts (last updated v5.4.0) (utils/cryptography/signers/SignerERC7913.sol)
3
+
4
+ pragma solidity ^0.8.24;
5
+
6
+ import {AbstractSigner} from "./AbstractSigner.sol";
7
+ import {SignatureChecker} from "../SignatureChecker.sol";
8
+
9
+ /**
10
+ * @dev Implementation of {AbstractSigner} using
11
+ * https://eips.ethereum.org/EIPS/eip-7913[ERC-7913] signature verification.
12
+ *
13
+ * For {Account} usage, a {_setSigner} function is provided to set the ERC-7913 formatted {signer}.
14
+ * Doing so is easier for a factory, who is likely to use initializable clones of this contract.
15
+ *
16
+ * The signer is a `bytes` object that concatenates a verifier address and a key: `verifier || key`.
17
+ *
18
+ * Example of usage:
19
+ *
20
+ * ```solidity
21
+ * contract MyAccountERC7913 is Account, SignerERC7913, Initializable {
22
+ * function initialize(bytes memory signer_) public initializer {
23
+ * _setSigner(signer_);
24
+ * }
25
+ *
26
+ * function setSigner(bytes memory signer_) public onlyEntryPointOrSelf {
27
+ * _setSigner(signer_);
28
+ * }
29
+ * }
30
+ * ```
31
+ *
32
+ * IMPORTANT: Failing to call {_setSigner} either during construction (if used standalone)
33
+ * or during initialization (if used as a clone) may leave the signer either front-runnable or unusable.
34
+ */
35
+
36
+ abstract contract SignerERC7913 is AbstractSigner {
37
+ bytes private _signer;
38
+
39
+ constructor(bytes memory signer_) {
40
+ _setSigner(signer_);
41
+ }
42
+
43
+ /// @dev Return the ERC-7913 signer (i.e. `verifier || key`).
44
+ function signer() public view virtual returns (bytes memory) {
45
+ return _signer;
46
+ }
47
+
48
+ /// @dev Sets the signer (i.e. `verifier || key`) with an ERC-7913 formatted signer.
49
+ function _setSigner(bytes memory signer_) internal {
50
+ _signer = signer_;
51
+ }
52
+
53
+ /**
54
+ * @dev Verifies a signature using {SignatureChecker-isValidSignatureNow-bytes-bytes32-bytes-}
55
+ * with {signer}, `hash` and `signature`.
56
+ */
57
+ function _rawSignatureValidation(
58
+ bytes32 hash,
59
+ bytes calldata signature
60
+ ) internal view virtual override returns (bool) {
61
+ return SignatureChecker.isValidSignatureNow(signer(), hash, signature);
62
+ }
63
+ }
@@ -0,0 +1,64 @@
1
+ // SPDX-License-Identifier: MIT
2
+ // OpenZeppelin Contracts (last updated v5.4.0) (utils/cryptography/signers/SignerP256.sol)
3
+
4
+ pragma solidity ^0.8.20;
5
+
6
+ import {AbstractSigner} from "./AbstractSigner.sol";
7
+ import {P256} from "../P256.sol";
8
+
9
+ /**
10
+ * @dev Implementation of {AbstractSigner} using xref:api:utils/cryptography#P256[P256] signatures.
11
+ *
12
+ * For {Account} usage, a {_setSigner} function is provided to set the {signer} public key.
13
+ * Doing so is easier for a factory, who is likely to use initializable clones of this contract.
14
+ *
15
+ * Example of usage:
16
+ *
17
+ * ```solidity
18
+ * contract MyAccountP256 is Account, SignerP256, Initializable {
19
+ * function initialize(bytes32 qx, bytes32 qy) public initializer {
20
+ * _setSigner(qx, qy);
21
+ * }
22
+ * }
23
+ * ```
24
+ *
25
+ * IMPORTANT: Failing to call {_setSigner} either during construction (if used standalone)
26
+ * or during initialization (if used as a clone) may leave the signer either front-runnable or unusable.
27
+ */
28
+ abstract contract SignerP256 is AbstractSigner {
29
+ bytes32 private _qx;
30
+ bytes32 private _qy;
31
+
32
+ error SignerP256InvalidPublicKey(bytes32 qx, bytes32 qy);
33
+
34
+ constructor(bytes32 qx, bytes32 qy) {
35
+ _setSigner(qx, qy);
36
+ }
37
+
38
+ /**
39
+ * @dev Sets the signer with a P256 public key. This function should be called during construction
40
+ * or through an initializer.
41
+ */
42
+ function _setSigner(bytes32 qx, bytes32 qy) internal {
43
+ if (!P256.isValidPublicKey(qx, qy)) revert SignerP256InvalidPublicKey(qx, qy);
44
+ _qx = qx;
45
+ _qy = qy;
46
+ }
47
+
48
+ /// @dev Return the signer's P256 public key.
49
+ function signer() public view virtual returns (bytes32 qx, bytes32 qy) {
50
+ return (_qx, _qy);
51
+ }
52
+
53
+ /// @inheritdoc AbstractSigner
54
+ function _rawSignatureValidation(
55
+ bytes32 hash,
56
+ bytes calldata signature
57
+ ) internal view virtual override returns (bool) {
58
+ if (signature.length < 0x40) return false;
59
+ bytes32 r = bytes32(signature[0x00:0x20]);
60
+ bytes32 s = bytes32(signature[0x20:0x40]);
61
+ (bytes32 qx, bytes32 qy) = signer();
62
+ return P256.verify(hash, r, s, qx, qy);
63
+ }
64
+ }