-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_tools.go
96 lines (67 loc) · 1.65 KB
/
test_tools.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
package ecdaa
import (
"github.com/akakou-fork/amcl-go/miracl/core"
"github.com/akakou/ecdaa/tpm_utils"
)
func testIssuer(rng *core.RAND) (*Issuer, error) {
issuer := RandomIssuer(rng)
err := VerifyIPK(&issuer.Ipk)
return &issuer, err
}
func ExampleInitialize(rng *core.RAND) (*Issuer, *SWSigner, error) {
issuer, err := testIssuer(rng)
if err != nil {
return nil, nil, err
}
seed, issuerB, err := GenJoinSeed(rng)
if err != nil {
return nil, nil, err
}
req, sk, err := GenJoinReq(seed, rng)
if err != nil {
return nil, nil, err
}
err = VerifyJoinReq(req, seed, issuerB)
if err != nil {
return nil, nil, err
}
cred, err := issuer.MakeCred(req, issuerB, rng)
if err != nil {
return nil, nil, err
}
err = VerifyCred(cred, &issuer.Ipk)
if err != nil {
return nil, nil, err
}
randCred := RandomizeCred(cred, rng)
err = VerifyCred(randCred, &issuer.Ipk)
if err != nil {
return nil, nil, err
}
signer := NewSWSigner(cred, sk)
return issuer, &signer, nil
}
func ExampleTPMInitialize(tpm *tpm_utils.TPM, rng *core.RAND) (*Issuer, *TPMSigner, error) {
issuer, err := testIssuer(rng)
if err != nil {
return nil, nil, err
}
seed, issuerB, err := GenJoinSeed(rng)
if err != nil {
return nil, nil, err
}
req, handle, err := GenJoinReqWithTPM(seed, tpm, rng)
if err != nil {
return nil, nil, err
}
cipherCred, _, err := issuer.MakeCredEncrypted(req, issuerB, rng)
if err != nil {
return nil, nil, err
}
cred, err := ActivateCredential(cipherCred, issuerB, req.JoinReq.Q, &issuer.Ipk, handle, tpm)
if err != nil {
return nil, nil, err
}
signer := NewTPMSigner(cred, handle, tpm)
return issuer, &signer, nil
}