mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-10 04:51:20 +00:00
66 lines
1.7 KiB
Go
66 lines
1.7 KiB
Go
package download
|
|
|
|
import (
|
|
"context"
|
|
"math/big"
|
|
|
|
"github.com/ledgerwatch/turbo-geth/common"
|
|
"github.com/ledgerwatch/turbo-geth/core/types"
|
|
"github.com/ledgerwatch/turbo-geth/eth/protocols/eth"
|
|
proto_sentry "github.com/ledgerwatch/turbo-geth/gointerfaces/sentry"
|
|
"github.com/ledgerwatch/turbo-geth/log"
|
|
"github.com/ledgerwatch/turbo-geth/rlp"
|
|
"google.golang.org/grpc"
|
|
)
|
|
|
|
// Methods of sentry called by Core
|
|
|
|
func (cs *ControlServerImpl) PropagateNewBlockHashes(ctx context.Context, hash common.Hash, number uint64) {
|
|
cs.lock.RLock()
|
|
defer cs.lock.RUnlock()
|
|
data, err := rlp.EncodeToBytes(ð.NewBlockHashesPacket{
|
|
{
|
|
Hash: hash,
|
|
Number: number,
|
|
},
|
|
})
|
|
if err != nil {
|
|
log.Error("propagateNewBlockHashes", "error", err)
|
|
return
|
|
}
|
|
req := &proto_sentry.OutboundMessageData{
|
|
Id: proto_sentry.MessageId_NewBlockHashes,
|
|
Data: data,
|
|
}
|
|
for _, sentry := range cs.sentries {
|
|
_, err = sentry.SendMessageToAll(ctx, req, &grpc.EmptyCallOption{})
|
|
if err != nil {
|
|
log.Error("propagateNewBlockHashes", "error", err)
|
|
}
|
|
}
|
|
}
|
|
|
|
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,
|
|
},
|
|
}
|
|
for _, sentry := range cs.sentries {
|
|
if _, err = sentry.SendMessageToRandomPeers(ctx, &req, &grpc.EmptyCallOption{}); err != nil {
|
|
log.Error("broadcastNewBlock", "error", err)
|
|
}
|
|
}
|
|
}
|