-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathnode.go
More file actions
104 lines (89 loc) · 2 KB
/
Copy pathnode.go
File metadata and controls
104 lines (89 loc) · 2 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
package PromethoniXTrie
import (
"bytes"
"io"
)
// Data stores raw trie payload bytes.
type Data []byte
// Hash stores trie node hashes and user keys.
type Hash []byte
// Route stores nibble-expanded key paths used while traversing the trie.
type Route Hash
// NodeType identifies the concrete trie node kind.
type NodeType int8
const (
_ NodeType = iota
// Extension represents an extension node.
Extension
// Leaf represents a leaf node.
Leaf
// Branch represents a branch node.
Branch
)
// Node is implemented by all trie node types.
type Node interface {
Type() NodeType
Encode(io.Writer) error
Decode(io.Reader) error
NextRoute(Route) (Hash, Route, error)
Details() *NodeDetails
EncodeAndHash() error
}
// NodeDetails stores encoded node data and its calculated hash.
type NodeDetails struct {
_node Node
Hash Hash
EncodedData Data
}
// EncodeNode serializes a node with its node type prefix.
func EncodeNode(node Node) (Data, error) {
buf := bytes.Buffer{}
err := writeNodeType(&buf, node.Type())
if err == nil {
err = node.Encode(&buf)
}
return buf.Bytes(), err
}
// DecodeNode deserializes raw node data into the matching concrete node type.
func DecodeNode(raw Data) (Node, error) {
reader := bytes.NewReader(raw)
typ, err := readNodeType(reader)
if err != nil {
return nil, err
}
var node Node = nil
switch typ {
case Branch:
node = NewBranchNode()
err = node.Decode(reader)
case Leaf:
node = NewLeafNode()
err = node.Decode(reader)
case Extension:
node = NewExtensionNode()
err = node.Decode(reader)
default:
err = ErrInvalidNodeType
}
if err == nil {
node.Details().EncodedData = raw
node.Details().Hash, err = sha3Hash(raw)
}
return node, err
}
func (details *NodeDetails) Details() *NodeDetails {
return details
}
func (details *NodeDetails) EncodeAndHash() error {
b, err := EncodeNode(details._node)
if err != nil {
return err
}
details.EncodedData = b
h, err := sha3Hash(b)
if err != nil {
return err
}
details.Hash = h
return nil
}