-
Notifications
You must be signed in to change notification settings - Fork 124
/
Copy pathprovider.go
74 lines (63 loc) · 1.94 KB
/
provider.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
// Copyright (C) 2024, Ava Labs, Inc. All rights reserved.
// See the file LICENSE for licensing terms.
package auth
import (
"errors"
"fmt"
"os"
)
var (
ErrAlreadyRegisteredKeyType = errors.New("already registered key type")
ErrInvalidPrivateKeySize = errors.New("invalid private key size")
)
// WithDefaultPrivateKeyFactories registers the default PrivateKeyFactories
func WithDefaultPrivateKeyFactories(authProvider *AuthProvider) error {
return errors.Join(
authProvider.Register(ED25519Key, NewED25519PrivateKeyFactory()),
authProvider.Register(Secp256r1Key, NewSECP256R1PrivateKeyFactory()),
authProvider.Register(BLSKey, NewBLSPrivateKeyFactory()),
)
}
// AuthProvider stores the used PrivateKeys types
type AuthProvider struct {
keys map[string]PrivateKeyFactory
}
func NewAuthProvider() *AuthProvider {
return &AuthProvider{
keys: make(map[string]PrivateKeyFactory),
}
}
func (p *AuthProvider) Register(key string, privateKeyProvider PrivateKeyFactory) error {
if _, ok := p.keys[key]; ok {
return fmt.Errorf("%w: %s", ErrAlreadyRegisteredKeyType, key)
}
p.keys[key] = privateKeyProvider
return nil
}
func (p *AuthProvider) CheckType(key string) error {
if _, ok := p.keys[key]; ok {
return nil
}
return fmt.Errorf("%w: %s", ErrInvalidKeyType, key)
}
func (p *AuthProvider) GeneratePrivateKey(key string) (*PrivateKey, error) {
if privateKeyFactory, ok := p.keys[key]; ok {
return privateKeyFactory.GeneratePrivateKey()
}
return nil, fmt.Errorf("%w: %s", ErrInvalidKeyType, key)
}
func (p *AuthProvider) LoadPrivateKey(key, path string) (*PrivateKey, error) {
privateKeyFactory, ok := p.keys[key]
if !ok {
return nil, fmt.Errorf("%w: %s", ErrInvalidKeyType, key)
}
privateKey, err := os.ReadFile(path)
if err != nil {
return nil, err
}
return privateKeyFactory.LoadPrivateKey(privateKey)
}
type PrivateKeyFactory interface {
GeneratePrivateKey() (*PrivateKey, error)
LoadPrivateKey(p []byte) (*PrivateKey, error)
}