-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathitem.go
90 lines (72 loc) · 1.42 KB
/
item.go
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
package raft
import (
"crypto/md5"
"encoding/hex"
"encoding/json"
"sync"
"capnproto.org/go/capnp/v3"
"github.com/mikelsr/raft-capnp/proto/api"
)
type Item struct {
Key []byte `json:"key,omitempty"`
Value []byte `json:"value,omitempty"`
}
func (i Item) Marshal() ([]byte, error) {
return json.Marshal(i)
}
func (i *Item) Unmarshal(data []byte) error {
return json.Unmarshal(data, i)
}
func ItemFromApi(i api.Item) (Item, error) {
var item Item
k, err := i.Key()
if err != nil {
return item, err
}
kBuf := make([]byte, len(k))
copy(kBuf, k)
item.Key = kBuf
v, err := i.Value()
if err != nil {
return item, err
}
vBuf := make([]byte, len(v))
copy(vBuf, v)
item.Value = v
return item, nil
}
func ItemToApi(i Item) (api.Item, error) {
var item api.Item
var err error
_, seg, err := capnp.NewMessage(capnp.SingleSegment(nil))
if err != nil {
return item, err
}
item, err = api.NewItem(seg)
if err != nil {
return item, err
}
if err = item.SetKey(i.Key); err != nil {
return item, err
}
err = item.SetValue(i.Value)
return item, err
}
type ItemMap struct {
sync.Map
}
func (i *ItemMap) Put(item Item) {
sum := md5.Sum(item.Key)
k := hex.EncodeToString(sum[:])
i.Map.Store(k, item)
}
func (i *ItemMap) Get(key []byte) (Item, bool) {
sum := md5.Sum(key)
k := hex.EncodeToString(sum[:])
v, found := i.Map.Load(k)
if !found {
return Item{}, found
}
item, ok := v.(Item)
return item, ok
}