setSubnodeOwner config & update params

This commit is contained in:
gozzy 2023-04-16 15:22:17 +00:00
parent 34e9ef1e39
commit ff7c62af24
3 changed files with 46 additions and 26 deletions

View File

@ -8,38 +8,44 @@ import "@interfaces/IENSRegistry.sol";
contract Proposal { contract Proposal {
function updateENSIPFSConfig() internal { function updateENSIPFSConfig() internal {
bytes32 CLASSIC_ENS_NODE = 0xe6ae31d630cc7a8279c0f1c7cbe6e7064814c47d1785fa2703d9ae511ee2be0c; bytes32 ROOT_ENS_NODE = 0xe6ae31d630cc7a8279c0f1c7cbe6e7064814c47d1785fa2703d9ae511ee2be0c;
bytes32 CLASSIC_ENS_DOCS_LABEL_HASH = 0x25e5cde5b364d3ffc5a7c8fecda7cf863701488fc2dd91fb4c9e6c59e62bad4a; bytes32 ENS_DOCS_LABEL_HASH = 0x6bf9054545420e9e9f4aa4f353a32c7d0d52c11dbcdda56c53be8375cafeebb1;
bytes32 CLASSIC_ENS_RELAYERS_NETWORK_SUBNODE = 0x4e37047f2c961db41dfb7d38cf79ca745faf134a8392cfb834d3a93330b9108d; bytes32 ENS_RELAYERS_NETWORK_LABEL_HASH = 0x25e5cde5b364d3ffc5a7c8fecda7cf863701488fc2dd91fb4c9e6c59e62bad4a;
bytes32 ENS_RELAYERS_NETWORK_SUBNODE = 0x4e37047f2c961db41dfb7d38cf79ca745faf134a8392cfb834d3a93330b9108d;
bytes memory CLASSIC_ROOT_IPFS_HASH = hex"e30101701220d422ef6e800db34f50101daa4ea6b04365ab44b49bf58c00b54c1067befb7370"; bytes memory ROOT_IPFS_HASH = hex"e301017012209958c2dae126b12afe086fa7397b4af704bbe4e7feda58813932078ecdaf71a3";
bytes memory CLASSIC_DOCS_IPFS_HASH = hex"e30101701220d422ef6e800db34f50101daa4ea6b04365ab44b49bf58c00b54c1067befb7370"; bytes memory DOCS_IPFS_HASH = hex"e30101701220fe412f995e15573c95e24858e0427816f13632c6aba8751538888d84747baf64";
bytes memory CLASSIC_RELAYERS_NETWORK_IPFS_HASH = hex"e30101701220d422ef6e800db34f50101daa4ea6b04365ab44b49bf58c00b54c1067befb7370"; bytes memory RELAYERS_NETWORK_IPFS_HASH = hex"e3010170122019d458d9e82c0e5637fb90f5a0701b273aee8f733691492f870c35517749769b";
address _resolverAddress = 0x4976fb03C32e5B8cfe2b6cCB31c09Ba78EBaBa41; address _resolverAddress = 0x4976fb03C32e5B8cfe2b6cCB31c09Ba78EBaBa41;
address _registryAddress = 0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e; address _registryAddress = 0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e;
address _governanceAddress = 0x5efda50f22d34F262c29268506C5Fa42cB56A1Ce; address _governanceAddress = 0x5efda50f22d34F262c29268506C5Fa42cB56A1Ce;
bytes32 CLASSIC_ENS_DOCS_SUBNODE = IENSRegistry(_registryAddress).setSubnodeOwner(CLASSIC_ENS_NODE, CLASSIC_ENS_DOCS_LABEL_HASH, _governanceAddress); IENSRegistry(_registryAddress).setSubnodeRecord(ROOT_ENS_NODE, ENS_DOCS_LABEL_HASH, _governanceAddress, _resolverAddress, 0);
IENSRegistry(_registryAddress).setSubnodeOwner(ROOT_ENS_NODE, ENS_RELAYERS_NETWORK_LABEL_HASH, _governanceAddress);
IENSRegistry(_registryAddress).setSubnodeRecord(CLASSIC_ENS_NODE, CLASSIC_ENS_DOCS_LABEL_HASH, _governanceAddress, _resolverAddress, 0); bytes32 ENS_DOCS_SUBNODE = IENSRegistry(_registryAddress).setSubnodeOwner(ROOT_ENS_NODE, ENS_DOCS_LABEL_HASH, _governanceAddress);
IENSResolver(_resolverAddress).setContenthash(CLASSIC_ENS_NODE, CLASSIC_ROOT_IPFS_HASH); IENSResolver(_resolverAddress).setContenthash(ROOT_ENS_NODE, ROOT_IPFS_HASH);
IENSResolver(_resolverAddress).setContenthash(CLASSIC_ENS_DOCS_SUBNODE, CLASSIC_DOCS_IPFS_HASH); IENSResolver(_resolverAddress).setContenthash(ENS_DOCS_SUBNODE, DOCS_IPFS_HASH);
IENSResolver(_resolverAddress).setContenthash(CLASSIC_ENS_RELAYERS_NETWORK_SUBNODE, CLASSIC_RELAYERS_NETWORK_IPFS_HASH); IENSResolver(_resolverAddress).setContenthash(ENS_RELAYERS_NETWORK_SUBNODE, RELAYERS_NETWORK_IPFS_HASH);
} }
function appendSablierRemuneration() internal { function appendSablierRemuneration() internal {
uint256 FISCAL_Q_DURATION = 91 days; uint256 FISCAL_Q_DURATION = 91 days;
uint256 RENUMERATION_START_TS = block.timestamp; uint256 RENUMERATION_START_TS = block.timestamp;
uint256 RENUMERATION_AMOUNT = 13363 ether; uint256 RENUMERATION_AMOUNT = 8131 ether;
uint256 RENUMERATION_NORMALISED_AMOUNT = RENUMERATION_AMOUNT - (RENUMERATION_AMOUNT % FISCAL_Q_DURATION); uint256 RENUMERATION_NORMALISED_AMOUNT = RENUMERATION_AMOUNT - (RENUMERATION_AMOUNT % FISCAL_Q_DURATION);
address RENUMERATION_ADDRESS = 0x40d16C473CB7bF5fAB9713b27A4562EAa6f915d1; address RENUMERATION_ADDRESS = 0x40d16C473CB7bF5fAB9713b27A4562EAa6f915d1;
uint256 AUDIT_REMMINBURSEMENT_AMOUNT = 1802 ether;
address _tokenAddress = 0x77777FeDdddFfC19Ff86DB637967013e6C6A116C; address _tokenAddress = 0x77777FeDdddFfC19Ff86DB637967013e6C6A116C;
address _sablierAddress = 0xCD18eAa163733Da39c232722cBC4E8940b1D8888; address _sablierAddress = 0xCD18eAa163733Da39c232722cBC4E8940b1D8888;
IERC20(_tokenAddress).transfer(RENUMERATION_ADDRESS, AUDIT_REMMINBURSEMENT_AMOUNT);
IERC20(_tokenAddress).approve(_sablierAddress, RENUMERATION_NORMALISED_AMOUNT); IERC20(_tokenAddress).approve(_sablierAddress, RENUMERATION_NORMALISED_AMOUNT);
ISablier(_sablierAddress).createStream( ISablier(_sablierAddress).createStream(

View File

@ -3,26 +3,31 @@ pragma solidity ^0.8.1;
contract Parameters { contract Parameters {
// Remuneration // Remuneration
uint256 public FISCAL_Q_DURATION = 91 days; uint256 FISCAL_Q_DURATION = 91 days;
uint256 public RENUMERATION_AMOUNT = 13363 ether; uint256 RENUMERATION_START_TS = block.timestamp;
uint256 public RENUMERATION_NORMALISED_AMOUNT = RENUMERATION_AMOUNT - (RENUMERATION_AMOUNT % FISCAL_Q_DURATION); uint256 RENUMERATION_AMOUNT = 8131 ether;
uint256 RENUMERATION_NORMALISED_AMOUNT = RENUMERATION_AMOUNT - (RENUMERATION_AMOUNT % FISCAL_Q_DURATION);
address public RENUMERATION_ADDRESS = 0x40d16C473CB7bF5fAB9713b27A4562EAa6f915d1; address RENUMERATION_ADDRESS = 0x40d16C473CB7bF5fAB9713b27A4562EAa6f915d1;
uint256 AUDIT_REMMINBURSEMENT_AMOUNT = 1802 ether;
// ENS IPFS configuration // ENS IPFS configuration
bytes32 CLASSIC_ENS_ROOT_SUBNODE = 0xe6ae31d630cc7a8279c0f1c7cbe6e7064814c47d1785fa2703d9ae511ee2be0c; bytes32 ROOT_ENS_NODE = 0xe6ae31d630cc7a8279c0f1c7cbe6e7064814c47d1785fa2703d9ae511ee2be0c;
bytes32 CLASSIC_ENS_DOCS_SUBNODE = 0xe6ae31d630cc7a8279c0f1c7cbe6e7064814c47d1785fa2703d9ae511ee2be0c; bytes32 ENS_DOCS_SUBNODE = 0xd7b8aac14a9b2507ab99b5fde3060197fddb9735afa9bf38b1f7e34923cb935e;
bytes32 CLASSIC_ENS_RELAYERS_NETWORK_SUBNODE = 0xe6ae31d630cc7a8279c0f1c7cbe6e7064814c47d1785fa2703d9ae511ee2be0c; bytes32 ENS_RELAYERS_NETWORK_SUBNODE = 0x4e37047f2c961db41dfb7d38cf79ca745faf134a8392cfb834d3a93330b9108d;
bytes32 ENS_RELAYERS_NETWORK_LABEL_HASH = 0x25e5cde5b364d3ffc5a7c8fecda7cf863701488fc2dd91fb4c9e6c59e62bad4a;
bytes32 ENS_DOCS_LABEL_HASH = 0x6bf9054545420e9e9f4aa4f353a32c7d0d52c11dbcdda56c53be8375cafeebb1;
bytes CLASSIC_ROOT_IPFS_HASH = hex"e30101701220d422ef6e800db34f50101daa4ea6b04365ab44b49bf58c00b54c1067befb7370"; bytes ROOT_IPFS_HASH = hex"e301017012209958c2dae126b12afe086fa7397b4af704bbe4e7feda58813932078ecdaf71a3";
bytes CLASSIC_DOCS_IPFS_HASH = hex"e30101701220d422ef6e800db34f50101daa4ea6b04365ab44b49bf58c00b54c1067befb7370"; bytes DOCS_IPFS_HASH = hex"e30101701220fe412f995e15573c95e24858e0427816f13632c6aba8751538888d84747baf64";
bytes CLASSIC_RELAYERS_NETWORK_IPFS_HASH = hex"e30101701220d422ef6e800db34f50101daa4ea6b04365ab44b49bf58c00b54c1067befb7370"; bytes RELAYERS_NETWORK_IPFS_HASH = hex"e3010170122019d458d9e82c0e5637fb90f5a0701b273aee8f733691492f870c35517749769b";
// Beneficary addresses // Beneficary addresses
address public _governanceAddress = 0x5efda50f22d34F262c29268506C5Fa42cB56A1Ce; address public _governanceAddress = 0x5efda50f22d34F262c29268506C5Fa42cB56A1Ce;
address public _tokenAddress = 0x77777FeDdddFfC19Ff86DB637967013e6C6A116C; address public _tokenAddress = 0x77777FeDdddFfC19Ff86DB637967013e6C6A116C;
address public _sablierAddress = 0xCD18eAa163733Da39c232722cBC4E8940b1D8888; address public _sablierAddress = 0xCD18eAa163733Da39c232722cBC4E8940b1D8888;
address public registryAddress = 0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e; address public _registryAddress = 0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e;
address public _resolverAddress = 0x4976fb03C32e5B8cfe2b6cCB31c09Ba78EBaBa41; address public _resolverAddress = 0x4976fb03C32e5B8cfe2b6cCB31c09Ba78EBaBa41;
} }

View File

@ -2,6 +2,7 @@ pragma solidity ^0.8.1;
import "@interfaces/IGovernance.sol"; import "@interfaces/IGovernance.sol";
import "@interfaces/IERC20.sol"; import "@interfaces/IERC20.sol";
import "@interfaces/IENSResolver.sol";
import "@proprietary/Parameters.sol"; import "@proprietary/Parameters.sol";
import "@proprietary/Mock.sol"; import "@proprietary/Mock.sol";
@ -77,7 +78,15 @@ contract ProposalTest is Test, Parameters, Mock {
/* ----------------------------*/ /* ----------------------------*/
} }
function compareBytes(bytes memory a, bytes memory b) public returns (bool e) {
e = keccak256(abi.encodePacked(a)) == keccak256(abi.encodePacked(b));
}
function checkParameters() internal {} function checkParameters() internal {}
function checkResults() internal {} function checkResults() internal {
require(compareBytes(IENSResolver(_resolverAddress).contenthash(ROOT_ENS_NODE), ROOT_IPFS_HASH));
require(compareBytes(IENSResolver(_resolverAddress).contenthash(ENS_DOCS_SUBNODE), DOCS_IPFS_HASH));
require(compareBytes(IENSResolver(_resolverAddress).contenthash(ENS_RELAYERS_NETWORK_SUBNODE), RELAYERS_NETWORK_IPFS_HASH));
}
} }