Skip to content

Commit

Permalink
Revert "refactor(protocol): clean up permission code (whitelisting di…
Browse files Browse the repository at this point in the history
…sabled) (#2096)"

This reverts commit 972f527.
  • Loading branch information
dantaik committed Jan 29, 2023
1 parent 4144f4b commit f8105f7
Show file tree
Hide file tree
Showing 6 changed files with 177 additions and 15 deletions.
9 changes: 9 additions & 0 deletions packages/protocol/contracts/L1/TaikoData.sol
Original file line number Diff line number Diff line change
Expand Up @@ -103,4 +103,13 @@ library TaikoData {
// Reserved
uint256[42] __gap;
}

struct TentativeState {
mapping(address => bool) proposers; // Whitelisted proposers
mapping(address => bool) provers; // Whitelisted provers
bool whitelistProposers;
bool whitelistProvers;
// // Reserved
uint256[46] __gap;
}
}
6 changes: 6 additions & 0 deletions packages/protocol/contracts/L1/TaikoEvents.sol
Original file line number Diff line number Diff line change
Expand Up @@ -30,5 +30,11 @@ abstract contract TaikoEvents {
address prover
);

event WhitelistingEnabled(bool whitelistProposers, bool whitelistProvers);

event ProposerWhitelisted(address indexed prover, bool whitelisted);

event ProverWhitelisted(address indexed prover, bool whitelisted);

event Halted(bool halted);
}
81 changes: 80 additions & 1 deletion packages/protocol/contracts/L1/TaikoL1.sol
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,8 @@ contract TaikoL1 is EssentialContract, IHeaderSync, TaikoEvents {
using LibUtils for TaikoData.State;

TaikoData.State public state;
uint256[100] private __gap;
TaikoData.TentativeState public tentative;
uint256[50] private __gap;

function init(
address _addressManager,
Expand All @@ -37,6 +38,9 @@ contract TaikoL1 is EssentialContract, IHeaderSync, TaikoEvents {
genesisBlockHash: _genesisBlockHash,
feeBase: _feeBase
});

tentative.whitelistProposers = false;
tentative.whitelistProvers = true;
}

/**
Expand Down Expand Up @@ -82,6 +86,7 @@ contract TaikoL1 is EssentialContract, IHeaderSync, TaikoEvents {
LibProposing.proposeBlock({
state: state,
config: config,
tentative: tentative,
resolver: AddressResolver(this),
inputs: inputs
});
Expand Down Expand Up @@ -116,6 +121,7 @@ contract TaikoL1 is EssentialContract, IHeaderSync, TaikoEvents {
TaikoData.Config memory config = getConfig();
LibProving.proveBlock({
state: state,
tentative: tentative,
config: config,
resolver: AddressResolver(this),
blockId: blockId,
Expand Down Expand Up @@ -152,6 +158,7 @@ contract TaikoL1 is EssentialContract, IHeaderSync, TaikoEvents {

LibProving.proveBlockInvalid({
state: state,
tentative: tentative,
config: config,
resolver: AddressResolver(this),
blockId: blockId,
Expand Down Expand Up @@ -181,6 +188,56 @@ contract TaikoL1 is EssentialContract, IHeaderSync, TaikoEvents {
});
}

/**
* Enable or disable proposer and prover whitelisting
* @param whitelistProposers True to enable proposer whitelisting.
* @param whitelistProvers True to enable prover whitelisting.
*/
function enableWhitelisting(
bool whitelistProposers,
bool whitelistProvers
) public onlyOwner {
LibUtils.enableWhitelisting({
tentative: tentative,
whitelistProposers: whitelistProposers,
whitelistProvers: whitelistProvers
});
}

/**
* Add or remove a proposer from the whitelist.
*
* @param proposer The proposer to be added or removed.
* @param whitelisted True to add; remove otherwise.
*/
function whitelistProposer(
address proposer,
bool whitelisted
) public onlyOwner {
LibUtils.whitelistProposer({
tentative: tentative,
proposer: proposer,
whitelisted: whitelisted
});
}

/**
* Add or remove a prover from the whitelist.
*
* @param prover The prover to be added or removed.
* @param whitelisted True to add; remove otherwise.
*/
function whitelistProver(
address prover,
bool whitelisted
) public onlyOwner {
LibUtils.whitelistProver({
tentative: tentative,
prover: prover,
whitelisted: whitelisted
});
}

/**
* Halt or resume the chain.
* @param toHalt True to halt, false to resume.
Expand All @@ -189,6 +246,28 @@ contract TaikoL1 is EssentialContract, IHeaderSync, TaikoEvents {
LibUtils.halt(state, toHalt);
}

/**
* Check whether a proposer is whitelisted.
*
* @param proposer The proposer.
* @return True if the proposer is whitelisted, false otherwise.
*/
function isProposerWhitelisted(
address proposer
) public view returns (bool) {
return LibUtils.isProposerWhitelisted(tentative, proposer);
}

/**
* Check whether a prover is whitelisted.
*
* @param prover The prover.
* @return True if the prover is whitelisted, false otherwise.
*/
function isProverWhitelisted(address prover) public view returns (bool) {
return LibUtils.isProverWhitelisted(tentative, prover);
}

function getBlockFee() public view returns (uint256) {
(, uint fee, uint deposit) = LibProposing.getBlockFee(
state,
Expand Down
23 changes: 11 additions & 12 deletions packages/protocol/contracts/L1/libs/LibProposing.sol
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,15 @@ library LibProposing {
);
event BlockProposed(uint256 indexed id, TaikoData.BlockMetadata meta);

modifier onlyWhitelistedProposer(
TaikoData.TentativeState storage tentative
) {
if (tentative.whitelistProposers) {
require(tentative.proposers[msg.sender], "L1:whitelist");
}
_;
}

function commitBlock(
TaikoData.State storage state,
TaikoData.Config memory config,
Expand Down Expand Up @@ -51,20 +60,10 @@ library LibProposing {
function proposeBlock(
TaikoData.State storage state,
TaikoData.Config memory config,
TaikoData.TentativeState storage tentative,
AddressResolver resolver,
bytes[] calldata inputs
) public {
// For alpha-2 testnet, the network only allows an special address
// to propose but anyone to prove. This is the first step of testing
// the tokenomics.

// TODO(daniel): remove this special address.
address specialProposer = resolver.resolve("special_proposer", true);
require(
specialProposer == address(0) || specialProposer == msg.sender,
"L1:specialProposer"
);

) public onlyWhitelistedProposer(tentative) {
assert(!LibUtils.isHalted(state));

require(inputs.length == 2, "L1:inputs:size");
Expand Down
13 changes: 11 additions & 2 deletions packages/protocol/contracts/L1/libs/LibProving.sol
Original file line number Diff line number Diff line change
Expand Up @@ -46,13 +46,21 @@ library LibProving {
address prover
);

modifier onlyWhitelistedProver(TaikoData.TentativeState storage tentative) {
if (tentative.whitelistProvers) {
require(tentative.provers[msg.sender], "L1:whitelist");
}
_;
}

function proveBlock(
TaikoData.State storage state,
TaikoData.TentativeState storage tentative,
TaikoData.Config memory config,
AddressResolver resolver,
uint256 blockId,
bytes[] calldata inputs
) public {
) public onlyWhitelistedProver(tentative) {
assert(!LibUtils.isHalted(state));

// Check and decode inputs
Expand Down Expand Up @@ -149,11 +157,12 @@ library LibProving {

function proveBlockInvalid(
TaikoData.State storage state,
TaikoData.TentativeState storage tentative,
TaikoData.Config memory config,
AddressResolver resolver,
uint256 blockId,
bytes[] calldata inputs
) public {
) public onlyWhitelistedProver(tentative) {
assert(!LibUtils.isHalted(state));

// Check and decode inputs
Expand Down
60 changes: 60 additions & 0 deletions packages/protocol/contracts/L1/libs/LibUtils.sol
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,52 @@ library LibUtils {

bytes32 public constant BLOCK_DEADEND_HASH = bytes32(uint256(1));

event WhitelistingEnabled(bool whitelistProposers, bool whitelistProvers);
event ProposerWhitelisted(address indexed proposer, bool whitelisted);
event ProverWhitelisted(address indexed prover, bool whitelisted);
event Halted(bool halted);

function enableWhitelisting(
TaikoData.TentativeState storage tentative,
bool whitelistProposers,
bool whitelistProvers
) internal {
tentative.whitelistProposers = whitelistProvers;
tentative.whitelistProvers = whitelistProvers;
emit WhitelistingEnabled(whitelistProposers, whitelistProvers);
}

function whitelistProposer(
TaikoData.TentativeState storage tentative,
address proposer,
bool whitelisted
) internal {
assert(tentative.whitelistProposers);
require(
proposer != address(0) &&
tentative.proposers[proposer] != whitelisted,
"L1:precondition"
);

tentative.proposers[proposer] = whitelisted;
emit ProposerWhitelisted(proposer, whitelisted);
}

function whitelistProver(
TaikoData.TentativeState storage tentative,
address prover,
bool whitelisted
) internal {
assert(tentative.whitelistProvers);
require(
prover != address(0) && tentative.provers[prover] != whitelisted,
"L1:precondition"
);

tentative.provers[prover] = whitelisted;
emit ProverWhitelisted(prover, whitelisted);
}

function halt(TaikoData.State storage state, bool toHalt) internal {
require(isHalted(state) != toHalt, "L1:precondition");
setBit(state, MASK_HALT, toHalt);
Expand Down Expand Up @@ -86,6 +130,22 @@ library LibUtils {
return isBitOne(state, MASK_HALT);
}

function isProposerWhitelisted(
TaikoData.TentativeState storage tentative,
address proposer
) internal view returns (bool) {
assert(tentative.whitelistProposers);
return tentative.proposers[proposer];
}

function isProverWhitelisted(
TaikoData.TentativeState storage tentative,
address prover
) internal view returns (bool) {
assert(tentative.whitelistProvers);
return tentative.provers[prover];
}

// Implement "Incentive Multipliers", see the whitepaper.
function getTimeAdjustedFee(
TaikoData.State storage state,
Expand Down

0 comments on commit f8105f7

Please sign in to comment.