-
Notifications
You must be signed in to change notification settings - Fork 117
/
Copy pathcallback.go
67 lines (57 loc) · 1.54 KB
/
callback.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
package osdconfig
import (
"encoding/json"
"fmt"
"github.com/portworx/kvdb"
"github.com/sirupsen/logrus"
)
// execClusterCallbacks executes a registered cluster watcher
func (manager *configManager) execClusterCallbacks(f CallbackClusterConfigFunc, data *data) {
config := new(ClusterConfig)
if err := json.Unmarshal(data.Value, config); err != nil {
logrus.Error(err)
return
}
f(config)
}
// execNodeCallbacks executes a registered node watcher
func (manager *configManager) execNodeCallbacks(f CallbackNodeConfigFunc, data *data) {
config := new(NodeConfig)
if err := json.Unmarshal(data.Value, config); err != nil {
logrus.Error(err)
return
}
f(config)
}
// kvdbCallback is a callback to be registered with kvdb.
// this callback simply receives data from kvdb and reflects it on a channel it receives in opaque
func (manager *configManager) kvdbCallback(prefix string,
opaque interface{}, kvp *kvdb.KVPair, err error) error {
manager.Lock()
defer manager.Unlock()
c, ok := opaque.(*dataToKvdb)
if !ok {
return fmt.Errorf("opaque value type is incorrect")
}
x := new(data)
if kvp != nil {
x.Key = kvp.Key
x.Value = kvp.Value
}
x.Type = c.Type
switch c.Type {
case clusterWatcher:
for _, f := range manager.cbCluster {
go func(f1 CallbackClusterConfigFunc, wd *data) {
manager.execClusterCallbacks(f1, wd)
}(f, copyData(x))
}
case nodeWatcher:
for _, f := range manager.cbNode {
go func(f1 CallbackNodeConfigFunc, wd *data) {
manager.execNodeCallbacks(f1, wd)
}(f, copyData(x))
}
}
return nil
}