polkamarkets-js 3.1.11 → 3.2.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/.gitmodules +18 -0
- package/README.md +356 -53
- package/abis/AccessControl.json +1 -0
- package/abis/Address.json +1 -0
- package/abis/BalanceHolder_ERC20.json +1 -0
- package/abis/CeilDiv.json +1 -0
- package/abis/CeilDivBad.json +1 -0
- package/abis/CeilDivGood.json +1 -0
- package/abis/Clones.json +1 -0
- package/abis/CommonBase.json +1 -0
- package/abis/Context.json +1 -0
- package/abis/ContextUpgradeable.json +1 -0
- package/abis/Create2.json +1 -0
- package/abis/CreateMarketLib.json +1 -0
- package/abis/DeployProxy.json +1 -0
- package/abis/DeployUpgradeablePM.json +1 -0
- package/abis/ERC165.json +1 -0
- package/abis/ERC1967Proxy.json +1 -0
- package/abis/ERC1967Utils.json +1 -0
- package/abis/ERC20.json +1 -0
- package/abis/ERC20Burnable.json +1 -0
- package/abis/ERC20MinterPauser.json +1 -0
- package/abis/ERC20Pausable.json +1 -0
- package/abis/Errors.json +1 -0
- package/abis/FantasyERC20.json +1 -0
- package/abis/IAccessControl.json +1 -0
- package/abis/IBalanceHolder_ERC20.json +1 -0
- package/abis/IBeacon.json +1 -0
- package/abis/IERC1155Errors.json +1 -0
- package/abis/IERC1363.json +1 -0
- package/abis/IERC165.json +1 -0
- package/abis/IERC1822Proxiable.json +1 -0
- package/abis/IERC1967.json +1 -0
- package/abis/IERC20.json +1 -0
- package/abis/IERC20Errors.json +1 -0
- package/abis/IERC20Metadata.json +1 -0
- package/abis/IERC721.json +1 -0
- package/abis/IERC721Enumerable.json +1 -0
- package/abis/IERC721Errors.json +1 -0
- package/abis/IERC721Metadata.json +1 -0
- package/abis/IERC721TokenReceiver.json +1 -0
- package/abis/IFantasyERC20.json +1 -0
- package/abis/IMulticall3.json +1 -0
- package/abis/IPredictionMarketV3Factory.json +1 -0
- package/abis/IPredictionMarketV3Manager.json +1 -0
- package/abis/IPredictionMarketV3_2.json +1 -0
- package/abis/IPredictionMarketV3_4.json +1 -0
- package/abis/IRealityETH_ERC20.json +1 -0
- package/abis/IRealityETH_IERC20.json +1 -0
- package/abis/IWETH.json +1 -0
- package/abis/Initializable.json +1 -0
- package/abis/LandFactory.json +1 -0
- package/abis/MockERC20.json +1 -0
- package/abis/MockERC721.json +1 -0
- package/abis/Ownable.json +1 -0
- package/abis/Ownable2StepUpgradeable.json +1 -0
- package/abis/OwnableUpgradeable.json +1 -0
- package/abis/Pausable.json +1 -0
- package/abis/PredictionMarketManagerTest.json +1 -0
- package/abis/PredictionMarketTest.json +1 -0
- package/abis/PredictionMarketV33Flow.json +1 -0
- package/abis/PredictionMarketV3Controller.json +1 -0
- package/abis/PredictionMarketV3Factory.json +1 -0
- package/abis/PredictionMarketV3Manager.json +1 -0
- package/abis/PredictionMarketV3Querier.json +1 -0
- package/abis/PredictionMarketV3_2.json +1 -0
- package/abis/PredictionMarketV3_4.json +1 -0
- package/abis/PredictionMarketV3_4Bad.json +1 -0
- package/abis/PredictionMarketV3_4Good.json +1 -0
- package/abis/Proxy.json +1 -0
- package/abis/RealityETH_ERC20_Factory.json +1 -0
- package/abis/RealityETH_ERC20_v3_0.json +1 -0
- package/abis/ReentrancyGuard.json +1 -0
- package/abis/ReentrancyGuardUpgradeable.json +1 -0
- package/abis/SafeERC20.json +1 -0
- package/abis/Script.json +1 -0
- package/abis/ScriptBase.json +1 -0
- package/abis/StdAssertions.json +1 -0
- package/abis/StdChains.json +1 -0
- package/abis/StdCheats.json +1 -0
- package/abis/StdCheatsSafe.json +1 -0
- package/abis/StdInvariant.json +1 -0
- package/abis/StdStyle.json +1 -0
- package/abis/StdUtils.json +1 -0
- package/abis/StorageSlot.json +1 -0
- package/abis/TestBase.json +1 -0
- package/abis/UUPSUpgradeable.json +1 -0
- package/abis/Vm.json +1 -0
- package/abis/VmSafe.json +1 -0
- package/abis/Voting.json +1 -0
- package/abis/WETH.json +1 -0
- package/abis/console.json +1 -0
- package/abis/safeconsole.json +1 -0
- package/abis/stdError.json +1 -0
- package/abis/stdJson.json +1 -0
- package/abis/stdMath.json +1 -0
- package/abis/stdStorage.json +1 -0
- package/abis/stdStorageSafe.json +1 -0
- package/abis/stdToml.json +1 -0
- package/abis/test.json +1 -0
- package/contracts/ERC20MinterPauser.sol +100 -0
- package/contracts/FantasyERC20.sol +12 -10
- package/contracts/IFantasyERC20.sol +1 -1
- package/contracts/IPredictionMarketV3Factory.sol +1 -1
- package/contracts/IPredictionMarketV3Manager.sol +5 -1
- package/contracts/IPredictionMarketV3_4.sol +219 -0
- package/contracts/IRealityETH_ERC20.sol +1 -1
- package/contracts/IWETH.sol +12 -0
- package/contracts/LandFactory.sol +71 -27
- package/contracts/PredictionMarketV3Controller.sol +7 -7
- package/contracts/PredictionMarketV3Factory.sol +7 -5
- package/contracts/PredictionMarketV3Manager.sol +7 -7
- package/contracts/PredictionMarketV3Querier.sol +14 -4
- package/contracts/PredictionMarketV3_4.sol +1492 -0
- package/contracts/PredictionMarketV3_4Bad.sol +1487 -0
- package/contracts/PredictionMarketV3_4Good.sol +1508 -0
- package/contracts/Proxy.sol +35 -0
- package/contracts/RealityETH_ERC20_Factory.sol +4 -11
- package/contracts/Voting.sol +4 -7
- package/contracts/WETH.sol +58 -0
- package/dist/Application.d.ts +201 -0
- package/dist/Application.d.ts.map +1 -0
- package/dist/Application.js +411 -0
- package/dist/Application.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +16 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces/index.d.ts +4 -0
- package/dist/interfaces/index.d.ts.map +1 -0
- package/dist/interfaces/index.js +22 -0
- package/dist/interfaces/index.js.map +1 -0
- package/dist/models/AchievementsContract.d.ts +43 -0
- package/dist/models/AchievementsContract.d.ts.map +1 -0
- package/dist/models/AchievementsContract.js +177 -0
- package/dist/models/AchievementsContract.js.map +1 -0
- package/dist/models/ArbitrationContract.d.ts +23 -0
- package/dist/models/ArbitrationContract.d.ts.map +1 -0
- package/dist/models/ArbitrationContract.js +47 -0
- package/dist/models/ArbitrationContract.js.map +1 -0
- package/dist/models/ArbitrationProxyContract.d.ts +14 -0
- package/dist/models/ArbitrationProxyContract.d.ts.map +1 -0
- package/dist/models/ArbitrationProxyContract.js +26 -0
- package/dist/models/ArbitrationProxyContract.js.map +1 -0
- package/dist/models/ERC20Contract.d.ts +50 -0
- package/dist/models/ERC20Contract.d.ts.map +1 -0
- package/dist/models/ERC20Contract.js +99 -0
- package/dist/models/ERC20Contract.js.map +1 -0
- package/dist/models/FantasyERC20Contract.d.ts +13 -0
- package/dist/models/FantasyERC20Contract.d.ts.map +1 -0
- package/dist/models/FantasyERC20Contract.js +43 -0
- package/dist/models/FantasyERC20Contract.js.map +1 -0
- package/dist/models/IContract.d.ts +57 -0
- package/dist/models/IContract.d.ts.map +1 -0
- package/dist/models/IContract.js +515 -0
- package/dist/models/IContract.js.map +1 -0
- package/dist/models/PolkamarketsSmartAccount.d.ts +26 -0
- package/dist/models/PolkamarketsSmartAccount.d.ts.map +1 -0
- package/dist/models/PolkamarketsSmartAccount.js +100 -0
- package/dist/models/PolkamarketsSmartAccount.js.map +1 -0
- package/dist/models/PredictionMarketContract.d.ts +113 -0
- package/dist/models/PredictionMarketContract.d.ts.map +1 -0
- package/dist/models/PredictionMarketContract.js +298 -0
- package/dist/models/PredictionMarketContract.js.map +1 -0
- package/dist/models/PredictionMarketV2Contract.d.ts +157 -0
- package/dist/models/PredictionMarketV2Contract.d.ts.map +1 -0
- package/dist/models/PredictionMarketV2Contract.js +431 -0
- package/dist/models/PredictionMarketV2Contract.js.map +1 -0
- package/dist/models/PredictionMarketV3Contract.d.ts +42 -0
- package/dist/models/PredictionMarketV3Contract.d.ts.map +1 -0
- package/dist/models/PredictionMarketV3Contract.js +277 -0
- package/dist/models/PredictionMarketV3Contract.js.map +1 -0
- package/dist/models/PredictionMarketV3ControllerContract.d.ts +128 -0
- package/dist/models/PredictionMarketV3ControllerContract.d.ts.map +1 -0
- package/dist/models/PredictionMarketV3ControllerContract.js +174 -0
- package/dist/models/PredictionMarketV3ControllerContract.js.map +1 -0
- package/dist/models/PredictionMarketV3FactoryContract.d.ts +31 -0
- package/dist/models/PredictionMarketV3FactoryContract.d.ts.map +1 -0
- package/dist/models/PredictionMarketV3FactoryContract.js +81 -0
- package/dist/models/PredictionMarketV3FactoryContract.js.map +1 -0
- package/dist/models/PredictionMarketV3ManagerContract.d.ts +67 -0
- package/dist/models/PredictionMarketV3ManagerContract.d.ts.map +1 -0
- package/dist/models/PredictionMarketV3ManagerContract.js +97 -0
- package/dist/models/PredictionMarketV3ManagerContract.js.map +1 -0
- package/dist/models/PredictionMarketV3QuerierContract.d.ts +33 -0
- package/dist/models/PredictionMarketV3QuerierContract.d.ts.map +1 -0
- package/dist/models/PredictionMarketV3QuerierContract.js +61 -0
- package/dist/models/PredictionMarketV3QuerierContract.js.map +1 -0
- package/dist/models/PredictionMarketV3_2Contract.d.ts +32 -0
- package/dist/models/PredictionMarketV3_2Contract.d.ts.map +1 -0
- package/dist/models/PredictionMarketV3_2Contract.js +169 -0
- package/dist/models/PredictionMarketV3_2Contract.js.map +1 -0
- package/dist/models/RealitioERC20Contract.d.ts +16 -0
- package/dist/models/RealitioERC20Contract.d.ts.map +1 -0
- package/dist/models/RealitioERC20Contract.js +18 -0
- package/dist/models/RealitioERC20Contract.js.map +1 -0
- package/dist/models/VotingContract.d.ts +38 -0
- package/dist/models/VotingContract.d.ts.map +1 -0
- package/dist/models/VotingContract.js +85 -0
- package/dist/models/VotingContract.js.map +1 -0
- package/dist/models/WETH9Contract.d.ts +29 -0
- package/dist/models/WETH9Contract.d.ts.map +1 -0
- package/dist/models/WETH9Contract.js +44 -0
- package/dist/models/WETH9Contract.js.map +1 -0
- package/dist/models/index.d.ts +18 -0
- package/dist/models/index.d.ts.map +1 -0
- package/dist/models/index.js +37 -0
- package/dist/models/index.js.map +1 -0
- package/dist/types/contracts.d.ts +46 -0
- package/dist/types/contracts.d.ts.map +1 -0
- package/dist/types/contracts.js +3 -0
- package/dist/types/contracts.js.map +1 -0
- package/dist/types/index.d.ts +1 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/Account.d.ts +34 -0
- package/dist/utils/Account.d.ts.map +1 -0
- package/dist/utils/Account.js +38 -0
- package/dist/utils/Account.js.map +1 -0
- package/dist/utils/Contract.d.ts +31 -0
- package/dist/utils/Contract.d.ts.map +1 -0
- package/dist/utils/Contract.js +123 -0
- package/dist/utils/Contract.js.map +1 -0
- package/dist/utils/Numbers.d.ts +27 -0
- package/dist/utils/Numbers.d.ts.map +1 -0
- package/dist/utils/Numbers.js +87 -0
- package/dist/utils/Numbers.js.map +1 -0
- package/foundry.toml +11 -0
- package/lib/openzeppelin-contracts/.changeset/all-geese-stand.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/clean-ways-push.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/config.json +12 -0
- package/lib/openzeppelin-contracts/.changeset/dull-students-eat.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/eight-radios-check.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/fine-frogs-bake.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/full-ways-help.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/funny-years-yawn.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/hot-grapes-lie.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/lazy-poets-cheer.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/long-hornets-mate.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/lucky-donuts-scream.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/major-feet-write.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/new-days-tease.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/nice-rings-wish.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/pink-dolls-shop.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/popular-geese-tan.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/proud-tables-sip.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/public-crabs-heal.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/quiet-kiwis-feel.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/rare-shirts-unite.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/rich-cows-repair.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/ripe-bears-hide.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/rotten-apes-lie.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/social-walls-obey.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/sour-pens-shake.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/strong-points-change.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/tame-bears-mix.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/violet-turtles-like.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/wet-dodos-reply.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/whole-plums-speak.md +5 -0
- package/lib/openzeppelin-contracts/.changeset/wild-baths-buy.md +5 -0
- package/lib/openzeppelin-contracts/.codecov.yml +4 -0
- package/lib/openzeppelin-contracts/.github/CODEOWNERS +10 -0
- package/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/bug_report.md +1 -1
- package/lib/openzeppelin-contracts/.github/PULL_REQUEST_TEMPLATE.md +1 -1
- package/lib/openzeppelin-contracts/.github/actions/gas-compare/action.yml +7 -5
- package/lib/openzeppelin-contracts/.github/actions/setup/action.yml +9 -7
- 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 +67 -25
- package/lib/openzeppelin-contracts/.github/workflows/docs.yml +1 -1
- package/lib/openzeppelin-contracts/.github/workflows/formal-verification.yml +86 -0
- package/lib/openzeppelin-contracts/.github/workflows/release-cycle.yml +214 -0
- package/lib/openzeppelin-contracts/.github/workflows/upgradeable.yml +23 -12
- package/lib/openzeppelin-contracts/.gitmodules +7 -0
- package/lib/openzeppelin-contracts/.husky/pre-commit +2 -0
- package/lib/openzeppelin-contracts/.prettierrc +5 -4
- package/lib/openzeppelin-contracts/.solcover.js +19 -13
- package/lib/openzeppelin-contracts/CHANGELOG.md +918 -325
- package/lib/openzeppelin-contracts/CODE_OF_CONDUCT.md +2 -2
- package/lib/openzeppelin-contracts/CONTRIBUTING.md +19 -47
- package/lib/openzeppelin-contracts/FUNDING.json +10 -0
- package/lib/openzeppelin-contracts/GUIDELINES.md +115 -65
- package/lib/openzeppelin-contracts/LICENSE +1 -1
- package/lib/openzeppelin-contracts/README.md +40 -16
- package/lib/openzeppelin-contracts/RELEASING.md +32 -23
- package/lib/openzeppelin-contracts/SECURITY.md +34 -11
- 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/README.md +20 -0
- package/lib/openzeppelin-contracts/certora/Makefile +44 -14
- package/lib/openzeppelin-contracts/certora/README.md +43 -39
- package/lib/openzeppelin-contracts/certora/diff/access_manager_AccessManager.sol.patch +97 -0
- package/lib/openzeppelin-contracts/certora/harnesses/AccessControlDefaultAdminRulesHarness.sol +46 -0
- package/lib/openzeppelin-contracts/certora/harnesses/AccessControlHarness.sol +6 -0
- package/lib/openzeppelin-contracts/certora/harnesses/AccessManagedHarness.sol +36 -0
- package/lib/openzeppelin-contracts/certora/harnesses/AccessManagerHarness.sol +116 -0
- package/lib/openzeppelin-contracts/certora/harnesses/DoubleEndedQueueHarness.sol +58 -0
- package/lib/openzeppelin-contracts/certora/harnesses/ERC20FlashMintHarness.sol +36 -0
- package/lib/openzeppelin-contracts/certora/harnesses/ERC20PermitHarness.sol +16 -0
- package/lib/openzeppelin-contracts/certora/harnesses/ERC20WrapperHarness.sol +34 -0
- package/lib/openzeppelin-contracts/certora/harnesses/ERC3156FlashBorrowerHarness.sol +13 -0
- package/lib/openzeppelin-contracts/certora/harnesses/ERC721Harness.sol +33 -0
- package/lib/openzeppelin-contracts/certora/harnesses/ERC721ReceiverHarness.sol +11 -0
- package/lib/openzeppelin-contracts/certora/harnesses/EnumerableMapHarness.sol +55 -0
- package/lib/openzeppelin-contracts/certora/harnesses/EnumerableSetHarness.sol +35 -0
- package/lib/openzeppelin-contracts/certora/harnesses/InitializableHarness.sol +23 -0
- package/lib/openzeppelin-contracts/certora/harnesses/NoncesHarness.sol +14 -0
- package/lib/openzeppelin-contracts/certora/harnesses/Ownable2StepHarness.sol +10 -0
- package/lib/openzeppelin-contracts/certora/harnesses/OwnableHarness.sol +10 -0
- package/lib/openzeppelin-contracts/certora/harnesses/PausableHarness.sol +18 -0
- package/lib/openzeppelin-contracts/certora/harnesses/TimelockControllerHarness.sol +13 -0
- package/lib/openzeppelin-contracts/certora/reports/2021-10.pdf +0 -0
- package/lib/openzeppelin-contracts/certora/reports/2022-03.pdf +0 -0
- package/lib/openzeppelin-contracts/certora/reports/2022-05.pdf +0 -0
- package/lib/openzeppelin-contracts/certora/run.js +168 -0
- package/lib/openzeppelin-contracts/certora/specs/AccessControl.spec +119 -0
- package/lib/openzeppelin-contracts/certora/specs/AccessControlDefaultAdminRules.spec +464 -0
- package/lib/openzeppelin-contracts/certora/specs/AccessManaged.spec +34 -0
- package/lib/openzeppelin-contracts/certora/specs/AccessManager.spec +826 -0
- package/lib/openzeppelin-contracts/certora/specs/DoubleEndedQueue.spec +300 -0
- package/lib/openzeppelin-contracts/certora/specs/ERC20.spec +352 -0
- package/lib/openzeppelin-contracts/certora/specs/ERC20FlashMint.spec +55 -0
- package/lib/openzeppelin-contracts/certora/specs/ERC20Wrapper.spec +198 -0
- package/lib/openzeppelin-contracts/certora/specs/ERC721.spec +679 -0
- package/lib/openzeppelin-contracts/certora/specs/EnumerableMap.spec +333 -0
- package/lib/openzeppelin-contracts/certora/specs/EnumerableSet.spec +246 -0
- package/lib/openzeppelin-contracts/certora/specs/Initializable.spec +165 -0
- package/lib/openzeppelin-contracts/certora/specs/Nonces.spec +92 -0
- package/lib/openzeppelin-contracts/certora/specs/Ownable.spec +77 -0
- package/lib/openzeppelin-contracts/certora/specs/Ownable2Step.spec +108 -0
- package/lib/openzeppelin-contracts/certora/specs/Pausable.spec +96 -0
- package/lib/openzeppelin-contracts/certora/specs/TimelockController.spec +274 -0
- package/lib/openzeppelin-contracts/certora/specs/helpers/helpers.spec +12 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IAccessControl.spec +8 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IAccessControlDefaultAdminRules.spec +36 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IAccessManaged.spec +5 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IAccessManager.spec +33 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC20.spec +11 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC2612.spec +5 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC3156FlashBorrower.spec +3 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC3156FlashLender.spec +5 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC5313.spec +3 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC721.spec +17 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC721Receiver.spec +3 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IOwnable.spec +5 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IOwnable2Step.spec +7 -0
- package/lib/openzeppelin-contracts/certora/specs.json +110 -0
- package/lib/openzeppelin-contracts/contracts/access/AccessControl.sol +41 -81
- package/lib/openzeppelin-contracts/contracts/access/IAccessControl.sol +20 -10
- package/lib/openzeppelin-contracts/contracts/access/Ownable.sol +29 -12
- package/lib/openzeppelin-contracts/contracts/access/Ownable2Step.sol +16 -6
- package/lib/openzeppelin-contracts/contracts/access/README.adoc +23 -3
- 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 +740 -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 +399 -0
- package/lib/openzeppelin-contracts/contracts/access/manager/IAuthority.sol +14 -0
- package/lib/openzeppelin-contracts/contracts/account/Account.sol +144 -0
- package/lib/openzeppelin-contracts/contracts/account/README.adoc +30 -0
- package/lib/openzeppelin-contracts/contracts/account/extensions/draft-AccountERC7579.sol +413 -0
- package/lib/openzeppelin-contracts/contracts/account/extensions/draft-AccountERC7579Hooked.sol +106 -0
- package/lib/openzeppelin-contracts/contracts/account/extensions/draft-ERC7821.sol +69 -0
- package/lib/openzeppelin-contracts/contracts/account/utils/EIP7702Utils.sol +20 -0
- package/lib/openzeppelin-contracts/contracts/account/utils/draft-ERC4337Utils.sol +159 -0
- package/lib/openzeppelin-contracts/contracts/account/utils/draft-ERC7579Utils.sol +280 -0
- package/lib/openzeppelin-contracts/contracts/finance/README.adoc +1 -7
- package/lib/openzeppelin-contracts/contracts/finance/VestingWallet.sol +42 -32
- package/lib/openzeppelin-contracts/contracts/finance/VestingWalletCliff.sol +54 -0
- package/lib/openzeppelin-contracts/contracts/governance/Governor.sol +474 -253
- package/lib/openzeppelin-contracts/contracts/governance/IGovernor.sol +236 -58
- package/lib/openzeppelin-contracts/contracts/governance/README.adoc +37 -16
- package/lib/openzeppelin-contracts/contracts/governance/TimelockController.sol +153 -108
- 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 +22 -33
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorNoncesKeyed.sol +90 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorPreventLateQuorum.sol +24 -40
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorProposalGuardian.sol +58 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSequentialProposalId.sol +75 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSettings.sol +19 -27
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorStorage.sol +125 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSuperQuorum.sol +58 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockAccess.sol +346 -0
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockCompound.sol +47 -75
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockControl.sol +57 -56
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotes.sol +43 -11
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesQuorumFraction.sol +38 -44
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesSuperQuorumFraction.sol +134 -0
- package/lib/openzeppelin-contracts/contracts/governance/utils/IVotes.sol +16 -18
- package/lib/openzeppelin-contracts/contracts/governance/utils/Votes.sol +116 -75
- package/lib/openzeppelin-contracts/contracts/governance/utils/VotesExtended.sol +84 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1155.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1155MetadataURI.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1155Receiver.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1271.sol +5 -7
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1363.sol +54 -63
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1363Receiver.sol +20 -20
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1363Spender.sol +19 -23
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC165.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1820Implementer.sol +17 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1820Registry.sol +109 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC1967.sol +24 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC20.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC20Metadata.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC2309.sol +2 -4
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC2612.sol +8 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC2981.sol +10 -9
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC3156.sol +4 -4
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC3156FlashBorrower.sol +4 -6
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC3156FlashLender.sol +4 -6
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC4626.sol +8 -18
- 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/IERC721.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC721Enumerable.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC721Metadata.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC721Receiver.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC777.sol +197 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC777Recipient.sol +32 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC777Sender.sol +32 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/IERC7913.sol +17 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/README.adoc +50 -1
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC1822.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC4337.sol +253 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC6093.sol +161 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC6909.sol +125 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7579.sol +226 -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 +30 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7821.sol +43 -0
- package/lib/openzeppelin-contracts/contracts/metatx/ERC2771Context.sol +62 -15
- package/lib/openzeppelin-contracts/contracts/metatx/ERC2771Forwarder.sol +372 -0
- package/lib/openzeppelin-contracts/contracts/metatx/README.adoc +6 -1
- 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 +124 -4
- 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 +26 -5
- package/lib/openzeppelin-contracts/contracts/mocks/ConstructorMock.sol +34 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ContextMock.sol +9 -7
- package/lib/openzeppelin-contracts/contracts/mocks/DummyImplementation.sol +10 -6
- package/lib/openzeppelin-contracts/contracts/mocks/EIP712Verifier.sol +16 -0
- package/lib/openzeppelin-contracts/contracts/mocks/ERC1271WalletMock.sol +7 -9
- package/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165InterfacesSupported.sol +4 -4
- package/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165MaliciousData.sol +1 -1
- package/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165MissingData.sol +1 -1
- package/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165NotSupported.sol +1 -1
- package/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165ReturnBomb.sol +2 -2
- package/lib/openzeppelin-contracts/contracts/mocks/ERC2771ContextMock.sol +10 -4
- package/lib/openzeppelin-contracts/contracts/mocks/ERC3156FlashBorrowerMock.sol +6 -6
- package/lib/openzeppelin-contracts/contracts/mocks/EtherReceiverMock.sol +1 -1
- package/lib/openzeppelin-contracts/contracts/mocks/InitializableMock.sol +6 -6
- 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 +7 -12
- package/lib/openzeppelin-contracts/contracts/mocks/PausableMock.sol +2 -2
- package/lib/openzeppelin-contracts/contracts/mocks/ReentrancyAttack.sol +4 -4
- package/lib/openzeppelin-contracts/contracts/mocks/ReentrancyMock.sol +13 -6
- package/lib/openzeppelin-contracts/contracts/mocks/ReentrancyTransientMock.sol +50 -0
- package/lib/openzeppelin-contracts/contracts/mocks/RegressionImplementation.sol +2 -2
- package/lib/openzeppelin-contracts/contracts/mocks/SingleInheritanceInitializableMocks.sol +2 -2
- package/lib/openzeppelin-contracts/contracts/mocks/Stateless.sol +55 -0
- package/lib/openzeppelin-contracts/contracts/mocks/StorageSlotMock.sol +61 -15
- 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 +20 -18
- package/lib/openzeppelin-contracts/contracts/mocks/account/AccountMock.sol +169 -0
- package/lib/openzeppelin-contracts/contracts/mocks/account/modules/ERC7579Mock.sol +122 -0
- package/lib/openzeppelin-contracts/contracts/mocks/account/utils/ERC7579UtilsMock.sol +23 -0
- package/lib/openzeppelin-contracts/contracts/mocks/compound/CompTimelock.sol +1 -1
- 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/MyAccountERC7702.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 +45 -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/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 +26 -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 +28 -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 +13 -0
- package/lib/openzeppelin-contracts/contracts/package.json +2 -2
- package/lib/openzeppelin-contracts/contracts/proxy/Clones.sol +197 -24
- package/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Proxy.sol +21 -13
- package/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Utils.sol +177 -0
- package/lib/openzeppelin-contracts/contracts/proxy/Proxy.sol +4 -21
- package/lib/openzeppelin-contracts/contracts/proxy/README.adoc +13 -11
- package/lib/openzeppelin-contracts/contracts/proxy/beacon/BeaconProxy.sol +23 -27
- package/lib/openzeppelin-contracts/contracts/proxy/beacon/IBeacon.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/proxy/beacon/UpgradeableBeacon.sol +16 -11
- package/lib/openzeppelin-contracts/contracts/proxy/transparent/ProxyAdmin.sol +17 -53
- package/lib/openzeppelin-contracts/contracts/proxy/transparent/TransparentUpgradeableProxy.sol +80 -86
- package/lib/openzeppelin-contracts/contracts/proxy/utils/Initializable.sol +108 -35
- package/lib/openzeppelin-contracts/contracts/proxy/utils/UUPSUpgradeable.sol +81 -30
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/ERC1155.sol +197 -325
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155.sol +28 -30
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155Receiver.sol +7 -6
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/README.adoc +6 -12
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Burnable.sol +11 -23
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Pausable.sol +11 -17
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Supply.sol +45 -21
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155URIStorage.sol +9 -11
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/IERC1155MetadataURI.sol +4 -6
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Holder.sol +11 -7
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Utils.sol +88 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/ERC20.sol +137 -221
- package/lib/openzeppelin-contracts/contracts/token/ERC20/IERC20.sol +13 -16
- package/lib/openzeppelin-contracts/contracts/token/ERC20/README.adoc +28 -36
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC1363.sol +135 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Burnable.sol +13 -13
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Capped.sol +27 -10
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20FlashMint.sol +56 -31
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Pausable.sol +9 -15
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Permit.sol +77 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Votes.sol +43 -235
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Wrapper.sol +48 -22
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC4626.sol +130 -132
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Metadata.sol +4 -6
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Permit.sol +90 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-ERC20Bridgeable.sol +50 -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 +241 -77
- package/lib/openzeppelin-contracts/contracts/token/ERC6909/README.adoc +27 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC6909/draft-ERC6909.sol +224 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/draft-ERC6909ContentURI.sol +53 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/draft-ERC6909Metadata.sol +77 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/draft-ERC6909TokenSupply.sol +35 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/ERC721.sol +250 -326
- package/lib/openzeppelin-contracts/contracts/token/ERC721/IERC721.sol +17 -27
- package/lib/openzeppelin-contracts/contracts/token/ERC721/IERC721Receiver.sol +6 -5
- package/lib/openzeppelin-contracts/contracts/token/ERC721/README.adoc +11 -12
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Burnable.sol +9 -9
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Consecutive.sol +82 -54
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Enumerable.sol +61 -56
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Pausable.sol +12 -15
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Royalty.sol +10 -22
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721URIStorage.sol +25 -29
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Votes.sol +22 -16
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Wrapper.sol +102 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/IERC721Enumerable.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/IERC721Metadata.sol +3 -3
- package/lib/openzeppelin-contracts/contracts/token/ERC721/utils/ERC721Holder.sol +7 -11
- package/lib/openzeppelin-contracts/contracts/token/ERC721/utils/ERC721Utils.sol +50 -0
- package/lib/openzeppelin-contracts/contracts/token/common/ERC2981.sol +56 -28
- package/lib/openzeppelin-contracts/contracts/token/common/README.adoc +2 -2
- package/lib/openzeppelin-contracts/contracts/utils/Address.sol +51 -146
- package/lib/openzeppelin-contracts/contracts/utils/Arrays.sol +481 -25
- package/lib/openzeppelin-contracts/contracts/utils/Base64.sol +65 -38
- package/lib/openzeppelin-contracts/contracts/utils/Blockhash.sol +52 -0
- package/lib/openzeppelin-contracts/contracts/utils/Bytes.sol +166 -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 +6 -2
- package/lib/openzeppelin-contracts/contracts/utils/Create2.sol +29 -20
- package/lib/openzeppelin-contracts/contracts/utils/Errors.sol +34 -0
- package/lib/openzeppelin-contracts/contracts/utils/Memory.sol +44 -0
- package/lib/openzeppelin-contracts/contracts/utils/Multicall.sol +19 -6
- 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 +79 -45
- package/lib/openzeppelin-contracts/contracts/utils/ReentrancyGuard.sol +87 -0
- package/lib/openzeppelin-contracts/contracts/utils/ReentrancyGuardTransient.sol +61 -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 +72 -17
- package/lib/openzeppelin-contracts/contracts/utils/Strings.sol +453 -16
- package/lib/openzeppelin-contracts/contracts/utils/TransientSlot.sol +183 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/ECDSA.sol +96 -96
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/EIP712.sol +96 -40
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/Hashes.sol +31 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/MerkleProof.sol +362 -71
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/MessageHashUtils.sol +99 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/P256.sol +408 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/README.adoc +67 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/RSA.sol +154 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/SignatureChecker.sol +143 -21
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/draft-ERC7739Utils.sol +206 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/AbstractSigner.sol +22 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/MultiSignerERC7913.sol +251 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/MultiSignerERC7913Weighted.sol +207 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerECDSA.sol +55 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerERC7702.sol +24 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerERC7913.sol +62 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerP256.sol +63 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerRSA.sol +64 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/draft-ERC7739.sol +98 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/verifiers/ERC7913P256Verifier.sol +28 -0
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/verifiers/ERC7913RSAVerifier.sol +22 -0
- package/lib/openzeppelin-contracts/contracts/utils/draft-InteroperableAddress.sol +234 -0
- package/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165.sol +6 -10
- package/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165Checker.sol +18 -21
- package/lib/openzeppelin-contracts/contracts/utils/introspection/IERC165.sol +5 -5
- package/lib/openzeppelin-contracts/contracts/utils/math/Math.sol +580 -176
- package/lib/openzeppelin-contracts/contracts/utils/math/SafeCast.sol +224 -198
- package/lib/openzeppelin-contracts/contracts/utils/math/SignedMath.sol +31 -6
- package/lib/openzeppelin-contracts/contracts/utils/structs/BitMaps.sol +14 -9
- package/lib/openzeppelin-contracts/contracts/utils/structs/Checkpoints.sol +833 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/CircularBuffer.sol +140 -0
- package/lib/openzeppelin-contracts/contracts/utils/structs/DoubleEndedQueue.sol +46 -60
- package/lib/openzeppelin-contracts/contracts/utils/structs/EnumerableMap.sol +919 -130
- package/lib/openzeppelin-contracts/contracts/utils/structs/EnumerableSet.sol +441 -27
- package/lib/openzeppelin-contracts/contracts/utils/structs/Heap.sol +256 -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 +3 -3
- package/lib/openzeppelin-contracts/docs/README.md +16 -0
- package/lib/openzeppelin-contracts/docs/antora.yml +2 -1
- 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/nav.adoc +13 -7
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/access-control.adoc +168 -97
- 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 +19 -54
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20-supply.adoc +13 -55
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20.adoc +7 -25
- 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 +10 -42
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/extending-contracts.adoc +4 -82
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/faq.adoc +13 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/governance.adoc +85 -167
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/index.adoc +19 -12
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/multisig.adoc +306 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/tokens.adoc +4 -5
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/upgradeable.adoc +14 -10
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/utilities.adoc +482 -81
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/wizard.adoc +1 -1
- package/lib/openzeppelin-contracts/docs/templates/contract.hbs +57 -1
- package/lib/openzeppelin-contracts/docs/templates/helpers.js +8 -8
- package/lib/openzeppelin-contracts/docs/templates/properties.js +47 -8
- package/lib/openzeppelin-contracts/eslint.config.mjs +26 -0
- package/lib/openzeppelin-contracts/foundry.toml +15 -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/common-contracts.js +69 -0
- package/lib/openzeppelin-contracts/hardhat/env-artifacts.js +29 -0
- package/lib/openzeppelin-contracts/hardhat/ignore-unreachable-warnings.js +2 -4
- package/lib/openzeppelin-contracts/hardhat/remappings.js +18 -0
- package/lib/openzeppelin-contracts/hardhat/skip-foundry-tests.js +3 -4
- package/lib/openzeppelin-contracts/hardhat/task-test-get-files.js +25 -0
- package/lib/openzeppelin-contracts/hardhat.config.js +67 -49
- package/lib/openzeppelin-contracts/lib/erc4626-tests/ERC4626.prop.sol +404 -0
- package/lib/openzeppelin-contracts/lib/erc4626-tests/ERC4626.test.sol +356 -0
- package/lib/openzeppelin-contracts/lib/erc4626-tests/LICENSE +661 -0
- package/lib/openzeppelin-contracts/lib/erc4626-tests/README.md +116 -0
- package/lib/openzeppelin-contracts/lib/forge-std/.gitattributes +1 -0
- package/lib/openzeppelin-contracts/lib/forge-std/.github/workflows/ci.yml +48 -12
- package/lib/openzeppelin-contracts/lib/forge-std/.github/workflows/sync.yml +31 -0
- package/lib/openzeppelin-contracts/lib/forge-std/CONTRIBUTING.md +193 -0
- package/lib/openzeppelin-contracts/lib/forge-std/README.md +19 -3
- package/lib/openzeppelin-contracts/lib/forge-std/foundry.toml +5 -3
- package/lib/openzeppelin-contracts/lib/forge-std/package.json +2 -2
- package/lib/openzeppelin-contracts/lib/forge-std/scripts/vm.py +646 -0
- package/lib/openzeppelin-contracts/lib/forge-std/src/Base.sol +7 -3
- package/lib/openzeppelin-contracts/lib/forge-std/src/Script.sol +4 -3
- package/lib/openzeppelin-contracts/lib/forge-std/src/StdAssertions.sol +595 -135
- package/lib/openzeppelin-contracts/lib/forge-std/src/StdChains.sol +146 -48
- package/lib/openzeppelin-contracts/lib/forge-std/src/StdCheats.sol +303 -39
- package/lib/openzeppelin-contracts/lib/forge-std/src/StdInvariant.sol +122 -0
- package/lib/openzeppelin-contracts/lib/forge-std/src/StdJson.sol +129 -25
- package/lib/openzeppelin-contracts/lib/forge-std/src/StdStorage.sol +245 -99
- package/lib/openzeppelin-contracts/lib/forge-std/src/StdStyle.sol +333 -0
- package/lib/openzeppelin-contracts/lib/forge-std/src/StdToml.sol +283 -0
- package/lib/openzeppelin-contracts/lib/forge-std/src/StdUtils.sol +125 -39
- package/lib/openzeppelin-contracts/lib/forge-std/src/Test.sol +10 -5
- package/lib/openzeppelin-contracts/lib/forge-std/src/Vm.sol +2182 -304
- package/lib/openzeppelin-contracts/lib/forge-std/src/console.sol +635 -608
- package/lib/openzeppelin-contracts/lib/forge-std/src/console2.sol +1 -1543
- package/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC4626.sol +2 -2
- package/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IMulticall3.sol +73 -0
- package/lib/openzeppelin-contracts/lib/forge-std/src/safeconsole.sol +13937 -0
- package/lib/openzeppelin-contracts/lib/forge-std/test/StdAssertions.t.sol +126 -572
- package/lib/openzeppelin-contracts/lib/forge-std/test/StdChains.t.sol +166 -62
- package/lib/openzeppelin-contracts/lib/forge-std/test/StdCheats.t.sol +348 -35
- package/lib/openzeppelin-contracts/lib/forge-std/test/StdError.t.sol +15 -13
- package/lib/openzeppelin-contracts/lib/forge-std/test/StdJson.t.sol +49 -0
- package/lib/openzeppelin-contracts/lib/forge-std/test/StdMath.t.sol +31 -26
- package/lib/openzeppelin-contracts/lib/forge-std/test/StdStorage.t.sol +251 -46
- package/lib/openzeppelin-contracts/lib/forge-std/test/StdStyle.t.sol +110 -0
- package/lib/openzeppelin-contracts/lib/forge-std/test/StdToml.t.sol +49 -0
- package/lib/openzeppelin-contracts/lib/forge-std/test/StdUtils.t.sol +186 -35
- package/lib/openzeppelin-contracts/lib/forge-std/test/Vm.t.sol +18 -0
- package/lib/openzeppelin-contracts/lib/forge-std/test/fixtures/test.json +8 -0
- package/lib/openzeppelin-contracts/lib/forge-std/test/fixtures/test.toml +6 -0
- package/lib/openzeppelin-contracts/lib/halmos-cheatcodes/LICENSE +661 -0
- package/lib/openzeppelin-contracts/lib/halmos-cheatcodes/README.md +97 -0
- package/lib/openzeppelin-contracts/lib/halmos-cheatcodes/src/SVM.sol +49 -0
- package/lib/openzeppelin-contracts/lib/halmos-cheatcodes/src/SymTest.sol +11 -0
- package/lib/openzeppelin-contracts/package.json +59 -45
- package/lib/openzeppelin-contracts/remappings.txt +1 -0
- package/lib/openzeppelin-contracts/renovate.json +2 -9
- package/lib/openzeppelin-contracts/scripts/checks/compare-layout.js +28 -0
- package/lib/openzeppelin-contracts/scripts/checks/compareGasReports.js +130 -92
- 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/inheritance-ordering.js +28 -23
- 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 +62 -22
- package/lib/openzeppelin-contracts/scripts/generate/format-lines.js +4 -4
- package/lib/openzeppelin-contracts/scripts/generate/helpers/sanitize.js +5 -0
- package/lib/openzeppelin-contracts/scripts/generate/run.js +38 -23
- package/lib/openzeppelin-contracts/scripts/generate/templates/Arrays.js +386 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Arrays.opts.js +9 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.js +67 -128
- 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 +53 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableMap.js +269 -84
- package/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableSet.js +252 -36
- package/lib/openzeppelin-contracts/scripts/generate/templates/MerkleProof.js +187 -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 +50 -82
- 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 +18 -18
- package/lib/openzeppelin-contracts/scripts/get-contracts-metadata.js +55 -0
- package/lib/openzeppelin-contracts/scripts/helpers.js +4 -20
- package/lib/openzeppelin-contracts/scripts/minimize-pragma.js +138 -0
- package/lib/openzeppelin-contracts/scripts/prepack.sh +14 -3
- package/lib/openzeppelin-contracts/scripts/prepare-docs.sh +12 -1
- package/lib/openzeppelin-contracts/scripts/release/format-changelog.js +33 -0
- package/lib/openzeppelin-contracts/scripts/release/synchronize-versions.js +6 -7
- package/lib/openzeppelin-contracts/scripts/release/update-comment.js +2 -4
- package/lib/openzeppelin-contracts/scripts/release/version.sh +4 -2
- 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 +4 -4
- 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 +84 -0
- package/lib/openzeppelin-contracts/scripts/solhint-custom/package.json +8 -0
- package/lib/openzeppelin-contracts/scripts/update-docs-branch.js +15 -5
- package/lib/openzeppelin-contracts/scripts/upgradeable/README.md +21 -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 +398 -0
- package/lib/openzeppelin-contracts/slither.config.json +3 -4
- package/lib/openzeppelin-contracts/solhint.config.js +29 -0
- package/lib/openzeppelin-contracts/test/TESTING.md +1 -1
- package/lib/openzeppelin-contracts/test/access/AccessControl.behavior.js +756 -98
- package/lib/openzeppelin-contracts/test/access/AccessControl.test.js +13 -7
- package/lib/openzeppelin-contracts/test/access/Ownable.test.js +50 -28
- package/lib/openzeppelin-contracts/test/access/Ownable2Step.test.js +77 -32
- 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/AccountERC7702.t.sol +103 -0
- package/lib/openzeppelin-contracts/test/account/AccountERC7702.test.js +52 -0
- package/lib/openzeppelin-contracts/test/account/AccountERC7913.test.js +116 -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/examples/AccountERC7702WithModulesMock.test.js +99 -0
- package/lib/openzeppelin-contracts/test/account/extensions/AccountERC7579.behavior.js +563 -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 +289 -0
- package/lib/openzeppelin-contracts/test/account/utils/draft-ERC7579Utils.t.sol +426 -0
- package/lib/openzeppelin-contracts/test/account/utils/draft-ERC7579Utils.test.js +399 -0
- package/lib/openzeppelin-contracts/test/bin/EntryPoint070.abi +1 -0
- package/lib/openzeppelin-contracts/test/bin/EntryPoint070.bytecode +0 -0
- package/lib/openzeppelin-contracts/test/bin/EntryPoint080.abi +1 -0
- package/lib/openzeppelin-contracts/test/bin/EntryPoint080.bytecode +0 -0
- package/lib/openzeppelin-contracts/test/bin/SenderCreator070.abi +1 -0
- package/lib/openzeppelin-contracts/test/bin/SenderCreator070.bytecode +0 -0
- package/lib/openzeppelin-contracts/test/bin/SenderCreator080.abi +1 -0
- package/lib/openzeppelin-contracts/test/bin/SenderCreator080.bytecode +0 -0
- package/lib/openzeppelin-contracts/test/finance/VestingWallet.behavior.js +59 -46
- package/lib/openzeppelin-contracts/test/finance/VestingWallet.test.js +35 -37
- 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 +938 -590
- package/lib/openzeppelin-contracts/test/governance/TimelockController.test.js +910 -765
- 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 +127 -100
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorNoncesKeyed.test.js +244 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorPreventLateQuorum.test.js +181 -173
- 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 +155 -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 +419 -339
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockControl.test.js +468 -384
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorVotesQuorumFraction.test.js +161 -133
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorVotesSuperQuorumFraction.test.js +160 -0
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorWithParams.test.js +234 -155
- package/lib/openzeppelin-contracts/test/governance/utils/ERC6372.behavior.js +28 -0
- package/lib/openzeppelin-contracts/test/governance/utils/Votes.behavior.js +254 -273
- package/lib/openzeppelin-contracts/test/governance/utils/Votes.test.js +89 -48
- 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 +14 -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 +41 -26
- package/lib/openzeppelin-contracts/test/helpers/enums.js +9 -24
- package/lib/openzeppelin-contracts/test/helpers/erc4337.js +217 -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 +194 -188
- 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 +24 -0
- package/lib/openzeppelin-contracts/test/helpers/signers.js +184 -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/txpool.js +9 -20
- package/lib/openzeppelin-contracts/test/metatx/ERC2771Context.test.js +95 -71
- 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 +60 -50
- package/lib/openzeppelin-contracts/test/proxy/Clones.t.sol +91 -0
- package/lib/openzeppelin-contracts/test/proxy/Clones.test.js +164 -56
- package/lib/openzeppelin-contracts/test/proxy/ERC1967/ERC1967Proxy.test.js +17 -7
- package/lib/openzeppelin-contracts/test/proxy/ERC1967/ERC1967Utils.test.js +162 -0
- package/lib/openzeppelin-contracts/test/proxy/Proxy.behaviour.js +59 -98
- package/lib/openzeppelin-contracts/test/proxy/beacon/BeaconProxy.test.js +98 -113
- package/lib/openzeppelin-contracts/test/proxy/beacon/UpgradeableBeacon.test.js +34 -29
- package/lib/openzeppelin-contracts/test/proxy/transparent/ProxyAdmin.test.js +45 -88
- package/lib/openzeppelin-contracts/test/proxy/transparent/TransparentUpgradeableProxy.behaviour.js +209 -283
- package/lib/openzeppelin-contracts/test/proxy/transparent/TransparentUpgradeableProxy.test.js +20 -7
- package/lib/openzeppelin-contracts/test/proxy/utils/Initializable.test.js +94 -96
- package/lib/openzeppelin-contracts/test/proxy/utils/UUPSUpgradeable.test.js +94 -59
- package/lib/openzeppelin-contracts/test/sanity.test.js +27 -0
- package/lib/openzeppelin-contracts/test/token/ERC1155/ERC1155.behavior.js +530 -541
- package/lib/openzeppelin-contracts/test/token/ERC1155/ERC1155.test.js +101 -152
- package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Burnable.test.js +35 -36
- package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Pausable.test.js +54 -57
- package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Supply.test.js +59 -51
- package/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155URIStorage.test.js +37 -33
- package/lib/openzeppelin-contracts/test/token/ERC1155/utils/ERC1155Holder.test.js +40 -46
- package/lib/openzeppelin-contracts/test/token/ERC1155/utils/ERC1155Utils.test.js +299 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/ERC20.behavior.js +142 -206
- package/lib/openzeppelin-contracts/test/token/ERC20/ERC20.test.js +133 -243
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC1363.test.js +370 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Burnable.test.js +96 -10
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Capped.test.js +43 -15
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20FlashMint.test.js +102 -82
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Pausable.test.js +59 -64
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Permit.test.js +109 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Votes.test.js +490 -462
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Wrapper.test.js +133 -120
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC4626.t.sol +41 -0
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC4626.test.js +802 -536
- 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 +387 -179
- 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 +49 -0
- package/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909Metadata.test.js +58 -0
- package/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909TokenSupply.test.js +53 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/ERC721.behavior.js +488 -479
- package/lib/openzeppelin-contracts/test/token/ERC721/ERC721.test.js +16 -11
- package/lib/openzeppelin-contracts/test/token/ERC721/ERC721Enumerable.test.js +16 -8
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Burnable.test.js +43 -44
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Consecutive.t.sol +80 -19
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Consecutive.test.js +179 -176
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Pausable.test.js +34 -51
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Royalty.test.js +41 -24
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721URIStorage.test.js +69 -44
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Votes.test.js +187 -167
- package/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Wrapper.test.js +201 -0
- package/lib/openzeppelin-contracts/test/token/ERC721/utils/ERC721Holder.test.js +12 -16
- package/lib/openzeppelin-contracts/test/token/ERC721/utils/ERC721Utils.test.js +94 -0
- package/lib/openzeppelin-contracts/test/token/common/ERC2981.behavior.js +80 -88
- package/lib/openzeppelin-contracts/test/utils/Address.test.js +159 -260
- package/lib/openzeppelin-contracts/test/utils/Arrays.t.sol +31 -0
- package/lib/openzeppelin-contracts/test/utils/Arrays.test.js +217 -95
- package/lib/openzeppelin-contracts/test/utils/Base64.t.sol +34 -0
- package/lib/openzeppelin-contracts/test/utils/Base64.test.js +48 -22
- 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 +74 -0
- package/lib/openzeppelin-contracts/test/utils/Bytes.test.js +212 -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 +26 -20
- package/lib/openzeppelin-contracts/test/utils/Context.test.js +10 -9
- package/lib/openzeppelin-contracts/test/utils/Create2.t.sol +17 -0
- package/lib/openzeppelin-contracts/test/utils/Create2.test.js +147 -49
- package/lib/openzeppelin-contracts/test/utils/Memory.t.sol +21 -0
- package/lib/openzeppelin-contracts/test/utils/Memory.test.js +39 -0
- package/lib/openzeppelin-contracts/test/utils/Multicall.test.js +50 -35
- 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.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/ReentrancyGuard.test.js +50 -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 +55 -92
- package/lib/openzeppelin-contracts/test/utils/Strings.t.sol +50 -0
- package/lib/openzeppelin-contracts/test/utils/Strings.test.js +323 -49
- package/lib/openzeppelin-contracts/test/utils/TransientSlot.test.js +59 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/ECDSA.test.js +167 -132
- package/lib/openzeppelin-contracts/test/utils/cryptography/EIP712.test.js +100 -52
- 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 +210 -176
- package/lib/openzeppelin-contracts/test/utils/cryptography/MessageHashUtils.t.sol +33 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/MessageHashUtils.test.js +97 -0
- package/lib/openzeppelin-contracts/test/utils/cryptography/P256.t.sol +65 -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 +397 -56
- 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 +11 -6
- package/lib/openzeppelin-contracts/test/utils/introspection/ERC165Checker.test.js +84 -142
- package/lib/openzeppelin-contracts/test/utils/introspection/SupportsInterface.behavior.js +109 -90
- package/lib/openzeppelin-contracts/test/utils/math/Math.t.sol +255 -24
- package/lib/openzeppelin-contracts/test/utils/math/Math.test.js +616 -215
- package/lib/openzeppelin-contracts/test/utils/math/SafeCast.test.js +84 -89
- package/lib/openzeppelin-contracts/test/utils/math/SignedMath.t.sol +80 -0
- package/lib/openzeppelin-contracts/test/utils/math/SignedMath.test.js +25 -65
- package/lib/openzeppelin-contracts/test/utils/structs/BitMap.test.js +83 -79
- 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 +47 -41
- package/lib/openzeppelin-contracts/test/utils/structs/EnumerableMap.behavior.js +122 -89
- package/lib/openzeppelin-contracts/test/utils/structs/EnumerableMap.test.js +70 -73
- package/lib/openzeppelin-contracts/test/utils/structs/EnumerableSet.behavior.js +105 -61
- package/lib/openzeppelin-contracts/test/utils/structs/EnumerableSet.test.js +53 -33
- 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/lib/openzeppelin-contracts-upgradeable/.changeset/all-geese-stand.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/clean-ways-push.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/config.json +12 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/dull-students-eat.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/eight-radios-check.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/fine-frogs-bake.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/full-ways-help.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/funny-years-yawn.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/hot-grapes-lie.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/lazy-poets-cheer.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/long-hornets-mate.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/lucky-donuts-scream.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/major-feet-write.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/new-days-tease.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/nice-rings-wish.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/pink-dolls-shop.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/popular-geese-tan.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/proud-tables-sip.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/public-crabs-heal.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/quiet-kiwis-feel.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/rare-shirts-unite.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/rich-cows-repair.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/ripe-bears-hide.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/rotten-apes-lie.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/social-walls-obey.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/sour-pens-shake.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/strong-points-change.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/tame-bears-mix.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/violet-turtles-like.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/wet-dodos-reply.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/whole-plums-speak.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.changeset/wild-baths-buy.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/.codecov.yml +4 -0
- package/lib/openzeppelin-contracts-upgradeable/.github/CODEOWNERS +10 -0
- package/lib/openzeppelin-contracts-upgradeable/.github/ISSUE_TEMPLATE/config.yml +4 -0
- package/lib/openzeppelin-contracts-upgradeable/.github/PULL_REQUEST_TEMPLATE.md +1 -1
- package/lib/openzeppelin-contracts-upgradeable/.github/actions/gas-compare/action.yml +7 -5
- package/lib/openzeppelin-contracts-upgradeable/.github/actions/setup/action.yml +9 -7
- package/lib/openzeppelin-contracts-upgradeable/.github/actions/storage-layout/action.yml +57 -0
- package/lib/openzeppelin-contracts-upgradeable/.github/workflows/actionlint.yml +18 -0
- package/lib/openzeppelin-contracts-upgradeable/.github/workflows/changeset.yml +28 -0
- package/lib/openzeppelin-contracts-upgradeable/.github/workflows/checks.yml +67 -36
- package/lib/openzeppelin-contracts-upgradeable/.github/workflows/docs.yml +1 -1
- package/lib/openzeppelin-contracts-upgradeable/.github/workflows/formal-verification.yml +86 -0
- package/lib/openzeppelin-contracts-upgradeable/.github/workflows/release-cycle.yml +214 -0
- package/lib/openzeppelin-contracts-upgradeable/.github/workflows/upgradeable.yml +34 -0
- package/lib/openzeppelin-contracts-upgradeable/.gitmodules +11 -0
- package/lib/openzeppelin-contracts-upgradeable/.husky/pre-commit +2 -0
- package/lib/openzeppelin-contracts-upgradeable/.prettierrc +5 -4
- package/lib/openzeppelin-contracts-upgradeable/.solcover.js +19 -13
- package/lib/openzeppelin-contracts-upgradeable/CHANGELOG.md +918 -328
- package/lib/openzeppelin-contracts-upgradeable/CODE_OF_CONDUCT.md +2 -2
- package/lib/openzeppelin-contracts-upgradeable/CONTRIBUTING.md +19 -47
- package/lib/openzeppelin-contracts-upgradeable/FUNDING.json +10 -0
- package/lib/openzeppelin-contracts-upgradeable/GUIDELINES.md +115 -65
- package/lib/openzeppelin-contracts-upgradeable/LICENSE +1 -1
- package/lib/openzeppelin-contracts-upgradeable/README.md +55 -47
- package/lib/openzeppelin-contracts-upgradeable/RELEASING.md +32 -23
- package/lib/openzeppelin-contracts-upgradeable/SECURITY.md +34 -11
- package/lib/openzeppelin-contracts-upgradeable/audits/2017-03.md +292 -0
- package/lib/openzeppelin-contracts-upgradeable/audits/2022-10-Checkpoints.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/audits/2022-10-ERC4626.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/audits/2023-05-v4.9.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/audits/2023-10-v5.0.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/audits/2024-10-v5.1.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/audits/2024-12-v5.2.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/audits/2025-04-v5.3.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/audits/README.md +20 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/Makefile +44 -14
- package/lib/openzeppelin-contracts-upgradeable/certora/README.md +43 -39
- package/lib/openzeppelin-contracts-upgradeable/certora/diff/access_manager_AccessManager.sol.patch +97 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/AccessControlDefaultAdminRulesHarness.sol +46 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/AccessControlHarness.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/AccessManagedHarness.sol +36 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/AccessManagerHarness.sol +116 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/DoubleEndedQueueHarness.sol +58 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/ERC20FlashMintHarness.sol +36 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/ERC20PermitHarness.sol +16 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/ERC20WrapperHarness.sol +34 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/ERC3156FlashBorrowerHarness.sol +13 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/ERC721Harness.sol +33 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/ERC721ReceiverHarness.sol +11 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/EnumerableMapHarness.sol +55 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/EnumerableSetHarness.sol +35 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/InitializableHarness.sol +23 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/NoncesHarness.sol +14 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/Ownable2StepHarness.sol +10 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/OwnableHarness.sol +10 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/PausableHarness.sol +18 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/TimelockControllerHarness.sol +13 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/reports/2021-10.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/reports/2022-03.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/reports/2022-05.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/run.js +168 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/AccessControl.spec +119 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/AccessControlDefaultAdminRules.spec +464 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/AccessManaged.spec +34 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/AccessManager.spec +826 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/DoubleEndedQueue.spec +300 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/ERC20.spec +352 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/ERC20FlashMint.spec +55 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/ERC20Wrapper.spec +198 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/ERC721.spec +679 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/EnumerableMap.spec +333 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/EnumerableSet.spec +246 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/Initializable.spec +165 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/Nonces.spec +92 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/Ownable.spec +77 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/Ownable2Step.spec +108 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/Pausable.spec +96 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/TimelockController.spec +274 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/helpers/helpers.spec +12 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IAccessControl.spec +8 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IAccessControlDefaultAdminRules.spec +36 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IAccessManaged.spec +5 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IAccessManager.spec +33 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IERC20.spec +11 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IERC2612.spec +5 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IERC3156FlashBorrower.spec +3 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IERC3156FlashLender.spec +5 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IERC5313.spec +3 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IERC721.spec +17 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IERC721Receiver.spec +3 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IOwnable.spec +5 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/methods/IOwnable2Step.spec +7 -0
- package/lib/openzeppelin-contracts-upgradeable/certora/specs.json +110 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/AccessControlUpgradeable.sol +71 -99
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/Ownable2StepUpgradeable.sol +38 -21
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/OwnableUpgradeable.sol +50 -26
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/README.adoc +23 -3
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/extensions/AccessControlDefaultAdminRulesUpgradeable.sol +401 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/extensions/AccessControlEnumerableUpgradeable.sol +104 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/manager/AccessManagedUpgradeable.sol +133 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/manager/AccessManagerUpgradeable.sol +783 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/account/README.adoc +30 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/account/extensions/draft-AccountERC7579HookedUpgradeable.sol +127 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/account/extensions/draft-AccountERC7579Upgradeable.sol +426 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/finance/README.adoc +1 -7
- package/lib/openzeppelin-contracts-upgradeable/contracts/finance/VestingWalletCliffUpgradeable.sol +73 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/finance/VestingWalletUpgradeable.sol +79 -59
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/GovernorUpgradeable.sol +509 -269
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/README.adoc +37 -16
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/TimelockControllerUpgradeable.sol +186 -131
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorCountingFractionalUpgradeable.sol +214 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorCountingOverridableUpgradeable.sol +248 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorCountingSimpleUpgradeable.sol +51 -51
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorNoncesKeyedUpgradeable.sol +96 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorPreventLateQuorumUpgradeable.sol +46 -53
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorProposalGuardianUpgradeable.sol +78 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorSequentialProposalIdUpgradeable.sol +98 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorSettingsUpgradeable.sol +50 -50
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorStorageUpgradeable.sol +150 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorSuperQuorumUpgradeable.sol +64 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorTimelockAccessUpgradeable.sol +376 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorTimelockCompoundUpgradeable.sol +77 -91
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorTimelockControlUpgradeable.sol +84 -70
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorVotesQuorumFractionUpgradeable.sol +51 -49
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorVotesSuperQuorumFractionUpgradeable.sol +155 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorVotesUpgradeable.sol +60 -23
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/utils/VotesExtendedUpgradeable.sol +106 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/utils/VotesUpgradeable.sol +143 -87
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/README.adoc +50 -1
- package/lib/openzeppelin-contracts-upgradeable/contracts/metatx/ERC2771ContextUpgradeable.sol +60 -20
- package/lib/openzeppelin-contracts-upgradeable/contracts/metatx/ERC2771ForwarderUpgradeable.sol +380 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/metatx/README.adoc +6 -1
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/AccessManagedTargetUpgradeable.sol +40 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/AccessManagerMockUpgradeable.sol +25 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ArraysMockUpgradeable.sol +133 -26
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/AuthorityMockUpgradeable.sol +95 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/Base64DirtyUpgradeable.sol +25 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/BatchCallerUpgradeable.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/CallReceiverMockUpgradeable.sol +35 -17
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ConstructorMockUpgradeable.sol +39 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ContextMockUpgradeable.sol +11 -23
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/DummyImplementationUpgradeable.sol +14 -31
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/EIP712VerifierUpgradeable.sol +22 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC1271WalletMockUpgradeable.sol +12 -29
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC165/ERC165InterfacesSupportedUpgradeable.sol +6 -20
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC165/ERC165MaliciousDataUpgradeable.sol +2 -9
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC165/ERC165MissingDataUpgradeable.sol +2 -9
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC165/ERC165NotSupportedUpgradeable.sol +2 -9
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC165/ERC165ReturnBombUpgradeable.sol +5 -12
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC2771ContextMockUpgradeable.sol +10 -11
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC3156FlashBorrowerMockUpgradeable.sol +12 -19
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/EtherReceiverMockUpgradeable.sol +4 -11
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/InitializableMock.sol +6 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/MerkleProofCustomHashMockUpgradeable.sol +68 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/MerkleTreeMockUpgradeable.sol +58 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/MulticallHelperUpgradeable.sol +29 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/MultipleInheritanceInitializableMocks.sol +7 -12
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/PausableMockUpgradeable.sol +3 -11
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ReentrancyAttackUpgradeable.sol +5 -12
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ReentrancyMockUpgradeable.sol +13 -13
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ReentrancyTransientMockUpgradeable.sol +55 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/RegressionImplementation.sol +2 -2
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/SingleInheritanceInitializableMocks.sol +2 -2
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/StatelessUpgradeable.sol +61 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/StorageSlotMockUpgradeable.sol +62 -23
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/TimelockReentrantUpgradeable.sol +32 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/TransientSlotMockUpgradeable.sol +67 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/UpgradeableBeaconMockUpgradeable.sol +34 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/VotesExtendedMockUpgradeable.sol +53 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/VotesMockUpgradeable.sol +28 -27
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/WithInit.sol +849 -740
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/account/AccountMockUpgradeable.sol +223 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/account/modules/ERC7579MockUpgradeable.sol +138 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/account/utils/ERC7579UtilsMockUpgradeable.sol +29 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/compound/CompTimelockUpgradeable.sol +2 -9
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/ERC20WithAutoMinerRewardUpgradeable.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/ERC4626FeesUpgradeable.sol +115 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/MyNFTUpgradeable.sol +14 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/AccessControlERC20MintBaseUpgradeable.sol +31 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/AccessControlERC20MintMissingUpgradeable.sol +30 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/AccessControlERC20MintOnlyRoleUpgradeable.sol +29 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/AccessControlModifiedUpgradeable.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/AccessManagedERC20MintBaseUpgradeable.sol +22 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/access-control/MyContractOwnableUpgradeable.sol +22 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/account/MyAccountERC7702Upgradeable.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/account/MyFactoryAccountUpgradeable.sol +42 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/governance/MyGovernorUpgradeable.sol +92 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/governance/MyTokenTimestampBasedUpgradeable.sol +39 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/governance/MyTokenUpgradeable.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/governance/MyTokenWrappedUpgradeable.sol +39 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/token/ERC1155/GameItemsUpgradeable.sol +27 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/token/ERC1155/MyERC115HolderContractUpgradeable.sol +13 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/token/ERC20/GLDTokenUpgradeable.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/token/ERC6909/ERC6909GameItemsUpgradeable.sol +31 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/token/ERC721/GameItemUpgradeable.sol +24 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/utilities/Base64NFTUpgradeable.sol +32 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/docs/utilities/MulticallUpgradeable.sol +21 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorCountingOverridableMockUpgradeable.sol +24 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorFractionalMockUpgradeable.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorMockUpgradeable.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorNoncesKeyedMockUpgradeable.sol +51 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorPreventLateQuorumMockUpgradeable.sol +45 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorProposalGuardianMockUpgradeable.sol +33 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorSequentialProposalIdMockUpgradeable.sol +45 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorStorageMockUpgradeable.sol +85 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorSuperQuorumMockUpgradeable.sol +100 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorTimelockAccessMockUpgradeable.sol +76 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorTimelockCompoundMockUpgradeable.sol +75 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorTimelockControlMockUpgradeable.sol +75 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorVoteMockUpgradeable.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorVotesSuperQuorumFractionMockUpgradeable.sol +43 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/governance/GovernorWithParamsMockUpgradeable.sol +57 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/proxy/BadBeaconUpgradeable.sol +22 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/proxy/ClashingImplementationUpgradeable.sol +25 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/proxy/UUPSUpgradeableMockUpgradeable.sol +56 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC1155ReceiverMockUpgradeable.sol +79 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC1363ForceApproveMockUpgradeable.sol +19 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC1363NoReturnMockUpgradeable.sol +39 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC1363ReceiverMockUpgradeable.sol +57 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC1363ReturnFalseMockUpgradeable.sol +46 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC1363SpenderMockUpgradeable.sol +52 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20ApprovalMockUpgradeable.sol +16 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20BridgeableMockUpgradeable.sol +31 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20DecimalsMockUpgradeable.sol +22 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20ExcessDecimalsMockUpgradeable.sol +15 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20FlashMintMockUpgradeable.sol +32 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20ForceApproveMockUpgradeable.sol +19 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20GetterHelperUpgradeable.sol +44 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20MockUpgradeable.sol +21 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20MulticallMockUpgradeable.sol +14 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20NoReturnMockUpgradeable.sol +34 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20ReentrantUpgradeable.sol +46 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20ReturnFalseMockUpgradeable.sol +25 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20VotesAdditionalCheckpointsMockUpgradeable.sol +42 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20VotesLegacyMockUpgradeable.sol +259 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC20VotesTimestampMockUpgradeable.sol +40 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC4626LimitsMockUpgradeable.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC4626MockUpgradeable.sol +24 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC4626OffsetMockUpgradeable.sol +22 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC4646FeesMockUpgradeable.sol +50 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC721ConsecutiveEnumerableMockUpgradeable.sol +53 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC721ConsecutiveMockUpgradeable.sol +80 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC721ReceiverMockUpgradeable.sol +52 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/token/ERC721URIStorageMockUpgradeable.sol +23 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/utils/cryptography/ERC7739MockUpgradeable.sol +29 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/package.json +7 -4
- package/lib/openzeppelin-contracts-upgradeable/contracts/proxy/README.adoc +13 -11
- package/lib/openzeppelin-contracts-upgradeable/contracts/proxy/utils/Initializable.sol +108 -35
- package/lib/openzeppelin-contracts-upgradeable/contracts/proxy/utils/UUPSUpgradeable.sol +84 -40
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/ERC1155Upgradeable.sol +227 -343
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/README.adoc +6 -12
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/extensions/ERC1155BurnableUpgradeable.sol +12 -31
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/extensions/ERC1155PausableUpgradeable.sol +12 -26
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/extensions/ERC1155SupplyUpgradeable.sol +63 -31
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/extensions/ERC1155URIStorageUpgradeable.sol +37 -30
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/utils/ERC1155HolderUpgradeable.sol +13 -15
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/ERC20Upgradeable.sol +168 -239
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/README.adoc +28 -36
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC1363Upgradeable.sol +142 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC20BurnableUpgradeable.sol +14 -21
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC20CappedUpgradeable.sol +45 -23
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC20FlashMintUpgradeable.sol +60 -42
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC20PausableUpgradeable.sol +10 -24
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC20PermitUpgradeable.sol +82 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC20VotesUpgradeable.sol +46 -245
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC20WrapperUpgradeable.sol +71 -34
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC4626Upgradeable.sol +156 -148
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/draft-ERC20BridgeableUpgradeable.sol +57 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/draft-ERC20TemporaryApprovalUpgradeable.sol +126 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC6909/README.adoc +27 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC6909/draft-ERC6909Upgradeable.sol +250 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC6909/extensions/draft-ERC6909ContentURIUpgradeable.sol +75 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC6909/extensions/draft-ERC6909MetadataUpgradeable.sol +101 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC6909/extensions/draft-ERC6909TokenSupplyUpgradeable.sol +55 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/ERC721Upgradeable.sol +288 -347
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/README.adoc +11 -12
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/ERC721BurnableUpgradeable.sol +10 -17
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/ERC721ConsecutiveUpgradeable.sol +106 -69
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/ERC721EnumerableUpgradeable.sol +100 -83
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/ERC721PausableUpgradeable.sol +13 -24
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/ERC721RoyaltyUpgradeable.sol +11 -30
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/ERC721URIStorageUpgradeable.sol +45 -42
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/ERC721VotesUpgradeable.sol +20 -21
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/ERC721WrapperUpgradeable.sol +122 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/utils/ERC721HolderUpgradeable.sol +8 -19
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/common/ERC2981Upgradeable.sol +86 -47
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/common/README.adoc +2 -2
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/ContextUpgradeable.sol +6 -9
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/MulticallUpgradeable.sol +20 -28
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/NoncesKeyedUpgradeable.sol +94 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/NoncesUpgradeable.sol +66 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/PausableUpgradeable.sol +133 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/README.adoc +79 -45
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/ReentrancyGuardTransientUpgradeable.sol +67 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/ReentrancyGuardUpgradeable.sol +108 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/EIP712Upgradeable.sol +127 -41
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/README.adoc +67 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/signers/MultiSignerERC7913Upgradeable.sol +276 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/signers/MultiSignerERC7913WeightedUpgradeable.sol +229 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/signers/SignerECDSAUpgradeable.sol +74 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/signers/SignerERC7913Upgradeable.sol +81 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/signers/SignerP256Upgradeable.sol +82 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/signers/SignerRSAUpgradeable.sol +83 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/signers/draft-ERC7739Upgradeable.sol +104 -0
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/introspection/ERC165Upgradeable.sol +9 -20
- package/lib/openzeppelin-contracts-upgradeable/docs/antora.yml +2 -1
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/access-control-multiple.svg +97 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/access-manager-functions.svg +47 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/access-manager.svg +99 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-attack-3a.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-attack-3b.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-attack-6.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-attack.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-deposit.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-mint.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-rate-linear.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-rate-loglog.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/images/erc4626-rate-loglogext.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/nav.adoc +13 -7
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/access-control.adoc +168 -97
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/account-abstraction.adoc +100 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/accounts.adoc +354 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/backwards-compatibility.adoc +50 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/eoa-delegation.adoc +143 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc1155.adoc +19 -54
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc20-supply.adoc +13 -55
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc20.adoc +7 -25
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc4626.adoc +214 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc6909.adoc +47 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc721.adoc +10 -42
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/extending-contracts.adoc +4 -82
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/faq.adoc +13 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/governance.adoc +85 -167
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/index.adoc +19 -12
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/multisig.adoc +306 -0
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/tokens.adoc +4 -5
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/upgradeable.adoc +14 -10
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/utilities.adoc +482 -81
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/wizard.adoc +1 -1
- package/lib/openzeppelin-contracts-upgradeable/docs/templates/contract.hbs +57 -1
- package/lib/openzeppelin-contracts-upgradeable/docs/templates/helpers.js +8 -8
- package/lib/openzeppelin-contracts-upgradeable/docs/templates/properties.js +47 -8
- package/lib/openzeppelin-contracts-upgradeable/eslint.config.mjs +26 -0
- package/lib/openzeppelin-contracts-upgradeable/foundry.toml +15 -0
- package/lib/openzeppelin-contracts-upgradeable/fv-requirements.txt +4 -0
- package/lib/openzeppelin-contracts-upgradeable/hardhat/async-test-sanity.js +10 -0
- package/lib/openzeppelin-contracts-upgradeable/hardhat/common-contracts.js +69 -0
- package/lib/openzeppelin-contracts-upgradeable/hardhat/env-artifacts.js +15 -6
- package/lib/openzeppelin-contracts-upgradeable/hardhat/ignore-unreachable-warnings.js +2 -4
- package/lib/openzeppelin-contracts-upgradeable/hardhat/remappings.js +18 -0
- package/lib/openzeppelin-contracts-upgradeable/hardhat/skip-foundry-tests.js +3 -4
- package/lib/openzeppelin-contracts-upgradeable/hardhat/task-test-get-files.js +22 -16
- package/lib/openzeppelin-contracts-upgradeable/hardhat.config.js +67 -49
- package/lib/openzeppelin-contracts-upgradeable/lib/erc4626-tests/ERC4626.prop.sol +404 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/erc4626-tests/ERC4626.test.sol +356 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/erc4626-tests/LICENSE +661 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/erc4626-tests/README.md +116 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/.gitattributes +1 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/.github/workflows/ci.yml +48 -12
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/.github/workflows/sync.yml +31 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/CONTRIBUTING.md +193 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/README.md +19 -3
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/foundry.toml +5 -3
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/package.json +2 -2
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/scripts/vm.py +646 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/Base.sol +7 -3
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/Script.sol +4 -3
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/StdAssertions.sol +595 -135
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/StdChains.sol +146 -48
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/StdCheats.sol +303 -39
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/StdInvariant.sol +122 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/StdJson.sol +129 -25
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/StdStorage.sol +245 -99
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/StdStyle.sol +333 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/StdToml.sol +283 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/StdUtils.sol +125 -39
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/Test.sol +10 -5
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/Vm.sol +2182 -304
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/console.sol +635 -608
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/console2.sol +1 -1543
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/interfaces/IERC4626.sol +2 -2
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/interfaces/IMulticall3.sol +73 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/src/safeconsole.sol +13937 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/StdAssertions.t.sol +126 -572
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/StdChains.t.sol +166 -62
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/StdCheats.t.sol +348 -35
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/StdError.t.sol +15 -13
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/StdJson.t.sol +49 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/StdMath.t.sol +31 -26
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/StdStorage.t.sol +251 -46
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/StdStyle.t.sol +110 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/StdToml.t.sol +49 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/StdUtils.t.sol +186 -35
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/Vm.t.sol +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/fixtures/test.json +8 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/test/fixtures/test.toml +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/halmos-cheatcodes/LICENSE +661 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/halmos-cheatcodes/README.md +97 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/halmos-cheatcodes/src/SVM.sol +49 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/halmos-cheatcodes/src/SymTest.sol +11 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/all-geese-stand.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/clean-ways-push.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/config.json +12 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/dull-students-eat.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/eight-radios-check.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/fine-frogs-bake.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/full-ways-help.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/funny-years-yawn.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/hot-grapes-lie.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/lazy-poets-cheer.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/long-hornets-mate.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/lucky-donuts-scream.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/major-feet-write.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/new-days-tease.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/nice-rings-wish.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/pink-dolls-shop.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/popular-geese-tan.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/proud-tables-sip.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/public-crabs-heal.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/quiet-kiwis-feel.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/rare-shirts-unite.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/rich-cows-repair.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/ripe-bears-hide.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/rotten-apes-lie.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/social-walls-obey.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/sour-pens-shake.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/strong-points-change.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/tame-bears-mix.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/violet-turtles-like.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/wet-dodos-reply.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/whole-plums-speak.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.changeset/wild-baths-buy.md +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.codecov.yml +16 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.editorconfig +21 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/CODEOWNERS +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/bug_report.md +21 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/config.yml +4 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/PULL_REQUEST_TEMPLATE.md +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/actions/gas-compare/action.yml +51 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/actions/setup/action.yml +22 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/actions/storage-layout/action.yml +57 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/workflows/actionlint.yml +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/workflows/changeset.yml +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/workflows/checks.yml +132 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/workflows/docs.yml +19 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/workflows/formal-verification.yml +86 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/workflows/release-cycle.yml +214 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.github/workflows/upgradeable.yml +34 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.gitmodules +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.husky/pre-commit +2 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.mocharc.js +4 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.prettierrc +15 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/.solcover.js +21 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/CHANGELOG.md +1220 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/CODE_OF_CONDUCT.md +73 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/CONTRIBUTING.md +36 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/FUNDING.json +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/GUIDELINES.md +155 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/LICENSE +22 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/README.md +108 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/RELEASING.md +45 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/SECURITY.md +43 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/audits/2017-03.md +292 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/audits/2022-10-Checkpoints.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/audits/2022-10-ERC4626.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/audits/2023-05-v4.9.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/audits/2023-10-v5.0.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/audits/2024-10-v5.1.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/audits/2024-12-v5.2.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/audits/2025-04-v5.3.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/audits/README.md +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/Makefile +54 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/README.md +60 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/diff/access_manager_AccessManager.sol.patch +97 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/AccessControlDefaultAdminRulesHarness.sol +46 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/AccessControlHarness.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/AccessManagedHarness.sol +36 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/AccessManagerHarness.sol +116 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/DoubleEndedQueueHarness.sol +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/ERC20FlashMintHarness.sol +36 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/ERC20PermitHarness.sol +16 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/ERC20WrapperHarness.sol +34 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/ERC3156FlashBorrowerHarness.sol +13 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/ERC721Harness.sol +33 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/ERC721ReceiverHarness.sol +11 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/EnumerableMapHarness.sol +55 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/EnumerableSetHarness.sol +35 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/InitializableHarness.sol +23 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/NoncesHarness.sol +14 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/Ownable2StepHarness.sol +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/OwnableHarness.sol +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/PausableHarness.sol +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/harnesses/TimelockControllerHarness.sol +13 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/reports/2021-10.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/reports/2022-03.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/reports/2022-05.pdf +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/run.js +168 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/AccessControl.spec +119 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/AccessControlDefaultAdminRules.spec +464 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/AccessManaged.spec +34 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/AccessManager.spec +826 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/DoubleEndedQueue.spec +300 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/ERC20.spec +352 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/ERC20FlashMint.spec +55 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/ERC20Wrapper.spec +198 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/ERC721.spec +679 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/EnumerableMap.spec +333 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/EnumerableSet.spec +246 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/Initializable.spec +165 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/Nonces.spec +92 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/Ownable.spec +77 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/Ownable2Step.spec +108 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/Pausable.spec +96 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/TimelockController.spec +274 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/helpers/helpers.spec +12 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IAccessControl.spec +8 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IAccessControlDefaultAdminRules.spec +36 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IAccessManaged.spec +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IAccessManager.spec +33 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IERC20.spec +11 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IERC2612.spec +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IERC3156FlashBorrower.spec +3 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IERC3156FlashLender.spec +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IERC5313.spec +3 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IERC721.spec +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IERC721Receiver.spec +3 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IOwnable.spec +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs/methods/IOwnable2Step.spec +7 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/certora/specs.json +110 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/AccessControl.sol +207 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/IAccessControl.sol +98 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/Ownable.sol +100 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/Ownable2Step.sol +67 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/README.adoc +45 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/extensions/AccessControlDefaultAdminRules.sol +372 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/extensions/AccessControlEnumerable.sol +81 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/extensions/IAccessControlDefaultAdminRules.sol +192 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/extensions/IAccessControlEnumerable.sol +31 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/manager/AccessManaged.sol +112 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/manager/AccessManager.sol +740 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/manager/AuthorityUtils.sol +36 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/manager/IAccessManaged.sol +32 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/manager/IAccessManager.sol +399 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/access/manager/IAuthority.sol +14 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/account/Account.sol +144 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/account/README.adoc +30 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/account/extensions/draft-AccountERC7579.sol +413 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/account/extensions/draft-AccountERC7579Hooked.sol +106 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/account/extensions/draft-ERC7821.sol +69 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/account/utils/EIP7702Utils.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/account/utils/draft-ERC4337Utils.sol +159 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/account/utils/draft-ERC7579Utils.sol +280 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/finance/README.adoc +14 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/finance/VestingWallet.sol +159 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/finance/VestingWalletCliff.sol +54 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/Governor.sol +818 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/IGovernor.sol +454 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/README.adoc +197 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/TimelockController.sol +471 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorCountingFractional.sol +190 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorCountingOverridable.sol +222 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorCountingSimple.sol +96 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorNoncesKeyed.sol +90 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorPreventLateQuorum.sol +92 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorProposalGuardian.sol +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSequentialProposalId.sol +75 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSettings.sol +106 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorStorage.sol +125 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorSuperQuorum.sol +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockAccess.sol +346 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockCompound.sol +165 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorTimelockControl.sol +167 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotes.sol +63 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesQuorumFraction.sol +113 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesSuperQuorumFraction.sol +134 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/utils/IVotes.sol +59 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/utils/Votes.sol +252 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/governance/utils/VotesExtended.sol +84 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC1155.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC1155MetadataURI.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC1155Receiver.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC1271.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC1363.sol +86 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC1363Receiver.sol +32 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC1363Spender.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC165.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC1820Implementer.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC1820Registry.sol +112 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC1967.sol +24 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC20.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC20Metadata.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC2309.sol +19 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC2612.sol +8 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC2981.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC3156.sol +7 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC3156FlashBorrower.sol +27 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC3156FlashLender.sol +41 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC4626.sol +230 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC4906.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC5267.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC5313.sol +16 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC5805.sol +9 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC6372.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC721.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC721Enumerable.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC721Metadata.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC721Receiver.sol +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC777.sol +200 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC777Recipient.sol +35 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC777Sender.sol +35 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/IERC7913.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/README.adoc +105 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC1822.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC4337.sol +253 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC6093.sol +161 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC6909.sol +125 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7579.sol +226 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7674.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7786.sol +64 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7802.sol +30 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC7821.sol +43 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/metatx/ERC2771Context.sol +90 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/metatx/ERC2771Forwarder.sol +372 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/metatx/README.adoc +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/AccessManagedTarget.sol +34 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/AccessManagerMock.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ArraysMock.sol +171 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/AuthorityMock.sol +69 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/Base64Dirty.sol +19 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/BatchCaller.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/CallReceiverMock.sol +78 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ConstructorMock.sol +34 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ContextMock.sol +35 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/DummyImplementation.sol +65 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/EIP712Verifier.sol +16 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ERC1271WalletMock.sol +24 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165InterfacesSupported.sol +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165MaliciousData.sol +12 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165MissingData.sol +7 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165NotSupported.sol +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ERC165/ERC165ReturnBomb.sol +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ERC2771ContextMock.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ERC3156FlashBorrowerMock.sol +53 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/EtherReceiverMock.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/InitializableMock.sol +130 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/MerkleProofCustomHashMock.sol +62 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/MerkleTreeMock.sol +52 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/MulticallHelper.sol +23 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/MultipleInheritanceInitializableMocks.sol +131 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/PausableMock.sol +31 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ReentrancyAttack.sol +12 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ReentrancyMock.sol +50 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/ReentrancyTransientMock.sol +50 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/RegressionImplementation.sol +61 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/SingleInheritanceInitializableMocks.sol +49 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/Stateless.sol +55 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/StorageSlotMock.sol +87 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/TimelockReentrant.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/TransientSlotMock.sol +61 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/UpgradeableBeaconMock.sol +27 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/VotesExtendedMock.sol +42 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/VotesMock.sol +42 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/account/AccountMock.sol +169 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/account/modules/ERC7579Mock.sol +122 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/account/utils/ERC7579UtilsMock.sol +23 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/compound/CompTimelock.sol +174 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/ERC20WithAutoMinerReward.sol +22 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/ERC4626Fees.sol +109 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/MyNFT.sol +9 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintBase.sol +25 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintMissing.sol +24 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlERC20MintOnlyRole.sol +23 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessControlModified.sol +14 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/AccessManagedERC20MintBase.sol +16 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/access-control/MyContractOwnable.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/account/MyAccountERC7702.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/account/MyFactoryAccount.sol +37 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyGovernor.sol +80 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyToken.sol +21 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenTimestampBased.sol +32 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/governance/MyTokenWrapped.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC1155/GameItems.sol +21 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC1155/MyERC115HolderContract.sol +7 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC20/GLDToken.sol +11 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC6909/ERC6909GameItems.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/token/ERC721/GameItem.sol +19 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/utilities/Base64NFT.sol +27 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/docs/utilities/Multicall.sol +15 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorCountingOverridableMock.sol +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorFractionalMock.sol +14 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorMock.sol +14 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorNoncesKeyedMock.sol +45 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorPreventLateQuorumMock.sol +40 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorProposalGuardianMock.sol +27 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorSequentialProposalIdMock.sol +39 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorStorageMock.sol +79 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorSuperQuorumMock.sol +95 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockAccessMock.sol +70 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockCompoundMock.sol +69 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorTimelockControlMock.sol +69 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorVoteMock.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorVotesSuperQuorumFractionMock.sol +37 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/governance/GovernorWithParamsMock.sol +51 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/proxy/BadBeacon.sol +11 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/proxy/ClashingImplementation.sol +19 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/proxy/UUPSUpgradeableMock.sol +35 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC1155ReceiverMock.sol +74 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363ForceApproveMock.sol +13 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363NoReturnMock.sol +33 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363ReceiverMock.sol +52 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363ReturnFalseMock.sol +34 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC1363SpenderMock.sol +47 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ApprovalMock.sol +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20BridgeableMock.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20DecimalsMock.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ExcessDecimalsMock.sol +9 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20FlashMintMock.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ForceApproveMock.sol +13 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20GetterHelper.sol +38 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20Mock.sol +16 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20MulticallMock.sol +8 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20NoReturnMock.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20Reentrant.sol +39 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20ReturnFalseMock.sol +19 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20VotesAdditionalCheckpointsMock.sol +31 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20VotesLegacyMock.sol +253 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC20VotesTimestampMock.sol +29 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC4626LimitsMock.sol +23 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC4626Mock.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC4626OffsetMock.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC4646FeesMock.sol +40 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ConsecutiveEnumerableMock.sol +42 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ConsecutiveMock.sol +61 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC721ReceiverMock.sol +47 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/token/ERC721URIStorageMock.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/mocks/utils/cryptography/ERC7739Mock.sol +13 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/package.json +32 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/Clones.sol +262 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Proxy.sol +40 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Utils.sol +177 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/Proxy.sol +69 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/README.adoc +87 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/beacon/BeaconProxy.sol +57 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/beacon/IBeacon.sol +16 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/beacon/UpgradeableBeacon.sol +70 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/transparent/ProxyAdmin.sol +45 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/transparent/TransparentUpgradeableProxy.sol +118 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/utils/Initializable.sol +238 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/proxy/utils/UUPSUpgradeable.sol +146 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/ERC1155.sol +389 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155.sol +123 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/IERC1155Receiver.sol +59 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/README.adoc +43 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Burnable.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Pausable.sol +38 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155Supply.sol +88 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/ERC1155URIStorage.sol +61 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/extensions/IERC1155MetadataURI.sol +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Holder.sol +40 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Utils.sol +88 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/ERC20.sol +305 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/IERC20.sol +79 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/README.adoc +78 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC1363.sol +135 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Burnable.sol +39 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Capped.sol +54 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20FlashMint.sol +134 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Pausable.sol +33 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Permit.sol +77 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Votes.sol +83 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Wrapper.sol +89 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC4626.sol +282 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Metadata.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/IERC20Permit.sol +90 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-ERC20Bridgeable.sol +50 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-ERC20TemporaryApproval.sol +119 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/utils/ERC1363Utils.sol +95 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC20/utils/SafeERC20.sol +280 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC6909/README.adoc +27 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC6909/draft-ERC6909.sol +224 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/draft-ERC6909ContentURI.sol +53 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/draft-ERC6909Metadata.sol +77 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC6909/extensions/draft-ERC6909TokenSupply.sol +35 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/ERC721.sol +430 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/IERC721.sol +135 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/IERC721Receiver.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/README.adoc +69 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Burnable.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Consecutive.sol +176 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Enumerable.sol +164 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Pausable.sol +37 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Royalty.sol +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721URIStorage.sol +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Votes.sol +47 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/ERC721Wrapper.sol +102 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/IERC721Enumerable.sol +29 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/IERC721Metadata.sol +27 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/utils/ERC721Holder.sol +24 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/ERC721/utils/ERC721Utils.sol +50 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/common/ERC2981.sol +139 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/token/common/README.adoc +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Address.sol +149 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Arrays.sol +552 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Base64.sol +119 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Blockhash.sol +52 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Bytes.sol +166 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/CAIP10.sol +54 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/CAIP2.sol +51 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Calldata.sol +25 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Comparators.sol +19 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Context.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Create2.sol +92 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Errors.sol +34 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Memory.sol +44 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Multicall.sol +37 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Nonces.sol +46 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/NoncesKeyed.sol +74 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Packing.sol +1656 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Panic.sol +57 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Pausable.sol +112 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/README.adoc +145 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/ReentrancyGuard.sol +87 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/ReentrancyGuardTransient.sol +61 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/ShortStrings.sol +122 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/SlotDerivation.sol +155 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/StorageSlot.sol +143 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/Strings.sol +507 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/TransientSlot.sol +183 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/ECDSA.sol +213 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/EIP712.sol +160 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/Hashes.sol +31 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/MerkleProof.sol +514 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/MessageHashUtils.sol +99 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/P256.sol +408 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/README.adoc +67 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/RSA.sol +154 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/SignatureChecker.sol +164 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/draft-ERC7739Utils.sol +206 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/AbstractSigner.sol +22 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/MultiSignerERC7913.sol +251 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/MultiSignerERC7913Weighted.sol +207 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerECDSA.sol +55 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerERC7702.sol +24 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerERC7913.sol +62 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerP256.sol +63 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/SignerRSA.sol +64 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/signers/draft-ERC7739.sol +98 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/verifiers/ERC7913P256Verifier.sol +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/cryptography/verifiers/ERC7913RSAVerifier.sol +22 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/draft-InteroperableAddress.sol +234 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165.sol +25 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165Checker.sol +124 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/introspection/IERC165.sol +25 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/math/Math.sol +749 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/math/SafeCast.sol +1162 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/math/SignedMath.sol +68 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/structs/BitMaps.sol +60 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/structs/Checkpoints.sol +833 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/structs/CircularBuffer.sol +140 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/structs/DoubleEndedQueue.sol +156 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/structs/EnumerableMap.sol +1319 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/structs/EnumerableSet.sol +792 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/structs/Heap.sol +256 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/structs/MerkleTree.sol +267 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/utils/types/Time.sol +133 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/vendor/compound/ICompoundTimelock.sol +86 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/contracts/vendor/compound/LICENSE +11 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/antora.yml +7 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/config.js +21 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-control-multiple.svg +97 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-manager-functions.svg +47 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/access-manager.svg +99 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3a.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3b.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-6.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-deposit.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-mint.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-linear.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglog.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglogext.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-exec.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-vote.png +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/nav.adoc +29 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/access-control.adoc +288 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/account-abstraction.adoc +100 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/accounts.adoc +354 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/backwards-compatibility.adoc +50 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/eoa-delegation.adoc +143 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc1155.adoc +118 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20-supply.adoc +71 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20.adoc +67 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc4626.adoc +214 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc6909.adoc +47 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc721.adoc +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/extending-contracts.adoc +51 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/faq.adoc +13 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/governance.adoc +239 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/index.adoc +70 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/multisig.adoc +306 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/tokens.adoc +31 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/upgradeable.adoc +77 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/utilities.adoc +591 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/modules/ROOT/pages/wizard.adoc +15 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/templates/contract.hbs +141 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/templates/helpers.js +46 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/templates/page.hbs +4 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/templates/properties.js +88 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/eslint.config.mjs +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/foundry.toml +15 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/fv-requirements.txt +4 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/hardhat/async-test-sanity.js +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/hardhat/common-contracts.js +69 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/hardhat/env-artifacts.js +29 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/hardhat/ignore-unreachable-warnings.js +45 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/hardhat/remappings.js +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/hardhat/skip-foundry-tests.js +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/hardhat/task-test-get-files.js +25 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/hardhat.config.js +124 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/erc4626-tests/ERC4626.prop.sol +404 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/erc4626-tests/ERC4626.test.sol +356 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/erc4626-tests/LICENSE +661 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/erc4626-tests/README.md +116 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/.gitattributes +1 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/.github/workflows/ci.yml +128 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/.github/workflows/sync.yml +31 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/CONTRIBUTING.md +193 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/LICENSE-APACHE +203 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/LICENSE-MIT +25 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/README.md +266 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/foundry.toml +23 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/package.json +16 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/scripts/vm.py +646 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/Base.sol +35 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/Script.sol +27 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdAssertions.sol +669 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdChains.sol +287 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdCheats.sol +829 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdError.sol +15 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdInvariant.sol +122 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdJson.sol +283 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdMath.sol +43 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdStorage.sol +473 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdStyle.sol +333 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdToml.sol +283 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/StdUtils.sol +209 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/Test.sol +33 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/Vm.sol +2263 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/console.sol +1560 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/console2.sol +4 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC1155.sol +105 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC165.sol +12 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC20.sol +43 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC4626.sol +190 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IERC721.sol +164 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/interfaces/IMulticall3.sol +73 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/src/safeconsole.sol +13937 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/StdAssertions.t.sol +141 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/StdChains.t.sol +227 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/StdCheats.t.sol +618 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/StdError.t.sol +120 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/StdJson.t.sol +49 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/StdMath.t.sol +202 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/StdStorage.t.sol +488 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/StdStyle.t.sol +110 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/StdToml.t.sol +49 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/StdUtils.t.sol +342 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/Vm.t.sol +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/compilation/CompilationScript.sol +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/compilation/CompilationScriptBase.sol +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/compilation/CompilationTest.sol +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/compilation/CompilationTestBase.sol +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/fixtures/broadcast.log.json +187 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/fixtures/test.json +8 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/forge-std/test/fixtures/test.toml +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/halmos-cheatcodes/LICENSE +661 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/halmos-cheatcodes/README.md +97 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/halmos-cheatcodes/src/SVM.sol +49 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/lib/halmos-cheatcodes/src/SymTest.sol +11 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/logo.svg +15 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/netlify.toml +3 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/package.json +106 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/remappings.txt +1 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/renovate.json +4 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/checks/compare-layout.js +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/checks/compareGasReports.js +249 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/checks/coverage.sh +24 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/checks/extract-layout.js +39 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/checks/generation.sh +6 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/checks/inheritance-ordering.js +55 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/checks/pragma-validity.js +45 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/fetch-common-contracts.js +50 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/gen-nav.js +81 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/format-lines.js +16 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/helpers/sanitize.js +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/run.js +61 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/Arrays.js +386 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/Arrays.opts.js +9 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.js +242 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.opts.js +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.t.js +141 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/Enumerable.opts.js +53 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableMap.js +463 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableSet.js +469 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/MerkleProof.js +187 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/MerkleProof.opts.js +11 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/Packing.js +92 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/Packing.opts.js +3 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/Packing.t.js +48 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/SafeCast.js +136 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/Slot.opts.js +15 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/SlotDerivation.js +119 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/SlotDerivation.t.js +127 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/StorageSlot.js +77 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/StorageSlotMock.js +57 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/TransientSlot.js +80 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/TransientSlotMock.js +35 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/generate/templates/conversion.js +30 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/get-contracts-metadata.js +55 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/helpers.js +7 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/minimize-pragma.js +138 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/prepack.sh +23 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/prepare-docs.sh +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/format-changelog.js +33 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/synchronize-versions.js +15 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/update-comment.js +34 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/version.sh +11 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/workflow/exit-prerelease.sh +8 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/workflow/github-release.js +48 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/workflow/integrity-check.sh +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/workflow/pack.sh +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/workflow/publish.sh +26 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/workflow/rerun.js +7 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/workflow/set-changesets-pr-title.js +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/workflow/start.sh +35 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/release/workflow/state.js +112 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/remove-ignored-artifacts.js +45 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/set-max-old-space-size.sh +10 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/solc-versions.js +15 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/solhint-custom/index.js +84 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/solhint-custom/package.json +8 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/update-docs-branch.js +65 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/upgradeable/README.md +21 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/upgradeable/patch-apply.sh +19 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/upgradeable/patch-save.sh +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/upgradeable/transpile-onto.sh +54 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/upgradeable/transpile.sh +50 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/scripts/upgradeable/upgradeable.patch +398 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/slither.config.json +4 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/solhint.config.js +29 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/TESTING.md +3 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/AccessControl.behavior.js +874 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/AccessControl.test.js +19 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/Ownable.test.js +79 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/Ownable2Step.test.js +102 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/extensions/AccessControlDefaultAdminRules.test.js +32 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/extensions/AccessControlEnumerable.test.js +24 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/manager/AccessManaged.test.js +146 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/manager/AccessManager.behavior.js +257 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/manager/AccessManager.predicate.js +456 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/manager/AccessManager.test.js +2489 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/access/manager/AuthorityUtils.test.js +112 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/Account.behavior.js +144 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/Account.test.js +48 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/AccountECDSA.test.js +52 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/AccountERC7702.t.sol +103 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/AccountERC7702.test.js +52 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/AccountERC7913.test.js +116 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/AccountMultiSigner.test.js +326 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/AccountMultiSignerWeighted.test.js +312 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/AccountP256.test.js +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/AccountRSA.test.js +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/examples/AccountERC7702WithModulesMock.test.js +99 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/extensions/AccountERC7579.behavior.js +563 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/extensions/AccountERC7579.test.js +60 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/extensions/AccountERC7579Hooked.test.js +60 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/extensions/ERC7821.behavior.js +145 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/utils/EIP7702Utils.test.js +53 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/utils/draft-ERC4337Utils.test.js +289 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/utils/draft-ERC7579Utils.t.sol +426 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/account/utils/draft-ERC7579Utils.test.js +399 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/bin/EntryPoint070.abi +1 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/bin/EntryPoint070.bytecode +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/bin/EntryPoint080.abi +1 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/bin/EntryPoint080.bytecode +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/bin/SenderCreator070.abi +1 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/bin/SenderCreator070.bytecode +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/bin/SenderCreator080.abi +1 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/bin/SenderCreator080.bytecode +0 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/finance/VestingWallet.behavior.js +87 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/finance/VestingWallet.test.js +65 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/finance/VestingWalletCliff.test.js +70 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/Governor.t.sol +59 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/Governor.test.js +980 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/TimelockController.test.js +1279 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorCountingFractional.test.js +248 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorCountingOverridable.test.js +346 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorERC721.test.js +131 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorNoncesKeyed.test.js +244 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorPreventLateQuorum.test.js +185 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorProposalGuardian.test.js +132 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorSequentialProposalId.test.js +202 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorStorage.test.js +155 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorSuperQuorum.test.js +168 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorSuperQuorumGreaterThanQuorum.t.sol +83 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockAccess.test.js +864 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockCompound.test.js +448 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorTimelockControl.test.js +504 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorVotesQuorumFraction.test.js +165 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorVotesSuperQuorumFraction.test.js +160 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/extensions/GovernorWithParams.test.js +245 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/utils/ERC6372.behavior.js +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/utils/Votes.behavior.js +325 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/utils/Votes.test.js +102 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/governance/utils/VotesExtended.test.js +152 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/access-manager.js +85 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/account.js +14 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/chains.js +56 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/constants.js +7 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/deploy.js +14 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/eip712-types.js +61 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/eip712.js +45 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/enums.js +14 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/erc4337.js +217 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/erc7579.js +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/erc7739.js +118 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/governance.js +217 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/iterate.js +41 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/math.js +33 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/methods.js +14 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/precompiles.js +12 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/random.js +24 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/signers.js +184 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/storage.js +48 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/strings.js +5 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/time.js +33 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/helpers/txpool.js +29 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/metatx/ERC2771Context.test.js +133 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/metatx/ERC2771Forwarder.t.sol +279 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/metatx/ERC2771Forwarder.test.js +384 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/Clones.behaviour.js +160 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/Clones.t.sol +91 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/Clones.test.js +177 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/ERC1967/ERC1967Proxy.test.js +23 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/ERC1967/ERC1967Utils.test.js +162 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/Proxy.behaviour.js +185 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/beacon/BeaconProxy.test.js +141 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/beacon/UpgradeableBeacon.test.js +55 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/transparent/ProxyAdmin.test.js +82 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/transparent/TransparentUpgradeableProxy.behaviour.js +357 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/transparent/TransparentUpgradeableProxy.test.js +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/utils/Initializable.test.js +216 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/proxy/utils/UUPSUpgradeable.test.js +120 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/sanity.test.js +27 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC1155/ERC1155.behavior.js +763 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC1155/ERC1155.test.js +213 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Burnable.test.js +66 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Pausable.test.js +105 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155Supply.test.js +119 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC1155/extensions/ERC1155URIStorage.test.js +70 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC1155/utils/ERC1155Holder.test.js +56 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC1155/utils/ERC1155Utils.test.js +299 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/ERC20.behavior.js +269 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/ERC20.test.js +199 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC1363.test.js +370 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Burnable.test.js +105 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Capped.test.js +55 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20FlashMint.test.js +164 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Pausable.test.js +129 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Permit.test.js +109 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Votes.test.js +546 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Wrapper.test.js +203 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC4626.t.sol +41 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC4626.test.js +888 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/draft-ERC20Bridgeable.test.js +89 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/extensions/draft-ERC20TemporaryApproval.test.js +142 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC20/utils/SafeERC20.test.js +463 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC6909/ERC6909.behavior.js +216 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC6909/ERC6909.test.js +104 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909ContentURI.test.js +49 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909Metadata.test.js +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC6909/extensions/ERC6909TokenSupply.test.js +53 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/ERC721.behavior.js +946 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/ERC721.test.js +23 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/ERC721Enumerable.test.js +28 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Burnable.test.js +77 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Consecutive.t.sol +181 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Consecutive.test.js +228 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Pausable.test.js +81 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Royalty.test.js +57 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721URIStorage.test.js +121 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Votes.test.js +194 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/extensions/ERC721Wrapper.test.js +201 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/utils/ERC721Holder.test.js +20 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/ERC721/utils/ERC721Utils.test.js +94 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/token/common/ERC2981.behavior.js +152 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Address.test.js +281 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Arrays.t.sol +31 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Arrays.test.js +227 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Base64.t.sol +34 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Base64.test.js +59 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Blockhash.t.sol +101 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Blockhash.test.js +59 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Bytes.t.sol +74 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Bytes.test.js +212 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/CAIP.test.js +56 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Calldata.test.js +22 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Context.behavior.js +48 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Context.test.js +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Create2.t.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Create2.test.js +190 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Memory.t.sol +21 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Memory.test.js +39 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Multicall.test.js +72 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Nonces.behavior.js +189 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Nonces.test.js +16 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/NoncesKeyed.test.js +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Packing.t.sol +993 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Packing.test.js +70 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Panic.test.js +37 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Pausable.test.js +90 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/ReentrancyGuard.test.js +50 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/ShortStrings.t.sol +109 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/ShortStrings.test.js +64 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/SlotDerivation.t.sol +248 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/SlotDerivation.test.js +58 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/StorageSlot.test.js +73 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Strings.t.sol +50 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/Strings.test.js +360 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/TransientSlot.test.js +59 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/ECDSA.test.js +239 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/EIP712.test.js +105 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/ERC1271.behavior.js +111 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/ERC7739.test.js +42 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/ERC7739Utils.test.js +203 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/MerkleProof.test.js +213 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/MessageHashUtils.t.sol +33 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/MessageHashUtils.test.js +97 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/P256.t.sol +65 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/P256.test.js +182 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/RSA.helper.js +17 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/RSA.test.js +102 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/SigVer15_186-3.rsp +3850 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/SignatureChecker.test.js +422 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/cryptography/ecdsa_secp256r1_sha256_p1363_test.json +3719 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/draft-InteroperableAddress.t.sol +99 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/draft-InteroperableAddress.test.js +170 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/introspection/ERC165.test.js +18 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/introspection/ERC165Checker.test.js +245 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/introspection/SupportsInterface.behavior.js +166 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/math/Math.t.sol +349 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/math/Math.test.js +713 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/math/SafeCast.test.js +159 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/math/SignedMath.t.sol +80 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/math/SignedMath.test.js +53 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/BitMap.test.js +149 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/Checkpoints.t.sol +440 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/Checkpoints.test.js +147 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/CircularBuffer.test.js +83 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/DoubleEndedQueue.test.js +102 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/EnumerableMap.behavior.js +214 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/EnumerableMap.test.js +83 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/EnumerableSet.behavior.js +175 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/EnumerableSet.test.js +66 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/Heap.t.sol +74 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/Heap.test.js +113 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/structs/MerkleTree.test.js +180 -0
- package/lib/openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/test/utils/types/Time.test.js +135 -0
- package/lib/openzeppelin-contracts-upgradeable/package.json +60 -47
- package/lib/openzeppelin-contracts-upgradeable/remappings.txt +2 -0
- package/lib/openzeppelin-contracts-upgradeable/renovate.json +2 -9
- package/lib/openzeppelin-contracts-upgradeable/scripts/checks/compare-layout.js +28 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/checks/compareGasReports.js +130 -92
- package/lib/openzeppelin-contracts-upgradeable/scripts/checks/coverage.sh +24 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/checks/extract-layout.js +39 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/checks/inheritance-ordering.js +28 -23
- package/lib/openzeppelin-contracts-upgradeable/scripts/checks/pragma-validity.js +45 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/fetch-common-contracts.js +50 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/gen-nav.js +62 -22
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/format-lines.js +4 -4
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/helpers/sanitize.js +5 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/run.js +38 -23
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/Arrays.js +386 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/Arrays.opts.js +9 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/Checkpoints.js +67 -128
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/Checkpoints.opts.js +18 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/Checkpoints.t.js +141 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/Enumerable.opts.js +53 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/EnumerableMap.js +269 -84
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/EnumerableSet.js +252 -36
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/MerkleProof.js +187 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/MerkleProof.opts.js +11 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/Packing.js +92 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/Packing.opts.js +3 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/Packing.t.js +48 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/SafeCast.js +50 -82
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/Slot.opts.js +15 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/SlotDerivation.js +119 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/SlotDerivation.t.js +127 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/StorageSlot.js +77 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/StorageSlotMock.js +57 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/TransientSlot.js +80 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/TransientSlotMock.js +35 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/conversion.js +18 -18
- package/lib/openzeppelin-contracts-upgradeable/scripts/get-contracts-metadata.js +55 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/helpers.js +4 -20
- package/lib/openzeppelin-contracts-upgradeable/scripts/minimize-pragma.js +138 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/prepack.sh +14 -3
- package/lib/openzeppelin-contracts-upgradeable/scripts/prepare-docs.sh +12 -1
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/format-changelog.js +33 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/synchronize-versions.js +6 -7
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/update-comment.js +2 -4
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/version.sh +4 -2
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/workflow/exit-prerelease.sh +8 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/workflow/github-release.js +48 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/workflow/integrity-check.sh +20 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/workflow/pack.sh +26 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/workflow/publish.sh +26 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/workflow/rerun.js +7 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/workflow/set-changesets-pr-title.js +17 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/workflow/start.sh +35 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/workflow/state.js +112 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/remove-ignored-artifacts.js +4 -4
- package/lib/openzeppelin-contracts-upgradeable/scripts/set-max-old-space-size.sh +10 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/solc-versions.js +15 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/solhint-custom/index.js +84 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/solhint-custom/package.json +8 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/update-docs-branch.js +15 -5
- package/lib/openzeppelin-contracts-upgradeable/scripts/upgradeable/README.md +21 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/upgradeable/patch-apply.sh +19 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/upgradeable/patch-save.sh +18 -0
- package/lib/openzeppelin-contracts-upgradeable/scripts/upgradeable/transpile-onto.sh +21 -5
- package/lib/openzeppelin-contracts-upgradeable/scripts/upgradeable/transpile.sh +24 -8
- package/lib/openzeppelin-contracts-upgradeable/scripts/upgradeable/upgradeable.patch +398 -0
- package/lib/openzeppelin-contracts-upgradeable/slither.config.json +3 -4
- package/lib/openzeppelin-contracts-upgradeable/solhint.config.js +29 -0
- package/lib/openzeppelin-contracts-upgradeable/test/TESTING.md +1 -1
- package/lib/openzeppelin-contracts-upgradeable/test/access/AccessControl.behavior.js +756 -98
- package/lib/openzeppelin-contracts-upgradeable/test/access/AccessControl.test.js +13 -7
- package/lib/openzeppelin-contracts-upgradeable/test/access/Ownable.test.js +50 -28
- package/lib/openzeppelin-contracts-upgradeable/test/access/Ownable2Step.test.js +77 -32
- package/lib/openzeppelin-contracts-upgradeable/test/access/extensions/AccessControlDefaultAdminRules.test.js +32 -0
- package/lib/openzeppelin-contracts-upgradeable/test/access/extensions/AccessControlEnumerable.test.js +24 -0
- package/lib/openzeppelin-contracts-upgradeable/test/access/manager/AccessManaged.test.js +146 -0
- package/lib/openzeppelin-contracts-upgradeable/test/access/manager/AccessManager.behavior.js +257 -0
- package/lib/openzeppelin-contracts-upgradeable/test/access/manager/AccessManager.predicate.js +456 -0
- package/lib/openzeppelin-contracts-upgradeable/test/access/manager/AccessManager.test.js +2489 -0
- package/lib/openzeppelin-contracts-upgradeable/test/access/manager/AuthorityUtils.test.js +112 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/Account.behavior.js +144 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/Account.test.js +48 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/AccountECDSA.test.js +52 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/AccountERC7702.t.sol +103 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/AccountERC7702.test.js +52 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/AccountERC7913.test.js +116 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/AccountMultiSigner.test.js +326 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/AccountMultiSignerWeighted.test.js +312 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/AccountP256.test.js +58 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/AccountRSA.test.js +58 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/examples/AccountERC7702WithModulesMock.test.js +99 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/extensions/AccountERC7579.behavior.js +563 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/extensions/AccountERC7579.test.js +60 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/extensions/AccountERC7579Hooked.test.js +60 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/extensions/ERC7821.behavior.js +145 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/utils/EIP7702Utils.test.js +53 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/utils/draft-ERC4337Utils.test.js +289 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/utils/draft-ERC7579Utils.t.sol +426 -0
- package/lib/openzeppelin-contracts-upgradeable/test/account/utils/draft-ERC7579Utils.test.js +399 -0
- package/lib/openzeppelin-contracts-upgradeable/test/bin/EntryPoint070.abi +1 -0
- package/lib/openzeppelin-contracts-upgradeable/test/bin/EntryPoint070.bytecode +0 -0
- package/lib/openzeppelin-contracts-upgradeable/test/bin/EntryPoint080.abi +1 -0
- package/lib/openzeppelin-contracts-upgradeable/test/bin/EntryPoint080.bytecode +0 -0
- package/lib/openzeppelin-contracts-upgradeable/test/bin/SenderCreator070.abi +1 -0
- package/lib/openzeppelin-contracts-upgradeable/test/bin/SenderCreator070.bytecode +0 -0
- package/lib/openzeppelin-contracts-upgradeable/test/bin/SenderCreator080.abi +1 -0
- package/lib/openzeppelin-contracts-upgradeable/test/bin/SenderCreator080.bytecode +0 -0
- package/lib/openzeppelin-contracts-upgradeable/test/finance/VestingWallet.behavior.js +59 -46
- package/lib/openzeppelin-contracts-upgradeable/test/finance/VestingWallet.test.js +35 -37
- package/lib/openzeppelin-contracts-upgradeable/test/finance/VestingWalletCliff.test.js +70 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/Governor.t.sol +59 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/Governor.test.js +938 -590
- package/lib/openzeppelin-contracts-upgradeable/test/governance/TimelockController.test.js +910 -765
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorCountingFractional.test.js +248 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorCountingOverridable.test.js +346 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorERC721.test.js +127 -100
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorNoncesKeyed.test.js +244 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorPreventLateQuorum.test.js +181 -173
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorProposalGuardian.test.js +132 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorSequentialProposalId.test.js +202 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorStorage.test.js +155 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorSuperQuorum.test.js +168 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorSuperQuorumGreaterThanQuorum.t.sol +83 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorTimelockAccess.test.js +864 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorTimelockCompound.test.js +419 -339
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorTimelockControl.test.js +468 -384
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorVotesQuorumFraction.test.js +161 -133
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorVotesSuperQuorumFraction.test.js +160 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorWithParams.test.js +234 -155
- package/lib/openzeppelin-contracts-upgradeable/test/governance/utils/ERC6372.behavior.js +28 -0
- package/lib/openzeppelin-contracts-upgradeable/test/governance/utils/Votes.behavior.js +254 -273
- package/lib/openzeppelin-contracts-upgradeable/test/governance/utils/Votes.test.js +89 -48
- package/lib/openzeppelin-contracts-upgradeable/test/governance/utils/VotesExtended.test.js +152 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/access-manager.js +85 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/account.js +14 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/chains.js +56 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/constants.js +7 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/deploy.js +14 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/eip712-types.js +61 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/eip712.js +41 -26
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/enums.js +9 -24
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/erc4337.js +217 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/erc7579.js +58 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/erc7739.js +118 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/governance.js +194 -188
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/iterate.js +41 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/math.js +33 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/methods.js +14 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/precompiles.js +12 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/random.js +24 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/signers.js +184 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/storage.js +48 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/strings.js +5 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/time.js +33 -0
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/txpool.js +9 -20
- package/lib/openzeppelin-contracts-upgradeable/test/metatx/ERC2771Context.test.js +95 -71
- package/lib/openzeppelin-contracts-upgradeable/test/metatx/ERC2771Forwarder.t.sol +279 -0
- package/lib/openzeppelin-contracts-upgradeable/test/metatx/ERC2771Forwarder.test.js +384 -0
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/Clones.behaviour.js +60 -50
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/Clones.t.sol +91 -0
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/Clones.test.js +164 -56
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/ERC1967/ERC1967Proxy.test.js +17 -7
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/ERC1967/ERC1967Utils.test.js +162 -0
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/Proxy.behaviour.js +59 -98
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/beacon/BeaconProxy.test.js +98 -113
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/beacon/UpgradeableBeacon.test.js +34 -29
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/transparent/ProxyAdmin.test.js +45 -88
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/transparent/TransparentUpgradeableProxy.behaviour.js +209 -283
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/transparent/TransparentUpgradeableProxy.test.js +20 -7
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/utils/Initializable.test.js +94 -96
- package/lib/openzeppelin-contracts-upgradeable/test/proxy/utils/UUPSUpgradeable.test.js +94 -59
- package/lib/openzeppelin-contracts-upgradeable/test/sanity.test.js +27 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC1155/ERC1155.behavior.js +530 -541
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC1155/ERC1155.test.js +101 -152
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC1155/extensions/ERC1155Burnable.test.js +35 -36
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC1155/extensions/ERC1155Pausable.test.js +54 -57
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC1155/extensions/ERC1155Supply.test.js +59 -51
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC1155/extensions/ERC1155URIStorage.test.js +37 -33
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC1155/utils/ERC1155Holder.test.js +40 -46
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC1155/utils/ERC1155Utils.test.js +299 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/ERC20.behavior.js +142 -206
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/ERC20.test.js +133 -243
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC1363.test.js +370 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20Burnable.test.js +96 -10
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20Capped.test.js +43 -15
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20FlashMint.test.js +102 -82
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20Pausable.test.js +59 -64
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20Permit.test.js +109 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20Votes.test.js +490 -462
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20Wrapper.test.js +133 -120
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC4626.t.sol +41 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC4626.test.js +802 -536
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/draft-ERC20Bridgeable.test.js +89 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/draft-ERC20TemporaryApproval.test.js +142 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/utils/SafeERC20.test.js +387 -179
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC6909/ERC6909.behavior.js +216 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC6909/ERC6909.test.js +104 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC6909/extensions/ERC6909ContentURI.test.js +49 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC6909/extensions/ERC6909Metadata.test.js +58 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC6909/extensions/ERC6909TokenSupply.test.js +53 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/ERC721.behavior.js +488 -479
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/ERC721.test.js +16 -11
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/ERC721Enumerable.test.js +16 -8
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/extensions/ERC721Burnable.test.js +43 -44
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/extensions/ERC721Consecutive.t.sol +80 -19
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/extensions/ERC721Consecutive.test.js +181 -165
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/extensions/ERC721Pausable.test.js +34 -51
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/extensions/ERC721Royalty.test.js +41 -24
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/extensions/ERC721URIStorage.test.js +69 -44
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/extensions/ERC721Votes.test.js +187 -167
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/extensions/ERC721Wrapper.test.js +201 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/utils/ERC721Holder.test.js +12 -16
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/utils/ERC721Utils.test.js +94 -0
- package/lib/openzeppelin-contracts-upgradeable/test/token/common/ERC2981.behavior.js +80 -88
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Address.test.js +160 -261
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Arrays.t.sol +31 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Arrays.test.js +217 -95
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Base64.t.sol +34 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Base64.test.js +48 -22
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Blockhash.t.sol +101 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Blockhash.test.js +59 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Bytes.t.sol +74 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Bytes.test.js +212 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/CAIP.test.js +56 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Calldata.test.js +22 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Context.behavior.js +26 -20
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Context.test.js +10 -9
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Create2.t.sol +17 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Create2.test.js +147 -49
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Memory.t.sol +21 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Memory.test.js +39 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Multicall.test.js +50 -35
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Nonces.behavior.js +189 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Nonces.test.js +16 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/NoncesKeyed.test.js +17 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Packing.t.sol +993 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Packing.test.js +70 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Panic.test.js +37 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Pausable.test.js +90 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/ReentrancyGuard.test.js +50 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/ShortStrings.t.sol +109 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/ShortStrings.test.js +64 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/SlotDerivation.t.sol +248 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/SlotDerivation.test.js +58 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/StorageSlot.test.js +55 -92
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Strings.t.sol +50 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Strings.test.js +323 -49
- package/lib/openzeppelin-contracts-upgradeable/test/utils/TransientSlot.test.js +59 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/ECDSA.test.js +167 -132
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/EIP712.test.js +79 -52
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/ERC1271.behavior.js +111 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/ERC7739.test.js +42 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/ERC7739Utils.test.js +203 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/MerkleProof.test.js +210 -176
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/MessageHashUtils.t.sol +33 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/MessageHashUtils.test.js +97 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/P256.t.sol +65 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/P256.test.js +182 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/RSA.helper.js +17 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/RSA.test.js +102 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/SigVer15_186-3.rsp +3850 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/SignatureChecker.test.js +397 -56
- package/lib/openzeppelin-contracts-upgradeable/test/utils/cryptography/ecdsa_secp256r1_sha256_p1363_test.json +3719 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/draft-InteroperableAddress.t.sol +99 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/draft-InteroperableAddress.test.js +170 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/introspection/ERC165.test.js +11 -6
- package/lib/openzeppelin-contracts-upgradeable/test/utils/introspection/ERC165Checker.test.js +84 -142
- package/lib/openzeppelin-contracts-upgradeable/test/utils/introspection/SupportsInterface.behavior.js +109 -90
- package/lib/openzeppelin-contracts-upgradeable/test/utils/math/Math.t.sol +255 -24
- package/lib/openzeppelin-contracts-upgradeable/test/utils/math/Math.test.js +616 -215
- package/lib/openzeppelin-contracts-upgradeable/test/utils/math/SafeCast.test.js +84 -89
- package/lib/openzeppelin-contracts-upgradeable/test/utils/math/SignedMath.t.sol +80 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/math/SignedMath.test.js +25 -65
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/BitMap.test.js +83 -79
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/Checkpoints.t.sol +440 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/Checkpoints.test.js +147 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/CircularBuffer.test.js +83 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/DoubleEndedQueue.test.js +47 -41
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/EnumerableMap.behavior.js +122 -89
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/EnumerableMap.test.js +70 -73
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/EnumerableSet.behavior.js +105 -61
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/EnumerableSet.test.js +53 -33
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/Heap.t.sol +74 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/Heap.test.js +113 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/structs/MerkleTree.test.js +180 -0
- package/lib/openzeppelin-contracts-upgradeable/test/utils/types/Time.test.js +135 -0
- package/package.json +9 -23
- package/remappings.txt +5 -0
- package/script/CreateMarketLib.sol +1873 -0
- package/script/DeployProxy.s.sol +27 -0
- package/script/DeployUpgradeablePM.s.sol +47 -0
- package/script/PredictionMarketV3_3Flow.s.sol +132 -0
- package/scripts/copy-abis.js +57 -0
- package/src/Application.js +18 -0
- package/src/interfaces/index.js +16 -15
- package/src/models/PredictionMarketV3ControllerContract.js +2 -2
- package/src/models/PredictionMarketV3ManagerContract.js +4 -0
- package/src/models/PredictionMarketV3PlusContract.js +210 -0
- package/src/models/index.js +2 -0
- package/test/PredictionMarket.t.sol +923 -0
- package/test/PredictionMarketManager.t.sol +909 -0
- package/build/contracts/AccessControl.json +0 -1
- package/build/contracts/Address.json +0 -1
- package/build/contracts/BalanceHolder_ERC20.json +0 -1
- package/build/contracts/CeilDiv.json +0 -1
- package/build/contracts/Clones.json +0 -1
- package/build/contracts/Context.json +0 -1
- package/build/contracts/ERC165.json +0 -1
- package/build/contracts/ERC20.json +0 -1
- package/build/contracts/ERC20Burnable.json +0 -1
- package/build/contracts/ERC20Pausable.json +0 -1
- package/build/contracts/FantasyERC20.json +0 -1
- package/build/contracts/IAccessControl.json +0 -1
- package/build/contracts/IBalanceHolder_ERC20.json +0 -1
- package/build/contracts/IERC165.json +0 -1
- package/build/contracts/IERC20.json +0 -1
- package/build/contracts/IERC20Metadata.json +0 -1
- package/build/contracts/IERC721.json +0 -1
- package/build/contracts/IERC721Enumerable.json +0 -1
- package/build/contracts/IERC721Metadata.json +0 -1
- package/build/contracts/IFantasyERC20.json +0 -1
- package/build/contracts/IPredictionMarketV3Factory.json +0 -1
- package/build/contracts/IPredictionMarketV3Manager.json +0 -1
- package/build/contracts/IRealityETH_ERC20.json +0 -1
- package/build/contracts/IRealityETH_IERC20.json +0 -1
- package/build/contracts/IWETH.json +0 -1
- package/build/contracts/LandFactory.json +0 -1
- package/build/contracts/Ownable.json +0 -1
- package/build/contracts/Pausable.json +0 -1
- package/build/contracts/PredictionMarketV3Claimer.json +0 -1
- package/build/contracts/PredictionMarketV3Controller.json +0 -1
- package/build/contracts/PredictionMarketV3Factory.json +0 -1
- package/build/contracts/PredictionMarketV3Manager.json +0 -1
- package/build/contracts/PredictionMarketV3Querier.json +0 -1
- package/build/contracts/Proxy.json +0 -1
- package/build/contracts/RealityETH_ERC20_Factory.json +0 -1
- package/build/contracts/RealityETH_ERC20_v3_0.json +0 -1
- package/build/contracts/RealityETH_ERC20_v3_0_.json +0 -1
- package/build/contracts/ReentrancyGuard.json +0 -1
- package/build/contracts/SafeERC20.json +0 -1
- package/build/contracts/StorageSlot.json +0 -1
- package/build/contracts/TWProxy.json +0 -1
- package/build/contracts/USDCERC20.json +0 -1
- package/build/contracts/Voting.json +0 -1
- package/build/contracts/test.json +0 -1
- package/cache/solidity-files-cache.json +0 -1
- package/cache/zksync-solidity-files-cache.json +0 -1
- package/cleanContracts.js +0 -22
- package/contracts/IPredictionMarketV3.sol +0 -207
- package/contracts/Migrations.sol +0 -24
- package/contracts/PredictionMarketV3.sol +0 -1332
- package/contracts/RealityETH_ERC20_v3_0.sol +0 -8
- package/contracts/TWProxy.sol +0 -42
- package/contracts/USDCERC20.sol +0 -12
- package/contracts/WETH9.sol +0 -62
- package/lib/openzeppelin-contracts/.changeset/new-ways-own.md +0 -5
- package/lib/openzeppelin-contracts/.eslintrc +0 -62
- package/lib/openzeppelin-contracts/.gitattributes +0 -1
- package/lib/openzeppelin-contracts/.github/workflows/changelog.yml +0 -28
- package/lib/openzeppelin-contracts/.solhint.json +0 -14
- package/lib/openzeppelin-contracts/audit/2017-03.md +0 -292
- package/lib/openzeppelin-contracts/certora/applyHarness.patch +0 -101
- package/lib/openzeppelin-contracts/certora/harnesses/ERC20VotesHarness.sol +0 -28
- package/lib/openzeppelin-contracts/certora/harnesses/WizardControlFirstPriority.sol +0 -150
- package/lib/openzeppelin-contracts/certora/harnesses/WizardFirstTry.sol +0 -141
- package/lib/openzeppelin-contracts/certora/munged/.gitignore +0 -2
- package/lib/openzeppelin-contracts/certora/scripts/Governor.sh +0 -10
- package/lib/openzeppelin-contracts/certora/scripts/GovernorCountingSimple-counting.sh +0 -10
- package/lib/openzeppelin-contracts/certora/scripts/WizardControlFirstPriority.sh +0 -12
- package/lib/openzeppelin-contracts/certora/scripts/WizardFirstTry.sh +0 -10
- package/lib/openzeppelin-contracts/certora/scripts/sanity.sh +0 -14
- package/lib/openzeppelin-contracts/certora/scripts/verifyAll.sh +0 -39
- package/lib/openzeppelin-contracts/certora/specs/GovernorBase.spec +0 -333
- package/lib/openzeppelin-contracts/certora/specs/GovernorCountingSimple.spec +0 -221
- package/lib/openzeppelin-contracts/certora/specs/RulesInProgress.spec +0 -139
- package/lib/openzeppelin-contracts/certora/specs/sanity.spec +0 -14
- package/lib/openzeppelin-contracts/contracts/access/AccessControlCrossChain.sol +0 -45
- package/lib/openzeppelin-contracts/contracts/access/AccessControlEnumerable.sol +0 -64
- package/lib/openzeppelin-contracts/contracts/access/IAccessControlEnumerable.sol +0 -31
- package/lib/openzeppelin-contracts/contracts/crosschain/CrossChainEnabled.sol +0 -54
- package/lib/openzeppelin-contracts/contracts/crosschain/README.adoc +0 -34
- package/lib/openzeppelin-contracts/contracts/crosschain/amb/CrossChainEnabledAMB.sol +0 -49
- package/lib/openzeppelin-contracts/contracts/crosschain/amb/LibAMB.sol +0 -35
- package/lib/openzeppelin-contracts/contracts/crosschain/arbitrum/CrossChainEnabledArbitrumL1.sol +0 -44
- package/lib/openzeppelin-contracts/contracts/crosschain/arbitrum/CrossChainEnabledArbitrumL2.sol +0 -40
- package/lib/openzeppelin-contracts/contracts/crosschain/arbitrum/LibArbitrumL1.sol +0 -42
- package/lib/openzeppelin-contracts/contracts/crosschain/arbitrum/LibArbitrumL2.sol +0 -45
- package/lib/openzeppelin-contracts/contracts/crosschain/errors.sol +0 -7
- package/lib/openzeppelin-contracts/contracts/crosschain/optimism/CrossChainEnabledOptimism.sol +0 -41
- package/lib/openzeppelin-contracts/contracts/crosschain/optimism/LibOptimism.sol +0 -36
- package/lib/openzeppelin-contracts/contracts/crosschain/polygon/CrossChainEnabledPolygonChild.sol +0 -72
- package/lib/openzeppelin-contracts/contracts/finance/PaymentSplitter.sol +0 -214
- package/lib/openzeppelin-contracts/contracts/governance/compatibility/GovernorCompatibilityBravo.sol +0 -285
- package/lib/openzeppelin-contracts/contracts/governance/compatibility/IGovernorCompatibilityBravo.sol +0 -114
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorProposalThreshold.sol +0 -23
- package/lib/openzeppelin-contracts/contracts/governance/extensions/GovernorVotesComp.sol +0 -31
- package/lib/openzeppelin-contracts/contracts/governance/extensions/IGovernorTimelock.sol +0 -26
- package/lib/openzeppelin-contracts/contracts/interfaces/draft-IERC2612.sol +0 -8
- package/lib/openzeppelin-contracts/contracts/metatx/MinimalForwarder.sol +0 -73
- package/lib/openzeppelin-contracts/contracts/mocks/AccessControlCrossChainMock.sol +0 -22
- package/lib/openzeppelin-contracts/contracts/mocks/AccessControlEnumerableMock.sol +0 -17
- package/lib/openzeppelin-contracts/contracts/mocks/AccessControlMock.sol +0 -17
- package/lib/openzeppelin-contracts/contracts/mocks/AddressImpl.sol +0 -46
- package/lib/openzeppelin-contracts/contracts/mocks/BadBeacon.sol +0 -11
- package/lib/openzeppelin-contracts/contracts/mocks/Base64Mock.sol +0 -11
- package/lib/openzeppelin-contracts/contracts/mocks/BitmapMock.sol +0 -27
- package/lib/openzeppelin-contracts/contracts/mocks/CheckpointsMock.sol +0 -120
- package/lib/openzeppelin-contracts/contracts/mocks/ClashingImplementation.sol +0 -18
- package/lib/openzeppelin-contracts/contracts/mocks/ClonesMock.sol +0 -36
- package/lib/openzeppelin-contracts/contracts/mocks/ConditionalEscrowMock.sol +0 -18
- package/lib/openzeppelin-contracts/contracts/mocks/CountersImpl.sol +0 -27
- package/lib/openzeppelin-contracts/contracts/mocks/Create2Impl.sol +0 -34
- package/lib/openzeppelin-contracts/contracts/mocks/DoubleEndedQueueMock.sol +0 -58
- package/lib/openzeppelin-contracts/contracts/mocks/ECDSAMock.sol +0 -41
- package/lib/openzeppelin-contracts/contracts/mocks/EIP712External.sol +0 -31
- package/lib/openzeppelin-contracts/contracts/mocks/ERC1155BurnableMock.sol +0 -18
- package/lib/openzeppelin-contracts/contracts/mocks/ERC1155Mock.sol +0 -51
- package/lib/openzeppelin-contracts/contracts/mocks/ERC1155PausableMock.sol +0 -29
- package/lib/openzeppelin-contracts/contracts/mocks/ERC1155ReceiverMock.sol +0 -52
- package/lib/openzeppelin-contracts/contracts/mocks/ERC1155SupplyMock.sol +0 -21
- package/lib/openzeppelin-contracts/contracts/mocks/ERC1155URIStorageMock.sol +0 -22
- package/lib/openzeppelin-contracts/contracts/mocks/ERC165CheckerMock.sol +0 -29
- package/lib/openzeppelin-contracts/contracts/mocks/ERC165Mock.sol +0 -7
- package/lib/openzeppelin-contracts/contracts/mocks/ERC165StorageMock.sol +0 -11
- package/lib/openzeppelin-contracts/contracts/mocks/ERC1820ImplementerMock.sol +0 -11
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20BurnableMock.sol +0 -16
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20CappedMock.sol +0 -17
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20DecimalsMock.sol +0 -29
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20FlashMintMock.sol +0 -43
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20Mock.sol +0 -41
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20PausableMock.sol +0 -33
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20PermitMock.sol +0 -20
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20SnapshotMock.sol +0 -28
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20VotesCompMock.sol +0 -21
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20VotesMock.sol +0 -21
- package/lib/openzeppelin-contracts/contracts/mocks/ERC20WrapperMock.sol +0 -17
- package/lib/openzeppelin-contracts/contracts/mocks/ERC4626Mock.sol +0 -60
- package/lib/openzeppelin-contracts/contracts/mocks/ERC721BurnableMock.sol +0 -29
- package/lib/openzeppelin-contracts/contracts/mocks/ERC721ConsecutiveEnumerableMock.sol +0 -55
- package/lib/openzeppelin-contracts/contracts/mocks/ERC721ConsecutiveMock.sol +0 -86
- package/lib/openzeppelin-contracts/contracts/mocks/ERC721EnumerableMock.sol +0 -51
- package/lib/openzeppelin-contracts/contracts/mocks/ERC721Mock.sol +0 -41
- package/lib/openzeppelin-contracts/contracts/mocks/ERC721PausableMock.sol +0 -45
- package/lib/openzeppelin-contracts/contracts/mocks/ERC721ReceiverMock.sol +0 -42
- package/lib/openzeppelin-contracts/contracts/mocks/ERC721RoyaltyMock.sol +0 -33
- package/lib/openzeppelin-contracts/contracts/mocks/ERC721URIStorageMock.sol +0 -55
- package/lib/openzeppelin-contracts/contracts/mocks/ERC721VotesMock.sol +0 -25
- package/lib/openzeppelin-contracts/contracts/mocks/ERC777Mock.sol +0 -56
- package/lib/openzeppelin-contracts/contracts/mocks/ERC777SenderRecipientMock.sol +0 -161
- package/lib/openzeppelin-contracts/contracts/mocks/EnumerableMapMock.sol +0 -221
- package/lib/openzeppelin-contracts/contracts/mocks/EnumerableSetMock.sol +0 -111
- package/lib/openzeppelin-contracts/contracts/mocks/GovernorCompMock.sol +0 -31
- package/lib/openzeppelin-contracts/contracts/mocks/GovernorCompatibilityBravoMock.sol +0 -127
- package/lib/openzeppelin-contracts/contracts/mocks/GovernorMock.sol +0 -50
- package/lib/openzeppelin-contracts/contracts/mocks/GovernorPreventLateQuorumMock.sol +0 -60
- package/lib/openzeppelin-contracts/contracts/mocks/GovernorTimelockCompoundMock.sol +0 -96
- package/lib/openzeppelin-contracts/contracts/mocks/GovernorTimelockControlMock.sol +0 -93
- package/lib/openzeppelin-contracts/contracts/mocks/GovernorVoteMock.sol +0 -31
- package/lib/openzeppelin-contracts/contracts/mocks/GovernorWithParamsMock.sol +0 -61
- package/lib/openzeppelin-contracts/contracts/mocks/MathMock.sol +0 -48
- package/lib/openzeppelin-contracts/contracts/mocks/MerkleProofWrapper.sol +0 -65
- package/lib/openzeppelin-contracts/contracts/mocks/MulticallTest.sol +0 -23
- package/lib/openzeppelin-contracts/contracts/mocks/MulticallTokenMock.sol +0 -10
- package/lib/openzeppelin-contracts/contracts/mocks/Ownable2StepMock.sol +0 -7
- package/lib/openzeppelin-contracts/contracts/mocks/OwnableMock.sol +0 -7
- package/lib/openzeppelin-contracts/contracts/mocks/PullPaymentMock.sol +0 -15
- package/lib/openzeppelin-contracts/contracts/mocks/SafeCastMock.sol +0 -267
- package/lib/openzeppelin-contracts/contracts/mocks/SafeERC20Helper.sol +0 -194
- package/lib/openzeppelin-contracts/contracts/mocks/SafeMathMock.sol +0 -138
- package/lib/openzeppelin-contracts/contracts/mocks/SignatureCheckerMock.sol +0 -17
- package/lib/openzeppelin-contracts/contracts/mocks/SignedMathMock.sol +0 -23
- package/lib/openzeppelin-contracts/contracts/mocks/SignedSafeMathMock.sol +0 -23
- package/lib/openzeppelin-contracts/contracts/mocks/StringsMock.sol +0 -23
- package/lib/openzeppelin-contracts/contracts/mocks/TimersBlockNumberImpl.sol +0 -39
- package/lib/openzeppelin-contracts/contracts/mocks/TimersTimestampImpl.sol +0 -39
- package/lib/openzeppelin-contracts/contracts/mocks/UUPS/UUPSLegacy.sol +0 -58
- package/lib/openzeppelin-contracts/contracts/mocks/UUPS/UUPSUpgradeableMock.sol +0 -21
- package/lib/openzeppelin-contracts/contracts/mocks/crosschain/bridges.sol +0 -102
- package/lib/openzeppelin-contracts/contracts/mocks/crosschain/receivers.sol +0 -54
- package/lib/openzeppelin-contracts/contracts/mocks/wizard/MyGovernor1.sol +0 -87
- package/lib/openzeppelin-contracts/contracts/mocks/wizard/MyGovernor2.sol +0 -93
- package/lib/openzeppelin-contracts/contracts/mocks/wizard/MyGovernor3.sol +0 -96
- package/lib/openzeppelin-contracts/contracts/proxy/ERC1967/ERC1967Upgrade.sol +0 -185
- package/lib/openzeppelin-contracts/contracts/security/Pausable.sol +0 -105
- package/lib/openzeppelin-contracts/contracts/security/PullPayment.sol +0 -74
- package/lib/openzeppelin-contracts/contracts/security/README.adoc +0 -20
- package/lib/openzeppelin-contracts/contracts/security/ReentrancyGuard.sol +0 -69
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/presets/ERC1155PresetMinterPauser.sol +0 -128
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/presets/README.md +0 -1
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/utils/ERC1155Receiver.sol +0 -19
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20Snapshot.sol +0 -195
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/ERC20VotesComp.sol +0 -46
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-ERC20Permit.sol +0 -95
- package/lib/openzeppelin-contracts/contracts/token/ERC20/extensions/draft-IERC20Permit.sol +0 -60
- package/lib/openzeppelin-contracts/contracts/token/ERC20/presets/ERC20PresetFixedSupply.sol +0 -35
- package/lib/openzeppelin-contracts/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol +0 -94
- package/lib/openzeppelin-contracts/contracts/token/ERC20/presets/README.md +0 -1
- package/lib/openzeppelin-contracts/contracts/token/ERC20/utils/TokenTimelock.sol +0 -76
- package/lib/openzeppelin-contracts/contracts/token/ERC721/extensions/draft-ERC721Votes.sol +0 -9
- package/lib/openzeppelin-contracts/contracts/token/ERC721/presets/ERC721PresetMinterPauserAutoId.sol +0 -140
- package/lib/openzeppelin-contracts/contracts/token/ERC721/presets/README.md +0 -1
- package/lib/openzeppelin-contracts/contracts/token/ERC777/ERC777.sol +0 -547
- package/lib/openzeppelin-contracts/contracts/token/ERC777/IERC777.sol +0 -209
- package/lib/openzeppelin-contracts/contracts/token/ERC777/IERC777Recipient.sol +0 -35
- package/lib/openzeppelin-contracts/contracts/token/ERC777/IERC777Sender.sol +0 -35
- package/lib/openzeppelin-contracts/contracts/token/ERC777/README.adoc +0 -30
- package/lib/openzeppelin-contracts/contracts/token/ERC777/presets/ERC777PresetFixedSupply.sol +0 -30
- package/lib/openzeppelin-contracts/contracts/utils/Checkpoints.sol +0 -554
- package/lib/openzeppelin-contracts/contracts/utils/Counters.sol +0 -43
- package/lib/openzeppelin-contracts/contracts/utils/Timers.sol +0 -73
- package/lib/openzeppelin-contracts/contracts/utils/cryptography/draft-EIP712.sol +0 -8
- package/lib/openzeppelin-contracts/contracts/utils/escrow/ConditionalEscrow.sol +0 -25
- package/lib/openzeppelin-contracts/contracts/utils/escrow/Escrow.sol +0 -67
- package/lib/openzeppelin-contracts/contracts/utils/escrow/RefundEscrow.sol +0 -100
- package/lib/openzeppelin-contracts/contracts/utils/introspection/ERC165Storage.sol +0 -42
- package/lib/openzeppelin-contracts/contracts/utils/introspection/ERC1820Implementer.sol +0 -44
- package/lib/openzeppelin-contracts/contracts/utils/introspection/IERC1820Implementer.sol +0 -20
- package/lib/openzeppelin-contracts/contracts/utils/introspection/IERC1820Registry.sol +0 -116
- package/lib/openzeppelin-contracts/contracts/utils/math/SafeMath.sol +0 -227
- package/lib/openzeppelin-contracts/contracts/utils/math/SignedSafeMath.sol +0 -68
- package/lib/openzeppelin-contracts/contracts/vendor/amb/IAMB.sol +0 -49
- package/lib/openzeppelin-contracts/contracts/vendor/arbitrum/IArbSys.sol +0 -141
- package/lib/openzeppelin-contracts/contracts/vendor/arbitrum/IBridge.sol +0 -109
- package/lib/openzeppelin-contracts/contracts/vendor/arbitrum/IDelayedMessageProvider.sol +0 -16
- package/lib/openzeppelin-contracts/contracts/vendor/arbitrum/IInbox.sol +0 -152
- package/lib/openzeppelin-contracts/contracts/vendor/arbitrum/IOutbox.sol +0 -121
- package/lib/openzeppelin-contracts/contracts/vendor/optimism/ICrossDomainMessenger.sol +0 -38
- package/lib/openzeppelin-contracts/contracts/vendor/optimism/LICENSE +0 -22
- package/lib/openzeppelin-contracts/contracts/vendor/polygon/IFxMessageProcessor.sol +0 -11
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/crosschain.adoc +0 -210
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/crowdsales.adoc +0 -11
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/drafts.adoc +0 -19
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc777.adoc +0 -73
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/releases-stability.adoc +0 -85
- package/lib/openzeppelin-contracts/hardhat/env-contract.js +0 -10
- package/lib/openzeppelin-contracts/lib/forge-std/.gitmodules +0 -3
- package/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/LICENSE +0 -674
- package/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/Makefile +0 -14
- package/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/default.nix +0 -4
- package/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/demo/demo.sol +0 -222
- package/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/package.json +0 -15
- package/lib/openzeppelin-contracts/lib/forge-std/lib/ds-test/src/test.sol +0 -469
- package/lib/openzeppelin-contracts/scripts/generate/templates/CheckpointsMock.js +0 -80
- package/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableMapMock.js +0 -66
- package/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableSetMock.js +0 -56
- package/lib/openzeppelin-contracts/scripts/generate/templates/SafeCastMock.js +0 -50
- package/lib/openzeppelin-contracts/scripts/migrate-imports.js +0 -177
- package/lib/openzeppelin-contracts/scripts/prepare-contracts-package.sh +0 -15
- package/lib/openzeppelin-contracts/scripts/prepare.sh +0 -10
- package/lib/openzeppelin-contracts/scripts/release/release.sh +0 -145
- package/lib/openzeppelin-contracts/scripts/release/update-changelog-release-date.js +0 -34
- package/lib/openzeppelin-contracts/test/access/AccessControlCrossChain.test.js +0 -59
- package/lib/openzeppelin-contracts/test/access/AccessControlEnumerable.test.js +0 -15
- package/lib/openzeppelin-contracts/test/crosschain/CrossChainEnabled.test.js +0 -88
- package/lib/openzeppelin-contracts/test/finance/PaymentSplitter.test.js +0 -217
- package/lib/openzeppelin-contracts/test/governance/compatibility/GovernorCompatibilityBravo.test.js +0 -265
- package/lib/openzeppelin-contracts/test/governance/extensions/GovernorComp.test.js +0 -78
- package/lib/openzeppelin-contracts/test/helpers/create2.js +0 -12
- package/lib/openzeppelin-contracts/test/helpers/crosschain.js +0 -63
- package/lib/openzeppelin-contracts/test/helpers/customError.js +0 -24
- package/lib/openzeppelin-contracts/test/helpers/erc1967.js +0 -24
- package/lib/openzeppelin-contracts/test/helpers/sign.js +0 -47
- package/lib/openzeppelin-contracts/test/metatx/MinimalForwarder.test.js +0 -184
- package/lib/openzeppelin-contracts/test/migrate-imports.test.js +0 -29
- package/lib/openzeppelin-contracts/test/security/Pausable.test.js +0 -89
- package/lib/openzeppelin-contracts/test/security/PullPayment.test.js +0 -51
- package/lib/openzeppelin-contracts/test/security/ReentrancyGuard.test.js +0 -40
- package/lib/openzeppelin-contracts/test/token/ERC1155/presets/ERC1155PresetMinterPauser.test.js +0 -146
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Burnable.behavior.js +0 -109
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Capped.behavior.js +0 -32
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20Snapshot.test.js +0 -204
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/ERC20VotesComp.test.js +0 -496
- package/lib/openzeppelin-contracts/test/token/ERC20/extensions/draft-ERC20Permit.test.js +0 -109
- package/lib/openzeppelin-contracts/test/token/ERC20/presets/ERC20PresetFixedSupply.test.js +0 -42
- package/lib/openzeppelin-contracts/test/token/ERC20/presets/ERC20PresetMinterPauser.test.js +0 -113
- package/lib/openzeppelin-contracts/test/token/ERC20/utils/TokenTimelock.test.js +0 -71
- package/lib/openzeppelin-contracts/test/token/ERC721/presets/ERC721PresetMinterPauserAutoId.test.js +0 -125
- package/lib/openzeppelin-contracts/test/token/ERC777/ERC777.behavior.js +0 -555
- package/lib/openzeppelin-contracts/test/token/ERC777/ERC777.test.js +0 -610
- package/lib/openzeppelin-contracts/test/token/ERC777/presets/ERC777PresetFixedSupply.test.js +0 -49
- package/lib/openzeppelin-contracts/test/utils/Checkpoints.test.js +0 -189
- package/lib/openzeppelin-contracts/test/utils/Counters.test.js +0 -84
- package/lib/openzeppelin-contracts/test/utils/TimersBlockNumberImpl.test.js +0 -55
- package/lib/openzeppelin-contracts/test/utils/TimersTimestamp.test.js +0 -55
- package/lib/openzeppelin-contracts/test/utils/escrow/ConditionalEscrow.test.js +0 -36
- package/lib/openzeppelin-contracts/test/utils/escrow/Escrow.behavior.js +0 -94
- package/lib/openzeppelin-contracts/test/utils/escrow/Escrow.test.js +0 -14
- package/lib/openzeppelin-contracts/test/utils/escrow/RefundEscrow.test.js +0 -148
- package/lib/openzeppelin-contracts/test/utils/introspection/ERC165Storage.test.js +0 -25
- package/lib/openzeppelin-contracts/test/utils/introspection/ERC1820Implementer.test.js +0 -66
- package/lib/openzeppelin-contracts/test/utils/math/SafeMath.test.js +0 -403
- package/lib/openzeppelin-contracts/test/utils/math/SignedSafeMath.test.js +0 -152
- package/lib/openzeppelin-contracts-upgradeable/.changeset/new-ways-own.md +0 -5
- package/lib/openzeppelin-contracts-upgradeable/.eslintrc +0 -62
- package/lib/openzeppelin-contracts-upgradeable/.gitattributes +0 -1
- package/lib/openzeppelin-contracts-upgradeable/.github/ISSUE_TEMPLATE/bug_report.md +0 -21
- package/lib/openzeppelin-contracts-upgradeable/.github/workflows/changelog.yml +0 -28
- package/lib/openzeppelin-contracts-upgradeable/.github/workflows/merge-upstream.yml +0 -28
- package/lib/openzeppelin-contracts-upgradeable/.github/workflows/transpile.yml +0 -27
- package/lib/openzeppelin-contracts-upgradeable/.solhint.json +0 -14
- package/lib/openzeppelin-contracts-upgradeable/UPGRADEABLE.md +0 -47
- package/lib/openzeppelin-contracts-upgradeable/audit/2017-03.md +0 -292
- package/lib/openzeppelin-contracts-upgradeable/certora/applyHarness.patch +0 -101
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/ERC20VotesHarness.sol +0 -28
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/WizardControlFirstPriority.sol +0 -150
- package/lib/openzeppelin-contracts-upgradeable/certora/harnesses/WizardFirstTry.sol +0 -141
- package/lib/openzeppelin-contracts-upgradeable/certora/munged/.gitignore +0 -2
- package/lib/openzeppelin-contracts-upgradeable/certora/scripts/Governor.sh +0 -10
- package/lib/openzeppelin-contracts-upgradeable/certora/scripts/GovernorCountingSimple-counting.sh +0 -10
- package/lib/openzeppelin-contracts-upgradeable/certora/scripts/WizardControlFirstPriority.sh +0 -12
- package/lib/openzeppelin-contracts-upgradeable/certora/scripts/WizardFirstTry.sh +0 -10
- package/lib/openzeppelin-contracts-upgradeable/certora/scripts/sanity.sh +0 -14
- package/lib/openzeppelin-contracts-upgradeable/certora/scripts/verifyAll.sh +0 -39
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/GovernorBase.spec +0 -333
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/GovernorCountingSimple.spec +0 -221
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/RulesInProgress.spec +0 -139
- package/lib/openzeppelin-contracts-upgradeable/certora/specs/sanity.spec +0 -14
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/AccessControlCrossChainUpgradeable.sol +0 -58
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/AccessControlEnumerableUpgradeable.sol +0 -77
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/IAccessControlEnumerableUpgradeable.sol +0 -31
- package/lib/openzeppelin-contracts-upgradeable/contracts/access/IAccessControlUpgradeable.sol +0 -88
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/CrossChainEnabledUpgradeable.sol +0 -67
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/README.adoc +0 -34
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/amb/CrossChainEnabledAMBUpgradeable.sol +0 -57
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/amb/LibAMBUpgradeable.sol +0 -35
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/arbitrum/CrossChainEnabledArbitrumL1Upgradeable.sol +0 -52
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/arbitrum/CrossChainEnabledArbitrumL2Upgradeable.sol +0 -53
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/arbitrum/LibArbitrumL1Upgradeable.sol +0 -42
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/arbitrum/LibArbitrumL2Upgradeable.sol +0 -45
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/errorsUpgradeable.sol +0 -7
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/optimism/CrossChainEnabledOptimismUpgradeable.sol +0 -49
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/optimism/LibOptimismUpgradeable.sol +0 -36
- package/lib/openzeppelin-contracts-upgradeable/contracts/crosschain/polygon/CrossChainEnabledPolygonChildUpgradeable.sol +0 -90
- package/lib/openzeppelin-contracts-upgradeable/contracts/finance/PaymentSplitterUpgradeable.sol +0 -226
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/IGovernorUpgradeable.sol +0 -289
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/TimelockControllerWith46MigrationUpgradeable.sol +0 -56
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/compatibility/GovernorCompatibilityBravoUpgradeable.sol +0 -298
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/compatibility/IGovernorCompatibilityBravoUpgradeable.sol +0 -127
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorProposalThresholdUpgradeable.sol +0 -36
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/GovernorVotesCompUpgradeable.sol +0 -45
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/extensions/IGovernorTimelockUpgradeable.sol +0 -39
- package/lib/openzeppelin-contracts-upgradeable/contracts/governance/utils/IVotesUpgradeable.sol +0 -61
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC1155MetadataURIUpgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC1155ReceiverUpgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC1155Upgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC1271Upgradeable.sol +0 -19
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC1363ReceiverUpgradeable.sol +0 -32
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC1363SpenderUpgradeable.sol +0 -30
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC1363Upgradeable.sol +0 -95
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC165Upgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC1820ImplementerUpgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC1820RegistryUpgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC20MetadataUpgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC20Upgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC2309Upgradeable.sol +0 -21
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC2981Upgradeable.sol +0 -25
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC3156FlashBorrowerUpgradeable.sol +0 -29
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC3156FlashLenderUpgradeable.sol +0 -43
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC3156Upgradeable.sol +0 -7
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC4626Upgradeable.sol +0 -240
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC721EnumerableUpgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC721MetadataUpgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC721ReceiverUpgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC721Upgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC777RecipientUpgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC777SenderUpgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/IERC777Upgradeable.sol +0 -6
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/draft-IERC1822Upgradeable.sol +0 -20
- package/lib/openzeppelin-contracts-upgradeable/contracts/interfaces/draft-IERC2612Upgradeable.sol +0 -8
- package/lib/openzeppelin-contracts-upgradeable/contracts/metatx/MinimalForwarderUpgradeable.sol +0 -85
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/AccessControlCrossChainMockUpgradeable.sol +0 -34
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/AccessControlEnumerableMockUpgradeable.sol +0 -29
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/AccessControlMockUpgradeable.sol +0 -29
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/AddressImplUpgradeable.sol +0 -54
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/BadBeaconUpgradeable.sol +0 -36
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/Base64MockUpgradeable.sol +0 -24
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/BitmapMockUpgradeable.sol +0 -40
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/CheckpointsMockUpgradeable.sol +0 -157
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ClashingImplementationUpgradeable.sol +0 -31
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ClonesMockUpgradeable.sol +0 -49
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ConditionalEscrowMockUpgradeable.sol +0 -32
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/CountersImplUpgradeable.sol +0 -40
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/Create2ImplUpgradeable.sol +0 -47
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/DoubleEndedQueueMockUpgradeable.sol +0 -71
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ECDSAMockUpgradeable.sol +0 -54
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/EIP712ExternalUpgradeable.sol +0 -43
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC1155BurnableMockUpgradeable.sol +0 -30
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC1155MockUpgradeable.sol +0 -63
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC1155PausableMockUpgradeable.sol +0 -43
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC1155ReceiverMockUpgradeable.sol +0 -69
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC1155SupplyMockUpgradeable.sol +0 -34
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC1155URIStorageMockUpgradeable.sol +0 -36
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC165CheckerMockUpgradeable.sol +0 -42
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC165MockUpgradeable.sol +0 -20
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC165StorageMockUpgradeable.sol +0 -24
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC1820ImplementerMockUpgradeable.sol +0 -24
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20BurnableMockUpgradeable.sol +0 -34
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20CappedMockUpgradeable.sol +0 -34
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20DecimalsMockUpgradeable.sol +0 -46
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20FlashMintMockUpgradeable.sol +0 -61
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20MockUpgradeable.sol +0 -59
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20PausableMockUpgradeable.sol +0 -52
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20PermitMockUpgradeable.sol +0 -40
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20SnapshotMockUpgradeable.sol +0 -46
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20VotesCompMockUpgradeable.sol +0 -35
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20VotesMockUpgradeable.sol +0 -35
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC20WrapperMockUpgradeable.sol +0 -34
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC4626MockUpgradeable.sol +0 -96
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC721BurnableMockUpgradeable.sol +0 -41
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC721ConsecutiveEnumerableMockUpgradeable.sol +0 -73
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC721ConsecutiveMockUpgradeable.sol +0 -119
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC721EnumerableMockUpgradeable.sol +0 -63
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC721MockUpgradeable.sol +0 -53
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC721PausableMockUpgradeable.sol +0 -58
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC721ReceiverMockUpgradeable.sol +0 -54
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC721RoyaltyMockUpgradeable.sol +0 -45
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC721URIStorageMockUpgradeable.sol +0 -67
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC721VotesMockUpgradeable.sol +0 -38
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC777MockUpgradeable.sol +0 -75
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/ERC777SenderRecipientMockUpgradeable.sol +0 -176
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/EnumerableMapMockUpgradeable.sol +0 -282
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/EnumerableSetMockUpgradeable.sol +0 -148
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/GovernorCompMockUpgradeable.sol +0 -45
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/GovernorCompatibilityBravoMockUpgradeable.sol +0 -145
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/GovernorMockUpgradeable.sol +0 -67
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/GovernorPreventLateQuorumMockUpgradeable.sol +0 -79
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/GovernorTimelockCompoundMockUpgradeable.sol +0 -114
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/GovernorTimelockControlMockUpgradeable.sol +0 -111
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/GovernorVoteMockUpgradeable.sol +0 -45
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/GovernorWithParamsMockUpgradeable.sol +0 -75
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/MathMockUpgradeable.sol +0 -61
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/MerkleProofWrapperUpgradeable.sol +0 -78
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/MulticallTestUpgradeable.sol +0 -36
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/MulticallTokenMockUpgradeable.sol +0 -23
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/Ownable2StepMockUpgradeable.sol +0 -21
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/OwnableMockUpgradeable.sol +0 -21
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/PullPaymentMockUpgradeable.sol +0 -27
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/SafeCastMockUpgradeable.sol +0 -280
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/SafeERC20HelperUpgradeable.sol +0 -257
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/SafeMathMockUpgradeable.sol +0 -151
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/SignatureCheckerMockUpgradeable.sol +0 -30
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/SignedMathMockUpgradeable.sol +0 -36
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/SignedSafeMathMockUpgradeable.sol +0 -36
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/StringsMockUpgradeable.sol +0 -36
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/TimersBlockNumberImplUpgradeable.sol +0 -52
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/TimersTimestampImplUpgradeable.sol +0 -52
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/UUPS/UUPSLegacyUpgradeable.sol +0 -81
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/UUPS/UUPSUpgradeableMockUpgradeable.sol +0 -46
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/crosschain/bridgesUpgradeable.sol +0 -199
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/crosschain/receiversUpgradeable.sol +0 -107
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/wizard/MyGovernor1Upgradeable.sol +0 -98
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/wizard/MyGovernor2Upgradeable.sol +0 -104
- package/lib/openzeppelin-contracts-upgradeable/contracts/mocks/wizard/MyGovernor3Upgradeable.sol +0 -107
- package/lib/openzeppelin-contracts-upgradeable/contracts/proxy/ClonesUpgradeable.sol +0 -89
- package/lib/openzeppelin-contracts-upgradeable/contracts/proxy/ERC1967/ERC1967UpgradeUpgradeable.sol +0 -212
- package/lib/openzeppelin-contracts-upgradeable/contracts/proxy/beacon/IBeaconUpgradeable.sol +0 -16
- package/lib/openzeppelin-contracts-upgradeable/contracts/security/PausableUpgradeable.sol +0 -117
- package/lib/openzeppelin-contracts-upgradeable/contracts/security/PullPaymentUpgradeable.sol +0 -89
- package/lib/openzeppelin-contracts-upgradeable/contracts/security/README.adoc +0 -20
- package/lib/openzeppelin-contracts-upgradeable/contracts/security/ReentrancyGuardUpgradeable.sol +0 -81
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/IERC1155ReceiverUpgradeable.sol +0 -58
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/IERC1155Upgradeable.sol +0 -125
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/extensions/IERC1155MetadataURIUpgradeable.sol +0 -22
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/presets/ERC1155PresetMinterPauserUpgradeable.sol +0 -145
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/presets/README.md +0 -1
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC1155/utils/ERC1155ReceiverUpgradeable.sol +0 -32
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/IERC20Upgradeable.sol +0 -82
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC20SnapshotUpgradeable.sol +0 -208
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/ERC20VotesCompUpgradeable.sol +0 -59
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/IERC20MetadataUpgradeable.sol +0 -28
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/draft-ERC20PermitUpgradeable.sol +0 -109
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/extensions/draft-IERC20PermitUpgradeable.sol +0 -60
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/presets/ERC20PresetFixedSupplyUpgradeable.sol +0 -61
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/presets/ERC20PresetMinterPauserUpgradeable.sol +0 -111
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/presets/README.md +0 -1
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/utils/SafeERC20Upgradeable.sol +0 -116
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC20/utils/TokenTimelockUpgradeable.sol +0 -94
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/IERC721ReceiverUpgradeable.sol +0 -27
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/IERC721Upgradeable.sol +0 -145
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/IERC721EnumerableUpgradeable.sol +0 -29
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/IERC721MetadataUpgradeable.sol +0 -27
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/extensions/draft-ERC721VotesUpgradeable.sol +0 -9
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/presets/ERC721PresetMinterPauserAutoIdUpgradeable.sol +0 -165
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC721/presets/README.md +0 -1
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC777/ERC777Upgradeable.sol +0 -563
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC777/IERC777RecipientUpgradeable.sol +0 -35
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC777/IERC777SenderUpgradeable.sol +0 -35
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC777/IERC777Upgradeable.sol +0 -209
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC777/README.adoc +0 -30
- package/lib/openzeppelin-contracts-upgradeable/contracts/token/ERC777/presets/ERC777PresetFixedSupplyUpgradeable.sol +0 -58
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/AddressUpgradeable.sol +0 -219
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/ArraysUpgradeable.sol +0 -96
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/Base64Upgradeable.sol +0 -92
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/CheckpointsUpgradeable.sol +0 -554
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/CountersUpgradeable.sol +0 -43
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/Create2Upgradeable.sol +0 -83
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/StorageSlotUpgradeable.sol +0 -88
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/StringsUpgradeable.sol +0 -70
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/TimersUpgradeable.sol +0 -73
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/ECDSAUpgradeable.sol +0 -213
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/MerkleProofUpgradeable.sol +0 -223
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/SignatureCheckerUpgradeable.sol +0 -42
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/cryptography/draft-EIP712Upgradeable.sol +0 -8
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/escrow/ConditionalEscrowUpgradeable.sol +0 -39
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/escrow/EscrowUpgradeable.sol +0 -84
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/escrow/RefundEscrowUpgradeable.sol +0 -113
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/introspection/ERC165CheckerUpgradeable.sol +0 -127
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/introspection/ERC165StorageUpgradeable.sol +0 -55
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/introspection/ERC1820ImplementerUpgradeable.sol +0 -57
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/introspection/IERC165Upgradeable.sol +0 -25
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/introspection/IERC1820ImplementerUpgradeable.sol +0 -20
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/introspection/IERC1820RegistryUpgradeable.sol +0 -116
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/math/MathUpgradeable.sol +0 -345
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/math/SafeCastUpgradeable.sol +0 -1136
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/math/SafeMathUpgradeable.sol +0 -227
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/math/SignedMathUpgradeable.sol +0 -43
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/math/SignedSafeMathUpgradeable.sol +0 -68
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/structs/BitMapsUpgradeable.sol +0 -55
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/structs/DoubleEndedQueueUpgradeable.sol +0 -170
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/structs/EnumerableMapUpgradeable.sol +0 -530
- package/lib/openzeppelin-contracts-upgradeable/contracts/utils/structs/EnumerableSetUpgradeable.sol +0 -378
- package/lib/openzeppelin-contracts-upgradeable/contracts/vendor/amb/IAMBUpgradeable.sol +0 -49
- package/lib/openzeppelin-contracts-upgradeable/contracts/vendor/arbitrum/IArbSysUpgradeable.sol +0 -141
- package/lib/openzeppelin-contracts-upgradeable/contracts/vendor/arbitrum/IBridgeUpgradeable.sol +0 -109
- package/lib/openzeppelin-contracts-upgradeable/contracts/vendor/arbitrum/IDelayedMessageProviderUpgradeable.sol +0 -16
- package/lib/openzeppelin-contracts-upgradeable/contracts/vendor/arbitrum/IInboxUpgradeable.sol +0 -152
- package/lib/openzeppelin-contracts-upgradeable/contracts/vendor/arbitrum/IOutboxUpgradeable.sol +0 -121
- package/lib/openzeppelin-contracts-upgradeable/contracts/vendor/compound/ICompoundTimelockUpgradeable.sol +0 -86
- package/lib/openzeppelin-contracts-upgradeable/contracts/vendor/optimism/ICrossDomainMessengerUpgradeable.sol +0 -38
- package/lib/openzeppelin-contracts-upgradeable/contracts/vendor/optimism/LICENSE +0 -22
- package/lib/openzeppelin-contracts-upgradeable/contracts/vendor/polygon/IFxMessageProcessorUpgradeable.sol +0 -11
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/crosschain.adoc +0 -210
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/crowdsales.adoc +0 -11
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/drafts.adoc +0 -19
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/erc777.adoc +0 -73
- package/lib/openzeppelin-contracts-upgradeable/docs/modules/ROOT/pages/releases-stability.adoc +0 -85
- package/lib/openzeppelin-contracts-upgradeable/hardhat/env-contract.js +0 -10
- package/lib/openzeppelin-contracts-upgradeable/hardhat/task-get-compiler-input.js +0 -10
- package/lib/openzeppelin-contracts-upgradeable/icon.svg +0 -13
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/.gitmodules +0 -3
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/lib/ds-test/LICENSE +0 -674
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/lib/ds-test/Makefile +0 -14
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/lib/ds-test/default.nix +0 -4
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/lib/ds-test/demo/demo.sol +0 -222
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/lib/ds-test/package.json +0 -15
- package/lib/openzeppelin-contracts-upgradeable/lib/forge-std/lib/ds-test/src/test.sol +0 -469
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/CheckpointsMock.js +0 -80
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/EnumerableMapMock.js +0 -66
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/EnumerableSetMock.js +0 -56
- package/lib/openzeppelin-contracts-upgradeable/scripts/generate/templates/SafeCastMock.js +0 -50
- package/lib/openzeppelin-contracts-upgradeable/scripts/migrate-imports.js +0 -177
- package/lib/openzeppelin-contracts-upgradeable/scripts/prepare-contracts-package.sh +0 -15
- package/lib/openzeppelin-contracts-upgradeable/scripts/prepare.sh +0 -10
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/release.sh +0 -145
- package/lib/openzeppelin-contracts-upgradeable/scripts/release/update-changelog-release-date.js +0 -34
- package/lib/openzeppelin-contracts-upgradeable/scripts/upgradeable/merge-upstream.sh +0 -33
- package/lib/openzeppelin-contracts-upgradeable/scripts/upgradeable/patch/.gitkeep +0 -0
- package/lib/openzeppelin-contracts-upgradeable/test/access/AccessControlCrossChain.test.js +0 -59
- package/lib/openzeppelin-contracts-upgradeable/test/access/AccessControlEnumerable.test.js +0 -15
- package/lib/openzeppelin-contracts-upgradeable/test/crosschain/CrossChainEnabled.test.js +0 -88
- package/lib/openzeppelin-contracts-upgradeable/test/finance/PaymentSplitter.test.js +0 -217
- package/lib/openzeppelin-contracts-upgradeable/test/governance/compatibility/GovernorCompatibilityBravo.test.js +0 -265
- package/lib/openzeppelin-contracts-upgradeable/test/governance/extensions/GovernorComp.test.js +0 -78
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/create2.js +0 -12
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/crosschain.js +0 -63
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/customError.js +0 -24
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/erc1967.js +0 -24
- package/lib/openzeppelin-contracts-upgradeable/test/helpers/sign.js +0 -47
- package/lib/openzeppelin-contracts-upgradeable/test/metatx/MinimalForwarder.test.js +0 -184
- package/lib/openzeppelin-contracts-upgradeable/test/migrate-imports.test.js +0 -29
- package/lib/openzeppelin-contracts-upgradeable/test/security/Pausable.test.js +0 -89
- package/lib/openzeppelin-contracts-upgradeable/test/security/PullPayment.test.js +0 -51
- package/lib/openzeppelin-contracts-upgradeable/test/security/ReentrancyGuard.test.js +0 -40
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC1155/presets/ERC1155PresetMinterPauser.test.js +0 -146
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20Burnable.behavior.js +0 -109
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20Capped.behavior.js +0 -32
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20Snapshot.test.js +0 -204
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/ERC20VotesComp.test.js +0 -496
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/extensions/draft-ERC20Permit.test.js +0 -109
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/presets/ERC20PresetFixedSupply.test.js +0 -42
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/presets/ERC20PresetMinterPauser.test.js +0 -113
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC20/utils/TokenTimelock.test.js +0 -71
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC721/presets/ERC721PresetMinterPauserAutoId.test.js +0 -125
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC777/ERC777.behavior.js +0 -555
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC777/ERC777.test.js +0 -610
- package/lib/openzeppelin-contracts-upgradeable/test/token/ERC777/presets/ERC777PresetFixedSupply.test.js +0 -49
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Checkpoints.test.js +0 -189
- package/lib/openzeppelin-contracts-upgradeable/test/utils/Counters.test.js +0 -84
- package/lib/openzeppelin-contracts-upgradeable/test/utils/TimersBlockNumberImpl.test.js +0 -55
- package/lib/openzeppelin-contracts-upgradeable/test/utils/TimersTimestamp.test.js +0 -55
- package/lib/openzeppelin-contracts-upgradeable/test/utils/escrow/ConditionalEscrow.test.js +0 -36
- package/lib/openzeppelin-contracts-upgradeable/test/utils/escrow/Escrow.behavior.js +0 -94
- package/lib/openzeppelin-contracts-upgradeable/test/utils/escrow/Escrow.test.js +0 -14
- package/lib/openzeppelin-contracts-upgradeable/test/utils/escrow/RefundEscrow.test.js +0 -148
- package/lib/openzeppelin-contracts-upgradeable/test/utils/introspection/ERC165Storage.test.js +0 -25
- package/lib/openzeppelin-contracts-upgradeable/test/utils/introspection/ERC1820Implementer.test.js +0 -66
- package/lib/openzeppelin-contracts-upgradeable/test/utils/math/SafeMath.test.js +0 -403
- package/lib/openzeppelin-contracts-upgradeable/test/utils/math/SignedSafeMath.test.js +0 -152
- package/migrations/10_deploy_weth.js +0 -5
- package/migrations/11_deploy_full_flow.js +0 -99
- package/migrations/12_deploy_pm_v3_querier.js +0 -7
- package/migrations/13_deploy_pm_v3_factory.js +0 -14
- package/migrations/15_deploy_ppmm.js +0 -10
- package/migrations/16_deploy_raffle.js +0 -5
- package/migrations/1_initial_migration.js +0 -5
- package/migrations/2_deploy_erc20.js +0 -10
- package/migrations/3_deploy_realitio.js +0 -11
- package/migrations/4_deploy_pm.js +0 -20
- package/migrations/5_seed_markets.js +0 -51
- package/migrations/6_deploy_achievements.js +0 -5
- package/migrations/7_deploy_voting.js +0 -14
- package/migrations/8_deploy_pm_v2.js +0 -20
- package/migrations/9_seed_markets_v2.js +0 -68
- package/tests/PPMMarketContract.js +0 -340
- package/tests/fantasyERC20Contract.js +0 -225
- package/tests/getAverageOutcomeBuyPrice.test.ts +0 -179
- package/tests/index.js +0 -10
- package/tests/predictionMarketContract.js +0 -466
- package/tests/predictionMarketV2Contract.js +0 -1042
- package/tests/predictionMarketV3Contract.js +0 -1079
- package/tests/predictionMarketV3ControllerContract.js +0 -613
- package/tests/predictionMarketV3FactoryContract.js +0 -469
- package/tests/predictionMarketV3ManagerContract.js +0 -610
- package/tests/utils.js +0 -16
- package/tests/votingContract.js +0 -490
- package/truffle-config.js +0 -134
- package/zkout/AccessControl.sol/AccessControl.json +0 -1
- package/zkout/AccessControlEnumerable.sol/AccessControlEnumerable.json +0 -1
- package/zkout/Address.sol/Address.json +0 -1
- package/zkout/Clones.sol/Clones.json +0 -1
- package/zkout/Context.sol/Context.json +0 -1
- package/zkout/ERC165.sol/ERC165.json +0 -1
- package/zkout/ERC20.sol/ERC20.json +0 -1
- package/zkout/ERC20Burnable.sol/ERC20Burnable.json +0 -1
- package/zkout/ERC20Pausable.sol/ERC20Pausable.json +0 -1
- package/zkout/ERC20PresetMinterPauser.sol/ERC20PresetMinterPauser.json +0 -1
- package/zkout/EnumerableSet.sol/EnumerableSet.json +0 -1
- package/zkout/FantasyERC20.sol/FantasyERC20.json +0 -1
- package/zkout/IAccessControl.sol/IAccessControl.json +0 -1
- package/zkout/IAccessControlEnumerable.sol/IAccessControlEnumerable.json +0 -1
- package/zkout/IERC165.sol/IERC165.json +0 -1
- package/zkout/IERC20.sol/IERC20.json +0 -1
- package/zkout/IERC20Metadata.sol/IERC20Metadata.json +0 -1
- package/zkout/IFantasyERC20.sol/IFantasyERC20.json +0 -1
- package/zkout/IPredictionMarketV3.sol/IPredictionMarketV3.json +0 -1
- package/zkout/IPredictionMarketV3Factory.sol/IPredictionMarketV3Factory.json +0 -1
- package/zkout/IPredictionMarketV3Manager.sol/IPredictionMarketV3Manager.json +0 -1
- package/zkout/IRealityETH_ERC20.sol/IRealityETH_ERC20.json +0 -1
- package/zkout/LandFactory.sol/LandFactory.json +0 -1
- package/zkout/Math.sol/Math.json +0 -1
- package/zkout/Migrations.sol/Migrations.json +0 -1
- package/zkout/Ownable.sol/Ownable.json +0 -1
- package/zkout/Pausable.sol/Pausable.json +0 -1
- package/zkout/PredictionMarketV3.sol/CeilDiv.json +0 -1
- package/zkout/PredictionMarketV3.sol/IWETH.json +0 -1
- package/zkout/PredictionMarketV3.sol/PredictionMarketV3.json +0 -1
- package/zkout/PredictionMarketV3Controller.sol/PredictionMarketV3Controller.json +0 -1
- package/zkout/PredictionMarketV3Factory.sol/PredictionMarketV3Factory.json +0 -1
- package/zkout/PredictionMarketV3Manager.sol/PredictionMarketV3Manager.json +0 -1
- package/zkout/PredictionMarketV3Querier.sol/PredictionMarketV3Querier.json +0 -1
- package/zkout/Proxy.sol/Proxy.json +0 -1
- package/zkout/RealityETH_ERC20_Factory.sol/IRealityETH_IERC20.json +0 -1
- package/zkout/RealityETH_ERC20_Factory.sol/RealityETH_ERC20_Factory.json +0 -1
- package/zkout/RealityETH_ERC20_v3_0.sol/RealityETH_ERC20_v3_0_.json +0 -1
- package/zkout/ReentrancyGuard.sol/ReentrancyGuard.json +0 -1
- package/zkout/SafeERC20.sol/SafeERC20.json +0 -1
- package/zkout/SafeMath.sol/SafeMath.json +0 -1
- package/zkout/Strings.sol/Strings.json +0 -1
- package/zkout/USDCERC20.sol/USDCERC20.json +0 -1
- package/zkout/Voting.sol/Voting.json +0 -1
- package/zkout/build-info/0fa499f04838f8c1f593bcbafd0fd1a5.json +0 -1
- package/zkout/build-info/39c03363a71a9805ec8ec63c81a8aaaf.json +0 -1
- package/zkout/build-info/637aa7b0942c0ead878e36bd5d598008.json +0 -1
- package/zkout/build-info/810ab68b6fb1e3386ce5a111c7eb136f.json +0 -1
- package/zkout/build-info/aec05d9534229710b5b5f567c42384a1.json +0 -1
- package/zkout/build-info/cdd531656c4131c11667647afa1b2cca.json +0 -1
- package/zkout/build-info/e702288987d16a0b64efe75b321dfb8a.json +0 -1
- package/zkout/build-info/eccbfbbf7a8a18e02ebf05d3b7c6eea8.json +0 -1
- package/zkout/contracts/BalanceHolder_ERC20.sol/BalanceHolder_ERC20.json +0 -1
- package/zkout/contracts/IBalanceHolder_ERC20.sol/IBalanceHolder_ERC20.json +0 -1
- package/zkout/contracts/RealityETH_ERC20-3.0.sol/RealityETH_ERC20_v3_0.json +0 -1
- package/zkout/development/contracts/IERC20.sol/IERC20.json +0 -1
- package/zkout/draft-IERC20Permit.sol/IERC20Permit.json +0 -1
- /package/{build/contracts → abis}/AccessControlEnumerable.json +0 -0
- /package/{build/contracts → abis}/Achievements.json +0 -0
- /package/{build/contracts → abis}/BalanceHolder.json +0 -0
- /package/{build/contracts → abis}/Counters.json +0 -0
- /package/{build/contracts → abis}/ERC20PresetMinterPauser.json +0 -0
- /package/{build/contracts → abis}/ERC721.json +0 -0
- /package/{build/contracts → abis}/EnumerableMap.json +0 -0
- /package/{build/contracts → abis}/EnumerableSet.json +0 -0
- /package/{build/contracts → abis}/IAccessControlEnumerable.json +0 -0
- /package/{build/contracts → abis}/IERC20Permit.json +0 -0
- /package/{build/contracts → abis}/IERC721Receiver.json +0 -0
- /package/{build/contracts → abis}/IPredictionMarketV3.json +0 -0
- /package/{build/contracts → abis}/Math.json +0 -0
- /package/{build/contracts → abis}/Migrations.json +0 -0
- /package/{build/contracts → abis}/PredictionMarket.json +0 -0
- /package/{build/contracts → abis}/PredictionMarketV2.json +0 -0
- /package/{build/contracts → abis}/PredictionMarketV3.json +0 -0
- /package/{build/contracts → abis}/RealitioERC20.json +0 -0
- /package/{build/contracts → abis}/RealitioForeignArbitrationProxyWithAppeals.json +0 -0
- /package/{build/contracts → abis}/RealitioHomeArbitrationProxy.json +0 -0
- /package/{build/contracts → abis}/RealitioSafeMath256.json +0 -0
- /package/{build/contracts → abis}/RealitioSafeMath32.json +0 -0
- /package/{build/contracts → abis}/SafeMath.json +0 -0
- /package/{build/contracts → abis}/Strings.json +0 -0
- /package/{build/contracts → abis}/WETH9.json +0 -0
- /package/lib/openzeppelin-contracts-upgradeable/{audit → audits}/2018-10.pdf +0 -0
- /package/lib/openzeppelin-contracts-upgradeable/{DOCUMENTATION.md → docs/README.md} +0 -0
- /package/lib/openzeppelin-contracts-upgradeable/{.github → lib/openzeppelin-contracts/.github}/ISSUE_TEMPLATE/feature_request.md +0 -0
- /package/lib/{openzeppelin-contracts/audit → openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/audits}/2018-10.pdf +0 -0
- /package/lib/{openzeppelin-contracts/DOCUMENTATION.md → openzeppelin-contracts-upgradeable/lib/openzeppelin-contracts/docs/README.md} +0 -0
- /package/lib/openzeppelin-contracts-upgradeable/{scripts/upgradeable → lib/openzeppelin-contracts/scripts}/git-user-config.sh +0 -0
|
@@ -1,54 +1,57 @@
|
|
|
1
1
|
// SPDX-License-Identifier: MIT
|
|
2
|
-
// OpenZeppelin Contracts (last updated
|
|
3
|
-
|
|
4
|
-
pragma solidity ^0.8.
|
|
5
|
-
|
|
6
|
-
import "../token/ERC721/IERC721Receiver.sol";
|
|
7
|
-
import "../token/ERC1155/IERC1155Receiver.sol";
|
|
8
|
-
import "../utils/cryptography/
|
|
9
|
-
import "../utils/cryptography/
|
|
10
|
-
import "../utils/introspection/ERC165.sol";
|
|
11
|
-
import "../utils/math/SafeCast.sol";
|
|
12
|
-
import "../utils/structs/DoubleEndedQueue.sol";
|
|
13
|
-
import "../utils/Address.sol";
|
|
14
|
-
import "../utils/Context.sol";
|
|
15
|
-
import "../utils/
|
|
16
|
-
import "
|
|
2
|
+
// OpenZeppelin Contracts (last updated v5.3.0) (governance/Governor.sol)
|
|
3
|
+
|
|
4
|
+
pragma solidity ^0.8.24;
|
|
5
|
+
|
|
6
|
+
import {IERC721Receiver} from "../token/ERC721/IERC721Receiver.sol";
|
|
7
|
+
import {IERC1155Receiver} from "../token/ERC1155/IERC1155Receiver.sol";
|
|
8
|
+
import {EIP712} from "../utils/cryptography/EIP712.sol";
|
|
9
|
+
import {SignatureChecker} from "../utils/cryptography/SignatureChecker.sol";
|
|
10
|
+
import {IERC165, ERC165} from "../utils/introspection/ERC165.sol";
|
|
11
|
+
import {SafeCast} from "../utils/math/SafeCast.sol";
|
|
12
|
+
import {DoubleEndedQueue} from "../utils/structs/DoubleEndedQueue.sol";
|
|
13
|
+
import {Address} from "../utils/Address.sol";
|
|
14
|
+
import {Context} from "../utils/Context.sol";
|
|
15
|
+
import {Nonces} from "../utils/Nonces.sol";
|
|
16
|
+
import {Strings} from "../utils/Strings.sol";
|
|
17
|
+
import {IGovernor, IERC6372} from "./IGovernor.sol";
|
|
17
18
|
|
|
18
19
|
/**
|
|
19
|
-
* @dev Core of the governance system, designed to be extended
|
|
20
|
+
* @dev Core of the governance system, designed to be extended through various modules.
|
|
20
21
|
*
|
|
21
|
-
* This contract is abstract and requires several
|
|
22
|
+
* This contract is abstract and requires several functions to be implemented in various modules:
|
|
22
23
|
*
|
|
23
|
-
* - A counting module must implement {
|
|
24
|
+
* - A counting module must implement {_quorumReached}, {_voteSucceeded} and {_countVote}
|
|
24
25
|
* - A voting module must implement {_getVotes}
|
|
25
|
-
* -
|
|
26
|
-
*
|
|
27
|
-
* _Available since v4.3._
|
|
26
|
+
* - Additionally, {votingPeriod}, {votingDelay}, and {quorum} must also be implemented
|
|
28
27
|
*/
|
|
29
|
-
abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receiver, IERC1155Receiver {
|
|
28
|
+
abstract contract Governor is Context, ERC165, EIP712, Nonces, IGovernor, IERC721Receiver, IERC1155Receiver {
|
|
30
29
|
using DoubleEndedQueue for DoubleEndedQueue.Bytes32Deque;
|
|
31
|
-
using SafeCast for uint256;
|
|
32
|
-
using Timers for Timers.BlockNumber;
|
|
33
30
|
|
|
34
|
-
bytes32 public constant BALLOT_TYPEHASH =
|
|
31
|
+
bytes32 public constant BALLOT_TYPEHASH =
|
|
32
|
+
keccak256("Ballot(uint256 proposalId,uint8 support,address voter,uint256 nonce)");
|
|
35
33
|
bytes32 public constant EXTENDED_BALLOT_TYPEHASH =
|
|
36
|
-
keccak256(
|
|
34
|
+
keccak256(
|
|
35
|
+
"ExtendedBallot(uint256 proposalId,uint8 support,address voter,uint256 nonce,string reason,bytes params)"
|
|
36
|
+
);
|
|
37
37
|
|
|
38
38
|
struct ProposalCore {
|
|
39
|
-
|
|
40
|
-
|
|
39
|
+
address proposer;
|
|
40
|
+
uint48 voteStart;
|
|
41
|
+
uint32 voteDuration;
|
|
41
42
|
bool executed;
|
|
42
43
|
bool canceled;
|
|
44
|
+
uint48 etaSeconds;
|
|
43
45
|
}
|
|
44
46
|
|
|
47
|
+
bytes32 private constant ALL_PROPOSAL_STATES_BITMAP = bytes32((2 ** (uint8(type(ProposalState).max) + 1)) - 1);
|
|
45
48
|
string private _name;
|
|
46
49
|
|
|
47
|
-
mapping(uint256 => ProposalCore) private _proposals;
|
|
50
|
+
mapping(uint256 proposalId => ProposalCore) private _proposals;
|
|
48
51
|
|
|
49
|
-
// This queue keeps track of the governor operating on itself. Calls to functions protected by the
|
|
50
|
-
//
|
|
51
|
-
//
|
|
52
|
+
// This queue keeps track of the governor operating on itself. Calls to functions protected by the {onlyGovernance}
|
|
53
|
+
// modifier needs to be whitelisted in this queue. Whitelisting is set in {execute}, consumed by the
|
|
54
|
+
// {onlyGovernance} modifier and eventually reset after {_executeOperations} completes. This ensures that the
|
|
52
55
|
// execution of {onlyGovernance} protected calls can only be achieved through successful proposals.
|
|
53
56
|
DoubleEndedQueue.Bytes32Deque private _governanceCall;
|
|
54
57
|
|
|
@@ -63,12 +66,7 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
63
66
|
* governance protocol (since v4.6).
|
|
64
67
|
*/
|
|
65
68
|
modifier onlyGovernance() {
|
|
66
|
-
|
|
67
|
-
if (_executor() != address(this)) {
|
|
68
|
-
bytes32 msgDataHash = keccak256(_msgData());
|
|
69
|
-
// loop until popping the expected operation - throw if deque is empty (operation not authorized)
|
|
70
|
-
while (_governanceCall.popFront() != msgDataHash) {}
|
|
71
|
-
}
|
|
69
|
+
_checkGovernance();
|
|
72
70
|
_;
|
|
73
71
|
}
|
|
74
72
|
|
|
@@ -83,37 +81,27 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
83
81
|
* @dev Function to receive ETH that will be handled by the governor (disabled if executor is a third party contract)
|
|
84
82
|
*/
|
|
85
83
|
receive() external payable virtual {
|
|
86
|
-
|
|
84
|
+
if (_executor() != address(this)) {
|
|
85
|
+
revert GovernorDisabledDeposit();
|
|
86
|
+
}
|
|
87
87
|
}
|
|
88
88
|
|
|
89
|
-
|
|
90
|
-
* @dev See {IERC165-supportsInterface}.
|
|
91
|
-
*/
|
|
89
|
+
/// @inheritdoc IERC165
|
|
92
90
|
function supportsInterface(bytes4 interfaceId) public view virtual override(IERC165, ERC165) returns (bool) {
|
|
93
|
-
// In addition to the current interfaceId, also support previous version of the interfaceId that did not
|
|
94
|
-
// include the castVoteWithReasonAndParams() function as standard
|
|
95
91
|
return
|
|
96
|
-
interfaceId ==
|
|
97
|
-
(type(IGovernor).interfaceId ^
|
|
98
|
-
this.castVoteWithReasonAndParams.selector ^
|
|
99
|
-
this.castVoteWithReasonAndParamsBySig.selector ^
|
|
100
|
-
this.getVotesWithParams.selector) ||
|
|
101
92
|
interfaceId == type(IGovernor).interfaceId ||
|
|
93
|
+
interfaceId == type(IGovernor).interfaceId ^ IGovernor.getProposalId.selector ||
|
|
102
94
|
interfaceId == type(IERC1155Receiver).interfaceId ||
|
|
103
95
|
super.supportsInterface(interfaceId);
|
|
104
96
|
}
|
|
105
97
|
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
*/
|
|
109
|
-
function name() public view virtual override returns (string memory) {
|
|
98
|
+
/// @inheritdoc IGovernor
|
|
99
|
+
function name() public view virtual returns (string memory) {
|
|
110
100
|
return _name;
|
|
111
101
|
}
|
|
112
102
|
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
*/
|
|
116
|
-
function version() public view virtual override returns (string memory) {
|
|
103
|
+
/// @inheritdoc IGovernor
|
|
104
|
+
function version() public view virtual returns (string memory) {
|
|
117
105
|
return "1";
|
|
118
106
|
}
|
|
119
107
|
|
|
@@ -135,66 +123,104 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
135
123
|
uint256[] memory values,
|
|
136
124
|
bytes[] memory calldatas,
|
|
137
125
|
bytes32 descriptionHash
|
|
138
|
-
) public pure virtual
|
|
126
|
+
) public pure virtual returns (uint256) {
|
|
139
127
|
return uint256(keccak256(abi.encode(targets, values, calldatas, descriptionHash)));
|
|
140
128
|
}
|
|
141
129
|
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
130
|
+
/// @inheritdoc IGovernor
|
|
131
|
+
function getProposalId(
|
|
132
|
+
address[] memory targets,
|
|
133
|
+
uint256[] memory values,
|
|
134
|
+
bytes[] memory calldatas,
|
|
135
|
+
bytes32 descriptionHash
|
|
136
|
+
) public view virtual returns (uint256) {
|
|
137
|
+
return hashProposal(targets, values, calldatas, descriptionHash);
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
/// @inheritdoc IGovernor
|
|
141
|
+
function state(uint256 proposalId) public view virtual returns (ProposalState) {
|
|
142
|
+
// We read the struct fields into the stack at once so Solidity emits a single SLOAD
|
|
146
143
|
ProposalCore storage proposal = _proposals[proposalId];
|
|
144
|
+
bool proposalExecuted = proposal.executed;
|
|
145
|
+
bool proposalCanceled = proposal.canceled;
|
|
147
146
|
|
|
148
|
-
if (
|
|
147
|
+
if (proposalExecuted) {
|
|
149
148
|
return ProposalState.Executed;
|
|
150
149
|
}
|
|
151
150
|
|
|
152
|
-
if (
|
|
151
|
+
if (proposalCanceled) {
|
|
153
152
|
return ProposalState.Canceled;
|
|
154
153
|
}
|
|
155
154
|
|
|
156
155
|
uint256 snapshot = proposalSnapshot(proposalId);
|
|
157
156
|
|
|
158
157
|
if (snapshot == 0) {
|
|
159
|
-
revert(
|
|
158
|
+
revert GovernorNonexistentProposal(proposalId);
|
|
160
159
|
}
|
|
161
160
|
|
|
162
|
-
|
|
161
|
+
uint256 currentTimepoint = clock();
|
|
162
|
+
|
|
163
|
+
if (snapshot >= currentTimepoint) {
|
|
163
164
|
return ProposalState.Pending;
|
|
164
165
|
}
|
|
165
166
|
|
|
166
167
|
uint256 deadline = proposalDeadline(proposalId);
|
|
167
168
|
|
|
168
|
-
if (deadline >=
|
|
169
|
+
if (deadline >= currentTimepoint) {
|
|
169
170
|
return ProposalState.Active;
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
if (
|
|
171
|
+
} else if (!_quorumReached(proposalId) || !_voteSucceeded(proposalId)) {
|
|
172
|
+
return ProposalState.Defeated;
|
|
173
|
+
} else if (proposalEta(proposalId) == 0) {
|
|
173
174
|
return ProposalState.Succeeded;
|
|
174
175
|
} else {
|
|
175
|
-
return ProposalState.
|
|
176
|
+
return ProposalState.Queued;
|
|
176
177
|
}
|
|
177
178
|
}
|
|
178
179
|
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
function proposalSnapshot(uint256 proposalId) public view virtual override returns (uint256) {
|
|
183
|
-
return _proposals[proposalId].voteStart.getDeadline();
|
|
180
|
+
/// @inheritdoc IGovernor
|
|
181
|
+
function proposalThreshold() public view virtual returns (uint256) {
|
|
182
|
+
return 0;
|
|
184
183
|
}
|
|
185
184
|
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
185
|
+
/// @inheritdoc IGovernor
|
|
186
|
+
function proposalSnapshot(uint256 proposalId) public view virtual returns (uint256) {
|
|
187
|
+
return _proposals[proposalId].voteStart;
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
/// @inheritdoc IGovernor
|
|
191
|
+
function proposalDeadline(uint256 proposalId) public view virtual returns (uint256) {
|
|
192
|
+
return _proposals[proposalId].voteStart + _proposals[proposalId].voteDuration;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
/// @inheritdoc IGovernor
|
|
196
|
+
function proposalProposer(uint256 proposalId) public view virtual returns (address) {
|
|
197
|
+
return _proposals[proposalId].proposer;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
/// @inheritdoc IGovernor
|
|
201
|
+
function proposalEta(uint256 proposalId) public view virtual returns (uint256) {
|
|
202
|
+
return _proposals[proposalId].etaSeconds;
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
/// @inheritdoc IGovernor
|
|
206
|
+
function proposalNeedsQueuing(uint256) public view virtual returns (bool) {
|
|
207
|
+
return false;
|
|
191
208
|
}
|
|
192
209
|
|
|
193
210
|
/**
|
|
194
|
-
* @dev
|
|
211
|
+
* @dev Reverts if the `msg.sender` is not the executor. In case the executor is not this contract
|
|
212
|
+
* itself, the function reverts if `msg.data` is not whitelisted as a result of an {execute}
|
|
213
|
+
* operation. See {onlyGovernance}.
|
|
195
214
|
*/
|
|
196
|
-
function
|
|
197
|
-
|
|
215
|
+
function _checkGovernance() internal virtual {
|
|
216
|
+
if (_executor() != _msgSender()) {
|
|
217
|
+
revert GovernorOnlyExecutor(_msgSender());
|
|
218
|
+
}
|
|
219
|
+
if (_executor() != address(this)) {
|
|
220
|
+
bytes32 msgDataHash = keccak256(_msgData());
|
|
221
|
+
// loop until popping the expected operation - throw if deque is empty (operation not authorized)
|
|
222
|
+
while (_governanceCall.popFront() != msgDataHash) {}
|
|
223
|
+
}
|
|
198
224
|
}
|
|
199
225
|
|
|
200
226
|
/**
|
|
@@ -208,13 +234,9 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
208
234
|
function _voteSucceeded(uint256 proposalId) internal view virtual returns (bool);
|
|
209
235
|
|
|
210
236
|
/**
|
|
211
|
-
* @dev Get the voting weight of `account` at a specific `
|
|
237
|
+
* @dev Get the voting weight of `account` at a specific `timepoint`, for a vote as described by `params`.
|
|
212
238
|
*/
|
|
213
|
-
function _getVotes(
|
|
214
|
-
address account,
|
|
215
|
-
uint256 blockNumber,
|
|
216
|
-
bytes memory params
|
|
217
|
-
) internal view virtual returns (uint256);
|
|
239
|
+
function _getVotes(address account, uint256 timepoint, bytes memory params) internal view virtual returns (uint256);
|
|
218
240
|
|
|
219
241
|
/**
|
|
220
242
|
* @dev Register a vote for `proposalId` by `account` with a given `support`, voting `weight` and voting `params`.
|
|
@@ -225,9 +247,16 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
225
247
|
uint256 proposalId,
|
|
226
248
|
address account,
|
|
227
249
|
uint8 support,
|
|
228
|
-
uint256
|
|
250
|
+
uint256 totalWeight,
|
|
229
251
|
bytes memory params
|
|
230
|
-
) internal virtual;
|
|
252
|
+
) internal virtual returns (uint256);
|
|
253
|
+
|
|
254
|
+
/**
|
|
255
|
+
* @dev Hook that should be called every time the tally for a proposal is updated.
|
|
256
|
+
*
|
|
257
|
+
* Note: This function must run successfully. Reverts will result in the bricking of governance
|
|
258
|
+
*/
|
|
259
|
+
function _tallyUpdated(uint256 proposalId) internal virtual {}
|
|
231
260
|
|
|
232
261
|
/**
|
|
233
262
|
* @dev Default additional encoded parameters used by castVote methods that don't include them
|
|
@@ -240,103 +269,141 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
240
269
|
}
|
|
241
270
|
|
|
242
271
|
/**
|
|
243
|
-
* @dev See {IGovernor-propose}.
|
|
272
|
+
* @dev See {IGovernor-propose}. This function has opt-in frontrunning protection, described in {_isValidDescriptionForProposer}.
|
|
244
273
|
*/
|
|
245
274
|
function propose(
|
|
246
275
|
address[] memory targets,
|
|
247
276
|
uint256[] memory values,
|
|
248
277
|
bytes[] memory calldatas,
|
|
249
278
|
string memory description
|
|
250
|
-
) public virtual
|
|
251
|
-
|
|
252
|
-
getVotes(_msgSender(), block.number - 1) >= proposalThreshold(),
|
|
253
|
-
"Governor: proposer votes below proposal threshold"
|
|
254
|
-
);
|
|
279
|
+
) public virtual returns (uint256) {
|
|
280
|
+
address proposer = _msgSender();
|
|
255
281
|
|
|
256
|
-
|
|
282
|
+
// check description restriction
|
|
283
|
+
if (!_isValidDescriptionForProposer(proposer, description)) {
|
|
284
|
+
revert GovernorRestrictedProposer(proposer);
|
|
285
|
+
}
|
|
257
286
|
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
287
|
+
// check proposal threshold
|
|
288
|
+
uint256 votesThreshold = proposalThreshold();
|
|
289
|
+
if (votesThreshold > 0) {
|
|
290
|
+
uint256 proposerVotes = getVotes(proposer, clock() - 1);
|
|
291
|
+
if (proposerVotes < votesThreshold) {
|
|
292
|
+
revert GovernorInsufficientProposerVotes(proposer, proposerVotes, votesThreshold);
|
|
293
|
+
}
|
|
294
|
+
}
|
|
261
295
|
|
|
262
|
-
|
|
263
|
-
|
|
296
|
+
return _propose(targets, values, calldatas, description, proposer);
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
/**
|
|
300
|
+
* @dev Internal propose mechanism. Can be overridden to add more logic on proposal creation.
|
|
301
|
+
*
|
|
302
|
+
* Emits a {IGovernor-ProposalCreated} event.
|
|
303
|
+
*/
|
|
304
|
+
function _propose(
|
|
305
|
+
address[] memory targets,
|
|
306
|
+
uint256[] memory values,
|
|
307
|
+
bytes[] memory calldatas,
|
|
308
|
+
string memory description,
|
|
309
|
+
address proposer
|
|
310
|
+
) internal virtual returns (uint256 proposalId) {
|
|
311
|
+
proposalId = getProposalId(targets, values, calldatas, keccak256(bytes(description)));
|
|
264
312
|
|
|
265
|
-
|
|
266
|
-
|
|
313
|
+
if (targets.length != values.length || targets.length != calldatas.length || targets.length == 0) {
|
|
314
|
+
revert GovernorInvalidProposalLength(targets.length, calldatas.length, values.length);
|
|
315
|
+
}
|
|
316
|
+
if (_proposals[proposalId].voteStart != 0) {
|
|
317
|
+
revert GovernorUnexpectedProposalState(proposalId, state(proposalId), bytes32(0));
|
|
318
|
+
}
|
|
267
319
|
|
|
268
|
-
|
|
269
|
-
|
|
320
|
+
uint256 snapshot = clock() + votingDelay();
|
|
321
|
+
uint256 duration = votingPeriod();
|
|
322
|
+
|
|
323
|
+
ProposalCore storage proposal = _proposals[proposalId];
|
|
324
|
+
proposal.proposer = proposer;
|
|
325
|
+
proposal.voteStart = SafeCast.toUint48(snapshot);
|
|
326
|
+
proposal.voteDuration = SafeCast.toUint32(duration);
|
|
270
327
|
|
|
271
328
|
emit ProposalCreated(
|
|
272
329
|
proposalId,
|
|
273
|
-
|
|
330
|
+
proposer,
|
|
274
331
|
targets,
|
|
275
332
|
values,
|
|
276
333
|
new string[](targets.length),
|
|
277
334
|
calldatas,
|
|
278
335
|
snapshot,
|
|
279
|
-
|
|
336
|
+
snapshot + duration,
|
|
280
337
|
description
|
|
281
338
|
);
|
|
282
339
|
|
|
283
|
-
return
|
|
340
|
+
// Using a named return variable to avoid stack too deep errors
|
|
284
341
|
}
|
|
285
342
|
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
*/
|
|
289
|
-
function execute(
|
|
343
|
+
/// @inheritdoc IGovernor
|
|
344
|
+
function queue(
|
|
290
345
|
address[] memory targets,
|
|
291
346
|
uint256[] memory values,
|
|
292
347
|
bytes[] memory calldatas,
|
|
293
348
|
bytes32 descriptionHash
|
|
294
|
-
) public
|
|
295
|
-
uint256 proposalId =
|
|
349
|
+
) public virtual returns (uint256) {
|
|
350
|
+
uint256 proposalId = getProposalId(targets, values, calldatas, descriptionHash);
|
|
296
351
|
|
|
297
|
-
|
|
298
|
-
require(
|
|
299
|
-
status == ProposalState.Succeeded || status == ProposalState.Queued,
|
|
300
|
-
"Governor: proposal not successful"
|
|
301
|
-
);
|
|
302
|
-
_proposals[proposalId].executed = true;
|
|
352
|
+
_validateStateBitmap(proposalId, _encodeStateBitmap(ProposalState.Succeeded));
|
|
303
353
|
|
|
304
|
-
|
|
354
|
+
uint48 etaSeconds = _queueOperations(proposalId, targets, values, calldatas, descriptionHash);
|
|
305
355
|
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
356
|
+
if (etaSeconds != 0) {
|
|
357
|
+
_proposals[proposalId].etaSeconds = etaSeconds;
|
|
358
|
+
emit ProposalQueued(proposalId, etaSeconds);
|
|
359
|
+
} else {
|
|
360
|
+
revert GovernorQueueNotImplemented();
|
|
361
|
+
}
|
|
309
362
|
|
|
310
363
|
return proposalId;
|
|
311
364
|
}
|
|
312
365
|
|
|
313
366
|
/**
|
|
314
|
-
* @dev Internal
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
367
|
+
* @dev Internal queuing mechanism. Can be overridden (without a super call) to modify the way queuing is
|
|
368
|
+
* performed (for example adding a vault/timelock).
|
|
369
|
+
*
|
|
370
|
+
* This is empty by default, and must be overridden to implement queuing.
|
|
371
|
+
*
|
|
372
|
+
* This function returns a timestamp that describes the expected ETA for execution. If the returned value is 0
|
|
373
|
+
* (which is the default value), the core will consider queueing did not succeed, and the public {queue} function
|
|
374
|
+
* will revert.
|
|
375
|
+
*
|
|
376
|
+
* NOTE: Calling this function directly will NOT check the current state of the proposal, or emit the
|
|
377
|
+
* `ProposalQueued` event. Queuing a proposal should be done using {queue}.
|
|
378
|
+
*/
|
|
379
|
+
function _queueOperations(
|
|
380
|
+
uint256 /*proposalId*/,
|
|
381
|
+
address[] memory /*targets*/,
|
|
382
|
+
uint256[] memory /*values*/,
|
|
383
|
+
bytes[] memory /*calldatas*/,
|
|
321
384
|
bytes32 /*descriptionHash*/
|
|
322
|
-
) internal virtual {
|
|
323
|
-
|
|
324
|
-
for (uint256 i = 0; i < targets.length; ++i) {
|
|
325
|
-
(bool success, bytes memory returndata) = targets[i].call{value: values[i]}(calldatas[i]);
|
|
326
|
-
Address.verifyCallResult(success, returndata, errorMessage);
|
|
327
|
-
}
|
|
385
|
+
) internal virtual returns (uint48) {
|
|
386
|
+
return 0;
|
|
328
387
|
}
|
|
329
388
|
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
*/
|
|
333
|
-
function _beforeExecute(
|
|
334
|
-
uint256, /* proposalId */
|
|
389
|
+
/// @inheritdoc IGovernor
|
|
390
|
+
function execute(
|
|
335
391
|
address[] memory targets,
|
|
336
|
-
uint256[] memory
|
|
392
|
+
uint256[] memory values,
|
|
337
393
|
bytes[] memory calldatas,
|
|
338
|
-
bytes32
|
|
339
|
-
)
|
|
394
|
+
bytes32 descriptionHash
|
|
395
|
+
) public payable virtual returns (uint256) {
|
|
396
|
+
uint256 proposalId = getProposalId(targets, values, calldatas, descriptionHash);
|
|
397
|
+
|
|
398
|
+
_validateStateBitmap(
|
|
399
|
+
proposalId,
|
|
400
|
+
_encodeStateBitmap(ProposalState.Succeeded) | _encodeStateBitmap(ProposalState.Queued)
|
|
401
|
+
);
|
|
402
|
+
|
|
403
|
+
// mark as executed before calls to avoid reentrancy
|
|
404
|
+
_proposals[proposalId].executed = true;
|
|
405
|
+
|
|
406
|
+
// before execute: register governance call in queue.
|
|
340
407
|
if (_executor() != address(this)) {
|
|
341
408
|
for (uint256 i = 0; i < targets.length; ++i) {
|
|
342
409
|
if (targets[i] == address(this)) {
|
|
@@ -344,28 +411,60 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
344
411
|
}
|
|
345
412
|
}
|
|
346
413
|
}
|
|
414
|
+
|
|
415
|
+
_executeOperations(proposalId, targets, values, calldatas, descriptionHash);
|
|
416
|
+
|
|
417
|
+
// after execute: cleanup governance call queue.
|
|
418
|
+
if (_executor() != address(this) && !_governanceCall.empty()) {
|
|
419
|
+
_governanceCall.clear();
|
|
420
|
+
}
|
|
421
|
+
|
|
422
|
+
emit ProposalExecuted(proposalId);
|
|
423
|
+
|
|
424
|
+
return proposalId;
|
|
347
425
|
}
|
|
348
426
|
|
|
349
427
|
/**
|
|
350
|
-
* @dev
|
|
428
|
+
* @dev Internal execution mechanism. Can be overridden (without a super call) to modify the way execution is
|
|
429
|
+
* performed (for example adding a vault/timelock).
|
|
430
|
+
*
|
|
431
|
+
* NOTE: Calling this function directly will NOT check the current state of the proposal, set the executed flag to
|
|
432
|
+
* true or emit the `ProposalExecuted` event. Executing a proposal should be done using {execute}.
|
|
351
433
|
*/
|
|
352
|
-
function
|
|
353
|
-
uint256
|
|
354
|
-
address[] memory
|
|
355
|
-
uint256[] memory
|
|
356
|
-
bytes[] memory
|
|
434
|
+
function _executeOperations(
|
|
435
|
+
uint256 /* proposalId */,
|
|
436
|
+
address[] memory targets,
|
|
437
|
+
uint256[] memory values,
|
|
438
|
+
bytes[] memory calldatas,
|
|
357
439
|
bytes32 /*descriptionHash*/
|
|
358
440
|
) internal virtual {
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
}
|
|
441
|
+
for (uint256 i = 0; i < targets.length; ++i) {
|
|
442
|
+
(bool success, bytes memory returndata) = targets[i].call{value: values[i]}(calldatas[i]);
|
|
443
|
+
Address.verifyCallResult(success, returndata);
|
|
363
444
|
}
|
|
364
445
|
}
|
|
365
446
|
|
|
447
|
+
/// @inheritdoc IGovernor
|
|
448
|
+
function cancel(
|
|
449
|
+
address[] memory targets,
|
|
450
|
+
uint256[] memory values,
|
|
451
|
+
bytes[] memory calldatas,
|
|
452
|
+
bytes32 descriptionHash
|
|
453
|
+
) public virtual returns (uint256) {
|
|
454
|
+
// The proposalId will be recomputed in the `_cancel` call further down. However we need the value before we
|
|
455
|
+
// do the internal call, because we need to check the proposal state BEFORE the internal `_cancel` call
|
|
456
|
+
// changes it. The `getProposalId` duplication has a cost that is limited, and that we accept.
|
|
457
|
+
uint256 proposalId = getProposalId(targets, values, calldatas, descriptionHash);
|
|
458
|
+
|
|
459
|
+
address caller = _msgSender();
|
|
460
|
+
if (!_validateCancel(proposalId, caller)) revert GovernorUnableToCancel(proposalId, caller);
|
|
461
|
+
|
|
462
|
+
return _cancel(targets, values, calldatas, descriptionHash);
|
|
463
|
+
}
|
|
464
|
+
|
|
366
465
|
/**
|
|
367
|
-
* @dev Internal cancel mechanism
|
|
368
|
-
*
|
|
466
|
+
* @dev Internal cancel mechanism with minimal restrictions. A proposal can be cancelled in any state other than
|
|
467
|
+
* Canceled, Expired, or Executed. Once cancelled a proposal can't be re-submitted.
|
|
369
468
|
*
|
|
370
469
|
* Emits a {IGovernor-ProposalCanceled} event.
|
|
371
470
|
*/
|
|
@@ -375,122 +474,135 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
375
474
|
bytes[] memory calldatas,
|
|
376
475
|
bytes32 descriptionHash
|
|
377
476
|
) internal virtual returns (uint256) {
|
|
378
|
-
uint256 proposalId =
|
|
379
|
-
ProposalState status = state(proposalId);
|
|
477
|
+
uint256 proposalId = getProposalId(targets, values, calldatas, descriptionHash);
|
|
380
478
|
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
479
|
+
_validateStateBitmap(
|
|
480
|
+
proposalId,
|
|
481
|
+
ALL_PROPOSAL_STATES_BITMAP ^
|
|
482
|
+
_encodeStateBitmap(ProposalState.Canceled) ^
|
|
483
|
+
_encodeStateBitmap(ProposalState.Expired) ^
|
|
484
|
+
_encodeStateBitmap(ProposalState.Executed)
|
|
384
485
|
);
|
|
385
|
-
_proposals[proposalId].canceled = true;
|
|
386
486
|
|
|
487
|
+
_proposals[proposalId].canceled = true;
|
|
387
488
|
emit ProposalCanceled(proposalId);
|
|
388
489
|
|
|
389
490
|
return proposalId;
|
|
390
491
|
}
|
|
391
492
|
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
function getVotes(address account, uint256 blockNumber) public view virtual override returns (uint256) {
|
|
396
|
-
return _getVotes(account, blockNumber, _defaultParams());
|
|
493
|
+
/// @inheritdoc IGovernor
|
|
494
|
+
function getVotes(address account, uint256 timepoint) public view virtual returns (uint256) {
|
|
495
|
+
return _getVotes(account, timepoint, _defaultParams());
|
|
397
496
|
}
|
|
398
497
|
|
|
399
|
-
|
|
400
|
-
* @dev See {IGovernor-getVotesWithParams}.
|
|
401
|
-
*/
|
|
498
|
+
/// @inheritdoc IGovernor
|
|
402
499
|
function getVotesWithParams(
|
|
403
500
|
address account,
|
|
404
|
-
uint256
|
|
501
|
+
uint256 timepoint,
|
|
405
502
|
bytes memory params
|
|
406
|
-
) public view virtual
|
|
407
|
-
return _getVotes(account,
|
|
503
|
+
) public view virtual returns (uint256) {
|
|
504
|
+
return _getVotes(account, timepoint, params);
|
|
408
505
|
}
|
|
409
506
|
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
*/
|
|
413
|
-
function castVote(uint256 proposalId, uint8 support) public virtual override returns (uint256) {
|
|
507
|
+
/// @inheritdoc IGovernor
|
|
508
|
+
function castVote(uint256 proposalId, uint8 support) public virtual returns (uint256) {
|
|
414
509
|
address voter = _msgSender();
|
|
415
510
|
return _castVote(proposalId, voter, support, "");
|
|
416
511
|
}
|
|
417
512
|
|
|
418
|
-
|
|
419
|
-
* @dev See {IGovernor-castVoteWithReason}.
|
|
420
|
-
*/
|
|
513
|
+
/// @inheritdoc IGovernor
|
|
421
514
|
function castVoteWithReason(
|
|
422
515
|
uint256 proposalId,
|
|
423
516
|
uint8 support,
|
|
424
517
|
string calldata reason
|
|
425
|
-
) public virtual
|
|
518
|
+
) public virtual returns (uint256) {
|
|
426
519
|
address voter = _msgSender();
|
|
427
520
|
return _castVote(proposalId, voter, support, reason);
|
|
428
521
|
}
|
|
429
522
|
|
|
430
|
-
|
|
431
|
-
* @dev See {IGovernor-castVoteWithReasonAndParams}.
|
|
432
|
-
*/
|
|
523
|
+
/// @inheritdoc IGovernor
|
|
433
524
|
function castVoteWithReasonAndParams(
|
|
434
525
|
uint256 proposalId,
|
|
435
526
|
uint8 support,
|
|
436
527
|
string calldata reason,
|
|
437
528
|
bytes memory params
|
|
438
|
-
) public virtual
|
|
529
|
+
) public virtual returns (uint256) {
|
|
439
530
|
address voter = _msgSender();
|
|
440
531
|
return _castVote(proposalId, voter, support, reason, params);
|
|
441
532
|
}
|
|
442
533
|
|
|
443
|
-
|
|
444
|
-
* @dev See {IGovernor-castVoteBySig}.
|
|
445
|
-
*/
|
|
534
|
+
/// @inheritdoc IGovernor
|
|
446
535
|
function castVoteBySig(
|
|
447
536
|
uint256 proposalId,
|
|
448
537
|
uint8 support,
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
v,
|
|
456
|
-
r,
|
|
457
|
-
s
|
|
458
|
-
);
|
|
538
|
+
address voter,
|
|
539
|
+
bytes memory signature
|
|
540
|
+
) public virtual returns (uint256) {
|
|
541
|
+
if (!_validateVoteSig(proposalId, support, voter, signature)) {
|
|
542
|
+
revert GovernorInvalidSignature(voter);
|
|
543
|
+
}
|
|
459
544
|
return _castVote(proposalId, voter, support, "");
|
|
460
545
|
}
|
|
461
546
|
|
|
462
|
-
|
|
463
|
-
* @dev See {IGovernor-castVoteWithReasonAndParamsBySig}.
|
|
464
|
-
*/
|
|
547
|
+
/// @inheritdoc IGovernor
|
|
465
548
|
function castVoteWithReasonAndParamsBySig(
|
|
466
549
|
uint256 proposalId,
|
|
467
550
|
uint8 support,
|
|
551
|
+
address voter,
|
|
468
552
|
string calldata reason,
|
|
469
553
|
bytes memory params,
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
_hashTypedDataV4(
|
|
476
|
-
keccak256(
|
|
477
|
-
abi.encode(
|
|
478
|
-
EXTENDED_BALLOT_TYPEHASH,
|
|
479
|
-
proposalId,
|
|
480
|
-
support,
|
|
481
|
-
keccak256(bytes(reason)),
|
|
482
|
-
keccak256(params)
|
|
483
|
-
)
|
|
484
|
-
)
|
|
485
|
-
),
|
|
486
|
-
v,
|
|
487
|
-
r,
|
|
488
|
-
s
|
|
489
|
-
);
|
|
490
|
-
|
|
554
|
+
bytes memory signature
|
|
555
|
+
) public virtual returns (uint256) {
|
|
556
|
+
if (!_validateExtendedVoteSig(proposalId, support, voter, reason, params, signature)) {
|
|
557
|
+
revert GovernorInvalidSignature(voter);
|
|
558
|
+
}
|
|
491
559
|
return _castVote(proposalId, voter, support, reason, params);
|
|
492
560
|
}
|
|
493
561
|
|
|
562
|
+
/// @dev Validate the `signature` used in {castVoteBySig} function.
|
|
563
|
+
function _validateVoteSig(
|
|
564
|
+
uint256 proposalId,
|
|
565
|
+
uint8 support,
|
|
566
|
+
address voter,
|
|
567
|
+
bytes memory signature
|
|
568
|
+
) internal virtual returns (bool) {
|
|
569
|
+
return
|
|
570
|
+
SignatureChecker.isValidSignatureNow(
|
|
571
|
+
voter,
|
|
572
|
+
_hashTypedDataV4(keccak256(abi.encode(BALLOT_TYPEHASH, proposalId, support, voter, _useNonce(voter)))),
|
|
573
|
+
signature
|
|
574
|
+
);
|
|
575
|
+
}
|
|
576
|
+
|
|
577
|
+
/// @dev Validate the `signature` used in {castVoteWithReasonAndParamsBySig} function.
|
|
578
|
+
function _validateExtendedVoteSig(
|
|
579
|
+
uint256 proposalId,
|
|
580
|
+
uint8 support,
|
|
581
|
+
address voter,
|
|
582
|
+
string memory reason,
|
|
583
|
+
bytes memory params,
|
|
584
|
+
bytes memory signature
|
|
585
|
+
) internal virtual returns (bool) {
|
|
586
|
+
return
|
|
587
|
+
SignatureChecker.isValidSignatureNow(
|
|
588
|
+
voter,
|
|
589
|
+
_hashTypedDataV4(
|
|
590
|
+
keccak256(
|
|
591
|
+
abi.encode(
|
|
592
|
+
EXTENDED_BALLOT_TYPEHASH,
|
|
593
|
+
proposalId,
|
|
594
|
+
support,
|
|
595
|
+
voter,
|
|
596
|
+
_useNonce(voter),
|
|
597
|
+
keccak256(bytes(reason)),
|
|
598
|
+
keccak256(params)
|
|
599
|
+
)
|
|
600
|
+
)
|
|
601
|
+
),
|
|
602
|
+
signature
|
|
603
|
+
);
|
|
604
|
+
}
|
|
605
|
+
|
|
494
606
|
/**
|
|
495
607
|
* @dev Internal vote casting mechanism: Check that the vote is pending, that it has not been cast yet, retrieve
|
|
496
608
|
* voting weight using {IGovernor-getVotes} and call the {_countVote} internal function. Uses the _defaultParams().
|
|
@@ -519,19 +631,20 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
519
631
|
string memory reason,
|
|
520
632
|
bytes memory params
|
|
521
633
|
) internal virtual returns (uint256) {
|
|
522
|
-
|
|
523
|
-
require(state(proposalId) == ProposalState.Active, "Governor: vote not currently active");
|
|
634
|
+
_validateStateBitmap(proposalId, _encodeStateBitmap(ProposalState.Active));
|
|
524
635
|
|
|
525
|
-
uint256
|
|
526
|
-
_countVote(proposalId, account, support,
|
|
636
|
+
uint256 totalWeight = _getVotes(account, proposalSnapshot(proposalId), params);
|
|
637
|
+
uint256 votedWeight = _countVote(proposalId, account, support, totalWeight, params);
|
|
527
638
|
|
|
528
639
|
if (params.length == 0) {
|
|
529
|
-
emit VoteCast(account, proposalId, support,
|
|
640
|
+
emit VoteCast(account, proposalId, support, votedWeight, reason);
|
|
530
641
|
} else {
|
|
531
|
-
emit VoteCastWithParams(account, proposalId, support,
|
|
642
|
+
emit VoteCastWithParams(account, proposalId, support, votedWeight, reason, params);
|
|
532
643
|
}
|
|
533
644
|
|
|
534
|
-
|
|
645
|
+
_tallyUpdated(proposalId);
|
|
646
|
+
|
|
647
|
+
return votedWeight;
|
|
535
648
|
}
|
|
536
649
|
|
|
537
650
|
/**
|
|
@@ -540,13 +653,9 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
540
653
|
* in a governance proposal to recover tokens or Ether that was sent to the governor contract by mistake.
|
|
541
654
|
* Note that if the executor is simply the governor itself, use of `relay` is redundant.
|
|
542
655
|
*/
|
|
543
|
-
function relay(
|
|
544
|
-
address target,
|
|
545
|
-
uint256 value,
|
|
546
|
-
bytes calldata data
|
|
547
|
-
) external payable virtual onlyGovernance {
|
|
656
|
+
function relay(address target, uint256 value, bytes calldata data) external payable virtual onlyGovernance {
|
|
548
657
|
(bool success, bytes memory returndata) = target.call{value: value}(data);
|
|
549
|
-
Address.verifyCallResult(success, returndata
|
|
658
|
+
Address.verifyCallResult(success, returndata);
|
|
550
659
|
}
|
|
551
660
|
|
|
552
661
|
/**
|
|
@@ -559,31 +668,29 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
559
668
|
|
|
560
669
|
/**
|
|
561
670
|
* @dev See {IERC721Receiver-onERC721Received}.
|
|
671
|
+
* Receiving tokens is disabled if the governance executor is other than the governor itself (eg. when using with a timelock).
|
|
562
672
|
*/
|
|
563
|
-
function onERC721Received(
|
|
564
|
-
address
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
bytes memory
|
|
568
|
-
) public virtual override returns (bytes4) {
|
|
673
|
+
function onERC721Received(address, address, uint256, bytes memory) public virtual returns (bytes4) {
|
|
674
|
+
if (_executor() != address(this)) {
|
|
675
|
+
revert GovernorDisabledDeposit();
|
|
676
|
+
}
|
|
569
677
|
return this.onERC721Received.selector;
|
|
570
678
|
}
|
|
571
679
|
|
|
572
680
|
/**
|
|
573
681
|
* @dev See {IERC1155Receiver-onERC1155Received}.
|
|
682
|
+
* Receiving tokens is disabled if the governance executor is other than the governor itself (eg. when using with a timelock).
|
|
574
683
|
*/
|
|
575
|
-
function onERC1155Received(
|
|
576
|
-
address
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
uint256,
|
|
580
|
-
bytes memory
|
|
581
|
-
) public virtual override returns (bytes4) {
|
|
684
|
+
function onERC1155Received(address, address, uint256, uint256, bytes memory) public virtual returns (bytes4) {
|
|
685
|
+
if (_executor() != address(this)) {
|
|
686
|
+
revert GovernorDisabledDeposit();
|
|
687
|
+
}
|
|
582
688
|
return this.onERC1155Received.selector;
|
|
583
689
|
}
|
|
584
690
|
|
|
585
691
|
/**
|
|
586
692
|
* @dev See {IERC1155Receiver-onERC1155BatchReceived}.
|
|
693
|
+
* Receiving tokens is disabled if the governance executor is other than the governor itself (eg. when using with a timelock).
|
|
587
694
|
*/
|
|
588
695
|
function onERC1155BatchReceived(
|
|
589
696
|
address,
|
|
@@ -591,7 +698,121 @@ abstract contract Governor is Context, ERC165, EIP712, IGovernor, IERC721Receive
|
|
|
591
698
|
uint256[] memory,
|
|
592
699
|
uint256[] memory,
|
|
593
700
|
bytes memory
|
|
594
|
-
) public virtual
|
|
701
|
+
) public virtual returns (bytes4) {
|
|
702
|
+
if (_executor() != address(this)) {
|
|
703
|
+
revert GovernorDisabledDeposit();
|
|
704
|
+
}
|
|
595
705
|
return this.onERC1155BatchReceived.selector;
|
|
596
706
|
}
|
|
707
|
+
|
|
708
|
+
/**
|
|
709
|
+
* @dev Encodes a `ProposalState` into a `bytes32` representation where each bit enabled corresponds to
|
|
710
|
+
* the underlying position in the `ProposalState` enum. For example:
|
|
711
|
+
*
|
|
712
|
+
* 0x000...10000
|
|
713
|
+
* ^^^^^^------ ...
|
|
714
|
+
* ^----- Succeeded
|
|
715
|
+
* ^---- Defeated
|
|
716
|
+
* ^--- Canceled
|
|
717
|
+
* ^-- Active
|
|
718
|
+
* ^- Pending
|
|
719
|
+
*/
|
|
720
|
+
function _encodeStateBitmap(ProposalState proposalState) internal pure returns (bytes32) {
|
|
721
|
+
return bytes32(1 << uint8(proposalState));
|
|
722
|
+
}
|
|
723
|
+
|
|
724
|
+
/**
|
|
725
|
+
* @dev Check that the current state of a proposal matches the requirements described by the `allowedStates` bitmap.
|
|
726
|
+
* This bitmap should be built using `_encodeStateBitmap`.
|
|
727
|
+
*
|
|
728
|
+
* If requirements are not met, reverts with a {GovernorUnexpectedProposalState} error.
|
|
729
|
+
*/
|
|
730
|
+
function _validateStateBitmap(uint256 proposalId, bytes32 allowedStates) internal view returns (ProposalState) {
|
|
731
|
+
ProposalState currentState = state(proposalId);
|
|
732
|
+
if (_encodeStateBitmap(currentState) & allowedStates == bytes32(0)) {
|
|
733
|
+
revert GovernorUnexpectedProposalState(proposalId, currentState, allowedStates);
|
|
734
|
+
}
|
|
735
|
+
return currentState;
|
|
736
|
+
}
|
|
737
|
+
|
|
738
|
+
/*
|
|
739
|
+
* @dev Check if the proposer is authorized to submit a proposal with the given description.
|
|
740
|
+
*
|
|
741
|
+
* If the proposal description ends with `#proposer=0x???`, where `0x???` is an address written as a hex string
|
|
742
|
+
* (case insensitive), then the submission of this proposal will only be authorized to said address.
|
|
743
|
+
*
|
|
744
|
+
* This is used for frontrunning protection. By adding this pattern at the end of their proposal, one can ensure
|
|
745
|
+
* that no other address can submit the same proposal. An attacker would have to either remove or change that part,
|
|
746
|
+
* which would result in a different proposal id.
|
|
747
|
+
*
|
|
748
|
+
* If the description does not match this pattern, it is unrestricted and anyone can submit it. This includes:
|
|
749
|
+
* - If the `0x???` part is not a valid hex string.
|
|
750
|
+
* - If the `0x???` part is a valid hex string, but does not contain exactly 40 hex digits.
|
|
751
|
+
* - If it ends with the expected suffix followed by newlines or other whitespace.
|
|
752
|
+
* - If it ends with some other similar suffix, e.g. `#other=abc`.
|
|
753
|
+
* - If it does not end with any such suffix.
|
|
754
|
+
*/
|
|
755
|
+
function _isValidDescriptionForProposer(
|
|
756
|
+
address proposer,
|
|
757
|
+
string memory description
|
|
758
|
+
) internal view virtual returns (bool) {
|
|
759
|
+
unchecked {
|
|
760
|
+
uint256 length = bytes(description).length;
|
|
761
|
+
|
|
762
|
+
// Length is too short to contain a valid proposer suffix
|
|
763
|
+
if (length < 52) {
|
|
764
|
+
return true;
|
|
765
|
+
}
|
|
766
|
+
|
|
767
|
+
// Extract what would be the `#proposer=` marker beginning the suffix
|
|
768
|
+
bytes10 marker = bytes10(_unsafeReadBytesOffset(bytes(description), length - 52));
|
|
769
|
+
|
|
770
|
+
// If the marker is not found, there is no proposer suffix to check
|
|
771
|
+
if (marker != bytes10("#proposer=")) {
|
|
772
|
+
return true;
|
|
773
|
+
}
|
|
774
|
+
|
|
775
|
+
// Check that the last 42 characters (after the marker) are a properly formatted address.
|
|
776
|
+
(bool success, address recovered) = Strings.tryParseAddress(description, length - 42, length);
|
|
777
|
+
return !success || recovered == proposer;
|
|
778
|
+
}
|
|
779
|
+
}
|
|
780
|
+
|
|
781
|
+
/**
|
|
782
|
+
* @dev Check if the `caller` can cancel the proposal with the given `proposalId`.
|
|
783
|
+
*
|
|
784
|
+
* The default implementation allows the proposal proposer to cancel the proposal during the pending state.
|
|
785
|
+
*/
|
|
786
|
+
function _validateCancel(uint256 proposalId, address caller) internal view virtual returns (bool) {
|
|
787
|
+
return (state(proposalId) == ProposalState.Pending) && caller == proposalProposer(proposalId);
|
|
788
|
+
}
|
|
789
|
+
|
|
790
|
+
/// @inheritdoc IERC6372
|
|
791
|
+
function clock() public view virtual returns (uint48);
|
|
792
|
+
|
|
793
|
+
/// @inheritdoc IERC6372
|
|
794
|
+
// solhint-disable-next-line func-name-mixedcase
|
|
795
|
+
function CLOCK_MODE() public view virtual returns (string memory);
|
|
796
|
+
|
|
797
|
+
/// @inheritdoc IGovernor
|
|
798
|
+
function votingDelay() public view virtual returns (uint256);
|
|
799
|
+
|
|
800
|
+
/// @inheritdoc IGovernor
|
|
801
|
+
function votingPeriod() public view virtual returns (uint256);
|
|
802
|
+
|
|
803
|
+
/// @inheritdoc IGovernor
|
|
804
|
+
function quorum(uint256 timepoint) public view virtual returns (uint256);
|
|
805
|
+
|
|
806
|
+
/**
|
|
807
|
+
* @dev Reads a bytes32 from a bytes array without bounds checking.
|
|
808
|
+
*
|
|
809
|
+
* NOTE: making this function internal would mean it could be used with memory unsafe offset, and marking the
|
|
810
|
+
* assembly block as such would prevent some optimizations.
|
|
811
|
+
*/
|
|
812
|
+
function _unsafeReadBytesOffset(bytes memory buffer, uint256 offset) private pure returns (bytes32 value) {
|
|
813
|
+
// This is not memory safe in the general case, but all calls to this private function are within bounds.
|
|
814
|
+
assembly ("memory-safe") {
|
|
815
|
+
value := mload(add(add(buffer, 0x20), offset))
|
|
816
|
+
}
|
|
817
|
+
}
|
|
597
818
|
}
|