bsc/eth/handler_trust.go
dean 0483394ef6
[R4R] Separate Processing and State Verification on BSC (#926)
Implement Separate Processing and State Verification on BSC
2022-07-04 09:49:07 +08:00

53 lines
1.6 KiB
Go

package eth
import (
"fmt"
"github.com/ethereum/go-ethereum/core"
"github.com/ethereum/go-ethereum/eth/protocols/trust"
"github.com/ethereum/go-ethereum/p2p/enode"
)
// trustHandler implements the trust.Backend interface to handle the various network
// packets that are sent as replies or broadcasts.
type trustHandler handler
func (h *trustHandler) Chain() *core.BlockChain { return h.chain }
// RunPeer is invoked when a peer joins on the `snap` protocol.
func (h *trustHandler) RunPeer(peer *trust.Peer, hand trust.Handler) error {
return (*handler)(h).runTrustExtension(peer, hand)
}
// PeerInfo retrieves all known `trust` information about a peer.
func (h *trustHandler) PeerInfo(id enode.ID) interface{} {
if p := h.peers.peer(id.String()); p != nil {
if p.trustExt != nil {
return p.trustExt.info()
}
}
return nil
}
// Handle is invoked from a peer's message handler when it receives a new remote
// message that the handler couldn't consume and serve itself.
func (h *trustHandler) Handle(peer *trust.Peer, packet trust.Packet) error {
switch packet := packet.(type) {
case *trust.RootResponsePacket:
verifyResult := &core.VerifyResult{
Status: packet.Status,
BlockNumber: packet.BlockNumber,
BlockHash: packet.BlockHash,
Root: packet.Root,
}
if vm := h.Chain().Validator().RemoteVerifyManager(); vm != nil {
vm.HandleRootResponse(verifyResult, peer.ID())
return nil
}
return fmt.Errorf("verify manager is nil which is unexpected")
default:
return fmt.Errorf("unexpected trust packet type: %T", packet)
}
}