Skip to content

Commit

Permalink
Apply suggestions from code review
Browse files Browse the repository at this point in the history
Co-authored-by: David Núñez <[email protected]>
  • Loading branch information
vzotova and cygnusv committed Oct 24, 2023
1 parent 6ed49bc commit 094b765
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 31 deletions.
12 changes: 6 additions & 6 deletions contracts/staking/IStaking.sol
Original file line number Diff line number Diff line change
Expand Up @@ -185,16 +185,16 @@ interface IStaking {
/// called only by the delegation owner or the staking provider.
function unstakeKeep(address stakingProvider) external;

/// @notice Sets the legacy NU staking contract active stake amount cached
/// in T staking contract to 0. Reverts if there is at least one
/// @notice Sets to 0 the amount of T that is cached from the legacy
/// NU staking contract. Reverts if there is at least one
/// authorization higher than the sum of remaining legacy NU stake
/// and liquid T stake for that staking provider or if the unstaked
/// and native T stake for that staking provider or if the unstaked
/// amount is higher than the cached legacy stake amount. If succeeded,
/// the legacy NU stake can be partially or fully undelegated on
/// the legacy staking contract. This function allows to unstake
/// the legacy NU staking contract. This function allows to unstake
/// from NU staking contract while still being able to operate in
/// T network and earning rewards based on the liquid T staked.
/// Can be called only by the delegation owner or the staking provider.
/// T network and earning rewards based on the native T staked.
/// Can be called only by the stake owner or the staking provider.
function unstakeNu(address stakingProvider) external;

/// @notice Sets cached legacy stake amount to 0, sets the liquid T stake
Expand Down
20 changes: 9 additions & 11 deletions contracts/staking/TokenStaking.sol
Original file line number Diff line number Diff line change
Expand Up @@ -664,16 +664,16 @@ contract TokenStaking is Initializable, IStaking, Checkpoints {
decreaseStakeCheckpoint(stakingProvider, keepInTStake);
}

/// @notice Sets the legacy NU staking contract active stake amount cached
/// in T staking contract to 0. Reverts if there is at least one
/// @notice Sets to 0 the amount of T that is cached from the legacy
/// NU staking contract. Reverts if there is at least one
/// authorization higher than the sum of remaining legacy NU stake
/// and liquid T stake for that staking provider or if the unstaked
/// and native T stake for that staking provider or if the unstaked
/// amount is higher than the cached legacy stake amount. If succeeded,
/// the legacy NU stake can be partially or fully undelegated on
/// the legacy staking contract. This function allows to unstake
/// the legacy NU staking contract. This function allows to unstake
/// from NU staking contract while still being able to operate in
/// T network and earning rewards based on the liquid T staked.
/// Can be called only by the delegation owner or the staking provider.
/// T network and earning rewards based on the native T staked.
/// Can be called only by the stake owner or the staking provider.
/// @dev This function (or `unstakeAll`) must be called before `withdraw`
/// in NuCypher staking contract. Otherwise NU tokens can't be
/// unlocked.
Expand Down Expand Up @@ -1244,11 +1244,9 @@ contract TokenStaking is Initializable, IStaking, Checkpoints {
stakingProviderStruct.keepInTStake +
stakingProviderStruct.nuInTStake;
// slash T
if (tAmountToSlash <= stakingProviderStruct.tStake) {
tAmountToBurn = tAmountToSlash;
} else {
tAmountToBurn = stakingProviderStruct.tStake;
}
tAmountToBurn = MathUpgradeable
.min(tAmountToSlash, stakingProviderStruct.tStake)
.toUint96();
stakingProviderStruct.tStake -= tAmountToBurn;
tAmountToSlash -= tAmountToBurn;

Expand Down
26 changes: 12 additions & 14 deletions docs/rfc-1-staking-contract.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,8 @@ network throughput without compromising the security of the owners’ stake.

This proposal aims at implementing a minimum viable staking contract version
allowing to support native T delegations in all applications developed against
this staking contract version. It means that stakers will be able to participate
in all applications developed against this staking contract version on equal rules.
The functionality of the staking contract can be further extended by the
upgradeability of the contract code.
this staking contract version. The functionality of the staking contract can be
further extended by the upgradeability of the contract code.

=== Terminology

Expand Down Expand Up @@ -131,9 +129,9 @@ increase the authorization for applications. This increases the probability of b
chosen for work in the application but is only effective for future checks of the
authorized amount.

Stakers can only top-up their stakes with a liquid T.
Stakes can only be topped-up with liquid T.

Anyone can execute a stake top-up for a staking provider using a liquid T.
Anyone can execute a stake top-up for a staking provider using liquid T.
Stake top-up does not automatically increase authorization levels for applications.
Stake top-up is a one-step process and does not require any delay.

Expand Down Expand Up @@ -308,14 +306,14 @@ delegation owner or the staking provider.

==== `unstakeNu(address stakingProvider, uint96 amount) external onlyOwnerOrStakingProvider(stakingProvider)`

Reduces cached legacy NU stake amount by `amount`. Reverts if there is at least
one authorization higher than the sum of remaining legacy NU stake and liquid T
stake for that provider or if amount is higher than the cached legacy stake
amount. If succeeded, the legacy NU stake can be partially or fully undelegated
on the legacy staking contract. This function allows to unstake from NU staking
contract while sill being able to operate in T network and earning rewards based
on the liquid T staked. Can be called only by the delegation owner or the
staking provider.
Sets to 0 the amount of T that is cached from the legacy NU staking contract.
Reverts if there is at least one authorization higher than the sum of remaining
legacy NU stake and native T stake for that staking provider or if the unstaked
amount is higher than the cached legacy stake amount. If succeeded, the legacy
NU stake can be partially or fully undelegated on the legacy NU staking contract.
This function allows to unstake from NU staking contract while still being able
to operate in T network and earning rewards based on the native T staked.
Can be called only by the stake owner or the staking provider.

==== `unstakeAll(address stakingProvider) external onlyOwnerOrStakingProvider(stakingProvider)`

Expand Down

0 comments on commit 094b765

Please sign in to comment.