-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathserver.go
88 lines (76 loc) · 1.93 KB
/
server.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
package disco
import (
"encoding/json"
"errors"
"fmt"
"net/url"
"os"
"slices"
"time"
)
type Server struct {
Secret SecretStore
URL string
}
func NewServer(serverURL string, store SecretStore) (*Server, error) {
if store == nil {
return nil, errors.New("secret store is required")
}
server, err := url.Parse(serverURL)
if err != nil {
return nil, err
}
if !slices.Contains([]string{"https", "wss", "http", "ws"}, server.Scheme) {
return nil, fmt.Errorf("unsupport server protocol: %s", server.String())
}
return &Server{
Secret: store,
URL: serverURL,
}, nil
}
type SecretStore interface {
NetworkSecret() (NetworkSecret, error)
UpdateNetworkSecret(NetworkSecret) error
}
type NetworkSecret struct {
Secret string `json:"secret"`
Network string `json:"network"`
Expire time.Time `json:"expire"`
}
func (s NetworkSecret) Expired() bool {
return time.Until(s.Expire) <= 0
}
func (s *NetworkSecret) NetworkSecret() (NetworkSecret, error) {
return *s, nil
}
func (s *NetworkSecret) UpdateNetworkSecret(secret NetworkSecret) error {
s.Secret = secret.Secret
s.Network = secret.Network
s.Expire = secret.Expire
return nil
}
type SecretFile struct {
FilePath string
}
func (s *SecretFile) NetworkSecret() (NetworkSecret, error) {
f, err := os.Open(s.FilePath)
if err != nil {
return NetworkSecret{}, fmt.Errorf("file secret store(%s) open failed: %s", s.FilePath, err)
}
defer f.Close()
var secret NetworkSecret
if err = json.NewDecoder(f).Decode(&secret); err != nil {
return secret, fmt.Errorf("file secret store(%s) decode failed: %w", s.FilePath, err)
}
return secret, nil
}
func (s *SecretFile) UpdateNetworkSecret(secret NetworkSecret) error {
f, err := os.Create(s.FilePath)
if err != nil {
return fmt.Errorf("update network secret failed: %w", err)
}
if err := json.NewEncoder(f).Encode(secret); err != nil {
return fmt.Errorf("save network secret failed: %w", err)
}
return f.Close()
}