forked from kirsch33/realip
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstate.go
78 lines (62 loc) · 1.41 KB
/
state.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
package realip
import (
"time"
"go.uber.org/zap"
)
type state struct {
Refreshed chan bool
done chan bool
logger *zap.Logger
}
func (state *state) Start(duration time.Duration, logger *zap.Logger) {
logger.Info("starting cidr refresh routine")
state.logger = logger
state.Refreshed = make(chan bool, 1)
state.done = make(chan bool, 1)
go func() {
ticker := time.NewTicker(duration)
defer ticker.Stop()
state.updateDynamicPresets()
for {
select {
case <-ticker.C:
err := state.updateDynamicPresets()
if err != nil {
logger.Error("cidr refresh failed", zap.Error(err))
}
state.Refreshed <- true
case <-state.done:
logger.Debug("cidr refresh stopped")
return
}
}
}()
}
func (state *state) Destruct() error {
state.logger.Debug("destorying realip state")
if state.done != nil {
close(state.done)
}
return nil
}
func (state *state) updateDynamicPresets() error {
// refresh presets
for name, p := range presetRegistry {
if p.Update != nil {
start := time.Now()
newRanges, err := p.Update()
if err != nil {
state.logger.Error("failed to update dynamic preset",
zap.String("name", name),
zap.Error(err))
} else {
p.Ranges = newRanges
state.logger.Info("refresh completed",
zap.String("name", name),
zap.Int("count", len(newRanges)),
zap.Float64("elapsed", time.Since(start).Seconds()))
}
}
}
return nil
}