2023-05-21 13:21:59 -04:00
|
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
|
2023-05-21 15:51:14 -04:00
|
|
|
pragma solidity ^0.6.12;
|
2023-05-21 13:21:59 -04:00
|
|
|
pragma experimental ABIEncoderV2;
|
|
|
|
|
|
|
|
import "../v1/Governance.sol";
|
|
|
|
import "../v3-relayer-registry/GovernanceStakingUpgrade.sol";
|
|
|
|
|
2023-05-21 15:51:14 -04:00
|
|
|
contract GovernancePatchUpgrade is GovernanceStakingUpgrade {
|
|
|
|
mapping(uint256 => bytes32) public proposalCodehashes;
|
2023-05-21 13:21:59 -04:00
|
|
|
|
2023-05-21 15:51:14 -04:00
|
|
|
event CodehashDifferent(address target, bytes32 oldHash, bytes32 newHash);
|
|
|
|
|
|
|
|
// The stakingRewardsAddress sets the immutable to the new staking contract
|
|
|
|
constructor(
|
|
|
|
address stakingRewardsAddress,
|
|
|
|
address gasCompLogic,
|
|
|
|
address userVaultAddress
|
|
|
|
) public GovernanceStakingUpgrade(stakingRewardsAddress, gasCompLogic, userVaultAddress) {}
|
|
|
|
|
|
|
|
// This should guarantee that the proposal extcodehashes are good
|
|
|
|
function execute(uint256 proposalId) public payable virtual override(Governance) {
|
|
|
|
require(msg.sender != address(this), "pseudo-external function");
|
2023-05-21 13:21:59 -04:00
|
|
|
|
|
|
|
Proposal storage proposal = proposals[proposalId];
|
|
|
|
|
2023-05-21 15:51:14 -04:00
|
|
|
address target = proposal.target;
|
|
|
|
|
|
|
|
bytes32 proposalCodehash;
|
|
|
|
|
|
|
|
assembly {
|
|
|
|
proposalCodehash := extcodehash(target)
|
|
|
|
}
|
|
|
|
|
|
|
|
if (proposalCodehash == proposalCodehashes[proposalId]) {
|
2023-05-21 13:21:59 -04:00
|
|
|
super.execute(proposalId);
|
|
|
|
} else {
|
2023-05-22 14:23:39 -04:00
|
|
|
// So this should guarantee that the proposal should not be able to be executed in future
|
|
|
|
// But also, the proposal will be skipped each time. So the question is whether this, a silent
|
|
|
|
// skip, or a require can be used to stay "concise", and abandon the safety of having also this assign
|
|
|
|
// Outside dependencies, which don't exist as of yet, might believe that the proposal code was executed
|
2023-05-21 13:21:59 -04:00
|
|
|
proposal.executed = true;
|
2023-05-21 21:44:30 -04:00
|
|
|
|
2023-05-22 14:23:39 -04:00
|
|
|
// Let the event signify it was metamorphic
|
2023-05-21 21:44:30 -04:00
|
|
|
emit CodehashDifferent(target, proposalCodehashes[proposalId], proposalCodehash);
|
2023-05-21 13:21:59 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-05-21 15:51:14 -04:00
|
|
|
// This should store the proposal extcodehash
|
2023-05-21 13:21:59 -04:00
|
|
|
function _propose(
|
|
|
|
address proposer,
|
|
|
|
address target,
|
|
|
|
string memory description
|
2023-05-21 15:51:14 -04:00
|
|
|
) internal virtual override(Governance) returns (uint256 proposalId) {
|
|
|
|
// Implies all former predicates were valid
|
|
|
|
proposalId = super._propose(proposer, target, description);
|
|
|
|
|
|
|
|
bytes32 proposalCodehash;
|
|
|
|
|
|
|
|
assembly {
|
|
|
|
proposalCodehash := extcodehash(target)
|
|
|
|
}
|
|
|
|
|
|
|
|
proposalCodehashes[proposalId] = proposalCodehash;
|
2023-05-21 13:21:59 -04:00
|
|
|
}
|
|
|
|
}
|