2020-02-19 22:26:14 +00:00
|
|
|
package beaconclient
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2021-02-22 23:20:57 +00:00
|
|
|
types "github.com/prysmaticlabs/eth2-types"
|
2021-06-02 23:49:52 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/prysm/proto/eth/v1alpha1"
|
2020-06-29 14:17:24 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/cmd"
|
2020-02-23 22:30:52 +00:00
|
|
|
"go.opencensus.io/trace"
|
2020-02-19 22:26:14 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// RequestHistoricalAttestations requests all indexed attestations for a
|
|
|
|
// given epoch from a beacon node via gRPC.
|
2021-01-20 14:39:07 +00:00
|
|
|
func (s *Service) RequestHistoricalAttestations(
|
2020-02-19 22:26:14 +00:00
|
|
|
ctx context.Context,
|
2021-02-09 10:05:22 +00:00
|
|
|
epoch types.Epoch,
|
2020-02-19 22:26:14 +00:00
|
|
|
) ([]*ethpb.IndexedAttestation, error) {
|
|
|
|
ctx, span := trace.StartSpan(ctx, "beaconclient.RequestHistoricalAttestations")
|
|
|
|
defer span.End()
|
|
|
|
indexedAtts := make([]*ethpb.IndexedAttestation, 0)
|
|
|
|
res := ðpb.ListIndexedAttestationsResponse{}
|
|
|
|
var err error
|
|
|
|
for {
|
2020-05-20 19:52:18 +00:00
|
|
|
if ctx.Err() != nil {
|
|
|
|
return nil, ctx.Err()
|
|
|
|
}
|
|
|
|
if res == nil {
|
|
|
|
res = ðpb.ListIndexedAttestationsResponse{}
|
|
|
|
}
|
2021-03-21 17:53:17 +00:00
|
|
|
res, err = s.cfg.BeaconClient.ListIndexedAttestations(ctx, ðpb.ListIndexedAttestationsRequest{
|
2020-03-23 20:22:37 +00:00
|
|
|
QueryFilter: ðpb.ListIndexedAttestationsRequest_Epoch{
|
|
|
|
Epoch: epoch,
|
2020-02-19 22:26:14 +00:00
|
|
|
},
|
2020-06-29 14:17:24 +00:00
|
|
|
PageSize: int32(cmd.Get().MaxRPCPageSize),
|
2020-02-19 22:26:14 +00:00
|
|
|
PageToken: res.NextPageToken,
|
|
|
|
})
|
|
|
|
if err != nil {
|
2020-05-20 19:52:18 +00:00
|
|
|
log.WithError(err).Errorf("could not request indexed attestations for epoch: %d", epoch)
|
2020-05-28 14:24:54 +00:00
|
|
|
break
|
2020-02-19 22:26:14 +00:00
|
|
|
}
|
|
|
|
indexedAtts = append(indexedAtts, res.IndexedAttestations...)
|
|
|
|
log.Infof(
|
|
|
|
"Retrieved %d/%d indexed attestations for epoch %d",
|
|
|
|
len(indexedAtts),
|
|
|
|
res.TotalSize,
|
|
|
|
epoch,
|
|
|
|
)
|
|
|
|
if res.NextPageToken == "" || res.TotalSize == 0 || len(indexedAtts) == int(res.TotalSize) {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return indexedAtts, nil
|
|
|
|
}
|