-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathclient_data.go
86 lines (73 loc) · 1.53 KB
/
client_data.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
package growthbook
import (
"net/http"
"sync"
"time"
"github.com/growthbook/growthbook-golang/internal/condition"
)
type data struct {
mu sync.RWMutex
features FeatureMap
savedGroups condition.SavedGroups
dateUpdated time.Time
apiHost string
clientKey string
decryptionKey string
httpClient *http.Client
dataSource DataSource
dsStarted bool
dsStartWait chan struct{}
dsStartErr error
}
func newData() *data {
return &data{
dsStartWait: make(chan struct{}),
apiHost: defaultApiHost,
httpClient: http.DefaultClient,
}
}
func (d *data) getDateUpdated() time.Time {
d.mu.RLock()
defer d.mu.RUnlock()
return d.dateUpdated
}
func (d *data) getFeatures() FeatureMap {
d.mu.RLock()
defer d.mu.RUnlock()
return d.features
}
func (d *data) getApiUrl() string {
d.mu.RLock()
defer d.mu.RUnlock()
return d.apiHost + "/api/features/" + d.clientKey
}
func (d *data) getSseUrl() string {
d.mu.RLock()
defer d.mu.RUnlock()
return d.apiHost + "/sub/" + d.clientKey
}
func (d *data) getDsStartErr() error {
d.mu.RLock()
defer d.mu.RUnlock()
return d.dsStartErr
}
func (d *data) getDsStarted() bool {
d.mu.RLock()
defer d.mu.RUnlock()
return d.dsStarted
}
type dataUpdate func(*data) error
func (d *data) withLock(f dataUpdate) error {
d.mu.Lock()
defer d.mu.Unlock()
return f(d)
}
func (d *data) decrypt(encrypted string) (string, error) {
d.mu.RLock()
key := d.decryptionKey
d.mu.RUnlock()
if key == "" {
return "", ErrNoDecryptionKey
}
return decrypt(encrypted, key)
}