Skip to content

Commit

Permalink
refactor
Browse files Browse the repository at this point in the history
  • Loading branch information
StefanBratanov committed Oct 17, 2023
1 parent f2b9bf9 commit 37bc64c
Showing 1 changed file with 13 additions and 13 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -125,19 +125,19 @@ public void onUpdatedValidatorStatuses(
final boolean possibleMissingEvents) {
proposerConfigPropertiesProvider
.refresh()
.thenRun(
() -> {
.thenCompose(
__ -> {
if (!isReadyToRegister()) {
return;
return SafeFuture.COMPLETE;
}
final List<Validator> validators =
getValidatorsRequiringRegistration(newValidatorStatuses);
if (validators.isEmpty()) {
LOG.debug("No validator registrations are required to be sent");
return;
return SafeFuture.COMPLETE;
}
if (registrationNeedsToBeRun(possibleMissingEvents)) {
registerValidators(validators, true);
return registerValidators(validators, true);
} else {
final List<Validator> newValidators =
validators.stream()
Expand All @@ -146,11 +146,12 @@ public void onUpdatedValidatorStatuses(
!cachedValidatorRegistrations.containsKey(validator.getPublicKey()))
.toList();
if (newValidators.isEmpty()) {
return;
return SafeFuture.COMPLETE;
}
registerValidators(newValidators, false);
return registerValidators(newValidators, false);
}
});
})
.finish(VALIDATOR_LOGGER::registeringValidatorsFailed);
}

public int getNumberOfCachedRegistrations() {
Expand Down Expand Up @@ -203,20 +204,19 @@ private boolean registrationNeedsToBeRun(final boolean possibleMissingEvents) {
.isGreaterThanOrEqualTo(Constants.EPOCHS_PER_VALIDATOR_REGISTRATION_SUBMISSION);
}

private void registerValidators(
private SafeFuture<Void> registerValidators(
final List<Validator> validators, final boolean updateLastRunEpoch) {
if (!registrationInProgress.compareAndSet(false, true)) {
LOG.warn(
"Validator registration(s) is still in progress. Will skip sending registration(s).");
return;
return SafeFuture.COMPLETE;
}
if (updateLastRunEpoch) {
lastRunEpoch.set(currentEpoch.get());
}

processInBatches(validators)
.handleException(VALIDATOR_LOGGER::registeringValidatorsFailed)
.always(
return processInBatches(validators)
.alwaysRun(
() -> {
registrationInProgress.set(false);
cleanupCache(ownedValidators.getActiveValidators());
Expand Down

0 comments on commit 37bc64c

Please sign in to comment.