Skip to content

Commit

Permalink
refactor: remove modifier in favor of helper method (#64)
Browse files Browse the repository at this point in the history
  • Loading branch information
wadealexc authored and 8sunyuan committed Dec 8, 2023
1 parent 23b0698 commit 30ebab1
Showing 1 changed file with 16 additions and 11 deletions.
27 changes: 16 additions & 11 deletions src/RegistryCoordinator.sol
Original file line number Diff line number Diff line change
Expand Up @@ -96,16 +96,6 @@ contract RegistryCoordinator is EIP712, Initializable, IRegistryCoordinator, ISo
_;
}

modifier quorumsAllExist(bytes calldata quorumNumbers) {
uint256 quorumNumbersBitmap = BitmapUtils.orderedBytesArrayToBitmap(quorumNumbers);
uint256 initializedQuorumBitmap = 1 << quorumCount - 2;
require(
quorumNumbersBitmap.isSubsetOf(initializedQuorumBitmap),
"BLSRegistryCoordinatorWithIndices.quorumsAllExist: one or more quorums do not exist"
);
_;
}

constructor(
ISlasher _slasher,
IServiceManager _serviceManager,
Expand Down Expand Up @@ -282,6 +272,7 @@ contract RegistryCoordinator is EIP712, Initializable, IRegistryCoordinator, ISo

uint192 currentBitmap = _currentOperatorBitmap(operatorId);
bytes memory currentQuorums = BitmapUtils.bitmapToBytesArray(currentBitmap);
require(_quorumsAllExist(currentBitmap), "BLSRegistryCoordinatorWithIndices.updateOperators: some quorums do not exist");

/**
* Update the operator's stake for their active quorums. The stakeRegistry returns a bitmap
Expand Down Expand Up @@ -311,11 +302,15 @@ contract RegistryCoordinator is EIP712, Initializable, IRegistryCoordinator, ISo
function updateOperatorsForQuorum(
address[][] calldata operatorsPerQuorum,
bytes calldata quorumNumbers
) external onlyWhenNotPaused(PAUSED_UPDATE_OPERATOR) quorumsAllExist(quorumNumbers) {
) external onlyWhenNotPaused(PAUSED_UPDATE_OPERATOR) {
require(
operatorsPerQuorum.length == quorumNumbers.length,
"BLSRegistryCoordinatorWithIndices.updateOperatorsForQuorum: input length mismatch"
);

uint192 quorumBitmap = uint192(BitmapUtils.orderedBytesArrayToBitmap(quorumNumbers));
require(_quorumsAllExist(quorumBitmap), "BLSRegistryCoordinatorWithIndices.updateOperatorsForQuorum: some quorums do not exist");

_updateOperatorsForQuorum(operatorsPerQuorum, quorumNumbers);
}

Expand Down Expand Up @@ -422,6 +417,7 @@ contract RegistryCoordinator is EIP712, Initializable, IRegistryCoordinator, ISo
uint192 quorumsToAdd = uint192(BitmapUtils.orderedBytesArrayToBitmap(quorumNumbers, quorumCount));
uint192 currentBitmap = _currentOperatorBitmap(operatorId);
require(!quorumsToAdd.isEmpty(), "RegistryCoordinator._registerOperator: bitmap cannot be 0");
require(_quorumsAllExist(quorumsToAdd), "RegistryCoordinator._registerOperator: some quorums do not exist");
require(quorumsToAdd.noBitsInCommon(currentBitmap), "RegistryCoordinator._registerOperator: operator already registered for some quorums being registered for");
uint192 newBitmap = uint192(currentBitmap.plus(quorumsToAdd));

Expand Down Expand Up @@ -509,6 +505,7 @@ contract RegistryCoordinator is EIP712, Initializable, IRegistryCoordinator, ISo
uint192 quorumsToRemove = uint192(BitmapUtils.orderedBytesArrayToBitmap(quorumNumbers, quorumCount));
uint192 currentBitmap = _currentOperatorBitmap(operatorId);
require(!quorumsToRemove.isEmpty(), "RegistryCoordinator._deregisterOperator: bitmap cannot be 0");
require(_quorumsAllExist(quorumsToRemove), "RegistryCoordinator._deregisterOperator: some quorums do not exist");
require(quorumsToRemove.isSubsetOf(currentBitmap), "RegistryCoordinator._deregisterOperator: operator is not registered for specified quorums");
uint192 newBitmap = uint192(currentBitmap.minus(quorumsToRemove));

Expand Down Expand Up @@ -694,6 +691,14 @@ contract RegistryCoordinator is EIP712, Initializable, IRegistryCoordinator, ISo
}
}

/**
* @notice Returns true iff all of the bits in `quorumBitmap` belong to initialized quorums
*/
function _quorumsAllExist(uint192 quorumBitmap) internal view returns (bool) {
uint192 initializedQuorumBitmap = uint192(1 << quorumCount - 2);
return quorumBitmap.isSubsetOf(initializedQuorumBitmap);
}

/// @notice Get the most recent bitmap for the operator, returning an empty bitmap if
/// the operator is not registered.
function _currentOperatorBitmap(bytes32 operatorId) internal view returns (uint192) {
Expand Down

0 comments on commit 30ebab1

Please sign in to comment.