-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathserver.go
103 lines (90 loc) · 2.43 KB
/
server.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
91
92
93
94
95
96
97
98
99
100
101
102
103
package main
import (
"context"
"fmt"
"log"
"github.com/google/trillian"
"github.com/google/trillian/merkle/rfc6962"
"google.golang.org/grpc/codes"
)
type server struct {
client trillian.TrillianLogClient
logID int64
}
func newServer(client trillian.TrillianLogClient, logID int64) *server {
log.Println("[server] Creating")
return &server{
client: client,
logID: logID,
}
}
func (s *server) put(r *Request) (*Response, error) {
log.Println("[server:put] Entered")
// Marshal a Thing (actually just 'name' which is a string) into []byte
// Eventually we'll marshal a more interesting data structure
leafValue, err := r.thing.Marshal()
if err != nil {
log.Fatal(err)
}
// Marshal an Extra (again)
extraData, err := r.extra.Marshal()
if err != nil {
log.Fatal(err)
}
leaf := &trillian.LogLeaf{
LeafValue: leafValue,
ExtraData: extraData,
}
rqst := &trillian.QueueLeafRequest{
LogId: s.logID,
Leaf: leaf,
}
resp, err := s.client.QueueLeaf(context.Background(), rqst)
if err != nil {
log.Fatal(err)
}
c := codes.Code(resp.QueuedLeaf.GetStatus().GetCode())
if c != codes.OK && c != codes.AlreadyExists {
return &Response{}, fmt.Errorf("[server:put] Bad status: %v", resp.QueuedLeaf.GetStatus())
}
if c == codes.OK {
log.Println("[server:put] ok")
} else if c == codes.AlreadyExists {
log.Printf("[server:put] %s already Exists", leafValue)
}
return &Response{
status: "ok",
}, nil
}
func (s *server) get(r *Request) (*Response, error) {
log.Println("[server:get] Entered")
// Marshal a Thing (actually just 'name' which is a string) into []byte
// Eventually we'll marshal a more interesting data structure
leafValue, err := r.thing.Marshal()
if err != nil {
log.Fatal(err)
}
// Trillian uses its own (rfc6962) hasher
hasher := rfc6962.DefaultHasher
leafHash := hasher.HashLeaf(leafValue)
// Output the hashed value (conventionally hex is used)
log.Printf("[server:get] hash: %x\n", leafHash)
// Create the request
rqst := &trillian.GetLeavesByHashRequest{
LogId: s.logID,
LeafHash: [][]byte{leafHash},
}
// Submit the request to the Trillian Log Server
resp, err := s.client.GetLeavesByHash(context.Background(), rqst)
if err != nil {
log.Fatal(err)
}
// Iterate over the responses; there should be 0 or 1
for i, logLeaf := range resp.GetLeaves() {
leafValue := logLeaf.GetLeafValue()
log.Printf("[server:get] %d: %s", i, leafValue)
}
return &Response{
status: "ok",
}, nil
}