-
Notifications
You must be signed in to change notification settings - Fork 787
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
Add voluntary exit via validator manager #6612
base: unstable
Are you sure you want to change the base?
Conversation
} | ||
|
||
// Check validator status after publishing voluntary exit | ||
if exit_status { |
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.
The --status
is used to query the exit status of validators. The reason behind introducing it is:
In lighthouse account validator exit
, the status was shown after a sleep of, e.g., 12s
sleep(Duration::from_secs(spec.seconds_per_slot)).await; |
If we introduce a sleep here, then for each validator_to_exit
, it will sleep for 12s, which is not really UX friendly. For practical consideration, the user's priority may just want to first publish the exit messages for all validators.
While there is a way to tweak it so that it only sleeps once and not for the rest of validator_to_exit
(or shortening the sleep time), doing so will likely cause the exit status to be shown as:
Voluntary exit for Validator {} is waiting to be accepted into the beacon chain.
for the rest of validator_to_exit
as the head block is not yet updated, which is not really useful either.
So I ended up introducing this --status
flag to query the exit status separately. But I am not sure if this is a good idea.
Keen on hear the thoughts of reviewers on this.
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.
Looking good overall, just a few minor suggestions!
if validator_data.status == ValidatorStatus::ActiveOngoing | ||
&& updated_validator_data.status == ValidatorStatus::ActiveOngoing | ||
{ | ||
eprintln!("Voluntary exit for Validator {} is waiting to be accepted into the beacon chain.", validator_to_exit); |
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.
I would have thought that in practice, we would often just hit this case. Unless there's a block that includes the exit immediately after the post request?
Maybe if --status
is provided, there should be a loop over all validators after the messages have been posted, in which case most of them should have been included in blocks
Issue Addressed
--exit-epoch
flag to validator-manager #4303Proposed Changes
-Add voluntary exit feature to the validator manager
-Add delete all validators by using the keyword "all"
Additional Info
I reuse some code from the
lighthouse account validator exit
file:https://github.com/sigp/lighthouse/blob/stable/account_manager/src/validator/exit.rs
Thank you @michaelsproul for the help and guidance along the way