diff --git a/backend/pkg/api/services/service_slot_viz.go b/backend/pkg/api/services/service_slot_viz.go index 95fad1b69..2ebf68437 100644 --- a/backend/pkg/api/services/service_slot_viz.go +++ b/backend/pkg/api/services/service_slot_viz.go @@ -228,6 +228,9 @@ func (s *Services) updateSlotVizData() error { dutiesInfo.SlotSyncParticipated[duty.Slot] = make(map[constypes.ValidatorIndex]bool, 0) partValidators := utils.GetParticipatingSyncCommitteeValidators(duty.SyncAggregateBits, dutiesInfo.TotalSyncAssignmentsForEpoch[utils.EpochOfSlot(duty.Slot)]) + if len(partValidators) == 0 { + log.Error(nil, "no participating sync validators found", 0, map[string]interface{}{"slot": duty.Slot}) + } for _, validator := range partValidators { dutiesInfo.SlotSyncParticipated[duty.Slot][validator] = true } diff --git a/backend/pkg/commons/utils/utils.go b/backend/pkg/commons/utils/utils.go index 73844a5de..20c45e829 100644 --- a/backend/pkg/commons/utils/utils.go +++ b/backend/pkg/commons/utils/utils.go @@ -221,6 +221,9 @@ func SortedUniqueUint64(arr []uint64) []uint64 { } func GetParticipatingSyncCommitteeValidators(syncAggregateBits []byte, validators []uint64) []uint64 { + if len(validators) != len(syncAggregateBits)*8 { + return nil + } participatingValidators := []uint64{} for i := 0; i < len(syncAggregateBits)*8; i++ { val := validators[i]