mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2024-12-29 19:27:36 +00:00
95c279325a
It's not network-tied any more, network is only needed to sign/verify. Unfortunately we still have to keep network in consensus data structures because of dbft library interface.
62 lines
1.5 KiB
Go
62 lines
1.5 KiB
Go
package payload
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/core/block"
|
|
"github.com/nspcc-dev/neo-go/pkg/io"
|
|
)
|
|
|
|
// Headers payload.
|
|
type Headers struct {
|
|
Hdrs []*block.Header
|
|
// StateRootInHeader specifies whether header contains state root.
|
|
StateRootInHeader bool
|
|
}
|
|
|
|
// Users can at most request 2k header.
|
|
const (
|
|
MaxHeadersAllowed = 2000
|
|
)
|
|
|
|
// ErrTooManyHeaders is an error returned when too many headers were received.
|
|
var ErrTooManyHeaders = fmt.Errorf("too many headers were received (max: %d)", MaxHeadersAllowed)
|
|
|
|
// ErrNoHeaders is returned for zero-elements Headers payload which is considered to be invalid.
|
|
var ErrNoHeaders = errors.New("no headers (zero length array)")
|
|
|
|
// DecodeBinary implements Serializable interface.
|
|
func (p *Headers) DecodeBinary(br *io.BinReader) {
|
|
lenHeaders := br.ReadVarUint()
|
|
|
|
if br.Err == nil && lenHeaders == 0 {
|
|
br.Err = ErrNoHeaders
|
|
return
|
|
}
|
|
|
|
var limitExceeded bool
|
|
|
|
// C# node does it silently
|
|
if limitExceeded = lenHeaders > MaxHeadersAllowed; limitExceeded {
|
|
lenHeaders = MaxHeadersAllowed
|
|
}
|
|
|
|
p.Hdrs = make([]*block.Header, lenHeaders)
|
|
|
|
for i := 0; i < int(lenHeaders); i++ {
|
|
header := &block.Header{}
|
|
header.StateRootEnabled = p.StateRootInHeader
|
|
header.DecodeBinary(br)
|
|
p.Hdrs[i] = header
|
|
}
|
|
|
|
if br.Err == nil && limitExceeded {
|
|
br.Err = ErrTooManyHeaders
|
|
}
|
|
}
|
|
|
|
// EncodeBinary implements Serializable interface.
|
|
func (p *Headers) EncodeBinary(bw *io.BinWriter) {
|
|
bw.WriteArray(p.Hdrs)
|
|
}
|