neoneo-go/_pkg.dev/wire/payload/mheaders.go

83 lines
1.7 KiB
Go
Raw Normal View History

2019-02-25 22:44:14 +00:00
package payload
import (
"errors"
"io"
"github.com/CityOfZion/neo-go/pkg/wire/command"
"github.com/CityOfZion/neo-go/pkg/wire/util"
)
// HeadersMessage represents a Header(s) Message on the neo-network
2019-02-25 22:44:14 +00:00
type HeadersMessage struct {
Headers []*BlockBase
// Padding that is fixed to 0
_ uint8
}
// Users can at most request 2k header
const (
maxHeadersAllowed = 2000
)
var (
errMaxHeaders = errors.New("Maximum amount of headers allowed is 2000")
2019-02-25 22:44:14 +00:00
)
//NewHeadersMessage returns a HeadersMessage Object
2019-02-25 22:44:14 +00:00
func NewHeadersMessage() (*HeadersMessage, error) {
headers := &HeadersMessage{nil, 0}
return headers, nil
}
// AddHeader adds a header into the list of Headers.
// Since a header is just blockbase with padding, we use BlockBase
2019-02-25 22:44:14 +00:00
func (h *HeadersMessage) AddHeader(head *BlockBase) error {
if len(h.Headers)+1 > maxHeadersAllowed {
return errMaxHeaders
2019-02-25 22:44:14 +00:00
}
h.Headers = append(h.Headers, head)
return nil
}
// DecodePayload Implements Messager interface
func (h *HeadersMessage) DecodePayload(r io.Reader) error {
2019-02-25 22:44:14 +00:00
br := &util.BinReader{R: r}
lenHeaders := br.VarUint()
h.Headers = make([]*BlockBase, lenHeaders)
2019-02-25 22:44:14 +00:00
for i := 0; i < int(lenHeaders); i++ {
header := &BlockBase{}
header.DecodePayload(br)
var padding uint8
br.Read(&padding)
if padding != 0 {
return errPadding
2019-02-25 22:44:14 +00:00
}
h.Headers[i] = header
2019-02-25 22:44:14 +00:00
}
return br.Err
}
// EncodePayload Implements messager interface
func (h *HeadersMessage) EncodePayload(w io.Writer) error {
2019-02-25 22:44:14 +00:00
bw := &util.BinWriter{W: w}
bw.VarUint(uint64(len(h.Headers)))
for _, header := range h.Headers {
2019-02-25 22:44:14 +00:00
header.EncodePayload(bw)
bw.Write(uint8(0))
}
return bw.Err
}
// Command Implements messager interface
func (h *HeadersMessage) Command() command.Type {
2019-02-25 22:44:14 +00:00
return command.Headers
}