This repository has been archived by the owner on Nov 11, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
subscription.go
107 lines (92 loc) · 2.65 KB
/
subscription.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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
package kv
import (
"bytes"
)
type SubscriptionManager struct {
keySubscribers map[string][]int64
prefixSubscribers map[string][]int64
hub *Hub
}
func makeSubscriptionManager() *SubscriptionManager {
return &SubscriptionManager{
keySubscribers: make(map[string][]int64),
prefixSubscribers: make(map[string][]int64),
}
}
func (s *SubscriptionManager) SubscribeKey(uid int64, key string) {
s.keySubscribers[key] = append(s.keySubscribers[key], uid)
}
func (s *SubscriptionManager) SubscribePrefix(uid int64, prefix string) {
s.prefixSubscribers[prefix] = append(s.prefixSubscribers[prefix], uid)
}
func (s *SubscriptionManager) UnsubscribeKey(uid int64, key string) {
subscribers := s.keySubscribers[key]
for i, subscriber := range subscribers {
if subscriber == uid {
s.keySubscribers[key] = append(subscribers[:i], subscribers[i+1:]...)
break
}
}
}
func (s *SubscriptionManager) UnsubscribePrefix(uid int64, prefix string) {
subscribers := s.prefixSubscribers[prefix]
for i, subscriber := range subscribers {
if subscriber == uid {
s.prefixSubscribers[prefix] = append(subscribers[:i], subscribers[i+1:]...)
break
}
}
}
func (s *SubscriptionManager) UnsubscribeAll(uid int64) {
for key, subscribers := range s.keySubscribers {
for i, subscriber := range subscribers {
if subscriber == uid {
s.keySubscribers[key] = append(subscribers[:i], subscribers[i+1:]...)
break
}
}
}
for prefix, subscribers := range s.prefixSubscribers {
for i, subscriber := range subscribers {
if subscriber == uid {
s.prefixSubscribers[prefix] = append(subscribers[:i], subscribers[i+1:]...)
break
}
}
}
}
func (s *SubscriptionManager) GetSubscribers(key string) []int64 {
subscribers := make(map[int64]bool)
// Get subscribers for key
if keySubscribers, ok := s.keySubscribers[key]; ok {
for _, subscriber := range keySubscribers {
subscribers[subscriber] = true
}
}
// Get subscribers for prefix
for prefix, prefixSubscribers := range s.prefixSubscribers {
if bytes.HasPrefix([]byte(key), []byte(prefix)) {
for _, subscriber := range prefixSubscribers {
subscribers[subscriber] = true
}
}
}
// Convert to array
result := []int64{}
for subscriber := range subscribers {
result = append(result, subscriber)
}
return result
}
func (s *SubscriptionManager) KeyChanged(key string, value string) {
// Notify subscribers
clients := s.GetSubscribers(key)
for _, clientID := range clients {
client, ok := s.hub.clients.GetByID(clientID)
if ok {
options := client.Options()
msg, _ := json.Marshal(Push{"push", key[len(options.Namespace):], value})
client.SendMessage(msg)
}
}
}