Skip to content

Commit

Permalink
Increment Rebalance Period by 1 Day (#1308)
Browse files Browse the repository at this point in the history
This PR increments the rebalance period to (`unbonding_period + 1`), to avoid any race conditions with the timing of rebalance ICAs
  • Loading branch information
shellvish authored Dec 11, 2024
1 parent ac98fbc commit 7355bec
Showing 1 changed file with 6 additions and 1 deletion.
7 changes: 6 additions & 1 deletion x/stakeibc/keeper/rebalance.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,12 @@ func (k Keeper) RebalanceAllHostZones(ctx sdk.Context) {
}

for _, hostZone := range k.GetAllActiveHostZone(ctx) {
if dayEpoch.EpochNumber%hostZone.UnbondingPeriod != 0 {
// We add 1 to the UnbondingPeriod to avoid any race conditions
// In particular, you can only rebalance _away_ from a validator once per UnbondingPeriod
// Roughly half the time, a rebalance message will get sent a few seconds _before_
// the last rebalance fully completed. By adding an extra day, we ensure that
// all rebalances are completed before initiating any new ones
if dayEpoch.EpochNumber%(hostZone.UnbondingPeriod+1) != 0 {
k.Logger(ctx).Info(utils.LogWithHostZone(hostZone.ChainId,
"Host does not rebalance this epoch (Unbonding Period: %d, Epoch: %d)", hostZone.UnbondingPeriod, dayEpoch.EpochNumber))
continue
Expand Down

0 comments on commit 7355bec

Please sign in to comment.