From cbd40aef8a0d60c5fdec228ec955287edd7ea41c Mon Sep 17 00:00:00 2001 From: Ricardo Guilherme Schmidt <3esmit@gmail.com> Date: Mon, 4 Mar 2024 12:27:40 -0300 Subject: [PATCH] fix(StakeManager): lock function checks for MIN_LOCKUP_PERIOD --- contracts/StakeManager.sol | 49 ++++++++++++++++++++++++-------------- test/StakeManager.t.sol | 6 ++--- 2 files changed, 34 insertions(+), 21 deletions(-) diff --git a/contracts/StakeManager.sol b/contracts/StakeManager.sol index 33d6d3e..2110bb1 100644 --- a/contracts/StakeManager.sol +++ b/contracts/StakeManager.sol @@ -128,14 +128,11 @@ contract StakeManager is Ownable { /** * Increases balance of msg.sender; * @param _amount Amount of balance to be decreased. - * @param _time Seconds from block.timestamp to lock balance. + * @param _timeToIncrease Seconds to increase in locked time. If stake is unlocked, increases from block.timestamp. * - * @dev Reverts when `_time` is not in range of [MIN_LOCKUP_PERIOD, MAX_LOCKUP_PERIOD] + * @dev Reverts when resulting locked time is not in range of [MIN_LOCKUP_PERIOD, MAX_LOCKUP_PERIOD] */ - function stake(uint256 _amount, uint256 _time) external onlyVault noMigration processEpoch { - if (_time > 0 && (_time < MIN_LOCKUP_PERIOD || _time > MAX_LOCKUP_PERIOD)) { - revert StakeManager__InvalidLockTime(); - } + function stake(uint256 _amount, uint256 _timeToIncrease) external onlyVault noMigration processEpoch { Account storage account = accounts[msg.sender]; if (account.lockUntil == 0) { // account not initialized @@ -145,11 +142,22 @@ contract StakeManager is Ownable { } else { _processAccount(account, currentEpoch); } - _mintIntialMP(account, _time, _amount); + uint256 deltaTime = 0; + if (_timeToIncrease > 0) { + uint256 lockUntil = account.lockUntil + _timeToIncrease; + if (lockUntil < block.timestamp) { + revert StakeManager__InvalidLockTime(); + } + deltaTime = lockUntil - block.timestamp; + if (deltaTime < MIN_LOCKUP_PERIOD || deltaTime > MAX_LOCKUP_PERIOD) { + revert StakeManager__InvalidLockTime(); + } + } + _mintIntialMP(account, deltaTime, _amount); //update storage totalSupplyBalance += _amount; account.balance += _amount; - account.lockUntil += _time; + account.lockUntil += _timeToIncrease; } /** @@ -178,23 +186,28 @@ contract StakeManager is Ownable { /** * @notice Locks entire balance for more amount of time. - * @param _time amount of time to lock from now. + * @param _timeToIncrease Seconds to increase in locked time. If stake is unlocked, increases from block.timestamp. * - * @dev Reverts when `_time` is bigger than `MAX_LOCKUP_PERIOD` - * @dev Reverts when `_time + block.timestamp` is smaller than current lock time. + * @dev Reverts when resulting locked time is not in range of [MIN_LOCKUP_PERIOD, MAX_LOCKUP_PERIOD] */ - function lock(uint256 _time) external onlyVault onlyInitialized(msg.sender) noMigration processEpoch { - if (_time > MAX_LOCKUP_PERIOD) { - revert StakeManager__InvalidLockTime(); - } + function lock(uint256 _timeToIncrease) external onlyVault onlyInitialized(msg.sender) noMigration processEpoch { Account storage account = accounts[msg.sender]; _processAccount(account, currentEpoch); - if (account.lockUntil + _time < block.timestamp) { + uint256 lockUntil = account.lockUntil; + uint256 deltaTime; + if (lockUntil < block.timestamp) { + lockUntil = block.timestamp + _timeToIncrease; + deltaTime = _timeToIncrease; + } else { + lockUntil += _timeToIncrease; + deltaTime = lockUntil - block.timestamp; + } + if (deltaTime < MIN_LOCKUP_PERIOD || deltaTime > MAX_LOCKUP_PERIOD) { revert StakeManager__InvalidLockTime(); } - _mintIntialMP(account, _time, 0); + _mintIntialMP(account, _timeToIncrease, 0); //update account storage - account.lockUntil += _time; + account.lockUntil = lockUntil; } /** diff --git a/test/StakeManager.t.sol b/test/StakeManager.t.sol index e487f61..db85d81 100644 --- a/test/StakeManager.t.sol +++ b/test/StakeManager.t.sol @@ -68,11 +68,11 @@ contract StakeTest is StakeManagerTest { ERC20(stakeToken).approve(address(userVault), 100); uint256 lockTime = stakeManager.MIN_LOCKUP_PERIOD() - 1; - vm.expectRevert(StakeManager.StakeManager__InvalidLockupPeriod.selector); + vm.expectRevert(StakeManager.StakeManager__InvalidLockTime.selector); userVault.stake(100, lockTime); lockTime = stakeManager.MAX_LOCKUP_PERIOD() + 1; - vm.expectRevert(StakeManager.StakeManager__InvalidLockupPeriod.selector); + vm.expectRevert(StakeManager.StakeManager__InvalidLockTime.selector); userVault.stake(100, lockTime); } @@ -214,7 +214,7 @@ contract LockTest is StakeManagerTest { ERC20(stakeToken).approve(address(userVault), 100); uint256 lockTime = stakeManager.MAX_LOCKUP_PERIOD() + 1; - vm.expectRevert(StakeManager.StakeManager__InvalidLockupPeriod.selector); + vm.expectRevert(StakeManager.StakeManager__InvalidLockTime.selector); userVault.stake(100, lockTime); } }