forked from TrueCloudLab/neoneo-go
Added getheaders payload + abstracted the fields.
This commit is contained in:
parent
04e9060484
commit
63072ebe75
3 changed files with 73 additions and 13 deletions
|
@ -7,24 +7,17 @@ import (
|
||||||
. "github.com/anthdm/neo-go/pkg/util"
|
. "github.com/anthdm/neo-go/pkg/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
// GetBlocks payload
|
// HashStartStop contains fields and methods to be shared with the
|
||||||
type GetBlocks struct {
|
// "GetBlocks" and "GetHeaders" payload.
|
||||||
|
type HashStartStop struct {
|
||||||
// hash of latest block that node requests
|
// hash of latest block that node requests
|
||||||
HashStart []Uint256
|
HashStart []Uint256
|
||||||
// hash of last block that node requests
|
// hash of last block that node requests
|
||||||
HashStop Uint256
|
HashStop Uint256
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewGetBlocks return a pointer to a GetBlocks object.
|
|
||||||
func NewGetBlocks(start []Uint256, stop Uint256) *GetBlocks {
|
|
||||||
return &GetBlocks{
|
|
||||||
HashStart: start,
|
|
||||||
HashStop: stop,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// DecodeBinary implements the payload interface.
|
// DecodeBinary implements the payload interface.
|
||||||
func (p *GetBlocks) DecodeBinary(r io.Reader) error {
|
func (p *HashStartStop) DecodeBinary(r io.Reader) error {
|
||||||
var lenStart uint8
|
var lenStart uint8
|
||||||
|
|
||||||
err := binary.Read(r, binary.LittleEndian, &lenStart)
|
err := binary.Read(r, binary.LittleEndian, &lenStart)
|
||||||
|
@ -36,7 +29,7 @@ func (p *GetBlocks) DecodeBinary(r io.Reader) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// EncodeBinary implements the payload interface.
|
// EncodeBinary implements the payload interface.
|
||||||
func (p *GetBlocks) EncodeBinary(w io.Writer) error {
|
func (p *HashStartStop) EncodeBinary(w io.Writer) error {
|
||||||
err := binary.Write(w, binary.LittleEndian, uint8(len(p.HashStart)))
|
err := binary.Write(w, binary.LittleEndian, uint8(len(p.HashStart)))
|
||||||
err = binary.Write(w, binary.LittleEndian, p.HashStart)
|
err = binary.Write(w, binary.LittleEndian, p.HashStart)
|
||||||
err = binary.Write(w, binary.LittleEndian, p.HashStop)
|
err = binary.Write(w, binary.LittleEndian, p.HashStop)
|
||||||
|
@ -45,4 +38,17 @@ func (p *GetBlocks) EncodeBinary(w io.Writer) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Size implements the payload interface.
|
// Size implements the payload interface.
|
||||||
func (p *GetBlocks) Size() uint32 { return 0 }
|
func (p *HashStartStop) Size() uint32 { return 0 }
|
||||||
|
|
||||||
|
// GetBlocks payload
|
||||||
|
type GetBlocks struct {
|
||||||
|
HashStartStop
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewGetBlocks return a pointer to a GetBlocks object.
|
||||||
|
func NewGetBlocks(start []Uint256, stop Uint256) *GetBlocks {
|
||||||
|
p := &GetBlocks{}
|
||||||
|
p.HashStart = start
|
||||||
|
p.HashStop = stop
|
||||||
|
return p
|
||||||
|
}
|
||||||
|
|
17
pkg/network/payload/getheaders.go
Normal file
17
pkg/network/payload/getheaders.go
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
package payload
|
||||||
|
|
||||||
|
import "github.com/anthdm/neo-go/pkg/util"
|
||||||
|
|
||||||
|
// GetHeaders payload is the same as the "GetBlocks" payload.
|
||||||
|
type GetHeaders struct {
|
||||||
|
HashStartStop
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewGetHeaders return a pointer to a GetHeaders object.
|
||||||
|
func NewGetHeaders(start []util.Uint256, stop util.Uint256) *GetHeaders {
|
||||||
|
p := &GetHeaders{}
|
||||||
|
p.HashStart = start
|
||||||
|
p.HashStop = stop
|
||||||
|
|
||||||
|
return p
|
||||||
|
}
|
37
pkg/network/payload/getheaders_test.go
Normal file
37
pkg/network/payload/getheaders_test.go
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
package payload
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"crypto/sha256"
|
||||||
|
"reflect"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/anthdm/neo-go/pkg/util"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestGetHeadersEncodeDecode(t *testing.T) {
|
||||||
|
start := []util.Uint256{
|
||||||
|
sha256.Sum256([]byte("a")),
|
||||||
|
sha256.Sum256([]byte("b")),
|
||||||
|
}
|
||||||
|
stop := sha256.Sum256([]byte("c"))
|
||||||
|
|
||||||
|
p := NewGetHeaders(start, stop)
|
||||||
|
buf := new(bytes.Buffer)
|
||||||
|
if err := p.EncodeBinary(buf); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if have, want := buf.Len(), 1+64+32; have != want {
|
||||||
|
t.Fatalf("expecting a length of %d got %d", want, have)
|
||||||
|
}
|
||||||
|
|
||||||
|
pDecode := &GetHeaders{}
|
||||||
|
if err := pDecode.DecodeBinary(buf); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if !reflect.DeepEqual(p, pDecode) {
|
||||||
|
t.Fatalf("expecting both getheaders payloads to be equal %v and %v", p, pDecode)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue