package sync import ( "context" "fmt" "github.com/pkg/errors" types "github.com/prysmaticlabs/eth2-types" "github.com/prysmaticlabs/prysm/beacon-chain/cache" "github.com/prysmaticlabs/prysm/beacon-chain/core/helpers" eth "github.com/prysmaticlabs/prysm/proto/eth/v1alpha1" "github.com/prysmaticlabs/prysm/shared/params" "github.com/prysmaticlabs/prysm/shared/sliceutil" "google.golang.org/protobuf/proto" ) func (s *Service) committeeIndexBeaconAttestationSubscriber(_ context.Context, msg proto.Message) error { a, ok := msg.(*eth.Attestation) if !ok { return fmt.Errorf("message was not type *eth.Attestation, type=%T", msg) } if a.Data == nil { return errors.New("nil attestation") } s.setSeenCommitteeIndicesSlot(a.Data.Slot, a.Data.CommitteeIndex, a.AggregationBits) exists, err := s.cfg.AttPool.HasAggregatedAttestation(a) if err != nil { return errors.Wrap(err, "Could not determine if attestation pool has this atttestation") } if exists { return nil } return s.cfg.AttPool.SaveUnaggregatedAttestation(a) } func (s *Service) persistentSubnetIndices() []uint64 { return cache.SubnetIDs.GetAllSubnets() } func (s *Service) aggregatorSubnetIndices(currentSlot types.Slot) []uint64 { endEpoch := helpers.SlotToEpoch(currentSlot) + 1 endSlot := params.BeaconConfig().SlotsPerEpoch.Mul(uint64(endEpoch)) var commIds []uint64 for i := currentSlot; i <= endSlot; i++ { commIds = append(commIds, cache.SubnetIDs.GetAggregatorSubnetIDs(i)...) } return sliceutil.SetUint64(commIds) } func (s *Service) attesterSubnetIndices(currentSlot types.Slot) []uint64 { endEpoch := helpers.SlotToEpoch(currentSlot) + 1 endSlot := params.BeaconConfig().SlotsPerEpoch.Mul(uint64(endEpoch)) var commIds []uint64 for i := currentSlot; i <= endSlot; i++ { commIds = append(commIds, cache.SubnetIDs.GetAttesterSubnetIDs(i)...) } return sliceutil.SetUint64(commIds) }