From 07e7d0ef51d315666445d1678f7c924b0c33b8cb Mon Sep 17 00:00:00 2001 From: Shawn <44221603+shaspitz@users.noreply.github.com> Date: Tue, 17 Sep 2024 11:23:55 -0700 Subject: [PATCH] comments + storage gap --- .../interfaces/IMevCommitMiddleware.sol | 11 ++++++++++ .../middleware/MevCommitMiddlewareStorage.sol | 22 +++++++++++++++++-- 2 files changed, 31 insertions(+), 2 deletions(-) diff --git a/contracts/contracts/interfaces/IMevCommitMiddleware.sol b/contracts/contracts/interfaces/IMevCommitMiddleware.sol index 4c98c274e..67392c312 100644 --- a/contracts/contracts/interfaces/IMevCommitMiddleware.sol +++ b/contracts/contracts/interfaces/IMevCommitMiddleware.sol @@ -6,24 +6,35 @@ import {IRegistry} from "symbiotic-core/interfaces/common/IRegistry.sol"; interface IMevCommitMiddleware { + /// @notice Struct representing a registered operator. struct OperatorRecord { + /// @notice A possible occurrence of a deregistration request. TimestampOccurrence.Occurrence deregRequestOccurrence; + /// @notice Whether this operator record exists. bool exists; + /// @notice Whether this operator is blacklisted. bool isBlacklisted; } + /// @notice Struct representing a registered vault. struct VaultRecord { + /// @notice Whether this vault record exists. bool exists; + /// @notice A possible occurrence of a deregistration request. TimestampOccurrence.Occurrence deregRequestOccurrence; + /// @notice The slash amount per validator, relevant to this vault. uint256 slashAmount; } + /// @notice Struct representing a registered validator. struct ValidatorRecord { /// @notice The vault holding slashable stake which represents the validator. address vault; /// @notice The operator which registered this validator pubkey with a vault. address operator; + /// @notice Whether this validator record exists. bool exists; + /// @notice A possible occurrence of a deregistration request. TimestampOccurrence.Occurrence deregRequestOccurrence; } diff --git a/contracts/contracts/validator-registry/middleware/MevCommitMiddlewareStorage.sol b/contracts/contracts/validator-registry/middleware/MevCommitMiddlewareStorage.sol index 0c072fc10..04789bb72 100644 --- a/contracts/contracts/validator-registry/middleware/MevCommitMiddlewareStorage.sol +++ b/contracts/contracts/validator-registry/middleware/MevCommitMiddlewareStorage.sol @@ -7,18 +7,28 @@ import {IRegistry} from "symbiotic-core/interfaces/common/IRegistry.sol"; abstract contract MevCommitMiddlewareStorage { + /// @notice The only subnetwork ID for mev-commit middleware. Ie. mev-commit doesn't implement multiple subnets. uint96 public constant SUBNETWORK_ID = 1; + /// @notice Enum TYPE for Symbiotic core NetworkRestakeDelegator. uint64 public constant NETWORK_RESTAKE_DELEGATOR_TYPE = 0; + + /// @notice Enum TYPE for Symbiotic core FullRestakeDelegator. uint64 public constant FULL_RESTAKE_DELEGATOR_TYPE = 1; + /// @notice Enum TYPE for Symbiotic core InstantSlasher. uint64 public constant INSTANT_SLASHER_TYPE = 0; + + /// @notice Enum TYPE for Symbiotic core VetoSlasher. uint64 public constant VETO_SLASHER_TYPE = 1; + /// @notice Symbiotic core network registry. IRegistry public networkRegistry; + /// @notice Symbiotic core operator registry. IRegistry public operatorRegistry; + /// @notice Symbiotic core vault factory. IRegistry public vaultFactory; /// @notice The network address, which must have registered with the NETWORK_REGISTRY. @@ -29,14 +39,22 @@ abstract contract MevCommitMiddlewareStorage { /// @notice This also serves as the number of seconds that a registered Vault's epochDuration must be greater than. uint256 public slashPeriodSeconds; + /// @notice Address of the mev-commit slash oracle. address public slashOracle; + /// @notice Mapping of a validator's BLS public key to its validator record. mapping(bytes blsPubkey => IMevCommitMiddleware.ValidatorRecord) public validatorRecords; + /// @notice Mapping of an operator's address to its operator record. mapping(address operatorAddress => IMevCommitMiddleware.OperatorRecord) public operatorRecords; + /// @notice Mapping of a vault's address to its vault record. mapping(address vaultAddress => IMevCommitMiddleware.VaultRecord) public vaultRecords; - mapping(address vault => - mapping(address operator => EnumerableSet.BytesSet)) internal _vaultAndOperatorToValset; + /// @notice Mapping of a vault to its representative operator, to a set of validator BLS public keys being secured + /// by the vault. + mapping(address vault => mapping(address operator => EnumerableSet.BytesSet)) internal _vaultAndOperatorToValset; + + /// @dev See https://docs.openzeppelin.com/upgrades-plugins/1.x/writing-upgradeable#storage-gaps + uint256[48] private __gap; }