Previous ATX is not checked to be the newest valid ATX by Smesher when validating incoming ATX
High severity
GitHub Reviewed
Published
May 10, 2024
in
spacemeshos/go-spacemesh
•
Updated May 14, 2024
Description
Published to the GitHub Advisory Database
May 10, 2024
Reviewed
May 10, 2024
Published by the National Vulnerability Database
May 14, 2024
Last updated
May 14, 2024
Impact
Nodes can publish ATXs which reference the incorrect previous ATX of the Smesher that created the ATX. ATXs are expected to form a single chain from the newest to the first ATX ever published by an identity. Allowing Smeshers to reference an earlier (but not the latest) ATX as previous breaks this protocol rule and can serve as an attack vector where Nodes are rewarded for holding their PoST data for less than one epoch but still being eligible for rewards.
Patches
Workarounds
n/a
References
Spacemesh protocol whitepaper: https://spacemesh.io/blog/spacemesh-white-paper-1/, specifically sections 4.4.2 ("ATX Contents") and 4.4.3 ("ATX validity")
References