2021-04-06 05:54:50 +00:00
|
|
|
package download
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"math/big"
|
|
|
|
|
2021-05-20 18:25:53 +00:00
|
|
|
"github.com/ledgerwatch/erigon/core/types"
|
|
|
|
"github.com/ledgerwatch/erigon/eth/protocols/eth"
|
|
|
|
proto_sentry "github.com/ledgerwatch/erigon/gointerfaces/sentry"
|
|
|
|
"github.com/ledgerwatch/erigon/log"
|
|
|
|
"github.com/ledgerwatch/erigon/rlp"
|
|
|
|
"github.com/ledgerwatch/erigon/turbo/stages/headerdownload"
|
2021-04-06 05:54:50 +00:00
|
|
|
"google.golang.org/grpc"
|
|
|
|
)
|
|
|
|
|
2021-04-07 08:54:25 +00:00
|
|
|
// Methods of sentry called by Core
|
|
|
|
|
2021-05-01 20:03:51 +00:00
|
|
|
func (cs *ControlServerImpl) PropagateNewBlockHashes(ctx context.Context, announces []headerdownload.Announce) {
|
2021-04-06 05:54:50 +00:00
|
|
|
cs.lock.RLock()
|
|
|
|
defer cs.lock.RUnlock()
|
2021-05-01 20:03:51 +00:00
|
|
|
typedRequest := make(eth.NewBlockHashesPacket, len(announces))
|
|
|
|
for i := range announces {
|
|
|
|
typedRequest[i].Hash = announces[i].Hash
|
|
|
|
typedRequest[i].Number = announces[i].Number
|
|
|
|
}
|
|
|
|
data, err := rlp.EncodeToBytes(&typedRequest)
|
2021-04-06 05:54:50 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Error("propagateNewBlockHashes", "error", err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
req := &proto_sentry.OutboundMessageData{
|
|
|
|
Id: proto_sentry.MessageId_NewBlockHashes,
|
|
|
|
Data: data,
|
|
|
|
}
|
2021-04-07 08:54:25 +00:00
|
|
|
for _, sentry := range cs.sentries {
|
|
|
|
_, err = sentry.SendMessageToAll(ctx, req, &grpc.EmptyCallOption{})
|
|
|
|
if err != nil {
|
|
|
|
log.Error("propagateNewBlockHashes", "error", err)
|
|
|
|
}
|
2021-04-06 05:54:50 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (cs *ControlServerImpl) BroadcastNewBlock(ctx context.Context, block *types.Block, td *big.Int) {
|
|
|
|
cs.lock.RLock()
|
|
|
|
defer cs.lock.RUnlock()
|
|
|
|
data, err := rlp.EncodeToBytes(ð.NewBlockPacket{
|
|
|
|
Block: block,
|
|
|
|
TD: td,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
log.Error("broadcastNewBlock", "error", err)
|
|
|
|
}
|
|
|
|
req := proto_sentry.SendMessageToRandomPeersRequest{
|
|
|
|
MaxPeers: 1024,
|
|
|
|
Data: &proto_sentry.OutboundMessageData{
|
|
|
|
Id: proto_sentry.MessageId_NewBlock,
|
|
|
|
Data: data,
|
|
|
|
},
|
|
|
|
}
|
2021-04-07 08:54:25 +00:00
|
|
|
for _, sentry := range cs.sentries {
|
|
|
|
if _, err = sentry.SendMessageToRandomPeers(ctx, &req, &grpc.EmptyCallOption{}); err != nil {
|
|
|
|
log.Error("broadcastNewBlock", "error", err)
|
|
|
|
}
|
2021-04-06 05:54:50 +00:00
|
|
|
}
|
|
|
|
}
|