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

TRST audit fixes for HorizonStaking contract #1073

Merged
merged 23 commits into from
Dec 17, 2024
Merged

Conversation

Maikol
Copy link
Member

@Maikol Maikol commented Nov 28, 2024

This PR fixes the following issues:

  • TRST-H-2 Core thawing logic of Horizon staking can be broken due to collision in data structures
  • TRST-H-3 An attacker could prevent a delegator from ever withdrawing their tokens
  • TRST-H-4 The last withdrawal from a provision or delegation could permanently revert due to accounting flaw in slashing
  • TRST-H-6 During the transition period, legacy allocations cannot be slashed
  • TRST-H-7 Delegators that began undelegation before the transition would not be able to withdraw them
  • TRST-M-3 An attacker could make the minimum delegation amount arbitrarily large and prevent competing delegations
  • TRST-M-11 After the transition period, locked amount would still not be available for use
  • TRST-M-12 The operator check in closeAllocations() will not work, indexers must close by themselves
  • TRST-L-3 The getThawedTokens() function could return a wrong amount leading to integration risks
  • TRST-R-1 Improve event structure
  • TRST-R-7 Thawing shares should be rounded up to protect from early unlocking of tokens
  • TRST-R-9 Documentation errors

Copy link

openzeppelin-code bot commented Nov 28, 2024

TRST audit fixes for HorizonStaking contract

Generated at commit: 399b7a91f89248d95a224dc5369286b3f39ec590

🚨 Report Summary

Severity Level Results
Contracts Critical
High
Medium
Low
Note
Total
2
4
0
15
39
60
Dependencies Critical
High
Medium
Low
Note
Total
0
0
0
0
0
0

For more details view the full report in OpenZeppelin Code Inspector

@Maikol Maikol force-pushed the mde/trust-staking-fixes branch from 9e05f2f to edb248c Compare November 28, 2024 16:29
@Maikol Maikol force-pushed the mde/trust-staking-fixes branch from edb248c to ce749be Compare November 28, 2024 18:26
@Maikol Maikol marked this pull request as ready for review November 29, 2024 19:49
@Maikol Maikol changed the title fix: separate delegation and provision thaw request lists (TRST-H02) TRST audit fixes for HorizonStaking contract Dec 2, 2024
Copy link
Contributor

@tmigone tmigone left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some suggestions!

@Maikol Maikol requested review from pcarranzav and tmigone December 6, 2024 18:32
@Maikol Maikol force-pushed the mde/trust-staking-fixes branch from 6521be6 to 399b7a9 Compare December 16, 2024 15:33
Copy link
Contributor

@tmigone tmigone left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🔥

@tmigone tmigone merged commit 032e4a4 into horizon Dec 17, 2024
4 checks passed
@tmigone tmigone deleted the mde/trust-staking-fixes branch December 17, 2024 19:37
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants