mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-14 05:58:19 +00:00
35dc8c31fa
* Add in context * use better function signatures * add in chainservice * fix rpc requests * add in test * fix tests * add in comments * Update beacon-chain/sync/rpc_chunked_response.go Co-authored-by: terence tsao <terence@prysmaticlabs.com> * Update beacon-chain/sync/rpc_send_request.go Co-authored-by: terence tsao <terence@prysmaticlabs.com> * rename files * fmt Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> Co-authored-by: terence tsao <terence@prysmaticlabs.com> Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
56 lines
1.4 KiB
Go
56 lines
1.4 KiB
Go
package sync
|
|
|
|
import (
|
|
"errors"
|
|
|
|
"github.com/libp2p/go-libp2p-core/network"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/blockchain"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/p2p"
|
|
)
|
|
|
|
// writes peer's current context for the expected payload to the stream.
|
|
func writeContextToStream(stream network.Stream, chain blockchain.ChainInfoFetcher) error {
|
|
rpcCtx, err := rpcContext(stream, chain)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
// Exit early if there is an empty context.
|
|
if len(rpcCtx) == 0 {
|
|
return nil
|
|
}
|
|
_, err = stream.Write(rpcCtx)
|
|
return err
|
|
}
|
|
|
|
// reads any attached context-bytes to the payload.
|
|
func readContextFromStream(stream network.Stream, chain blockchain.ChainInfoFetcher) ([]byte, error) {
|
|
rpcCtx, err := rpcContext(stream, chain)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if len(rpcCtx) == 0 {
|
|
return []byte{}, nil
|
|
}
|
|
// Read context (fork-digest) from stream
|
|
b := make([]byte, 4)
|
|
if _, err := stream.Read(b); err != nil {
|
|
return nil, err
|
|
}
|
|
return b, nil
|
|
}
|
|
|
|
// retrieve expected context depending on rpc topic schema version.
|
|
func rpcContext(stream network.Stream, chain blockchain.ChainInfoFetcher) ([]byte, error) {
|
|
_, _, version, err := p2p.TopicDeconstructor(string(stream.Protocol()))
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
switch version {
|
|
case p2p.SchemaVersionV1:
|
|
// Return empty context for a v1 method.
|
|
return []byte{}, nil
|
|
default:
|
|
return nil, errors.New("invalid version of %s registered for topic: %s")
|
|
}
|
|
}
|