This repository has been archived by the owner on Nov 14, 2018. It is now read-only.
/
signatures_mock.go
60 lines (50 loc) · 1.68 KB
/
signatures_mock.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
package crypto
import (
"bytes"
"crypto/rand"
"io"
"golang.org/x/crypto/ed25519"
)
type (
// keyDeriver contains all of the dependencies for a signature key
// generator. The dependencies are separated to enable mocking.
keyDeriver interface {
deriveKeyPair([EntropySize]byte) (SecretKey, PublicKey)
}
)
var (
// stdKeyGen is a signature generator that can be used to generate random
// and deterministic keys for signing objects.
stdKeyGen = sigKeyGen{entropySource: rand.Reader, keyDeriver: &stdKeyDeriver{}}
)
// sigKeyGen contains a set of dependencies that are used to build out the core
// logic for generating keys in Sia.
type sigKeyGen struct {
entropySource io.Reader
keyDeriver keyDeriver
}
// generate builds a signature keypair using a sigKeyGen to manage
// dependencies.
func (skg sigKeyGen) generate() (sk SecretKey, pk PublicKey, err error) {
var entropy [EntropySize]byte
_, err = io.ReadFull(skg.entropySource, entropy[:])
if err != nil {
return
}
skPointer, pkPointer := skg.keyDeriver.deriveKeyPair(entropy)
return skPointer, pkPointer, nil
}
// generateDeterministic builds a signature keypair deterministically using a
// sigKeyGen to manage dependencies.
func (skg sigKeyGen) generateDeterministic(entropy [EntropySize]byte) (SecretKey, PublicKey) {
skPointer, pkPointer := skg.keyDeriver.deriveKeyPair(entropy)
return skPointer, pkPointer
}
// stdKeyDeriver implements the keyDeriver dependency for the sigKeyGen.
type stdKeyDeriver struct{}
func (skd *stdKeyDeriver) deriveKeyPair(entropy [EntropySize]byte) (sk SecretKey, pk PublicKey) {
epk, esk, _ := ed25519.GenerateKey(bytes.NewReader(entropy[:]))
copy(pk[:], epk[:])
copy(sk[:], esk[:])
return
}