Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Oyster Secret Storage Implementation #14

Open
wants to merge 65 commits into
base: master
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
4ee59da
secret store changes added
rajatlko13 Sep 23, 2024
57eb506
comments updated
rajatlko13 Sep 23, 2024
a3e63d6
more functions added to SecretStorage contract
rajatlko13 Sep 24, 2024
738a5e0
secret store contract splitted
rajatlko13 Sep 24, 2024
c139ef0
selectedEnclaves added to SecretStoreCreated event
rajatlko13 Sep 25, 2024
53996b4
SecretStoreCreated event updated
rajatlko13 Sep 25, 2024
ad101d9
secret store contracts renamed and other post review updates
rajatlko13 Sep 26, 2024
047b741
contract updates pushed
rajatlko13 Sep 27, 2024
2678318
secret store deployment script pushed
rajatlko13 Sep 27, 2024
cd9eb9b
secret store deployment script updated
rajatlko13 Sep 27, 2024
7c5a194
secret store contract updates
rajatlko13 Sep 30, 2024
4acc2d6
test cases pushed for SecretStore
rajatlko13 Sep 30, 2024
84b0cce
Secret Manager test cases added
rajatlko13 Oct 1, 2024
e811930
usdc value checks added to SecretManager test cases
rajatlko13 Oct 1, 2024
af342f4
indentation fixed in secret store test cases
rajatlko13 Oct 2, 2024
6b6b13e
Merge branch 'master' into rajat/secret-store
rajatlko13 Oct 2, 2024
ce1166c
addChainGlobal() logic updated for duplicate chains
rajatlko13 Oct 2, 2024
665d901
indentation fix
rajatlko13 Oct 2, 2024
2fbc7f9
test cases updated
rajatlko13 Oct 3, 2024
047593d
added check for all selected enclaves acknowledgement before end time…
rajatlko13 Oct 8, 2024
6c01211
updated logic for mark store alive/dead
rajatlko13 Oct 10, 2024
2806a05
secret contracts updated
rajatlko13 Oct 14, 2024
936136e
underflow condition fixed in secret store payment logic
rajatlko13 Oct 14, 2024
698ca2d
added ack fail logic for replaced stores
rajatlko13 Oct 14, 2024
77836ab
terminate and remove secret functions updated
rajatlko13 Oct 14, 2024
8f331a2
updates in ack fail function
rajatlko13 Oct 15, 2024
a2dca16
fixed usdc payment issue for dead store marked in the last epoch
rajatlko13 Oct 16, 2024
87f5183
review fixes for usdc payment for secret
rajatlko13 Oct 17, 2024
e097254
contracts and test cases updated
rajatlko13 Oct 21, 2024
605979e
Alive check signature fix done
rajatlko13 Nov 4, 2024
5d9fb9c
bug fix in contract and UTs updated
rajatlko13 Nov 4, 2024
bcc1449
fixed function getCurrentConfirmedUsdcDeposit()
rajatlko13 Nov 4, 2024
2ef609c
quick fix in _markEnclaveDead()
rajatlko13 Nov 4, 2024
78a6a81
missing test cases added for SecretStore
rajatlko13 Nov 5, 2024
6ae9c3b
mark dead logic updated in SecretManager
rajatlko13 Nov 15, 2024
8fdc10b
nit fix - function name updated
rajatlko13 Nov 15, 2024
ed8e74e
storeSecretIds and deadTimestamp mapping moved to SecretStore contract
rajatlko13 Nov 15, 2024
4814c84
markAlive() updated
rajatlko13 Nov 19, 2024
0807a46
markAlive() logic fix
rajatlko13 Nov 19, 2024
b92efce
nit fix
rajatlko13 Nov 21, 2024
b741bad
secret store slashing logic updated
rajatlko13 Nov 22, 2024
492c7f7
secret store slashing logic bug resolved
rajatlko13 Nov 26, 2024
d700780
markAlive bug fix
rajatlko13 Nov 27, 2024
ffe578b
secret store test cases updated
rajatlko13 Nov 27, 2024
16b32e0
markDead gas estimate script pushed
rajatlko13 Nov 28, 2024
556cd82
secret store + job allocation changes pushed
rajatlko13 Dec 3, 2024
6a72098
executors code combined in secret store contract
rajatlko13 Dec 4, 2024
2d1373e
review bug fixes
rajatlko13 Dec 4, 2024
ecd6ca3
function logic updated
rajatlko13 Dec 5, 2024
3d986cb
SecretStore contract splitted
rajatlko13 Dec 6, 2024
ac6280a
review bug fixes
rajatlko13 Dec 9, 2024
aed7337
new structure for secret store and executors contract
rajatlko13 Dec 15, 2024
4d5c420
review issues fixed
rajatlko13 Dec 17, 2024
558fd1f
reputation logic moved to Executors
rajatlko13 Dec 17, 2024
26e5098
updated logic for adding back nodes to the tree post selection
rajatlko13 Dec 17, 2024
7a89e1c
slash store exponent issue resolved
rajatlko13 Dec 19, 2024
d2e8275
review bug fixes and updated test cases
rajatlko13 Dec 23, 2024
27bf83a
bug fixes and jobs UTs updated
rajatlko13 Dec 24, 2024
7f548e1
renounceSecrets function added
rajatlko13 Dec 25, 2024
139e91c
renounceSecret review fixes
rajatlko13 Dec 31, 2024
179a848
renounceSecrets() moved to SecretStore
rajatlko13 Dec 31, 2024
d3dcefe
quick fixes
rajatlko13 Dec 31, 2024
d8428dd
UT bug fixes
rajatlko13 Jan 6, 2025
f30c569
createJob function updated - only select from secret stores
rajatlko13 Jan 7, 2025
9363615
test cases updated
rajatlko13 Jan 9, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 17 additions & 1 deletion contracts/secret-storage/TeeManager.sol
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,8 @@ contract TeeManager is
error TeeManagerZeroAddressStakingToken();
/// @notice Thrown when the provided minimum stake amount is zero.
error TeeManagerZeroMinStakeAmount();
/// @notice Thrown when the provided slash parameters are invalid.
error TeeManagerInvalidSlashParams();

/**
* @dev Initializes the logic contract without any admins, safeguarding against takeover.
Expand Down Expand Up @@ -62,6 +64,8 @@ contract TeeManager is
STAKING_TOKEN = _stakingToken;
MIN_STAKE_AMOUNT = _minStakeAmount;

if(_slashPercentInBips > _slashMaxBips || _slashMaxBips > 1e6)
revert TeeManagerInvalidSlashParams();
SLASH_PERCENT_IN_BIPS = _slashPercentInBips;
SLASH_MAX_BIPS = _slashMaxBips;
}
Expand Down Expand Up @@ -554,7 +558,19 @@ contract TeeManager is
) internal {
uint256 stakeAmount = teeNodes[_enclaveAddress].stakeAmount;
// compounding slashing formula: remainingStakeAmount = stakeAmount * (1 - (r/100)) ^ n
uint256 remainingStakeAmount = stakeAmount * ((SLASH_MAX_BIPS - SLASH_PERCENT_IN_BIPS) ** _missedEpochsCount) / (SLASH_MAX_BIPS ** _missedEpochsCount);
// uint256 remainingStakeAmount = stakeAmount * ((SLASH_MAX_BIPS - SLASH_PERCENT_IN_BIPS) ** _missedEpochsCount) / (SLASH_MAX_BIPS ** _missedEpochsCount);

uint256 remainingStakeAmount = stakeAmount;
uint256 iterations = _missedEpochsCount / 12;
vg-27 marked this conversation as resolved.
Show resolved Hide resolved
for (uint256 i = 0; i < iterations; i++) {
remainingStakeAmount = remainingStakeAmount * ((SLASH_MAX_BIPS - SLASH_PERCENT_IN_BIPS) ** 12) / (SLASH_MAX_BIPS ** 12);
vg-27 marked this conversation as resolved.
Show resolved Hide resolved
vg-27 marked this conversation as resolved.
Show resolved Hide resolved
}

uint256 remainingEpochs = _missedEpochsCount % 12;
if (remainingEpochs > 0) {
remainingStakeAmount = remainingStakeAmount * ((SLASH_MAX_BIPS - SLASH_PERCENT_IN_BIPS) ** remainingEpochs) / (SLASH_MAX_BIPS ** remainingEpochs);
}

uint256 slashAmount = stakeAmount - remainingStakeAmount;
teeNodes[_enclaveAddress].stakeAmount = remainingStakeAmount;

Expand Down