-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathevents.go
81 lines (68 loc) · 2.63 KB
/
events.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
/*
Copyright 2016 The Smudge Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package smudge
import "sync"
var broadcastListeners = struct {
sync.RWMutex
s []BroadcastListener
}{s: make([]BroadcastListener, 0, 16)}
var statusListeners = struct {
sync.RWMutex
s []StatusListener
}{s: make([]StatusListener, 0, 16)}
// BroadcastListener is the interface that must be implemented to take advantage
// of the cluster member status update notification functionality provided by
// the AddBroadcastListener() function.
type BroadcastListener interface {
// The OnBroadcast() function is called whenever the node is notified of
// an incoming broadcast message.
OnBroadcast(broadcast *Broadcast)
}
// AddBroadcastListener allows the submission of a BroadcastListener implementation
// whose OnChange() function will be called whenever the node is notified of any
// change in the status of a cluster member.
func AddBroadcastListener(listener BroadcastListener) {
broadcastListeners.Lock()
broadcastListeners.s = append(broadcastListeners.s, listener)
broadcastListeners.Unlock()
}
func doBroadcastUpdate(broadcast *Broadcast) {
broadcastListeners.RLock()
for _, sl := range broadcastListeners.s {
sl.OnBroadcast(broadcast)
}
broadcastListeners.RUnlock()
}
// StatusListener is the interface that must be implemented to take advantage
// of the cluster member status update notification functionality provided by
// the AddStatusListener() function.
type StatusListener interface {
// The OnChange() function is called whenever the node is notified of any
// change in the status of a cluster member.
OnChange(node *Node, status NodeStatus)
}
// AddStatusListener allows the submission of a StatusListener implementation
// whose OnChange() function will be called whenever the node is notified of any
// change in the status of a cluster member.
func AddStatusListener(listener StatusListener) {
statusListeners.Lock()
statusListeners.s = append(statusListeners.s, listener)
statusListeners.Unlock()
}
func doStatusUpdate(node *Node, status NodeStatus) {
statusListeners.RLock()
for _, sl := range statusListeners.s {
sl.OnChange(node, status)
}
statusListeners.RUnlock()
}