-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
main.go
58 lines (49 loc) · 1.19 KB
/
main.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
package main
import (
"context"
"fmt"
"log"
"time"
"github.com/keys-pub/keys"
"github.com/keys-pub/keys/api"
"github.com/keys-pub/keys/tsutil"
"github.com/keys-pub/vault"
"github.com/keys-pub/vault/auth"
"github.com/keys-pub/vault/client"
"github.com/pkg/errors"
)
func main() {
logger := vault.NewLogger(vault.DebugLevel)
vault.SetLogger(logger)
client.SetLogger(logger)
auth, err := auth.NewDB("/tmp/auth.db")
if err != nil {
log.Fatal(err)
}
defer auth.Close()
vlt, err := vault.New("/tmp/vault.db", auth)
if err != nil {
log.Fatal(err)
}
if _, err := vlt.UnlockWithPassword("testpassword"); err != nil {
log.Fatal(errors.Wrapf(err, "failed to open vault"))
}
defer vlt.Lock()
test := api.NewKey(keys.GenerateEdX25519Key()).WithLabels("test").Created(tsutil.NowMillis())
if err := vlt.Keyring().Set(test); err != nil {
log.Fatal(err)
}
start := time.Now()
err = vlt.Keyring().Sync(context.TODO())
if err != nil {
log.Fatal(err)
}
fmt.Printf("Sync took %s\n", time.Since(start))
ks, err := vlt.Keyring().Keys()
if err != nil {
log.Fatal(err)
}
for _, key := range ks {
fmt.Printf("%s %s %s\n", key.ID, tsutil.ParseMillis(key.CreatedAt), key.Labels)
}
}