-
Notifications
You must be signed in to change notification settings - Fork 5
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
feat: reorg handling #44
base: main
Are you sure you want to change the base?
Conversation
// QueryIsBlockBabylonFinalizedFromBabylon returns the finality status of a block by | ||
// querying Babylon chain directly | ||
rpc QueryIsBlockBabylonFinalizedFromBabylon(QueryIsBlockBabylonFinalizedRequest) | ||
returns (QueryIsBlockFinalizedResponse); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this seems irrelevant to the PR
do you know why we didn't include it? IIRC we intentionally removed this to prevent DoS attack. plus, there is no call site of this grpc method anyway
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we can remove it from this PR and add it to a new one. It is needed for debugging the isBlockFinalized call from Babylon. I was trying to call it during most recent debug of devnet-7 but realized we never exposed the grpc method.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we can remove it from this PR and add it to a new one
it's fine to keep it here but the question is whether we should expose it. probably fine for now but we need to be aware of the potential DoS attacks
does calling this function making babylon rpc calls every time or it's reading from the db? if it's calling the Babylon rpc, then there is a DoS attack vector
Summary
This PR adds reorg handling to the FG.
The current FG cannot handle L2 block reorgs because the new block hash breaks the finality votes query. This causes the finalized head to become stuck.
We implement a new whitelist system where:
Test plan