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
|
package main
import (
"flag"
"os"
"crypto/sha256"
"io/ioutil"
"github.com/golang/glog"
"github.com/google/certificate-transparency-go/tls"
"github.com/system-transparency/stfe"
)
var (
name = flag.String("name", "foobar-1.2.3", "a package identifier")
dir = flag.String("dir", "stitem", "directory path where output is stored")
)
func main() {
flag.Parse()
// Use H(name) as a dummy checksum
hasher := sha256.New()
hasher.Write([]byte(*name))
checksum := hasher.Sum(nil)
// Create and serialize an StItem of type checksum_v1
item := stfe.NewChecksumV1([]byte(*name), checksum)
serialized, err := tls.Marshal(item)
if err != nil {
glog.Fatalf("tls marshal failed: %v", err)
}
// Store the serialized item in *dir/name
if err := os.MkdirAll(*dir, 0755); err != nil {
glog.Fatalf("creating directory %s failed: %v", *dir, err)
}
path := *dir + "/" + *name
if err := ioutil.WriteFile(path, serialized, 0644); err != nil {
glog.Fatalf("writing to %s failed: %v", path, err)
}
glog.Infof("Created serialized checksum_v1 StItem: %s", path)
glog.Flush()
}
|