Compare commits

..

No commits in common. "2da7c8a4c1eceacdc086cea2a996b427696fa679" and "b5406b1451e62c90e7fe3b85b3ff61019605526b" have entirely different histories.

View File

@ -1,7 +1,6 @@
package sse package sse
import ( import (
"gitea.bvbej.com/bvbej/base-golang/pkg/mux"
"github.com/gin-gonic/gin" "github.com/gin-gonic/gin"
"io" "io"
"net/http" "net/http"
@ -12,14 +11,13 @@ import (
var _ Server = (*event)(nil) var _ Server = (*event)(nil)
type Server interface { type Server interface {
GinHandle(ctx *gin.Context, user any) HandlerFunc(auth func(c *gin.Context) (string, error)) gin.HandlerFunc
HandlerFunc() mux.HandlerFunc
Push(user, name, msg string) bool Push(user, name, msg string) bool
Broadcast(name, msg string) Broadcast(name, msg string)
} }
type clientChan struct { type clientChan struct {
User any User string
Chan chan msgChan Chan chan msgChan
} }
@ -33,7 +31,7 @@ type event struct {
Count atomic.Int32 Count atomic.Int32
Register chan clientChan Register chan clientChan
Unregister chan any Unregister chan string
} }
func NewServer() Server { func NewServer() Server {
@ -41,7 +39,7 @@ func NewServer() Server {
SessionList: sync.Map{}, SessionList: sync.Map{},
Count: atomic.Int32{}, Count: atomic.Int32{},
Register: make(chan clientChan), Register: make(chan clientChan),
Unregister: make(chan any), Unregister: make(chan string),
} }
go e.listen() go e.listen()
@ -67,40 +65,38 @@ func (stream *event) listen() {
} }
} }
func (stream *event) GinHandle(ctx *gin.Context, user any) { func (stream *event) HandlerFunc(auth func(c *gin.Context) (string, error)) gin.HandlerFunc {
if user == nil { return func(c *gin.Context) {
ctx.AbortWithStatus(http.StatusUnauthorized) user, err := auth(c)
return if err != nil {
} c.AbortWithStatus(http.StatusBadRequest)
e := make(chan msgChan) return
client := clientChan{
User: user,
Chan: e,
}
stream.Register <- client
defer func() {
stream.Unregister <- user
}()
ctx.Writer.Header().Set("Content-Type", "text/event-stream")
ctx.Writer.Header().Set("Cache-Control", "no-cache")
ctx.Writer.Header().Set("Connection", "keep-alive")
ctx.Writer.Header().Set("Transfer-Encoding", "chunked")
ctx.Stream(func(w io.Writer) bool {
if msg, ok := <-e; ok {
ctx.SSEvent(msg.Name, msg.Message)
return true
} }
return false
})
ctx.Next() e := make(chan msgChan)
} client := clientChan{
User: user,
Chan: e,
}
stream.Register <- client
defer func() {
stream.Unregister <- user
}()
func (stream *event) HandlerFunc() mux.HandlerFunc { c.Writer.Header().Set("Content-Type", "text/event-stream")
return func(c mux.Context) { c.Writer.Header().Set("Cache-Control", "no-cache")
stream.GinHandle(c.Context(), c.Auth()) c.Writer.Header().Set("Connection", "keep-alive")
c.Writer.Header().Set("Transfer-Encoding", "chunked")
c.Stream(func(w io.Writer) bool {
if msg, ok := <-e; ok {
c.SSEvent(msg.Name, msg.Message)
return true
}
return false
})
c.Next()
} }
} }