Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
0c9b20d47f | |||
1e33734ab1 | |||
0c6e90e644 | |||
3d5a4a1482 |
@ -17,6 +17,7 @@ type Server interface {
|
|||||||
GinHandlerFunc(auth func(c *gin.Context) (string, error)) gin.HandlerFunc
|
GinHandlerFunc(auth func(c *gin.Context) (string, error)) gin.HandlerFunc
|
||||||
Push(user any, name, msg string) bool
|
Push(user any, name, msg string) bool
|
||||||
Broadcast(name, msg string)
|
Broadcast(name, msg string)
|
||||||
|
ClientCount() int32
|
||||||
}
|
}
|
||||||
|
|
||||||
type clientChan struct {
|
type clientChan struct {
|
||||||
@ -90,6 +91,10 @@ func (stream *event) HandlerFunc() mux.HandlerFunc {
|
|||||||
c.Context().Writer.Header().Set("Connection", "keep-alive")
|
c.Context().Writer.Header().Set("Connection", "keep-alive")
|
||||||
c.Context().Writer.Header().Set("Transfer-Encoding", "chunked")
|
c.Context().Writer.Header().Set("Transfer-Encoding", "chunked")
|
||||||
|
|
||||||
|
time.AfterFunc(time.Second, func() {
|
||||||
|
e <- msgChan{Name: "message", Message: "success"}
|
||||||
|
})
|
||||||
|
|
||||||
c.Context().Stream(func(w io.Writer) bool {
|
c.Context().Stream(func(w io.Writer) bool {
|
||||||
if msg, ok := <-e; ok {
|
if msg, ok := <-e; ok {
|
||||||
c.Context().SSEvent(msg.Name, msg.Message)
|
c.Context().SSEvent(msg.Name, msg.Message)
|
||||||
@ -153,3 +158,7 @@ func (stream *event) Broadcast(name, msg string) {
|
|||||||
return true
|
return true
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (stream *event) ClientCount() int32 {
|
||||||
|
return stream.Count.Load()
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user