|
|
|
@ -13,6 +13,7 @@ import ( |
|
|
|
|
|
|
|
|
|
var _ = (*headerMarshaling)(nil) |
|
|
|
|
|
|
|
|
|
// MarshalJSON marshals as JSON.
|
|
|
|
|
func (h Header) MarshalJSON() ([]byte, error) { |
|
|
|
|
type Header struct { |
|
|
|
|
ParentHash common.Hash `json:"parentHash" gencodec:"required"` |
|
|
|
@ -28,8 +29,8 @@ func (h Header) MarshalJSON() ([]byte, error) { |
|
|
|
|
GasUsed hexutil.Uint64 `json:"gasUsed" gencodec:"required"` |
|
|
|
|
Time *hexutil.Big `json:"timestamp" gencodec:"required"` |
|
|
|
|
Extra hexutil.Bytes `json:"extraData" gencodec:"required"` |
|
|
|
|
MixDigest common.Hash `json:"mixHash" gencodec:"required"` |
|
|
|
|
Nonce BlockNonce `json:"nonce" gencodec:"required"` |
|
|
|
|
MixDigest common.Hash `json:"mixHash"` |
|
|
|
|
Nonce BlockNonce `json:"nonce"` |
|
|
|
|
Hash common.Hash `json:"hash"` |
|
|
|
|
} |
|
|
|
|
var enc Header |
|
|
|
@ -52,6 +53,7 @@ func (h Header) MarshalJSON() ([]byte, error) { |
|
|
|
|
return json.Marshal(&enc) |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// UnmarshalJSON unmarshals from JSON.
|
|
|
|
|
func (h *Header) UnmarshalJSON(input []byte) error { |
|
|
|
|
type Header struct { |
|
|
|
|
ParentHash *common.Hash `json:"parentHash" gencodec:"required"` |
|
|
|
@ -67,8 +69,8 @@ func (h *Header) UnmarshalJSON(input []byte) error { |
|
|
|
|
GasUsed *hexutil.Uint64 `json:"gasUsed" gencodec:"required"` |
|
|
|
|
Time *hexutil.Big `json:"timestamp" gencodec:"required"` |
|
|
|
|
Extra *hexutil.Bytes `json:"extraData" gencodec:"required"` |
|
|
|
|
MixDigest *common.Hash `json:"mixHash" gencodec:"required"` |
|
|
|
|
Nonce *BlockNonce `json:"nonce" gencodec:"required"` |
|
|
|
|
MixDigest *common.Hash `json:"mixHash"` |
|
|
|
|
Nonce *BlockNonce `json:"nonce"` |
|
|
|
|
} |
|
|
|
|
var dec Header |
|
|
|
|
if err := json.Unmarshal(input, &dec); err != nil { |
|
|
|
@ -126,13 +128,11 @@ func (h *Header) UnmarshalJSON(input []byte) error { |
|
|
|
|
return errors.New("missing required field 'extraData' for Header") |
|
|
|
|
} |
|
|
|
|
h.Extra = *dec.Extra |
|
|
|
|
if dec.MixDigest == nil { |
|
|
|
|
return errors.New("missing required field 'mixHash' for Header") |
|
|
|
|
if dec.MixDigest != nil { |
|
|
|
|
h.MixDigest = *dec.MixDigest |
|
|
|
|
} |
|
|
|
|
h.MixDigest = *dec.MixDigest |
|
|
|
|
if dec.Nonce == nil { |
|
|
|
|
return errors.New("missing required field 'nonce' for Header") |
|
|
|
|
if dec.Nonce != nil { |
|
|
|
|
h.Nonce = *dec.Nonce |
|
|
|
|
} |
|
|
|
|
h.Nonce = *dec.Nonce |
|
|
|
|
return nil |
|
|
|
|
} |
|
|
|
|