|
@ -12,8 +12,9 @@ type hub struct { |
|
|
exit chan *envelope |
|
|
exit chan *envelope |
|
|
open bool |
|
|
open bool |
|
|
rwmutex *sync.RWMutex |
|
|
rwmutex *sync.RWMutex |
|
|
|
|
|
|
|
|
// extends
|
|
|
// extends
|
|
|
channels map[string]*Session |
|
|
|
|
|
|
|
|
channels map[string]*Channel |
|
|
subscribe chan *Session |
|
|
subscribe chan *Session |
|
|
publish chan *envelope |
|
|
publish chan *envelope |
|
|
unsubscribe chan *Session |
|
|
unsubscribe chan *Session |
|
@ -29,7 +30,7 @@ func newHub() *hub { |
|
|
open: true, |
|
|
open: true, |
|
|
rwmutex: &sync.RWMutex{}, |
|
|
rwmutex: &sync.RWMutex{}, |
|
|
// extends
|
|
|
// extends
|
|
|
channels: make(map[string]*Session), |
|
|
|
|
|
|
|
|
channels: make(map[string]*Channel), |
|
|
subscribe: make(chan *Session), |
|
|
subscribe: make(chan *Session), |
|
|
publish: make(chan *envelope), |
|
|
publish: make(chan *envelope), |
|
|
unsubscribe: make(chan *Session), |
|
|
unsubscribe: make(chan *Session), |
|
@ -77,12 +78,17 @@ loop: |
|
|
// extends
|
|
|
// extends
|
|
|
h.rwmutex.Lock() |
|
|
h.rwmutex.Lock() |
|
|
if _, ok := h.channels[s.channel]; !ok { |
|
|
if _, ok := h.channels[s.channel]; !ok { |
|
|
h.channels[s.channel] = s |
|
|
|
|
|
|
|
|
h.channels[s.channel] = &Channel{ |
|
|
|
|
|
session: s, |
|
|
|
|
|
online: 1, |
|
|
|
|
|
name: s.channel, |
|
|
|
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
h.channels[s.channel].prev = s // 原来的上一个指向现在的
|
|
|
|
|
|
s.next = h.channels[s.channel] // 现在的下一个是原来的
|
|
|
|
|
|
s.prev = nil // 成为队头
|
|
|
|
|
|
h.channels[s.channel] = s // 现在的替代原来的位置
|
|
|
|
|
|
|
|
|
h.channels[s.channel].session.prev = s // 原来的上一个指向现在的
|
|
|
|
|
|
s.next = h.channels[s.channel].session // 现在的下一个是原来的
|
|
|
|
|
|
s.prev = nil // 成为队头
|
|
|
|
|
|
h.channels[s.channel].session = s // 现在的替代原来的位置
|
|
|
|
|
|
h.channels[s.channel].online++ // 增加人数
|
|
|
} |
|
|
} |
|
|
h.rwmutex.Unlock() |
|
|
h.rwmutex.Unlock() |
|
|
case s := <-h.unsubscribe: |
|
|
case s := <-h.unsubscribe: |
|
@ -94,15 +100,16 @@ loop: |
|
|
if s.prev != nil { |
|
|
if s.prev != nil { |
|
|
s.prev.next = s.next |
|
|
s.prev.next = s.next |
|
|
} else { |
|
|
} else { |
|
|
h.channels[s.channel] = s.next |
|
|
|
|
|
|
|
|
h.channels[s.channel].session = s.next |
|
|
} |
|
|
} |
|
|
|
|
|
h.channels[s.channel].online-- |
|
|
s.channel = "" // 置空
|
|
|
s.channel = "" // 置空
|
|
|
h.rwmutex.Unlock() |
|
|
h.rwmutex.Unlock() |
|
|
} |
|
|
} |
|
|
case m := <-h.publish: |
|
|
case m := <-h.publish: |
|
|
h.rwmutex.RLock() |
|
|
h.rwmutex.RLock() |
|
|
if _, ok := h.channels[m.c]; ok { |
|
|
if _, ok := h.channels[m.c]; ok { |
|
|
for s := h.channels[m.c]; s != nil; s = s.next { |
|
|
|
|
|
|
|
|
for s := h.channels[m.c].session; s != nil; s = s.next { |
|
|
if m.filter != nil { |
|
|
if m.filter != nil { |
|
|
if m.filter(s) { |
|
|
if m.filter(s) { |
|
|
s.writeMessage(m) |
|
|
s.writeMessage(m) |
|
|