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.
- package/--broadcast +0 -0
- package/--private-key +0 -0
- package/--rpc-url +0 -0
- package/.github/workflows/test.yml +38 -0
- package/.gitmodules +3 -0
- package/GbitToken_flat.sol +2 -0
- package/GbitToken_flat.solnpx +0 -0
- package/README.md +72 -0
- package/admin-cli.js +413 -0
- package/cache/solidity-files-cache.json +1 -0
- package/foundry.lock +8 -0
- package/foundry.toml +6 -0
- package/lib/forge-std/.gitattributes +1 -0
- package/lib/forge-std/.github/CODEOWNERS +1 -0
- package/lib/forge-std/.github/dependabot.yml +6 -0
- package/lib/forge-std/.github/workflows/ci.yml +125 -0
- package/lib/forge-std/.github/workflows/sync.yml +36 -0
- package/lib/forge-std/CONTRIBUTING.md +193 -0
- package/lib/forge-std/LICENSE-APACHE +203 -0
- package/lib/forge-std/LICENSE-MIT +25 -0
- package/lib/forge-std/README.md +268 -0
- package/lib/forge-std/RELEASE_CHECKLIST.md +12 -0
- package/lib/forge-std/foundry.toml +18 -0
- package/lib/forge-std/package.json +16 -0
- package/lib/forge-std/scripts/vm.py +636 -0
- package/lib/forge-std/src/Base.sol +48 -0
- package/lib/forge-std/src/Config.sol +60 -0
- package/lib/forge-std/src/LibVariable.sol +477 -0
- package/lib/forge-std/src/Script.sol +28 -0
- package/lib/forge-std/src/StdAssertions.sol +779 -0
- package/lib/forge-std/src/StdChains.sol +295 -0
- package/lib/forge-std/src/StdCheats.sol +825 -0
- package/lib/forge-std/src/StdConfig.sol +632 -0
- package/lib/forge-std/src/StdConstants.sol +30 -0
- package/lib/forge-std/src/StdError.sol +15 -0
- package/lib/forge-std/src/StdInvariant.sol +120 -0
- package/lib/forge-std/src/StdJson.sol +275 -0
- package/lib/forge-std/src/StdMath.sol +47 -0
- package/lib/forge-std/src/StdStorage.sol +475 -0
- package/lib/forge-std/src/StdStyle.sol +333 -0
- package/lib/forge-std/src/StdToml.sol +275 -0
- package/lib/forge-std/src/StdUtils.sol +200 -0
- package/lib/forge-std/src/Test.sol +32 -0
- package/lib/forge-std/src/Vm.sol +2500 -0
- package/lib/forge-std/src/console.sol +1551 -0
- package/lib/forge-std/src/console2.sol +4 -0
- package/lib/forge-std/src/interfaces/IERC1155.sol +105 -0
- package/lib/forge-std/src/interfaces/IERC165.sol +12 -0
- package/lib/forge-std/src/interfaces/IERC20.sol +43 -0
- package/lib/forge-std/src/interfaces/IERC4626.sol +190 -0
- package/lib/forge-std/src/interfaces/IERC6909.sol +72 -0
- package/lib/forge-std/src/interfaces/IERC721.sol +164 -0
- package/lib/forge-std/src/interfaces/IERC7540.sol +144 -0
- package/lib/forge-std/src/interfaces/IERC7575.sol +241 -0
- package/lib/forge-std/src/interfaces/IMulticall3.sol +68 -0
- package/lib/forge-std/src/safeconsole.sol +13248 -0
- package/lib/forge-std/test/CommonBase.t.sol +44 -0
- package/lib/forge-std/test/Config.t.sol +381 -0
- package/lib/forge-std/test/LibVariable.t.sol +452 -0
- package/lib/forge-std/test/StdAssertions.t.sol +141 -0
- package/lib/forge-std/test/StdChains.t.sol +227 -0
- package/lib/forge-std/test/StdCheats.t.sol +638 -0
- package/lib/forge-std/test/StdConstants.t.sol +38 -0
- package/lib/forge-std/test/StdError.t.sol +119 -0
- package/lib/forge-std/test/StdJson.t.sol +49 -0
- package/lib/forge-std/test/StdMath.t.sol +202 -0
- package/lib/forge-std/test/StdStorage.t.sol +485 -0
- package/lib/forge-std/test/StdStyle.t.sol +110 -0
- package/lib/forge-std/test/StdToml.t.sol +49 -0
- package/lib/forge-std/test/StdUtils.t.sol +342 -0
- package/lib/forge-std/test/Vm.t.sol +18 -0
- package/lib/forge-std/test/compilation/CompilationScript.sol +8 -0
- package/lib/forge-std/test/compilation/CompilationScriptBase.sol +8 -0
- package/lib/forge-std/test/compilation/CompilationTest.sol +8 -0
- package/lib/forge-std/test/compilation/CompilationTestBase.sol +8 -0
- package/lib/forge-std/test/fixtures/broadcast.log.json +187 -0
- package/lib/forge-std/test/fixtures/config.toml +81 -0
- package/lib/forge-std/test/fixtures/test.json +8 -0
- package/lib/forge-std/test/fixtures/test.toml +6 -0
- package/lib/openzeppelin-contracts/.changeset/blue-mirrors-agree.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/bright-webs-create.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/clean-worlds-end.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/config.json +12 -0
- package/lib/openzeppelin-contracts/.changeset/curly-pandas-flow.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/flat-ideas-count.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/fluffy-facts-brake.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/forty-ads-design.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/full-emus-hear.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/fuzzy-lizards-do.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/grumpy-cats-brake.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/khaki-crews-join.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/new-socks-deny.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/shaky-phones-mix.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/social-tools-sniff.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/spotty-plums-brush.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/stale-lizards-cheat.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/swift-planets-juggle.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/tame-monkeys-make.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/tender-pans-yawn.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/thick-banks-relate.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/vast-worlds-pull.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/whole-turkeys-swim.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/yellow-clowns-mate.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/young-corners-help.md +5 -0
- package/lib/openzeppelin-contracts/.codecov.yml +16 -0
- package/lib/openzeppelin-contracts/.editorconfig +21 -0
- package/lib/openzeppelin-contracts/.gitattributes +3 -0
- package/lib/openzeppelin-contracts/.github/CODEOWNERS +10 -0
- package/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/bug_report.md +21 -0
- package/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/config.yml +4 -0
- package/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/feature_request.md +14 -0
- package/lib/openzeppelin-contracts/.github/PULL_REQUEST_TEMPLATE.md +20 -0
- package/lib/openzeppelin-contracts/.github/actions/gas-compare/action.yml +51 -0
- package/lib/openzeppelin-contracts/.github/actions/setup/action.yml +108 -0
- package/lib/openzeppelin-contracts/.github/actions/storage-layout/action.yml +57 -0
- package/lib/openzeppelin-contracts/.github/workflows/actionlint.yml +18 -0
- package/lib/openzeppelin-contracts/.github/workflows/changeset.yml +28 -0
- package/lib/openzeppelin-contracts/.github/workflows/checks.yml +132 -0
- package/lib/openzeppelin-contracts/.github/workflows/docs.yml +19 -0
- package/lib/openzeppelin-contracts/.github/workflows/formal-verification.yml +63 -0
- package/lib/openzeppelin-contracts/.github/workflows/release-cycle.yml +212 -0
- package/lib/openzeppelin-contracts/.github/workflows/release-upgradeable.yml +95 -0
- package/lib/openzeppelin-contracts/.github/workflows/upgradeable.yml +35 -0
- package/lib/openzeppelin-contracts/.gitmodules +10 -0
- package/lib/openzeppelin-contracts/.husky/pre-commit +2 -0
- package/lib/openzeppelin-contracts/.mocharc.js +4 -0
- package/lib/openzeppelin-contracts/.prettierrc +15 -0
- package/lib/openzeppelin-contracts/.solcover.js +21 -0
- package/lib/openzeppelin-contracts/CHANGELOG.md +1364 -0
- package/lib/openzeppelin-contracts/CODE_OF_CONDUCT.md +73 -0
- package/lib/openzeppelin-contracts/CONTRIBUTING.md +36 -0
- package/lib/openzeppelin-contracts/FUNDING.json +10 -0
- package/lib/openzeppelin-contracts/GUIDELINES.md +170 -0
- package/lib/openzeppelin-contracts/LICENSE +22 -0
- package/lib/openzeppelin-contracts/README.md +122 -0
- package/lib/openzeppelin-contracts/RELEASING.md +45 -0
- package/lib/openzeppelin-contracts/SECURITY.md +43 -0
- package/lib/openzeppelin-contracts/audits/2017-03.md +292 -0
- package/lib/openzeppelin-contracts/audits/2018-10.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2022-10-Checkpoints.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2022-10-ERC4626.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2023-05-v4.9.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2023-10-v5.0.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2024-10-v5.1.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2024-12-v5.2.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2025-04-v5.3.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2025-07-v5.4.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2025-10-v5.5.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/README.md +22 -0
- package/lib/openzeppelin-contracts/contracts/access/AccessControl.sol +207 -0
- package/lib/openzeppelin-contracts/contracts/access/IAccessControl.sol +98 -0
- package/lib/openzeppelin-contracts/contracts/access/Ownable.sol +100 -0
- package/lib/openzeppelin-contracts/contracts/access/Ownable2Step.sol +67 -0
- package/lib/openzeppelin-contracts/contracts/access/README.adoc +45 -0
- package/lib/openzeppelin-contracts/contracts/access/extensions/AccessControlDefaultAdminRules.sol +372 -0
- package/lib/openzeppelin-contracts/contracts/access/extensions/AccessControlEnumerable.sol +81 -0
- package/lib/openzeppelin-contracts/contracts/access/extensions/IAccessControlDefaultAdminRules.sol +192 -0
- package/lib/openzeppelin-contracts/contracts/access/extensions/IAccessControlEnumerable.sol +31 -0
- package/lib/openzeppelin-contracts/contracts/access/manager/AccessManaged.sol +112 -0
- package/lib/openzeppelin-contracts/contracts/access/manager/AccessManager.sol +741 -0
- package/lib/openzeppelin-contracts/contracts/access/manager/AuthorityUtils.sol +36 -0
- package/lib/openzeppelin-contracts/contracts/access/manager/IAccessManaged.sol +32 -0
- package/lib/openzeppelin-contracts/contracts/access/manager/IAccessManager.sol +403 -0
- package/lib/openzeppelin-contracts/contracts/access/manager/IAuthority.sol +14 -0
- package/lib/openzeppelin-contracts/contracts/account/Account.sol +151 -0
- package/lib/openzeppelin-contracts/contracts/account/README.adoc +30 -0
- package/lib/openzeppelin-contracts/contracts/account/extensions/draft-AccountERC7579.sol +420 -0
- package/lib/openzeppelin-contracts/contracts/account/extensions/draft-AccountERC7579Hooked.sol +107 -0
- package/lib/openzeppelin-contracts/contracts/account/extensions/draft-ERC7821.sol +70 -0
- package/lib/openzeppelin-contracts/contracts/account/utils/EIP7702Utils.sol +21 -0
- package/lib/openzeppelin-contracts/contracts/account/utils/draft-ERC4337Utils.sol +279 -0
- package/lib/openzeppelin-contracts/contracts/account/utils/draft-ERC7579Utils.sol +280 -0
- package/lib/openzeppelin-contracts/contracts/crosschain/CrosschainLinked.sol +108 -0
- package/lib/openzeppelin-contracts/contracts/crosschain/ERC7786Recipient.sol +70 -0
- package/lib/openzeppelin-contracts/contracts/crosschain/README.adoc +29 -0
- package/lib/openzeppelin-contracts/contracts/crosschain/bridges/BridgeERC20.sol +36 -0
- package/lib/openzeppelin-contracts/contracts/crosschain/bridges/BridgeERC20Core.sol +79 -0
- package/lib/openzeppelin-contracts/contracts/crosschain/bridges/BridgeERC7802.sol +33 -0
- package/lib/openzeppelin-contracts/contracts/finance/README.adoc +14 -0
- package/lib/openzeppelin-contracts/contracts/finance/VestingWallet.sol +160 -0
- package/lib/openzeppelin-contracts/contracts/finance/VestingWalletCliff.sol +54 -0
- package/lib/openzeppelin-contracts/contracts/governance/Governor.sol +819 -0
- package/lib/openzeppelin-contracts/contracts/governance/IGovernor.sol +454 -0
- package/lib/openzeppelin-contracts/contracts/governance/README.adoc +197 -0
- package/lib/openzeppelin-contracts/contracts/governance/TimelockController.sol +470 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorCountingFractional.sol +190 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorCountingOverridable.sol +222 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorCountingSimple.sol +96 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorNoncesKeyed.sol +91 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorPreventLateQuorum.sol +92 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorProposalGuardian.sol +59 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSequentialProposalId.sol +75 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSettings.sol +106 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorStorage.sol +134 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSuperQuorum.sol +59 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockAccess.sol +346 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockCompound.sol +165 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockControl.sol +167 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotes.sol +63 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesQuorumFraction.sol +113 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesSuperQuorumFraction.sol +135 -0
- package/lib/openzeppelin-contracts/contracts/governance/utils/IVotes.sol +60 -0
- package/lib/openzeppelin-contracts/contracts/governance/utils/Votes.sol +253 -0
- package/lib/openzeppelin-contracts/contracts/governance/utils/VotesExtended.sol +85 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1155.sol +6 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1155MetadataURI.sol +6 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1155Receiver.sol +6 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1271.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1363.sol +86 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1363Receiver.sol +32 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1363Spender.sol +26 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC165.sol +6 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1820Implementer.sol +20 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1820Registry.sol +112 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1967.sol +24 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC20.sol +6 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC20Metadata.sol +6 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC2309.sol +19 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC2612.sol +8 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC2981.sol +26 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC3156.sol +7 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC3156FlashBorrower.sol +27 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC3156FlashLender.sol +41 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC4626.sol +230 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC4906.sol +20 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC5267.sol +28 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC5313.sol +16 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC5805.sol +9 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC6372.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC6909.sol +125 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC721.sol +6 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC721Enumerable.sol +6 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC721Metadata.sol +6 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC721Receiver.sol +6 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC7751.sol +12 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC777.sol +200 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC777Recipient.sol +35 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC777Sender.sol +35 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC7913.sol +18 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/README.adoc +138 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC1822.sol +20 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC4337.sol +255 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC6093.sol +162 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7579.sol +227 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7674.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7786.sol +64 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7802.sol +32 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7821.sol +44 -0
- package/lib/openzeppelin-contracts/contracts/metatx/ERC2771Context.sol +90 -0
- package/lib/openzeppelin-contracts/contracts/metatx/ERC2771Forwarder.sol +372 -0
- package/lib/openzeppelin-contracts/contracts/metatx/README.adoc +17 -0
- package/lib/openzeppelin-contracts/contracts/mocks/AccessManagedTarget.sol +34 -0
- package/lib/openzeppelin-contracts/contracts/mocks/AccessManagerMock.sol +20 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ArraysMock.sol +171 -0
- package/lib/openzeppelin-contracts/contracts/mocks/AuthorityMock.sol +69 -0
- package/lib/openzeppelin-contracts/contracts/mocks/Base64Dirty.sol +19 -0
- package/lib/openzeppelin-contracts/contracts/mocks/BatchCaller.sol +20 -0
- package/lib/openzeppelin-contracts/contracts/mocks/CallReceiverMock.sol +106 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ConstructorMock.sol +34 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ContextMock.sol +35 -0
- package/lib/openzeppelin-contracts/contracts/mocks/DummyImplementation.sol +61 -0
- package/lib/openzeppelin-contracts/contracts/mocks/EIP712Verifier.sol +16 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ERC1271WalletMock.sol +24 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ERC165Mock.sol +100 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ERC2771ContextMock.sol +28 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ERC3156FlashBorrowerMock.sol +53 -0
- package/lib/openzeppelin-contracts/contracts/mocks/EtherReceiverMock.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/mocks/InitializableMock.sol +130 -0
- package/lib/openzeppelin-contracts/contracts/mocks/MerkleProofCustomHashMock.sol +62 -0
- package/lib/openzeppelin-contracts/contracts/mocks/MerkleTreeMock.sol +52 -0
- package/lib/openzeppelin-contracts/contracts/mocks/MulticallHelper.sol +23 -0
- package/lib/openzeppelin-contracts/contracts/mocks/MultipleInheritanceInitializableMocks.sol +131 -0
- package/lib/openzeppelin-contracts/contracts/mocks/PausableMock.sol +31 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ReentrancyAttack.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ReentrancyMock.sol +59 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ReentrancyTransientMock.sol +59 -0
- package/lib/openzeppelin-contracts/contracts/mocks/RegressionImplementation.sol +61 -0
- package/lib/openzeppelin-contracts/contracts/mocks/SingleInheritanceInitializableMocks.sol +49 -0
- package/lib/openzeppelin-contracts/contracts/mocks/Stateless.sol +62 -0
- package/lib/openzeppelin-contracts/contracts/mocks/StorageSlotMock.sol +87 -0
- package/lib/openzeppelin-contracts/contracts/mocks/TimelockReentrant.sol +26 -0
- package/lib/openzeppelin-contracts/contracts/mocks/TransientSlotMock.sol +61 -0
- package/lib/openzeppelin-contracts/contracts/mocks/UpgradeableBeaconMock.sol +27 -0
- package/lib/openzeppelin-contracts/contracts/mocks/VotesExtendedMock.sol +42 -0
- package/lib/openzeppelin-contracts/contracts/mocks/VotesMock.sol +42 -0
- package/lib/openzeppelin-contracts/contracts/mocks/account/AccountMock.sol +181 -0
- package/lib/openzeppelin-contracts/contracts/mocks/account/modules/ERC7579Mock.sol +128 -0
- package/lib/openzeppelin-contracts/contracts/mocks/account/utils/ERC7579UtilsMock.sol +23 -0
- package/lib/openzeppelin-contracts/contracts/mocks/compound/CompTimelock.sol +174 -0
- package/lib/openzeppelin-contracts/contracts/mocks/crosschain/ERC7786GatewayMock.sol +56 -0
- package/lib/openzeppelin-contracts/contracts/mocks/crosschain/ERC7786RecipientMock.sol +31 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/AccessManagerEnumerable.sol +161 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/ERC20WithAutoMinerReward.sol +22 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/ERC4626Fees.sol +109 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/MyNFT.sol +9 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintBase.sol +25 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintMissing.sol +24 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintOnlyRole.sol +23 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlModified.sol +14 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessManagedERC20MintBase.sol +16 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/MyContractOwnable.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/account/MyAccountEIP7702.sol +20 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/account/MyFactoryAccount.sol +37 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyGovernor.sol +80 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyToken.sol +21 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenTimestampBased.sol +32 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenWrapped.sol +28 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC1155/GameItems.sol +21 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC1155/MyERC115HolderContract.sol +7 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC20/GLDToken.sol +11 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC6909/ERC6909GameItems.sol +26 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC721/GameItem.sol +19 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/utilities/Base64NFT.sol +27 -0
- package/lib/openzeppelin-contracts/contracts/mocks/docs/utilities/Multicall.sol +15 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorCountingOverridableMock.sol +18 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorFractionalMock.sol +14 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorMock.sol +14 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorNoncesKeyedMock.sol +44 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorPreventLateQuorumMock.sol +40 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorProposalGuardianMock.sol +27 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorSequentialProposalIdMock.sol +39 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorStorageMock.sol +79 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorSuperQuorumMock.sol +95 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockAccessMock.sol +70 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockCompoundMock.sol +69 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockControlMock.sol +69 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorVoteMock.sol +20 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorVotesSuperQuorumFractionMock.sol +37 -0
- package/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorWithParamsMock.sol +51 -0
- package/lib/openzeppelin-contracts/contracts/mocks/proxy/BadBeacon.sol +11 -0
- package/lib/openzeppelin-contracts/contracts/mocks/proxy/ClashingImplementation.sol +19 -0
- package/lib/openzeppelin-contracts/contracts/mocks/proxy/ERC1967ProxyUnsafe.sol +13 -0
- package/lib/openzeppelin-contracts/contracts/mocks/proxy/UUPSUpgradeableMock.sol +35 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1155ReceiverMock.sol +74 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363ForceApproveMock.sol +13 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363NoReturnMock.sol +33 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363ReceiverMock.sol +52 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363ReturnFalseMock.sol +34 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363SpenderMock.sol +47 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ApprovalMock.sol +10 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20BridgeableMock.sol +30 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20DecimalsMock.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ExcessDecimalsMock.sol +9 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20FlashMintMock.sol +26 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ForceApproveMock.sol +13 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20GetterHelper.sol +38 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20Mock.sol +16 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20MulticallMock.sol +8 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20NoReturnMock.sol +30 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20Reentrant.sol +39 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ReturnFalseMock.sol +19 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20VotesAdditionalCheckpointsMock.sol +31 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20VotesLegacyMock.sol +253 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC20VotesTimestampMock.sol +29 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC4626LimitsMock.sol +23 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC4626Mock.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC4626OffsetMock.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC4646FeesMock.sol +40 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ConsecutiveEnumerableMock.sol +42 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ConsecutiveMock.sol +61 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ReceiverMock.sol +47 -0
- package/lib/openzeppelin-contracts/contracts/mocks/token/ERC721URIStorageMock.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/mocks/utils/cryptography/ERC7739Mock.sol +12 -0
- package/lib/openzeppelin-contracts/contracts/package.json +32 -0
- package/lib/openzeppelin-contracts/contracts/proxy/Clones.sol +294 -0
- package/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Proxy.sol +62 -0
- package/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Utils.sol +177 -0
- package/lib/openzeppelin-contracts/contracts/proxy/Proxy.sol +69 -0
- package/lib/openzeppelin-contracts/contracts/proxy/README.adoc +87 -0
- package/lib/openzeppelin-contracts/contracts/proxy/beacon/BeaconProxy.sol +57 -0
- package/lib/openzeppelin-contracts/contracts/proxy/beacon/IBeacon.sol +16 -0
- package/lib/openzeppelin-contracts/contracts/proxy/beacon/UpgradeableBeacon.sol +70 -0
- package/lib/openzeppelin-contracts/contracts/proxy/transparent/ProxyAdmin.sol +45 -0
- package/lib/openzeppelin-contracts/contracts/proxy/transparent/TransparentUpgradeableProxy.sol +118 -0
- package/lib/openzeppelin-contracts/contracts/proxy/utils/Initializable.sol +238 -0
- package/lib/openzeppelin-contracts/contracts/proxy/utils/UUPSUpgradeable.sol +148 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/ERC1155.sol +416 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155.sol +123 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155Receiver.sol +59 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/README.adoc +43 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Burnable.sol +28 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Pausable.sol +38 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Supply.sol +88 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155URIStorage.sol +58 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/IERC1155MetadataURI.sol +20 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Holder.sol +42 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Utils.sol +88 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/ERC20.sol +305 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/IERC20.sol +79 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/README.adoc +81 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC1363.sol +135 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Burnable.sol +39 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Capped.sol +54 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Crosschain.sol +38 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20FlashMint.sol +130 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Pausable.sol +33 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Permit.sol +77 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Votes.sol +83 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Wrapper.sol +89 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC4626.sol +315 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Metadata.sol +26 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Permit.sol +90 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-ERC20Bridgeable.sol +51 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-ERC20TemporaryApproval.sol +119 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/utils/ERC1363Utils.sol +95 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/utils/SafeERC20.sol +280 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC6909/ERC6909.sol +224 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC6909/README.adoc +27 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/ERC6909ContentURI.sol +59 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/ERC6909Metadata.sol +83 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/ERC6909TokenSupply.sol +41 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/ERC721.sol +433 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/IERC721.sol +135 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/IERC721Receiver.sol +28 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/README.adoc +69 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Burnable.sol +26 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Consecutive.sol +176 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Enumerable.sol +165 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Pausable.sol +37 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Royalty.sol +26 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721URIStorage.sol +62 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Votes.sol +47 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Wrapper.sol +102 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/IERC721Enumerable.sol +29 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/IERC721Metadata.sol +27 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/utils/ERC721Holder.sol +26 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/utils/ERC721Utils.sol +50 -0
- package/lib/openzeppelin-contracts/contracts/token/common/ERC2981.sol +139 -0
- package/lib/openzeppelin-contracts/contracts/token/common/README.adoc +10 -0
- package/lib/openzeppelin-contracts/contracts/utils/Address.sol +167 -0
- package/lib/openzeppelin-contracts/contracts/utils/Arrays.sol +888 -0
- package/lib/openzeppelin-contracts/contracts/utils/Base58.sol +240 -0
- package/lib/openzeppelin-contracts/contracts/utils/Base64.sol +234 -0
- package/lib/openzeppelin-contracts/contracts/utils/Blockhash.sol +54 -0
- package/lib/openzeppelin-contracts/contracts/utils/Bytes.sol +332 -0
- package/lib/openzeppelin-contracts/contracts/utils/CAIP10.sol +54 -0
- package/lib/openzeppelin-contracts/contracts/utils/CAIP2.sol +51 -0
- package/lib/openzeppelin-contracts/contracts/utils/Calldata.sol +25 -0
- package/lib/openzeppelin-contracts/contracts/utils/Comparators.sol +19 -0
- package/lib/openzeppelin-contracts/contracts/utils/Context.sol +28 -0
- package/lib/openzeppelin-contracts/contracts/utils/Create2.sol +91 -0
- package/lib/openzeppelin-contracts/contracts/utils/Errors.sol +34 -0
- package/lib/openzeppelin-contracts/contracts/utils/LowLevelCall.sol +127 -0
- package/lib/openzeppelin-contracts/contracts/utils/Memory.sol +146 -0
- package/lib/openzeppelin-contracts/contracts/utils/Multicall.sol +37 -0
- package/lib/openzeppelin-contracts/contracts/utils/Nonces.sol +46 -0
- package/lib/openzeppelin-contracts/contracts/utils/NoncesKeyed.sol +74 -0
- package/lib/openzeppelin-contracts/contracts/utils/Packing.sol +1656 -0
- package/lib/openzeppelin-contracts/contracts/utils/Panic.sol +57 -0
- package/lib/openzeppelin-contracts/contracts/utils/Pausable.sol +112 -0
- package/lib/openzeppelin-contracts/contracts/utils/README.adoc +160 -0
- package/lib/openzeppelin-contracts/contracts/utils/RLP.sol +476 -0
- package/lib/openzeppelin-contracts/contracts/utils/ReentrancyGuard.sol +119 -0
- package/lib/openzeppelin-contracts/contracts/utils/ReentrancyGuardTransient.sol +84 -0
- package/lib/openzeppelin-contracts/contracts/utils/RelayedCall.sol +133 -0
- package/lib/openzeppelin-contracts/contracts/utils/ShortStrings.sol +122 -0
- package/lib/openzeppelin-contracts/contracts/utils/SlotDerivation.sol +155 -0
- package/lib/openzeppelin-contracts/contracts/utils/StorageSlot.sol +143 -0
- package/lib/openzeppelin-contracts/contracts/utils/Strings.sol +508 -0
- package/lib/openzeppelin-contracts/contracts/utils/TransientSlot.sol +183 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/ECDSA.sol +284 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/EIP712.sol +160 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/Hashes.sol +31 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/MerkleProof.sol +510 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/MessageHashUtils.sol +228 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/P256.sol +408 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/README.adoc +76 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/RSA.sol +154 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/SignatureChecker.sol +191 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/TrieProof.sol +230 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/WebAuthn.sol +261 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/draft-ERC7739Utils.sol +207 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/AbstractSigner.sol +23 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/MultiSignerERC7913.sol +259 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/MultiSignerERC7913Weighted.sol +208 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerECDSA.sol +56 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerEIP7702.sol +25 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerERC7913.sol +63 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerP256.sol +64 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerRSA.sol +65 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerWebAuthn.sol +51 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/draft-ERC7739.sol +98 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/verifiers/ERC7913P256Verifier.sol +29 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/verifiers/ERC7913RSAVerifier.sol +23 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/verifiers/ERC7913WebAuthnVerifier.sol +35 -0
- package/lib/openzeppelin-contracts/contracts/utils/draft-InteroperableAddress.sol +235 -0
- package/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165.sol +25 -0
- package/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165Checker.sol +142 -0
- package/lib/openzeppelin-contracts/contracts/utils/introspection/IERC165.sol +25 -0
- package/lib/openzeppelin-contracts/contracts/utils/math/Math.sol +763 -0
- package/lib/openzeppelin-contracts/contracts/utils/math/SafeCast.sol +1162 -0
- package/lib/openzeppelin-contracts/contracts/utils/math/SignedMath.sol +68 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/Accumulators.sol +130 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/BitMaps.sol +60 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/Checkpoints.sol +833 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/CircularBuffer.sol +152 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/DoubleEndedQueue.sol +237 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/EnumerableMap.sol +1443 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/EnumerableSet.sol +895 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/Heap.sol +259 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/MerkleTree.sol +267 -0
- package/lib/openzeppelin-contracts/contracts/utils/types/Time.sol +133 -0
- package/lib/openzeppelin-contracts/contracts/vendor/compound/ICompoundTimelock.sol +86 -0
- package/lib/openzeppelin-contracts/contracts/vendor/compound/LICENSE +11 -0
- package/lib/openzeppelin-contracts/docs/README.md +16 -0
- package/lib/openzeppelin-contracts/docs/antora.yml +7 -0
- package/lib/openzeppelin-contracts/docs/config.js +21 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-control-multiple.svg +97 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-manager-functions.svg +47 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-manager.svg +99 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3a.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3b.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-6.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-deposit.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-mint.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-linear.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglog.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglogext.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-exec.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-vote.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/nav.adoc +29 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/access-control.adoc +339 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/account-abstraction.adoc +100 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/accounts.adoc +354 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/backwards-compatibility.adoc +50 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/eoa-delegation.adoc +143 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc1155.adoc +118 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20-supply.adoc +71 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20.adoc +67 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc4626.adoc +214 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc6909.adoc +47 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc721.adoc +58 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/extending-contracts.adoc +51 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/faq.adoc +13 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/governance.adoc +242 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/index.adoc +100 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/multisig.adoc +308 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/tokens.adoc +31 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/upgradeable.adoc +77 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/utilities.adoc +634 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/wizard.adoc +15 -0
- package/lib/openzeppelin-contracts/docs/templates/contract.hbs +141 -0
- package/lib/openzeppelin-contracts/docs/templates/helpers.js +46 -0
- package/lib/openzeppelin-contracts/docs/templates/page.hbs +4 -0
- package/lib/openzeppelin-contracts/docs/templates/properties.js +88 -0
- package/lib/openzeppelin-contracts/eslint.config.mjs +29 -0
- package/lib/openzeppelin-contracts/foundry.toml +20 -0
- package/lib/openzeppelin-contracts/fv/Makefile +54 -0
- package/lib/openzeppelin-contracts/fv/README.md +60 -0
- package/lib/openzeppelin-contracts/fv/diff/access_manager_AccessManager.sol.patch +97 -0
- package/lib/openzeppelin-contracts/fv/diff/account_extensions_draft-AccountERC7579.sol.patch +25 -0
- package/lib/openzeppelin-contracts/fv/diff/token_ERC721_ERC721.sol.patch +11 -0
- package/lib/openzeppelin-contracts/fv/harnesses/AccessControlDefaultAdminRulesHarness.sol +46 -0
- package/lib/openzeppelin-contracts/fv/harnesses/AccessControlHarness.sol +6 -0
- package/lib/openzeppelin-contracts/fv/harnesses/AccessManagedHarness.sol +36 -0
- package/lib/openzeppelin-contracts/fv/harnesses/AccessManagerHarness.sol +116 -0
- package/lib/openzeppelin-contracts/fv/harnesses/AccountHarness.sol +60 -0
- package/lib/openzeppelin-contracts/fv/harnesses/DoubleEndedQueueHarness.sol +58 -0
- package/lib/openzeppelin-contracts/fv/harnesses/ERC20FlashMintHarness.sol +36 -0
- package/lib/openzeppelin-contracts/fv/harnesses/ERC20PermitHarness.sol +16 -0
- package/lib/openzeppelin-contracts/fv/harnesses/ERC20WrapperHarness.sol +22 -0
- package/lib/openzeppelin-contracts/fv/harnesses/ERC3156FlashBorrowerHarness.sol +13 -0
- package/lib/openzeppelin-contracts/fv/harnesses/ERC721Harness.sol +37 -0
- package/lib/openzeppelin-contracts/fv/harnesses/ERC721ReceiverHarness.sol +11 -0
- package/lib/openzeppelin-contracts/fv/harnesses/EnumerableMapHarness.sol +55 -0
- package/lib/openzeppelin-contracts/fv/harnesses/EnumerableSetHarness.sol +35 -0
- package/lib/openzeppelin-contracts/fv/harnesses/InitializableHarness.sol +23 -0
- package/lib/openzeppelin-contracts/fv/harnesses/NoncesHarness.sol +14 -0
- package/lib/openzeppelin-contracts/fv/harnesses/Ownable2StepHarness.sol +10 -0
- package/lib/openzeppelin-contracts/fv/harnesses/OwnableHarness.sol +10 -0
- package/lib/openzeppelin-contracts/fv/harnesses/PausableHarness.sol +18 -0
- package/lib/openzeppelin-contracts/fv/harnesses/TimelockControllerHarness.sol +13 -0
- package/lib/openzeppelin-contracts/fv/reports/2021-10.pdf +0 -0
- package/lib/openzeppelin-contracts/fv/reports/2022-03.pdf +0 -0
- package/lib/openzeppelin-contracts/fv/reports/2022-05.pdf +0 -0
- package/lib/openzeppelin-contracts/fv/run.js +68 -0
- package/lib/openzeppelin-contracts/fv/specs/AccessControl.conf +8 -0
- package/lib/openzeppelin-contracts/fv/specs/AccessControl.spec +119 -0
- package/lib/openzeppelin-contracts/fv/specs/AccessControlDefaultAdminRules.conf +8 -0
- package/lib/openzeppelin-contracts/fv/specs/AccessControlDefaultAdminRules.spec +467 -0
- package/lib/openzeppelin-contracts/fv/specs/AccessManaged.conf +14 -0
- package/lib/openzeppelin-contracts/fv/specs/AccessManaged.spec +49 -0
- package/lib/openzeppelin-contracts/fv/specs/AccessManager.conf +10 -0
- package/lib/openzeppelin-contracts/fv/specs/AccessManager.spec +837 -0
- package/lib/openzeppelin-contracts/fv/specs/Account.conf +9 -0
- package/lib/openzeppelin-contracts/fv/specs/Account.spec +490 -0
- package/lib/openzeppelin-contracts/fv/specs/DoubleEndedQueue.conf +8 -0
- package/lib/openzeppelin-contracts/fv/specs/DoubleEndedQueue.spec +300 -0
- package/lib/openzeppelin-contracts/fv/specs/ERC20.conf +9 -0
- package/lib/openzeppelin-contracts/fv/specs/ERC20.spec +352 -0
- package/lib/openzeppelin-contracts/fv/specs/ERC20FlashMint.conf +10 -0
- package/lib/openzeppelin-contracts/fv/specs/ERC20FlashMint.spec +55 -0
- package/lib/openzeppelin-contracts/fv/specs/ERC20Wrapper.conf +13 -0
- package/lib/openzeppelin-contracts/fv/specs/ERC20Wrapper.spec +226 -0
- package/lib/openzeppelin-contracts/fv/specs/ERC721.conf +10 -0
- package/lib/openzeppelin-contracts/fv/specs/ERC721.spec +695 -0
- package/lib/openzeppelin-contracts/fv/specs/EnumerableMap.conf +8 -0
- package/lib/openzeppelin-contracts/fv/specs/EnumerableMap.spec +364 -0
- package/lib/openzeppelin-contracts/fv/specs/EnumerableSet.conf +8 -0
- package/lib/openzeppelin-contracts/fv/specs/EnumerableSet.spec +272 -0
- package/lib/openzeppelin-contracts/fv/specs/Initializable.conf +8 -0
- package/lib/openzeppelin-contracts/fv/specs/Initializable.spec +176 -0
- package/lib/openzeppelin-contracts/fv/specs/Nonces.conf +8 -0
- package/lib/openzeppelin-contracts/fv/specs/Nonces.spec +92 -0
- package/lib/openzeppelin-contracts/fv/specs/Ownable.conf +8 -0
- package/lib/openzeppelin-contracts/fv/specs/Ownable.spec +77 -0
- package/lib/openzeppelin-contracts/fv/specs/Ownable2Step.conf +8 -0
- package/lib/openzeppelin-contracts/fv/specs/Ownable2Step.spec +108 -0
- package/lib/openzeppelin-contracts/fv/specs/Pausable.conf +8 -0
- package/lib/openzeppelin-contracts/fv/specs/Pausable.spec +96 -0
- package/lib/openzeppelin-contracts/fv/specs/TimelockController.conf +10 -0
- package/lib/openzeppelin-contracts/fv/specs/TimelockController.spec +299 -0
- package/lib/openzeppelin-contracts/fv/specs/helpers/helpers.spec +13 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IAccessControl.spec +8 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IAccessControlDefaultAdminRules.spec +36 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IAccessManaged.spec +5 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IAccessManager.spec +33 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IAccount.spec +34 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IERC20.spec +11 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IERC2612.spec +5 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IERC3156FlashBorrower.spec +3 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IERC3156FlashLender.spec +5 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IERC5313.spec +3 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IERC721.spec +17 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IERC721Receiver.spec +3 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IOwnable.spec +5 -0
- package/lib/openzeppelin-contracts/fv/specs/methods/IOwnable2Step.spec +7 -0
- package/lib/openzeppelin-contracts/fv-requirements.txt +4 -0
- package/lib/openzeppelin-contracts/hardhat/async-test-sanity.js +10 -0
- package/lib/openzeppelin-contracts/hardhat/env-artifacts.js +29 -0
- package/lib/openzeppelin-contracts/hardhat/ignore-unreachable-warnings.js +45 -0
- package/lib/openzeppelin-contracts/hardhat/remappings.js +18 -0
- package/lib/openzeppelin-contracts/hardhat/skip-foundry-tests.js +6 -0
- package/lib/openzeppelin-contracts/hardhat/task-test-get-files.js +25 -0
- package/lib/openzeppelin-contracts/hardhat.config.js +124 -0
- package/lib/openzeppelin-contracts/logo.svg +15 -0
- package/lib/openzeppelin-contracts/netlify.toml +3 -0
- package/lib/openzeppelin-contracts/package-lock.json +11140 -0
- package/lib/openzeppelin-contracts/package.json +108 -0
- package/lib/openzeppelin-contracts/remappings.txt +1 -0
- package/lib/openzeppelin-contracts/renovate.json +4 -0
- package/lib/openzeppelin-contracts/scripts/checks/compare-layout.js +28 -0
- package/lib/openzeppelin-contracts/scripts/checks/compareGasReports.js +249 -0
- package/lib/openzeppelin-contracts/scripts/checks/coverage.sh +24 -0
- package/lib/openzeppelin-contracts/scripts/checks/extract-layout.js +39 -0
- package/lib/openzeppelin-contracts/scripts/checks/generation.sh +6 -0
- package/lib/openzeppelin-contracts/scripts/checks/inheritance-ordering.js +55 -0
- package/lib/openzeppelin-contracts/scripts/checks/pragma-validity.js +45 -0
- package/lib/openzeppelin-contracts/scripts/fetch-common-contracts.js +50 -0
- package/lib/openzeppelin-contracts/scripts/gen-nav.js +81 -0
- package/lib/openzeppelin-contracts/scripts/generate/format-lines.js +16 -0
- package/lib/openzeppelin-contracts/scripts/generate/helpers/sanitize.js +5 -0
- package/lib/openzeppelin-contracts/scripts/generate/run.js +61 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Arrays.js +505 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Arrays.opts.js +9 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.js +242 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.opts.js +18 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.t.js +141 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Enumerable.opts.js +56 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableMap.js +464 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableSet.js +470 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/MerkleProof.js +186 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/MerkleProof.opts.js +11 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Packing.js +92 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Packing.opts.js +3 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Packing.t.js +48 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/SafeCast.js +136 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Slot.opts.js +15 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/SlotDerivation.js +119 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/SlotDerivation.t.js +127 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/StorageSlot.js +77 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/StorageSlotMock.js +57 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/TransientSlot.js +80 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/TransientSlotMock.js +35 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/conversion.js +34 -0
- package/lib/openzeppelin-contracts/scripts/get-contracts-metadata.js +55 -0
- package/lib/openzeppelin-contracts/scripts/git-user-config.sh +6 -0
- package/lib/openzeppelin-contracts/scripts/helpers.js +7 -0
- package/lib/openzeppelin-contracts/scripts/minimize-pragma.js +140 -0
- package/lib/openzeppelin-contracts/scripts/prepack.sh +23 -0
- package/lib/openzeppelin-contracts/scripts/prepare-docs.sh +26 -0
- package/lib/openzeppelin-contracts/scripts/release/format-changelog.js +33 -0
- package/lib/openzeppelin-contracts/scripts/release/synchronize-versions.js +15 -0
- package/lib/openzeppelin-contracts/scripts/release/update-comment.js +34 -0
- package/lib/openzeppelin-contracts/scripts/release/version.sh +11 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/check-upgradeable.sh +27 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/exit-prerelease.sh +8 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/github-release.js +48 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/integrity-check.sh +20 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/pack.sh +26 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/publish.sh +26 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/rerun.js +7 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/set-changesets-pr-title.js +17 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/start.sh +35 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/state.js +112 -0
- package/lib/openzeppelin-contracts/scripts/remove-ignored-artifacts.js +45 -0
- package/lib/openzeppelin-contracts/scripts/set-max-old-space-size.sh +10 -0
- package/lib/openzeppelin-contracts/scripts/solc-versions.js +15 -0
- package/lib/openzeppelin-contracts/scripts/solhint-custom/index.js +118 -0
- package/lib/openzeppelin-contracts/scripts/solhint-custom/package.json +8 -0
- package/lib/openzeppelin-contracts/scripts/update-docs-branch.js +65 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/README.md +21 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/alias/Initializable.sol +5 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/alias/UUPSUpgradeable.sol +5 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/patch-apply.sh +19 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/patch-save.sh +18 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/transpile-onto.sh +54 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/transpile.sh +50 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/upgradeable.patch +390 -0
- package/lib/openzeppelin-contracts/slither.config.json +4 -0
- package/lib/openzeppelin-contracts/solhint.config.js +29 -0
- package/lib/openzeppelin-contracts/test/TESTING.md +3 -0
- package/lib/openzeppelin-contracts/test/access/AccessControl.behavior.js +874 -0
- package/lib/openzeppelin-contracts/test/access/AccessControl.test.js +19 -0
- package/lib/openzeppelin-contracts/test/access/Ownable.test.js +79 -0
- package/lib/openzeppelin-contracts/test/access/Ownable2Step.test.js +102 -0
- package/lib/openzeppelin-contracts/test/access/extensions/AccessControlDefaultAdminRules.test.js +32 -0
- package/lib/openzeppelin-contracts/test/access/extensions/AccessControlEnumerable.test.js +24 -0
- package/lib/openzeppelin-contracts/test/access/manager/AccessManaged.test.js +146 -0
- package/lib/openzeppelin-contracts/test/access/manager/AccessManager.behavior.js +257 -0
- package/lib/openzeppelin-contracts/test/access/manager/AccessManager.predicate.js +456 -0
- package/lib/openzeppelin-contracts/test/access/manager/AccessManager.test.js +2489 -0
- package/lib/openzeppelin-contracts/test/access/manager/AuthorityUtils.test.js +112 -0
- package/lib/openzeppelin-contracts/test/account/Account.behavior.js +144 -0
- package/lib/openzeppelin-contracts/test/account/Account.test.js +48 -0
- package/lib/openzeppelin-contracts/test/account/AccountECDSA.test.js +52 -0
- package/lib/openzeppelin-contracts/test/account/AccountEIP7702.t.sol +116 -0
- package/lib/openzeppelin-contracts/test/account/AccountEIP7702.test.js +52 -0
- package/lib/openzeppelin-contracts/test/account/AccountERC7913.test.js +138 -0
- package/lib/openzeppelin-contracts/test/account/AccountMultiSigner.test.js +326 -0
- package/lib/openzeppelin-contracts/test/account/AccountMultiSignerWeighted.test.js +312 -0
- package/lib/openzeppelin-contracts/test/account/AccountP256.test.js +58 -0
- package/lib/openzeppelin-contracts/test/account/AccountRSA.test.js +58 -0
- package/lib/openzeppelin-contracts/test/account/AccountWebAuthn.test.js +88 -0
- package/lib/openzeppelin-contracts/test/account/examples/AccountEIP7702WithModulesMock.test.js +99 -0
- package/lib/openzeppelin-contracts/test/account/extensions/AccountERC7579.behavior.js +621 -0
- package/lib/openzeppelin-contracts/test/account/extensions/AccountERC7579.test.js +60 -0
- package/lib/openzeppelin-contracts/test/account/extensions/AccountERC7579Hooked.test.js +60 -0
- package/lib/openzeppelin-contracts/test/account/extensions/ERC7821.behavior.js +145 -0
- package/lib/openzeppelin-contracts/test/account/utils/EIP7702Utils.test.js +53 -0
- package/lib/openzeppelin-contracts/test/account/utils/draft-ERC4337Utils.test.js +594 -0
- package/lib/openzeppelin-contracts/test/account/utils/draft-ERC7579Utils.t.sol +434 -0
- package/lib/openzeppelin-contracts/test/account/utils/draft-ERC7579Utils.test.js +399 -0
- package/lib/openzeppelin-contracts/test/crosschain/BridgeERC20.behavior.js +163 -0
- package/lib/openzeppelin-contracts/test/crosschain/BridgeERC20.test.js +46 -0
- package/lib/openzeppelin-contracts/test/crosschain/ERC7786Recipient.test.js +73 -0
- package/lib/openzeppelin-contracts/test/finance/VestingWallet.behavior.js +87 -0
- package/lib/openzeppelin-contracts/test/finance/VestingWallet.test.js +65 -0
- package/lib/openzeppelin-contracts/test/finance/VestingWalletCliff.test.js +70 -0
- package/lib/openzeppelin-contracts/test/governance/Governor.t.sol +59 -0
- package/lib/openzeppelin-contracts/test/governance/Governor.test.js +980 -0
- package/lib/openzeppelin-contracts/test/governance/TimelockController.test.js +1279 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorCountingFractional.test.js +248 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorCountingOverridable.test.js +346 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorERC721.test.js +131 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorNoncesKeyed.test.js +243 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorPreventLateQuorum.test.js +185 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorProposalGuardian.test.js +132 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorSequentialProposalId.test.js +202 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorStorage.test.js +175 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorSuperQuorum.test.js +168 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorSuperQuorumGreaterThanQuorum.t.sol +83 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockAccess.test.js +864 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockCompound.test.js +448 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockControl.test.js +504 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorVotesQuorumFraction.test.js +165 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorVotesSuperQuorumFraction.test.js +160 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorWithParams.test.js +245 -0
- package/lib/openzeppelin-contracts/test/governance/utils/ERC6372.behavior.js +28 -0
- package/lib/openzeppelin-contracts/test/governance/utils/Votes.behavior.js +325 -0
- package/lib/openzeppelin-contracts/test/governance/utils/Votes.test.js +102 -0
- package/lib/openzeppelin-contracts/test/governance/utils/VotesExtended.test.js +152 -0
- package/lib/openzeppelin-contracts/test/helpers/access-manager.js +85 -0
- package/lib/openzeppelin-contracts/test/helpers/account.js +16 -0
- package/lib/openzeppelin-contracts/test/helpers/chains.js +56 -0
- package/lib/openzeppelin-contracts/test/helpers/constants.js +7 -0
- package/lib/openzeppelin-contracts/test/helpers/deploy.js +14 -0
- package/lib/openzeppelin-contracts/test/helpers/eip712-types.js +61 -0
- package/lib/openzeppelin-contracts/test/helpers/eip712.js +45 -0
- package/lib/openzeppelin-contracts/test/helpers/enums.js +15 -0
- package/lib/openzeppelin-contracts/test/helpers/erc4337.js +244 -0
- package/lib/openzeppelin-contracts/test/helpers/erc7579.js +58 -0
- package/lib/openzeppelin-contracts/test/helpers/erc7739.js +118 -0
- package/lib/openzeppelin-contracts/test/helpers/governance.js +218 -0
- package/lib/openzeppelin-contracts/test/helpers/iterate.js +41 -0
- package/lib/openzeppelin-contracts/test/helpers/math.js +33 -0
- package/lib/openzeppelin-contracts/test/helpers/methods.js +14 -0
- package/lib/openzeppelin-contracts/test/helpers/precompiles.js +12 -0
- package/lib/openzeppelin-contracts/test/helpers/random.js +26 -0
- package/lib/openzeppelin-contracts/test/helpers/signers.js +222 -0
- package/lib/openzeppelin-contracts/test/helpers/storage.js +48 -0
- package/lib/openzeppelin-contracts/test/helpers/strings.js +5 -0
- package/lib/openzeppelin-contracts/test/helpers/time.js +33 -0
- package/lib/openzeppelin-contracts/test/helpers/trie.js +79 -0
- package/lib/openzeppelin-contracts/test/helpers/txpool.js +28 -0
- package/lib/openzeppelin-contracts/test/metatx/ERC2771Context.test.js +109 -0
- package/lib/openzeppelin-contracts/test/metatx/ERC2771Forwarder.t.sol +279 -0
- package/lib/openzeppelin-contracts/test/metatx/ERC2771Forwarder.test.js +384 -0
- package/lib/openzeppelin-contracts/test/proxy/Clones.behaviour.js +160 -0
- package/lib/openzeppelin-contracts/test/proxy/Clones.t.sol +91 -0
- package/lib/openzeppelin-contracts/test/proxy/Clones.test.js +177 -0
- package/lib/openzeppelin-contracts/test/proxy/ERC1967/ERC1967Proxy.test.js +36 -0
- package/lib/openzeppelin-contracts/test/proxy/ERC1967/ERC1967Utils.test.js +162 -0
- package/lib/openzeppelin-contracts/test/proxy/Proxy.behaviour.js +198 -0
- package/lib/openzeppelin-contracts/test/proxy/beacon/BeaconProxy.test.js +141 -0
- package/lib/openzeppelin-contracts/test/proxy/beacon/UpgradeableBeacon.test.js +55 -0
- package/lib/openzeppelin-contracts/test/proxy/transparent/ProxyAdmin.test.js +82 -0
- package/lib/openzeppelin-contracts/test/proxy/transparent/TransparentUpgradeableProxy.behaviour.js +367 -0
- package/lib/openzeppelin-contracts/test/proxy/transparent/TransparentUpgradeableProxy.test.js +28 -0
- package/lib/openzeppelin-contracts/test/proxy/utils/Initializable.test.js +216 -0
- package/lib/openzeppelin-contracts/test/proxy/utils/UUPSUpgradeable.test.js +120 -0
- package/lib/openzeppelin-contracts/test/sanity.test.js +27 -0
- package/lib/openzeppelin-contracts/test/token/ERC1155/ERC1155.behavior.js +865 -0
- package/lib/openzeppelin-contracts/test/token/ERC1155/ERC1155.test.js +258 -0
- package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Burnable.test.js +66 -0
- package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Pausable.test.js +105 -0
- package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Supply.test.js +119 -0
- package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155URIStorage.test.js +70 -0
- package/lib/openzeppelin-contracts/test/token/ERC1155/utils/ERC1155Holder.test.js +56 -0
- package/lib/openzeppelin-contracts/test/token/ERC1155/utils/ERC1155Utils.test.js +299 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/ERC20.behavior.js +269 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/ERC20.test.js +199 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC1363.test.js +370 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Burnable.test.js +105 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Capped.test.js +55 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Crosschain.test.js +83 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20FlashMint.test.js +164 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Pausable.test.js +129 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Permit.test.js +109 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Votes.test.js +546 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Wrapper.test.js +203 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC4626.t.sol +41 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC4626.test.js +888 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/draft-ERC20Bridgeable.test.js +89 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/draft-ERC20TemporaryApproval.test.js +142 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/utils/SafeERC20.test.js +463 -0
- package/lib/openzeppelin-contracts/test/token/ERC6909/ERC6909.behavior.js +216 -0
- package/lib/openzeppelin-contracts/test/token/ERC6909/ERC6909.test.js +104 -0
- package/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909ContentURI.test.js +52 -0
- package/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909Metadata.test.js +62 -0
- package/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909TokenSupply.test.js +56 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/ERC721.behavior.js +954 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/ERC721.test.js +23 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/ERC721Enumerable.test.js +28 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Burnable.test.js +77 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Consecutive.t.sol +187 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Consecutive.test.js +228 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Pausable.test.js +81 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Royalty.test.js +57 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721URIStorage.test.js +134 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Votes.test.js +194 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Wrapper.test.js +201 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/utils/ERC721Holder.test.js +20 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/utils/ERC721Utils.test.js +94 -0
- package/lib/openzeppelin-contracts/test/token/common/ERC2981.behavior.js +152 -0
- package/lib/openzeppelin-contracts/test/utils/Address.test.js +332 -0
- package/lib/openzeppelin-contracts/test/utils/Arrays.t.sol +416 -0
- package/lib/openzeppelin-contracts/test/utils/Arrays.test.js +284 -0
- package/lib/openzeppelin-contracts/test/utils/Base58.t.sol +24 -0
- package/lib/openzeppelin-contracts/test/utils/Base58.test.js +65 -0
- package/lib/openzeppelin-contracts/test/utils/Base64.t.sol +36 -0
- package/lib/openzeppelin-contracts/test/utils/Base64.test.js +79 -0
- package/lib/openzeppelin-contracts/test/utils/Blockhash.t.sol +101 -0
- package/lib/openzeppelin-contracts/test/utils/Blockhash.test.js +59 -0
- package/lib/openzeppelin-contracts/test/utils/Bytes.t.sol +322 -0
- package/lib/openzeppelin-contracts/test/utils/Bytes.test.js +371 -0
- package/lib/openzeppelin-contracts/test/utils/CAIP.test.js +56 -0
- package/lib/openzeppelin-contracts/test/utils/Calldata.test.js +22 -0
- package/lib/openzeppelin-contracts/test/utils/Context.behavior.js +48 -0
- package/lib/openzeppelin-contracts/test/utils/Context.test.js +18 -0
- package/lib/openzeppelin-contracts/test/utils/Create2.t.sol +17 -0
- package/lib/openzeppelin-contracts/test/utils/Create2.test.js +190 -0
- package/lib/openzeppelin-contracts/test/utils/LowLevelCall.test.js +257 -0
- package/lib/openzeppelin-contracts/test/utils/Memory.t.sol +63 -0
- package/lib/openzeppelin-contracts/test/utils/Memory.test.js +106 -0
- package/lib/openzeppelin-contracts/test/utils/Multicall.test.js +72 -0
- package/lib/openzeppelin-contracts/test/utils/Nonces.behavior.js +189 -0
- package/lib/openzeppelin-contracts/test/utils/Nonces.test.js +16 -0
- package/lib/openzeppelin-contracts/test/utils/NoncesKeyed.t.sol +51 -0
- package/lib/openzeppelin-contracts/test/utils/NoncesKeyed.test.js +17 -0
- package/lib/openzeppelin-contracts/test/utils/Packing.t.sol +993 -0
- package/lib/openzeppelin-contracts/test/utils/Packing.test.js +70 -0
- package/lib/openzeppelin-contracts/test/utils/Panic.test.js +37 -0
- package/lib/openzeppelin-contracts/test/utils/Pausable.test.js +90 -0
- package/lib/openzeppelin-contracts/test/utils/RLP.t.sol +144 -0
- package/lib/openzeppelin-contracts/test/utils/RLP.test.js +224 -0
- package/lib/openzeppelin-contracts/test/utils/ReentrancyGuard.test.js +58 -0
- package/lib/openzeppelin-contracts/test/utils/RelayedCall.test.js +217 -0
- package/lib/openzeppelin-contracts/test/utils/ShortStrings.t.sol +109 -0
- package/lib/openzeppelin-contracts/test/utils/ShortStrings.test.js +64 -0
- package/lib/openzeppelin-contracts/test/utils/SlotDerivation.t.sol +248 -0
- package/lib/openzeppelin-contracts/test/utils/SlotDerivation.test.js +58 -0
- package/lib/openzeppelin-contracts/test/utils/StorageSlot.test.js +73 -0
- package/lib/openzeppelin-contracts/test/utils/Strings.t.sol +50 -0
- package/lib/openzeppelin-contracts/test/utils/Strings.test.js +360 -0
- package/lib/openzeppelin-contracts/test/utils/TransientSlot.test.js +59 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/ECDSA.test.js +322 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/EIP712.test.js +105 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/ERC1271.behavior.js +111 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/ERC7739.test.js +42 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/ERC7739Utils.test.js +203 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/MerkleProof.test.js +216 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/MessageHashUtils.t.sol +33 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/MessageHashUtils.test.js +149 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/P256.t.sol +45 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/P256.test.js +182 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/RSA.helper.js +17 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/RSA.test.js +102 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/SigVer15_186-3.rsp +3850 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/SignatureChecker.test.js +427 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/TrieProof.test.js +659 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/WebAuthn.t.sol +298 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/ecdsa_secp256r1_sha256_p1363_test.json +3719 -0
- package/lib/openzeppelin-contracts/test/utils/draft-InteroperableAddress.t.sol +99 -0
- package/lib/openzeppelin-contracts/test/utils/draft-InteroperableAddress.test.js +170 -0
- package/lib/openzeppelin-contracts/test/utils/introspection/ERC165.test.js +18 -0
- package/lib/openzeppelin-contracts/test/utils/introspection/ERC165Checker.test.js +272 -0
- package/lib/openzeppelin-contracts/test/utils/introspection/SupportsInterface.behavior.js +169 -0
- package/lib/openzeppelin-contracts/test/utils/math/Math.t.sol +370 -0
- package/lib/openzeppelin-contracts/test/utils/math/Math.test.js +746 -0
- package/lib/openzeppelin-contracts/test/utils/math/SafeCast.test.js +159 -0
- package/lib/openzeppelin-contracts/test/utils/math/SignedMath.t.sol +81 -0
- package/lib/openzeppelin-contracts/test/utils/math/SignedMath.test.js +53 -0
- package/lib/openzeppelin-contracts/test/utils/structs/Accumulators.t.sol +35 -0
- package/lib/openzeppelin-contracts/test/utils/structs/BitMap.test.js +149 -0
- package/lib/openzeppelin-contracts/test/utils/structs/Checkpoints.t.sol +440 -0
- package/lib/openzeppelin-contracts/test/utils/structs/Checkpoints.test.js +147 -0
- package/lib/openzeppelin-contracts/test/utils/structs/CircularBuffer.test.js +83 -0
- package/lib/openzeppelin-contracts/test/utils/structs/DoubleEndedQueue.test.js +144 -0
- package/lib/openzeppelin-contracts/test/utils/structs/EnumerableMap.behavior.js +214 -0
- package/lib/openzeppelin-contracts/test/utils/structs/EnumerableMap.test.js +83 -0
- package/lib/openzeppelin-contracts/test/utils/structs/EnumerableSet.behavior.js +175 -0
- package/lib/openzeppelin-contracts/test/utils/structs/EnumerableSet.test.js +66 -0
- package/lib/openzeppelin-contracts/test/utils/structs/Heap.t.sol +74 -0
- package/lib/openzeppelin-contracts/test/utils/structs/Heap.test.js +113 -0
- package/lib/openzeppelin-contracts/test/utils/structs/MerkleTree.test.js +180 -0
- package/lib/openzeppelin-contracts/test/utils/types/Time.test.js +135 -0
- package/lucro.txt +1 -0
- package/out/Base.sol/CommonBase.json +1 -0
- package/out/Base.sol/ScriptBase.json +1 -0
- package/out/Base.sol/TestBase.json +1 -0
- package/out/Context.sol/Context.json +1 -0
- package/out/Counter.s.sol/CounterScript.json +1 -0
- package/out/Counter.sol/Counter.json +1 -0
- package/out/Counter.t.sol/CounterTest.json +1 -0
- package/out/ERC20.sol/ERC20.json +1 -0
- package/out/GbitToken.sol/GbitToken.json +1 -0
- package/out/Guestbook.sol/Guestbook.json +1 -0
- package/out/IERC20.sol/IERC20.json +1 -0
- package/out/IERC20Metadata.sol/IERC20Metadata.json +1 -0
- package/out/IMulticall3.sol/IMulticall3.json +1 -0
- package/out/Script.sol/Script.json +1 -0
- package/out/StdAssertions.sol/StdAssertions.json +1 -0
- package/out/StdChains.sol/StdChains.json +1 -0
- package/out/StdCheats.sol/StdCheats.json +1 -0
- package/out/StdCheats.sol/StdCheatsSafe.json +1 -0
- package/out/StdConstants.sol/StdConstants.json +1 -0
- package/out/StdError.sol/stdError.json +1 -0
- package/out/StdInvariant.sol/StdInvariant.json +1 -0
- package/out/StdJson.sol/stdJson.json +1 -0
- package/out/StdMath.sol/stdMath.json +1 -0
- package/out/StdStorage.sol/stdStorage.json +1 -0
- package/out/StdStorage.sol/stdStorageSafe.json +1 -0
- package/out/StdStyle.sol/StdStyle.json +1 -0
- package/out/StdToml.sol/stdToml.json +1 -0
- package/out/StdUtils.sol/StdUtils.json +1 -0
- package/out/Test.sol/Test.json +1 -0
- package/out/Vm.sol/Vm.json +1 -0
- package/out/Vm.sol/VmSafe.json +1 -0
- package/out/Web3HubCore.sol/Web3HubCore.json +1 -0
- package/out/build-info/8a1d781106536b7b.json +1 -0
- package/out/build-info/aac4797350a36a99.json +1 -0
- package/out/build-info/c34d5a7881e6beba.json +1 -0
- package/out/build-info/ce38d811b8078146.json +1 -0
- package/out/build-info/db34a3531e47e196.json +1 -0
- package/out/console.sol/console.json +1 -0
- package/out/draft-IERC6093.sol/IERC1155Errors.json +1 -0
- package/out/draft-IERC6093.sol/IERC20Errors.json +1 -0
- package/out/draft-IERC6093.sol/IERC721Errors.json +1 -0
- package/out/safeconsole.sol/safeconsole.json +1 -0
- package/package.json +25 -0
- package/remappings.txt +1 -0
- package/script/Counter.s.sol +19 -0
- package/src/Counter.sol +14 -0
- package/src/GbitToken.sol +72 -0
- package/src/Guestbook.sol +28 -0
- package/src/Web3HubCore.sol +42 -0
- package/test/Counter.t.sol +24 -0
|
@@ -0,0 +1,825 @@
|
|
|
1
|
+
// SPDX-License-Identifier: MIT OR Apache-2.0
|
|
2
|
+
pragma solidity >=0.8.13 <0.9.0;
|
|
3
|
+
|
|
4
|
+
import {StdStorage, stdStorage} from "./StdStorage.sol";
|
|
5
|
+
import {console2} from "./console2.sol";
|
|
6
|
+
import {Vm} from "./Vm.sol";
|
|
7
|
+
|
|
8
|
+
abstract contract StdCheatsSafe {
|
|
9
|
+
Vm private constant vm = Vm(address(uint160(uint256(keccak256("hevm cheat code")))));
|
|
10
|
+
|
|
11
|
+
uint256 private constant UINT256_MAX =
|
|
12
|
+
115792089237316195423570985008687907853269984665640564039457584007913129639935;
|
|
13
|
+
|
|
14
|
+
bool private gasMeteringOff;
|
|
15
|
+
|
|
16
|
+
// Data structures to parse Transaction objects from the broadcast artifact
|
|
17
|
+
// that conform to EIP1559. The Raw structs is what is parsed from the JSON
|
|
18
|
+
// and then converted to the one that is used by the user for better UX.
|
|
19
|
+
|
|
20
|
+
struct RawTx1559 {
|
|
21
|
+
string[] arguments;
|
|
22
|
+
address contractAddress;
|
|
23
|
+
string contractName;
|
|
24
|
+
// json value name = function
|
|
25
|
+
string functionSig;
|
|
26
|
+
bytes32 hash;
|
|
27
|
+
// json value name = tx
|
|
28
|
+
RawTx1559Detail txDetail;
|
|
29
|
+
// json value name = type
|
|
30
|
+
string opcode;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
struct RawTx1559Detail {
|
|
34
|
+
AccessList[] accessList;
|
|
35
|
+
bytes data;
|
|
36
|
+
address from;
|
|
37
|
+
bytes gas;
|
|
38
|
+
bytes nonce;
|
|
39
|
+
address to;
|
|
40
|
+
bytes txType;
|
|
41
|
+
bytes value;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
struct Tx1559 {
|
|
45
|
+
string[] arguments;
|
|
46
|
+
address contractAddress;
|
|
47
|
+
string contractName;
|
|
48
|
+
string functionSig;
|
|
49
|
+
bytes32 hash;
|
|
50
|
+
Tx1559Detail txDetail;
|
|
51
|
+
string opcode;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
struct Tx1559Detail {
|
|
55
|
+
AccessList[] accessList;
|
|
56
|
+
bytes data;
|
|
57
|
+
address from;
|
|
58
|
+
uint256 gas;
|
|
59
|
+
uint256 nonce;
|
|
60
|
+
address to;
|
|
61
|
+
uint256 txType;
|
|
62
|
+
uint256 value;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
// Data structures to parse Transaction objects from the broadcast artifact
|
|
66
|
+
// that DO NOT conform to EIP1559. The Raw structs is what is parsed from the JSON
|
|
67
|
+
// and then converted to the one that is used by the user for better UX.
|
|
68
|
+
|
|
69
|
+
struct TxLegacy {
|
|
70
|
+
string[] arguments;
|
|
71
|
+
address contractAddress;
|
|
72
|
+
string contractName;
|
|
73
|
+
string functionSig;
|
|
74
|
+
string hash;
|
|
75
|
+
string opcode;
|
|
76
|
+
TxDetailLegacy transaction;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
struct TxDetailLegacy {
|
|
80
|
+
AccessList[] accessList;
|
|
81
|
+
uint256 chainId;
|
|
82
|
+
bytes data;
|
|
83
|
+
address from;
|
|
84
|
+
uint256 gas;
|
|
85
|
+
uint256 gasPrice;
|
|
86
|
+
bytes32 hash;
|
|
87
|
+
uint256 nonce;
|
|
88
|
+
bytes1 opcode;
|
|
89
|
+
bytes32 r;
|
|
90
|
+
bytes32 s;
|
|
91
|
+
uint256 txType;
|
|
92
|
+
address to;
|
|
93
|
+
uint8 v;
|
|
94
|
+
uint256 value;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
struct AccessList {
|
|
98
|
+
address accessAddress;
|
|
99
|
+
bytes32[] storageKeys;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
// Data structures to parse Receipt objects from the broadcast artifact.
|
|
103
|
+
// The Raw structs is what is parsed from the JSON
|
|
104
|
+
// and then converted to the one that is used by the user for better UX.
|
|
105
|
+
|
|
106
|
+
struct RawReceipt {
|
|
107
|
+
bytes32 blockHash;
|
|
108
|
+
bytes blockNumber;
|
|
109
|
+
address contractAddress;
|
|
110
|
+
bytes cumulativeGasUsed;
|
|
111
|
+
bytes effectiveGasPrice;
|
|
112
|
+
address from;
|
|
113
|
+
bytes gasUsed;
|
|
114
|
+
RawReceiptLog[] logs;
|
|
115
|
+
bytes logsBloom;
|
|
116
|
+
bytes status;
|
|
117
|
+
address to;
|
|
118
|
+
bytes32 transactionHash;
|
|
119
|
+
bytes transactionIndex;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
struct Receipt {
|
|
123
|
+
bytes32 blockHash;
|
|
124
|
+
uint256 blockNumber;
|
|
125
|
+
address contractAddress;
|
|
126
|
+
uint256 cumulativeGasUsed;
|
|
127
|
+
uint256 effectiveGasPrice;
|
|
128
|
+
address from;
|
|
129
|
+
uint256 gasUsed;
|
|
130
|
+
ReceiptLog[] logs;
|
|
131
|
+
bytes logsBloom;
|
|
132
|
+
uint256 status;
|
|
133
|
+
address to;
|
|
134
|
+
bytes32 transactionHash;
|
|
135
|
+
uint256 transactionIndex;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
// Data structures to parse the entire broadcast artifact, assuming the
|
|
139
|
+
// transactions conform to EIP1559.
|
|
140
|
+
|
|
141
|
+
struct EIP1559ScriptArtifact {
|
|
142
|
+
string[] libraries;
|
|
143
|
+
string path;
|
|
144
|
+
string[] pending;
|
|
145
|
+
Receipt[] receipts;
|
|
146
|
+
uint256 timestamp;
|
|
147
|
+
Tx1559[] transactions;
|
|
148
|
+
TxReturn[] txReturns;
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
struct RawEIP1559ScriptArtifact {
|
|
152
|
+
string[] libraries;
|
|
153
|
+
string path;
|
|
154
|
+
string[] pending;
|
|
155
|
+
RawReceipt[] receipts;
|
|
156
|
+
TxReturn[] txReturns;
|
|
157
|
+
uint256 timestamp;
|
|
158
|
+
RawTx1559[] transactions;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
struct RawReceiptLog {
|
|
162
|
+
// json value = address
|
|
163
|
+
address logAddress;
|
|
164
|
+
bytes32 blockHash;
|
|
165
|
+
bytes blockNumber;
|
|
166
|
+
bytes data;
|
|
167
|
+
bytes logIndex;
|
|
168
|
+
bool removed;
|
|
169
|
+
bytes32[] topics;
|
|
170
|
+
bytes32 transactionHash;
|
|
171
|
+
bytes transactionIndex;
|
|
172
|
+
bytes transactionLogIndex;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
struct ReceiptLog {
|
|
176
|
+
// json value = address
|
|
177
|
+
address logAddress;
|
|
178
|
+
bytes32 blockHash;
|
|
179
|
+
uint256 blockNumber;
|
|
180
|
+
bytes data;
|
|
181
|
+
uint256 logIndex;
|
|
182
|
+
bytes32[] topics;
|
|
183
|
+
uint256 transactionIndex;
|
|
184
|
+
uint256 transactionLogIndex;
|
|
185
|
+
bool removed;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
struct TxReturn {
|
|
189
|
+
string internalType;
|
|
190
|
+
string value;
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
struct Account {
|
|
194
|
+
address addr;
|
|
195
|
+
uint256 key;
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
enum AddressType {
|
|
199
|
+
Payable,
|
|
200
|
+
NonPayable,
|
|
201
|
+
ZeroAddress,
|
|
202
|
+
Precompile,
|
|
203
|
+
ForgeAddress
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
// Checks that `addr` is not blacklisted by token contracts that have a blacklist.
|
|
207
|
+
function assumeNotBlacklisted(address token, address addr) internal view virtual {
|
|
208
|
+
// Nothing to check if `token` is not a contract.
|
|
209
|
+
uint256 tokenCodeSize;
|
|
210
|
+
assembly {
|
|
211
|
+
tokenCodeSize := extcodesize(token)
|
|
212
|
+
}
|
|
213
|
+
require(tokenCodeSize > 0, "StdCheats assumeNotBlacklisted(address,address): Token address is not a contract.");
|
|
214
|
+
|
|
215
|
+
bool success;
|
|
216
|
+
bytes memory returnData;
|
|
217
|
+
|
|
218
|
+
// 4-byte selector for `isBlacklisted(address)`, used by USDC.
|
|
219
|
+
(success, returnData) = token.staticcall(abi.encodeWithSelector(0xfe575a87, addr));
|
|
220
|
+
vm.assume(!success || abi.decode(returnData, (bool)) == false);
|
|
221
|
+
|
|
222
|
+
// 4-byte selector for `isBlackListed(address)`, used by USDT.
|
|
223
|
+
(success, returnData) = token.staticcall(abi.encodeWithSelector(0xe47d6060, addr));
|
|
224
|
+
vm.assume(!success || abi.decode(returnData, (bool)) == false);
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
// Checks that `addr` is not blacklisted by token contracts that have a blacklist.
|
|
228
|
+
// This is identical to `assumeNotBlacklisted(address,address)` but with a different name, for
|
|
229
|
+
// backwards compatibility, since this name was used in the original PR which already has
|
|
230
|
+
// a release. This function can be removed in a future release once we want a breaking change.
|
|
231
|
+
function assumeNoBlacklisted(address token, address addr) internal view virtual {
|
|
232
|
+
assumeNotBlacklisted(token, addr);
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
function assumeAddressIsNot(address addr, AddressType addressType) internal virtual {
|
|
236
|
+
if (addressType == AddressType.Payable) {
|
|
237
|
+
assumeNotPayable(addr);
|
|
238
|
+
} else if (addressType == AddressType.NonPayable) {
|
|
239
|
+
assumePayable(addr);
|
|
240
|
+
} else if (addressType == AddressType.ZeroAddress) {
|
|
241
|
+
assumeNotZeroAddress(addr);
|
|
242
|
+
} else if (addressType == AddressType.Precompile) {
|
|
243
|
+
assumeNotPrecompile(addr);
|
|
244
|
+
} else if (addressType == AddressType.ForgeAddress) {
|
|
245
|
+
assumeNotForgeAddress(addr);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
function assumeAddressIsNot(address addr, AddressType addressType1, AddressType addressType2) internal virtual {
|
|
250
|
+
assumeAddressIsNot(addr, addressType1);
|
|
251
|
+
assumeAddressIsNot(addr, addressType2);
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
function assumeAddressIsNot(
|
|
255
|
+
address addr,
|
|
256
|
+
AddressType addressType1,
|
|
257
|
+
AddressType addressType2,
|
|
258
|
+
AddressType addressType3
|
|
259
|
+
) internal virtual {
|
|
260
|
+
assumeAddressIsNot(addr, addressType1);
|
|
261
|
+
assumeAddressIsNot(addr, addressType2);
|
|
262
|
+
assumeAddressIsNot(addr, addressType3);
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
function assumeAddressIsNot(
|
|
266
|
+
address addr,
|
|
267
|
+
AddressType addressType1,
|
|
268
|
+
AddressType addressType2,
|
|
269
|
+
AddressType addressType3,
|
|
270
|
+
AddressType addressType4
|
|
271
|
+
) internal virtual {
|
|
272
|
+
assumeAddressIsNot(addr, addressType1);
|
|
273
|
+
assumeAddressIsNot(addr, addressType2);
|
|
274
|
+
assumeAddressIsNot(addr, addressType3);
|
|
275
|
+
assumeAddressIsNot(addr, addressType4);
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
// This function checks whether an address, `addr`, is payable. It works by sending 1 wei to
|
|
279
|
+
// `addr` and checking the `success` return value.
|
|
280
|
+
// NOTE: This function may result in state changes depending on the fallback/receive logic
|
|
281
|
+
// implemented by `addr`, which should be taken into account when this function is used.
|
|
282
|
+
function _isPayable(address addr) private returns (bool) {
|
|
283
|
+
require(
|
|
284
|
+
addr.balance < UINT256_MAX,
|
|
285
|
+
"StdCheats _isPayable(address): Balance equals max uint256, so it cannot receive any more funds"
|
|
286
|
+
);
|
|
287
|
+
uint256 origBalanceTest = address(this).balance;
|
|
288
|
+
uint256 origBalanceAddr = address(addr).balance;
|
|
289
|
+
|
|
290
|
+
vm.deal(address(this), 1);
|
|
291
|
+
(bool success,) = payable(addr).call{value: 1}("");
|
|
292
|
+
|
|
293
|
+
// reset balances
|
|
294
|
+
vm.deal(address(this), origBalanceTest);
|
|
295
|
+
vm.deal(addr, origBalanceAddr);
|
|
296
|
+
|
|
297
|
+
return success;
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
// NOTE: This function may result in state changes depending on the fallback/receive logic
|
|
301
|
+
// implemented by `addr`, which should be taken into account when this function is used. See the
|
|
302
|
+
// `_isPayable` method for more information.
|
|
303
|
+
function assumePayable(address addr) internal virtual {
|
|
304
|
+
vm.assume(_isPayable(addr));
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
function assumeNotPayable(address addr) internal virtual {
|
|
308
|
+
vm.assume(!_isPayable(addr));
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
function assumeNotZeroAddress(address addr) internal pure virtual {
|
|
312
|
+
vm.assume(addr != address(0));
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
function assumeNotPrecompile(address addr) internal pure virtual {
|
|
316
|
+
assumeNotPrecompile(addr, _pureChainId());
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
function assumeNotPrecompile(address addr, uint256 chainId) internal pure virtual {
|
|
320
|
+
// Note: For some chains like Optimism these are technically predeploys (i.e. bytecode placed at a specific
|
|
321
|
+
// address), but the same rationale for excluding them applies so we include those too.
|
|
322
|
+
|
|
323
|
+
// These are reserved by Ethereum and may be on all EVM-compatible chains.
|
|
324
|
+
vm.assume(addr < address(0x1) || addr > address(0xff));
|
|
325
|
+
|
|
326
|
+
// forgefmt: disable-start
|
|
327
|
+
if (chainId == 10 || chainId == 420 || chainId == 11155420) {
|
|
328
|
+
// https://github.com/ethereum-optimism/optimism/blob/eaa371a0184b56b7ca6d9eb9cb0a2b78b2ccd864/op-bindings/predeploys/addresses.go#L6-L21
|
|
329
|
+
vm.assume(addr < address(0x4200000000000000000000000000000000000000) || addr > address(0x4200000000000000000000000000000000000800));
|
|
330
|
+
} else if (chainId == 42161 || chainId == 421613) {
|
|
331
|
+
// https://developer.arbitrum.io/useful-addresses#arbitrum-precompiles-l2-same-on-all-arb-chains
|
|
332
|
+
vm.assume(addr < address(0x0000000000000000000000000000000000000064) || addr > address(0x0000000000000000000000000000000000000068));
|
|
333
|
+
} else if (chainId == 43114 || chainId == 43113) {
|
|
334
|
+
// https://github.com/ava-labs/subnet-evm/blob/47c03fd007ecaa6de2c52ea081596e0a88401f58/precompile/params.go#L18-L59
|
|
335
|
+
vm.assume(addr < address(0x0100000000000000000000000000000000000000) || addr > address(0x01000000000000000000000000000000000000ff));
|
|
336
|
+
vm.assume(addr < address(0x0200000000000000000000000000000000000000) || addr > address(0x02000000000000000000000000000000000000FF));
|
|
337
|
+
vm.assume(addr < address(0x0300000000000000000000000000000000000000) || addr > address(0x03000000000000000000000000000000000000Ff));
|
|
338
|
+
}
|
|
339
|
+
// forgefmt: disable-end
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
function assumeNotForgeAddress(address addr) internal pure virtual {
|
|
343
|
+
// vm, console, and Create2Deployer addresses
|
|
344
|
+
vm.assume(
|
|
345
|
+
addr != address(vm) && addr != 0x000000000000000000636F6e736F6c652e6c6f67
|
|
346
|
+
&& addr != 0x4e59b44847b379578588920cA78FbF26c0B4956C
|
|
347
|
+
);
|
|
348
|
+
}
|
|
349
|
+
|
|
350
|
+
function assumeUnusedAddress(address addr) internal view virtual {
|
|
351
|
+
uint256 size;
|
|
352
|
+
assembly {
|
|
353
|
+
size := extcodesize(addr)
|
|
354
|
+
}
|
|
355
|
+
vm.assume(size == 0);
|
|
356
|
+
|
|
357
|
+
assumeNotPrecompile(addr);
|
|
358
|
+
assumeNotZeroAddress(addr);
|
|
359
|
+
assumeNotForgeAddress(addr);
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
function readEIP1559ScriptArtifact(string memory path)
|
|
363
|
+
internal
|
|
364
|
+
view
|
|
365
|
+
virtual
|
|
366
|
+
returns (EIP1559ScriptArtifact memory)
|
|
367
|
+
{
|
|
368
|
+
string memory data = vm.readFile(path);
|
|
369
|
+
bytes memory parsedData = vm.parseJson(data);
|
|
370
|
+
RawEIP1559ScriptArtifact memory rawArtifact = abi.decode(parsedData, (RawEIP1559ScriptArtifact));
|
|
371
|
+
EIP1559ScriptArtifact memory artifact;
|
|
372
|
+
artifact.libraries = rawArtifact.libraries;
|
|
373
|
+
artifact.path = rawArtifact.path;
|
|
374
|
+
artifact.timestamp = rawArtifact.timestamp;
|
|
375
|
+
artifact.pending = rawArtifact.pending;
|
|
376
|
+
artifact.txReturns = rawArtifact.txReturns;
|
|
377
|
+
artifact.receipts = rawToConvertedReceipts(rawArtifact.receipts);
|
|
378
|
+
artifact.transactions = rawToConvertedEIPTx1559s(rawArtifact.transactions);
|
|
379
|
+
return artifact;
|
|
380
|
+
}
|
|
381
|
+
|
|
382
|
+
function rawToConvertedEIPTx1559s(RawTx1559[] memory rawTxs) internal pure virtual returns (Tx1559[] memory) {
|
|
383
|
+
Tx1559[] memory txs = new Tx1559[](rawTxs.length);
|
|
384
|
+
for (uint256 i; i < rawTxs.length; i++) {
|
|
385
|
+
txs[i] = rawToConvertedEIPTx1559(rawTxs[i]);
|
|
386
|
+
}
|
|
387
|
+
return txs;
|
|
388
|
+
}
|
|
389
|
+
|
|
390
|
+
function rawToConvertedEIPTx1559(RawTx1559 memory rawTx) internal pure virtual returns (Tx1559 memory) {
|
|
391
|
+
Tx1559 memory transaction;
|
|
392
|
+
transaction.arguments = rawTx.arguments;
|
|
393
|
+
transaction.contractAddress = rawTx.contractAddress;
|
|
394
|
+
transaction.contractName = rawTx.contractName;
|
|
395
|
+
transaction.functionSig = rawTx.functionSig;
|
|
396
|
+
transaction.hash = rawTx.hash;
|
|
397
|
+
transaction.txDetail = rawToConvertedEIP1559Detail(rawTx.txDetail);
|
|
398
|
+
transaction.opcode = rawTx.opcode;
|
|
399
|
+
return transaction;
|
|
400
|
+
}
|
|
401
|
+
|
|
402
|
+
function rawToConvertedEIP1559Detail(RawTx1559Detail memory rawDetail)
|
|
403
|
+
internal
|
|
404
|
+
pure
|
|
405
|
+
virtual
|
|
406
|
+
returns (Tx1559Detail memory)
|
|
407
|
+
{
|
|
408
|
+
Tx1559Detail memory txDetail;
|
|
409
|
+
txDetail.data = rawDetail.data;
|
|
410
|
+
txDetail.from = rawDetail.from;
|
|
411
|
+
txDetail.to = rawDetail.to;
|
|
412
|
+
txDetail.nonce = _bytesToUint(rawDetail.nonce);
|
|
413
|
+
txDetail.txType = _bytesToUint(rawDetail.txType);
|
|
414
|
+
txDetail.value = _bytesToUint(rawDetail.value);
|
|
415
|
+
txDetail.gas = _bytesToUint(rawDetail.gas);
|
|
416
|
+
txDetail.accessList = rawDetail.accessList;
|
|
417
|
+
return txDetail;
|
|
418
|
+
}
|
|
419
|
+
|
|
420
|
+
function readTx1559s(string memory path) internal view virtual returns (Tx1559[] memory) {
|
|
421
|
+
string memory deployData = vm.readFile(path);
|
|
422
|
+
bytes memory parsedDeployData = vm.parseJson(deployData, ".transactions");
|
|
423
|
+
RawTx1559[] memory rawTxs = abi.decode(parsedDeployData, (RawTx1559[]));
|
|
424
|
+
return rawToConvertedEIPTx1559s(rawTxs);
|
|
425
|
+
}
|
|
426
|
+
|
|
427
|
+
function readTx1559(string memory path, uint256 index) internal view virtual returns (Tx1559 memory) {
|
|
428
|
+
string memory deployData = vm.readFile(path);
|
|
429
|
+
string memory key = string(abi.encodePacked(".transactions[", vm.toString(index), "]"));
|
|
430
|
+
bytes memory parsedDeployData = vm.parseJson(deployData, key);
|
|
431
|
+
RawTx1559 memory rawTx = abi.decode(parsedDeployData, (RawTx1559));
|
|
432
|
+
return rawToConvertedEIPTx1559(rawTx);
|
|
433
|
+
}
|
|
434
|
+
|
|
435
|
+
// Analogous to readTransactions, but for receipts.
|
|
436
|
+
function readReceipts(string memory path) internal view virtual returns (Receipt[] memory) {
|
|
437
|
+
string memory deployData = vm.readFile(path);
|
|
438
|
+
bytes memory parsedDeployData = vm.parseJson(deployData, ".receipts");
|
|
439
|
+
RawReceipt[] memory rawReceipts = abi.decode(parsedDeployData, (RawReceipt[]));
|
|
440
|
+
return rawToConvertedReceipts(rawReceipts);
|
|
441
|
+
}
|
|
442
|
+
|
|
443
|
+
function readReceipt(string memory path, uint256 index) internal view virtual returns (Receipt memory) {
|
|
444
|
+
string memory deployData = vm.readFile(path);
|
|
445
|
+
string memory key = string(abi.encodePacked(".receipts[", vm.toString(index), "]"));
|
|
446
|
+
bytes memory parsedDeployData = vm.parseJson(deployData, key);
|
|
447
|
+
RawReceipt memory rawReceipt = abi.decode(parsedDeployData, (RawReceipt));
|
|
448
|
+
return rawToConvertedReceipt(rawReceipt);
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
function rawToConvertedReceipts(RawReceipt[] memory rawReceipts) internal pure virtual returns (Receipt[] memory) {
|
|
452
|
+
Receipt[] memory receipts = new Receipt[](rawReceipts.length);
|
|
453
|
+
for (uint256 i; i < rawReceipts.length; i++) {
|
|
454
|
+
receipts[i] = rawToConvertedReceipt(rawReceipts[i]);
|
|
455
|
+
}
|
|
456
|
+
return receipts;
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
function rawToConvertedReceipt(RawReceipt memory rawReceipt) internal pure virtual returns (Receipt memory) {
|
|
460
|
+
Receipt memory receipt;
|
|
461
|
+
receipt.blockHash = rawReceipt.blockHash;
|
|
462
|
+
receipt.to = rawReceipt.to;
|
|
463
|
+
receipt.from = rawReceipt.from;
|
|
464
|
+
receipt.contractAddress = rawReceipt.contractAddress;
|
|
465
|
+
receipt.effectiveGasPrice = _bytesToUint(rawReceipt.effectiveGasPrice);
|
|
466
|
+
receipt.cumulativeGasUsed = _bytesToUint(rawReceipt.cumulativeGasUsed);
|
|
467
|
+
receipt.gasUsed = _bytesToUint(rawReceipt.gasUsed);
|
|
468
|
+
receipt.status = _bytesToUint(rawReceipt.status);
|
|
469
|
+
receipt.transactionIndex = _bytesToUint(rawReceipt.transactionIndex);
|
|
470
|
+
receipt.blockNumber = _bytesToUint(rawReceipt.blockNumber);
|
|
471
|
+
receipt.logs = rawToConvertedReceiptLogs(rawReceipt.logs);
|
|
472
|
+
receipt.logsBloom = rawReceipt.logsBloom;
|
|
473
|
+
receipt.transactionHash = rawReceipt.transactionHash;
|
|
474
|
+
return receipt;
|
|
475
|
+
}
|
|
476
|
+
|
|
477
|
+
function rawToConvertedReceiptLogs(RawReceiptLog[] memory rawLogs)
|
|
478
|
+
internal
|
|
479
|
+
pure
|
|
480
|
+
virtual
|
|
481
|
+
returns (ReceiptLog[] memory)
|
|
482
|
+
{
|
|
483
|
+
ReceiptLog[] memory logs = new ReceiptLog[](rawLogs.length);
|
|
484
|
+
for (uint256 i; i < rawLogs.length; i++) {
|
|
485
|
+
logs[i].logAddress = rawLogs[i].logAddress;
|
|
486
|
+
logs[i].blockHash = rawLogs[i].blockHash;
|
|
487
|
+
logs[i].blockNumber = _bytesToUint(rawLogs[i].blockNumber);
|
|
488
|
+
logs[i].data = rawLogs[i].data;
|
|
489
|
+
logs[i].logIndex = _bytesToUint(rawLogs[i].logIndex);
|
|
490
|
+
logs[i].topics = rawLogs[i].topics;
|
|
491
|
+
logs[i].transactionIndex = _bytesToUint(rawLogs[i].transactionIndex);
|
|
492
|
+
logs[i].transactionLogIndex = _bytesToUint(rawLogs[i].transactionLogIndex);
|
|
493
|
+
logs[i].removed = rawLogs[i].removed;
|
|
494
|
+
}
|
|
495
|
+
return logs;
|
|
496
|
+
}
|
|
497
|
+
|
|
498
|
+
// Deploy a contract by fetching the contract bytecode from
|
|
499
|
+
// the artifacts directory
|
|
500
|
+
// e.g. `deployCode(code, abi.encode(arg1,arg2,arg3))`
|
|
501
|
+
function deployCode(string memory what, bytes memory args) internal virtual returns (address addr) {
|
|
502
|
+
bytes memory bytecode = abi.encodePacked(vm.getCode(what), args);
|
|
503
|
+
assembly ("memory-safe") {
|
|
504
|
+
addr := create(0, add(bytecode, 0x20), mload(bytecode))
|
|
505
|
+
}
|
|
506
|
+
|
|
507
|
+
require(addr != address(0), "StdCheats deployCode(string,bytes): Deployment failed.");
|
|
508
|
+
}
|
|
509
|
+
|
|
510
|
+
function deployCode(string memory what) internal virtual returns (address addr) {
|
|
511
|
+
bytes memory bytecode = vm.getCode(what);
|
|
512
|
+
assembly ("memory-safe") {
|
|
513
|
+
addr := create(0, add(bytecode, 0x20), mload(bytecode))
|
|
514
|
+
}
|
|
515
|
+
|
|
516
|
+
require(addr != address(0), "StdCheats deployCode(string): Deployment failed.");
|
|
517
|
+
}
|
|
518
|
+
|
|
519
|
+
/// @dev deploy contract with value on construction
|
|
520
|
+
function deployCode(string memory what, bytes memory args, uint256 val) internal virtual returns (address addr) {
|
|
521
|
+
bytes memory bytecode = abi.encodePacked(vm.getCode(what), args);
|
|
522
|
+
assembly ("memory-safe") {
|
|
523
|
+
addr := create(val, add(bytecode, 0x20), mload(bytecode))
|
|
524
|
+
}
|
|
525
|
+
|
|
526
|
+
require(addr != address(0), "StdCheats deployCode(string,bytes,uint256): Deployment failed.");
|
|
527
|
+
}
|
|
528
|
+
|
|
529
|
+
function deployCode(string memory what, uint256 val) internal virtual returns (address addr) {
|
|
530
|
+
bytes memory bytecode = vm.getCode(what);
|
|
531
|
+
assembly ("memory-safe") {
|
|
532
|
+
addr := create(val, add(bytecode, 0x20), mload(bytecode))
|
|
533
|
+
}
|
|
534
|
+
|
|
535
|
+
require(addr != address(0), "StdCheats deployCode(string,uint256): Deployment failed.");
|
|
536
|
+
}
|
|
537
|
+
|
|
538
|
+
// creates a labeled address and the corresponding private key
|
|
539
|
+
function makeAddrAndKey(string memory name) internal virtual returns (address addr, uint256 privateKey) {
|
|
540
|
+
privateKey = uint256(keccak256(abi.encodePacked(name)));
|
|
541
|
+
addr = vm.addr(privateKey);
|
|
542
|
+
vm.label(addr, name);
|
|
543
|
+
}
|
|
544
|
+
|
|
545
|
+
// creates a labeled address
|
|
546
|
+
function makeAddr(string memory name) internal virtual returns (address addr) {
|
|
547
|
+
(addr,) = makeAddrAndKey(name);
|
|
548
|
+
}
|
|
549
|
+
|
|
550
|
+
// Destroys an account immediately, sending the balance to beneficiary.
|
|
551
|
+
// Destroying means: balance will be zero, code will be empty, and nonce will be 0
|
|
552
|
+
// This is similar to selfdestruct but not identical: selfdestruct destroys code and nonce
|
|
553
|
+
// only after tx ends, this will run immediately.
|
|
554
|
+
function destroyAccount(address who, address beneficiary) internal virtual {
|
|
555
|
+
uint256 currBalance = who.balance;
|
|
556
|
+
vm.etch(who, abi.encode());
|
|
557
|
+
vm.deal(who, 0);
|
|
558
|
+
vm.resetNonce(who);
|
|
559
|
+
|
|
560
|
+
uint256 beneficiaryBalance = beneficiary.balance;
|
|
561
|
+
vm.deal(beneficiary, currBalance + beneficiaryBalance);
|
|
562
|
+
}
|
|
563
|
+
|
|
564
|
+
// creates a struct containing both a labeled address and the corresponding private key
|
|
565
|
+
function makeAccount(string memory name) internal virtual returns (Account memory account) {
|
|
566
|
+
(account.addr, account.key) = makeAddrAndKey(name);
|
|
567
|
+
}
|
|
568
|
+
|
|
569
|
+
function deriveRememberKey(string memory mnemonic, uint32 index)
|
|
570
|
+
internal
|
|
571
|
+
virtual
|
|
572
|
+
returns (address who, uint256 privateKey)
|
|
573
|
+
{
|
|
574
|
+
privateKey = vm.deriveKey(mnemonic, index);
|
|
575
|
+
who = vm.rememberKey(privateKey);
|
|
576
|
+
}
|
|
577
|
+
|
|
578
|
+
function _bytesToUint(bytes memory b) private pure returns (uint256) {
|
|
579
|
+
require(b.length <= 32, "StdCheats _bytesToUint(bytes): Bytes length exceeds 32.");
|
|
580
|
+
return abi.decode(abi.encodePacked(new bytes(32 - b.length), b), (uint256));
|
|
581
|
+
}
|
|
582
|
+
|
|
583
|
+
function isFork() internal view virtual returns (bool status) {
|
|
584
|
+
try vm.activeFork() {
|
|
585
|
+
status = true;
|
|
586
|
+
} catch (bytes memory) {}
|
|
587
|
+
}
|
|
588
|
+
|
|
589
|
+
modifier skipWhenForking() {
|
|
590
|
+
if (!isFork()) {
|
|
591
|
+
_;
|
|
592
|
+
}
|
|
593
|
+
}
|
|
594
|
+
|
|
595
|
+
modifier skipWhenNotForking() {
|
|
596
|
+
if (isFork()) {
|
|
597
|
+
_;
|
|
598
|
+
}
|
|
599
|
+
}
|
|
600
|
+
|
|
601
|
+
modifier noGasMetering() {
|
|
602
|
+
vm.pauseGasMetering();
|
|
603
|
+
// To prevent turning gas monitoring back on with nested functions that use this modifier,
|
|
604
|
+
// we check if gasMetering started in the off position. If it did, we don't want to turn
|
|
605
|
+
// it back on until we exit the top level function that used the modifier
|
|
606
|
+
//
|
|
607
|
+
// i.e. funcA() noGasMetering { funcB() }, where funcB has noGasMetering as well.
|
|
608
|
+
// funcA will have `gasStartedOff` as false, funcB will have it as true,
|
|
609
|
+
// so we only turn metering back on at the end of the funcA
|
|
610
|
+
bool gasStartedOff = gasMeteringOff;
|
|
611
|
+
gasMeteringOff = true;
|
|
612
|
+
|
|
613
|
+
_;
|
|
614
|
+
|
|
615
|
+
// if gas metering was on when this modifier was called, turn it back on at the end
|
|
616
|
+
if (!gasStartedOff) {
|
|
617
|
+
gasMeteringOff = false;
|
|
618
|
+
vm.resumeGasMetering();
|
|
619
|
+
}
|
|
620
|
+
}
|
|
621
|
+
|
|
622
|
+
// We use this complex approach of `_viewChainId` and `_pureChainId` to ensure there are no
|
|
623
|
+
// compiler warnings when accessing chain ID in any solidity version supported by forge-std. We
|
|
624
|
+
// can't simply access the chain ID in a normal view or pure function because the solc View Pure
|
|
625
|
+
// Checker changed `chainid` from pure to view in 0.8.0.
|
|
626
|
+
function _viewChainId() private view returns (uint256 chainId) {
|
|
627
|
+
// Assembly required since `block.chainid` was introduced in 0.8.0.
|
|
628
|
+
assembly {
|
|
629
|
+
chainId := chainid()
|
|
630
|
+
}
|
|
631
|
+
|
|
632
|
+
address(this); // Silence warnings in older Solc versions.
|
|
633
|
+
}
|
|
634
|
+
|
|
635
|
+
function _pureChainId() private pure returns (uint256 chainId) {
|
|
636
|
+
function() internal view returns (uint256) fnIn = _viewChainId;
|
|
637
|
+
function() internal pure returns (uint256) pureChainId;
|
|
638
|
+
assembly {
|
|
639
|
+
pureChainId := fnIn
|
|
640
|
+
}
|
|
641
|
+
chainId = pureChainId();
|
|
642
|
+
}
|
|
643
|
+
}
|
|
644
|
+
|
|
645
|
+
// Wrappers around cheatcodes to avoid footguns
|
|
646
|
+
abstract contract StdCheats is StdCheatsSafe {
|
|
647
|
+
using stdStorage for StdStorage;
|
|
648
|
+
|
|
649
|
+
StdStorage private stdstore;
|
|
650
|
+
Vm private constant vm = Vm(address(uint160(uint256(keccak256("hevm cheat code")))));
|
|
651
|
+
address private constant CONSOLE2_ADDRESS = 0x000000000000000000636F6e736F6c652e6c6f67;
|
|
652
|
+
|
|
653
|
+
// Skip forward or rewind time by the specified number of seconds
|
|
654
|
+
function skip(uint256 time) internal virtual {
|
|
655
|
+
vm.warp(vm.getBlockTimestamp() + time);
|
|
656
|
+
}
|
|
657
|
+
|
|
658
|
+
function rewind(uint256 time) internal virtual {
|
|
659
|
+
vm.warp(vm.getBlockTimestamp() - time);
|
|
660
|
+
}
|
|
661
|
+
|
|
662
|
+
// Setup a prank from an address that has some ether
|
|
663
|
+
function hoax(address msgSender) internal virtual {
|
|
664
|
+
vm.deal(msgSender, 1 << 128);
|
|
665
|
+
vm.prank(msgSender);
|
|
666
|
+
}
|
|
667
|
+
|
|
668
|
+
function hoax(address msgSender, uint256 give) internal virtual {
|
|
669
|
+
vm.deal(msgSender, give);
|
|
670
|
+
vm.prank(msgSender);
|
|
671
|
+
}
|
|
672
|
+
|
|
673
|
+
function hoax(address msgSender, address origin) internal virtual {
|
|
674
|
+
vm.deal(msgSender, 1 << 128);
|
|
675
|
+
vm.prank(msgSender, origin);
|
|
676
|
+
}
|
|
677
|
+
|
|
678
|
+
function hoax(address msgSender, address origin, uint256 give) internal virtual {
|
|
679
|
+
vm.deal(msgSender, give);
|
|
680
|
+
vm.prank(msgSender, origin);
|
|
681
|
+
}
|
|
682
|
+
|
|
683
|
+
// Start perpetual prank from an address that has some ether
|
|
684
|
+
function startHoax(address msgSender) internal virtual {
|
|
685
|
+
vm.deal(msgSender, 1 << 128);
|
|
686
|
+
vm.startPrank(msgSender);
|
|
687
|
+
}
|
|
688
|
+
|
|
689
|
+
function startHoax(address msgSender, uint256 give) internal virtual {
|
|
690
|
+
vm.deal(msgSender, give);
|
|
691
|
+
vm.startPrank(msgSender);
|
|
692
|
+
}
|
|
693
|
+
|
|
694
|
+
// Start perpetual prank from an address that has some ether
|
|
695
|
+
// tx.origin is set to the origin parameter
|
|
696
|
+
function startHoax(address msgSender, address origin) internal virtual {
|
|
697
|
+
vm.deal(msgSender, 1 << 128);
|
|
698
|
+
vm.startPrank(msgSender, origin);
|
|
699
|
+
}
|
|
700
|
+
|
|
701
|
+
function startHoax(address msgSender, address origin, uint256 give) internal virtual {
|
|
702
|
+
vm.deal(msgSender, give);
|
|
703
|
+
vm.startPrank(msgSender, origin);
|
|
704
|
+
}
|
|
705
|
+
|
|
706
|
+
function changePrank(address msgSender) internal virtual {
|
|
707
|
+
console2_log_StdCheats("changePrank is deprecated. Please use vm.startPrank instead.");
|
|
708
|
+
vm.stopPrank();
|
|
709
|
+
vm.startPrank(msgSender);
|
|
710
|
+
}
|
|
711
|
+
|
|
712
|
+
function changePrank(address msgSender, address txOrigin) internal virtual {
|
|
713
|
+
console2_log_StdCheats("changePrank is deprecated. Please use vm.startPrank instead.");
|
|
714
|
+
vm.stopPrank();
|
|
715
|
+
vm.startPrank(msgSender, txOrigin);
|
|
716
|
+
}
|
|
717
|
+
|
|
718
|
+
// The same as Vm's `deal`
|
|
719
|
+
// Use the alternative signature for ERC20 tokens
|
|
720
|
+
function deal(address to, uint256 give) internal virtual {
|
|
721
|
+
vm.deal(to, give);
|
|
722
|
+
}
|
|
723
|
+
|
|
724
|
+
// Set the balance of an account for any ERC20 token
|
|
725
|
+
// Use the alternative signature to update `totalSupply`
|
|
726
|
+
function deal(address token, address to, uint256 give) internal virtual {
|
|
727
|
+
deal(token, to, give, false);
|
|
728
|
+
}
|
|
729
|
+
|
|
730
|
+
// Set the balance of an account for any ERC1155 token
|
|
731
|
+
// Use the alternative signature to update `totalSupply`
|
|
732
|
+
function dealERC1155(address token, address to, uint256 id, uint256 give) internal virtual {
|
|
733
|
+
dealERC1155(token, to, id, give, false);
|
|
734
|
+
}
|
|
735
|
+
|
|
736
|
+
function deal(address token, address to, uint256 give, bool adjust) internal virtual {
|
|
737
|
+
// get current balance
|
|
738
|
+
(, bytes memory balData) = token.staticcall(abi.encodeWithSelector(0x70a08231, to));
|
|
739
|
+
uint256 prevBal = abi.decode(balData, (uint256));
|
|
740
|
+
|
|
741
|
+
// update balance
|
|
742
|
+
stdstore.target(token).sig(0x70a08231).with_key(to).checked_write(give);
|
|
743
|
+
|
|
744
|
+
// update total supply
|
|
745
|
+
if (adjust) {
|
|
746
|
+
(, bytes memory totSupData) = token.staticcall(abi.encodeWithSelector(0x18160ddd));
|
|
747
|
+
uint256 totSup = abi.decode(totSupData, (uint256));
|
|
748
|
+
if (give < prevBal) {
|
|
749
|
+
totSup -= (prevBal - give);
|
|
750
|
+
} else {
|
|
751
|
+
totSup += (give - prevBal);
|
|
752
|
+
}
|
|
753
|
+
stdstore.target(token).sig(0x18160ddd).checked_write(totSup);
|
|
754
|
+
}
|
|
755
|
+
}
|
|
756
|
+
|
|
757
|
+
function dealERC1155(address token, address to, uint256 id, uint256 give, bool adjust) internal virtual {
|
|
758
|
+
// get current balance
|
|
759
|
+
(, bytes memory balData) = token.staticcall(abi.encodeWithSelector(0x00fdd58e, to, id));
|
|
760
|
+
uint256 prevBal = abi.decode(balData, (uint256));
|
|
761
|
+
|
|
762
|
+
// update balance
|
|
763
|
+
stdstore.target(token).sig(0x00fdd58e).with_key(to).with_key(id).checked_write(give);
|
|
764
|
+
|
|
765
|
+
// update total supply
|
|
766
|
+
if (adjust) {
|
|
767
|
+
(, bytes memory totSupData) = token.staticcall(abi.encodeWithSelector(0xbd85b039, id));
|
|
768
|
+
require(
|
|
769
|
+
totSupData.length != 0,
|
|
770
|
+
"StdCheats deal(address,address,uint,uint,bool): target contract is not ERC1155Supply."
|
|
771
|
+
);
|
|
772
|
+
uint256 totSup = abi.decode(totSupData, (uint256));
|
|
773
|
+
if (give < prevBal) {
|
|
774
|
+
totSup -= (prevBal - give);
|
|
775
|
+
} else {
|
|
776
|
+
totSup += (give - prevBal);
|
|
777
|
+
}
|
|
778
|
+
stdstore.target(token).sig(0xbd85b039).with_key(id).checked_write(totSup);
|
|
779
|
+
}
|
|
780
|
+
}
|
|
781
|
+
|
|
782
|
+
function dealERC721(address token, address to, uint256 id) internal virtual {
|
|
783
|
+
// check if token id is already minted and the actual owner.
|
|
784
|
+
(bool successMinted, bytes memory ownerData) = token.staticcall(abi.encodeWithSelector(0x6352211e, id));
|
|
785
|
+
require(successMinted, "StdCheats deal(address,address,uint,bool): id not minted.");
|
|
786
|
+
|
|
787
|
+
// get owner current balance
|
|
788
|
+
(, bytes memory fromBalData) =
|
|
789
|
+
token.staticcall(abi.encodeWithSelector(0x70a08231, abi.decode(ownerData, (address))));
|
|
790
|
+
uint256 fromPrevBal = abi.decode(fromBalData, (uint256));
|
|
791
|
+
|
|
792
|
+
// get new user current balance
|
|
793
|
+
(, bytes memory toBalData) = token.staticcall(abi.encodeWithSelector(0x70a08231, to));
|
|
794
|
+
uint256 toPrevBal = abi.decode(toBalData, (uint256));
|
|
795
|
+
|
|
796
|
+
// update balances
|
|
797
|
+
stdstore.target(token).sig(0x70a08231).with_key(abi.decode(ownerData, (address))).checked_write(--fromPrevBal);
|
|
798
|
+
stdstore.target(token).sig(0x70a08231).with_key(to).checked_write(++toPrevBal);
|
|
799
|
+
|
|
800
|
+
// update owner
|
|
801
|
+
stdstore.target(token).sig(0x6352211e).with_key(id).checked_write(to);
|
|
802
|
+
}
|
|
803
|
+
|
|
804
|
+
function deployCodeTo(string memory what, address where) internal virtual {
|
|
805
|
+
deployCodeTo(what, "", 0, where);
|
|
806
|
+
}
|
|
807
|
+
|
|
808
|
+
function deployCodeTo(string memory what, bytes memory args, address where) internal virtual {
|
|
809
|
+
deployCodeTo(what, args, 0, where);
|
|
810
|
+
}
|
|
811
|
+
|
|
812
|
+
function deployCodeTo(string memory what, bytes memory args, uint256 value, address where) internal virtual {
|
|
813
|
+
bytes memory creationCode = vm.getCode(what);
|
|
814
|
+
vm.etch(where, abi.encodePacked(creationCode, args));
|
|
815
|
+
(bool success, bytes memory runtimeBytecode) = where.call{value: value}("");
|
|
816
|
+
require(success, "StdCheats deployCodeTo(string,bytes,uint256,address): Failed to create runtime bytecode.");
|
|
817
|
+
vm.etch(where, runtimeBytecode);
|
|
818
|
+
}
|
|
819
|
+
|
|
820
|
+
// Used to prevent the compilation of console, which shortens the compilation time when console is not used elsewhere.
|
|
821
|
+
function console2_log_StdCheats(string memory p0) private view {
|
|
822
|
+
(bool status,) = address(CONSOLE2_ADDRESS).staticcall(abi.encodeWithSignature("log(string)", p0));
|
|
823
|
+
status;
|
|
824
|
+
}
|
|
825
|
+
}
|