mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-16 07:48:20 +00:00
f2d95d16cc
* separated the encoding * picking random peer node * sending ping request * updated enconding and reading * requesting ping interval and more verbose vars * disconnecting from unresponsive peers * penalizing instead of disconnecting for irresponsiveness * closing stream for streamCodec * solved meged issues * changed back * separated const values * requesting ping interval to 1 sec * added closing of read and write stream && receiving responses! * fixecd typo * general sending request function * added constants of resqresp topics * fixed uncorrect name * refactored sending requests * added todo * little detail * moved to main * no need to sleep * sending request retries until timeout * type * lint
128 lines
2.6 KiB
Go
128 lines
2.6 KiB
Go
package ssz_snappy
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"reflect"
|
|
"sync"
|
|
|
|
ssz "github.com/ferranbt/fastssz"
|
|
"github.com/golang/snappy"
|
|
"github.com/ledgerwatch/erigon/cmd/lightclient/sentinel/proto"
|
|
"github.com/ledgerwatch/erigon/cmd/lightclient/sentinel/proto/p2p"
|
|
"github.com/libp2p/go-libp2p/core/network"
|
|
)
|
|
|
|
type StreamCodec struct {
|
|
s network.Stream
|
|
sr *snappy.Reader
|
|
|
|
mu sync.Mutex
|
|
}
|
|
|
|
func NewStreamCodec(
|
|
s network.Stream,
|
|
) proto.StreamCodec {
|
|
return &StreamCodec{
|
|
s: s,
|
|
sr: snappy.NewReader(s),
|
|
}
|
|
}
|
|
|
|
func (d *StreamCodec) Close() error {
|
|
if err := d.s.Close(); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (d *StreamCodec) CloseWriter() error {
|
|
if err := d.s.CloseWrite(); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (d *StreamCodec) CloseReader() error {
|
|
if err := d.s.CloseRead(); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// write packet to stream. will add correct header + compression
|
|
// will error if packet does not implement ssz.Marshaler interface
|
|
func (d *StreamCodec) WritePacket(pkt proto.Packet) (n int, err error) {
|
|
// if its a metadata request we dont write anything
|
|
if reflect.TypeOf(pkt) == reflect.TypeOf(&p2p.MetadataV1{}) || reflect.TypeOf(pkt) == reflect.TypeOf(&p2p.MetadataV2{}) {
|
|
return 0, nil
|
|
}
|
|
|
|
p, sw, err := EncodePacket(pkt, d.s)
|
|
if err != nil {
|
|
return 0, fmt.Errorf("Failed to write packet err=%s", err)
|
|
}
|
|
|
|
n, err = sw.Write(p)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
if err := sw.Flush(); err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
return n, nil
|
|
}
|
|
|
|
// write raw bytes to stream
|
|
func (d *StreamCodec) Write(payload []byte) (n int, err error) {
|
|
return d.s.Write(payload)
|
|
}
|
|
|
|
// read raw bytes to stream
|
|
func (d *StreamCodec) Read(b []byte) (n int, err error) {
|
|
return d.s.Read(b)
|
|
}
|
|
|
|
// read raw bytes to stream
|
|
func (d *StreamCodec) ReadByte() (b byte, err error) {
|
|
o := [1]byte{}
|
|
_, err = io.ReadFull(d.s, o[:])
|
|
if err != nil {
|
|
return
|
|
}
|
|
return o[0], nil
|
|
}
|
|
|
|
// decode into packet p, then return the packet context
|
|
func (d *StreamCodec) Decode(p proto.Packet) (ctx *proto.StreamContext, err error) {
|
|
ctx, err = d.readPacket(p)
|
|
return
|
|
}
|
|
|
|
func (d *StreamCodec) readPacket(p proto.Packet) (ctx *proto.StreamContext, err error) {
|
|
c := &proto.StreamContext{
|
|
Packet: p,
|
|
Stream: d.s,
|
|
Codec: d,
|
|
Protocol: d.s.Protocol(),
|
|
}
|
|
if val, ok := p.(ssz.Unmarshaler); ok {
|
|
ln, _, err := proto.ReadUvarint(d.s)
|
|
if err != nil {
|
|
return c, err
|
|
}
|
|
c.Raw = make([]byte, ln)
|
|
_, err = io.ReadFull(d.sr, c.Raw)
|
|
if err != nil {
|
|
return c, fmt.Errorf("readPacket: %w", err)
|
|
}
|
|
err = val.UnmarshalSSZ(c.Raw)
|
|
if err != nil {
|
|
return c, fmt.Errorf("readPacket: %w", err)
|
|
}
|
|
}
|
|
return c, nil
|
|
}
|