From b66705d4ce7793d74563354d63677b3826fc4793 Mon Sep 17 00:00:00 2001 From: Josh Levine Date: Tue, 7 May 2024 16:29:55 -0700 Subject: [PATCH] chore: add double root push forge script function --- contracts/script/PointTokenVault.s.sol | 33 +++++++++++++++++++------- 1 file changed, 25 insertions(+), 8 deletions(-) diff --git a/contracts/script/PointTokenVault.s.sol b/contracts/script/PointTokenVault.s.sol index 9db5cc0..4059473 100644 --- a/contracts/script/PointTokenVault.s.sol +++ b/contracts/script/PointTokenVault.s.sol @@ -57,13 +57,15 @@ contract PointTokenVaultScripts is BatchScript { function run(string memory version) public returns (PointTokenVault) { PointTokenVault pointTokenVaultImplementation = new PointTokenVault{salt: keccak256(abi.encode(version))}(); - PointTokenVault pointTokenVault = PointTokenVault(payable( - address( - new ERC1967Proxy{salt: keccak256(abi.encode(version))}( - address(pointTokenVaultImplementation), - abi.encodeCall(PointTokenVault.initialize, (msg.sender)) // msg.sender is admin + PointTokenVault pointTokenVault = PointTokenVault( + payable( + address( + new ERC1967Proxy{salt: keccak256(abi.encode(version))}( + address(pointTokenVaultImplementation), + abi.encodeCall(PointTokenVault.initialize, (msg.sender)) // msg.sender is admin + ) ) - )) + ) ); return pointTokenVault; @@ -118,15 +120,30 @@ contract PointTokenVaultScripts is BatchScript { vm.stopBroadcast(); } + // Useful for emergencies, where we need to override both the current and previous root at once + // For example, if minting for a specific pToken needs to be stopped, a root without any claim rights for the pToken would need to be pushed twice + function doublePushRoot(address pointTokenVaultAddress, bytes32 newRoot, address merkleUpdaterSafe) public { + uint256 deployerPrivateKey = vm.envUint("PRIVATE_KEY"); + vm.startBroadcast(deployerPrivateKey); + + bytes memory txn = abi.encodeWithSelector(PointTokenVault.updateRoot.selector, newRoot); + addToBatch(pointTokenVaultAddress, 0, txn); + addToBatch(pointTokenVaultAddress, 0, txn); + + executeBatch(merkleUpdaterSafe, true); + + vm.stopBroadcast(); + } + function setCap() public { uint256 deployerPrivateKey = vm.envUint("PRIVATE_KEY"); vm.startBroadcast(deployerPrivateKey); - address pointTokenVault = 0xbff7Fb79efC49504afc97e74F83EE618768e63E9; + address pointTokenVaultAddress = 0xbff7Fb79efC49504afc97e74F83EE618768e63E9; bytes memory txn = abi.encodeWithSelector(PointTokenVault.setCap.selector, 0x791a051631c9c4cDf4E03Fb7Aec3163AE164A34B, 10e18); - addToBatch(pointTokenVault, 0, txn); + addToBatch(pointTokenVaultAddress, 0, txn); executeBatch(SEOPLIA_ADMIN_SAFE, true); vm.stopBroadcast();