Skip to content

Commit

Permalink
feat: remove unnecessary steps while deposit and claim
Browse files Browse the repository at this point in the history
  • Loading branch information
blockgroot committed Nov 27, 2024
1 parent c2b620a commit 4ba8f6e
Show file tree
Hide file tree
Showing 5 changed files with 32 additions and 70 deletions.
14 changes: 12 additions & 2 deletions contracts/OperatorRewardsCollector.sol
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import { ISDUtilityPool, UserData, OperatorLiquidation } from "./interfaces/ISDU
import { ISDCollateral } from "./interfaces/SDCollateral/ISDCollateral.sol";
import { IWETH } from "./interfaces/IWETH.sol";
import { IStaderOracle } from "../contracts/interfaces/IStaderOracle.sol";
import { IPoolUtils } from "../contracts/interfaces/IPoolUtils.sol";

contract OperatorRewardsCollector is IOperatorRewardsCollector, AccessControlUpgradeable {
IStaderConfig public staderConfig;
Expand Down Expand Up @@ -52,7 +53,12 @@ contract OperatorRewardsCollector is IOperatorRewardsCollector, AccessControlUpg
* @dev This function first checks for any unpaid liquidations for the operator and repays them if necessary. Then, it transfers any remaining balance to the operator's reward address.
*/
function claim() external {
claimLiquidation(msg.sender);
IPoolUtils poolUtils = IPoolUtils(staderConfig.getPoolUtils());
uint8 poolId = poolUtils.getOperatorPoolId(msg.sender);
address permissionlessNodeRegistry = staderConfig.getPermissionlessNodeRegistry();

if (INodeRegistry(permissionlessNodeRegistry).POOL_ID() == poolId) claimLiquidation(msg.sender);

uint256 amount = balances[msg.sender] > withdrawableInEth(msg.sender)
? withdrawableInEth(msg.sender)
: balances[msg.sender];
Expand All @@ -66,7 +72,11 @@ contract OperatorRewardsCollector is IOperatorRewardsCollector, AccessControlUpg
* @param _amount amount of ETH to claim
*/
function claimWithAmount(uint256 _amount) external {
claimLiquidation(msg.sender);
IPoolUtils poolUtils = IPoolUtils(staderConfig.getPoolUtils());
uint8 poolId = poolUtils.getOperatorPoolId(msg.sender);
address permissionlessNodeRegistry = staderConfig.getPermissionlessNodeRegistry();

Check warning on line 77 in contracts/OperatorRewardsCollector.sol

View check run for this annotation

Codecov / codecov/patch

contracts/OperatorRewardsCollector.sol#L75-L77

Added lines #L75 - L77 were not covered by tests

if (INodeRegistry(permissionlessNodeRegistry).POOL_ID() == poolId) claimLiquidation(msg.sender);
_claim(msg.sender, _amount);
}

Expand Down
16 changes: 0 additions & 16 deletions contracts/PermissionedNodeRegistry.sol
Original file line number Diff line number Diff line change
Expand Up @@ -720,22 +720,6 @@ contract PermissionedNodeRegistry is
revert InvalidKeyCount();
}
totalKeys = getOperatorTotalKeys(_operatorId);
uint256 totalNonTerminalKeys = getOperatorTotalNonTerminalKeys(msg.sender, 0, totalKeys);
if ((totalNonTerminalKeys + keyCount) > maxNonTerminalKeyPerOperator) {
revert MaxKeyLimitReached();
}

//checks if operator has enough SD collateral for adding `keyCount` keys
//SD threshold for permissioned NOs is 0 for phase1
if (
!ISDCollateral(staderConfig.getSDCollateral()).hasEnoughSDCollateral(
msg.sender,
POOL_ID,
totalNonTerminalKeys + keyCount
)
) {
revert NotEnoughSDCollateral();
}
}

// operator in active state
Expand Down
10 changes: 10 additions & 0 deletions test/foundry_tests/NodeELRewardVault.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import { PoolUtilsMock } from "../mocks/PoolUtilsMock.sol";
import { StakePoolManagerMock } from "../mocks/StakePoolManagerMock.sol";
import { StaderOracleMock } from "../mocks/StaderOracleMock.sol";
import { SDUtilityPoolMock } from "../mocks/SDUtilityPoolMock.sol";
import { PermissionlessNodeRegistryMock } from "../mocks/PermissionlessNodeRegistryMock.sol";

contract NodeELRewardVaultTest is Test {
address private constant OPERATOR_ADDRESSS = address(500);
Expand Down Expand Up @@ -59,6 +60,7 @@ contract NodeELRewardVaultTest is Test {
address operator = OPERATOR_ADDRESSS;
mockStaderOracle(staderOracleMock);
mockSdUtilityPool(sdUtilityPoolMock, operator);
mockPermissionlessNodeRegistry(vm.addr(105));

OperatorRewardsCollector operatorRCImpl = new OperatorRewardsCollector();
TransparentUpgradeableProxy operatorRCProxy = new TransparentUpgradeableProxy(
Expand Down Expand Up @@ -95,6 +97,7 @@ contract NodeELRewardVaultTest is Test {
staderConfig.updateSDCollateral(address(sdCollateral));
staderConfig.updateSDUtilityPool(sdUtilityPoolMock);
staderConfig.updateStaderOracle(staderOracleMock);
staderConfig.updatePermissionlessNodeRegistry(vm.addr(105));
staderConfig.grantRole(staderConfig.MANAGER(), staderManager);
vaultFactory.grantRole(vaultFactory.NODE_REGISTRY_CONTRACT(), address(poolUtils.nodeRegistry()));
vm.stopPrank();
Expand Down Expand Up @@ -265,4 +268,11 @@ contract NodeELRewardVaultTest is Test {
bytes memory mockCode = address(implementation).code;
vm.etch(staderOracleMock, mockCode);
}

function mockPermissionlessNodeRegistry(address _permissionlessNodeRegistry) private {
emit log_named_address("permissionlessNodeRegistry", _permissionlessNodeRegistry);
PermissionlessNodeRegistryMock nodeRegistryMock = new PermissionlessNodeRegistryMock();
bytes memory mockCode = address(nodeRegistryMock).code;
vm.etch(_permissionlessNodeRegistry, mockCode);
}
}
52 changes: 0 additions & 52 deletions test/foundry_tests/PermissionedNodeRegistry.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -227,24 +227,6 @@ contract PermissionedNodeRegistryTest is Test {
assertEq(nodeRegistry.isExistingPubkey(pubkeys[0]), true);
}

function testAddValidatorKeysNotEnoughSDCollateral() public {
(
bytes[] memory pubkeys,
bytes[] memory preDepositSignature,
bytes[] memory depositSignature
) = getValidatorKeys();
vm.startPrank(permissionedNO);
nodeRegistry.onboardNodeOperator("testOP", payable(address(this)));
vm.mockCall(
address(sdCollateral),
abi.encodeWithSelector(ISDCollateral.hasEnoughSDCollateral.selector),
abi.encode(false)
);
vm.expectRevert(INodeRegistry.NotEnoughSDCollateral.selector);
nodeRegistry.addValidatorKeys(pubkeys, preDepositSignature, depositSignature);
vm.stopPrank();
}

function test_addValidatorKeysWithMisMatchingInputs() public {
bytes[] memory pubkeys = new bytes[](1);
bytes[] memory preDepositSignature = new bytes[](1);
Expand All @@ -271,40 +253,6 @@ contract PermissionedNodeRegistryTest is Test {
vm.stopPrank();
}

function test_addValidatorKeysOPCrossingMaxNonTerminalKeys() public {
(
bytes[] memory pubkeys,
bytes[] memory preDepositSignature,
bytes[] memory depositSignature
) = getValidatorKeys();
vm.prank(staderManager);
nodeRegistry.updateMaxNonTerminalKeyPerOperator(2);
vm.startPrank(permissionedNO);
nodeRegistry.onboardNodeOperator("testOP", payable(address(this)));
vm.expectRevert(INodeRegistry.MaxKeyLimitReached.selector);
nodeRegistry.addValidatorKeys(pubkeys, preDepositSignature, depositSignature);
vm.stopPrank();
}

function test_addValidatorKeysWithInsufficientSDCollateral() public {
(
bytes[] memory pubkeys,
bytes[] memory preDepositSignature,
bytes[] memory depositSignature
) = getValidatorKeys();

vm.startPrank(permissionedNO);
nodeRegistry.onboardNodeOperator("testOP", payable(address(this)));
vm.mockCall(
address(sdCollateral),
abi.encodeWithSelector(ISDCollateral.hasEnoughSDCollateral.selector),
abi.encode(false)
);
vm.expectRevert(INodeRegistry.NotEnoughSDCollateral.selector);
nodeRegistry.addValidatorKeys(pubkeys, preDepositSignature, depositSignature);
vm.stopPrank();
}

function test_markReadyToDepositValidator() public {
(
bytes[] memory pubkeys,
Expand Down
10 changes: 10 additions & 0 deletions test/foundry_tests/ValidatorWithdrawalVault.t.sol
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import "../mocks/StakePoolManagerMock.sol";

import { SDUtilityPoolMock } from "../mocks/SDUtilityPoolMock.sol";
import { StaderOracleMock } from "../mocks/StaderOracleMock.sol";
import { PermissionlessNodeRegistryMock } from "../mocks/PermissionlessNodeRegistryMock.sol";

contract ValidatorWithdrawalVaultTest is Test {
address private constant OPERATOR_ADDRESS = address(500);
Expand Down Expand Up @@ -52,6 +53,7 @@ contract ValidatorWithdrawalVaultTest is Test {

mockStaderOracle(staderOracleMock);
mockSDUtilityPool(sdUtilityPoolMock, operator);
mockPermissionlessNodeRegistry(vm.addr(105));

ProxyAdmin proxyAdmin = new ProxyAdmin();

Expand Down Expand Up @@ -93,6 +95,7 @@ contract ValidatorWithdrawalVaultTest is Test {
staderConfig.updateOperatorRewardsCollector(address(operatorRC));
staderConfig.updateValidatorWithdrawalVaultImplementation(address(withdrawVaultImpl));
staderConfig.updateStaderOracle(staderOracleMock);
staderConfig.updatePermissionlessNodeRegistry(vm.addr(105));
staderConfig.grantRole(staderConfig.MANAGER(), staderManager);
vaultFactory.grantRole(vaultFactory.NODE_REGISTRY_CONTRACT(), address(poolUtils.nodeRegistry()));
vm.stopPrank();
Expand Down Expand Up @@ -384,4 +387,11 @@ contract ValidatorWithdrawalVaultTest is Test {
abi.encode(UserData(0 ether, 4 ether, 1, 0))
);
}

function mockPermissionlessNodeRegistry(address _permissionlessNodeRegistry) private {
emit log_named_address("permissionlessNodeRegistry", _permissionlessNodeRegistry);
PermissionlessNodeRegistryMock nodeRegistryMock = new PermissionlessNodeRegistryMock();
bytes memory mockCode = address(nodeRegistryMock).code;
vm.etch(_permissionlessNodeRegistry, mockCode);
}
}

0 comments on commit 4ba8f6e

Please sign in to comment.